@agilemotion/oui-react-js 1.7.0 → 1.7.2
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/dist/ApplicationManager.js +8 -3
- package/dist/BasicAppHome.js +1 -1
- package/dist/DynamicJS.js +5 -2
- package/dist/InteractionPortalAppHome.js +5 -0
- package/dist/RestService.js +344 -0
- package/dist/RestUtils.js +22 -8
- package/dist/Utils.js +9 -0
- package/dist/components/AlertBar.js +3 -0
- package/dist/components/DataGrid.js +72 -43
- package/dist/components/DocumentTemplateDesigner.css +2 -2
- package/dist/components/DocumentTemplateDesigner.js +43 -31
- package/dist/components/DocumentTemplateDesignerComponent.css +6 -159
- package/dist/components/DocumentTemplateDesignerComponent.js +368 -72
- package/dist/components/DocumentTemplatePlaceholderDialog.js +6 -6
- package/dist/components/DocumentViewer.css +10 -0
- package/dist/components/DocumentViewer.js +95 -45
- package/dist/components/Graph.js +12 -2
- package/dist/components/GraphNode.js +0 -2
- package/dist/components/{DocumentViewerComponent.js → PDFViewer.js} +2 -2
- package/dist/components/TabPage.js +7 -3
- package/dist/components/TabPanel.js +13 -3
- package/dist/components/TableCellContent.js +21 -4
- package/dist/components/TemplateDesigner.css +3 -2
- package/dist/components/TemplateDesigner.js +3 -1
- package/dist/components/TemplateItemEventHandler.js +30 -15
- package/dist/components/Toolbar.js +3 -1
- package/dist/components/Tree.js +5 -5
- package/dist/components/WordDocumentViewer.js +167 -0
- package/dist/components/dashboard/SideMenuModuleDashboard.js +1 -3
- package/dist/components/dashboard/components/blackDashboard/sidebar/ModuleMenuSidebar.css +4 -0
- package/dist/components/dashboard/components/blackDashboard/sidebar/ModuleMenuSidebar.js +131 -159
- package/dist/components/form/AutoComplete.js +28 -6
- package/dist/components/form/BaseField.js +3 -3
- package/dist/components/form/DatePicker.js +7 -2
- package/dist/components/form/FieldSet.js +24 -8
- package/dist/components/form/Form.js +4 -3
- package/dist/components/form/GridField.js +13 -37
- package/dist/components/form/LookupField.js +23 -23
- package/dist/components/form/RadioGroup.js +2 -1
- package/dist/components/form/Section.js +4 -0
- package/dist/components/form/SelectItem.js +2 -3
- package/dist/components/form/TextField.js +6 -6
- package/dist/components/layout/Layout.js +24 -15
- package/dist/components/menu/MenuButton.js +12 -7
- package/dist/components/menu/MenuLink.js +6 -0
- package/dist/components/signatures/AgilitySignaturePanel.js +33 -14
- package/dist/components/signatures/DocumentContainer.css +26 -1
- package/dist/components/signatures/DocumentContainer.js +55 -10
- package/dist/components/signatures/SignatureInputProps.js +59 -9
- package/dist/components/signatures/SignatureTemplateDesigner.js +71 -38
- package/dist/event/ActionHandlers.js +7 -4
- package/dist/event/RouteActionHandler.js +3 -3
- package/dist/event/ScriptActionHandler.js +2 -2
- package/dist/event/ServiceCallActionHandler.js +73 -28
- package/dist/js/Docs.js +57 -10
- package/dist/view/Dashboard.js +3 -3
- package/package.json +10 -5
- package/dist/components/DocumentView.css +0 -4
|
@@ -13,6 +13,9 @@ var _CardAvatar = _interopRequireDefault(require("../../../../card/CardAvatar"))
|
|
|
13
13
|
var _core = require("@material-ui/core");
|
|
14
14
|
var _RestUtils = require("../../../../../RestUtils");
|
|
15
15
|
require("./ModuleMenuSidebar.css");
|
|
16
|
+
var _Event = _interopRequireDefault(require("../../../../../event/Event"));
|
|
17
|
+
var _Observable = _interopRequireDefault(require("../../../../../event/Observable"));
|
|
18
|
+
var _EventType = _interopRequireDefault(require("../../../../../event/EventType"));
|
|
16
19
|
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
17
20
|
/*eslint-disable*/
|
|
18
21
|
|
|
@@ -22,21 +25,51 @@ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e
|
|
|
22
25
|
|
|
23
26
|
let ps;
|
|
24
27
|
const TAB = 16;
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
28
|
+
const ModuleMenuSidebar = props => {
|
|
29
|
+
const [menuState, setMenuState] = _react.default.useState();
|
|
30
|
+
const [routes, setRoutes] = _react.default.useState();
|
|
31
|
+
const [isLoading, setIsLoading] = _react.default.useState(false);
|
|
32
|
+
const [error, setError] = _react.default.useState(false);
|
|
33
|
+
const [activeModule, setActiveModule] = _react.default.useState('home');
|
|
34
|
+
const [selectedMenuRoutes, setSelectedMenuRoutes] = _react.default.useState(null);
|
|
35
|
+
const [activeRouteMenu, setActiveRouteMenu] = _react.default.useState({
|
|
36
|
+
id: 'dashboard',
|
|
37
|
+
name: 'Dashboard'
|
|
38
|
+
});
|
|
39
|
+
_react.default.useEffect(() => {
|
|
40
|
+
setMenuState(getCollapseInitialState(props.routes));
|
|
41
|
+
let service = {
|
|
42
|
+
url: '/ui/api/v1/menu/filter',
|
|
43
|
+
parameters: [{
|
|
44
|
+
value: props.routes,
|
|
45
|
+
httpParameterType: 'REQUEST_BODY'
|
|
46
|
+
}],
|
|
47
|
+
method: 'POST',
|
|
48
|
+
contentType: 'application/json'
|
|
37
49
|
};
|
|
38
|
-
|
|
39
|
-
|
|
50
|
+
(0, _RestUtils.invokeRest)(service, {
|
|
51
|
+
api: {
|
|
52
|
+
get id() {
|
|
53
|
+
return 'dashboard-sidebar';
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}, 'dashboard-sidebar', result => {
|
|
57
|
+
setRoutes(result);
|
|
58
|
+
let currentModule = result.find(r => r.name === activeModule);
|
|
59
|
+
if (currentModule) {
|
|
60
|
+
getMenu(currentModule).then(result => {});
|
|
61
|
+
}
|
|
62
|
+
}, e => {
|
|
63
|
+
console.error(e);
|
|
64
|
+
}, null);
|
|
65
|
+
}, []);
|
|
66
|
+
_react.default.useEffect(() => {
|
|
67
|
+
if (routes) {
|
|
68
|
+
let currentModule = routes.find(r => r.name === activeModule);
|
|
69
|
+
getMenu(currentModule).then(result => {});
|
|
70
|
+
}
|
|
71
|
+
}, [activeModule]);
|
|
72
|
+
const getViews = (menus, level) => {
|
|
40
73
|
let newViews = [];
|
|
41
74
|
for (let i = 0; i < menus.length; i++) {
|
|
42
75
|
let createView = {};
|
|
@@ -48,16 +81,15 @@ class ModuleMenuSidebar extends _react.default.Component {
|
|
|
48
81
|
if (menus[i].subMenu) {
|
|
49
82
|
createView.collapse = true;
|
|
50
83
|
createView.state = menus[i].id + 'Collapse';
|
|
51
|
-
createView.views =
|
|
84
|
+
createView.views = getItems(menus[i].subMenu.items, level + 1);
|
|
52
85
|
} else {
|
|
53
86
|
createView.item = menus[i];
|
|
54
87
|
}
|
|
55
88
|
newViews.push(createView);
|
|
56
89
|
}
|
|
57
|
-
console.log('VIEWS : ', newViews, menus);
|
|
58
90
|
return newViews;
|
|
59
91
|
};
|
|
60
|
-
getItems = (items, level) => {
|
|
92
|
+
const getItems = (items, level) => {
|
|
61
93
|
let newItems = [];
|
|
62
94
|
for (let i = 0; i < items.length; i++) {
|
|
63
95
|
let createItem = {};
|
|
@@ -70,7 +102,7 @@ class ModuleMenuSidebar extends _react.default.Component {
|
|
|
70
102
|
if (!_Utils.default.isNull(items[i].subMenu)) {
|
|
71
103
|
createItem.collapse = true;
|
|
72
104
|
createItem.state = items[i].id + 'SubMenuCollapse';
|
|
73
|
-
createItem.views =
|
|
105
|
+
createItem.views = getItems(items[i].subMenu.items, level + 1);
|
|
74
106
|
}
|
|
75
107
|
newItems.push(createItem);
|
|
76
108
|
}
|
|
@@ -78,15 +110,15 @@ class ModuleMenuSidebar extends _react.default.Component {
|
|
|
78
110
|
};
|
|
79
111
|
|
|
80
112
|
// this creates the intial state of this component based on the collapse routes
|
|
81
|
-
// that it gets through
|
|
82
|
-
getCollapseStates = routes => {
|
|
113
|
+
// that it gets through state.routes
|
|
114
|
+
const getCollapseStates = routes => {
|
|
83
115
|
let initialState = {};
|
|
84
116
|
if (routes) {
|
|
85
|
-
routes.map(
|
|
117
|
+
routes.map(prop => {
|
|
86
118
|
if (prop.collapse) {
|
|
87
119
|
initialState = {
|
|
88
|
-
[prop.state]:
|
|
89
|
-
...
|
|
120
|
+
[prop.state]: getCollapseInitialState(prop.views),
|
|
121
|
+
...getCollapseStates(prop.views),
|
|
90
122
|
...initialState
|
|
91
123
|
};
|
|
92
124
|
}
|
|
@@ -95,10 +127,11 @@ class ModuleMenuSidebar extends _react.default.Component {
|
|
|
95
127
|
}
|
|
96
128
|
return initialState;
|
|
97
129
|
};
|
|
130
|
+
|
|
98
131
|
// this verifies if any of the collapses should be default opened on a rerender of this component
|
|
99
132
|
// for example, on the refresh of the page,
|
|
100
133
|
// while on the src/views/forms/RegularForms.js - route /admin/regular-forms
|
|
101
|
-
getCollapseInitialState
|
|
134
|
+
const getCollapseInitialState = routes => {
|
|
102
135
|
if (!routes) {
|
|
103
136
|
return false;
|
|
104
137
|
}
|
|
@@ -106,15 +139,15 @@ class ModuleMenuSidebar extends _react.default.Component {
|
|
|
106
139
|
if (!routes[i].views) {
|
|
107
140
|
return true;
|
|
108
141
|
}
|
|
109
|
-
if (routes[i].collapse &&
|
|
142
|
+
if (routes[i].collapse && getCollapseInitialState(routes[i].views)) {
|
|
110
143
|
return true;
|
|
111
144
|
} else if (window.location.href.indexOf(routes[i].path) !== -1) {
|
|
112
145
|
return true;
|
|
113
146
|
}
|
|
114
147
|
}
|
|
115
148
|
return false;
|
|
116
|
-
}
|
|
117
|
-
getMenu = route => {
|
|
149
|
+
};
|
|
150
|
+
const getMenu = route => {
|
|
118
151
|
return new Promise(resolve => {
|
|
119
152
|
let service = {
|
|
120
153
|
url: '/ui/api/v1/menu/get',
|
|
@@ -136,41 +169,51 @@ class ModuleMenuSidebar extends _react.default.Component {
|
|
|
136
169
|
}
|
|
137
170
|
}
|
|
138
171
|
}, 'dashboard-sidebar', result => {
|
|
139
|
-
|
|
172
|
+
let views = getViews(result.menus, route.level + 1);
|
|
173
|
+
setSelectedMenuRoutes(views);
|
|
174
|
+
let defaultMenu = views.find(m => m.item.defaultItem);
|
|
175
|
+
if (defaultMenu) {
|
|
176
|
+
if (defaultMenu.id === 'Dashboard') {
|
|
177
|
+
props.dashboardLauncher();
|
|
178
|
+
}
|
|
179
|
+
setActiveRouteMenu({
|
|
180
|
+
id: defaultMenu.id,
|
|
181
|
+
name: defaultMenu.name
|
|
182
|
+
});
|
|
183
|
+
let event = new _Event.default({
|
|
184
|
+
api: {
|
|
185
|
+
get id() {
|
|
186
|
+
return defaultMenu.id;
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
}, "menuBar");
|
|
190
|
+
_Observable.default.fireEvent(_EventType.default.CLICK, event);
|
|
191
|
+
}
|
|
192
|
+
resolve(views);
|
|
140
193
|
}, e => {
|
|
141
194
|
console.error(e);
|
|
142
195
|
resolve(null);
|
|
143
196
|
}, null);
|
|
144
197
|
});
|
|
145
198
|
};
|
|
146
|
-
getLiClassName = prop => {
|
|
199
|
+
const getLiClassName = prop => {
|
|
147
200
|
return "li-" + prop.level;
|
|
148
201
|
};
|
|
149
|
-
createModuleTabs = routes => {
|
|
202
|
+
const createModuleTabs = routes => {
|
|
150
203
|
const {
|
|
151
204
|
rtlActive,
|
|
152
205
|
secondaryThemeColor,
|
|
153
206
|
primaryThemeColor
|
|
154
|
-
} =
|
|
207
|
+
} = props;
|
|
155
208
|
return routes.map((module, key) => {
|
|
156
209
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
157
210
|
key: key,
|
|
158
211
|
style: {
|
|
159
|
-
backgroundColor:
|
|
212
|
+
backgroundColor: isActiveModule(module.name) ? primaryThemeColor : (0, _core.lighten)(secondaryThemeColor, .1)
|
|
160
213
|
},
|
|
161
|
-
className: `${
|
|
214
|
+
className: `${isActiveModule(module.name) ? 'module-tab-selected' : 'module-tab'}`,
|
|
162
215
|
onClick: e => {
|
|
163
|
-
|
|
164
|
-
...this.state,
|
|
165
|
-
activeModule: module.name
|
|
166
|
-
});
|
|
167
|
-
let currentModule = this.state.routes.find(r => r.name === module.name);
|
|
168
|
-
this.getMenu(currentModule).then(result => {
|
|
169
|
-
this.setState({
|
|
170
|
-
...this.state,
|
|
171
|
-
selectedMenuRoutes: result
|
|
172
|
-
});
|
|
173
|
-
});
|
|
216
|
+
setActiveModule(module.name);
|
|
174
217
|
}
|
|
175
218
|
}, /*#__PURE__*/_react.default.createElement("div", null, module.icon ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
|
|
176
219
|
className: 'tab-icon'
|
|
@@ -178,30 +221,29 @@ class ModuleMenuSidebar extends _react.default.Component {
|
|
|
178
221
|
className: module.icon,
|
|
179
222
|
style: {
|
|
180
223
|
width: '28px',
|
|
181
|
-
color:
|
|
224
|
+
color: isActiveModule(module.name) ? '#000000' : '#444746'
|
|
182
225
|
}
|
|
183
|
-
}), ' '), /*#__PURE__*/_react.default.createElement("div", null, ' ', module.label), ' ', ' ') : /*#__PURE__*/_react.default.createElement("span", null, module.name),
|
|
226
|
+
}), ' '), /*#__PURE__*/_react.default.createElement("div", null, ' ', module.label), ' ', ' ') : /*#__PURE__*/_react.default.createElement("span", null, module.name), isActiveModule(module.name) && /*#__PURE__*/_react.default.createElement("i", {
|
|
184
227
|
className: 'fas fa-caret-left selected-module-caret'
|
|
185
228
|
})));
|
|
186
229
|
});
|
|
187
230
|
};
|
|
188
231
|
|
|
189
232
|
// this function creates the links and collapses that appear in the sidebar (left menu)
|
|
190
|
-
createLinks =
|
|
233
|
+
const createLinks = moduleRoutes => {
|
|
191
234
|
const {
|
|
192
235
|
rtlActive,
|
|
193
236
|
secondaryThemeColor,
|
|
194
237
|
primaryThemeColor
|
|
195
|
-
} =
|
|
196
|
-
return
|
|
238
|
+
} = props;
|
|
239
|
+
return moduleRoutes.map((prop, key) => {
|
|
197
240
|
if (prop.redirect) {
|
|
198
241
|
return null;
|
|
199
242
|
}
|
|
200
243
|
if ((prop.collapse || prop.isParent) && prop.name !== 'Dashboard' && prop.name !== 'My Work Items') {
|
|
201
|
-
|
|
202
|
-
st[prop['state']] = !this.state[prop.state];
|
|
244
|
+
menuState[prop['state']] = !menuState[prop.state];
|
|
203
245
|
return /*#__PURE__*/_react.default.createElement("li", {
|
|
204
|
-
className: prop.collapse ?
|
|
246
|
+
className: prop.collapse ? getCollapseInitialState(prop.views) + '-' + prop.level ? 'active ' + getLiClassName(prop) : getLiClassName(prop) : getLiClassName(prop),
|
|
205
247
|
key: key
|
|
206
248
|
}, /*#__PURE__*/_react.default.createElement("a", {
|
|
207
249
|
href: "#pablo",
|
|
@@ -210,18 +252,16 @@ class ModuleMenuSidebar extends _react.default.Component {
|
|
|
210
252
|
style: {
|
|
211
253
|
marginLeft: (prop.level + 1) * TAB + 'px'
|
|
212
254
|
},
|
|
213
|
-
"aria-expanded":
|
|
255
|
+
"aria-expanded": menuState[prop.state],
|
|
214
256
|
onClick: e => {
|
|
215
257
|
if (!prop.views) {
|
|
216
|
-
|
|
258
|
+
getMenu(prop).then(views => {
|
|
217
259
|
if (views) {
|
|
218
|
-
prop.views = views;
|
|
219
|
-
//
|
|
220
|
-
|
|
260
|
+
//prop.views = views;
|
|
261
|
+
//getCollapseInitialState(views);
|
|
262
|
+
//setState(st);
|
|
221
263
|
}
|
|
222
264
|
});
|
|
223
|
-
} else {
|
|
224
|
-
this.setState(st);
|
|
225
265
|
}
|
|
226
266
|
e.preventDefault();
|
|
227
267
|
}
|
|
@@ -243,15 +283,15 @@ class ModuleMenuSidebar extends _react.default.Component {
|
|
|
243
283
|
}, ' ', prop.name, ' ', /*#__PURE__*/_react.default.createElement("b", {
|
|
244
284
|
className: "caret"
|
|
245
285
|
})), ' '), ' '), ' ', prop.collapse && prop.views ? /*#__PURE__*/_react.default.createElement(_reactstrap.Collapse, {
|
|
246
|
-
isOpen:
|
|
286
|
+
isOpen: menuState[prop.state]
|
|
247
287
|
}, /*#__PURE__*/_react.default.createElement("ul", {
|
|
248
288
|
className: "nav"
|
|
249
|
-
}, " ",
|
|
289
|
+
}, " ", createLinks(prop.views), " "), ' ') : null);
|
|
250
290
|
}
|
|
251
291
|
return /*#__PURE__*/_react.default.createElement("li", {
|
|
252
|
-
className: `${'menu-link-li' + (
|
|
292
|
+
className: `${'menu-link-li' + (isActiveRoute(prop.id) ? '-active' : '') + (prop.name === 'Dashboard' ? ' dashboard-link' : '')}`,
|
|
253
293
|
key: key,
|
|
254
|
-
style:
|
|
294
|
+
style: isActiveRoute(prop.id) ? {
|
|
255
295
|
backgroundColor: (0, _core.lighten)(secondaryThemeColor, .9),
|
|
256
296
|
borderRadius: '16px',
|
|
257
297
|
color: secondaryThemeColor,
|
|
@@ -260,97 +300,45 @@ class ModuleMenuSidebar extends _react.default.Component {
|
|
|
260
300
|
}, /*#__PURE__*/_react.default.createElement(_MenuLink.default, {
|
|
261
301
|
config: prop.item,
|
|
262
302
|
clickCallback: prop.name === 'Dashboard' ? item => {
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
...this.state,
|
|
270
|
-
activeRouteMenu: item
|
|
271
|
-
}),
|
|
272
|
-
autoClick: prop.name === 'My Work Items' || prop.item && prop.item.defaultItem,
|
|
303
|
+
props.dashboardLauncher();
|
|
304
|
+
setActiveRouteMenu(item);
|
|
305
|
+
} : item => {
|
|
306
|
+
setActiveRouteMenu(item);
|
|
307
|
+
},
|
|
308
|
+
autoClick: false,
|
|
273
309
|
viewId: "menuBar",
|
|
274
310
|
icon: prop.icon,
|
|
275
|
-
iconColor: (prop.name === 'Dashboard' || prop.name === 'My Work Items') &&
|
|
276
|
-
backgroundColor:
|
|
311
|
+
iconColor: (prop.name === 'Dashboard' || prop.name === 'My Work Items') && isActiveRoute(prop.id) ? secondaryThemeColor : null,
|
|
312
|
+
backgroundColor: isActiveRoute(prop.id) ? (0, _core.lighten)(secondaryThemeColor, .9) : null,
|
|
277
313
|
name: prop.name,
|
|
278
314
|
id: prop.id,
|
|
279
315
|
level: prop.level,
|
|
280
316
|
tab: TAB,
|
|
281
|
-
color:
|
|
317
|
+
color: isActiveRoute(prop.id) ? secondaryThemeColor : null
|
|
282
318
|
}), ' ');
|
|
283
319
|
});
|
|
284
320
|
};
|
|
285
321
|
|
|
286
322
|
// verifies if routeName is the one active (in browser input)
|
|
287
|
-
|
|
288
|
-
// return
|
|
289
|
-
return
|
|
323
|
+
const isActiveRoute = routeName => {
|
|
324
|
+
// return props.location.pathname.indexOf(routeName) > -1 ? "active" : "";
|
|
325
|
+
return activeRouteMenu.id === routeName;
|
|
290
326
|
};
|
|
291
|
-
|
|
292
|
-
return
|
|
327
|
+
const isActiveModule = moduleName => {
|
|
328
|
+
return activeModule === moduleName;
|
|
293
329
|
};
|
|
294
|
-
|
|
295
|
-
// if you are using a Windows Machine, the scrollbars will have a Mac look
|
|
296
|
-
if (navigator.platform.indexOf('Win') > -1) {
|
|
297
|
-
/*ps = new PerfectScrollbar(this.refs.sidebar, {
|
|
298
|
-
suppressScrollX: true,
|
|
299
|
-
suppressScrollY: false,
|
|
300
|
-
});*/
|
|
301
|
-
}
|
|
302
|
-
let service = {
|
|
303
|
-
url: '/ui/api/v1/menu/filter',
|
|
304
|
-
parameters: [{
|
|
305
|
-
value: this.props.routes,
|
|
306
|
-
httpParameterType: 'REQUEST_BODY'
|
|
307
|
-
}],
|
|
308
|
-
method: 'POST',
|
|
309
|
-
contentType: 'application/json'
|
|
310
|
-
};
|
|
311
|
-
(0, _RestUtils.invokeRest)(service, {
|
|
312
|
-
api: {
|
|
313
|
-
get id() {
|
|
314
|
-
return 'dashboard-sidebar';
|
|
315
|
-
}
|
|
316
|
-
}
|
|
317
|
-
}, 'dashboard-sidebar', result => {
|
|
318
|
-
this.setState({
|
|
319
|
-
...this.state,
|
|
320
|
-
routes: result
|
|
321
|
-
});
|
|
322
|
-
let currentModule = result.find(r => r.name === this.state.activeModule);
|
|
323
|
-
if (currentModule) {
|
|
324
|
-
this.getMenu(currentModule).then(result => {
|
|
325
|
-
this.setState({
|
|
326
|
-
...this.state,
|
|
327
|
-
selectedMenuRoutes: result
|
|
328
|
-
});
|
|
329
|
-
});
|
|
330
|
-
}
|
|
331
|
-
}, e => {
|
|
332
|
-
console.error(e);
|
|
333
|
-
}, null);
|
|
334
|
-
}
|
|
335
|
-
componentWillUnmount() {
|
|
336
|
-
// we need to destroy the false scrollbar when we navigate
|
|
337
|
-
// to a page that doesn't have this component rendered
|
|
338
|
-
if (navigator.platform.indexOf('Win') > -1) {
|
|
339
|
-
//ps.destroy();
|
|
340
|
-
}
|
|
341
|
-
}
|
|
342
|
-
render() {
|
|
330
|
+
const render = () => {
|
|
343
331
|
const {
|
|
344
332
|
activeColor,
|
|
345
333
|
logo
|
|
346
|
-
} =
|
|
334
|
+
} = props;
|
|
347
335
|
let logoImg = null;
|
|
348
336
|
let logoText = null;
|
|
349
337
|
if (!_Utils.default.isNull(logo)) {
|
|
350
338
|
logoImg = /*#__PURE__*/_react.default.createElement("a", {
|
|
351
339
|
href: logo.outterLink,
|
|
352
340
|
className: "logo-normal",
|
|
353
|
-
onClick:
|
|
341
|
+
onClick: props.closeSidebar
|
|
354
342
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
355
343
|
className: "logo-img",
|
|
356
344
|
style: {
|
|
@@ -364,11 +352,11 @@ class ModuleMenuSidebar extends _react.default.Component {
|
|
|
364
352
|
logoText = /*#__PURE__*/_react.default.createElement("a", {
|
|
365
353
|
href: logo.outterLink,
|
|
366
354
|
className: "simple-text ",
|
|
367
|
-
onClick:
|
|
355
|
+
onClick: props.closeSidebar
|
|
368
356
|
}, logo.text, ' ');
|
|
369
357
|
}
|
|
370
358
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
371
|
-
className:
|
|
359
|
+
className: `${props.className} module-menu-sidebar`,
|
|
372
360
|
data: activeColor,
|
|
373
361
|
style: {
|
|
374
362
|
overflow: 'auto',
|
|
@@ -379,18 +367,18 @@ class ModuleMenuSidebar extends _react.default.Component {
|
|
|
379
367
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
380
368
|
className: 'h-100 module-menu-strip',
|
|
381
369
|
style: {
|
|
382
|
-
backgroundColor:
|
|
370
|
+
backgroundColor: props.secondaryThemeColor
|
|
383
371
|
}
|
|
384
372
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
385
373
|
style: {
|
|
386
374
|
height: '16%'
|
|
387
375
|
}
|
|
388
|
-
}),
|
|
376
|
+
}), routes && /*#__PURE__*/_react.default.createElement(_reactstrap.Nav, {
|
|
389
377
|
style: {
|
|
390
378
|
padding: '8px'
|
|
391
379
|
},
|
|
392
380
|
className: 'nav-wrapper'
|
|
393
|
-
},
|
|
381
|
+
}, createModuleTabs(routes))), /*#__PURE__*/_react.default.createElement("div", {
|
|
394
382
|
className: 'h-100',
|
|
395
383
|
style: {
|
|
396
384
|
width: 'calc(100% - 120px)'
|
|
@@ -413,7 +401,7 @@ class ModuleMenuSidebar extends _react.default.Component {
|
|
|
413
401
|
alignItems: 'center',
|
|
414
402
|
height: '100%'
|
|
415
403
|
}
|
|
416
|
-
}, ' ', logoImg, ' ') : null, ' ', !_Utils.default.isNull(
|
|
404
|
+
}, ' ', logoImg, ' ') : null, ' ', !_Utils.default.isNull(props.heading) ? /*#__PURE__*/_react.default.createElement("div", {
|
|
417
405
|
className: "logo",
|
|
418
406
|
style: {
|
|
419
407
|
display: 'flex',
|
|
@@ -423,18 +411,18 @@ class ModuleMenuSidebar extends _react.default.Component {
|
|
|
423
411
|
fontSize: '20px',
|
|
424
412
|
fontWeight: 600
|
|
425
413
|
}
|
|
426
|
-
},
|
|
414
|
+
}, props.heading) : null)), /*#__PURE__*/_react.default.createElement("tr", null, /*#__PURE__*/_react.default.createElement("td", {
|
|
427
415
|
style: {
|
|
428
416
|
height: '75%'
|
|
429
417
|
},
|
|
430
418
|
valign: 'top'
|
|
431
|
-
},
|
|
419
|
+
}, selectedMenuRoutes && /*#__PURE__*/_react.default.createElement(_reactstrap.Nav, {
|
|
432
420
|
style: {
|
|
433
421
|
margin: '8px',
|
|
434
422
|
padding: '16px'
|
|
435
423
|
},
|
|
436
424
|
className: 'nav-wrapper'
|
|
437
|
-
},
|
|
425
|
+
}, createLinks(selectedMenuRoutes)))), /*#__PURE__*/_react.default.createElement("tr", null, /*#__PURE__*/_react.default.createElement("td", {
|
|
438
426
|
className: 'sidebar-app-logo-wrapper',
|
|
439
427
|
style: {
|
|
440
428
|
height: '5%'
|
|
@@ -454,23 +442,7 @@ class ModuleMenuSidebar extends _react.default.Component {
|
|
|
454
442
|
marginTop: '8px'
|
|
455
443
|
}
|
|
456
444
|
}, "Copyrights \xA9 ", 1900 + new Date().getYear(), " ", ' ')))))))));
|
|
457
|
-
}
|
|
458
|
-
|
|
459
|
-
ModuleMenuSidebar.propTypes = {
|
|
460
|
-
activeColor: _propTypes.default.oneOf(['primary', 'blue', 'green', 'orange', 'red', 'agility']),
|
|
461
|
-
secondaryThemeColor: _propTypes.default.string.isRequired,
|
|
462
|
-
rtlActive: _propTypes.default.bool,
|
|
463
|
-
routes: _propTypes.default.array.isRequired,
|
|
464
|
-
logo: _propTypes.default.oneOfType([_propTypes.default.shape({
|
|
465
|
-
innerLink: _propTypes.default.string.isRequired,
|
|
466
|
-
imgSrc: _propTypes.default.string.isRequired,
|
|
467
|
-
text: _propTypes.default.string.isRequired
|
|
468
|
-
}), _propTypes.default.shape({
|
|
469
|
-
outterLink: _propTypes.default.string.isRequired,
|
|
470
|
-
imgSrc: _propTypes.default.string.isRequired,
|
|
471
|
-
text: _propTypes.default.string.isRequired
|
|
472
|
-
})]),
|
|
473
|
-
// this is used on responsive to close the sidebar on route navigation
|
|
474
|
-
closeSidebar: _propTypes.default.func
|
|
445
|
+
};
|
|
446
|
+
return render();
|
|
475
447
|
};
|
|
476
448
|
var _default = exports.default = ModuleMenuSidebar;
|
|
@@ -54,6 +54,10 @@ const AutoCompleteWrapper = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_reac
|
|
|
54
54
|
}
|
|
55
55
|
baseValue.current = base.value;
|
|
56
56
|
setOptions(value.current);
|
|
57
|
+
} else {
|
|
58
|
+
//value.current = base.value;
|
|
59
|
+
//baseValue.current = base.value;
|
|
60
|
+
//setOptions([base.value]);
|
|
57
61
|
}
|
|
58
62
|
}, [base.value]);
|
|
59
63
|
const fetchOptions = () => {
|
|
@@ -92,23 +96,41 @@ const AutoCompleteWrapper = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_reac
|
|
|
92
96
|
};
|
|
93
97
|
return /*#__PURE__*/_react.default.createElement(_Autocomplete.default, {
|
|
94
98
|
inputValue: inputValue,
|
|
95
|
-
multiple: true,
|
|
99
|
+
multiple: _Utils.default.getComponentAttribute(props.config, 'multiple', true),
|
|
96
100
|
disabled: base.disabled,
|
|
97
101
|
value: value.current,
|
|
102
|
+
disableClearable: !_Utils.default.getComponentAttribute(props.config, 'multiple', true),
|
|
98
103
|
getOptionLabel: option => option ? option : '',
|
|
99
104
|
onInputChange: (event, newValue) => handleInputChange(event, newValue),
|
|
100
105
|
onChange: (e, newValue, reason) => {
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
106
|
+
if (Array.isArray(newValue)) {
|
|
107
|
+
let val = [];
|
|
108
|
+
for (const newValueElement of newValue) {
|
|
109
|
+
let find = entityStore.find(e => e[props.config.attributes.searchAttribute] === newValueElement);
|
|
110
|
+
if (find) {
|
|
111
|
+
find.dataRecordDescription = find[props.config.attributes.searchAttribute];
|
|
112
|
+
val.push(find);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
value.current = newValue;
|
|
116
|
+
base.handleValueChange(val);
|
|
117
|
+
} else {
|
|
118
|
+
let val = null;
|
|
119
|
+
let find = entityStore.find(e => e[props.config.attributes.searchAttribute] === newValue);
|
|
120
|
+
if (find) {
|
|
121
|
+
val = find;
|
|
122
|
+
val.dataRecordDescription = val[props.config.attributes.searchAttribute];
|
|
123
|
+
}
|
|
124
|
+
value.current = newValue;
|
|
125
|
+
base.handleValueChange(val);
|
|
104
126
|
}
|
|
105
|
-
value.current = newValue;
|
|
106
|
-
base.handleValueChange(val);
|
|
107
127
|
},
|
|
108
128
|
options: options,
|
|
109
129
|
id: props.config.id,
|
|
110
130
|
renderInput: params => /*#__PURE__*/_react.default.createElement(_TextField.default, _extends({
|
|
111
131
|
required: base.required,
|
|
132
|
+
margin: "dense",
|
|
133
|
+
size: "small",
|
|
112
134
|
error: base.hasError,
|
|
113
135
|
helperText: base.errorMessage,
|
|
114
136
|
variant: props.borderless ? 'standard' : 'outlined'
|
|
@@ -245,11 +245,11 @@ const BaseField = props => {
|
|
|
245
245
|
return config ? /*#__PURE__*/_react.default.createElement("div", {
|
|
246
246
|
className: "col-*-*",
|
|
247
247
|
key: config.id,
|
|
248
|
-
style:
|
|
248
|
+
style: {
|
|
249
249
|
textAlign: 'left',
|
|
250
|
-
marginLeft: '15px',
|
|
250
|
+
marginLeft: props.config.attributes?.style?.marginLeft || '15px',
|
|
251
251
|
display: !visible || _Utils.default.getComponentAttribute(config, 'hidden', false) === true ? 'none' : 'block'
|
|
252
|
-
}
|
|
252
|
+
}
|
|
253
253
|
}, /*#__PURE__*/_react.default.createElement("span", null, props.children({
|
|
254
254
|
required: required,
|
|
255
255
|
disabled: disabled,
|
|
@@ -13,6 +13,7 @@ var _dateFns2 = _interopRequireDefault(require("@date-io/date-fns"));
|
|
|
13
13
|
var _pickers = require("@material-ui/pickers");
|
|
14
14
|
var _styles = require("@material-ui/core/styles");
|
|
15
15
|
var _reactRedux = require("react-redux");
|
|
16
|
+
var _DynamicJS = _interopRequireDefault(require("../../DynamicJS"));
|
|
16
17
|
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
17
18
|
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
|
|
18
19
|
const CustomDatePickerComponent = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.default.forwardRef((props, ref) => {
|
|
@@ -49,6 +50,9 @@ const CustomDatePickerComponent = /*#__PURE__*/_react.default.memo( /*#__PURE__*
|
|
|
49
50
|
limit.setDate(limit.getDate() + days);
|
|
50
51
|
}
|
|
51
52
|
return limit.getFullYear() + "-" + formatNumber(limit.getMonth() + 1) + "-" + formatNumber(limit.getDate());
|
|
53
|
+
} else {
|
|
54
|
+
let limit = _DynamicJS.default.executeScript(props.config.id + "-" + id, dateAttr);
|
|
55
|
+
return limit.getFullYear() + "-" + formatNumber(limit.getMonth() + 1) + "-" + formatNumber(limit.getDate());
|
|
52
56
|
}
|
|
53
57
|
}
|
|
54
58
|
return id === "minDate" ? "1970-01-01" : "9000-12-31";
|
|
@@ -60,7 +64,7 @@ const CustomDatePickerComponent = /*#__PURE__*/_react.default.memo( /*#__PURE__*
|
|
|
60
64
|
if (maxDate === null) {
|
|
61
65
|
setMaxDate(getLimitDate("maxDate"));
|
|
62
66
|
}
|
|
63
|
-
});
|
|
67
|
+
}, []);
|
|
64
68
|
const secondaryColor = (0, _reactRedux.useSelector)(state => state.dashboard.secondaryThemeColor);
|
|
65
69
|
const ThemedKeyboardDatePicker = (0, _styles.withStyles)({
|
|
66
70
|
root: {
|
|
@@ -81,7 +85,8 @@ const CustomDatePickerComponent = /*#__PURE__*/_react.default.memo( /*#__PURE__*
|
|
|
81
85
|
utils: _dateFns2.default
|
|
82
86
|
}, /*#__PURE__*/_react.default.createElement(_Grid.default, {
|
|
83
87
|
container: true,
|
|
84
|
-
ref: ref
|
|
88
|
+
ref: ref,
|
|
89
|
+
onClick: e => e.stopPropagation()
|
|
85
90
|
}, /*#__PURE__*/_react.default.createElement(ThemedKeyboardDatePicker, {
|
|
86
91
|
id: props.id,
|
|
87
92
|
InputProps: {
|