@dhis2/analytics 26.5.0 → 26.6.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.
Files changed (35) hide show
  1. package/build/cjs/api/analytics/Analytics.js +7 -0
  2. package/build/cjs/api/analytics/AnalyticsBase.js +24 -6
  3. package/build/cjs/api/analytics/AnalyticsRequest.js +33 -10
  4. package/build/cjs/api/analytics/AnalyticsRequestBase.js +3 -1
  5. package/build/cjs/api/analytics/AnalyticsRequestPropertiesMixin.js +19 -0
  6. package/build/cjs/api/analytics/AnalyticsTrackedEntities.js +31 -0
  7. package/build/cjs/api/analytics/utils.js +21 -2
  8. package/build/cjs/locales/cs/translations.json +7 -2
  9. package/build/cjs/locales/zh/translations.json +7 -2
  10. package/build/cjs/modules/layout/axisGetDimensionIds.js +1 -1
  11. package/build/cjs/modules/layout/dimension.js +9 -2
  12. package/build/cjs/modules/layout/dimensionCreate.js +3 -0
  13. package/build/cjs/modules/layout/dimensionGetId.js +9 -3
  14. package/build/cjs/modules/layout/layoutFilterDimensions.js +1 -1
  15. package/build/cjs/modules/layout/layoutGetAxisIdDimensionIdsObject.js +1 -1
  16. package/build/cjs/modules/layout/layoutGetDimensionIdItemIdsObject.js +1 -1
  17. package/build/cjs/modules/layout/layoutHasDynamicDimension.js +1 -1
  18. package/build/es/api/analytics/Analytics.js +7 -0
  19. package/build/es/api/analytics/AnalyticsBase.js +24 -6
  20. package/build/es/api/analytics/AnalyticsRequest.js +33 -10
  21. package/build/es/api/analytics/AnalyticsRequestBase.js +3 -1
  22. package/build/es/api/analytics/AnalyticsRequestPropertiesMixin.js +19 -0
  23. package/build/es/api/analytics/AnalyticsTrackedEntities.js +24 -0
  24. package/build/es/api/analytics/utils.js +18 -1
  25. package/build/es/locales/cs/translations.json +7 -2
  26. package/build/es/locales/zh/translations.json +7 -2
  27. package/build/es/modules/layout/axisGetDimensionIds.js +1 -1
  28. package/build/es/modules/layout/dimension.js +7 -1
  29. package/build/es/modules/layout/dimensionCreate.js +4 -1
  30. package/build/es/modules/layout/dimensionGetId.js +10 -4
  31. package/build/es/modules/layout/layoutFilterDimensions.js +1 -1
  32. package/build/es/modules/layout/layoutGetAxisIdDimensionIdsObject.js +1 -1
  33. package/build/es/modules/layout/layoutGetDimensionIdItemIdsObject.js +1 -1
  34. package/build/es/modules/layout/layoutHasDynamicDimension.js +1 -1
  35. package/package.json +1 -1
