orc-shared 1.5.0-dev.10 → 1.5.0-dev.12

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 (43) hide show
  1. package/dist/actions/requestsApi.js +1 -0
  2. package/dist/actions/tasks.js +190 -0
  3. package/dist/buildStore.js +3 -1
  4. package/dist/components/AppFrame/Sidebar.js +4 -8
  5. package/dist/components/CategoryList.js +6 -0
  6. package/dist/components/MaterialUI/DataDisplay/PredefinedElements/DiscountedPrice.js +1 -0
  7. package/dist/components/MaterialUI/Inputs/PredefinedElements/SearchControl.js +12 -3
  8. package/dist/components/MaterialUI/hocs/withDeferredTooltip.js +0 -1
  9. package/dist/components/Navigation/index.js +0 -1
  10. package/dist/components/Routing/withWaypointing.js +1 -1
  11. package/dist/components/TaskDetailsModal.js +193 -0
  12. package/dist/constants.js +16 -1
  13. package/dist/reducers/request.js +4 -0
  14. package/dist/reducers/tasks.js +99 -0
  15. package/dist/selectors/tasks.js +66 -0
  16. package/dist/sharedMessages.js +17 -1
  17. package/dist/utils/propertyHelper.js +35 -0
  18. package/dist/whyDidYouRerender.js +1 -0
  19. package/package.json +1 -1
  20. package/src/actions/tasks.js +77 -0
  21. package/src/actions/tasks.test.js +169 -0
  22. package/src/buildStore.js +2 -0
  23. package/src/components/AppFrame/About.test.js +3 -3
  24. package/src/components/AppFrame/Sidebar.js +4 -3
  25. package/src/components/MaterialUI/Inputs/PredefinedElements/SearchControl.js +10 -1
  26. package/src/components/MaterialUI/Inputs/PredefinedElements/SearchControl.test.js +41 -1
  27. package/src/components/TaskDetailsModal.js +132 -0
  28. package/src/components/TaskDetailsModal.test.js +317 -0
  29. package/src/components/Text.test.js +44 -59
  30. package/src/constants.js +13 -0
  31. package/src/hooks/useLabelMessage.test.js +16 -10
  32. package/src/reducers/request.js +4 -0
  33. package/src/reducers/request.test.js +11 -0
  34. package/src/reducers/tasks.js +56 -0
  35. package/src/reducers/tasks.test.js +404 -0
  36. package/src/selectors/tasks.js +16 -0
  37. package/src/selectors/tasks.test.js +60 -0
  38. package/src/sharedMessages.js +17 -1
  39. package/src/translations/en-US.json +16 -12
  40. package/src/translations/fr-CA.json +16 -12
  41. package/src/utils/propertyHelper.js +38 -0
  42. package/src/utils/propertyHelper.test.js +160 -0
  43. package/src/utils/timezoneHelper.test.js +4 -2
@@ -24,6 +24,7 @@ var __signature__ = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoader
24
24
  var __signature__ = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.default.signature : function (a) {
25
25
  return a;
26
26
  };
