dsl-to-sql 1.0.0-fabric-1p-development.1
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.
- package/.turbo/turbo-build.log +9 -0
- package/.turbo/turbo-check-types.log +4 -0
- package/.turbo/turbo-lint.log +126 -0
- package/README.md +45 -0
- package/coverage/base.css +224 -0
- package/coverage/block-navigation.js +87 -0
- package/coverage/favicon.png +0 -0
- package/coverage/index.html +236 -0
- package/coverage/prettify.css +1 -0
- package/coverage/prettify.js +2 -0
- package/coverage/sort-arrow-sprite.png +0 -0
- package/coverage/sorter.js +210 -0
- package/coverage/src/constants.ts.html +826 -0
- package/coverage/src/database_types.ts.html +136 -0
- package/coverage/src/epm-query-builder/EpmQueryBuilder.ts.html +166 -0
- package/coverage/src/epm-query-builder/base/BaseAdvancedAggregations.ts.html +568 -0
- package/coverage/src/epm-query-builder/base/BaseAnalyticalFunctions.ts.html +694 -0
- package/coverage/src/epm-query-builder/base/BaseCTEGenerator.ts.html +1459 -0
- package/coverage/src/epm-query-builder/base/BaseCountQueryBuilder.ts.html +400 -0
- package/coverage/src/epm-query-builder/base/BaseMeasureBuilder.ts.html +295 -0
- package/coverage/src/epm-query-builder/base/BaseOrderBuilder.ts.html +670 -0
- package/coverage/src/epm-query-builder/base/BasePaginationBuilder.ts.html +364 -0
- package/coverage/src/epm-query-builder/base/BaseQueryBuilder.ts.html +238 -0
- package/coverage/src/epm-query-builder/base/BaseRollupBuilder.ts.html +532 -0
- package/coverage/src/epm-query-builder/base/BaseSqlBuilder.ts.html +601 -0
- package/coverage/src/epm-query-builder/base/BaseSuperFilterBuilder.ts.html +1966 -0
- package/coverage/src/epm-query-builder/base/BaseUtilities.ts.html +1798 -0
- package/coverage/src/epm-query-builder/base/ColumnRefUtils.ts.html +211 -0
- package/coverage/src/epm-query-builder/base/RelationshipResolver.ts.html +706 -0
- package/coverage/src/epm-query-builder/base/SharedFilterBuilder.ts.html +1717 -0
- package/coverage/src/epm-query-builder/base/index.html +326 -0
- package/coverage/src/epm-query-builder/constants/Aggregations.ts.html +133 -0
- package/coverage/src/epm-query-builder/constants/Database.ts.html +103 -0
- package/coverage/src/epm-query-builder/constants/Source.ts.html +106 -0
- package/coverage/src/epm-query-builder/constants/index.html +146 -0
- package/coverage/src/epm-query-builder/dialects/duckdb/DuckDbAdvancedAggregations.ts.html +286 -0
- package/coverage/src/epm-query-builder/dialects/duckdb/DuckDbJoinBuilder.ts.html +280 -0
- package/coverage/src/epm-query-builder/dialects/duckdb/DuckDbMeasureBuilder.ts.html +1924 -0
- package/coverage/src/epm-query-builder/dialects/duckdb/DuckDbOrderBuilder.ts.html +769 -0
- package/coverage/src/epm-query-builder/dialects/duckdb/DuckDbPaginationBuilder.ts.html +643 -0
- package/coverage/src/epm-query-builder/dialects/duckdb/DuckDbQueryBuilder.ts.html +2644 -0
- package/coverage/src/epm-query-builder/dialects/duckdb/DuckDbRollupBuilder.ts.html +478 -0
- package/coverage/src/epm-query-builder/dialects/duckdb/DuckDbSuperFilterBuilder.ts.html +1195 -0
- package/coverage/src/epm-query-builder/dialects/duckdb/index.html +221 -0
- package/coverage/src/epm-query-builder/errors/QueryBuilderErrors.ts.html +280 -0
- package/coverage/src/epm-query-builder/errors/index.html +116 -0
- package/coverage/src/epm-query-builder/index.html +116 -0
- package/coverage/src/epm-query-builder/interfaces/IDatabaseQueryBuilder.ts.html +100 -0
- package/coverage/src/epm-query-builder/interfaces/index.html +131 -0
- package/coverage/src/epm-query-builder/interfaces/index.ts.html +88 -0
- package/coverage/src/epm-query-builder/utils/format.ts.html +151 -0
- package/coverage/src/epm-query-builder/utils/index.html +146 -0
- package/coverage/src/epm-query-builder/utils/sql.ts.html +247 -0
- package/coverage/src/epm-query-builder/utils/validation.ts.html +124 -0
- package/coverage/src/epm-query-builder/validation/QueryOptionsValidator.ts.html +631 -0
- package/coverage/src/epm-query-builder/validation/SqlQueryValidator.ts.html +475 -0
- package/coverage/src/epm-query-builder/validation/index.html +131 -0
- package/coverage/src/filters/FilterConditionBuilder.ts.html +427 -0
- package/coverage/src/filters/filter-types.ts.html +484 -0
- package/coverage/src/filters/index.html +131 -0
- package/coverage/src/index.html +176 -0
- package/coverage/src/index.ts.html +103 -0
- package/coverage/src/js-lib/JsToSqlParser.ts.html +736 -0
- package/coverage/src/js-lib/ParseContext.ts.html +532 -0
- package/coverage/src/js-lib/db/azuresql/AzureSqlCallExpressionVisitor.ts.html +196 -0
- package/coverage/src/js-lib/db/azuresql/index.html +116 -0
- package/coverage/src/js-lib/db/base/ArrayExpressionVisitor.ts.html +133 -0
- package/coverage/src/js-lib/db/base/AssignmentExpressionVisitor.ts.html +187 -0
- package/coverage/src/js-lib/db/base/BinaryExpressionVisitor.ts.html +223 -0
- package/coverage/src/js-lib/db/base/CallExpressionVisitor.ts.html +5479 -0
- package/coverage/src/js-lib/db/base/IdentifierVisitor.ts.html +283 -0
- package/coverage/src/js-lib/db/base/LiteralVisitor.ts.html +199 -0
- package/coverage/src/js-lib/db/base/MemberExpressionVisitor.ts.html +193 -0
- package/coverage/src/js-lib/db/base/ProgramVisitor.ts.html +139 -0
- package/coverage/src/js-lib/db/base/UnaryExpressionVisitor.ts.html +181 -0
- package/coverage/src/js-lib/db/base/VisitorInterface.ts.html +103 -0
- package/coverage/src/js-lib/db/base/index.html +251 -0
- package/coverage/src/js-lib/db/bigquery/BigQueryCallExpressionVisitor.ts.html +1747 -0
- package/coverage/src/js-lib/db/bigquery/index.html +116 -0
- package/coverage/src/js-lib/db/commonTransforms.ts.html +2074 -0
- package/coverage/src/js-lib/db/databricks/DatabricksCallExpressionVisitor.ts.html +1303 -0
- package/coverage/src/js-lib/db/databricks/index.html +116 -0
- package/coverage/src/js-lib/db/fabricsql/FabricSqlCallExpressionVisitor.ts.html +196 -0
- package/coverage/src/js-lib/db/fabricsql/index.html +116 -0
- package/coverage/src/js-lib/db/fabricwarehouse/FabricWarehouseCallExpressionVisitor.ts.html +292 -0
- package/coverage/src/js-lib/db/fabricwarehouse/index.html +116 -0
- package/coverage/src/js-lib/db/index.html +116 -0
- package/coverage/src/js-lib/db/postgresql/PostgreSqlCallExpressionVisitor.ts.html +985 -0
- package/coverage/src/js-lib/db/postgresql/index.html +116 -0
- package/coverage/src/js-lib/db/redshift/RedshiftCallExpressionVisitor.ts.html +685 -0
- package/coverage/src/js-lib/db/redshift/index.html +116 -0
- package/coverage/src/js-lib/db/sample/SampleCallExpressionVisitor.ts.html +196 -0
- package/coverage/src/js-lib/db/sample/index.html +116 -0
- package/coverage/src/js-lib/db/snowflake/SnowflakeCallExpressionVisitor.ts.html +1447 -0
- package/coverage/src/js-lib/db/snowflake/index.html +116 -0
- package/coverage/src/js-lib/db/validator/FormulaValidator.ts.html +4162 -0
- package/coverage/src/js-lib/db/validator/index.html +116 -0
- package/coverage/src/js-lib/index.html +131 -0
- package/coverage/src/js-lib/objects/BaseObject.ts.html +169 -0
- package/coverage/src/js-lib/objects/DateObject.ts.html +169 -0
- package/coverage/src/js-lib/objects/PctObject.ts.html +178 -0
- package/coverage/src/js-lib/objects/index.html +146 -0
- package/coverage/src/query-builder/PaginationBuilder.ts.html +142 -0
- package/coverage/src/query-builder/QueryBuilder.ts.html +3118 -0
- package/coverage/src/query-builder/SuperFilterBuilder.ts.html +1969 -0
- package/coverage/src/query-builder/index.html +146 -0
- package/coverage/src/runtime_var.ts.html +109 -0
- package/coverage/src/sql-lib/binary_expr.ts.html +133 -0
- package/coverage/src/sql-lib/case.ts.html +133 -0
- package/coverage/src/sql-lib/column.ts.html +139 -0
- package/coverage/src/sql-lib/else.ts.html +124 -0
- package/coverage/src/sql-lib/function.ts.html +112 -0
- package/coverage/src/sql-lib/index.html +251 -0
- package/coverage/src/sql-lib/join.ts.html +127 -0
- package/coverage/src/sql-lib/literal.ts.html +130 -0
- package/coverage/src/sql-lib/select.ts.html +547 -0
- package/coverage/src/sql-lib/unary_expr.ts.html +112 -0
- package/coverage/src/sql-lib/when.ts.html +130 -0
- package/coverage/src/sql_query_gen.ts.html +535 -0
- package/coverage/src/superFilter/DateFilterFactory.ts.html +625 -0
- package/coverage/src/superFilter/dateFunction.ts.html +193 -0
- package/coverage/src/superFilter/index.html +131 -0
- package/coverage/src/utils.ts.html +571 -0
- package/dist/index.cjs +8440 -0
- package/dist/index.d.cts +927 -0
- package/dist/index.d.cts.map +1 -0
- package/dist/index.d.ts +927 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +8387 -0
- package/dist/index.js.map +1 -0
- package/eslint.config.js +4 -0
- package/jest.config.ts +44 -0
- package/package.json +45 -0
- package/src/constants.ts +247 -0
- package/src/epm-query-builder/EpmQueryBuilder.ts +27 -0
- package/src/epm-query-builder/base/BaseAdvancedAggregations.ts +161 -0
- package/src/epm-query-builder/base/BaseAnalyticalFunctions.ts +203 -0
- package/src/epm-query-builder/base/BaseCTEGenerator.ts +458 -0
- package/src/epm-query-builder/base/BaseCountQueryBuilder.ts +105 -0
- package/src/epm-query-builder/base/BaseMeasureBuilder.ts +87 -0
- package/src/epm-query-builder/base/BaseOrderBuilder.ts +195 -0
- package/src/epm-query-builder/base/BasePaginationBuilder.ts +93 -0
- package/src/epm-query-builder/base/BaseQueryBuilder.ts +51 -0
- package/src/epm-query-builder/base/BaseRollupBuilder.ts +149 -0
- package/src/epm-query-builder/base/BaseSqlBuilder.ts +172 -0
- package/src/epm-query-builder/base/BaseSuperFilterBuilder.ts +627 -0
- package/src/epm-query-builder/base/BaseUtilities.ts +571 -0
- package/src/epm-query-builder/base/ColumnRefUtils.ts +42 -0
- package/src/epm-query-builder/base/RelationshipResolver.ts +207 -0
- package/src/epm-query-builder/base/SharedFilterBuilder.ts +544 -0
- package/src/epm-query-builder/constants/Aggregations.ts +16 -0
- package/src/epm-query-builder/constants/Database.ts +6 -0
- package/src/epm-query-builder/constants/Source.ts +7 -0
- package/src/epm-query-builder/dialects/duckdb/DuckDbAdvancedAggregations.ts +67 -0
- package/src/epm-query-builder/dialects/duckdb/DuckDbJoinBuilder.ts +65 -0
- package/src/epm-query-builder/dialects/duckdb/DuckDbMeasureBuilder.ts +626 -0
- package/src/epm-query-builder/dialects/duckdb/DuckDbOrderBuilder.ts +228 -0
- package/src/epm-query-builder/dialects/duckdb/DuckDbPaginationBuilder.ts +186 -0
- package/src/epm-query-builder/dialects/duckdb/DuckDbQueryBuilder.ts +853 -0
- package/src/epm-query-builder/dialects/duckdb/DuckDbRollupBuilder.ts +131 -0
- package/src/epm-query-builder/dialects/duckdb/DuckDbSuperFilterBuilder.ts +370 -0
- package/src/epm-query-builder/errors/QueryBuilderErrors.ts +65 -0
- package/src/epm-query-builder/interfaces/IDatabaseQueryBuilder.ts +5 -0
- package/src/epm-query-builder/interfaces/index.ts +1 -0
- package/src/epm-query-builder/types/query-builder-types.d.ts +289 -0
- package/src/epm-query-builder/utils/format.ts +22 -0
- package/src/epm-query-builder/utils/sql.ts +54 -0
- package/src/epm-query-builder/utils/validation.ts +13 -0
- package/src/epm-query-builder/validation/QueryOptionsValidator.ts +182 -0
- package/src/epm-query-builder/validation/SqlQueryValidator.ts +130 -0
- package/src/filters/FilterConditionBuilder.ts +114 -0
- package/src/filters/filter-types.ts +133 -0
- package/src/index.ts +10 -0
- package/src/js-lib/JsToSqlParser.ts +217 -0
- package/src/js-lib/ParseContext.ts +149 -0
- package/src/js-lib/db/base/ArrayExpressionVisitor.ts +16 -0
- package/src/js-lib/db/base/AssignmentExpressionVisitor.ts +34 -0
- package/src/js-lib/db/base/BinaryExpressionVisitor.ts +46 -0
- package/src/js-lib/db/base/CallExpressionVisitor.ts +1798 -0
- package/src/js-lib/db/base/IdentifierVisitor.ts +66 -0
- package/src/js-lib/db/base/LiteralVisitor.ts +38 -0
- package/src/js-lib/db/base/MemberExpressionVisitor.ts +36 -0
- package/src/js-lib/db/base/ProgramVisitor.ts +18 -0
- package/src/js-lib/db/base/UnaryExpressionVisitor.ts +32 -0
- package/src/js-lib/db/base/VisitorInterface.ts +6 -0
- package/src/js-lib/db/validator/FormulaValidator.ts +1235 -0
- package/src/js-lib/objects/BaseObject.ts +28 -0
- package/src/js-lib/objects/DateObject.ts +28 -0
- package/src/js-lib/objects/PctObject.ts +31 -0
- package/src/query-builder/PaginationBuilder.ts +19 -0
- package/src/query-builder/QueryBuilder.ts +1035 -0
- package/src/query-builder/SuperFilterBuilder.ts +628 -0
- package/src/runtime_var.ts +8 -0
- package/src/sql-lib/binary_expr.ts +16 -0
- package/src/sql-lib/case.ts +16 -0
- package/src/sql-lib/column.ts +18 -0
- package/src/sql-lib/else.ts +13 -0
- package/src/sql-lib/function.ts +9 -0
- package/src/sql-lib/join.ts +14 -0
- package/src/sql-lib/literal.ts +15 -0
- package/src/sql-lib/select.ts +154 -0
- package/src/sql-lib/unary_expr.ts +9 -0
- package/src/sql-lib/when.ts +15 -0
- package/src/sql-types.d.ts +565 -0
- package/src/sql_query_gen.ts +150 -0
- package/src/superFilter/DateFilterFactory.ts +180 -0
- package/src/superFilter/dateFunction.ts +36 -0
- package/src/utils.ts +354 -0
- package/test-output/report/junit.xml +329 -0
- package/tests/JsToSqlParser.test.ts +163 -0
- package/tests/QueryBuilder.test.ts +1320 -0
- package/tests/js-lib/CallExpressionVisitor.test.ts +820 -0
- package/tests/mocks/MockQueryResolver.ts +14 -0
- package/tests/sanity.test.ts +146 -0
- package/tests/sql-lib/binary_expr.test.ts +75 -0
- package/tests/sql-lib/case.test.ts +117 -0
- package/tests/sql-lib/column.test.ts +87 -0
- package/tests/sql-lib/else.test.ts +56 -0
- package/tests/sql-lib/function.test.ts +96 -0
- package/tests/sql-lib/literal.test.ts +75 -0
- package/tests/sql-lib/select.test.ts +245 -0
- package/tests/sql-lib/unary_expr.test.ts +32 -0
- package/tests/utils.test.ts +13 -0
- package/tsconfig.json +24 -0
- package/tsdown.config.ts +23 -0
|
@@ -0,0 +1,1459 @@
|
|
|
1
|
+
|
|
2
|
+
<!doctype html>
|
|
3
|
+
<html lang="en">
|
|
4
|
+
|
|
5
|
+
<head>
|
|
6
|
+
<title>Code coverage report for src/epm-query-builder/base/BaseCTEGenerator.ts</title>
|
|
7
|
+
<meta charset="utf-8" />
|
|
8
|
+
<link rel="stylesheet" href="../../../prettify.css" />
|
|
9
|
+
<link rel="stylesheet" href="../../../base.css" />
|
|
10
|
+
<link rel="shortcut icon" type="image/x-icon" href="../../../favicon.png" />
|
|
11
|
+
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
12
|
+
<style type='text/css'>
|
|
13
|
+
.coverage-summary .sorter {
|
|
14
|
+
background-image: url(../../../sort-arrow-sprite.png);
|
|
15
|
+
}
|
|
16
|
+
</style>
|
|
17
|
+
</head>
|
|
18
|
+
|
|
19
|
+
<body>
|
|
20
|
+
<div class='wrapper'>
|
|
21
|
+
<div class='pad1'>
|
|
22
|
+
<h1><a href="../../../index.html">All files</a> / <a href="index.html">src/epm-query-builder/base</a> BaseCTEGenerator.ts</h1>
|
|
23
|
+
<div class='clearfix'>
|
|
24
|
+
|
|
25
|
+
<div class='fl pad1y space-right2'>
|
|
26
|
+
<span class="strong">0% </span>
|
|
27
|
+
<span class="quiet">Statements</span>
|
|
28
|
+
<span class='fraction'>0/198</span>
|
|
29
|
+
</div>
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
<div class='fl pad1y space-right2'>
|
|
33
|
+
<span class="strong">0% </span>
|
|
34
|
+
<span class="quiet">Branches</span>
|
|
35
|
+
<span class='fraction'>0/179</span>
|
|
36
|
+
</div>
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
<div class='fl pad1y space-right2'>
|
|
40
|
+
<span class="strong">0% </span>
|
|
41
|
+
<span class="quiet">Functions</span>
|
|
42
|
+
<span class='fraction'>0/26</span>
|
|
43
|
+
</div>
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
<div class='fl pad1y space-right2'>
|
|
47
|
+
<span class="strong">0% </span>
|
|
48
|
+
<span class="quiet">Lines</span>
|
|
49
|
+
<span class='fraction'>0/198</span>
|
|
50
|
+
</div>
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
</div>
|
|
54
|
+
<p class="quiet">
|
|
55
|
+
Press <em>n</em> or <em>j</em> to go to the next uncovered block, <em>b</em>, <em>p</em> or <em>k</em> for the previous block.
|
|
56
|
+
</p>
|
|
57
|
+
<template id="filterTemplate">
|
|
58
|
+
<div class="quiet">
|
|
59
|
+
Filter:
|
|
60
|
+
<input type="search" id="fileSearch">
|
|
61
|
+
</div>
|
|
62
|
+
</template>
|
|
63
|
+
</div>
|
|
64
|
+
<div class='status-line low'></div>
|
|
65
|
+
<pre><table class="coverage">
|
|
66
|
+
<tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
|
|
67
|
+
<a name='L2'></a><a href='#L2'>2</a>
|
|
68
|
+
<a name='L3'></a><a href='#L3'>3</a>
|
|
69
|
+
<a name='L4'></a><a href='#L4'>4</a>
|
|
70
|
+
<a name='L5'></a><a href='#L5'>5</a>
|
|
71
|
+
<a name='L6'></a><a href='#L6'>6</a>
|
|
72
|
+
<a name='L7'></a><a href='#L7'>7</a>
|
|
73
|
+
<a name='L8'></a><a href='#L8'>8</a>
|
|
74
|
+
<a name='L9'></a><a href='#L9'>9</a>
|
|
75
|
+
<a name='L10'></a><a href='#L10'>10</a>
|
|
76
|
+
<a name='L11'></a><a href='#L11'>11</a>
|
|
77
|
+
<a name='L12'></a><a href='#L12'>12</a>
|
|
78
|
+
<a name='L13'></a><a href='#L13'>13</a>
|
|
79
|
+
<a name='L14'></a><a href='#L14'>14</a>
|
|
80
|
+
<a name='L15'></a><a href='#L15'>15</a>
|
|
81
|
+
<a name='L16'></a><a href='#L16'>16</a>
|
|
82
|
+
<a name='L17'></a><a href='#L17'>17</a>
|
|
83
|
+
<a name='L18'></a><a href='#L18'>18</a>
|
|
84
|
+
<a name='L19'></a><a href='#L19'>19</a>
|
|
85
|
+
<a name='L20'></a><a href='#L20'>20</a>
|
|
86
|
+
<a name='L21'></a><a href='#L21'>21</a>
|
|
87
|
+
<a name='L22'></a><a href='#L22'>22</a>
|
|
88
|
+
<a name='L23'></a><a href='#L23'>23</a>
|
|
89
|
+
<a name='L24'></a><a href='#L24'>24</a>
|
|
90
|
+
<a name='L25'></a><a href='#L25'>25</a>
|
|
91
|
+
<a name='L26'></a><a href='#L26'>26</a>
|
|
92
|
+
<a name='L27'></a><a href='#L27'>27</a>
|
|
93
|
+
<a name='L28'></a><a href='#L28'>28</a>
|
|
94
|
+
<a name='L29'></a><a href='#L29'>29</a>
|
|
95
|
+
<a name='L30'></a><a href='#L30'>30</a>
|
|
96
|
+
<a name='L31'></a><a href='#L31'>31</a>
|
|
97
|
+
<a name='L32'></a><a href='#L32'>32</a>
|
|
98
|
+
<a name='L33'></a><a href='#L33'>33</a>
|
|
99
|
+
<a name='L34'></a><a href='#L34'>34</a>
|
|
100
|
+
<a name='L35'></a><a href='#L35'>35</a>
|
|
101
|
+
<a name='L36'></a><a href='#L36'>36</a>
|
|
102
|
+
<a name='L37'></a><a href='#L37'>37</a>
|
|
103
|
+
<a name='L38'></a><a href='#L38'>38</a>
|
|
104
|
+
<a name='L39'></a><a href='#L39'>39</a>
|
|
105
|
+
<a name='L40'></a><a href='#L40'>40</a>
|
|
106
|
+
<a name='L41'></a><a href='#L41'>41</a>
|
|
107
|
+
<a name='L42'></a><a href='#L42'>42</a>
|
|
108
|
+
<a name='L43'></a><a href='#L43'>43</a>
|
|
109
|
+
<a name='L44'></a><a href='#L44'>44</a>
|
|
110
|
+
<a name='L45'></a><a href='#L45'>45</a>
|
|
111
|
+
<a name='L46'></a><a href='#L46'>46</a>
|
|
112
|
+
<a name='L47'></a><a href='#L47'>47</a>
|
|
113
|
+
<a name='L48'></a><a href='#L48'>48</a>
|
|
114
|
+
<a name='L49'></a><a href='#L49'>49</a>
|
|
115
|
+
<a name='L50'></a><a href='#L50'>50</a>
|
|
116
|
+
<a name='L51'></a><a href='#L51'>51</a>
|
|
117
|
+
<a name='L52'></a><a href='#L52'>52</a>
|
|
118
|
+
<a name='L53'></a><a href='#L53'>53</a>
|
|
119
|
+
<a name='L54'></a><a href='#L54'>54</a>
|
|
120
|
+
<a name='L55'></a><a href='#L55'>55</a>
|
|
121
|
+
<a name='L56'></a><a href='#L56'>56</a>
|
|
122
|
+
<a name='L57'></a><a href='#L57'>57</a>
|
|
123
|
+
<a name='L58'></a><a href='#L58'>58</a>
|
|
124
|
+
<a name='L59'></a><a href='#L59'>59</a>
|
|
125
|
+
<a name='L60'></a><a href='#L60'>60</a>
|
|
126
|
+
<a name='L61'></a><a href='#L61'>61</a>
|
|
127
|
+
<a name='L62'></a><a href='#L62'>62</a>
|
|
128
|
+
<a name='L63'></a><a href='#L63'>63</a>
|
|
129
|
+
<a name='L64'></a><a href='#L64'>64</a>
|
|
130
|
+
<a name='L65'></a><a href='#L65'>65</a>
|
|
131
|
+
<a name='L66'></a><a href='#L66'>66</a>
|
|
132
|
+
<a name='L67'></a><a href='#L67'>67</a>
|
|
133
|
+
<a name='L68'></a><a href='#L68'>68</a>
|
|
134
|
+
<a name='L69'></a><a href='#L69'>69</a>
|
|
135
|
+
<a name='L70'></a><a href='#L70'>70</a>
|
|
136
|
+
<a name='L71'></a><a href='#L71'>71</a>
|
|
137
|
+
<a name='L72'></a><a href='#L72'>72</a>
|
|
138
|
+
<a name='L73'></a><a href='#L73'>73</a>
|
|
139
|
+
<a name='L74'></a><a href='#L74'>74</a>
|
|
140
|
+
<a name='L75'></a><a href='#L75'>75</a>
|
|
141
|
+
<a name='L76'></a><a href='#L76'>76</a>
|
|
142
|
+
<a name='L77'></a><a href='#L77'>77</a>
|
|
143
|
+
<a name='L78'></a><a href='#L78'>78</a>
|
|
144
|
+
<a name='L79'></a><a href='#L79'>79</a>
|
|
145
|
+
<a name='L80'></a><a href='#L80'>80</a>
|
|
146
|
+
<a name='L81'></a><a href='#L81'>81</a>
|
|
147
|
+
<a name='L82'></a><a href='#L82'>82</a>
|
|
148
|
+
<a name='L83'></a><a href='#L83'>83</a>
|
|
149
|
+
<a name='L84'></a><a href='#L84'>84</a>
|
|
150
|
+
<a name='L85'></a><a href='#L85'>85</a>
|
|
151
|
+
<a name='L86'></a><a href='#L86'>86</a>
|
|
152
|
+
<a name='L87'></a><a href='#L87'>87</a>
|
|
153
|
+
<a name='L88'></a><a href='#L88'>88</a>
|
|
154
|
+
<a name='L89'></a><a href='#L89'>89</a>
|
|
155
|
+
<a name='L90'></a><a href='#L90'>90</a>
|
|
156
|
+
<a name='L91'></a><a href='#L91'>91</a>
|
|
157
|
+
<a name='L92'></a><a href='#L92'>92</a>
|
|
158
|
+
<a name='L93'></a><a href='#L93'>93</a>
|
|
159
|
+
<a name='L94'></a><a href='#L94'>94</a>
|
|
160
|
+
<a name='L95'></a><a href='#L95'>95</a>
|
|
161
|
+
<a name='L96'></a><a href='#L96'>96</a>
|
|
162
|
+
<a name='L97'></a><a href='#L97'>97</a>
|
|
163
|
+
<a name='L98'></a><a href='#L98'>98</a>
|
|
164
|
+
<a name='L99'></a><a href='#L99'>99</a>
|
|
165
|
+
<a name='L100'></a><a href='#L100'>100</a>
|
|
166
|
+
<a name='L101'></a><a href='#L101'>101</a>
|
|
167
|
+
<a name='L102'></a><a href='#L102'>102</a>
|
|
168
|
+
<a name='L103'></a><a href='#L103'>103</a>
|
|
169
|
+
<a name='L104'></a><a href='#L104'>104</a>
|
|
170
|
+
<a name='L105'></a><a href='#L105'>105</a>
|
|
171
|
+
<a name='L106'></a><a href='#L106'>106</a>
|
|
172
|
+
<a name='L107'></a><a href='#L107'>107</a>
|
|
173
|
+
<a name='L108'></a><a href='#L108'>108</a>
|
|
174
|
+
<a name='L109'></a><a href='#L109'>109</a>
|
|
175
|
+
<a name='L110'></a><a href='#L110'>110</a>
|
|
176
|
+
<a name='L111'></a><a href='#L111'>111</a>
|
|
177
|
+
<a name='L112'></a><a href='#L112'>112</a>
|
|
178
|
+
<a name='L113'></a><a href='#L113'>113</a>
|
|
179
|
+
<a name='L114'></a><a href='#L114'>114</a>
|
|
180
|
+
<a name='L115'></a><a href='#L115'>115</a>
|
|
181
|
+
<a name='L116'></a><a href='#L116'>116</a>
|
|
182
|
+
<a name='L117'></a><a href='#L117'>117</a>
|
|
183
|
+
<a name='L118'></a><a href='#L118'>118</a>
|
|
184
|
+
<a name='L119'></a><a href='#L119'>119</a>
|
|
185
|
+
<a name='L120'></a><a href='#L120'>120</a>
|
|
186
|
+
<a name='L121'></a><a href='#L121'>121</a>
|
|
187
|
+
<a name='L122'></a><a href='#L122'>122</a>
|
|
188
|
+
<a name='L123'></a><a href='#L123'>123</a>
|
|
189
|
+
<a name='L124'></a><a href='#L124'>124</a>
|
|
190
|
+
<a name='L125'></a><a href='#L125'>125</a>
|
|
191
|
+
<a name='L126'></a><a href='#L126'>126</a>
|
|
192
|
+
<a name='L127'></a><a href='#L127'>127</a>
|
|
193
|
+
<a name='L128'></a><a href='#L128'>128</a>
|
|
194
|
+
<a name='L129'></a><a href='#L129'>129</a>
|
|
195
|
+
<a name='L130'></a><a href='#L130'>130</a>
|
|
196
|
+
<a name='L131'></a><a href='#L131'>131</a>
|
|
197
|
+
<a name='L132'></a><a href='#L132'>132</a>
|
|
198
|
+
<a name='L133'></a><a href='#L133'>133</a>
|
|
199
|
+
<a name='L134'></a><a href='#L134'>134</a>
|
|
200
|
+
<a name='L135'></a><a href='#L135'>135</a>
|
|
201
|
+
<a name='L136'></a><a href='#L136'>136</a>
|
|
202
|
+
<a name='L137'></a><a href='#L137'>137</a>
|
|
203
|
+
<a name='L138'></a><a href='#L138'>138</a>
|
|
204
|
+
<a name='L139'></a><a href='#L139'>139</a>
|
|
205
|
+
<a name='L140'></a><a href='#L140'>140</a>
|
|
206
|
+
<a name='L141'></a><a href='#L141'>141</a>
|
|
207
|
+
<a name='L142'></a><a href='#L142'>142</a>
|
|
208
|
+
<a name='L143'></a><a href='#L143'>143</a>
|
|
209
|
+
<a name='L144'></a><a href='#L144'>144</a>
|
|
210
|
+
<a name='L145'></a><a href='#L145'>145</a>
|
|
211
|
+
<a name='L146'></a><a href='#L146'>146</a>
|
|
212
|
+
<a name='L147'></a><a href='#L147'>147</a>
|
|
213
|
+
<a name='L148'></a><a href='#L148'>148</a>
|
|
214
|
+
<a name='L149'></a><a href='#L149'>149</a>
|
|
215
|
+
<a name='L150'></a><a href='#L150'>150</a>
|
|
216
|
+
<a name='L151'></a><a href='#L151'>151</a>
|
|
217
|
+
<a name='L152'></a><a href='#L152'>152</a>
|
|
218
|
+
<a name='L153'></a><a href='#L153'>153</a>
|
|
219
|
+
<a name='L154'></a><a href='#L154'>154</a>
|
|
220
|
+
<a name='L155'></a><a href='#L155'>155</a>
|
|
221
|
+
<a name='L156'></a><a href='#L156'>156</a>
|
|
222
|
+
<a name='L157'></a><a href='#L157'>157</a>
|
|
223
|
+
<a name='L158'></a><a href='#L158'>158</a>
|
|
224
|
+
<a name='L159'></a><a href='#L159'>159</a>
|
|
225
|
+
<a name='L160'></a><a href='#L160'>160</a>
|
|
226
|
+
<a name='L161'></a><a href='#L161'>161</a>
|
|
227
|
+
<a name='L162'></a><a href='#L162'>162</a>
|
|
228
|
+
<a name='L163'></a><a href='#L163'>163</a>
|
|
229
|
+
<a name='L164'></a><a href='#L164'>164</a>
|
|
230
|
+
<a name='L165'></a><a href='#L165'>165</a>
|
|
231
|
+
<a name='L166'></a><a href='#L166'>166</a>
|
|
232
|
+
<a name='L167'></a><a href='#L167'>167</a>
|
|
233
|
+
<a name='L168'></a><a href='#L168'>168</a>
|
|
234
|
+
<a name='L169'></a><a href='#L169'>169</a>
|
|
235
|
+
<a name='L170'></a><a href='#L170'>170</a>
|
|
236
|
+
<a name='L171'></a><a href='#L171'>171</a>
|
|
237
|
+
<a name='L172'></a><a href='#L172'>172</a>
|
|
238
|
+
<a name='L173'></a><a href='#L173'>173</a>
|
|
239
|
+
<a name='L174'></a><a href='#L174'>174</a>
|
|
240
|
+
<a name='L175'></a><a href='#L175'>175</a>
|
|
241
|
+
<a name='L176'></a><a href='#L176'>176</a>
|
|
242
|
+
<a name='L177'></a><a href='#L177'>177</a>
|
|
243
|
+
<a name='L178'></a><a href='#L178'>178</a>
|
|
244
|
+
<a name='L179'></a><a href='#L179'>179</a>
|
|
245
|
+
<a name='L180'></a><a href='#L180'>180</a>
|
|
246
|
+
<a name='L181'></a><a href='#L181'>181</a>
|
|
247
|
+
<a name='L182'></a><a href='#L182'>182</a>
|
|
248
|
+
<a name='L183'></a><a href='#L183'>183</a>
|
|
249
|
+
<a name='L184'></a><a href='#L184'>184</a>
|
|
250
|
+
<a name='L185'></a><a href='#L185'>185</a>
|
|
251
|
+
<a name='L186'></a><a href='#L186'>186</a>
|
|
252
|
+
<a name='L187'></a><a href='#L187'>187</a>
|
|
253
|
+
<a name='L188'></a><a href='#L188'>188</a>
|
|
254
|
+
<a name='L189'></a><a href='#L189'>189</a>
|
|
255
|
+
<a name='L190'></a><a href='#L190'>190</a>
|
|
256
|
+
<a name='L191'></a><a href='#L191'>191</a>
|
|
257
|
+
<a name='L192'></a><a href='#L192'>192</a>
|
|
258
|
+
<a name='L193'></a><a href='#L193'>193</a>
|
|
259
|
+
<a name='L194'></a><a href='#L194'>194</a>
|
|
260
|
+
<a name='L195'></a><a href='#L195'>195</a>
|
|
261
|
+
<a name='L196'></a><a href='#L196'>196</a>
|
|
262
|
+
<a name='L197'></a><a href='#L197'>197</a>
|
|
263
|
+
<a name='L198'></a><a href='#L198'>198</a>
|
|
264
|
+
<a name='L199'></a><a href='#L199'>199</a>
|
|
265
|
+
<a name='L200'></a><a href='#L200'>200</a>
|
|
266
|
+
<a name='L201'></a><a href='#L201'>201</a>
|
|
267
|
+
<a name='L202'></a><a href='#L202'>202</a>
|
|
268
|
+
<a name='L203'></a><a href='#L203'>203</a>
|
|
269
|
+
<a name='L204'></a><a href='#L204'>204</a>
|
|
270
|
+
<a name='L205'></a><a href='#L205'>205</a>
|
|
271
|
+
<a name='L206'></a><a href='#L206'>206</a>
|
|
272
|
+
<a name='L207'></a><a href='#L207'>207</a>
|
|
273
|
+
<a name='L208'></a><a href='#L208'>208</a>
|
|
274
|
+
<a name='L209'></a><a href='#L209'>209</a>
|
|
275
|
+
<a name='L210'></a><a href='#L210'>210</a>
|
|
276
|
+
<a name='L211'></a><a href='#L211'>211</a>
|
|
277
|
+
<a name='L212'></a><a href='#L212'>212</a>
|
|
278
|
+
<a name='L213'></a><a href='#L213'>213</a>
|
|
279
|
+
<a name='L214'></a><a href='#L214'>214</a>
|
|
280
|
+
<a name='L215'></a><a href='#L215'>215</a>
|
|
281
|
+
<a name='L216'></a><a href='#L216'>216</a>
|
|
282
|
+
<a name='L217'></a><a href='#L217'>217</a>
|
|
283
|
+
<a name='L218'></a><a href='#L218'>218</a>
|
|
284
|
+
<a name='L219'></a><a href='#L219'>219</a>
|
|
285
|
+
<a name='L220'></a><a href='#L220'>220</a>
|
|
286
|
+
<a name='L221'></a><a href='#L221'>221</a>
|
|
287
|
+
<a name='L222'></a><a href='#L222'>222</a>
|
|
288
|
+
<a name='L223'></a><a href='#L223'>223</a>
|
|
289
|
+
<a name='L224'></a><a href='#L224'>224</a>
|
|
290
|
+
<a name='L225'></a><a href='#L225'>225</a>
|
|
291
|
+
<a name='L226'></a><a href='#L226'>226</a>
|
|
292
|
+
<a name='L227'></a><a href='#L227'>227</a>
|
|
293
|
+
<a name='L228'></a><a href='#L228'>228</a>
|
|
294
|
+
<a name='L229'></a><a href='#L229'>229</a>
|
|
295
|
+
<a name='L230'></a><a href='#L230'>230</a>
|
|
296
|
+
<a name='L231'></a><a href='#L231'>231</a>
|
|
297
|
+
<a name='L232'></a><a href='#L232'>232</a>
|
|
298
|
+
<a name='L233'></a><a href='#L233'>233</a>
|
|
299
|
+
<a name='L234'></a><a href='#L234'>234</a>
|
|
300
|
+
<a name='L235'></a><a href='#L235'>235</a>
|
|
301
|
+
<a name='L236'></a><a href='#L236'>236</a>
|
|
302
|
+
<a name='L237'></a><a href='#L237'>237</a>
|
|
303
|
+
<a name='L238'></a><a href='#L238'>238</a>
|
|
304
|
+
<a name='L239'></a><a href='#L239'>239</a>
|
|
305
|
+
<a name='L240'></a><a href='#L240'>240</a>
|
|
306
|
+
<a name='L241'></a><a href='#L241'>241</a>
|
|
307
|
+
<a name='L242'></a><a href='#L242'>242</a>
|
|
308
|
+
<a name='L243'></a><a href='#L243'>243</a>
|
|
309
|
+
<a name='L244'></a><a href='#L244'>244</a>
|
|
310
|
+
<a name='L245'></a><a href='#L245'>245</a>
|
|
311
|
+
<a name='L246'></a><a href='#L246'>246</a>
|
|
312
|
+
<a name='L247'></a><a href='#L247'>247</a>
|
|
313
|
+
<a name='L248'></a><a href='#L248'>248</a>
|
|
314
|
+
<a name='L249'></a><a href='#L249'>249</a>
|
|
315
|
+
<a name='L250'></a><a href='#L250'>250</a>
|
|
316
|
+
<a name='L251'></a><a href='#L251'>251</a>
|
|
317
|
+
<a name='L252'></a><a href='#L252'>252</a>
|
|
318
|
+
<a name='L253'></a><a href='#L253'>253</a>
|
|
319
|
+
<a name='L254'></a><a href='#L254'>254</a>
|
|
320
|
+
<a name='L255'></a><a href='#L255'>255</a>
|
|
321
|
+
<a name='L256'></a><a href='#L256'>256</a>
|
|
322
|
+
<a name='L257'></a><a href='#L257'>257</a>
|
|
323
|
+
<a name='L258'></a><a href='#L258'>258</a>
|
|
324
|
+
<a name='L259'></a><a href='#L259'>259</a>
|
|
325
|
+
<a name='L260'></a><a href='#L260'>260</a>
|
|
326
|
+
<a name='L261'></a><a href='#L261'>261</a>
|
|
327
|
+
<a name='L262'></a><a href='#L262'>262</a>
|
|
328
|
+
<a name='L263'></a><a href='#L263'>263</a>
|
|
329
|
+
<a name='L264'></a><a href='#L264'>264</a>
|
|
330
|
+
<a name='L265'></a><a href='#L265'>265</a>
|
|
331
|
+
<a name='L266'></a><a href='#L266'>266</a>
|
|
332
|
+
<a name='L267'></a><a href='#L267'>267</a>
|
|
333
|
+
<a name='L268'></a><a href='#L268'>268</a>
|
|
334
|
+
<a name='L269'></a><a href='#L269'>269</a>
|
|
335
|
+
<a name='L270'></a><a href='#L270'>270</a>
|
|
336
|
+
<a name='L271'></a><a href='#L271'>271</a>
|
|
337
|
+
<a name='L272'></a><a href='#L272'>272</a>
|
|
338
|
+
<a name='L273'></a><a href='#L273'>273</a>
|
|
339
|
+
<a name='L274'></a><a href='#L274'>274</a>
|
|
340
|
+
<a name='L275'></a><a href='#L275'>275</a>
|
|
341
|
+
<a name='L276'></a><a href='#L276'>276</a>
|
|
342
|
+
<a name='L277'></a><a href='#L277'>277</a>
|
|
343
|
+
<a name='L278'></a><a href='#L278'>278</a>
|
|
344
|
+
<a name='L279'></a><a href='#L279'>279</a>
|
|
345
|
+
<a name='L280'></a><a href='#L280'>280</a>
|
|
346
|
+
<a name='L281'></a><a href='#L281'>281</a>
|
|
347
|
+
<a name='L282'></a><a href='#L282'>282</a>
|
|
348
|
+
<a name='L283'></a><a href='#L283'>283</a>
|
|
349
|
+
<a name='L284'></a><a href='#L284'>284</a>
|
|
350
|
+
<a name='L285'></a><a href='#L285'>285</a>
|
|
351
|
+
<a name='L286'></a><a href='#L286'>286</a>
|
|
352
|
+
<a name='L287'></a><a href='#L287'>287</a>
|
|
353
|
+
<a name='L288'></a><a href='#L288'>288</a>
|
|
354
|
+
<a name='L289'></a><a href='#L289'>289</a>
|
|
355
|
+
<a name='L290'></a><a href='#L290'>290</a>
|
|
356
|
+
<a name='L291'></a><a href='#L291'>291</a>
|
|
357
|
+
<a name='L292'></a><a href='#L292'>292</a>
|
|
358
|
+
<a name='L293'></a><a href='#L293'>293</a>
|
|
359
|
+
<a name='L294'></a><a href='#L294'>294</a>
|
|
360
|
+
<a name='L295'></a><a href='#L295'>295</a>
|
|
361
|
+
<a name='L296'></a><a href='#L296'>296</a>
|
|
362
|
+
<a name='L297'></a><a href='#L297'>297</a>
|
|
363
|
+
<a name='L298'></a><a href='#L298'>298</a>
|
|
364
|
+
<a name='L299'></a><a href='#L299'>299</a>
|
|
365
|
+
<a name='L300'></a><a href='#L300'>300</a>
|
|
366
|
+
<a name='L301'></a><a href='#L301'>301</a>
|
|
367
|
+
<a name='L302'></a><a href='#L302'>302</a>
|
|
368
|
+
<a name='L303'></a><a href='#L303'>303</a>
|
|
369
|
+
<a name='L304'></a><a href='#L304'>304</a>
|
|
370
|
+
<a name='L305'></a><a href='#L305'>305</a>
|
|
371
|
+
<a name='L306'></a><a href='#L306'>306</a>
|
|
372
|
+
<a name='L307'></a><a href='#L307'>307</a>
|
|
373
|
+
<a name='L308'></a><a href='#L308'>308</a>
|
|
374
|
+
<a name='L309'></a><a href='#L309'>309</a>
|
|
375
|
+
<a name='L310'></a><a href='#L310'>310</a>
|
|
376
|
+
<a name='L311'></a><a href='#L311'>311</a>
|
|
377
|
+
<a name='L312'></a><a href='#L312'>312</a>
|
|
378
|
+
<a name='L313'></a><a href='#L313'>313</a>
|
|
379
|
+
<a name='L314'></a><a href='#L314'>314</a>
|
|
380
|
+
<a name='L315'></a><a href='#L315'>315</a>
|
|
381
|
+
<a name='L316'></a><a href='#L316'>316</a>
|
|
382
|
+
<a name='L317'></a><a href='#L317'>317</a>
|
|
383
|
+
<a name='L318'></a><a href='#L318'>318</a>
|
|
384
|
+
<a name='L319'></a><a href='#L319'>319</a>
|
|
385
|
+
<a name='L320'></a><a href='#L320'>320</a>
|
|
386
|
+
<a name='L321'></a><a href='#L321'>321</a>
|
|
387
|
+
<a name='L322'></a><a href='#L322'>322</a>
|
|
388
|
+
<a name='L323'></a><a href='#L323'>323</a>
|
|
389
|
+
<a name='L324'></a><a href='#L324'>324</a>
|
|
390
|
+
<a name='L325'></a><a href='#L325'>325</a>
|
|
391
|
+
<a name='L326'></a><a href='#L326'>326</a>
|
|
392
|
+
<a name='L327'></a><a href='#L327'>327</a>
|
|
393
|
+
<a name='L328'></a><a href='#L328'>328</a>
|
|
394
|
+
<a name='L329'></a><a href='#L329'>329</a>
|
|
395
|
+
<a name='L330'></a><a href='#L330'>330</a>
|
|
396
|
+
<a name='L331'></a><a href='#L331'>331</a>
|
|
397
|
+
<a name='L332'></a><a href='#L332'>332</a>
|
|
398
|
+
<a name='L333'></a><a href='#L333'>333</a>
|
|
399
|
+
<a name='L334'></a><a href='#L334'>334</a>
|
|
400
|
+
<a name='L335'></a><a href='#L335'>335</a>
|
|
401
|
+
<a name='L336'></a><a href='#L336'>336</a>
|
|
402
|
+
<a name='L337'></a><a href='#L337'>337</a>
|
|
403
|
+
<a name='L338'></a><a href='#L338'>338</a>
|
|
404
|
+
<a name='L339'></a><a href='#L339'>339</a>
|
|
405
|
+
<a name='L340'></a><a href='#L340'>340</a>
|
|
406
|
+
<a name='L341'></a><a href='#L341'>341</a>
|
|
407
|
+
<a name='L342'></a><a href='#L342'>342</a>
|
|
408
|
+
<a name='L343'></a><a href='#L343'>343</a>
|
|
409
|
+
<a name='L344'></a><a href='#L344'>344</a>
|
|
410
|
+
<a name='L345'></a><a href='#L345'>345</a>
|
|
411
|
+
<a name='L346'></a><a href='#L346'>346</a>
|
|
412
|
+
<a name='L347'></a><a href='#L347'>347</a>
|
|
413
|
+
<a name='L348'></a><a href='#L348'>348</a>
|
|
414
|
+
<a name='L349'></a><a href='#L349'>349</a>
|
|
415
|
+
<a name='L350'></a><a href='#L350'>350</a>
|
|
416
|
+
<a name='L351'></a><a href='#L351'>351</a>
|
|
417
|
+
<a name='L352'></a><a href='#L352'>352</a>
|
|
418
|
+
<a name='L353'></a><a href='#L353'>353</a>
|
|
419
|
+
<a name='L354'></a><a href='#L354'>354</a>
|
|
420
|
+
<a name='L355'></a><a href='#L355'>355</a>
|
|
421
|
+
<a name='L356'></a><a href='#L356'>356</a>
|
|
422
|
+
<a name='L357'></a><a href='#L357'>357</a>
|
|
423
|
+
<a name='L358'></a><a href='#L358'>358</a>
|
|
424
|
+
<a name='L359'></a><a href='#L359'>359</a>
|
|
425
|
+
<a name='L360'></a><a href='#L360'>360</a>
|
|
426
|
+
<a name='L361'></a><a href='#L361'>361</a>
|
|
427
|
+
<a name='L362'></a><a href='#L362'>362</a>
|
|
428
|
+
<a name='L363'></a><a href='#L363'>363</a>
|
|
429
|
+
<a name='L364'></a><a href='#L364'>364</a>
|
|
430
|
+
<a name='L365'></a><a href='#L365'>365</a>
|
|
431
|
+
<a name='L366'></a><a href='#L366'>366</a>
|
|
432
|
+
<a name='L367'></a><a href='#L367'>367</a>
|
|
433
|
+
<a name='L368'></a><a href='#L368'>368</a>
|
|
434
|
+
<a name='L369'></a><a href='#L369'>369</a>
|
|
435
|
+
<a name='L370'></a><a href='#L370'>370</a>
|
|
436
|
+
<a name='L371'></a><a href='#L371'>371</a>
|
|
437
|
+
<a name='L372'></a><a href='#L372'>372</a>
|
|
438
|
+
<a name='L373'></a><a href='#L373'>373</a>
|
|
439
|
+
<a name='L374'></a><a href='#L374'>374</a>
|
|
440
|
+
<a name='L375'></a><a href='#L375'>375</a>
|
|
441
|
+
<a name='L376'></a><a href='#L376'>376</a>
|
|
442
|
+
<a name='L377'></a><a href='#L377'>377</a>
|
|
443
|
+
<a name='L378'></a><a href='#L378'>378</a>
|
|
444
|
+
<a name='L379'></a><a href='#L379'>379</a>
|
|
445
|
+
<a name='L380'></a><a href='#L380'>380</a>
|
|
446
|
+
<a name='L381'></a><a href='#L381'>381</a>
|
|
447
|
+
<a name='L382'></a><a href='#L382'>382</a>
|
|
448
|
+
<a name='L383'></a><a href='#L383'>383</a>
|
|
449
|
+
<a name='L384'></a><a href='#L384'>384</a>
|
|
450
|
+
<a name='L385'></a><a href='#L385'>385</a>
|
|
451
|
+
<a name='L386'></a><a href='#L386'>386</a>
|
|
452
|
+
<a name='L387'></a><a href='#L387'>387</a>
|
|
453
|
+
<a name='L388'></a><a href='#L388'>388</a>
|
|
454
|
+
<a name='L389'></a><a href='#L389'>389</a>
|
|
455
|
+
<a name='L390'></a><a href='#L390'>390</a>
|
|
456
|
+
<a name='L391'></a><a href='#L391'>391</a>
|
|
457
|
+
<a name='L392'></a><a href='#L392'>392</a>
|
|
458
|
+
<a name='L393'></a><a href='#L393'>393</a>
|
|
459
|
+
<a name='L394'></a><a href='#L394'>394</a>
|
|
460
|
+
<a name='L395'></a><a href='#L395'>395</a>
|
|
461
|
+
<a name='L396'></a><a href='#L396'>396</a>
|
|
462
|
+
<a name='L397'></a><a href='#L397'>397</a>
|
|
463
|
+
<a name='L398'></a><a href='#L398'>398</a>
|
|
464
|
+
<a name='L399'></a><a href='#L399'>399</a>
|
|
465
|
+
<a name='L400'></a><a href='#L400'>400</a>
|
|
466
|
+
<a name='L401'></a><a href='#L401'>401</a>
|
|
467
|
+
<a name='L402'></a><a href='#L402'>402</a>
|
|
468
|
+
<a name='L403'></a><a href='#L403'>403</a>
|
|
469
|
+
<a name='L404'></a><a href='#L404'>404</a>
|
|
470
|
+
<a name='L405'></a><a href='#L405'>405</a>
|
|
471
|
+
<a name='L406'></a><a href='#L406'>406</a>
|
|
472
|
+
<a name='L407'></a><a href='#L407'>407</a>
|
|
473
|
+
<a name='L408'></a><a href='#L408'>408</a>
|
|
474
|
+
<a name='L409'></a><a href='#L409'>409</a>
|
|
475
|
+
<a name='L410'></a><a href='#L410'>410</a>
|
|
476
|
+
<a name='L411'></a><a href='#L411'>411</a>
|
|
477
|
+
<a name='L412'></a><a href='#L412'>412</a>
|
|
478
|
+
<a name='L413'></a><a href='#L413'>413</a>
|
|
479
|
+
<a name='L414'></a><a href='#L414'>414</a>
|
|
480
|
+
<a name='L415'></a><a href='#L415'>415</a>
|
|
481
|
+
<a name='L416'></a><a href='#L416'>416</a>
|
|
482
|
+
<a name='L417'></a><a href='#L417'>417</a>
|
|
483
|
+
<a name='L418'></a><a href='#L418'>418</a>
|
|
484
|
+
<a name='L419'></a><a href='#L419'>419</a>
|
|
485
|
+
<a name='L420'></a><a href='#L420'>420</a>
|
|
486
|
+
<a name='L421'></a><a href='#L421'>421</a>
|
|
487
|
+
<a name='L422'></a><a href='#L422'>422</a>
|
|
488
|
+
<a name='L423'></a><a href='#L423'>423</a>
|
|
489
|
+
<a name='L424'></a><a href='#L424'>424</a>
|
|
490
|
+
<a name='L425'></a><a href='#L425'>425</a>
|
|
491
|
+
<a name='L426'></a><a href='#L426'>426</a>
|
|
492
|
+
<a name='L427'></a><a href='#L427'>427</a>
|
|
493
|
+
<a name='L428'></a><a href='#L428'>428</a>
|
|
494
|
+
<a name='L429'></a><a href='#L429'>429</a>
|
|
495
|
+
<a name='L430'></a><a href='#L430'>430</a>
|
|
496
|
+
<a name='L431'></a><a href='#L431'>431</a>
|
|
497
|
+
<a name='L432'></a><a href='#L432'>432</a>
|
|
498
|
+
<a name='L433'></a><a href='#L433'>433</a>
|
|
499
|
+
<a name='L434'></a><a href='#L434'>434</a>
|
|
500
|
+
<a name='L435'></a><a href='#L435'>435</a>
|
|
501
|
+
<a name='L436'></a><a href='#L436'>436</a>
|
|
502
|
+
<a name='L437'></a><a href='#L437'>437</a>
|
|
503
|
+
<a name='L438'></a><a href='#L438'>438</a>
|
|
504
|
+
<a name='L439'></a><a href='#L439'>439</a>
|
|
505
|
+
<a name='L440'></a><a href='#L440'>440</a>
|
|
506
|
+
<a name='L441'></a><a href='#L441'>441</a>
|
|
507
|
+
<a name='L442'></a><a href='#L442'>442</a>
|
|
508
|
+
<a name='L443'></a><a href='#L443'>443</a>
|
|
509
|
+
<a name='L444'></a><a href='#L444'>444</a>
|
|
510
|
+
<a name='L445'></a><a href='#L445'>445</a>
|
|
511
|
+
<a name='L446'></a><a href='#L446'>446</a>
|
|
512
|
+
<a name='L447'></a><a href='#L447'>447</a>
|
|
513
|
+
<a name='L448'></a><a href='#L448'>448</a>
|
|
514
|
+
<a name='L449'></a><a href='#L449'>449</a>
|
|
515
|
+
<a name='L450'></a><a href='#L450'>450</a>
|
|
516
|
+
<a name='L451'></a><a href='#L451'>451</a>
|
|
517
|
+
<a name='L452'></a><a href='#L452'>452</a>
|
|
518
|
+
<a name='L453'></a><a href='#L453'>453</a>
|
|
519
|
+
<a name='L454'></a><a href='#L454'>454</a>
|
|
520
|
+
<a name='L455'></a><a href='#L455'>455</a>
|
|
521
|
+
<a name='L456'></a><a href='#L456'>456</a>
|
|
522
|
+
<a name='L457'></a><a href='#L457'>457</a>
|
|
523
|
+
<a name='L458'></a><a href='#L458'>458</a>
|
|
524
|
+
<a name='L459'></a><a href='#L459'>459</a></td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span>
|
|
525
|
+
<span class="cline-any cline-neutral"> </span>
|
|
526
|
+
<span class="cline-any cline-neutral"> </span>
|
|
527
|
+
<span class="cline-any cline-neutral"> </span>
|
|
528
|
+
<span class="cline-any cline-neutral"> </span>
|
|
529
|
+
<span class="cline-any cline-no"> </span>
|
|
530
|
+
<span class="cline-any cline-neutral"> </span>
|
|
531
|
+
<span class="cline-any cline-neutral"> </span>
|
|
532
|
+
<span class="cline-any cline-no"> </span>
|
|
533
|
+
<span class="cline-any cline-neutral"> </span>
|
|
534
|
+
<span class="cline-any cline-neutral"> </span>
|
|
535
|
+
<span class="cline-any cline-no"> </span>
|
|
536
|
+
<span class="cline-any cline-no"> </span>
|
|
537
|
+
<span class="cline-any cline-no"> </span>
|
|
538
|
+
<span class="cline-any cline-no"> </span>
|
|
539
|
+
<span class="cline-any cline-no"> </span>
|
|
540
|
+
<span class="cline-any cline-neutral"> </span>
|
|
541
|
+
<span class="cline-any cline-neutral"> </span>
|
|
542
|
+
<span class="cline-any cline-no"> </span>
|
|
543
|
+
<span class="cline-any cline-no"> </span>
|
|
544
|
+
<span class="cline-any cline-no"> </span>
|
|
545
|
+
<span class="cline-any cline-neutral"> </span>
|
|
546
|
+
<span class="cline-any cline-no"> </span>
|
|
547
|
+
<span class="cline-any cline-no"> </span>
|
|
548
|
+
<span class="cline-any cline-no"> </span>
|
|
549
|
+
<span class="cline-any cline-no"> </span>
|
|
550
|
+
<span class="cline-any cline-no"> </span>
|
|
551
|
+
<span class="cline-any cline-no"> </span>
|
|
552
|
+
<span class="cline-any cline-neutral"> </span>
|
|
553
|
+
<span class="cline-any cline-neutral"> </span>
|
|
554
|
+
<span class="cline-any cline-no"> </span>
|
|
555
|
+
<span class="cline-any cline-no"> </span>
|
|
556
|
+
<span class="cline-any cline-no"> </span>
|
|
557
|
+
<span class="cline-any cline-neutral"> </span>
|
|
558
|
+
<span class="cline-any cline-no"> </span>
|
|
559
|
+
<span class="cline-any cline-no"> </span>
|
|
560
|
+
<span class="cline-any cline-no"> </span>
|
|
561
|
+
<span class="cline-any cline-no"> </span>
|
|
562
|
+
<span class="cline-any cline-no"> </span>
|
|
563
|
+
<span class="cline-any cline-neutral"> </span>
|
|
564
|
+
<span class="cline-any cline-no"> </span>
|
|
565
|
+
<span class="cline-any cline-no"> </span>
|
|
566
|
+
<span class="cline-any cline-no"> </span>
|
|
567
|
+
<span class="cline-any cline-no"> </span>
|
|
568
|
+
<span class="cline-any cline-no"> </span>
|
|
569
|
+
<span class="cline-any cline-neutral"> </span>
|
|
570
|
+
<span class="cline-any cline-no"> </span>
|
|
571
|
+
<span class="cline-any cline-neutral"> </span>
|
|
572
|
+
<span class="cline-any cline-no"> </span>
|
|
573
|
+
<span class="cline-any cline-no"> </span>
|
|
574
|
+
<span class="cline-any cline-no"> </span>
|
|
575
|
+
<span class="cline-any cline-no"> </span>
|
|
576
|
+
<span class="cline-any cline-no"> </span>
|
|
577
|
+
<span class="cline-any cline-no"> </span>
|
|
578
|
+
<span class="cline-any cline-no"> </span>
|
|
579
|
+
<span class="cline-any cline-neutral"> </span>
|
|
580
|
+
<span class="cline-any cline-neutral"> </span>
|
|
581
|
+
<span class="cline-any cline-no"> </span>
|
|
582
|
+
<span class="cline-any cline-no"> </span>
|
|
583
|
+
<span class="cline-any cline-no"> </span>
|
|
584
|
+
<span class="cline-any cline-neutral"> </span>
|
|
585
|
+
<span class="cline-any cline-no"> </span>
|
|
586
|
+
<span class="cline-any cline-no"> </span>
|
|
587
|
+
<span class="cline-any cline-no"> </span>
|
|
588
|
+
<span class="cline-any cline-no"> </span>
|
|
589
|
+
<span class="cline-any cline-no"> </span>
|
|
590
|
+
<span class="cline-any cline-no"> </span>
|
|
591
|
+
<span class="cline-any cline-no"> </span>
|
|
592
|
+
<span class="cline-any cline-no"> </span>
|
|
593
|
+
<span class="cline-any cline-neutral"> </span>
|
|
594
|
+
<span class="cline-any cline-neutral"> </span>
|
|
595
|
+
<span class="cline-any cline-no"> </span>
|
|
596
|
+
<span class="cline-any cline-no"> </span>
|
|
597
|
+
<span class="cline-any cline-neutral"> </span>
|
|
598
|
+
<span class="cline-any cline-no"> </span>
|
|
599
|
+
<span class="cline-any cline-no"> </span>
|
|
600
|
+
<span class="cline-any cline-no"> </span>
|
|
601
|
+
<span class="cline-any cline-no"> </span>
|
|
602
|
+
<span class="cline-any cline-no"> </span>
|
|
603
|
+
<span class="cline-any cline-no"> </span>
|
|
604
|
+
<span class="cline-any cline-no"> </span>
|
|
605
|
+
<span class="cline-any cline-no"> </span>
|
|
606
|
+
<span class="cline-any cline-no"> </span>
|
|
607
|
+
<span class="cline-any cline-no"> </span>
|
|
608
|
+
<span class="cline-any cline-neutral"> </span>
|
|
609
|
+
<span class="cline-any cline-neutral"> </span>
|
|
610
|
+
<span class="cline-any cline-neutral"> </span>
|
|
611
|
+
<span class="cline-any cline-no"> </span>
|
|
612
|
+
<span class="cline-any cline-neutral"> </span>
|
|
613
|
+
<span class="cline-any cline-neutral"> </span>
|
|
614
|
+
<span class="cline-any cline-no"> </span>
|
|
615
|
+
<span class="cline-any cline-no"> </span>
|
|
616
|
+
<span class="cline-any cline-no"> </span>
|
|
617
|
+
<span class="cline-any cline-no"> </span>
|
|
618
|
+
<span class="cline-any cline-neutral"> </span>
|
|
619
|
+
<span class="cline-any cline-no"> </span>
|
|
620
|
+
<span class="cline-any cline-no"> </span>
|
|
621
|
+
<span class="cline-any cline-no"> </span>
|
|
622
|
+
<span class="cline-any cline-no"> </span>
|
|
623
|
+
<span class="cline-any cline-neutral"> </span>
|
|
624
|
+
<span class="cline-any cline-no"> </span>
|
|
625
|
+
<span class="cline-any cline-no"> </span>
|
|
626
|
+
<span class="cline-any cline-no"> </span>
|
|
627
|
+
<span class="cline-any cline-no"> </span>
|
|
628
|
+
<span class="cline-any cline-no"> </span>
|
|
629
|
+
<span class="cline-any cline-no"> </span>
|
|
630
|
+
<span class="cline-any cline-no"> </span>
|
|
631
|
+
<span class="cline-any cline-neutral"> </span>
|
|
632
|
+
<span class="cline-any cline-neutral"> </span>
|
|
633
|
+
<span class="cline-any cline-no"> </span>
|
|
634
|
+
<span class="cline-any cline-neutral"> </span>
|
|
635
|
+
<span class="cline-any cline-no"> </span>
|
|
636
|
+
<span class="cline-any cline-no"> </span>
|
|
637
|
+
<span class="cline-any cline-no"> </span>
|
|
638
|
+
<span class="cline-any cline-no"> </span>
|
|
639
|
+
<span class="cline-any cline-no"> </span>
|
|
640
|
+
<span class="cline-any cline-no"> </span>
|
|
641
|
+
<span class="cline-any cline-no"> </span>
|
|
642
|
+
<span class="cline-any cline-no"> </span>
|
|
643
|
+
<span class="cline-any cline-no"> </span>
|
|
644
|
+
<span class="cline-any cline-no"> </span>
|
|
645
|
+
<span class="cline-any cline-no"> </span>
|
|
646
|
+
<span class="cline-any cline-no"> </span>
|
|
647
|
+
<span class="cline-any cline-neutral"> </span>
|
|
648
|
+
<span class="cline-any cline-no"> </span>
|
|
649
|
+
<span class="cline-any cline-no"> </span>
|
|
650
|
+
<span class="cline-any cline-neutral"> </span>
|
|
651
|
+
<span class="cline-any cline-neutral"> </span>
|
|
652
|
+
<span class="cline-any cline-no"> </span>
|
|
653
|
+
<span class="cline-any cline-no"> </span>
|
|
654
|
+
<span class="cline-any cline-no"> </span>
|
|
655
|
+
<span class="cline-any cline-no"> </span>
|
|
656
|
+
<span class="cline-any cline-neutral"> </span>
|
|
657
|
+
<span class="cline-any cline-neutral"> </span>
|
|
658
|
+
<span class="cline-any cline-no"> </span>
|
|
659
|
+
<span class="cline-any cline-no"> </span>
|
|
660
|
+
<span class="cline-any cline-neutral"> </span>
|
|
661
|
+
<span class="cline-any cline-neutral"> </span>
|
|
662
|
+
<span class="cline-any cline-neutral"> </span>
|
|
663
|
+
<span class="cline-any cline-no"> </span>
|
|
664
|
+
<span class="cline-any cline-neutral"> </span>
|
|
665
|
+
<span class="cline-any cline-neutral"> </span>
|
|
666
|
+
<span class="cline-any cline-no"> </span>
|
|
667
|
+
<span class="cline-any cline-no"> </span>
|
|
668
|
+
<span class="cline-any cline-no"> </span>
|
|
669
|
+
<span class="cline-any cline-neutral"> </span>
|
|
670
|
+
<span class="cline-any cline-no"> </span>
|
|
671
|
+
<span class="cline-any cline-no"> </span>
|
|
672
|
+
<span class="cline-any cline-no"> </span>
|
|
673
|
+
<span class="cline-any cline-no"> </span>
|
|
674
|
+
<span class="cline-any cline-neutral"> </span>
|
|
675
|
+
<span class="cline-any cline-neutral"> </span>
|
|
676
|
+
<span class="cline-any cline-neutral"> </span>
|
|
677
|
+
<span class="cline-any cline-no"> </span>
|
|
678
|
+
<span class="cline-any cline-no"> </span>
|
|
679
|
+
<span class="cline-any cline-no"> </span>
|
|
680
|
+
<span class="cline-any cline-neutral"> </span>
|
|
681
|
+
<span class="cline-any cline-no"> </span>
|
|
682
|
+
<span class="cline-any cline-neutral"> </span>
|
|
683
|
+
<span class="cline-any cline-neutral"> </span>
|
|
684
|
+
<span class="cline-any cline-neutral"> </span>
|
|
685
|
+
<span class="cline-any cline-no"> </span>
|
|
686
|
+
<span class="cline-any cline-neutral"> </span>
|
|
687
|
+
<span class="cline-any cline-no"> </span>
|
|
688
|
+
<span class="cline-any cline-neutral"> </span>
|
|
689
|
+
<span class="cline-any cline-neutral"> </span>
|
|
690
|
+
<span class="cline-any cline-neutral"> </span>
|
|
691
|
+
<span class="cline-any cline-no"> </span>
|
|
692
|
+
<span class="cline-any cline-neutral"> </span>
|
|
693
|
+
<span class="cline-any cline-no"> </span>
|
|
694
|
+
<span class="cline-any cline-neutral"> </span>
|
|
695
|
+
<span class="cline-any cline-neutral"> </span>
|
|
696
|
+
<span class="cline-any cline-neutral"> </span>
|
|
697
|
+
<span class="cline-any cline-no"> </span>
|
|
698
|
+
<span class="cline-any cline-neutral"> </span>
|
|
699
|
+
<span class="cline-any cline-neutral"> </span>
|
|
700
|
+
<span class="cline-any cline-neutral"> </span>
|
|
701
|
+
<span class="cline-any cline-no"> </span>
|
|
702
|
+
<span class="cline-any cline-neutral"> </span>
|
|
703
|
+
<span class="cline-any cline-neutral"> </span>
|
|
704
|
+
<span class="cline-any cline-neutral"> </span>
|
|
705
|
+
<span class="cline-any cline-no"> </span>
|
|
706
|
+
<span class="cline-any cline-neutral"> </span>
|
|
707
|
+
<span class="cline-any cline-neutral"> </span>
|
|
708
|
+
<span class="cline-any cline-no"> </span>
|
|
709
|
+
<span class="cline-any cline-neutral"> </span>
|
|
710
|
+
<span class="cline-any cline-neutral"> </span>
|
|
711
|
+
<span class="cline-any cline-no"> </span>
|
|
712
|
+
<span class="cline-any cline-neutral"> </span>
|
|
713
|
+
<span class="cline-any cline-no"> </span>
|
|
714
|
+
<span class="cline-any cline-neutral"> </span>
|
|
715
|
+
<span class="cline-any cline-no"> </span>
|
|
716
|
+
<span class="cline-any cline-neutral"> </span>
|
|
717
|
+
<span class="cline-any cline-no"> </span>
|
|
718
|
+
<span class="cline-any cline-neutral"> </span>
|
|
719
|
+
<span class="cline-any cline-neutral"> </span>
|
|
720
|
+
<span class="cline-any cline-no"> </span>
|
|
721
|
+
<span class="cline-any cline-no"> </span>
|
|
722
|
+
<span class="cline-any cline-neutral"> </span>
|
|
723
|
+
<span class="cline-any cline-neutral"> </span>
|
|
724
|
+
<span class="cline-any cline-no"> </span>
|
|
725
|
+
<span class="cline-any cline-no"> </span>
|
|
726
|
+
<span class="cline-any cline-no"> </span>
|
|
727
|
+
<span class="cline-any cline-neutral"> </span>
|
|
728
|
+
<span class="cline-any cline-no"> </span>
|
|
729
|
+
<span class="cline-any cline-no"> </span>
|
|
730
|
+
<span class="cline-any cline-no"> </span>
|
|
731
|
+
<span class="cline-any cline-neutral"> </span>
|
|
732
|
+
<span class="cline-any cline-no"> </span>
|
|
733
|
+
<span class="cline-any cline-no"> </span>
|
|
734
|
+
<span class="cline-any cline-no"> </span>
|
|
735
|
+
<span class="cline-any cline-neutral"> </span>
|
|
736
|
+
<span class="cline-any cline-neutral"> </span>
|
|
737
|
+
<span class="cline-any cline-no"> </span>
|
|
738
|
+
<span class="cline-any cline-neutral"> </span>
|
|
739
|
+
<span class="cline-any cline-neutral"> </span>
|
|
740
|
+
<span class="cline-any cline-neutral"> </span>
|
|
741
|
+
<span class="cline-any cline-no"> </span>
|
|
742
|
+
<span class="cline-any cline-no"> </span>
|
|
743
|
+
<span class="cline-any cline-neutral"> </span>
|
|
744
|
+
<span class="cline-any cline-neutral"> </span>
|
|
745
|
+
<span class="cline-any cline-no"> </span>
|
|
746
|
+
<span class="cline-any cline-neutral"> </span>
|
|
747
|
+
<span class="cline-any cline-neutral"> </span>
|
|
748
|
+
<span class="cline-any cline-no"> </span>
|
|
749
|
+
<span class="cline-any cline-neutral"> </span>
|
|
750
|
+
<span class="cline-any cline-neutral"> </span>
|
|
751
|
+
<span class="cline-any cline-no"> </span>
|
|
752
|
+
<span class="cline-any cline-no"> </span>
|
|
753
|
+
<span class="cline-any cline-no"> </span>
|
|
754
|
+
<span class="cline-any cline-neutral"> </span>
|
|
755
|
+
<span class="cline-any cline-no"> </span>
|
|
756
|
+
<span class="cline-any cline-no"> </span>
|
|
757
|
+
<span class="cline-any cline-no"> </span>
|
|
758
|
+
<span class="cline-any cline-no"> </span>
|
|
759
|
+
<span class="cline-any cline-no"> </span>
|
|
760
|
+
<span class="cline-any cline-neutral"> </span>
|
|
761
|
+
<span class="cline-any cline-neutral"> </span>
|
|
762
|
+
<span class="cline-any cline-no"> </span>
|
|
763
|
+
<span class="cline-any cline-no"> </span>
|
|
764
|
+
<span class="cline-any cline-no"> </span>
|
|
765
|
+
<span class="cline-any cline-neutral"> </span>
|
|
766
|
+
<span class="cline-any cline-no"> </span>
|
|
767
|
+
<span class="cline-any cline-no"> </span>
|
|
768
|
+
<span class="cline-any cline-no"> </span>
|
|
769
|
+
<span class="cline-any cline-neutral"> </span>
|
|
770
|
+
<span class="cline-any cline-no"> </span>
|
|
771
|
+
<span class="cline-any cline-neutral"> </span>
|
|
772
|
+
<span class="cline-any cline-no"> </span>
|
|
773
|
+
<span class="cline-any cline-no"> </span>
|
|
774
|
+
<span class="cline-any cline-neutral"> </span>
|
|
775
|
+
<span class="cline-any cline-no"> </span>
|
|
776
|
+
<span class="cline-any cline-no"> </span>
|
|
777
|
+
<span class="cline-any cline-neutral"> </span>
|
|
778
|
+
<span class="cline-any cline-no"> </span>
|
|
779
|
+
<span class="cline-any cline-no"> </span>
|
|
780
|
+
<span class="cline-any cline-neutral"> </span>
|
|
781
|
+
<span class="cline-any cline-no"> </span>
|
|
782
|
+
<span class="cline-any cline-no"> </span>
|
|
783
|
+
<span class="cline-any cline-neutral"> </span>
|
|
784
|
+
<span class="cline-any cline-no"> </span>
|
|
785
|
+
<span class="cline-any cline-neutral"> </span>
|
|
786
|
+
<span class="cline-any cline-no"> </span>
|
|
787
|
+
<span class="cline-any cline-no"> </span>
|
|
788
|
+
<span class="cline-any cline-neutral"> </span>
|
|
789
|
+
<span class="cline-any cline-neutral"> </span>
|
|
790
|
+
<span class="cline-any cline-no"> </span>
|
|
791
|
+
<span class="cline-any cline-no"> </span>
|
|
792
|
+
<span class="cline-any cline-no"> </span>
|
|
793
|
+
<span class="cline-any cline-neutral"> </span>
|
|
794
|
+
<span class="cline-any cline-no"> </span>
|
|
795
|
+
<span class="cline-any cline-no"> </span>
|
|
796
|
+
<span class="cline-any cline-no"> </span>
|
|
797
|
+
<span class="cline-any cline-no"> </span>
|
|
798
|
+
<span class="cline-any cline-no"> </span>
|
|
799
|
+
<span class="cline-any cline-neutral"> </span>
|
|
800
|
+
<span class="cline-any cline-neutral"> </span>
|
|
801
|
+
<span class="cline-any cline-no"> </span>
|
|
802
|
+
<span class="cline-any cline-no"> </span>
|
|
803
|
+
<span class="cline-any cline-no"> </span>
|
|
804
|
+
<span class="cline-any cline-no"> </span>
|
|
805
|
+
<span class="cline-any cline-neutral"> </span>
|
|
806
|
+
<span class="cline-any cline-no"> </span>
|
|
807
|
+
<span class="cline-any cline-neutral"> </span>
|
|
808
|
+
<span class="cline-any cline-no"> </span>
|
|
809
|
+
<span class="cline-any cline-neutral"> </span>
|
|
810
|
+
<span class="cline-any cline-no"> </span>
|
|
811
|
+
<span class="cline-any cline-neutral"> </span>
|
|
812
|
+
<span class="cline-any cline-no"> </span>
|
|
813
|
+
<span class="cline-any cline-neutral"> </span>
|
|
814
|
+
<span class="cline-any cline-no"> </span>
|
|
815
|
+
<span class="cline-any cline-neutral"> </span>
|
|
816
|
+
<span class="cline-any cline-no"> </span>
|
|
817
|
+
<span class="cline-any cline-neutral"> </span>
|
|
818
|
+
<span class="cline-any cline-neutral"> </span>
|
|
819
|
+
<span class="cline-any cline-no"> </span>
|
|
820
|
+
<span class="cline-any cline-neutral"> </span>
|
|
821
|
+
<span class="cline-any cline-no"> </span>
|
|
822
|
+
<span class="cline-any cline-neutral"> </span>
|
|
823
|
+
<span class="cline-any cline-no"> </span>
|
|
824
|
+
<span class="cline-any cline-neutral"> </span>
|
|
825
|
+
<span class="cline-any cline-no"> </span>
|
|
826
|
+
<span class="cline-any cline-neutral"> </span>
|
|
827
|
+
<span class="cline-any cline-no"> </span>
|
|
828
|
+
<span class="cline-any cline-neutral"> </span>
|
|
829
|
+
<span class="cline-any cline-no"> </span>
|
|
830
|
+
<span class="cline-any cline-neutral"> </span>
|
|
831
|
+
<span class="cline-any cline-neutral"> </span>
|
|
832
|
+
<span class="cline-any cline-no"> </span>
|
|
833
|
+
<span class="cline-any cline-neutral"> </span>
|
|
834
|
+
<span class="cline-any cline-no"> </span>
|
|
835
|
+
<span class="cline-any cline-neutral"> </span>
|
|
836
|
+
<span class="cline-any cline-no"> </span>
|
|
837
|
+
<span class="cline-any cline-neutral"> </span>
|
|
838
|
+
<span class="cline-any cline-no"> </span>
|
|
839
|
+
<span class="cline-any cline-neutral"> </span>
|
|
840
|
+
<span class="cline-any cline-no"> </span>
|
|
841
|
+
<span class="cline-any cline-neutral"> </span>
|
|
842
|
+
<span class="cline-any cline-no"> </span>
|
|
843
|
+
<span class="cline-any cline-neutral"> </span>
|
|
844
|
+
<span class="cline-any cline-neutral"> </span>
|
|
845
|
+
<span class="cline-any cline-no"> </span>
|
|
846
|
+
<span class="cline-any cline-neutral"> </span>
|
|
847
|
+
<span class="cline-any cline-neutral"> </span>
|
|
848
|
+
<span class="cline-any cline-neutral"> </span>
|
|
849
|
+
<span class="cline-any cline-no"> </span>
|
|
850
|
+
<span class="cline-any cline-no"> </span>
|
|
851
|
+
<span class="cline-any cline-neutral"> </span>
|
|
852
|
+
<span class="cline-any cline-no"> </span>
|
|
853
|
+
<span class="cline-any cline-neutral"> </span>
|
|
854
|
+
<span class="cline-any cline-neutral"> </span>
|
|
855
|
+
<span class="cline-any cline-no"> </span>
|
|
856
|
+
<span class="cline-any cline-neutral"> </span>
|
|
857
|
+
<span class="cline-any cline-neutral"> </span>
|
|
858
|
+
<span class="cline-any cline-neutral"> </span>
|
|
859
|
+
<span class="cline-any cline-neutral"> </span>
|
|
860
|
+
<span class="cline-any cline-neutral"> </span>
|
|
861
|
+
<span class="cline-any cline-neutral"> </span>
|
|
862
|
+
<span class="cline-any cline-neutral"> </span>
|
|
863
|
+
<span class="cline-any cline-neutral"> </span>
|
|
864
|
+
<span class="cline-any cline-neutral"> </span>
|
|
865
|
+
<span class="cline-any cline-neutral"> </span>
|
|
866
|
+
<span class="cline-any cline-neutral"> </span>
|
|
867
|
+
<span class="cline-any cline-neutral"> </span>
|
|
868
|
+
<span class="cline-any cline-neutral"> </span>
|
|
869
|
+
<span class="cline-any cline-neutral"> </span>
|
|
870
|
+
<span class="cline-any cline-neutral"> </span>
|
|
871
|
+
<span class="cline-any cline-neutral"> </span>
|
|
872
|
+
<span class="cline-any cline-neutral"> </span>
|
|
873
|
+
<span class="cline-any cline-neutral"> </span>
|
|
874
|
+
<span class="cline-any cline-neutral"> </span>
|
|
875
|
+
<span class="cline-any cline-neutral"> </span>
|
|
876
|
+
<span class="cline-any cline-neutral"> </span>
|
|
877
|
+
<span class="cline-any cline-neutral"> </span>
|
|
878
|
+
<span class="cline-any cline-neutral"> </span>
|
|
879
|
+
<span class="cline-any cline-neutral"> </span>
|
|
880
|
+
<span class="cline-any cline-neutral"> </span>
|
|
881
|
+
<span class="cline-any cline-neutral"> </span>
|
|
882
|
+
<span class="cline-any cline-neutral"> </span>
|
|
883
|
+
<span class="cline-any cline-neutral"> </span>
|
|
884
|
+
<span class="cline-any cline-neutral"> </span>
|
|
885
|
+
<span class="cline-any cline-neutral"> </span>
|
|
886
|
+
<span class="cline-any cline-neutral"> </span>
|
|
887
|
+
<span class="cline-any cline-neutral"> </span>
|
|
888
|
+
<span class="cline-any cline-neutral"> </span>
|
|
889
|
+
<span class="cline-any cline-neutral"> </span>
|
|
890
|
+
<span class="cline-any cline-neutral"> </span>
|
|
891
|
+
<span class="cline-any cline-neutral"> </span>
|
|
892
|
+
<span class="cline-any cline-neutral"> </span>
|
|
893
|
+
<span class="cline-any cline-neutral"> </span>
|
|
894
|
+
<span class="cline-any cline-neutral"> </span>
|
|
895
|
+
<span class="cline-any cline-neutral"> </span>
|
|
896
|
+
<span class="cline-any cline-neutral"> </span>
|
|
897
|
+
<span class="cline-any cline-neutral"> </span>
|
|
898
|
+
<span class="cline-any cline-neutral"> </span>
|
|
899
|
+
<span class="cline-any cline-neutral"> </span>
|
|
900
|
+
<span class="cline-any cline-neutral"> </span>
|
|
901
|
+
<span class="cline-any cline-neutral"> </span>
|
|
902
|
+
<span class="cline-any cline-neutral"> </span>
|
|
903
|
+
<span class="cline-any cline-neutral"> </span>
|
|
904
|
+
<span class="cline-any cline-neutral"> </span>
|
|
905
|
+
<span class="cline-any cline-neutral"> </span>
|
|
906
|
+
<span class="cline-any cline-neutral"> </span>
|
|
907
|
+
<span class="cline-any cline-neutral"> </span>
|
|
908
|
+
<span class="cline-any cline-neutral"> </span>
|
|
909
|
+
<span class="cline-any cline-neutral"> </span>
|
|
910
|
+
<span class="cline-any cline-neutral"> </span>
|
|
911
|
+
<span class="cline-any cline-neutral"> </span>
|
|
912
|
+
<span class="cline-any cline-neutral"> </span>
|
|
913
|
+
<span class="cline-any cline-neutral"> </span>
|
|
914
|
+
<span class="cline-any cline-neutral"> </span>
|
|
915
|
+
<span class="cline-any cline-neutral"> </span>
|
|
916
|
+
<span class="cline-any cline-neutral"> </span>
|
|
917
|
+
<span class="cline-any cline-neutral"> </span>
|
|
918
|
+
<span class="cline-any cline-neutral"> </span>
|
|
919
|
+
<span class="cline-any cline-neutral"> </span>
|
|
920
|
+
<span class="cline-any cline-neutral"> </span>
|
|
921
|
+
<span class="cline-any cline-neutral"> </span>
|
|
922
|
+
<span class="cline-any cline-neutral"> </span>
|
|
923
|
+
<span class="cline-any cline-neutral"> </span>
|
|
924
|
+
<span class="cline-any cline-neutral"> </span>
|
|
925
|
+
<span class="cline-any cline-neutral"> </span>
|
|
926
|
+
<span class="cline-any cline-neutral"> </span>
|
|
927
|
+
<span class="cline-any cline-neutral"> </span>
|
|
928
|
+
<span class="cline-any cline-neutral"> </span>
|
|
929
|
+
<span class="cline-any cline-neutral"> </span>
|
|
930
|
+
<span class="cline-any cline-neutral"> </span>
|
|
931
|
+
<span class="cline-any cline-neutral"> </span>
|
|
932
|
+
<span class="cline-any cline-neutral"> </span>
|
|
933
|
+
<span class="cline-any cline-neutral"> </span>
|
|
934
|
+
<span class="cline-any cline-neutral"> </span>
|
|
935
|
+
<span class="cline-any cline-neutral"> </span>
|
|
936
|
+
<span class="cline-any cline-neutral"> </span>
|
|
937
|
+
<span class="cline-any cline-neutral"> </span>
|
|
938
|
+
<span class="cline-any cline-neutral"> </span>
|
|
939
|
+
<span class="cline-any cline-neutral"> </span>
|
|
940
|
+
<span class="cline-any cline-neutral"> </span>
|
|
941
|
+
<span class="cline-any cline-neutral"> </span>
|
|
942
|
+
<span class="cline-any cline-neutral"> </span>
|
|
943
|
+
<span class="cline-any cline-neutral"> </span>
|
|
944
|
+
<span class="cline-any cline-neutral"> </span>
|
|
945
|
+
<span class="cline-any cline-neutral"> </span>
|
|
946
|
+
<span class="cline-any cline-neutral"> </span>
|
|
947
|
+
<span class="cline-any cline-neutral"> </span>
|
|
948
|
+
<span class="cline-any cline-neutral"> </span>
|
|
949
|
+
<span class="cline-any cline-neutral"> </span>
|
|
950
|
+
<span class="cline-any cline-neutral"> </span>
|
|
951
|
+
<span class="cline-any cline-neutral"> </span>
|
|
952
|
+
<span class="cline-any cline-neutral"> </span>
|
|
953
|
+
<span class="cline-any cline-neutral"> </span>
|
|
954
|
+
<span class="cline-any cline-neutral"> </span>
|
|
955
|
+
<span class="cline-any cline-neutral"> </span>
|
|
956
|
+
<span class="cline-any cline-neutral"> </span>
|
|
957
|
+
<span class="cline-any cline-neutral"> </span>
|
|
958
|
+
<span class="cline-any cline-neutral"> </span>
|
|
959
|
+
<span class="cline-any cline-neutral"> </span>
|
|
960
|
+
<span class="cline-any cline-neutral"> </span>
|
|
961
|
+
<span class="cline-any cline-neutral"> </span>
|
|
962
|
+
<span class="cline-any cline-neutral"> </span>
|
|
963
|
+
<span class="cline-any cline-neutral"> </span>
|
|
964
|
+
<span class="cline-any cline-neutral"> </span>
|
|
965
|
+
<span class="cline-any cline-neutral"> </span>
|
|
966
|
+
<span class="cline-any cline-neutral"> </span>
|
|
967
|
+
<span class="cline-any cline-neutral"> </span>
|
|
968
|
+
<span class="cline-any cline-neutral"> </span>
|
|
969
|
+
<span class="cline-any cline-neutral"> </span>
|
|
970
|
+
<span class="cline-any cline-neutral"> </span>
|
|
971
|
+
<span class="cline-any cline-neutral"> </span>
|
|
972
|
+
<span class="cline-any cline-neutral"> </span>
|
|
973
|
+
<span class="cline-any cline-neutral"> </span>
|
|
974
|
+
<span class="cline-any cline-neutral"> </span>
|
|
975
|
+
<span class="cline-any cline-neutral"> </span>
|
|
976
|
+
<span class="cline-any cline-neutral"> </span>
|
|
977
|
+
<span class="cline-any cline-neutral"> </span>
|
|
978
|
+
<span class="cline-any cline-neutral"> </span>
|
|
979
|
+
<span class="cline-any cline-neutral"> </span>
|
|
980
|
+
<span class="cline-any cline-neutral"> </span>
|
|
981
|
+
<span class="cline-any cline-neutral"> </span>
|
|
982
|
+
<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import {
|
|
983
|
+
EpmQueryBuilderOptions,
|
|
984
|
+
FilterConfig,
|
|
985
|
+
RankingConfig,
|
|
986
|
+
} fr<span class="fstat-no" title="function not covered" >om</span> '@epm-query-builder/types/query-builder-types';
|
|
987
|
+
import {<span class="cstat-no" title="statement not covered" > BaseUtilities } from '@</span>epm-query-builder/base/BaseUtilities';
|
|
988
|
+
import { SharedFilterBuilder } from '@epm-query-builder/base/SharedFilterBuilder';
|
|
989
|
+
impo<span class="fstat-no" title="function not covered" >rt</span> { mapAggregationType as mapAgg } from '@epm-query-builder/constants/Aggregations';
|
|
990
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
991
|
+
export abstract class BaseCTEGenerator {
|
|
992
|
+
pr<span class="fstat-no" title="function not covered" >ot</span>ected options: EpmQueryBuilderOptions;
|
|
993
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
994
|
+
constructor(options: EpmQu<span class="cstat-no" title="statement not covered" >eryBuilderOptions) {</span>
|
|
995
|
+
this<span class="cstat-no" title="statement not covered" >.options = options;</span>
|
|
996
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
997
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
998
|
+
protected generateCTE(name: string, query: string): string {
|
|
999
|
+
<span class="fstat-no" title="function not covered" > re</span>turn BaseUtilities.buildCTETemplate(name, query);
|
|
1000
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1001
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1002
|
+
protected <span class="cstat-no" title="statement not covered" >buildFilter</span>CTE(filter: FilterConfig, counter: number): string {
|
|
1003
|
+
const variableName = `filter_${counter}`;
|
|
1004
|
+
const specificCTE =<span class="cstat-no" title="statement not covered" > this.buildSpecificFil</span>terCTE(filter, variableName);
|
|
1005
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1006
|
+
if (!specificCTE) retu<span class="cstat-no" title="statement not covered" >rn '';</span>
|
|
1007
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1008
|
+
return t<span class="cstat-no" title="statement not covered" >his.generat</span>eCTE(variableName, specificCTE);
|
|
1009
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1010
|
+
|
|
1011
|
+
pr<span class="fstat-no" title="function not covered" >ot</span>ected buildBasicFilterCTE(filter: FilterConfig, _variableName?: string): string {
|
|
1012
|
+
void<span class="cstat-no" title="statement not covered" > _variableName;</span>
|
|
1013
|
+
if (<span class="cstat-no" title="statement not covered" >!filter.columnNames?.length || !filter.tableNames?.length) {</span>
|
|
1014
|
+
return<span class="cstat-no" title="statement not covered" > '';</span>
|
|
1015
|
+
}
|
|
1016
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1017
|
+
const column = filte<span class="cstat-no" title="statement not covered" >r.columnNames[0];</span>
|
|
1018
|
+
cons<span class="cstat-no" title="statement not covered" >t tableName = filter.tableNames[0];</span>
|
|
1019
|
+
const co<span class="cstat-no" title="statement not covered" >ndition = S</span>haredFilterBuilder.buildFilterCondition(filter);
|
|
1020
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1021
|
+
if (!conditio<span class="fstat-no" title="function not covered" >n)</span> return '';
|
|
1022
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1023
|
+
return B<span class="cstat-no" title="statement not covered" >aseUtilities.buildDistinctSelect([column], tableName, condition);</span>
|
|
1024
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1025
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1026
|
+
protected buildTupl<span class="fstat-no" title="function not covered" >eF</span>ilterCTE(fil<span class="cstat-no" title="statement not covered" >ter: FilterConfig, _variableName: string): string {</span>
|
|
1027
|
+
void _variableName;
|
|
1028
|
+
if (!fil<span class="cstat-no" title="statement not covered" >ter.columnNames?.length || filte</span>r.columnNames.length < 2) {
|
|
1029
|
+
return this.buildBasicFilterCTE(filter);
|
|
1030
|
+
}<span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" ></span></span>
|
|
1031
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1032
|
+
const ta<span class="cstat-no" title="statement not covered" >bleName = f</span>ilter.tableNames?.[0] || '';
|
|
1033
|
+
const columns = filter.c<span class="cstat-no" title="statement not covered" >olumnNames;</span>
|
|
1034
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1035
|
+
if (!filter.valuesFilter?.l<span class="cstat-no" title="statement not covered" >ength) return '';</span>
|
|
1036
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1037
|
+
const tupleConditions = filter.valuesFilter
|
|
1038
|
+
<span class="fstat-no" title="function not covered" ></span> .map((vf) => {
|
|
1039
|
+
const ids = Array.i<span class="cstat-no" title="statement not covered" >sArray(vf.id) ? vf.id : [vf.id];</span>
|
|
1040
|
+
<span class="cstat-no" title="statement not covered" > if (ids.length !== columns.length) return null;</span>
|
|
1041
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1042
|
+
const columnValuePairs = columns
|
|
1043
|
+
.map((col, idx) <span class="cstat-no" title="statement not covered" >=> `${col} = ${BaseUtilities.formatValue(ids[idx]</span>.toString())}`)
|
|
1044
|
+
<span class="cstat-no" title="statement not covered" > .join(' AND ');</span>
|
|
1045
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1046
|
+
return `(${colu<span class="cstat-no" title="statement not covered" >mnValuePairs})`;</span>
|
|
1047
|
+
})<span class="cstat-no" title="statement not covered" ></span>
|
|
1048
|
+
.f<span class="cstat-no" title="statement not covered" >ilter((condition): condition is string => Boolean(condition));</span>
|
|
1049
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1050
|
+
if (<span class="cstat-no" title="statement not covered" >!tupleConditions.length) return '';</span>
|
|
1051
|
+
|
|
1052
|
+
<span class="fstat-no" title="function not covered" > co</span>nst tupleClause = BaseUtilities.combineConditions(tupleConditions, 'OR');
|
|
1053
|
+
cons<span class="cstat-no" title="statement not covered" >t isExclude = filter.valuesFilterApplicationType?.toUpperCase() === 'EXCLUDE';</span>
|
|
1054
|
+
const fi<span class="cstat-no" title="statement not covered" >nalConditio</span>n = isExclude ? `NOT (${tupleClause})` : `(${tupleClause})`;
|
|
1055
|
+
|
|
1056
|
+
return BaseUtilities.bu<span class="cstat-no" title="statement not covered" >ild</span>DistinctSelect(columns, tableName, finalCondition);
|
|
1057
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1058
|
+
<span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" ></span></span>
|
|
1059
|
+
protected buildComplexFil<span class="cstat-no" title="statement not covered" >terCTE(filter:</span> FilterConfig, variableName: string): string {
|
|
1060
|
+
const fi<span class="cstat-no" title="statement not covered" >lterType = filter.filterType?.toUpperCase();</span>
|
|
1061
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1062
|
+
if (filt<span class="cstat-no" title="statement not covered" >erType === 'TUPLE') {</span>
|
|
1063
|
+
return this.buildTuple<span class="cstat-no" title="statement not covered" >FilterCTE(filter, variableName);</span>
|
|
1064
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1065
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1066
|
+
const condition = SharedFilterBuilder.buildFilterCondition(filter);
|
|
1067
|
+
if (!condition) return '';
|
|
1068
|
+
|
|
1069
|
+
cons<span class="cstat-no" title="statement not covered" >t column = filter.columnNames?.[0];</span>
|
|
1070
|
+
const tableName = filter.tableNames?.[0] || '';
|
|
1071
|
+
<span class="fstat-no" title="function not covered" > if</span> (!column) return '';
|
|
1072
|
+
retu<span class="cstat-no" title="statement not covered" >rn BaseUtilities.bui</span>ldDistinctSelect([column], tableName, condition);
|
|
1073
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1074
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1075
|
+
generateFi<span class="cstat-no" title="statement not covered" >lterCTEs():</span> string {
|
|
1076
|
+
if (!this.options.superFilters?.children) {
|
|
1077
|
+
return '';<span class="cstat-no" title="statement not covered" ></span>
|
|
1078
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1079
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1080
|
+
const fi<span class="cstat-no" title="statement not covered" >lterCTEs: string[] = [];</span>
|
|
1081
|
+
let variableCounter = 1;
|
|
1082
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1083
|
+
this.options.<span class="fstat-no" title="function not covered" >su</span>perFilters.childr<span class="cstat-no" title="statement not covered" >en.forEach((child) => {</span>
|
|
1084
|
+
const filter =<span class="fstat-no" title="function not covered" > c</span>hild.filt<span class="cstat-no" title="statement not covered" >ers;</span>
|
|
1085
|
+
if<span class="cstat-no" title="statement not covered" > (!filter) return;</span>
|
|
1086
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1087
|
+
if (this.isComplexF<span class="cstat-no" title="statement not covered" >ilter(filter)) {</span>
|
|
1088
|
+
<span class="cstat-no" title="statement not covered" > const cte = this.buildFilterCTE(filter, v</span>ariableCounter++);
|
|
1089
|
+
if (cte) {
|
|
1090
|
+
<span class="fstat-no" title="function not covered" ></span> filterCTEs.push(cte);
|
|
1091
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1092
|
+
}
|
|
1093
|
+
});<span class="cstat-no" title="statement not covered" ></span>
|
|
1094
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1095
|
+
return filterCTEs.leng<span class="cstat-no" title="statement not covered" >th > 0 ? `WITH ${filterCTEs.join(',\n')}` :</span> '';
|
|
1096
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1097
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1098
|
+
protected buildRankingFi<span class="cstat-no" title="statement not covered" >lterCTE(filter: FilterConfig, _variableName: string): string {</span>
|
|
1099
|
+
void<span class="cstat-no" title="statement not covered" > _variableName;</span>
|
|
1100
|
+
const rankingConfigs =<span class="cstat-no" title="statement not covered" ></span>
|
|
1101
|
+
filter.rankingFilter || (f<span class="cstat-no" title="statement not covered" >ilter.rankingConfig ? [fil</span>ter.rankingConfig] : []);
|
|
1102
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1103
|
+
if (!rankingConfigs.length |<span class="cstat-no" title="statement not covered" >| !filter.columnNames?.length) {</span>
|
|
1104
|
+
return<span class="cstat-no" title="statement not covered" > '';</span>
|
|
1105
|
+
}
|
|
1106
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1107
|
+
cons<span class="cstat-no" title="statement not covered" >t column = filter.columnNames[0];</span>
|
|
1108
|
+
const tableName = filter.tableNames?.[0] || '';
|
|
1109
|
+
<span class="fstat-no" title="function not covered" ></span>
|
|
1110
|
+
if (<span class="cstat-no" title="statement not covered" >rankingConfigs.length === 1) {</span>
|
|
1111
|
+
return this.buildSingleRanking<span class="cstat-no" title="statement not covered" >CTE(filter, rank</span>ingConfigs[0], column, tableName);
|
|
1112
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1113
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1114
|
+
const cteQueries = rankingConfigs
|
|
1115
|
+
.map((rankingConfig) => this.buildSingleRankingCTE(filter, rankingConfig, column, tableName))
|
|
1116
|
+
.filter((query) => query);<span class="cstat-no" title="statement not covered" ></span>
|
|
1117
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1118
|
+
if (!cteQueries.length) return '';
|
|
1119
|
+
|
|
1120
|
+
<span class="fstat-no" title="function not covered" > co</span>nst operator = filter.logicalOperator?.toUpperCase() === 'OR' ? 'UNION' : 'INTERSECT';
|
|
1121
|
+
retu<span class="cstat-no" title="statement not covered" >rn cteQueries.join(` ${operator}</span> `);
|
|
1122
|
+
}
|
|
1123
|
+
<span class="fstat-no" title="function not covered" ></span>
|
|
1124
|
+
privat<span class="cstat-no" title="statement not covered" >e buildSingleRanking</span>CTE(
|
|
1125
|
+
filt<span class="cstat-no" title="statement not covered" >er: FilterConfig,</span>
|
|
1126
|
+
rankingC<span class="cstat-no" title="statement not covered" >onfig: Rank</span>ingConfig,
|
|
1127
|
+
column: string,
|
|
1128
|
+
tableName: string,<span class="cstat-no" title="statement not covered" ></span>
|
|
1129
|
+
): string {<span class="cstat-no" title="statement not covered" ></span>
|
|
1130
|
+
const rankByColumnId =<span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" ></span></span>
|
|
1131
|
+
rankingConfig.rankByColu<span class="cstat-no" title="statement not covered" >mnId ||</span>
|
|
1132
|
+
`${rankingConfig.rankByTableName || ''}[${rankingConfig.rankByColumnName || column}]`;
|
|
1133
|
+
const actualColumnId = BaseUtilities.extractColumnIdFromHierarchy(rankByColumnId);
|
|
1134
|
+
const rankColumn = actualColumnId;
|
|
1135
|
+
const rankTable = ranking<span class="cstat-no" title="statement not covered" >Config.rankByTableName || tabl</span>eName;
|
|
1136
|
+
const aggregationType = this.<span class="cstat-no" title="statement not covered" >mapAggregationType(rankingCon</span>fig.rankByAggregationType || 'SUM');
|
|
1137
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1138
|
+
const topNValue = this.calculateTopNValue(
|
|
1139
|
+
rankingConfig.<span class="cstat-no" title="statement not covered" >value,</span>
|
|
1140
|
+
filter.distinctRowsCount || 1000000,
|
|
1141
|
+
rankingConfig.isPercentage || false,
|
|
1142
|
+
);
|
|
1143
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1144
|
+
const rankByRef = rankTable ? `"${rankTable}"."${rankColumn}"` : `"${rankColumn}"`;
|
|
1145
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1146
|
+
if (rankingConfig.type === 'BOTH') {
|
|
1147
|
+
const topValue = Math.ceil(topNValue / 2);
|
|
1148
|
+
const bottomValue = Math.floor(topNValue / 2);
|
|
1149
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1150
|
+
const topQuery = this.buildRankingSelectQuery(
|
|
1151
|
+
column,<span class="cstat-no" title="statement not covered" ></span>
|
|
1152
|
+
tableName,
|
|
1153
|
+
rankByRef,
|
|
1154
|
+
aggregationType,
|
|
1155
|
+
'DESC',<span class="cstat-no" title="statement not covered" ></span>
|
|
1156
|
+
topValue,
|
|
1157
|
+
);
|
|
1158
|
+
|
|
1159
|
+
const bottomQu<span class="cstat-no" title="statement not covered" >ery = this.buildRankingSelectQuery(</span>
|
|
1160
|
+
column,
|
|
1161
|
+
tableName,
|
|
1162
|
+
rankByRef,
|
|
1163
|
+
aggregationT<span class="cstat-no" title="statement not covered" >ype,</span>
|
|
1164
|
+
'ASC',
|
|
1165
|
+
bottomValue,
|
|
1166
|
+
);<span class="cstat-no" title="statement not covered" ></span>
|
|
1167
|
+
|
|
1168
|
+
return `(${topQuery}) UNION ALL (${bottomQuery})`;
|
|
1169
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1170
|
+
|
|
1171
|
+
const orderDirec<span class="cstat-no" title="statement not covered" >tion = rankingConfig.type === '</span>TOP' ? 'DESC' : 'ASC';
|
|
1172
|
+
|
|
1173
|
+
return this.buil<span class="cstat-no" title="statement not covered" >dRankingSelectQuery(</span>
|
|
1174
|
+
column,
|
|
1175
|
+
tableName,<span class="cstat-no" title="statement not covered" ></span>
|
|
1176
|
+
rankByRef,
|
|
1177
|
+
aggregationType,
|
|
1178
|
+
orderDirection,<span class="cstat-no" title="statement not covered" ></span>
|
|
1179
|
+
to<span class="cstat-no" title="statement not covered" >pNValue,</span>
|
|
1180
|
+
rankingConfig.isPercentage,
|
|
1181
|
+
<span class="fstat-no" title="function not covered" > );</span>
|
|
1182
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1183
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1184
|
+
private bu<span class="cstat-no" title="statement not covered" >ildRankingS</span>electQuery(
|
|
1185
|
+
column: string,
|
|
1186
|
+
tableName: string,<span class="cstat-no" title="statement not covered" ></span>
|
|
1187
|
+
rankByRef: string,<span class="cstat-no" title="statement not covered" ></span>
|
|
1188
|
+
aggregationType: string,<span class="cstat-no" title="statement not covered" ></span>
|
|
1189
|
+
orderDirection: string,
|
|
1190
|
+
topN<span class="cstat-no" title="statement not covered" >Value: number,</span>
|
|
1191
|
+
isPercen<span class="cstat-no" title="statement not covered" >tage?: boolean,</span>
|
|
1192
|
+
): string {<span class="cstat-no" title="statement not covered" ></span>
|
|
1193
|
+
if (isPercentage) {
|
|
1194
|
+
const percentileValue = topNValue / 100;
|
|
1195
|
+
const cond<span class="cstat-no" title="statement not covered" >ition = `PERCENT_RANK() OVER (ORD</span>ER BY ${aggregationType}(${rankByRef}) ${orderDirection}) <= ${percentileValue}`;
|
|
1196
|
+
return BaseUtilities.buildDistinctSelect([`"${column}"`], `"${tableName}"`, condition);
|
|
1197
|
+
} else {
|
|
1198
|
+
const orderByClause = `${aggregationType}(${rankByRef}) ${orderDirection} LIMIT ${topNValue}`;
|
|
1199
|
+
return<span class="cstat-no" title="statement not covered" > BaseUtilities.buildDistinctSelect(</span>
|
|
1200
|
+
[`"${col<span class="cstat-no" title="statement not covered" >umn}"`],</span>
|
|
1201
|
+
`"${tableName}"`,
|
|
1202
|
+
undefined,
|
|
1203
|
+
orderByC<span class="cstat-no" title="statement not covered" >lause,</span>
|
|
1204
|
+
);
|
|
1205
|
+
}
|
|
1206
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1207
|
+
|
|
1208
|
+
pr<span class="fstat-no" title="function not covered" >iv</span>ate mapAggregationType(aggregationType: string): string {
|
|
1209
|
+
retu<span class="cstat-no" title="statement not covered" >rn mapAgg(aggregatio</span>nType);
|
|
1210
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1211
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1212
|
+
protected buildSearchFilterCTE(filter: FilterConfig, _variableName: string): string {
|
|
1213
|
+
void _variableName;<span class="cstat-no" title="statement not covered" ></span>
|
|
1214
|
+
if (!BaseUtilities.val<span class="cstat-no" title="statement not covered" >idateRequiredFields(filter, [</span>'columnNames', 'searchConditions'])) {
|
|
1215
|
+
return '';<span class="cstat-no" title="statement not covered" ></span>
|
|
1216
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1217
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1218
|
+
const column = filter.columnNames![0];
|
|
1219
|
+
<span class="fstat-no" title="function not covered" > co</span>nst tableName = filter.tableNames?.[0] || '';
|
|
1220
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1221
|
+
cons<span class="cstat-no" title="statement not covered" >t conditions = filter.searchConditions!.map((condition) => {</span>
|
|
1222
|
+
const <span class="cstat-no" title="statement not covered" >canonical =</span> (condition.operator || '')
|
|
1223
|
+
.toLowerCase()
|
|
1224
|
+
.replace(/[^a-z<span class="cstat-no" title="statement not covered" >0-9]+/g, '_')</span>
|
|
1225
|
+
.replace(/^_+|_+$/<span class="cstat-no" title="statement not covered" >g, '');</span>
|
|
1226
|
+
const rawValue = String(co<span class="cstat-no" title="statement not covered" >ndition.value ?? '');</span>
|
|
1227
|
+
const escapedValue = rawValue.replace(/'/g, "''");
|
|
1228
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1229
|
+
switch (canonical) {
|
|
1230
|
+
case 'co<span class="cstat-no" title="statement not covered" >ntains':</span>
|
|
1231
|
+
return<span class="cstat-no" title="statement not covered" > `LOWER</span>(${column}) LIKE LOWER('%${escapedValue}%')`;
|
|
1232
|
+
case 'does_not_contain':
|
|
1233
|
+
case 'no<span class="cstat-no" title="statement not covered" >t_contains':</span>
|
|
1234
|
+
case 'no<span class="cstat-no" title="statement not covered" >t_conta</span>in':
|
|
1235
|
+
return `LOWER(${column}) NOT LIKE LOWER('%${escapedValue}%')`;
|
|
1236
|
+
case 'st<span class="cstat-no" title="statement not covered" >arts_with':</span>
|
|
1237
|
+
return<span class="cstat-no" title="statement not covered" > `LOWER</span>(${column}) LIKE LOWER('${escapedValue}%')`;
|
|
1238
|
+
case 'does_not_start_with':
|
|
1239
|
+
case 'no<span class="cstat-no" title="statement not covered" >t_starts_with':</span>
|
|
1240
|
+
case 'no<span class="cstat-no" title="statement not covered" >t_start</span>_with':
|
|
1241
|
+
return `LOWER(${column}) NOT LIKE LOWER('${escapedValue}%')`;
|
|
1242
|
+
case 'en<span class="cstat-no" title="statement not covered" >ds_with':</span>
|
|
1243
|
+
return `LOWER(${column}) LIKE LOWER('%${escapedValue}')`;
|
|
1244
|
+
case 'does_not_end_wi<span class="cstat-no" title="statement not covered" >th':</span>
|
|
1245
|
+
<span class="cstat-no" title="statement not covered" > case 'not_ends_with':</span>
|
|
1246
|
+
case 'not_end_with':
|
|
1247
|
+
<span class="fstat-no" title="function not covered" ></span> return `LOWER(${column}) NOT LIKE LOWER('%${escapedValue}')`;
|
|
1248
|
+
<span class="cstat-no" title="statement not covered" > case 'equals':</span>
|
|
1249
|
+
<span class="cstat-no" title="statement not covered" > case 'is_equal_to':</span>
|
|
1250
|
+
case<span class="cstat-no" title="statement not covered" > 'is':</span>
|
|
1251
|
+
return `${column} = ${BaseUtilities.formatValue(rawValue)}`;
|
|
1252
|
+
case 'not_equals<span class="cstat-no" title="statement not covered" >':</span>
|
|
1253
|
+
case 'is_not_equal<span class="cstat-no" title="statement not covered" >_to':</span>
|
|
1254
|
+
<span class="cstat-no" title="statement not covered" > case 'is_not':</span>
|
|
1255
|
+
re<span class="cstat-no" title="statement not covered" >turn `${col</span>umn} != ${BaseUtilities.formatValue(rawValue)}`;
|
|
1256
|
+
<span class="cstat-no" title="statement not covered" > case 'is_blank':</span>
|
|
1257
|
+
case 'blank':
|
|
1258
|
+
<span class="fstat-no" title="function not covered" ></span> return `${column} IS NULL`;
|
|
1259
|
+
case 'is_not<span class="cstat-no" title="statement not covered" >_blank':</span>
|
|
1260
|
+
case 'not_blank':<span class="cstat-no" title="statement not covered" ></span>
|
|
1261
|
+
return `${col<span class="cstat-no" title="statement not covered" >umn} IS NOT NU</span>LL`;
|
|
1262
|
+
<span class="cstat-no" title="statement not covered" > case 'is_empty':</span>
|
|
1263
|
+
return `TRIM(${column}) = ''`;
|
|
1264
|
+
case 'is<span class="cstat-no" title="statement not covered" >_not_empty':</span>
|
|
1265
|
+
return `TRIM(${column}) != ''`;
|
|
1266
|
+
default:<span class="cstat-no" title="statement not covered" ></span>
|
|
1267
|
+
return `LOWER(${column}) LIKE LOWER('%${escapedValue}%')`;
|
|
1268
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1269
|
+
});
|
|
1270
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1271
|
+
const whereCondition = BaseUtilities.combineConditions(conditions, 'AND');
|
|
1272
|
+
return BaseUtilities<span class="cstat-no" title="statement not covered" >.buildDistinctSelect([column], tableName, whereCondition);</span>
|
|
1273
|
+
}
|
|
1274
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1275
|
+
protected buildBlankFilterCTE(filter: FilterConfig, _variableName: string): string {
|
|
1276
|
+
void _variableName;
|
|
1277
|
+
if (!BaseUti<span class="cstat-no" title="statement not covered" >lities.validateRequiredFields(filter, ['columnNames', 'blankFilterConfig'])) {</span>
|
|
1278
|
+
return '';
|
|
1279
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1280
|
+
|
|
1281
|
+
const column = filte<span class="cstat-no" title="statement not covered" >r.columnNames![0];</span>
|
|
1282
|
+
const tableName = filter.tableNames?.[0] || '';
|
|
1283
|
+
const blankConfig = <span class="cstat-no" title="statement not covered" >filter.blankFilterConfig!;</span>
|
|
1284
|
+
|
|
1285
|
+
let condition: strin<span class="cstat-no" title="statement not covered" >g;</span>
|
|
1286
|
+
if (blankConfig.operator === 'IS_BLANK') {
|
|
1287
|
+
if (blankConfig.tr<span class="cstat-no" title="statement not covered" >eatEmptyStringAsBlank) {</span>
|
|
1288
|
+
condition = `(${column} IS NULL OR TRIM(${column}) = '')`;
|
|
1289
|
+
} else {
|
|
1290
|
+
conditio<span class="cstat-no" title="statement not covered" >n = `${column} IS NULL`;</span>
|
|
1291
|
+
}
|
|
1292
|
+
} else {<span class="cstat-no" title="statement not covered" ></span>
|
|
1293
|
+
if (blankConfig.treatEmptyStringAsBlank) {
|
|
1294
|
+
condition = `(${<span class="cstat-no" title="statement not covered" >column} IS NOT NULL AND TRIM(${column}) != '')`;</span>
|
|
1295
|
+
} else {
|
|
1296
|
+
condition = `${c<span class="cstat-no" title="statement not covered" >olumn} IS NOT NULL`;</span>
|
|
1297
|
+
}
|
|
1298
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1299
|
+
|
|
1300
|
+
return BaseUtilities<span class="cstat-no" title="statement not covered" >.buildDistinctSelect([column], tableName, condition);</span>
|
|
1301
|
+
}
|
|
1302
|
+
|
|
1303
|
+
protected buil<span class="cstat-no" title="statement not covered" >dRelativePeriodFilterCTE(filt</span>er: FilterConfig, _variableName: string): string {
|
|
1304
|
+
void _variableName;
|
|
1305
|
+
if (!BaseUtilities.validateRequiredFields(filter, ['columnNames', 'relativePeriodFilter'])) {
|
|
1306
|
+
<span class="fstat-no" title="function not covered" ></span> return '';
|
|
1307
|
+
}<span class="cstat-no" title="statement not covered" ></span>
|
|
1308
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
1309
|
+
const column = filter.columnNames![0];
|
|
1310
|
+
cons<span class="cstat-no" title="statement not covered" >t tableName = filter.tableNames?.[0] || '';</span>
|
|
1311
|
+
const relativePeriod = filter.relativePeriodFilter!;
|
|
1312
|
+
<span class="fstat-no" title="function not covered" ></span>
|
|
1313
|
+
cons<span class="cstat-no" title="statement not covered" >t condition = this.buildRelativePeriodCondition(column, relativePeriod);</span>
|
|
1314
|
+
return BaseUtilities.buildDistinctSelect([column], tableName, condition);
|
|
1315
|
+
}
|
|
1316
|
+
|
|
1317
|
+
protected buildDateHierarchyFilterCTE(filter: FilterConfig, _variableName: string): string {
|
|
1318
|
+
void _variableName;
|
|
1319
|
+
if (!BaseUtilities.validateRequiredFields(filter, ['columnNames', 'dateHierarchyConfig'])) {
|
|
1320
|
+
return '';
|
|
1321
|
+
}
|
|
1322
|
+
|
|
1323
|
+
const column = filter.columnNames![0];
|
|
1324
|
+
const tableName = filter.tableNames?.[0] || '';
|
|
1325
|
+
const hierarchyConfig = filter.dateHierarchyConfig!;
|
|
1326
|
+
|
|
1327
|
+
let hierarchyFunction: string;
|
|
1328
|
+
switch (hierarchyConfig.level) {
|
|
1329
|
+
case 'YEAR':
|
|
1330
|
+
hierarchyFunction = `EXTRACT(YEAR FROM ${column})`;
|
|
1331
|
+
break;
|
|
1332
|
+
case 'QUARTER':
|
|
1333
|
+
hierarchyFunction = `EXTRACT(QUARTER FROM ${column})`;
|
|
1334
|
+
break;
|
|
1335
|
+
case 'MONTH':
|
|
1336
|
+
hierarchyFunction = `EXTRACT(MONTH FROM ${column})`;
|
|
1337
|
+
break;
|
|
1338
|
+
case 'DAY':
|
|
1339
|
+
hierarchyFunction = `EXTRACT(DAY FROM ${column})`;
|
|
1340
|
+
break;
|
|
1341
|
+
default:
|
|
1342
|
+
hierarchyFunction = column;
|
|
1343
|
+
}
|
|
1344
|
+
|
|
1345
|
+
const selectColumn = `${hierarchyFunction} AS ${column}_${hierarchyConfig.level.toLowerCase()}`;
|
|
1346
|
+
return BaseUtilities.buildDistinctSelect([selectColumn], tableName);
|
|
1347
|
+
}
|
|
1348
|
+
|
|
1349
|
+
protected buildFieldParameterFilterCTE(filter: FilterConfig, _variableName: string): string {
|
|
1350
|
+
void _variableName;
|
|
1351
|
+
if (!filter.fieldParameterMapping) {
|
|
1352
|
+
return '';
|
|
1353
|
+
}
|
|
1354
|
+
|
|
1355
|
+
const mapping = filter.fieldParameterMapping;
|
|
1356
|
+
const tableName = mapping.targetTable;
|
|
1357
|
+
|
|
1358
|
+
if (!tableName || !mapping.targetField) return '';
|
|
1359
|
+
|
|
1360
|
+
return BaseUtilities.buildDistinctSelect([mapping.targetField], tableName);
|
|
1361
|
+
}
|
|
1362
|
+
|
|
1363
|
+
protected buildRelativePeriodCondition(
|
|
1364
|
+
column: string,
|
|
1365
|
+
config: { duration: number; period: string; relativeDateFilter: string },
|
|
1366
|
+
): string {
|
|
1367
|
+
const now = 'CURRENT_DATE';
|
|
1368
|
+
const duration = config.duration;
|
|
1369
|
+
const period = config.period;
|
|
1370
|
+
|
|
1371
|
+
switch (config.relativeDateFilter) {
|
|
1372
|
+
case 'IS_IN_THE_LAST':
|
|
1373
|
+
switch (period) {
|
|
1374
|
+
case 'DAYS':
|
|
1375
|
+
return `${column} >= ${now} - INTERVAL '${duration} days'`;
|
|
1376
|
+
case 'WEEKS':
|
|
1377
|
+
return `${column} >= ${now} - INTERVAL '${duration} weeks'`;
|
|
1378
|
+
case 'MONTHS':
|
|
1379
|
+
return `${column} >= ${now} - INTERVAL '${duration} months'`;
|
|
1380
|
+
case 'YEARS':
|
|
1381
|
+
return `${column} >= ${now} - INTERVAL '${duration} years'`;
|
|
1382
|
+
default:
|
|
1383
|
+
return `${column} >= ${now} - INTERVAL '${duration} days'`;
|
|
1384
|
+
}
|
|
1385
|
+
case 'IS_IN_THE_NEXT':
|
|
1386
|
+
switch (period) {
|
|
1387
|
+
case 'DAYS':
|
|
1388
|
+
return `${column} <= ${now} + INTERVAL '${duration} days'`;
|
|
1389
|
+
case 'WEEKS':
|
|
1390
|
+
return `${column} <= ${now} + INTERVAL '${duration} weeks'`;
|
|
1391
|
+
case 'MONTHS':
|
|
1392
|
+
return `${column} <= ${now} + INTERVAL '${duration} months'`;
|
|
1393
|
+
case 'YEARS':
|
|
1394
|
+
return `${column} <= ${now} + INTERVAL '${duration} years'`;
|
|
1395
|
+
default:
|
|
1396
|
+
return `${column} <= ${now} + INTERVAL '${duration} days'`;
|
|
1397
|
+
}
|
|
1398
|
+
case 'IS_IN_THIS':
|
|
1399
|
+
switch (period) {
|
|
1400
|
+
case 'DAYS':
|
|
1401
|
+
return `DATE_TRUNC('day', ${column}) = DATE_TRUNC('day', ${now})`;
|
|
1402
|
+
case 'WEEKS':
|
|
1403
|
+
return `DATE_TRUNC('week', ${column}) = DATE_TRUNC('week', ${now})`;
|
|
1404
|
+
case 'MONTHS':
|
|
1405
|
+
return `DATE_TRUNC('month', ${column}) = DATE_TRUNC('month', ${now})`;
|
|
1406
|
+
case 'YEARS':
|
|
1407
|
+
return `DATE_TRUNC('year', ${column}) = DATE_TRUNC('year', ${now})`;
|
|
1408
|
+
default:
|
|
1409
|
+
return `DATE_TRUNC('day', ${column}) = DATE_TRUNC('day', ${now})`;
|
|
1410
|
+
}
|
|
1411
|
+
default:
|
|
1412
|
+
return `${column} = ${now}`;
|
|
1413
|
+
}
|
|
1414
|
+
}
|
|
1415
|
+
|
|
1416
|
+
private calculateTopNValue(value: number, totalCount: number, isPercentage: boolean): number {
|
|
1417
|
+
if (totalCount === 0 || !isPercentage) {
|
|
1418
|
+
return value;
|
|
1419
|
+
}
|
|
1420
|
+
return Math.floor((value * totalCount) / 100);
|
|
1421
|
+
}
|
|
1422
|
+
|
|
1423
|
+
protected isComplexFilter(filter: FilterConfig): boolean {
|
|
1424
|
+
return Boolean(
|
|
1425
|
+
filter.filterType === 'TUPLE' ||
|
|
1426
|
+
filter.filterType === 'RANKING' ||
|
|
1427
|
+
filter.filterType === 'SEARCH' ||
|
|
1428
|
+
filter.filterType === 'BLANK' ||
|
|
1429
|
+
filter.filterType === 'RELATIVE_PERIOD' ||
|
|
1430
|
+
filter.filterType === 'DATE_HIERARCHY' ||
|
|
1431
|
+
filter.filterType === 'FIELD_PARAMETER' ||
|
|
1432
|
+
filter.isCrossHighlight ||
|
|
1433
|
+
(filter.filterType === 'RANGE' && filter.rangeFilter && filter.rangeFilter.length > 1) ||
|
|
1434
|
+
(filter.filterType === 'VALUES' && filter.valuesFilter && filter.valuesFilter.length > 10),
|
|
1435
|
+
);
|
|
1436
|
+
}
|
|
1437
|
+
|
|
1438
|
+
abstract buildSpecificFilterCTE(filter: FilterConfig, variableName: string): string;
|
|
1439
|
+
}
|
|
1440
|
+
</pre></td></tr></table></pre>
|
|
1441
|
+
|
|
1442
|
+
<div class='push'></div><!-- for sticky footer -->
|
|
1443
|
+
</div><!-- /wrapper -->
|
|
1444
|
+
<div class='footer quiet pad2 space-top1 center small'>
|
|
1445
|
+
Code coverage generated by
|
|
1446
|
+
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
|
|
1447
|
+
at 2025-12-03T07:39:44.024Z
|
|
1448
|
+
</div>
|
|
1449
|
+
<script src="../../../prettify.js"></script>
|
|
1450
|
+
<script>
|
|
1451
|
+
window.onload = function () {
|
|
1452
|
+
prettyPrint();
|
|
1453
|
+
};
|
|
1454
|
+
</script>
|
|
1455
|
+
<script src="../../../sorter.js"></script>
|
|
1456
|
+
<script src="../../../block-navigation.js"></script>
|
|
1457
|
+
</body>
|
|
1458
|
+
</html>
|
|
1459
|
+
|