@@ -9,6 +9,7 @@ var _AnalyticsEnrollments = _interopRequireDefault(require("./AnalyticsEnrollmen
9
9
  var _AnalyticsEvents = _interopRequireDefault(require("./AnalyticsEvents.js"));
10
10
  var _AnalyticsRequest = _interopRequireDefault(require("./AnalyticsRequest.js"));
11
11
  var _AnalyticsResponse = _interopRequireDefault(require("./AnalyticsResponse.js"));
12
+ var _AnalyticsTrackedEntities = _interopRequireDefault(require("./AnalyticsTrackedEntities.js"));
12
13
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
14
  /**
14
15
  * @module analytics
@@ -19,6 +20,8 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
19
20
  * Analytics class used to request analytics data from Web API.
20
21
  *
21
22
  * @requires analytics.AnalyticsAggregate
23
+ * @requires analytics.AnalyticsTrackedEntities
24
+ * @requires analytics.AnalyticsEnrollments
22
25
  * @requires analytics.AnalyticsEvents
23
26
  * @requires analytics.AnalyticsRequest
24
27
  * @requires analytics.AnalyticsResponse
@@ -38,6 +41,7 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
38
41
  class Analytics {
39
42
  /**
40
43
  * @param {!module:analytics.AnalyticsAggregate} analyticsAggregate The AnalyticsAggregate instance
44
+ * @param {!module:analytics.AnalyticsTrackedEntities} analyticsTrackedEntities The AnalyticsTrackedEntities instance
41
45
  * @param {!module:analytics.AnalyticsEnrollments} analyticsEnrollments The AnalyticsEnrollments instance
42
46
  * @param {!module:analytics.AnalyticsEvents} analyticsEvents The AnalyticsEvents instance
43
47
  * @param {!module:analytics.AnalyticsRequest} analyticsRequest The AnalyticsRequest class
@@ -46,12 +50,14 @@ class Analytics {
46
50
  constructor(_ref) {
47
51
  let {
48
52
  aggregate,
53
+ trackedEntities,
49
54
  enrollments,
50
55
  events,
51
56
  request,
52
57
  response
53
58
  } = _ref;
54
59
  this.aggregate = aggregate;
60
+ this.trackedEntities = trackedEntities;
55
61
  this.enrollments = enrollments;
56
62
  this.events = events;
57
63
  this.request = request;
@@ -74,6 +80,7 @@ class Analytics {
74
80
  if (!Analytics.getAnalytics.analytics) {
75
81
  Analytics.getAnalytics.analytics = new Analytics({
76
82
  aggregate: new _AnalyticsAggregate.default(dataEngine),
83
+ trackedEntities: new _AnalyticsTrackedEntities.default(dataEngine),
77
84
  enrollments: new _AnalyticsEnrollments.default(dataEngine),
78
85
  events: new _AnalyticsEvents.default(dataEngine),
79
86
  request: _AnalyticsRequest.default,
@@ -6,15 +6,21 @@ Object.defineProperty(exports, "__esModule", {
6
6
  exports.generateDimensionStrings = exports.default = void 0;
7
7
  var _sortBy = _interopRequireDefault(require("lodash/sortBy"));
8
8
  var _AnalyticsRequest = _interopRequireDefault(require("./AnalyticsRequest.js"));
9
+ var _utils = require("./utils.js");
9
10
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
10
11
  const analyticsQuery = {
11
12
  resource: 'analytics',
12
13
  id: _ref => {
13
14
  let {
14
15
  path,
15
- program
16
+ program,
17
+ trackedEntityType
16
18
  } = _ref;
17
- return [path, program].filter(Boolean).join('/');
19
+ return (0, _utils.formatRequestPath)({
20
+ path,
21
+ program,
22
+ trackedEntityType
23
+ });
18
24
  },
19
25
  params: _ref2 => {
20
26
  let {
@@ -34,9 +40,14 @@ const analyticsDataQuery = {
34
40
  id: _ref3 => {
35
41
  let {
36
42
  path,
37
- program
43
+ program,
44
+ trackedEntityType
38
45
  } = _ref3;
39
- return [path, program].filter(Boolean).join('/');
46
+ return (0, _utils.formatRequestPath)({
47
+ path,
48
+ program,
49
+ trackedEntityType
50
+ });
40
51
  },
41
52
  params: _ref4 => {
42
53
  let {
@@ -58,9 +69,14 @@ const analyticsMetaDataQuery = {
58
69
  id: _ref5 => {
59
70
  let {
60
71
  path,
61
- program
72
+ program,
73
+ trackedEntityType
62
74
  } = _ref5;
63
- return [path, program].filter(Boolean).join('/');
75
+ return (0, _utils.formatRequestPath)({
76
+ path,
77
+ program,
78
+ trackedEntityType
79
+ });
64
80
  },
65
81
  params: _ref6 => {
66
82
  let {
@@ -153,6 +169,7 @@ class AnalyticsBase {
153
169
  variables: {
154
170
  path: req.path,
155
171
  program: req.program,
172
+ trackedEntityType: req.trackedEntityType,
156
173
  dimensions: generateDimensionStrings(req.dimensions),
157
174
  filters: generateDimensionStrings(req.filters),
158
175
  parameters: req.parameters,
@@ -195,6 +212,7 @@ class AnalyticsBase {
195
212
  variables: {
196
213
  path: req.path,
197
214
  program: req.program,
215
+ trackedEntityType: req.trackedEntityType,
198
216
  dimensions: generateDimensionStrings(req.dimensions, options),
199
217
  filters: generateDimensionStrings(req.filters, options),
200
218
  parameters: req.parameters
@@ -10,6 +10,7 @@ var _AnalyticsRequestBase = _interopRequireDefault(require("./AnalyticsRequestBa
10
10
  var _AnalyticsRequestDimensionsMixin = _interopRequireDefault(require("./AnalyticsRequestDimensionsMixin.js"));
11
11
  var _AnalyticsRequestFiltersMixin = _interopRequireDefault(require("./AnalyticsRequestFiltersMixin.js"));
12
12
  var _AnalyticsRequestPropertiesMixin = _interopRequireDefault(require("./AnalyticsRequestPropertiesMixin.js"));
13
+ var _utils = require("./utils.js");
13
14
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
14
15
  /**
15
16
  * @description
@@ -47,6 +48,7 @@ class AnalyticsRequest extends (0, _AnalyticsRequestDimensionsMixin.default)((0,
47
48
  fromVisualization(visualization) {
48
49
  let passFilterAsDimension = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
49
50
  let request = this;
51
+ const outputType = visualization.outputType;
50
52
 
51
53
  // extract dimensions from visualization
52
54
  const columns = visualization.columns || [];
@@ -57,19 +59,28 @@ class AnalyticsRequest extends (0, _AnalyticsRequestDimensionsMixin.default)((0,
57
59
  if ((_d$legendSet = d.legendSet) !== null && _d$legendSet !== void 0 && _d$legendSet.id) {
58
60
  dimension += `-${d.legendSet.id}`;
59
61
  }
60
- if ((_d$programStage = d.programStage) !== null && _d$programStage !== void 0 && _d$programStage.id) {
61
- dimension = `${d.programStage.id}.${dimension}`;
62
- }
63
62
  if (d.filter) {
64
63
  dimension += `:${d.filter}`;
65
64
  }
65
+ const programStageId = (_d$programStage = d.programStage) === null || _d$programStage === void 0 ? void 0 : _d$programStage.id;
66
66
  if ((_d$repetition = d.repetition) !== null && _d$repetition !== void 0 && (_d$repetition$indexes = _d$repetition.indexes) !== null && _d$repetition$indexes !== void 0 && _d$repetition$indexes.length) {
67
67
  d.repetition.indexes.forEach(index => {
68
- request = request.addDimension(dimension.replace(/\./, `[${index}].`));
68
+ var _d$program;
69
+ request = request.addDimension((0, _utils.formatDimension)({
70
+ programId: (_d$program = d.program) === null || _d$program === void 0 ? void 0 : _d$program.id,
71
+ programStageId: `${programStageId}[${index}]`,
72
+ dimension,
73
+ outputType
74
+ }));
69
75
  });
70
76
  } else {
71
- var _d$items;
72
- request = request.addDimension(dimension, (_d$items = d.items) === null || _d$items === void 0 ? void 0 : _d$items.map(item => item.id));
77
+ var _d$program2, _d$items;
78
+ request = request.addDimension((0, _utils.formatDimension)({
79
+ programId: (_d$program2 = d.program) === null || _d$program2 === void 0 ? void 0 : _d$program2.id,
80
+ programStageId,
81
+ dimension,
82
+ outputType
83
+ }), (_d$items = d.items) === null || _d$items === void 0 ? void 0 : _d$items.map(item => item.id));
73
84
  }
74
85
  });
75
86
 
@@ -84,17 +95,29 @@ class AnalyticsRequest extends (0, _AnalyticsRequestDimensionsMixin.default)((0,
84
95
  request = request.addDimension(f.dimension, (_f$items = f.items) === null || _f$items === void 0 ? void 0 : _f$items.map(item => item.id));
85
96
  } else {
86
97
  var _f$programStage, _f$repetition, _f$repetition$indexes;
87
- let filterString = (_f$programStage = f.programStage) !== null && _f$programStage !== void 0 && _f$programStage.id ? `${f.programStage.id}.${f.dimension}` : f.dimension;
98
+ let filterString = f.dimension;
88
99
  if (f.filter) {
89
100
  filterString += `:${f.filter}`;
90
101
  }
102
+ const programStageId = (_f$programStage = f.programStage) === null || _f$programStage === void 0 ? void 0 : _f$programStage.id;
91
103
  if ((_f$repetition = f.repetition) !== null && _f$repetition !== void 0 && (_f$repetition$indexes = _f$repetition.indexes) !== null && _f$repetition$indexes !== void 0 && _f$repetition$indexes.length) {
92
104
  f.repetition.indexes.forEach(index => {
93
- request = request.addFilter(filterString.replace(/\./, `[${index}].`));
105
+ var _f$program;
106
+ request = request.addFilter((0, _utils.formatDimension)({
107
+ programId: (_f$program = f.program) === null || _f$program === void 0 ? void 0 : _f$program.id,
108
+ programStageId: `${programStageId}[${index}]`,
109
+ dimension: filterString,
110
+ outputType
111
+ }));
94
112
  });
95
113
  } else {
96
- var _f$items2;
97
- request = request.addFilter(filterString, (_f$items2 = f.items) === null || _f$items2 === void 0 ? void 0 : _f$items2.map(item => item.id));
114
+ var _f$program2, _f$items2;
115
+ request = request.addFilter((0, _utils.formatDimension)({
116
+ programId: (_f$program2 = f.program) === null || _f$program2 === void 0 ? void 0 : _f$program2.id,
117
+ programStageId,
118
+ dimension: filterString,
119
+ outputType
120
+ }), (_f$items2 = f.items) === null || _f$items2 === void 0 ? void 0 : _f$items2.map(item => item.id));
98
121
  }
99
122
  }
100
123
  });
@@ -24,6 +24,7 @@ class AnalyticsRequestBase {
24
24
  format = 'json',
25
25
  path,
26
26
  program,
27
+ trackedEntityType,
27
28
  dimensions = [],
28
29
  filters = [],
29
30
  parameters = {}
@@ -32,6 +33,7 @@ class AnalyticsRequestBase {
32
33
  this.format = format.toLowerCase();
33
34
  this.path = path;
34
35
  this.program = program;
36
+ this.trackedEntityType = trackedEntityType;
35
37
  this.dimensions = dimensions;
36
38
  this.filters = filters;
37
39
  this.parameters = {
@@ -70,7 +72,7 @@ class AnalyticsRequestBase {
70
72
  }
71
73
  return dimension;
72
74
  });
73
- const endPoint = [this.endPoint, this.path, this.program].filter(e => !!e).join('/');
75
+ const endPoint = [this.endPoint, this.path, this.program, this.trackedEntityType].filter(Boolean).join('/');
74
76
  let url = `${endPoint}.${this.format}`;
75
77
  if (encodedDimensions.length) {
76
78
  url += `?dimension=${encodedDimensions.join('&dimension=')}`;
@@ -497,6 +497,25 @@ class extends base {
497
497
  return new _AnalyticsRequest.default(this);
498
498
  }
499
499
 
500
+ /**
501
+ * Sets the tracked entity type for the request.
502
+ * It appends the tracked entity type id to the request's path.
503
+ *
504
+ * @param {!String} trackedEntityType The tracked entity type id
505
+ *
506
+ * @returns {AnalyticsRequest} A new instance of the class for chaining purposes
507
+ *
508
+ * @example
509
+ * const req = new analytics.request()
510
+ * .withTrackedEntityType('nEenWmSyUEp');
511
+ */
512
+ withTrackedEntityType(trackedEntityType) {
513
+ if (trackedEntityType) {
514
+ this.trackedEntityType = trackedEntityType;
515
+ }
516
+ return new _AnalyticsRequest.default(this);
517
+ }
518
+
500
519
  /**
501
520
  * Sets the program for the request.
502
521
  * It appends the program id to the request's path.
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ var _AnalyticsBase = _interopRequireDefault(require("./AnalyticsBase.js"));
8
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
9
+ /**
10
+ * @extends module:analytics.AnalyticsBase
11
+ *
12
+ * @description
13
+ * Analytics tracked entities class used to request analytics tracked entities data from Web API.
14
+ *
15
+ * @memberof module:analytics
16
+ */
17
+ class AnalyticsTrackedEntities extends _AnalyticsBase.default {
18
+ /**
19
+ * @param {!AnalyticsRequest} req Request object
20
+ *
21
+ * @returns {Promise} Promise that resolves with the analytics query data from the api.
22
+ *
23
+ * @example
24
+ // TODO: provide working example
25
+ */
26
+ getQuery(req) {
27
+ return this.fetch(req.withPath('trackedEntities/query'));
28
+ }
29
+ }
30
+ var _default = AnalyticsTrackedEntities;
31
+ exports.default = _default;
@@ -3,10 +3,29 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.customEncodeURIComponent = void 0;
6
+ exports.formatRequestPath = exports.formatDimension = exports.customEncodeURIComponent = void 0;
7
7
  // Define our very own special list of characters that we don't want to encode in the URI
8
8
  const whitelistURI = ',&$=/;:';
9
9
  const whitelistURICodes = whitelistURI.split('').map(c => encodeURIComponent(c));
10
10
  const whitelistRegExp = new RegExp(`(?:${whitelistURICodes.join('|')})`, 'g');
11
11
  const customEncodeURIComponent = uri => encodeURIComponent(uri).replace(whitelistRegExp, decodeURIComponent);
12
- exports.customEncodeURIComponent = customEncodeURIComponent;
12
+ exports.customEncodeURIComponent = customEncodeURIComponent;
13
+ const formatRequestPath = _ref => {
14
+ let {
15
+ path,
16
+ program,
17
+ trackedEntityType
18
+ } = _ref;
19
+ return [path, program, trackedEntityType].filter(Boolean).join('/');
20
+ };
21
+ exports.formatRequestPath = formatRequestPath;
22
+ const formatDimension = _ref2 => {
23
+ let {
24
+ outputType,
25
+ programId,
26
+ programStageId,
27
+ dimension
28
+ } = _ref2;
29
+ return [outputType === 'TRACKED_ENTITY_INSTANCE' ? programId : undefined, programStageId, dimension].filter(Boolean).join('.');
30
+ };
31
+ exports.formatDimension = formatDimension;
@@ -46,6 +46,7 @@
46
46
  "Drag items here, or double click in the list, to start building a calculation formula": "Přetáhněte položky sem nebo dvakrát klikněte na seznam a začněte vytvářet vzorec výpočtu",
47
47
  "Math operators": "Matematické operátory",
48
48
  "Data Type": "Typ dat",
49
+ "Only {{dataType}} can be used in {{visType}}": "",
49
50
  "All types": "Všechny typy",
50
51
  "Disaggregation": "Rozčlenění",
51
52
  "No data": "Nejsou data",
@@ -56,10 +57,12 @@
56
57
  "No data sets found": "Nebyly nalezeny žádné datové soubory",
57
58
  "No event data items found": "Nebyly nalezeny žádné datové položky události",
58
59
  "No program indicators found": "Nebyly nalezeny žádné programové indikátory",
60
+ "No calculations found": "Nenalezeny žádné výpočty",
59
61
  "No indicators found for \"{{- searchTerm}}\"": "Nebyly nalezeny žádné indikátory pro „{{- searchTerm}}“",
60
62
  "No data sets found for \"{{- searchTerm}}\"": "Nebyly nalezeny žádné soubory dat pro „{{- searchTerm}}“",
61
63
  "No event data items found for \"{{- searchTerm}}\"": "Pro „{{- searchTerm}}“ nebyly nalezeny žádné datové položky události",
62
64
  "No program indicators found for \"{{- searchTerm}}\"": "Nebyly nalezeny žádné programové indikátory pro „{{- searchTerm}}“",
65
+ "No calculations found for \"{{- searchTerm}}\"": "",
63
66
  "Nothing found for \"{{- searchTerm}}\"": "Pro dotaz „{{- searchTerm}}“ nebylo nic nalezeno",
64
67
  "Calculation": "Výpočet",
65
68
  "Metric type": "Metrický typ",
@@ -129,8 +132,9 @@
129
132
  "View replies": "",
130
133
  "Unlike": "Na rozdíl od",
131
134
  "Like": "Jako",
132
- "Share": "Sdílet",
133
135
  "See interpretation": "Zobrazit interpretaci",
136
+ "Open in app": "",
137
+ "Share": "Sdílet",
134
138
  "Manage sharing": "Spravovat sdílení",
135
139
  "Could not update interpretation": "Interpretaci nelze aktualizovat",
136
140
  "Enter interpretation text": "Zadejte text interpretace",
@@ -210,9 +214,9 @@
210
214
  "Year": "Rok",
211
215
  "Select year": "Vybrat rok",
212
216
  "Period": "Období",
217
+ "Selected Periods": "Vybraná období",
213
218
  "Relative periods": "Relativní období",
214
219
  "Fixed periods": "Pevné období",
215
- "Selected Periods": "Vybraná období",
216
220
  "No periods selected": "Nejsou vybrána žádná období",
217
221
  "Daily": "Denně",
218
222
  "Weekly": "Týdně",
@@ -380,6 +384,7 @@
380
384
  "Radar": "Radar",
381
385
  "Scatter": "Rozptyl",
382
386
  "Single value": "Jedna hodnota",
387
+ "Outlier table": "",
383
388
  "All charts": "Všechny grafy",
384
389
  "{{seriesName}} (trend)": "{{seriesName}} (trend)",
385
390
  "Trend": "Trend",
@@ -43,6 +43,7 @@
43
43
  "Drag items here, or double click in the list, to start building a calculation formula": "将项目拖到此处,或在列表中双击,开始构建计算公式",
44
44
  "Math operators": "数学运算符",
45
45
  "Data Type": "数据类型",
46
+ "Only {{dataType}} can be used in {{visType}}": "{{dataType}} 只能在 {{visType}} 中使用",
46
47
  "All types": "所有类型",
47
48
  "Disaggregation": "分解",
48
49
  "No data": "无数据",
@@ -53,10 +54,12 @@
53
54
  "No data sets found": "找不到数据集",
54
55
  "No event data items found": "找不到事件数据项",
55
56
  "No program indicators found": "找不到项目指标",
57
+ "No calculations found": "没有找到计算结果",
56
58
  "No indicators found for \"{{- searchTerm}}\"": "找不到“ {{- searchTerm}}”的指标",
57
59
  "No data sets found for \"{{- searchTerm}}\"": "找不到“ {{- searchTerm}}”的数据集",
58
60
  "No event data items found for \"{{- searchTerm}}\"": "找不到“ {{- searchTerm}}”的事件数据项",
59
61
  "No program indicators found for \"{{- searchTerm}}\"": "找不到“ {{- searchTerm}}”的计划指标",
62
+ "No calculations found for \"{{- searchTerm}}\"": "找不到“{{- searchTerm}}”的计算",
60
63
  "Nothing found for \"{{- searchTerm}}\"": "找不到“ {{- searchTerm}}”",
61
64
  "Calculation": "计算",
62
65
  "Metric type": "尺度类型",
@@ -123,8 +126,9 @@
123
126
  "View replies": "查看回复",
124
127
  "Unlike": "不喜欢",
125
128
  "Like": "喜欢",
126
- "Share": "分享",
127
129
  "See interpretation": "见解释",
130
+ "Open in app": "在应用程序中打开",
131
+ "Share": "分享",
128
132
  "Manage sharing": "管理共享",
129
133
  "Could not update interpretation": "无法更新解释",
130
134
  "Enter interpretation text": "输入解释文本",
@@ -195,9 +199,9 @@
195
199
  "Year": "年",
196
200
  "Select year": "选择年份",
197
201
  "Period": "期间",
202
+ "Selected Periods": "选择的期间",
198
203
  "Relative periods": "相对期间",
199
204
  "Fixed periods": "固定期间",
200
- "Selected Periods": "选择的期间",
201
205
  "No periods selected": "未选择期间",
202
206
  "Daily": "每日",
203
207
  "Weekly": "每周",
@@ -365,6 +369,7 @@
365
369
  "Radar": "雷达图",
366
370
  "Scatter": "分散",
367
371
  "Single value": "单个值",
372
+ "Outlier table": "异常值表",
368
373
  "All charts": "所有图表",
369
374
  "{{seriesName}} (trend)": "{{seriesName}}(趋势)",
370
375
  "Trend": "趋势",
@@ -6,5 +6,5 @@ Object.defineProperty(exports, "__esModule", {
6
6
  exports.axisGetDimensionIds = void 0;
7
7
  var _axis = require("./axis.js");
8
8
  var _dimensionGetId = require("./dimensionGetId.js");
9
- const axisGetDimensionIds = axis => _axis.AXIS.isValid(axis) ? axis.map(dimension => (0, _dimensionGetId.dimensionGetId)(dimension)) : _axis.AXIS.defaultValue;
9
+ const axisGetDimensionIds = (axis, outputType) => _axis.AXIS.isValid(axis) ? axis.map(dimension => (0, _dimensionGetId.dimensionGetId)(dimension, outputType)) : _axis.AXIS.defaultValue;
10
10
  exports.axisGetDimensionIds = axisGetDimensionIds;
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.DIMENSION_PROP_REPETITION = exports.DIMENSION_PROP_PROGRAM_STAGE = exports.DIMENSION_PROP_LEGEND_SET = exports.DIMENSION_PROP_ITEMS = exports.DIMENSION_PROP_ID = exports.DIMENSION_PROP_FILTER = exports.DIMENSION_PROPS = exports.DIMENSION = void 0;
6
+ exports.DIMENSION_PROP_REPETITION = exports.DIMENSION_PROP_PROGRAM_STAGE = exports.DIMENSION_PROP_PROGRAM = exports.DIMENSION_PROP_LEGEND_SET = exports.DIMENSION_PROP_ITEMS = exports.DIMENSION_PROP_ID = exports.DIMENSION_PROP_FILTER = exports.DIMENSION_PROPS = exports.DIMENSION = void 0;
7
7
  var _isObject = _interopRequireDefault(require("lodash/isObject"));
8
8
  var _isString = _interopRequireDefault(require("lodash/isString"));
9
9
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
@@ -43,6 +43,13 @@ const DIMENSION_PROP_LEGEND_SET = {
43
43
  isValid: prop => (0, _isString.default)(prop)
44
44
  };
45
45
  exports.DIMENSION_PROP_LEGEND_SET = DIMENSION_PROP_LEGEND_SET;
46
+ const DIMENSION_PROP_PROGRAM = {
47
+ name: 'program',
48
+ defaultValue: {},
49
+ required: false,
50
+ isValid: prop => (0, _isObject.default)(prop)
51
+ };
52
+ exports.DIMENSION_PROP_PROGRAM = DIMENSION_PROP_PROGRAM;
46
53
  const DIMENSION_PROP_PROGRAM_STAGE = {
47
54
  name: 'programStage',
48
55
  defaultValue: {},
@@ -57,5 +64,5 @@ const DIMENSION_PROP_REPETITION = {
57
64
  isValid: prop => Array.isArray(prop)
58
65
  };
59
66
  exports.DIMENSION_PROP_REPETITION = DIMENSION_PROP_REPETITION;
60
- const DIMENSION_PROPS = [DIMENSION_PROP_ID, DIMENSION_PROP_ITEMS, DIMENSION_PROP_FILTER, DIMENSION_PROP_LEGEND_SET, DIMENSION_PROP_PROGRAM_STAGE, DIMENSION_PROP_REPETITION];
67
+ const DIMENSION_PROPS = [DIMENSION_PROP_ID, DIMENSION_PROP_ITEMS, DIMENSION_PROP_FILTER, DIMENSION_PROP_LEGEND_SET, DIMENSION_PROP_PROGRAM, DIMENSION_PROP_PROGRAM_STAGE, DIMENSION_PROP_REPETITION];
61
68
  exports.DIMENSION_PROPS = DIMENSION_PROPS;
@@ -21,6 +21,9 @@ const dimensionCreate = function (dimensionId) {
21
21
  ...(args.legendSet && {
22
22
  [_dimension.DIMENSION_PROP_LEGEND_SET.name]: args.legendSet
23
23
  }),
24
+ ...(args.program && {
25
+ [_dimension.DIMENSION_PROP_PROGRAM.name]: args.program
26
+ }),
24
27
  ...(args.programStage && {
25
28
  [_dimension.DIMENSION_PROP_PROGRAM_STAGE.name]: args.programStage
26
29
  }),
@@ -4,9 +4,15 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.dimensionGetId = void 0;
7
+ var _utils = require("../../api/analytics/utils.js");
7
8
  var _dimension = require("./dimension.js");
8
- const dimensionGetId = dimension => {
9
- var _dimension$DIMENSION_;
10
- return (_dimension$DIMENSION_ = dimension[_dimension.DIMENSION_PROP_PROGRAM_STAGE.name]) !== null && _dimension$DIMENSION_ !== void 0 && _dimension$DIMENSION_.id ? `${dimension[_dimension.DIMENSION_PROP_PROGRAM_STAGE.name].id}.${dimension[_dimension.DIMENSION_PROP_ID.name]}` : dimension[_dimension.DIMENSION_PROP_ID.name];
9
+ const dimensionGetId = (dimension, outputType) => {
10
+ var _dimension$DIMENSION_, _dimension$DIMENSION_2;
11
+ return (0, _utils.formatDimension)({
12
+ dimension: dimension[_dimension.DIMENSION_PROP_ID.name],
13
+ programId: (_dimension$DIMENSION_ = dimension[_dimension.DIMENSION_PROP_PROGRAM.name]) === null || _dimension$DIMENSION_ === void 0 ? void 0 : _dimension$DIMENSION_.id,
14
+ programStageId: (_dimension$DIMENSION_2 = dimension[_dimension.DIMENSION_PROP_PROGRAM_STAGE.name]) === null || _dimension$DIMENSION_2 === void 0 ? void 0 : _dimension$DIMENSION_2.id,
15
+ outputType
16
+ });
11
17
  };
12
18
  exports.dimensionGetId = dimensionGetId;
@@ -11,7 +11,7 @@ const layoutFilterDimensions = (layout, dimensionIds) => {
11
11
  const filteredLayout = Object.assign({}, layout);
12
12
  _axis.DEFAULT_AXIS_IDS.forEach(axisId => {
13
13
  if (_axis.AXIS.isValid(filteredLayout[axisId])) {
14
- filteredLayout[axisId] = filteredLayout[axisId].filter(dimension => !idArray.includes((0, _dimensionGetId.dimensionGetId)(dimension)));
14
+ filteredLayout[axisId] = filteredLayout[axisId].filter(dimension => !idArray.includes((0, _dimensionGetId.dimensionGetId)(dimension, layout.outputType)));
15
15
  }
16
16
  });
17
17
  return filteredLayout;
@@ -8,7 +8,7 @@ var _axis = require("./axis.js");
8
8
  var _axisGetDimensionIds = require("./axisGetDimensionIds.js");
9
9
  const layoutGetAxisIdDimensionIdsObject = layout => _axis.DEFAULT_AXIS_IDS.reduce((obj, axisId) => {
10
10
  if (_axis.AXIS.isValid(layout[axisId])) {
11
- obj[axisId] = (0, _axisGetDimensionIds.axisGetDimensionIds)(layout[axisId]);
11
+ obj[axisId] = (0, _axisGetDimensionIds.axisGetDimensionIds)(layout[axisId], layout.outputType);
12
12
  }
13
13
  return obj;
14
14
  }, {});
@@ -8,7 +8,7 @@ var _dimensionGetId = require("./dimensionGetId.js");
8
8
  var _dimensionGetItemIds = require("./dimensionGetItemIds.js");
9
9
  var _layoutGetAllDimensions = require("./layoutGetAllDimensions.js");
10
10
  const layoutGetDimensionIdItemIdsObject = layout => (0, _layoutGetAllDimensions.layoutGetAllDimensions)(layout).reduce((obj, dimension) => {
11
- obj[(0, _dimensionGetId.dimensionGetId)(dimension)] = (0, _dimensionGetItemIds.dimensionGetItemIds)(dimension);
11
+ obj[(0, _dimensionGetId.dimensionGetId)(dimension, layout.outputType)] = (0, _dimensionGetItemIds.dimensionGetItemIds)(dimension);
12
12
  return obj;
13
13
  }, {});
14
14
  exports.layoutGetDimensionIdItemIdsObject = layoutGetDimensionIdItemIdsObject;
@@ -9,6 +9,6 @@ var _dimensionGetId = require("./dimensionGetId.js");
9
9
  var _layoutGetAllDimensions = require("./layoutGetAllDimensions.js");
10
10
  const layoutHasDynamicDimension = layout => {
11
11
  const fixedIds = Object.keys((0, _predefinedDimensions.getPredefinedDimensions)());
12
- return Boolean((0, _layoutGetAllDimensions.layoutGetAllDimensions)(layout).find(dimension => !fixedIds.includes((0, _dimensionGetId.dimensionGetId)(dimension))));
12
+ return Boolean((0, _layoutGetAllDimensions.layoutGetAllDimensions)(layout).find(dimension => !fixedIds.includes((0, _dimensionGetId.dimensionGetId)(dimension, layout.outputType))));
13
13
  };
14
14
  exports.layoutHasDynamicDimension = layoutHasDynamicDimension;
@@ -6,12 +6,15 @@ import AnalyticsEnrollments from './AnalyticsEnrollments.js';
6
6
  import AnalyticsEvents from './AnalyticsEvents.js';
7
7
  import AnalyticsRequest from './AnalyticsRequest.js';
8
8
  import AnalyticsResponse from './AnalyticsResponse.js';
9
+ import AnalyticsTrackedEntities from './AnalyticsTrackedEntities.js';
9
10
 
10
11
  /**
11
12
  * @description
12
13
  * Analytics class used to request analytics data from Web API.
13
14
  *
14
15
  * @requires analytics.AnalyticsAggregate
16
+ * @requires analytics.AnalyticsTrackedEntities
17
+ * @requires analytics.AnalyticsEnrollments
15
18
  * @requires analytics.AnalyticsEvents
16
19
  * @requires analytics.AnalyticsRequest
17
20
  * @requires analytics.AnalyticsResponse
@@ -31,6 +34,7 @@ import AnalyticsResponse from './AnalyticsResponse.js';
31
34
  class Analytics {
32
35
  /**
33
36
  * @param {!module:analytics.AnalyticsAggregate} analyticsAggregate The AnalyticsAggregate instance
37
+ * @param {!module:analytics.AnalyticsTrackedEntities} analyticsTrackedEntities The AnalyticsTrackedEntities instance
34
38
  * @param {!module:analytics.AnalyticsEnrollments} analyticsEnrollments The AnalyticsEnrollments instance
35
39
  * @param {!module:analytics.AnalyticsEvents} analyticsEvents The AnalyticsEvents instance
36
40
  * @param {!module:analytics.AnalyticsRequest} analyticsRequest The AnalyticsRequest class
@@ -39,12 +43,14 @@ class Analytics {
39
43
  constructor(_ref) {
40
44
  let {
41
45
  aggregate,
46
+ trackedEntities,
42
47
  enrollments,
43
48
  events,
44
49
  request,
45
50
  response
46
51
  } = _ref;
47
52
  this.aggregate = aggregate;
53
+ this.trackedEntities = trackedEntities;
48
54
  this.enrollments = enrollments;
49
55
  this.events = events;
50
56
  this.request = request;
@@ -67,6 +73,7 @@ class Analytics {
67
73
  if (!Analytics.getAnalytics.analytics) {
68
74
  Analytics.getAnalytics.analytics = new Analytics({
69
75
  aggregate: new AnalyticsAggregate(dataEngine),
76
+ trackedEntities: new AnalyticsTrackedEntities(dataEngine),
70
77
  enrollments: new AnalyticsEnrollments(dataEngine),
71
78
  events: new AnalyticsEvents(dataEngine),
72
79
  request: AnalyticsRequest,
@@ -1,13 +1,19 @@
1
1
  import sortBy from 'lodash/sortBy';
2
2
  import AnalyticsRequest from './AnalyticsRequest.js';
3
+ import { formatRequestPath } from './utils.js';
3
4
  const analyticsQuery = {
4
5
  resource: 'analytics',
5
6
  id: _ref => {
6
7
  let {
7
8
  path,
8
- program
9
+ program,
10
+ trackedEntityType
9
11
  } = _ref;
10
- return [path, program].filter(Boolean).join('/');
12
+ return formatRequestPath({
13
+ path,
14
+ program,
15
+ trackedEntityType
16
+ });
11
17
  },
12
18
  params: _ref2 => {
13
19
  let {
@@ -27,9 +33,14 @@ const analyticsDataQuery = {
27
33
  id: _ref3 => {
28
34
  let {
29
35
  path,
30
- program
36
+ program,
37
+ trackedEntityType
31
38
  } = _ref3;
32
- return [path, program].filter(Boolean).join('/');
39
+ return formatRequestPath({
40
+ path,
41
+ program,
42
+ trackedEntityType
43
+ });
33
44
  },
34
45
  params: _ref4 => {
35
46
  let {
@@ -51,9 +62,14 @@ const analyticsMetaDataQuery = {
51
62
  id: _ref5 => {
52
63
  let {
53
64
  path,
54
- program
65
+ program,
66
+ trackedEntityType
55
67
  } = _ref5;
56
- return [path, program].filter(Boolean).join('/');
68
+ return formatRequestPath({
69
+ path,
70
+ program,
71
+ trackedEntityType
72
+ });
57
73
  },
58
74
  params: _ref6 => {
59
75
  let {
@@ -145,6 +161,7 @@ class AnalyticsBase {
145
161
  variables: {
146
162
  path: req.path,
147
163
  program: req.program,
164
+ trackedEntityType: req.trackedEntityType,
148
165
  dimensions: generateDimensionStrings(req.dimensions),
149
166
  filters: generateDimensionStrings(req.filters),
150
167
  parameters: req.parameters,
@@ -187,6 +204,7 @@ class AnalyticsBase {
187
204
  variables: {
188
205
  path: req.path,
189
206
  program: req.program,
207
+ trackedEntityType: req.trackedEntityType,
190
208
  dimensions: generateDimensionStrings(req.dimensions, options),
191
209
  filters: generateDimensionStrings(req.filters, options),
192
210
  parameters: req.parameters
@@ -4,6 +4,7 @@ import AnalyticsRequestBase from './AnalyticsRequestBase.js';
4
4
  import AnalyticsRequestDimensionsMixin from './AnalyticsRequestDimensionsMixin.js';
5
5
  import AnalyticsRequestFiltersMixin from './AnalyticsRequestFiltersMixin.js';
6
6
  import AnalyticsRequestPropertiesMixin from './AnalyticsRequestPropertiesMixin.js';
7
+ import { formatDimension } from './utils.js';
7
8
 
8
9
  /**
9
10
  * @description
@@ -41,6 +42,7 @@ class AnalyticsRequest extends AnalyticsRequestDimensionsMixin(AnalyticsRequestF
41
42
  fromVisualization(visualization) {
42
43
  let passFilterAsDimension = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
43
44
  let request = this;
45
+ const outputType = visualization.outputType;
44
46
 
45
47
  // extract dimensions from visualization
46
48
  const columns = visualization.columns || [];
@@ -51,19 +53,28 @@ class AnalyticsRequest extends AnalyticsRequestDimensionsMixin(AnalyticsRequestF
51
53
  if ((_d$legendSet = d.legendSet) !== null && _d$legendSet !== void 0 && _d$legendSet.id) {
52
54
  dimension += `-${d.legendSet.id}`;
53
55
  }
54
- if ((_d$programStage = d.programStage) !== null && _d$programStage !== void 0 && _d$programStage.id) {
55
- dimension = `${d.programStage.id}.${dimension}`;
56
- }
57
56
  if (d.filter) {
58
57
  dimension += `:${d.filter}`;
59
58
  }
59
+ const programStageId = (_d$programStage = d.programStage) === null || _d$programStage === void 0 ? void 0 : _d$programStage.id;
60
60
  if ((_d$repetition = d.repetition) !== null && _d$repetition !== void 0 && (_d$repetition$indexes = _d$repetition.indexes) !== null && _d$repetition$indexes !== void 0 && _d$repetition$indexes.length) {
61
61
  d.repetition.indexes.forEach(index => {
62
- request = request.addDimension(dimension.replace(/\./, `[${index}].`));
62
+ var _d$program;
63
+ request = request.addDimension(formatDimension({
64
+ programId: (_d$program = d.program) === null || _d$program === void 0 ? void 0 : _d$program.id,
65
+ programStageId: `${programStageId}[${index}]`,
66
+ dimension,
67
+ outputType
68
+ }));
63
69
  });
64
70
  } else {
65
- var _d$items;
66
- request = request.addDimension(dimension, (_d$items = d.items) === null || _d$items === void 0 ? void 0 : _d$items.map(item => item.id));
71
+ var _d$program2, _d$items;
72
+ request = request.addDimension(formatDimension({
73
+ programId: (_d$program2 = d.program) === null || _d$program2 === void 0 ? void 0 : _d$program2.id,
74
+ programStageId,
75
+ dimension,
76
+ outputType
77
+ }), (_d$items = d.items) === null || _d$items === void 0 ? void 0 : _d$items.map(item => item.id));
67
78
  }
68
79
  });
69
80
 
@@ -78,17 +89,29 @@ class AnalyticsRequest extends AnalyticsRequestDimensionsMixin(AnalyticsRequestF
78
89
  request = request.addDimension(f.dimension, (_f$items = f.items) === null || _f$items === void 0 ? void 0 : _f$items.map(item => item.id));
79
90
  } else {
80
91
  var _f$programStage, _f$repetition, _f$repetition$indexes;
81
- let filterString = (_f$programStage = f.programStage) !== null && _f$programStage !== void 0 && _f$programStage.id ? `${f.programStage.id}.${f.dimension}` : f.dimension;
92
+ let filterString = f.dimension;
82
93
  if (f.filter) {
83
94
  filterString += `:${f.filter}`;
84
95
  }
96
+ const programStageId = (_f$programStage = f.programStage) === null || _f$programStage === void 0 ? void 0 : _f$programStage.id;
85
97
  if ((_f$repetition = f.repetition) !== null && _f$repetition !== void 0 && (_f$repetition$indexes = _f$repetition.indexes) !== null && _f$repetition$indexes !== void 0 && _f$repetition$indexes.length) {
86
98
  f.repetition.indexes.forEach(index => {
87
- request = request.addFilter(filterString.replace(/\./, `[${index}].`));
99
+ var _f$program;
100
+ request = request.addFilter(formatDimension({
101
+ programId: (_f$program = f.program) === null || _f$program === void 0 ? void 0 : _f$program.id,
102
+ programStageId: `${programStageId}[${index}]`,
103
+ dimension: filterString,
104
+ outputType
105
+ }));
88
106
  });
89
107
  } else {
90
- var _f$items2;
91
- request = request.addFilter(filterString, (_f$items2 = f.items) === null || _f$items2 === void 0 ? void 0 : _f$items2.map(item => item.id));
108
+ var _f$program2, _f$items2;
109
+ request = request.addFilter(formatDimension({
110
+ programId: (_f$program2 = f.program) === null || _f$program2 === void 0 ? void 0 : _f$program2.id,
111
+ programStageId,
112
+ dimension: filterString,
113
+ outputType
114
+ }), (_f$items2 = f.items) === null || _f$items2 === void 0 ? void 0 : _f$items2.map(item => item.id));
92
115
  }
93
116
  }
94
117
  });
@@ -18,6 +18,7 @@ class AnalyticsRequestBase {
18
18
  format = 'json',
19
19
  path,
20
20
  program,
21
+ trackedEntityType,
21
22
  dimensions = [],
22
23
  filters = [],
23
24
  parameters = {}
@@ -26,6 +27,7 @@ class AnalyticsRequestBase {
26
27
  this.format = format.toLowerCase();
27
28
  this.path = path;
28
29
  this.program = program;
30
+ this.trackedEntityType = trackedEntityType;
29
31
  this.dimensions = dimensions;
30
32
  this.filters = filters;
31
33
  this.parameters = {
@@ -64,7 +66,7 @@ class AnalyticsRequestBase {
64
66
  }
65
67
  return dimension;
66
68
  });
67
- const endPoint = [this.endPoint, this.path, this.program].filter(e => !!e).join('/');
69
+ const endPoint = [this.endPoint, this.path, this.program, this.trackedEntityType].filter(Boolean).join('/');
68
70
  let url = `${endPoint}.${this.format}`;
69
71
  if (encodedDimensions.length) {
70
72
  url += `?dimension=${encodedDimensions.join('&dimension=')}`;
@@ -491,6 +491,25 @@ class extends base {
491
491
  return new AnalyticsRequest(this);
492
492
  }
493
493
 
494
+ /**
495
+ * Sets the tracked entity type for the request.
496
+ * It appends the tracked entity type id to the request's path.
497
+ *
498
+ * @param {!String} trackedEntityType The tracked entity type id
499
+ *
500
+ * @returns {AnalyticsRequest} A new instance of the class for chaining purposes
501
+ *
502
+ * @example
503
+ * const req = new analytics.request()
504
+ * .withTrackedEntityType('nEenWmSyUEp');
505
+ */
506
+ withTrackedEntityType(trackedEntityType) {
507
+ if (trackedEntityType) {
508
+ this.trackedEntityType = trackedEntityType;
509
+ }
510
+ return new AnalyticsRequest(this);
511
+ }
512
+
494
513
  /**
495
514
  * Sets the program for the request.
496
515
  * It appends the program id to the request's path.
@@ -0,0 +1,24 @@
1
+ import AnalyticsBase from './AnalyticsBase.js';
2
+
3
+ /**
4
+ * @extends module:analytics.AnalyticsBase
5
+ *
6
+ * @description
7
+ * Analytics tracked entities class used to request analytics tracked entities data from Web API.
8
+ *
9
+ * @memberof module:analytics
10
+ */
11
+ class AnalyticsTrackedEntities extends AnalyticsBase {
12
+ /**
13
+ * @param {!AnalyticsRequest} req Request object
14
+ *
15
+ * @returns {Promise} Promise that resolves with the analytics query data from the api.
16
+ *
17
+ * @example
18
+ // TODO: provide working example
19
+ */
20
+ getQuery(req) {
21
+ return this.fetch(req.withPath('trackedEntities/query'));
22
+ }
23
+ }
24
+ export default AnalyticsTrackedEntities;
@@ -2,4 +2,21 @@
2
2
  const whitelistURI = ',&$=/;:';
3
3
  const whitelistURICodes = whitelistURI.split('').map(c => encodeURIComponent(c));
4
4
  const whitelistRegExp = new RegExp(`(?:${whitelistURICodes.join('|')})`, 'g');
5
- export const customEncodeURIComponent = uri => encodeURIComponent(uri).replace(whitelistRegExp, decodeURIComponent);
5
+ export const customEncodeURIComponent = uri => encodeURIComponent(uri).replace(whitelistRegExp, decodeURIComponent);
6
+ export const formatRequestPath = _ref => {
7
+ let {
8
+ path,
9
+ program,
10
+ trackedEntityType
11
+ } = _ref;
12
+ return [path, program, trackedEntityType].filter(Boolean).join('/');
13
+ };
14
+ export const formatDimension = _ref2 => {
15
+ let {
16
+ outputType,
17
+ programId,
18
+ programStageId,
19
+ dimension
20
+ } = _ref2;
21
+ return [outputType === 'TRACKED_ENTITY_INSTANCE' ? programId : undefined, programStageId, dimension].filter(Boolean).join('.');
22
+ };
@@ -46,6 +46,7 @@
46
46
  "Drag items here, or double click in the list, to start building a calculation formula": "Přetáhněte položky sem nebo dvakrát klikněte na seznam a začněte vytvářet vzorec výpočtu",
47
47
  "Math operators": "Matematické operátory",
48
48
  "Data Type": "Typ dat",
49
+ "Only {{dataType}} can be used in {{visType}}": "",
49
50
  "All types": "Všechny typy",
50
51
  "Disaggregation": "Rozčlenění",
51
52
  "No data": "Nejsou data",
@@ -56,10 +57,12 @@
56
57
  "No data sets found": "Nebyly nalezeny žádné datové soubory",
57
58
  "No event data items found": "Nebyly nalezeny žádné datové položky události",
58
59
  "No program indicators found": "Nebyly nalezeny žádné programové indikátory",
60
+ "No calculations found": "Nenalezeny žádné výpočty",
59
61
  "No indicators found for \"{{- searchTerm}}\"": "Nebyly nalezeny žádné indikátory pro „{{- searchTerm}}“",
60
62
  "No data sets found for \"{{- searchTerm}}\"": "Nebyly nalezeny žádné soubory dat pro „{{- searchTerm}}“",
61
63
  "No event data items found for \"{{- searchTerm}}\"": "Pro „{{- searchTerm}}“ nebyly nalezeny žádné datové položky události",
62
64
  "No program indicators found for \"{{- searchTerm}}\"": "Nebyly nalezeny žádné programové indikátory pro „{{- searchTerm}}“",
65
+ "No calculations found for \"{{- searchTerm}}\"": "",
63
66
  "Nothing found for \"{{- searchTerm}}\"": "Pro dotaz „{{- searchTerm}}“ nebylo nic nalezeno",
64
67
  "Calculation": "Výpočet",
65
68
  "Metric type": "Metrický typ",
@@ -129,8 +132,9 @@
129
132
  "View replies": "",
130
133
  "Unlike": "Na rozdíl od",
131
134
  "Like": "Jako",
132
- "Share": "Sdílet",
133
135
  "See interpretation": "Zobrazit interpretaci",
136
+ "Open in app": "",
137
+ "Share": "Sdílet",
134
138
  "Manage sharing": "Spravovat sdílení",
135
139
  "Could not update interpretation": "Interpretaci nelze aktualizovat",
136
140
  "Enter interpretation text": "Zadejte text interpretace",
@@ -210,9 +214,9 @@
210
214
  "Year": "Rok",
211
215
  "Select year": "Vybrat rok",
212
216
  "Period": "Období",
217
+ "Selected Periods": "Vybraná období",
213
218
  "Relative periods": "Relativní období",
214
219
  "Fixed periods": "Pevné období",
215
- "Selected Periods": "Vybraná období",
216
220
  "No periods selected": "Nejsou vybrána žádná období",
217
221
  "Daily": "Denně",
218
222
  "Weekly": "Týdně",
@@ -380,6 +384,7 @@
380
384
  "Radar": "Radar",
381
385
  "Scatter": "Rozptyl",
382
386
  "Single value": "Jedna hodnota",
387
+ "Outlier table": "",
383
388
  "All charts": "Všechny grafy",
384
389
  "{{seriesName}} (trend)": "{{seriesName}} (trend)",
385
390
  "Trend": "Trend",
@@ -43,6 +43,7 @@
43
43
  "Drag items here, or double click in the list, to start building a calculation formula": "将项目拖到此处,或在列表中双击,开始构建计算公式",
44
44
  "Math operators": "数学运算符",
45
45
  "Data Type": "数据类型",
46
+ "Only {{dataType}} can be used in {{visType}}": "{{dataType}} 只能在 {{visType}} 中使用",
46
47
  "All types": "所有类型",
47
48
  "Disaggregation": "分解",
48
49
  "No data": "无数据",
@@ -53,10 +54,12 @@
53
54
  "No data sets found": "找不到数据集",
54
55
  "No event data items found": "找不到事件数据项",
55
56
  "No program indicators found": "找不到项目指标",
57
+ "No calculations found": "没有找到计算结果",
56
58
  "No indicators found for \"{{- searchTerm}}\"": "找不到“ {{- searchTerm}}”的指标",
57
59
  "No data sets found for \"{{- searchTerm}}\"": "找不到“ {{- searchTerm}}”的数据集",
58
60
  "No event data items found for \"{{- searchTerm}}\"": "找不到“ {{- searchTerm}}”的事件数据项",
59
61
  "No program indicators found for \"{{- searchTerm}}\"": "找不到“ {{- searchTerm}}”的计划指标",
62
+ "No calculations found for \"{{- searchTerm}}\"": "找不到“{{- searchTerm}}”的计算",
60
63
  "Nothing found for \"{{- searchTerm}}\"": "找不到“ {{- searchTerm}}”",
61
64
  "Calculation": "计算",
62
65
  "Metric type": "尺度类型",
@@ -123,8 +126,9 @@
123
126
  "View replies": "查看回复",
124
127
  "Unlike": "不喜欢",
125
128
  "Like": "喜欢",
126
- "Share": "分享",
127
129
  "See interpretation": "见解释",
130
+ "Open in app": "在应用程序中打开",
131
+ "Share": "分享",
128
132
  "Manage sharing": "管理共享",
129
133
  "Could not update interpretation": "无法更新解释",
130
134
  "Enter interpretation text": "输入解释文本",
@@ -195,9 +199,9 @@
195
199
  "Year": "年",
196
200
  "Select year": "选择年份",
197
201
  "Period": "期间",
202
+ "Selected Periods": "选择的期间",
198
203
  "Relative periods": "相对期间",
199
204
  "Fixed periods": "固定期间",
200
- "Selected Periods": "选择的期间",
201
205
  "No periods selected": "未选择期间",
202
206
  "Daily": "每日",
203
207
  "Weekly": "每周",
@@ -365,6 +369,7 @@
365
369
  "Radar": "雷达图",
366
370
  "Scatter": "分散",
367
371
  "Single value": "单个值",
372
+ "Outlier table": "异常值表",
368
373
  "All charts": "所有图表",
369
374
  "{{seriesName}} (trend)": "{{seriesName}}(趋势)",
370
375
  "Trend": "趋势",
@@ -1,3 +1,3 @@
1
1
  import { AXIS } from './axis.js';
2
2
  import { dimensionGetId } from './dimensionGetId.js';
3
- export const axisGetDimensionIds = axis => AXIS.isValid(axis) ? axis.map(dimension => dimensionGetId(dimension)) : AXIS.defaultValue;
3
+ export const axisGetDimensionIds = (axis, outputType) => AXIS.isValid(axis) ? axis.map(dimension => dimensionGetId(dimension, outputType)) : AXIS.defaultValue;
@@ -33,6 +33,12 @@ export const DIMENSION_PROP_LEGEND_SET = {
33
33
  required: false,
34
34
  isValid: prop => isString(prop)
35
35
  };
36
+ export const DIMENSION_PROP_PROGRAM = {
37
+ name: 'program',
38
+ defaultValue: {},
39
+ required: false,
40
+ isValid: prop => isObject(prop)
41
+ };
36
42
  export const DIMENSION_PROP_PROGRAM_STAGE = {
37
43
  name: 'programStage',
38
44
  defaultValue: {},
@@ -45,4 +51,4 @@ export const DIMENSION_PROP_REPETITION = {
45
51
  required: false,
46
52
  isValid: prop => Array.isArray(prop)
47
53
  };
48
- export const DIMENSION_PROPS = [DIMENSION_PROP_ID, DIMENSION_PROP_ITEMS, DIMENSION_PROP_FILTER, DIMENSION_PROP_LEGEND_SET, DIMENSION_PROP_PROGRAM_STAGE, DIMENSION_PROP_REPETITION];
54
+ export const DIMENSION_PROPS = [DIMENSION_PROP_ID, DIMENSION_PROP_ITEMS, DIMENSION_PROP_FILTER, DIMENSION_PROP_LEGEND_SET, DIMENSION_PROP_PROGRAM, DIMENSION_PROP_PROGRAM_STAGE, DIMENSION_PROP_REPETITION];
@@ -1,4 +1,4 @@
1
- import { DIMENSION_PROP_ID, DIMENSION_PROP_ITEMS, DIMENSION_PROP_FILTER, DIMENSION_PROP_LEGEND_SET, DIMENSION_PROP_PROGRAM_STAGE, DIMENSION_PROP_REPETITION } from './dimension.js';
1
+ import { DIMENSION_PROP_ID, DIMENSION_PROP_ITEMS, DIMENSION_PROP_FILTER, DIMENSION_PROP_LEGEND_SET, DIMENSION_PROP_PROGRAM, DIMENSION_PROP_PROGRAM_STAGE, DIMENSION_PROP_REPETITION } from './dimension.js';
2
2
  export const dimensionCreate = function (dimensionId) {
3
3
  let itemIds = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
4
4
  let args = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
@@ -15,6 +15,9 @@ export const dimensionCreate = function (dimensionId) {
15
15
  ...(args.legendSet && {
16
16
  [DIMENSION_PROP_LEGEND_SET.name]: args.legendSet
17
17
  }),
18
+ ...(args.program && {
19
+ [DIMENSION_PROP_PROGRAM.name]: args.program
20
+ }),
18
21
  ...(args.programStage && {
19
22
  [DIMENSION_PROP_PROGRAM_STAGE.name]: args.programStage
20
23
  }),
@@ -1,5 +1,11 @@
1
- import { DIMENSION_PROP_ID, DIMENSION_PROP_PROGRAM_STAGE } from './dimension.js';
2
- export const dimensionGetId = dimension => {
3
- var _dimension$DIMENSION_;
4
- return (_dimension$DIMENSION_ = dimension[DIMENSION_PROP_PROGRAM_STAGE.name]) !== null && _dimension$DIMENSION_ !== void 0 && _dimension$DIMENSION_.id ? `${dimension[DIMENSION_PROP_PROGRAM_STAGE.name].id}.${dimension[DIMENSION_PROP_ID.name]}` : dimension[DIMENSION_PROP_ID.name];
1
+ import { formatDimension } from '../../api/analytics/utils.js';
2
+ import { DIMENSION_PROP_ID, DIMENSION_PROP_PROGRAM_STAGE, DIMENSION_PROP_PROGRAM } from './dimension.js';
3
+ export const dimensionGetId = (dimension, outputType) => {
4
+ var _dimension$DIMENSION_, _dimension$DIMENSION_2;
5
+ return formatDimension({
6
+ dimension: dimension[DIMENSION_PROP_ID.name],
7
+ programId: (_dimension$DIMENSION_ = dimension[DIMENSION_PROP_PROGRAM.name]) === null || _dimension$DIMENSION_ === void 0 ? void 0 : _dimension$DIMENSION_.id,
8
+ programStageId: (_dimension$DIMENSION_2 = dimension[DIMENSION_PROP_PROGRAM_STAGE.name]) === null || _dimension$DIMENSION_2 === void 0 ? void 0 : _dimension$DIMENSION_2.id,
9
+ outputType
10
+ });
5
11
  };
@@ -5,7 +5,7 @@ export const layoutFilterDimensions = (layout, dimensionIds) => {
5
5
  const filteredLayout = Object.assign({}, layout);
6
6
  DEFAULT_AXIS_IDS.forEach(axisId => {
7
7
  if (AXIS.isValid(filteredLayout[axisId])) {
8
- filteredLayout[axisId] = filteredLayout[axisId].filter(dimension => !idArray.includes(dimensionGetId(dimension)));
8
+ filteredLayout[axisId] = filteredLayout[axisId].filter(dimension => !idArray.includes(dimensionGetId(dimension, layout.outputType)));
9
9
  }
10
10
  });
11
11
  return filteredLayout;
@@ -2,7 +2,7 @@ import { AXIS, DEFAULT_AXIS_IDS } from './axis.js';
2
2
  import { axisGetDimensionIds } from './axisGetDimensionIds.js';
3
3
  export const layoutGetAxisIdDimensionIdsObject = layout => DEFAULT_AXIS_IDS.reduce((obj, axisId) => {
4
4
  if (AXIS.isValid(layout[axisId])) {
5
- obj[axisId] = axisGetDimensionIds(layout[axisId]);
5
+ obj[axisId] = axisGetDimensionIds(layout[axisId], layout.outputType);
6
6
  }
7
7
  return obj;
8
8
  }, {});
@@ -2,6 +2,6 @@ import { dimensionGetId } from './dimensionGetId.js';
2
2
  import { dimensionGetItemIds } from './dimensionGetItemIds.js';
3
3
  import { layoutGetAllDimensions } from './layoutGetAllDimensions.js';
4
4
  export const layoutGetDimensionIdItemIdsObject = layout => layoutGetAllDimensions(layout).reduce((obj, dimension) => {
5
- obj[dimensionGetId(dimension)] = dimensionGetItemIds(dimension);
5
+ obj[dimensionGetId(dimension, layout.outputType)] = dimensionGetItemIds(dimension);
6
6
  return obj;
7
7
  }, {});
@@ -3,5 +3,5 @@ import { dimensionGetId } from './dimensionGetId.js';
3
3
  import { layoutGetAllDimensions } from './layoutGetAllDimensions.js';
4
4
  export const layoutHasDynamicDimension = layout => {
5
5
  const fixedIds = Object.keys(getPredefinedDimensions());
6
- return Boolean(layoutGetAllDimensions(layout).find(dimension => !fixedIds.includes(dimensionGetId(dimension))));
6
+ return Boolean(layoutGetAllDimensions(layout).find(dimension => !fixedIds.includes(dimensionGetId(dimension, layout.outputType))));
7
7
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dhis2/analytics",
3
- "version": "26.5.0",
3
+ "version": "26.6.1",
4
4
  "main": "./build/cjs/index.js",
5
5
  "module": "./build/es/index.js",
6
6
  "exports": {