27
+ /* istanbul ignore file */
27
28
  var acquireEntityLockRequest = {
28
29
  name: "acquireEntityLockRequest",
29
30
  buildUrl: function buildUrl(scopeId, entity, entityId) {
@@ -0,0 +1,190 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports.ssrsDownloadFilterTaskNames = exports.getTaskLog = exports.getTaskList = exports.getTaskInfo = exports.deleteTask = exports.clearTaskLog = exports.GET_TASK_LOG_SUCCESS = exports.GET_TASK_LOG_REQUEST = exports.GET_TASK_LOG_FAILURE = exports.GET_TASK_LIST_SUCCESS = exports.GET_TASK_LIST_REQUEST = exports.GET_TASK_LIST_FAILURE = exports.GET_TASK_LIST = exports.GET_TASKINFO_SUCCESS = exports.GET_TASKINFO_REQUEST = exports.GET_TASKINFO_FAILURE = exports.DELETE_TASK_SUCCESS = exports.DELETE_TASK_REQUEST = exports.DELETE_TASK_FAILURE = exports.CLEAR_TASK_LOG = void 0;
5
+ var _makeApiAction = require("./makeApiAction");
6
+ var _makeOrcApiAction = _interopRequireDefault(require("./makeOrcApiAction"));
7
+ var _requestsApi = require("./requestsApi");
8
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
9
+ (function () {
10
+ var enterModule = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.enterModule : undefined;
11
+ enterModule && enterModule(module);
12
+ })();
13
+ (function () {
14
+ var enterModule = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.enterModule : undefined;
15
+ enterModule && enterModule(module);
16
+ })();
17
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
18
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
19
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
20
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
21
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
22
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
23
+ var __signature__ = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.default.signature : function (a) {
24
+ return a;
25
+ };
26
+ var __signature__ = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.default.signature : function (a) {
27
+ return a;
28
+ };
29
+ var GET_TASKINFO = "GET_TASKINFO";
30
+ var _makeActionTypes = (0, _makeApiAction.makeActionTypes)(GET_TASKINFO),
31
+ _makeActionTypes2 = _slicedToArray(_makeActionTypes, 3),
32
+ GET_TASKINFO_REQUEST = _makeActionTypes2[0],
33
+ GET_TASKINFO_SUCCESS = _makeActionTypes2[1],
34
+ GET_TASKINFO_FAILURE = _makeActionTypes2[2];
35
+ exports.GET_TASKINFO_FAILURE = GET_TASKINFO_FAILURE;
36
+ exports.GET_TASKINFO_SUCCESS = GET_TASKINFO_SUCCESS;
37
+ exports.GET_TASKINFO_REQUEST = GET_TASKINFO_REQUEST;
38
+ var getTaskInfo = function getTaskInfo(taskId) {
39
+ return (0, _makeOrcApiAction.default)(GET_TASKINFO, _requestsApi.getTaskInfoRequest.buildUrl(taskId));
40
+ };
41
+ exports.getTaskInfo = getTaskInfo;
42
+ var GET_TASK_LIST = "GET_TASK_LIST";
43
+ exports.GET_TASK_LIST = GET_TASK_LIST;
44
+ var ssrsDownloadFilterTaskNames = ["Orckestra.Overture.Providers.CommerceEngine.Profiles.ProfileSchemaExportTask, Orckestra.Overture.Providers.CommerceEngine", "Orckestra.Overture.Providers.CommerceEngine.Profiles.ProfileSchemaImportTask, Orckestra.Overture.Providers.CommerceEngine", "Orckestra.Overture.Providers.CommerceEngine.Orders.ExportOrderSchemaTask, Orckestra.Overture.Providers.CommerceEngine", "Orckestra.Overture.Providers.CommerceEngine.Orders.ImportOrderSchemaTask, Orckestra.Overture.Providers.CommerceEngine", "Orckestra.Overture.Providers.CommerceEngine.Products.ImportExport.ExportProductsTask, Orckestra.Overture.Providers.CommerceEngine", "Orckestra.Overture.Providers.CommerceEngine.Products.ImportExport.ProductSchemaExportTask, Orckestra.Overture.Providers.CommerceEngine", "Orckestra.Overture.Providers.CommerceEngine.Products.ImportExport.ImportProductsTask, Orckestra.Overture.Providers.CommerceEngine", "OrckestraCommerce.DataExchange.Product.Tasks.ProductExportTask, OrckestraCommerce.DataExchange", "Orckestra.Overture.Providers.CommerceEngine.Marketing.ExportCouponCodesTask, Orckestra.Overture.Providers.CommerceEngine", "Orckestra.Overture.Providers.CommerceEngine.Marketing.ImportCouponCodesTask, Orckestra.Overture.Providers.CommerceEngine", "Orckestra.Overture.Providers.CommerceEngine.Marketing.GenerateCouponTask, Orckestra.Overture.Providers.CommerceEngine", "Orckestra.Overture.Providers.CommerceEngine.Reporting.ReportExportTask, Orckestra.Overture.Providers.CommerceEngine"];
45
+ exports.ssrsDownloadFilterTaskNames = ssrsDownloadFilterTaskNames;
46
+ var _makeActionTypes3 = (0, _makeApiAction.makeActionTypes)(GET_TASK_LIST),
47
+ _makeActionTypes4 = _slicedToArray(_makeActionTypes3, 3),
48
+ GET_TASK_LIST_REQUEST = _makeActionTypes4[0],
49
+ GET_TASK_LIST_SUCCESS = _makeActionTypes4[1],
50
+ GET_TASK_LIST_FAILURE = _makeActionTypes4[2];
51
+ exports.GET_TASK_LIST_FAILURE = GET_TASK_LIST_FAILURE;
52
+ exports.GET_TASK_LIST_SUCCESS = GET_TASK_LIST_SUCCESS;
53
+ exports.GET_TASK_LIST_REQUEST = GET_TASK_LIST_REQUEST;
54
+ var getTaskList = function getTaskList(requester, filterTaskNames, lastModified, addToActiveRequests) {
55
+ if (lastModified === void 0) {
56
+ lastModified = null;
57
+ }
58
+ if (addToActiveRequests === void 0) {
59
+ addToActiveRequests = true;
60
+ }
61
+ return (0, _makeOrcApiAction.default)(GET_TASK_LIST, _requestsApi.getRequesterTasksInfoRequest.buildUrl({
62
+ filterTaskNames: filterTaskNames,
63
+ requester: requester,
64
+ lastModified: lastModified
65
+ }), _requestsApi.getRequesterTasksInfoRequest.verb, {
66
+ meta: {
67
+ addToActiveRequests: addToActiveRequests
68
+ }
69
+ });
70
+ };
71
+ exports.getTaskList = getTaskList;
72
+ var DELETE_TASK = "DELETE_TASK";
73
+ var _makeActionTypes5 = (0, _makeApiAction.makeActionTypes)(DELETE_TASK),
74
+ _makeActionTypes6 = _slicedToArray(_makeActionTypes5, 3),
75
+ DELETE_TASK_REQUEST = _makeActionTypes6[0],
76
+ DELETE_TASK_SUCCESS = _makeActionTypes6[1],
77
+ DELETE_TASK_FAILURE = _makeActionTypes6[2];
78
+ exports.DELETE_TASK_FAILURE = DELETE_TASK_FAILURE;
79
+ exports.DELETE_TASK_SUCCESS = DELETE_TASK_SUCCESS;
80
+ exports.DELETE_TASK_REQUEST = DELETE_TASK_REQUEST;
81
+ var deleteTask = function deleteTask(taskId) {
82
+ return (0, _makeOrcApiAction.default)(DELETE_TASK, _requestsApi.deleteTaskInfoRequest.buildUrl(taskId), _requestsApi.deleteTaskInfoRequest.verb, {
83
+ meta: {
84
+ taskId: taskId
85
+ }
86
+ });
87
+ };
88
+ exports.deleteTask = deleteTask;
89
+ var GET_TASK_LOG = "GET_TASK_LOG";
90
+ var _makeActionTypes7 = (0, _makeApiAction.makeActionTypes)(GET_TASK_LOG),
91
+ _makeActionTypes8 = _slicedToArray(_makeActionTypes7, 3),
92
+ GET_TASK_LOG_REQUEST = _makeActionTypes8[0],
93
+ GET_TASK_LOG_SUCCESS = _makeActionTypes8[1],
94
+ GET_TASK_LOG_FAILURE = _makeActionTypes8[2];
95
+ exports.GET_TASK_LOG_FAILURE = GET_TASK_LOG_FAILURE;
96
+ exports.GET_TASK_LOG_SUCCESS = GET_TASK_LOG_SUCCESS;
97
+ exports.GET_TASK_LOG_REQUEST = GET_TASK_LOG_REQUEST;
98
+ var getTaskLog = function getTaskLog(taskId, addToActiveRequests) {
99
+ if (addToActiveRequests === void 0) {
100
+ addToActiveRequests = true;
101
+ }
102
+ return (0, _makeOrcApiAction.default)(GET_TASK_LOG, _requestsApi.getTaskExecutionLogsRequest.buildUrl(taskId), _requestsApi.getTaskExecutionLogsRequest.verb, {
103
+ meta: {
104
+ taskId: taskId,
105
+ addToActiveRequests: addToActiveRequests
106
+ }
107
+ });
108
+ };
109
+ exports.getTaskLog = getTaskLog;
110
+ var CLEAR_TASK_LOG = "CLEAR_TASK_LOG";
111
+ exports.CLEAR_TASK_LOG = CLEAR_TASK_LOG;
112
+ var clearTaskLog = function clearTaskLog(taskId) {
113
+ return {
114
+ type: CLEAR_TASK_LOG,
115
+ meta: {
116
+ taskId: taskId
117
+ }
118
+ };
119
+ };
120
+ exports.clearTaskLog = clearTaskLog;
121
+ ;
122
+ (function () {
123
+ var reactHotLoader = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.default : undefined;
124
+ if (!reactHotLoader) {
125
+ return;
126
+ }
127
+ reactHotLoader.register(GET_TASKINFO, "GET_TASKINFO", "/home/vsts/work/1/s/src/actions/tasks.js");
128
+ reactHotLoader.register(GET_TASKINFO_REQUEST, "GET_TASKINFO_REQUEST", "/home/vsts/work/1/s/src/actions/tasks.js");
129
+ reactHotLoader.register(GET_TASKINFO_SUCCESS, "GET_TASKINFO_SUCCESS", "/home/vsts/work/1/s/src/actions/tasks.js");
130
+ reactHotLoader.register(GET_TASKINFO_FAILURE, "GET_TASKINFO_FAILURE", "/home/vsts/work/1/s/src/actions/tasks.js");
131
+ reactHotLoader.register(getTaskInfo, "getTaskInfo", "/home/vsts/work/1/s/src/actions/tasks.js");
132
+ reactHotLoader.register(GET_TASK_LIST, "GET_TASK_LIST", "/home/vsts/work/1/s/src/actions/tasks.js");
133
+ reactHotLoader.register(ssrsDownloadFilterTaskNames, "ssrsDownloadFilterTaskNames", "/home/vsts/work/1/s/src/actions/tasks.js");
134
+ reactHotLoader.register(GET_TASK_LIST_REQUEST, "GET_TASK_LIST_REQUEST", "/home/vsts/work/1/s/src/actions/tasks.js");
135
+ reactHotLoader.register(GET_TASK_LIST_SUCCESS, "GET_TASK_LIST_SUCCESS", "/home/vsts/work/1/s/src/actions/tasks.js");
136
+ reactHotLoader.register(GET_TASK_LIST_FAILURE, "GET_TASK_LIST_FAILURE", "/home/vsts/work/1/s/src/actions/tasks.js");
137
+ reactHotLoader.register(getTaskList, "getTaskList", "/home/vsts/work/1/s/src/actions/tasks.js");
138
+ reactHotLoader.register(DELETE_TASK, "DELETE_TASK", "/home/vsts/work/1/s/src/actions/tasks.js");
139
+ reactHotLoader.register(DELETE_TASK_REQUEST, "DELETE_TASK_REQUEST", "/home/vsts/work/1/s/src/actions/tasks.js");
140
+ reactHotLoader.register(DELETE_TASK_SUCCESS, "DELETE_TASK_SUCCESS", "/home/vsts/work/1/s/src/actions/tasks.js");
141
+ reactHotLoader.register(DELETE_TASK_FAILURE, "DELETE_TASK_FAILURE", "/home/vsts/work/1/s/src/actions/tasks.js");
142
+ reactHotLoader.register(deleteTask, "deleteTask", "/home/vsts/work/1/s/src/actions/tasks.js");
143
+ reactHotLoader.register(GET_TASK_LOG, "GET_TASK_LOG", "/home/vsts/work/1/s/src/actions/tasks.js");
144
+ reactHotLoader.register(GET_TASK_LOG_REQUEST, "GET_TASK_LOG_REQUEST", "/home/vsts/work/1/s/src/actions/tasks.js");
145
+ reactHotLoader.register(GET_TASK_LOG_SUCCESS, "GET_TASK_LOG_SUCCESS", "/home/vsts/work/1/s/src/actions/tasks.js");
146
+ reactHotLoader.register(GET_TASK_LOG_FAILURE, "GET_TASK_LOG_FAILURE", "/home/vsts/work/1/s/src/actions/tasks.js");
147
+ reactHotLoader.register(getTaskLog, "getTaskLog", "/home/vsts/work/1/s/src/actions/tasks.js");
148
+ reactHotLoader.register(CLEAR_TASK_LOG, "CLEAR_TASK_LOG", "/home/vsts/work/1/s/src/actions/tasks.js");
149
+ reactHotLoader.register(clearTaskLog, "clearTaskLog", "/home/vsts/work/1/s/src/actions/tasks.js");
150
+ })();
151
+ ;
152
+ (function () {
153
+ var leaveModule = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.leaveModule : undefined;
154
+ leaveModule && leaveModule(module);
155
+ })();
156
+ ;
157
+ (function () {
158
+ var reactHotLoader = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.default : undefined;
159
+ if (!reactHotLoader) {
160
+ return;
161
+ }
162
+ reactHotLoader.register(GET_TASKINFO, "GET_TASKINFO", "/home/vsts/work/1/s/src/actions/tasks.js");
163
+ reactHotLoader.register(GET_TASKINFO_REQUEST, "GET_TASKINFO_REQUEST", "/home/vsts/work/1/s/src/actions/tasks.js");
164
+ reactHotLoader.register(GET_TASKINFO_SUCCESS, "GET_TASKINFO_SUCCESS", "/home/vsts/work/1/s/src/actions/tasks.js");
165
+ reactHotLoader.register(GET_TASKINFO_FAILURE, "GET_TASKINFO_FAILURE", "/home/vsts/work/1/s/src/actions/tasks.js");
166
+ reactHotLoader.register(getTaskInfo, "getTaskInfo", "/home/vsts/work/1/s/src/actions/tasks.js");
167
+ reactHotLoader.register(GET_TASK_LIST, "GET_TASK_LIST", "/home/vsts/work/1/s/src/actions/tasks.js");
168
+ reactHotLoader.register(ssrsDownloadFilterTaskNames, "ssrsDownloadFilterTaskNames", "/home/vsts/work/1/s/src/actions/tasks.js");
169
+ reactHotLoader.register(GET_TASK_LIST_REQUEST, "GET_TASK_LIST_REQUEST", "/home/vsts/work/1/s/src/actions/tasks.js");
170
+ reactHotLoader.register(GET_TASK_LIST_SUCCESS, "GET_TASK_LIST_SUCCESS", "/home/vsts/work/1/s/src/actions/tasks.js");
171
+ reactHotLoader.register(GET_TASK_LIST_FAILURE, "GET_TASK_LIST_FAILURE", "/home/vsts/work/1/s/src/actions/tasks.js");
172
+ reactHotLoader.register(getTaskList, "getTaskList", "/home/vsts/work/1/s/src/actions/tasks.js");
173
+ reactHotLoader.register(DELETE_TASK, "DELETE_TASK", "/home/vsts/work/1/s/src/actions/tasks.js");
174
+ reactHotLoader.register(DELETE_TASK_REQUEST, "DELETE_TASK_REQUEST", "/home/vsts/work/1/s/src/actions/tasks.js");
175
+ reactHotLoader.register(DELETE_TASK_SUCCESS, "DELETE_TASK_SUCCESS", "/home/vsts/work/1/s/src/actions/tasks.js");
176
+ reactHotLoader.register(DELETE_TASK_FAILURE, "DELETE_TASK_FAILURE", "/home/vsts/work/1/s/src/actions/tasks.js");
177
+ reactHotLoader.register(deleteTask, "deleteTask", "/home/vsts/work/1/s/src/actions/tasks.js");
178
+ reactHotLoader.register(GET_TASK_LOG, "GET_TASK_LOG", "/home/vsts/work/1/s/src/actions/tasks.js");
179
+ reactHotLoader.register(GET_TASK_LOG_REQUEST, "GET_TASK_LOG_REQUEST", "/home/vsts/work/1/s/src/actions/tasks.js");
180
+ reactHotLoader.register(GET_TASK_LOG_SUCCESS, "GET_TASK_LOG_SUCCESS", "/home/vsts/work/1/s/src/actions/tasks.js");
181
+ reactHotLoader.register(GET_TASK_LOG_FAILURE, "GET_TASK_LOG_FAILURE", "/home/vsts/work/1/s/src/actions/tasks.js");
182
+ reactHotLoader.register(getTaskLog, "getTaskLog", "/home/vsts/work/1/s/src/actions/tasks.js");
183
+ reactHotLoader.register(CLEAR_TASK_LOG, "CLEAR_TASK_LOG", "/home/vsts/work/1/s/src/actions/tasks.js");
184
+ reactHotLoader.register(clearTaskLog, "clearTaskLog", "/home/vsts/work/1/s/src/actions/tasks.js");
185
+ })();
186
+ ;
187
+ (function () {
188
+ var leaveModule = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.leaveModule : undefined;
189
+ leaveModule && leaveModule(module);
190
+ })();
@@ -24,6 +24,7 @@ var _timezones = _interopRequireDefault(require("./reducers/timezones"));
24
24
  var _modules = _interopRequireDefault(require("./reducers/modules"));
25
25
  var _metadata = _interopRequireDefault(require("./reducers/metadata"));
26
26
  var _requestStates = _interopRequireDefault(require("./reducers/requestStates"));
27
+ var _tasks = _interopRequireDefault(require("./reducers/tasks"));
27
28
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
28
29
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
29
30
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
@@ -89,7 +90,8 @@ var buildStore = function buildStore(reducers, devOptions) {
89
90
  timezones: _timezones.default,
90
91
  modules: _modules.default,
91
92
  metadata: _metadata.default,
92
- requestStates: _requestStates.default
93
+ requestStates: _requestStates.default,
94
+ tasks: _tasks.default
93
95
  }));
94
96
  };
95
97
  var rootReducer = buildReducer(reducers);
@@ -88,14 +88,10 @@ var LogoSvg = _styledComponents.default.svg.withConfig({
88
88
  })(["flex:0 0 auto;margin:auto 12.5px 7px;height:25px;width:25px;fill-rule:evenodd;clip-rule:evenodd;fill:#666666;"]);
89
89
  var Logo = function Logo() {
90
90
  return /*#__PURE__*/_react.default.createElement(LogoSvg, {
91
- viewBox: "0 0 260 260"
92
- }, /*#__PURE__*/_react.default.createElement("path", {
93
- d: "M1.11,125.62C1.11,74.94,40.22,39,93.72,39S186,74.94,186,125.62s-38.79,86.66-92.29,86.66S1.11,176.3,1.11,125.62Zm135.47,0c0-29.1-18.46-46.62-42.86-46.62S50.54,96.52,50.54,125.62s18.77,46.62,43.18,46.62S136.58,154.72,136.58,125.62Z"
94
- }), /*#__PURE__*/_react.default.createElement("circle", {
95
- cx: "227.6",
96
- cy: "181.13",
97
- r: "31.29"
98
- }));
91
+ viewBox: "0 0 354 354"
92
+ }, /*#__PURE__*/_react.default.createElement("g", null, /*#__PURE__*/_react.default.createElement("path", {
93
+ d: "M0 241.41c0-65.49 50.53-111.98 119.66-111.98s119.25 46.49 119.25 111.98c0 65.49-50.13 111.97-119.25 111.97S0 306.9 0 241.41Zm175.04 0c0-37.6-23.85-60.23-55.38-60.23s-55.79 22.64-55.79 60.23c0 37.59 24.26 60.23 55.79 60.23 31.53 0 55.38-22.64 55.38-60.23Zm178.1-76.35h-77.48c0-48.29-39.29-87.58-87.58-87.58V0c91.02 0 165.07 74.05 165.07 165.06h-.01Z"
94
+ })));
99
95
  };
100
96
  exports.Logo = Logo;
101
97
  var Sidebar = function Sidebar(_ref3) {
@@ -35,6 +35,12 @@ var __signature__ = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoader
35
35
  var __signature__ = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.default.signature : function (a) {
36
36
  return a;
37
37
  };
38
+ /*
39
+ Multiple lists with a single header, aligned with each other
40
+ No virtualization or page loading
41
+ Categories can be folded up to hide content
42
+ Sortable, within categories
43
+ */
38
44
  var arrayToggle = function arrayToggle(array, item) {
39
45
  return array.includes(item) ? array.filter(function (x) {
40
46
  return x !== item;
@@ -21,6 +21,7 @@ var __signature__ = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoader
21
21
  var __signature__ = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.default.signature : function (a) {
22
22
  return a;
23
23
  };
24
+ /* eslint-disable react/style-prop-object */
24
25
  var useStyles = (0, _styles.makeStyles)(function (theme) {
25
26
  return {
26
27
  regular: {
@@ -182,7 +182,9 @@ var SearchControl = function SearchControl(_ref) {
182
182
  searchOption = _ref.searchOption,
183
183
  _ref$onSearch = _ref.onSearch,
184
184
  onSearch = _ref$onSearch === void 0 ? function () {} : _ref$onSearch,
185
- disabled = _ref.disabled;
185
+ disabled = _ref.disabled,
186
+ _ref$focusAndSelectSe = _ref.focusAndSelectSearchFieldOnLoad,
187
+ focusAndSelectSearchFieldOnLoad = _ref$focusAndSelectSe === void 0 ? true : _ref$focusAndSelectSe;
186
188
  searchOptions = !((_searchOptions = searchOptions) != null && _searchOptions.length) ? null : searchOptions;
187
189
  searchOption = getSearchOptionValue(searchOptions, searchOption);
188
190
  var _useState = (0, _react.useState)(false),
@@ -223,6 +225,13 @@ var SearchControl = function SearchControl(_ref) {
223
225
  event.preventDefault();
224
226
  event.stopPropagation();
225
227
  };
228
+ (0, _react.useEffect)(function () {
229
+ if (focusAndSelectSearchFieldOnLoad && inputRef.current) {
230
+ inputRef.current.focus();
231
+ inputRef.current.select();
232
+ setInputFocused(true);
233
+ }
234
+ }, [focusAndSelectSearchFieldOnLoad]);
226
235
  var SelectSection = function SelectSection() {
227
236
  if (searchOptions === null) return null;else return /*#__PURE__*/_react.default.createElement(_Select.default, {
228
237
  className: classes.selectInput,
@@ -287,10 +296,10 @@ var SearchControl = function SearchControl(_ref) {
287
296
  className: classes.container
288
297
  }, /*#__PURE__*/_react.default.createElement(SelectSection, null), inputSection, searchSection);
289
298
  };
290
- __signature__(SearchControl, "useState{[inputFocused, setInputFocused](false)}\nuseStyles{classes}\nuseRef{inputRef}", function () {
299
+ __signature__(SearchControl, "useState{[inputFocused, setInputFocused](false)}\nuseStyles{classes}\nuseRef{inputRef}\nuseEffect{}", function () {
291
300
  return [useStyles];
292
301
  });
293
- __signature__(SearchControl, "useState{[inputFocused, setInputFocused](false)}\nuseStyles{classes}\nuseRef{inputRef}", function () {
302
+ __signature__(SearchControl, "useState{[inputFocused, setInputFocused](false)}\nuseStyles{classes}\nuseRef{inputRef}\nuseEffect{}", function () {
294
303
  return [useStyles];
295
304
  });
296
305
  var _default = SearchControl;
@@ -35,7 +35,6 @@ var __signature__ = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoader
35
35
  // Pay attention that if component you are passed to this HOC contains titleValue property
36
36
  // by itself then that property will be disappeared after using that HOC.
37
37
  // To fix it rename that property and pass titleValue just as a title for tooltip.
38
-
39
38
  var withDeferredTooltip = function withDeferredTooltip(Comp) {
40
39
  return __signature__(__signature__(function (_ref) {
41
40
  var titleValue = _ref.titleValue,
@@ -26,7 +26,6 @@ var __signature__ = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoader
26
26
  // Scope concern: Changing scope means subpages may no longer be valid.
27
27
  // Grey out other-scoped tabs, change scope when opened?
28
28
  // Warn when changing scopes, close out-scope tabs?
29
-
30
29
  var Navigation = (0, _withErrorBoundary.default)("Navigation")(__signature__(__signature__(function (_ref) {
31
30
  var modules = _ref.modules;
32
31
  return /*#__PURE__*/_react.default.createElement(_TabBar.default, (0, _useNavigationState.useNavigationState)(modules));
@@ -27,7 +27,7 @@ var __signature__ = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoader
27
27
  };
28
28
  var __signature__ = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.default.signature : function (a) {
29
29
  return a;
30
- };
30
+ }; // HOC that sets the currently matched route of a component in state, including params
31
31
  var withWaypointing = function withWaypointing(Comp, isVisible, componentProps) {
32
32
  if (isVisible === void 0) {
33
33
  isVisible = true;
@@ -0,0 +1,193 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports.useStyles = exports.default = void 0;
5
+ var _react = _interopRequireWildcard(require("react"));
6
+ var _reactRedux = require("react-redux");
7
+ var _Button = _interopRequireDefault(require("@material-ui/core/Button"));
8
+ var _reactIntl = require("react-intl");
9
+ var _styles = require("@material-ui/core/styles");
10
+ var _constants = require("../constants");
11
+ var _useSelectorAndUnwrap = _interopRequireDefault(require("../hooks/useSelectorAndUnwrap"));
12
+ var _InformationItem = _interopRequireDefault(require("./MaterialUI/DataDisplay/PredefinedElements/InformationItem"));
13
+ var _tasks = require("../selectors/tasks");
14
+ var _propertyHelper = require("../utils/propertyHelper");
15
+ var _useLoader = _interopRequireDefault(require("../hooks/useLoader"));
16
+ var _tasks2 = require("../actions/tasks");
17
+ var _modalProps = _interopRequireDefault(require("./MaterialUI/DataDisplay/modalProps"));
18
+ var _Modal = _interopRequireDefault(require("./MaterialUI/DataDisplay/Modal"));
19
+ var _metadata = require("../selectors/metadata");
20
+ var _sharedMessages = _interopRequireDefault(require("../sharedMessages"));
21
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
22
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
23
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
24
+ (function () {
25
+ var enterModule = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.enterModule : undefined;
26
+ enterModule && enterModule(module);
27
+ })();
28
+ (function () {
29
+ var enterModule = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.enterModule : undefined;
30
+ enterModule && enterModule(module);
31
+ })();
32
+ var __signature__ = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.default.signature : function (a) {
33
+ return a;
34
+ };
35
+ var __signature__ = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.default.signature : function (a) {
36
+ return a;
37
+ };
38
+ var useStyles = (0, _styles.makeStyles)(function (theme) {
39
+ return {
40
+ actionPanel: {
41
+ display: "flex",
42
+ marginLeft: "auto",
43
+ flex: "1 1 0",
44
+ justifyContent: "flex-end"
45
+ },
46
+ taskContainer: {
47
+ display: "flex",
48
+ width: "100%",
49
+ flexDirection: "column",
50
+ "&>div": {
51
+ "&:last-child": {
52
+ flex: 1,
53
+ display: "flex",
54
+ flexDirection: "column",
55
+ "&>textarea": {
56
+ overflowY: "scroll",
57
+ resize: "none",
58
+ flex: 1
59
+ }
60
+ }
61
+ }
62
+ }
63
+ };
64
+ });
65
+ exports.useStyles = useStyles;
66
+ var isTaskCompleted = function isTaskCompleted(status) {
67
+ switch (status) {
68
+ case _constants.taskStatuses.faulted:
69
+ case _constants.taskStatuses.ranToCompletion:
70
+ case _constants.taskStatuses.canceled:
71
+ case _constants.taskStatuses.ignored:
72
+ return true;
73
+ default:
74
+ return false;
75
+ }
76
+ };
77
+ var TaskDetailsModal = function TaskDetailsModal(_ref) {
78
+ var taskId = _ref.taskId,
79
+ open = _ref.open,
80
+ closeModal = _ref.closeModal;
81
+ var classes = useStyles();
82
+ var dispatch = (0, _reactRedux.useDispatch)();
83
+ var taskDetails = (0, _useSelectorAndUnwrap.default)((0, _tasks.taskInfo)(taskId));
84
+ var logs = (0, _useSelectorAndUnwrap.default)((0, _tasks.taskLogs)(taskId));
85
+ var logsText = logs.sort(function (a, b) {
86
+ return (0, _propertyHelper.compareObjectProperty)(a, b, "executionTime");
87
+ }).reduce(function (accumulator, currentValue) {
88
+ if (currentValue.message === null) {
89
+ return accumulator;
90
+ }
91
+ if (accumulator === "") {
92
+ return currentValue.message.trim();
93
+ }
94
+ return accumulator + "\n" + currentValue.message.trim();
95
+ }, "");
96
+ (0, _useLoader.default)((0, _tasks2.getTaskInfo)(taskId), function () {
97
+ return taskDetails !== null;
98
+ });
99
+ var internalCloseModal = function internalCloseModal() {
100
+ dispatch((0, _tasks2.clearTaskLog)(taskId));
101
+ closeModal();
102
+ };
103
+ var taskStatus = taskDetails == null ? void 0 : taskDetails.status;
104
+ (0, _react.useEffect)(function () {
105
+ var timer = setInterval(function () {
106
+ if (!isTaskCompleted(taskStatus)) {
107
+ dispatch((0, _tasks2.getTaskInfo)(taskId));
108
+ dispatch((0, _tasks2.getTaskLog)(taskId, false));
109
+ }
110
+ }, 10000);
111
+ return function () {
112
+ return clearInterval(timer);
113
+ };
114
+ }, [dispatch, taskId, taskStatus]);
115
+ var localizedStatus = (0, _reactRedux.useSelector)((0, _metadata.namedLookupLocalizedSelector)("order", "TaskStatus", taskStatus));
116
+ var modalProps = new _modalProps.default();
117
+ var titleComponent = /*#__PURE__*/_react.default.createElement(_reactIntl.FormattedMessage, _sharedMessages.default.taskInProgressModalTitle);
118
+ modalProps.set(_modalProps.default.propNames.title, titleComponent);
119
+ modalProps.set(_modalProps.default.propNames.open, open);
120
+ modalProps.set(_modalProps.default.propNames.type, "wide");
121
+ modalProps.set(_modalProps.default.propNames.backdropClickCallback, internalCloseModal);
122
+ var actionPanel = /*#__PURE__*/_react.default.createElement("div", {
123
+ className: classes.actionPanel
124
+ }, /*#__PURE__*/_react.default.createElement(_Button.default, {
125
+ key: _sharedMessages.default.close.id,
126
+ "data-qa": _sharedMessages.default.close.id,
127
+ variant: "contained",
128
+ color: "primary",
129
+ disableElevation: true,
130
+ onClick: function onClick(e) {
131
+ return internalCloseModal(e);
132
+ }
133
+ }, /*#__PURE__*/_react.default.createElement(_reactIntl.FormattedMessage, _sharedMessages.default.close)));
134
+ modalProps.set(_modalProps.default.propNames.actionPanel, actionPanel);
135
+ var taskContent = /*#__PURE__*/_react.default.createElement("div", {
136
+ className: classes.taskContainer
137
+ }, /*#__PURE__*/_react.default.createElement(_InformationItem.default, {
138
+ label: _sharedMessages.default.taskId
139
+ }, taskId), /*#__PURE__*/_react.default.createElement(_InformationItem.default, {
140
+ label: _sharedMessages.default.taskStatus
141
+ }, localizedStatus), /*#__PURE__*/_react.default.createElement(_InformationItem.default, {
142
+ label: _sharedMessages.default.taskLogs
143
+ }, /*#__PURE__*/_react.default.createElement("textarea", {
144
+ readOnly: true,
145
+ value: logsText
146
+ })));
147
+ return /*#__PURE__*/_react.default.createElement(_Modal.default, {
148
+ message: taskContent,
149
+ modalProps: modalProps
150
+ });
151
+ };
152
+ __signature__(TaskDetailsModal, "useStyles{classes}\nuseDispatch{dispatch}\nuseSelectorAndUnwrap{taskDetails}\nuseSelectorAndUnwrap{logs}\nuseLoader{}\nuseEffect{}\nuseSelector{localizedStatus}", function () {
153
+ return [useStyles, _reactRedux.useDispatch, _useSelectorAndUnwrap.default, _useSelectorAndUnwrap.default, _useLoader.default, _reactRedux.useSelector];
154
+ });
155
+ __signature__(TaskDetailsModal, "useStyles{classes}\nuseDispatch{dispatch}\nuseSelectorAndUnwrap{taskDetails}\nuseSelectorAndUnwrap{logs}\nuseLoader{}\nuseEffect{}\nuseSelector{localizedStatus}", function () {
156
+ return [useStyles, _reactRedux.useDispatch, _useSelectorAndUnwrap.default, _useSelectorAndUnwrap.default, _useLoader.default, _reactRedux.useSelector];
157
+ });
158
+ var _default = TaskDetailsModal;
159
+ var _default2 = _default;
160
+ var _default3 = _default2;
161
+ exports.default = _default3;
162
+ ;
163
+ (function () {
164
+ var reactHotLoader = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.default : undefined;
165
+ if (!reactHotLoader) {
166
+ return;
167
+ }
168
+ reactHotLoader.register(useStyles, "useStyles", "/home/vsts/work/1/s/src/components/TaskDetailsModal.js");
169
+ reactHotLoader.register(isTaskCompleted, "isTaskCompleted", "/home/vsts/work/1/s/src/components/TaskDetailsModal.js");
170
+ reactHotLoader.register(TaskDetailsModal, "TaskDetailsModal", "/home/vsts/work/1/s/src/components/TaskDetailsModal.js");
171
+ reactHotLoader.register(_default, "default", "/home/vsts/work/1/s/src/components/TaskDetailsModal.js");
172
+ })();
173
+ ;
174
+ (function () {
175
+ var leaveModule = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.leaveModule : undefined;
176
+ leaveModule && leaveModule(module);
177
+ })();
178
+ ;
179
+ (function () {
180
+ var reactHotLoader = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.default : undefined;
181
+ if (!reactHotLoader) {
182
+ return;
183
+ }
184
+ reactHotLoader.register(useStyles, "useStyles", "/home/vsts/work/1/s/src/components/TaskDetailsModal.js");
185
+ reactHotLoader.register(isTaskCompleted, "isTaskCompleted", "/home/vsts/work/1/s/src/components/TaskDetailsModal.js");
186
+ reactHotLoader.register(TaskDetailsModal, "TaskDetailsModal", "/home/vsts/work/1/s/src/components/TaskDetailsModal.js");
187
+ reactHotLoader.register(_default2, "default", "/home/vsts/work/1/s/src/components/TaskDetailsModal.js");
188
+ })();
189
+ ;
190
+ (function () {
191
+ var leaveModule = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.leaveModule : undefined;
192
+ leaveModule && leaveModule(module);
193
+ })();
package/dist/constants.js CHANGED
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
2
 
3
3
  exports.__esModule = true;
4
- exports.validationErrorTypes = exports.scopeTypes = exports.scopeConfirmationDialogTypes = exports.roleGroups = exports.requestStates = exports.requestStateOperations = exports.requestStateOperationMap = exports.platformRoles = exports.overtureModule = exports.infoBar = exports.displayMode = exports.definitionType = exports.attributeDataType = void 0;
4
+ exports.validationErrorTypes = exports.taskStatuses = exports.scopeTypes = exports.scopeConfirmationDialogTypes = exports.roleGroups = exports.requestStates = exports.requestStateOperations = exports.requestStateOperationMap = exports.platformRoles = exports.overtureModule = exports.infoBar = exports.displayMode = exports.definitionType = exports.attributeDataType = void 0;
5
5
  (function () {
6
6
  var enterModule = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.enterModule : undefined;
7
7
  enterModule && enterModule(module);
@@ -128,6 +128,19 @@ var requestStateOperationMap = {
128
128
  update: "updates"
129
129
  };
130
130
  exports.requestStateOperationMap = requestStateOperationMap;
131
+ var taskStatuses = {
132
+ created: "Created",
133
+ waitingToRun: "WaitingToRun",
134
+ running: "Running",
135
+ ranToCompletion: "RanToCompletion",
136
+ canceled: "Canceled",
137
+ faulted: "Faulted",
138
+ idle: "Idle",
139
+ waitingToCancel: "WaitingToCancel",
140
+ ignored: "Ignored",
141
+ queuedForSequence: "QueuedForSequence"
142
+ };
143
+ exports.taskStatuses = taskStatuses;
131
144
  ;
132
145
  (function () {
133
146
  var reactHotLoader = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoaderGlobal.default : undefined;
@@ -147,6 +160,7 @@ exports.requestStateOperationMap = requestStateOperationMap;
147
160
  reactHotLoader.register(definitionType, "definitionType", "/home/vsts/work/1/s/src/constants.js");
148
161
  reactHotLoader.register(requestStateOperations, "requestStateOperations", "/home/vsts/work/1/s/src/constants.js");
149
162
  reactHotLoader.register(requestStateOperationMap, "requestStateOperationMap", "/home/vsts/work/1/s/src/constants.js");
163
+ reactHotLoader.register(taskStatuses, "taskStatuses", "/home/vsts/work/1/s/src/constants.js");
150
164
  })();
151
165
  ;
152
166
  (function () {
@@ -172,6 +186,7 @@ exports.requestStateOperationMap = requestStateOperationMap;
172
186
  reactHotLoader.register(definitionType, "definitionType", "/home/vsts/work/1/s/src/constants.js");
173
187
  reactHotLoader.register(requestStateOperations, "requestStateOperations", "/home/vsts/work/1/s/src/constants.js");
174
188
  reactHotLoader.register(requestStateOperationMap, "requestStateOperationMap", "/home/vsts/work/1/s/src/constants.js");
189
+ reactHotLoader.register(taskStatuses, "taskStatuses", "/home/vsts/work/1/s/src/constants.js");
175
190
  })();
176
191
  ;
177
192
  (function () {
@@ -33,6 +33,10 @@ var requestReducer = function requestReducer(state, action) {
33
33
  state = initialState;
34
34
  }
35
35
  if (action.type.endsWith("_REQUEST")) {
36
+ if ((0, _utils.safeGet)(action, "meta", "addToActiveRequests") === false) {
37
+ // this flag should only be used by requests triggered by a background process to avoid the spinner
38
+ return state;
39
+ }
36
40
  var requestName = action.type.replace(/_REQUEST$/, "");
37
41
  return state.setIn(["actives", requestName], true);
38
42
  }