@gpa-gemstone/common-pages 0.0.104 → 0.0.106

Sign up to get free protection for your applications and to get access to all the features.
Files changed (47) hide show
  1. package/lib/ErrorBoundary.d.ts +17 -17
  2. package/lib/ErrorBoundary.js +91 -68
  3. package/lib/Note.d.ts +22 -22
  4. package/lib/Note.js +256 -230
  5. package/lib/SearchBar.d.ts +37 -37
  6. package/lib/SearchBar.js +203 -180
  7. package/lib/SelectionPopup.d.ts +42 -42
  8. package/lib/SelectionPopup.js +93 -90
  9. package/lib/Setting.d.ts +8 -8
  10. package/lib/Setting.js +151 -125
  11. package/lib/SliceInterfaces.d.ts +76 -76
  12. package/lib/SliceInterfaces.js +2 -2
  13. package/lib/StandardSelectPopup.d.ts +20 -20
  14. package/lib/StandardSelectPopup.js +135 -109
  15. package/lib/TimeFilter/QuickSelects.d.ts +7 -0
  16. package/lib/TimeFilter/QuickSelects.js +240 -0
  17. package/lib/TimeFilter.d.ts +26 -0
  18. package/lib/TimeFilter.js +270 -0
  19. package/lib/TimeWindowUtils.d.ts +33 -0
  20. package/lib/TimeWindowUtils.js +121 -0
  21. package/lib/ValueList/ByValueList.d.ts +10 -10
  22. package/lib/ValueList/ByValueList.js +141 -115
  23. package/lib/ValueList/Group.d.ts +11 -11
  24. package/lib/ValueList/Group.js +97 -71
  25. package/lib/ValueList/GroupForm.d.ts +9 -9
  26. package/lib/ValueList/GroupForm.js +74 -51
  27. package/lib/ValueList/GroupInfo.d.ts +8 -8
  28. package/lib/ValueList/GroupInfo.js +95 -69
  29. package/lib/ValueList/GroupItem.d.ts +9 -9
  30. package/lib/ValueList/GroupItem.js +142 -116
  31. package/lib/ValueList/ItemForm.d.ts +9 -9
  32. package/lib/ValueList/ItemForm.js +82 -59
  33. package/lib/index.d.ts +12 -11
  34. package/lib/index.js +50 -45
  35. package/lib/user/AdditionalField.d.ts +26 -26
  36. package/lib/user/AdditionalField.js +290 -264
  37. package/lib/user/ByUser.d.ts +12 -12
  38. package/lib/user/ByUser.js +174 -148
  39. package/lib/user/User.d.ts +14 -14
  40. package/lib/user/User.js +97 -71
  41. package/lib/user/UserForm.d.ts +12 -12
  42. package/lib/user/UserForm.js +166 -143
  43. package/lib/user/UserInfo.d.ts +7 -7
  44. package/lib/user/UserInfo.js +123 -97
  45. package/lib/user/UserPermissions.d.ts +8 -8
  46. package/lib/user/UserPermissions.js +106 -83
  47. package/package.json +11 -10
@@ -1,264 +1,290 @@
1
- "use strict";
2
- // ******************************************************************************************************
3
- // AdditionalField.tsx - Gbtc
4
- //
5
- // Copyright © 2020, Grid Protection Alliance. All Rights Reserved.
6
- //
7
- // Licensed to the Grid Protection Alliance (GPA) under one or more contributor license agreements. See
8
- // the NOTICE file distributed with this work for additional information regarding copyright ownership.
9
- // The GPA licenses this file to you under the MIT License (MIT), the "License"; you may not use this
10
- // file except in compliance with the License. You may obtain a copy of the License at:
11
- //
12
- // http://opensource.org/licenses/MIT
13
- //
14
- // Unless agreed to in writing, the subject software distributed under the License is distributed on an
15
- // "AS-IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. Refer to the
16
- // License for the specific language governing permissions and limitations.
17
- //
18
- // Code Modification History:
19
- // ----------------------------------------------------------------------------------------------------
20
- // 07/14/2021 - C. Lackner
21
- // Generated original version of source code.
22
- // ******************************************************************************************************
23
- var __assign = (this && this.__assign) || function () {
24
- __assign = Object.assign || function(t) {
25
- for (var s, i = 1, n = arguments.length; i < n; i++) {
26
- s = arguments[i];
27
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
28
- t[p] = s[p];
29
- }
30
- return t;
31
- };
32
- return __assign.apply(this, arguments);
33
- };
34
- var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
35
- if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
36
- if (ar || !(i in from)) {
37
- if (!ar) ar = Array.prototype.slice.call(from, 0, i);
38
- ar[i] = from[i];
39
- }
40
- }
41
- return to.concat(ar || Array.prototype.slice.call(from));
42
- };
43
- Object.defineProperty(exports, "__esModule", { value: true });
44
- var React = require("react");
45
- var react_table_1 = require("@gpa-gemstone/react-table");
46
- var gpa_symbols_1 = require("@gpa-gemstone/gpa-symbols");
47
- var react_interactive_1 = require("@gpa-gemstone/react-interactive");
48
- var react_forms_1 = require("@gpa-gemstone/react-forms");
49
- var react_redux_1 = require("react-redux");
50
- var helper_functions_1 = require("@gpa-gemstone/helper-functions");
51
- function AdditionalField(props) {
52
- var dispatch = (0, react_redux_1.useDispatch)();
53
- var valueListItems = (0, react_redux_1.useSelector)(props.ValueListItemSlice.Data);
54
- var valueListItemStatus = (0, react_redux_1.useSelector)(props.ValueListItemSlice.Status);
55
- var valueListGroups = (0, react_redux_1.useSelector)(props.ValueListGroupSlice.Data);
56
- var valueListGroupStatus = (0, react_redux_1.useSelector)(props.ValueListGroupSlice.Status);
57
- var fields = (0, react_redux_1.useSelector)(props.AdditionalFieldSlice.Fields);
58
- var values = (0, react_redux_1.useSelector)(props.AdditionalFieldSlice.Values);
59
- var fieldStatus = (0, react_redux_1.useSelector)(props.AdditionalFieldSlice.FieldStatus);
60
- var valueStatus = (0, react_redux_1.useSelector)(props.AdditionalFieldSlice.ValueStatus);
61
- var valueParentID = (0, react_redux_1.useSelector)(props.AdditionalFieldSlice.ValueParentId);
62
- var _a = React.useState('unintiated'), pageStatus = _a[0], setPageStatus = _a[1];
63
- var _b = React.useState([]), editValues = _b[0], setEditValues = _b[1];
64
- var sortField = (0, react_redux_1.useSelector)(props.AdditionalFieldSlice.SortField);
65
- var ascending = (0, react_redux_1.useSelector)(props.AdditionalFieldSlice.Ascending);
66
- var _c = React.useState(props.EmptyField), newField = _c[0], setNewField = _c[1];
67
- var _d = React.useState(false), showWarning = _d[0], setShowWarning = _d[1];
68
- var _e = React.useState(false), showEdit = _e[0], setShowEdit = _e[1];
69
- var _f = React.useState('None'), hover = _f[0], setHover = _f[1];
70
- var _g = React.useState('View'), mode = _g[0], setMode = _g[1];
71
- var _h = React.useState([]), changedFields = _h[0], setChangedFields = _h[1];
72
- var _j = React.useState([]), errorFields = _j[0], setErrorFields = _j[1];
73
- var _k = React.useState([]), fieldErrors = _k[0], setFieldErrors = _k[1];
74
- React.useEffect(function () {
75
- if (fieldStatus === 'error' || valueStatus === 'error' || valueListGroupStatus === 'error' || valueListItemStatus === 'error')
76
- setPageStatus('error');
77
- else if (fieldStatus === 'loading' || valueStatus === 'loading' || valueListGroupStatus === 'loading' || valueListItemStatus === 'loading')
78
- setPageStatus('loading');
79
- else
80
- setPageStatus('idle');
81
- }, [fieldStatus, valueStatus, valueListGroupStatus, valueListItemStatus]);
82
- React.useEffect(function () {
83
- if (fieldStatus === 'unintiated' || fieldStatus === 'changed')
84
- dispatch(props.AdditionalFieldSlice.FetchField());
85
- }, [dispatch, fieldStatus]);
86
- React.useEffect(function () {
87
- if (valueStatus === 'unintiated' || valueStatus === 'changed' || props.Id !== valueParentID)
88
- dispatch(props.AdditionalFieldSlice.FetchValues(props.Id));
89
- }, [dispatch, valueStatus, props.Id, valueParentID]);
90
- React.useEffect(function () {
91
- if (valueListItemStatus === 'unintiated' || valueListItemStatus === 'changed')
92
- dispatch(props.ValueListItemSlice.Fetch());
93
- }, [dispatch, valueListItemStatus]);
94
- React.useEffect(function () {
95
- if (valueListGroupStatus === 'unintiated' || valueListGroupStatus === 'changed')
96
- dispatch(props.ValueListGroupSlice.Fetch());
97
- }, [dispatch, valueListGroupStatus]);
98
- React.useEffect(function () { setEditValues(values); }, [values]);
99
- var typeOptions = [{ Value: 'string', Label: 'string' }, { Value: 'integer', Label: 'integer' }, { Value: 'number', Label: 'number' }].concat(valueListGroups.map(function (x) { return { Value: x.Name, Label: x.Name }; }));
100
- React.useEffect(function () {
101
- var e = props.ValidateField(newField);
102
- if (newField.FieldName == null || newField.FieldName.length === 0)
103
- e.push('A FieldName is required');
104
- else if (fields.findIndex(function (f) { return f.FieldName.toLowerCase() === newField.FieldName.toLowerCase() && props.FieldKeySelector(f) !== props.FieldKeySelector(newField); }) > -1)
105
- e.push('A Field with this FieldName already exists');
106
- setFieldErrors(e);
107
- }, [newField]);
108
- React.useEffect(function () {
109
- var c = [];
110
- var e = [];
111
- editValues.forEach(function (v) {
112
- var eIndex = values.findIndex(function (val) { return val.ID === v.ID; });
113
- var fldIndex = props.GetFieldIndex(v, fields);
114
- if (eIndex === -1 && fldIndex > -1)
115
- c.push(fields[fldIndex].FieldName);
116
- else if (fldIndex > -1 && v.Value !== values[eIndex].Value)
117
- c.push(fields[fldIndex].FieldName);
118
- if (fldIndex > -1 && fields[fldIndex].Type === 'integer' && !(0, helper_functions_1.IsInteger)(v.Value))
119
- e.push("'" + fields[fldIndex].FieldName + "' has to be a valid integer");
120
- if (fldIndex > -1 && fields[fldIndex].Type === 'number' && !(0, helper_functions_1.IsNumber)(v.Value))
121
- e.push("'" + fields[fldIndex].FieldName + "' has to be a valid number");
122
- });
123
- setErrorFields(e);
124
- setChangedFields(c);
125
- }, [values, editValues]);
126
- if (pageStatus === 'error')
127
- return React.createElement("div", { className: "card", style: { marginBottom: 10, maxHeight: window.innerHeight - 215 } },
128
- React.createElement("div", { className: "card-header" },
129
- React.createElement("div", { className: "row" },
130
- React.createElement("div", { className: "col" },
131
- React.createElement("h4", null, "Additional Fields:")))),
132
- React.createElement("div", { className: "card-body", style: { maxHeight: window.innerHeight - 315, overflowY: 'auto' } },
133
- React.createElement("div", { style: { width: '100%', height: '200px' } },
134
- React.createElement("div", { style: { height: '40px', marginLeft: 'auto', marginRight: 'auto', marginTop: 'calc(50% - 20 px)' } },
135
- React.createElement(react_interactive_1.ServerErrorIcon, { Show: true, Size: 40, Label: 'A Server Error Occurred. Please Reload the Application' })))));
136
- return (React.createElement("div", { className: "card", style: { marginBottom: 10, maxHeight: window.innerHeight - 215 } },
137
- React.createElement("div", { className: "card-header" },
138
- React.createElement("div", { className: "row" },
139
- React.createElement("div", { className: "col" },
140
- React.createElement("h4", null, "Additional Fields:")),
141
- React.createElement("div", { className: "col" },
142
- (mode === 'Edit') ?
143
- React.createElement("button", { className: "btn btn-default pull-right", "data-tooltip": 'View', onClick: function () { setMode('View'); setEditValues(values); }, onMouseEnter: function () { return setHover('View'); }, onMouseLeave: function () { return setHover('None'); } }, "View") :
144
- React.createElement("button", { className: "btn btn-primary pull-right", onClick: function () { return setMode('Edit'); } }, "Edit"),
145
- React.createElement(react_interactive_1.ToolTip, { Show: hover === 'View' && changedFields.length > 0, Position: 'left', Theme: 'dark', Target: "View" }, changedFields.map(function (fld, i) { return React.createElement("p", { key: i },
146
- gpa_symbols_1.Warning,
147
- " Changes to '",
148
- fld,
149
- "' will be lost. "); }))))),
150
- React.createElement("div", { className: "card-body", style: { maxHeight: window.innerHeight - 315, overflowY: 'auto' } },
151
- React.createElement(react_table_1.default, { cols: [
152
- { key: 'FieldName', field: 'FieldName', label: 'Field', headerStyle: { width: 'auto' }, rowStyle: { width: 'auto' } },
153
- { key: 'Type', field: 'Type', label: 'Type', headerStyle: { width: 'auto' }, rowStyle: { width: 'auto' } },
154
- {
155
- key: 'Value', label: 'Value', headerStyle: { width: 'auto' }, rowStyle: { width: 'auto' }, content: function (item) {
156
- var valueListgrpId = valueListGroups.findIndex(function (g) { return g.Name === item.Type; });
157
- valueListgrpId = (valueListgrpId > -1 ? valueListGroups[valueListgrpId].ID : -1);
158
- var vList = valueListItems.filter(function (i) { return i.GroupID === valueListgrpId; });
159
- var valIdx = props.GetFieldValueIndex(item, editValues);
160
- if (valIdx > -1)
161
- return React.createElement(ValueDisplay, { Mode: mode, Type: item.Type, ValueListItems: vList, Value: editValues[valIdx], Setter: function (val) { return setEditValues(function (d) { var u = __spreadArray([], d, true); u[valIdx] = val; return u; }); } });
162
- return React.createElement(ValueDisplay, { Mode: mode, Type: item.Type, ValueListItems: vList, Value: props.CreateValue(item), Setter: function (val) { return setEditValues(function (d) { var u = __spreadArray([], d, true); u.push(val); return u; }); } });
163
- }
164
- },
165
- { key: 'EditButton', label: '', headerStyle: { width: 40, paddingRight: 0, paddingLeft: 10 }, rowStyle: { width: 40, paddingRight: 0, paddingLeft: 10, paddingTop: 36 }, content: function (item) { return (mode === 'Edit' ? React.createElement("button", { className: "btn btn-sm", onClick: function () { setNewField(item); setShowEdit(true); } },
166
- React.createElement("span", null,
167
- React.createElement("i", { className: "fa fa-pencil" }))) : ''); } },
168
- { key: 'DeleteButton', label: '', headerStyle: { width: 40, paddingLeft: 0, paddingRight: 10 }, rowStyle: { width: 40, paddingLeft: 0, paddingTop: 36, paddingRight: 10 }, content: function (item) { return (mode === 'Edit' ? React.createElement("button", { className: "btn btn-sm", onClick: function () { setNewField(item); setShowWarning(true); } },
169
- React.createElement("span", null,
170
- React.createElement("i", { className: "fa fa-times" }))) : ''); } },
171
- ], tableClass: "table table-hover", data: fields, sortKey: sortField, ascending: ascending, onSort: function (d) {
172
- if (d.colField === undefined)
173
- return;
174
- if (d.colKey === sortField)
175
- dispatch(props.AdditionalFieldSlice.Sort({ SortField: d.colField, Ascending: !ascending }));
176
- else
177
- dispatch(props.AdditionalFieldSlice.Sort({ SortField: d.colField, Ascending: true }));
178
- }, onClick: function () { }, theadStyle: { fontSize: 'smaller', display: 'table', tableLayout: 'fixed', width: '100%' }, tbodyStyle: { display: 'block', overflowY: 'scroll', maxHeight: window.innerHeight - 455, }, rowStyle: { display: 'table', tableLayout: 'fixed', width: '100%' }, selected: function () { return false; }, keySelector: props.FieldKeySelector })),
179
- React.createElement("div", { className: "card-footer" },
180
- React.createElement("div", { className: "btn-group mr-2" },
181
- React.createElement("button", { className: "btn btn-primary" + (mode === 'View' ? ' disabled' : ''), onMouseEnter: function () { return setHover('New'); }, onMouseLeave: function () { return setHover('None'); }, onClick: function () { if (mode === 'Edit') {
182
- setShowEdit(true);
183
- setNewField(props.EmptyField);
184
- } }, "data-tooltip": 'New' }, "Add Field")),
185
- React.createElement(react_interactive_1.ToolTip, { Show: hover === 'New' && mode === 'View', Position: 'top', Theme: 'dark', Target: "New" },
186
- React.createElement("p", null, " To add a new Field switch to Edit mode by clicking on the Edit Button on the upper right corner.")),
187
- React.createElement("div", { className: "btn-group mr-2" },
188
- React.createElement("button", { className: "btn btn-primary" + (changedFields.length === 0 || mode === 'View' || errorFields.length > 0 ? ' disabled' : ''), onClick: function () { if (errorFields.length === 0 && changedFields.length > 0 && mode === 'Edit')
189
- dispatch(props.AdditionalFieldSlice.UpdateValues({ ParentID: props.Id, Values: editValues })); }, onMouseEnter: function () { return setHover('Save'); }, onMouseLeave: function () { return setHover('None'); }, "data-tooltip": 'SaveValues' }, "Save Changes")),
190
- React.createElement(react_interactive_1.ToolTip, { Show: hover === 'Save' && (mode === 'View' || changedFields.length > 0), Position: 'top', Theme: 'dark', Target: "SaveValues" },
191
- mode === 'View' ? React.createElement("p", null, " To change any Fields switch to Edit mode by clicking on the Edit Button on the upper right corner.") : null,
192
- changedFields.length > 0 && errorFields.length === 0 ? changedFields.map(function (fld, i) { return React.createElement("p", { key: i },
193
- " ",
194
- gpa_symbols_1.HeavyCheckMark,
195
- " Changes to '",
196
- fld,
197
- "' are valid."); }) : null,
198
- changedFields.length > 0 && errorFields.length > 0 ? errorFields.map(function (t, i) { return React.createElement("p", { key: i },
199
- " ",
200
- gpa_symbols_1.CrossMark,
201
- " ",
202
- t,
203
- "."); }) : null),
204
- React.createElement("div", { className: "btn-group mr-2" },
205
- React.createElement("button", { className: "btn btn-default" + (changedFields.length === 0 || mode === 'View' ? ' disabled' : ''), onClick: function () {
206
- if (changedFields.length > 0 && mode === 'Edit')
207
- setEditValues(values);
208
- }, onMouseEnter: function () { return setHover('Clear'); }, onMouseLeave: function () { return setHover('None'); }, "data-tooltip": 'Reset' }, "Reset")),
209
- React.createElement(react_interactive_1.ToolTip, { Show: hover === 'Clear' && (mode === 'View' || changedFields.length > 0), Position: 'top', Theme: 'dark', Target: 'Reset' },
210
- mode === 'View' ? React.createElement("p", null, " To change any Fields switch to Edit mode by clicking on the Edit Button on the upper right corner.") : null,
211
- changedFields.length > 0 ? changedFields.map(function (fld, i) { return React.createElement("p", { key: i },
212
- gpa_symbols_1.Warning,
213
- " Changes to '",
214
- fld,
215
- "' will be lost. "); }) : null)),
216
- React.createElement(react_interactive_1.Warning, { Show: showWarning, Title: 'Delete ' + newField.FieldName, Message: "This will delete all instances of '" + newField.FieldName + "' and will also delete all information assigned to these fields.", CallBack: function (confirm) { if (confirm)
217
- dispatch(props.AdditionalFieldSlice.FieldAction({ Verb: 'DELETE', Record: newField })); setShowWarning(false); } }),
218
- React.createElement(react_interactive_1.Modal, { Title: 'Additional Field', ConfirmText: 'Save', ShowX: true, ShowCancel: false, ConfirmBtnClass: 'btn-primary' + (fieldErrors.length > 0 ? ' disabled' : ''), Show: showEdit, Size: 'lg', CallBack: function (confirmation) {
219
- if (confirmation) {
220
- if (props.FieldKeySelector(newField) === "new")
221
- dispatch(props.AdditionalFieldSlice.FieldAction({ Verb: "POST", Record: newField }));
222
- else
223
- dispatch(props.AdditionalFieldSlice.FieldAction({ Verb: "PATCH", Record: newField }));
224
- }
225
- setShowEdit(false);
226
- }, ConfirmShowToolTip: fieldErrors.length > 0, ConfirmToolTipContent: fieldErrors.map(function (t, i) { return React.createElement("p", { key: i },
227
- gpa_symbols_1.CrossMark,
228
- " ",
229
- t,
230
- " "); }) },
231
- React.createElement(react_forms_1.Input, { Record: newField, Field: 'FieldName', Valid: function (field) {
232
- return newField.FieldName != null && newField.FieldName.length > 0
233
- && fields.findIndex(function (f) { return f.FieldName.toLowerCase() === newField.FieldName.toLowerCase() && props.FieldKeySelector(f) !== props.FieldKeySelector(newField); }) < 0;
234
- }, Label: "Field Name", Setter: setNewField, Feedback: 'The additional field needs to have a unique Field Name' }),
235
- React.createElement(react_forms_1.Select, { Record: newField, Field: 'Type', Options: typeOptions, Label: "Field Type", Setter: setNewField }),
236
- props.FieldUI !== undefined ? props.FieldUI(newField, setNewField) : null)));
237
- }
238
- exports.default = AdditionalField;
239
- function ValueDisplay(props) {
240
- React.useEffect(function () {
241
- if (props.Type === 'integer' || props.Type === 'number' || props.Type === 'string')
242
- return;
243
- else if (props.Type !== 'boolean' &&
244
- props.ValueListItems.findIndex(function (i) { return i.Value.toLowerCase() === props.Value.Value.toString().toLowerCase(); }) < 0
245
- && props.ValueListItems.length > 0)
246
- props.Setter(__assign(__assign({}, props.Value), { Value: props.ValueListItems[0].Value }));
247
- }, [props.Type, props.Value, props.ValueListItems]);
248
- if (props.Mode === 'View') {
249
- if (props.Type === 'boolean')
250
- return React.createElement("span", null, props.Value.Value.toString().toLowerCase() === "true" ? "true" : "false");
251
- else
252
- return React.createElement("span", null, props.Value.Value);
253
- }
254
- if (props.Type === 'number')
255
- return React.createElement(react_forms_1.Input, { Record: props.Value, Field: 'Value', Valid: function () { return (0, helper_functions_1.IsInteger)(props.Value.Value); }, Label: '', Type: 'number', Setter: props.Setter, Feedback: 'Thi Field is a numeric field.' });
256
- if (props.Type === 'integer')
257
- return React.createElement(react_forms_1.Input, { Record: props.Value, Field: 'Value', Valid: function () { return (0, helper_functions_1.IsNumber)(props.Value.Value); }, Label: '', Type: 'number', Setter: props.Setter, Feedback: 'Thi Field is an integer field.' });
258
- else if (props.Type === 'string')
259
- return React.createElement(react_forms_1.Input, { Record: props.Value, Field: 'Value', Valid: function () { return true; }, Label: '', Type: 'text', Setter: props.Setter });
260
- else if (props.Type === 'boolean')
261
- return React.createElement(react_forms_1.CheckBox, { Record: props.Value, Field: 'Value', Label: '', Setter: props.Setter });
262
- else
263
- return React.createElement(react_forms_1.Select, { EmptyOption: true, Record: props.Value, Field: 'Value', Label: '', Setter: props.Setter, Options: props.ValueListItems.map(function (x) { return ({ Value: x.ID.toString(), Label: x.Value }); }) });
264
- }
1
+ "use strict";
2
+ // ******************************************************************************************************
3
+ // AdditionalField.tsx - Gbtc
4
+ //
5
+ // Copyright © 2020, Grid Protection Alliance. All Rights Reserved.
6
+ //
7
+ // Licensed to the Grid Protection Alliance (GPA) under one or more contributor license agreements. See
8
+ // the NOTICE file distributed with this work for additional information regarding copyright ownership.
9
+ // The GPA licenses this file to you under the MIT License (MIT), the "License"; you may not use this
10
+ // file except in compliance with the License. You may obtain a copy of the License at:
11
+ //
12
+ // http://opensource.org/licenses/MIT
13
+ //
14
+ // Unless agreed to in writing, the subject software distributed under the License is distributed on an
15
+ // "AS-IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. Refer to the
16
+ // License for the specific language governing permissions and limitations.
17
+ //
18
+ // Code Modification History:
19
+ // ----------------------------------------------------------------------------------------------------
20
+ // 07/14/2021 - C. Lackner
21
+ // Generated original version of source code.
22
+ // ******************************************************************************************************
23
+ var __assign = (this && this.__assign) || function () {
24
+ __assign = Object.assign || function(t) {
25
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
26
+ s = arguments[i];
27
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
28
+ t[p] = s[p];
29
+ }
30
+ return t;
31
+ };
32
+ return __assign.apply(this, arguments);
33
+ };
34
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
35
+ if (k2 === undefined) k2 = k;
36
+ var desc = Object.getOwnPropertyDescriptor(m, k);
37
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
38
+ desc = { enumerable: true, get: function() { return m[k]; } };
39
+ }
40
+ Object.defineProperty(o, k2, desc);
41
+ }) : (function(o, m, k, k2) {
42
+ if (k2 === undefined) k2 = k;
43
+ o[k2] = m[k];
44
+ }));
45
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
46
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
47
+ }) : function(o, v) {
48
+ o["default"] = v;
49
+ });
50
+ var __importStar = (this && this.__importStar) || function (mod) {
51
+ if (mod && mod.__esModule) return mod;
52
+ var result = {};
53
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
54
+ __setModuleDefault(result, mod);
55
+ return result;
56
+ };
57
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
58
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
59
+ if (ar || !(i in from)) {
60
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
61
+ ar[i] = from[i];
62
+ }
63
+ }
64
+ return to.concat(ar || Array.prototype.slice.call(from));
65
+ };
66
+ var __importDefault = (this && this.__importDefault) || function (mod) {
67
+ return (mod && mod.__esModule) ? mod : { "default": mod };
68
+ };
69
+ Object.defineProperty(exports, "__esModule", { value: true });
70
+ var React = __importStar(require("react"));
71
+ var react_table_1 = __importDefault(require("@gpa-gemstone/react-table"));
72
+ var gpa_symbols_1 = require("@gpa-gemstone/gpa-symbols");
73
+ var react_interactive_1 = require("@gpa-gemstone/react-interactive");
74
+ var react_forms_1 = require("@gpa-gemstone/react-forms");
75
+ var react_redux_1 = require("react-redux");
76
+ var helper_functions_1 = require("@gpa-gemstone/helper-functions");
77
+ function AdditionalField(props) {
78
+ var dispatch = (0, react_redux_1.useDispatch)();
79
+ var valueListItems = (0, react_redux_1.useSelector)(props.ValueListItemSlice.Data);
80
+ var valueListItemStatus = (0, react_redux_1.useSelector)(props.ValueListItemSlice.Status);
81
+ var valueListGroups = (0, react_redux_1.useSelector)(props.ValueListGroupSlice.Data);
82
+ var valueListGroupStatus = (0, react_redux_1.useSelector)(props.ValueListGroupSlice.Status);
83
+ var fields = (0, react_redux_1.useSelector)(props.AdditionalFieldSlice.Fields);
84
+ var values = (0, react_redux_1.useSelector)(props.AdditionalFieldSlice.Values);
85
+ var fieldStatus = (0, react_redux_1.useSelector)(props.AdditionalFieldSlice.FieldStatus);
86
+ var valueStatus = (0, react_redux_1.useSelector)(props.AdditionalFieldSlice.ValueStatus);
87
+ var valueParentID = (0, react_redux_1.useSelector)(props.AdditionalFieldSlice.ValueParentId);
88
+ var _a = React.useState('unintiated'), pageStatus = _a[0], setPageStatus = _a[1];
89
+ var _b = React.useState([]), editValues = _b[0], setEditValues = _b[1];
90
+ var sortField = (0, react_redux_1.useSelector)(props.AdditionalFieldSlice.SortField);
91
+ var ascending = (0, react_redux_1.useSelector)(props.AdditionalFieldSlice.Ascending);
92
+ var _c = React.useState(props.EmptyField), newField = _c[0], setNewField = _c[1];
93
+ var _d = React.useState(false), showWarning = _d[0], setShowWarning = _d[1];
94
+ var _e = React.useState(false), showEdit = _e[0], setShowEdit = _e[1];
95
+ var _f = React.useState('None'), hover = _f[0], setHover = _f[1];
96
+ var _g = React.useState('View'), mode = _g[0], setMode = _g[1];
97
+ var _h = React.useState([]), changedFields = _h[0], setChangedFields = _h[1];
98
+ var _j = React.useState([]), errorFields = _j[0], setErrorFields = _j[1];
99
+ var _k = React.useState([]), fieldErrors = _k[0], setFieldErrors = _k[1];
100
+ React.useEffect(function () {
101
+ if (fieldStatus === 'error' || valueStatus === 'error' || valueListGroupStatus === 'error' || valueListItemStatus === 'error')
102
+ setPageStatus('error');
103
+ else if (fieldStatus === 'loading' || valueStatus === 'loading' || valueListGroupStatus === 'loading' || valueListItemStatus === 'loading')
104
+ setPageStatus('loading');
105
+ else
106
+ setPageStatus('idle');
107
+ }, [fieldStatus, valueStatus, valueListGroupStatus, valueListItemStatus]);
108
+ React.useEffect(function () {
109
+ if (fieldStatus === 'unintiated' || fieldStatus === 'changed')
110
+ dispatch(props.AdditionalFieldSlice.FetchField());
111
+ }, [dispatch, fieldStatus]);
112
+ React.useEffect(function () {
113
+ if (valueStatus === 'unintiated' || valueStatus === 'changed' || props.Id !== valueParentID)
114
+ dispatch(props.AdditionalFieldSlice.FetchValues(props.Id));
115
+ }, [dispatch, valueStatus, props.Id, valueParentID]);
116
+ React.useEffect(function () {
117
+ if (valueListItemStatus === 'unintiated' || valueListItemStatus === 'changed')
118
+ dispatch(props.ValueListItemSlice.Fetch());
119
+ }, [dispatch, valueListItemStatus]);
120
+ React.useEffect(function () {
121
+ if (valueListGroupStatus === 'unintiated' || valueListGroupStatus === 'changed')
122
+ dispatch(props.ValueListGroupSlice.Fetch());
123
+ }, [dispatch, valueListGroupStatus]);
124
+ React.useEffect(function () { setEditValues(values); }, [values]);
125
+ var typeOptions = [{ Value: 'string', Label: 'string' }, { Value: 'integer', Label: 'integer' }, { Value: 'number', Label: 'number' }].concat(valueListGroups.map(function (x) { return { Value: x.Name, Label: x.Name }; }));
126
+ React.useEffect(function () {
127
+ var e = props.ValidateField(newField);
128
+ if (newField.FieldName == null || newField.FieldName.length === 0)
129
+ e.push('A FieldName is required');
130
+ else if (fields.findIndex(function (f) { return f.FieldName.toLowerCase() === newField.FieldName.toLowerCase() && props.FieldKeySelector(f) !== props.FieldKeySelector(newField); }) > -1)
131
+ e.push('A Field with this FieldName already exists');
132
+ setFieldErrors(e);
133
+ }, [newField]);
134
+ React.useEffect(function () {
135
+ var c = [];
136
+ var e = [];
137
+ editValues.forEach(function (v) {
138
+ var eIndex = values.findIndex(function (val) { return val.ID === v.ID; });
139
+ var fldIndex = props.GetFieldIndex(v, fields);
140
+ if (eIndex === -1 && fldIndex > -1)
141
+ c.push(fields[fldIndex].FieldName);
142
+ else if (fldIndex > -1 && v.Value !== values[eIndex].Value)
143
+ c.push(fields[fldIndex].FieldName);
144
+ if (fldIndex > -1 && fields[fldIndex].Type === 'integer' && !(0, helper_functions_1.IsInteger)(v.Value))
145
+ e.push("'" + fields[fldIndex].FieldName + "' has to be a valid integer");
146
+ if (fldIndex > -1 && fields[fldIndex].Type === 'number' && !(0, helper_functions_1.IsNumber)(v.Value))
147
+ e.push("'" + fields[fldIndex].FieldName + "' has to be a valid number");
148
+ });
149
+ setErrorFields(e);
150
+ setChangedFields(c);
151
+ }, [values, editValues]);
152
+ if (pageStatus === 'error')
153
+ return React.createElement("div", { className: "card", style: { marginBottom: 10, maxHeight: window.innerHeight - 215 } },
154
+ React.createElement("div", { className: "card-header" },
155
+ React.createElement("div", { className: "row" },
156
+ React.createElement("div", { className: "col" },
157
+ React.createElement("h4", null, "Additional Fields:")))),
158
+ React.createElement("div", { className: "card-body", style: { maxHeight: window.innerHeight - 315, overflowY: 'auto' } },
159
+ React.createElement("div", { style: { width: '100%', height: '200px' } },
160
+ React.createElement("div", { style: { height: '40px', marginLeft: 'auto', marginRight: 'auto', marginTop: 'calc(50% - 20 px)' } },
161
+ React.createElement(react_interactive_1.ServerErrorIcon, { Show: true, Size: 40, Label: 'A Server Error Occurred. Please Reload the Application' })))));
162
+ return (React.createElement("div", { className: "card", style: { marginBottom: 10, maxHeight: window.innerHeight - 215 } },
163
+ React.createElement("div", { className: "card-header" },
164
+ React.createElement("div", { className: "row" },
165
+ React.createElement("div", { className: "col" },
166
+ React.createElement("h4", null, "Additional Fields:")),
167
+ React.createElement("div", { className: "col" },
168
+ (mode === 'Edit') ?
169
+ React.createElement("button", { className: "btn btn-default pull-right", "data-tooltip": 'View', onClick: function () { setMode('View'); setEditValues(values); }, onMouseEnter: function () { return setHover('View'); }, onMouseLeave: function () { return setHover('None'); } }, "View") :
170
+ React.createElement("button", { className: "btn btn-primary pull-right", onClick: function () { return setMode('Edit'); } }, "Edit"),
171
+ React.createElement(react_interactive_1.ToolTip, { Show: hover === 'View' && changedFields.length > 0, Position: 'left', Theme: 'dark', Target: "View" }, changedFields.map(function (fld, i) { return React.createElement("p", { key: i },
172
+ gpa_symbols_1.Warning,
173
+ " Changes to '",
174
+ fld,
175
+ "' will be lost. "); }))))),
176
+ React.createElement("div", { className: "card-body", style: { maxHeight: window.innerHeight - 315, overflowY: 'auto' } },
177
+ React.createElement(react_table_1.default, { cols: [
178
+ { key: 'FieldName', field: 'FieldName', label: 'Field', headerStyle: { width: 'auto' }, rowStyle: { width: 'auto' } },
179
+ { key: 'Type', field: 'Type', label: 'Type', headerStyle: { width: 'auto' }, rowStyle: { width: 'auto' } },
180
+ {
181
+ key: 'Value', label: 'Value', headerStyle: { width: 'auto' }, rowStyle: { width: 'auto' }, content: function (item) {
182
+ var valueListgrpId = valueListGroups.findIndex(function (g) { return g.Name === item.Type; });
183
+ valueListgrpId = (valueListgrpId > -1 ? valueListGroups[valueListgrpId].ID : -1);
184
+ var vList = valueListItems.filter(function (i) { return i.GroupID === valueListgrpId; });
185
+ var valIdx = props.GetFieldValueIndex(item, editValues);
186
+ if (valIdx > -1)
187
+ return React.createElement(ValueDisplay, { Mode: mode, Type: item.Type, ValueListItems: vList, Value: editValues[valIdx], Setter: function (val) { return setEditValues(function (d) { var u = __spreadArray([], d, true); u[valIdx] = val; return u; }); } });
188
+ return React.createElement(ValueDisplay, { Mode: mode, Type: item.Type, ValueListItems: vList, Value: props.CreateValue(item), Setter: function (val) { return setEditValues(function (d) { var u = __spreadArray([], d, true); u.push(val); return u; }); } });
189
+ }
190
+ },
191
+ { key: 'EditButton', label: '', headerStyle: { width: 40, paddingRight: 0, paddingLeft: 10 }, rowStyle: { width: 40, paddingRight: 0, paddingLeft: 10, paddingTop: 36 }, content: function (item) { return (mode === 'Edit' ? React.createElement("button", { className: "btn btn-sm", onClick: function () { setNewField(item); setShowEdit(true); } },
192
+ React.createElement("span", null,
193
+ React.createElement("i", { className: "fa fa-pencil" }))) : ''); } },
194
+ { key: 'DeleteButton', label: '', headerStyle: { width: 40, paddingLeft: 0, paddingRight: 10 }, rowStyle: { width: 40, paddingLeft: 0, paddingTop: 36, paddingRight: 10 }, content: function (item) { return (mode === 'Edit' ? React.createElement("button", { className: "btn btn-sm", onClick: function () { setNewField(item); setShowWarning(true); } },
195
+ React.createElement("span", null,
196
+ React.createElement("i", { className: "fa fa-times" }))) : ''); } },
197
+ ], tableClass: "table table-hover", data: fields, sortKey: sortField, ascending: ascending, onSort: function (d) {
198
+ if (d.colField === undefined)
199
+ return;
200
+ if (d.colKey === sortField)
201
+ dispatch(props.AdditionalFieldSlice.Sort({ SortField: d.colField, Ascending: !ascending }));
202
+ else
203
+ dispatch(props.AdditionalFieldSlice.Sort({ SortField: d.colField, Ascending: true }));
204
+ }, onClick: function () { }, theadStyle: { fontSize: 'smaller', display: 'table', tableLayout: 'fixed', width: '100%' }, tbodyStyle: { display: 'block', overflowY: 'scroll', maxHeight: window.innerHeight - 455, }, rowStyle: { display: 'table', tableLayout: 'fixed', width: '100%' }, selected: function () { return false; }, keySelector: props.FieldKeySelector })),
205
+ React.createElement("div", { className: "card-footer" },
206
+ React.createElement("div", { className: "btn-group mr-2" },
207
+ React.createElement("button", { className: "btn btn-primary" + (mode === 'View' ? ' disabled' : ''), onMouseEnter: function () { return setHover('New'); }, onMouseLeave: function () { return setHover('None'); }, onClick: function () { if (mode === 'Edit') {
208
+ setShowEdit(true);
209
+ setNewField(props.EmptyField);
210
+ } }, "data-tooltip": 'New' }, "Add Field")),
211
+ React.createElement(react_interactive_1.ToolTip, { Show: hover === 'New' && mode === 'View', Position: 'top', Theme: 'dark', Target: "New" },
212
+ React.createElement("p", null, " To add a new Field switch to Edit mode by clicking on the Edit Button on the upper right corner.")),
213
+ React.createElement("div", { className: "btn-group mr-2" },
214
+ React.createElement("button", { className: "btn btn-primary" + (changedFields.length === 0 || mode === 'View' || errorFields.length > 0 ? ' disabled' : ''), onClick: function () { if (errorFields.length === 0 && changedFields.length > 0 && mode === 'Edit')
215
+ dispatch(props.AdditionalFieldSlice.UpdateValues({ ParentID: props.Id, Values: editValues })); }, onMouseEnter: function () { return setHover('Save'); }, onMouseLeave: function () { return setHover('None'); }, "data-tooltip": 'SaveValues' }, "Save Changes")),
216
+ React.createElement(react_interactive_1.ToolTip, { Show: hover === 'Save' && (mode === 'View' || changedFields.length > 0), Position: 'top', Theme: 'dark', Target: "SaveValues" },
217
+ mode === 'View' ? React.createElement("p", null, " To change any Fields switch to Edit mode by clicking on the Edit Button on the upper right corner.") : null,
218
+ changedFields.length > 0 && errorFields.length === 0 ? changedFields.map(function (fld, i) { return React.createElement("p", { key: i },
219
+ " ",
220
+ gpa_symbols_1.HeavyCheckMark,
221
+ " Changes to '",
222
+ fld,
223
+ "' are valid."); }) : null,
224
+ changedFields.length > 0 && errorFields.length > 0 ? errorFields.map(function (t, i) { return React.createElement("p", { key: i },
225
+ " ",
226
+ gpa_symbols_1.CrossMark,
227
+ " ",
228
+ t,
229
+ "."); }) : null),
230
+ React.createElement("div", { className: "btn-group mr-2" },
231
+ React.createElement("button", { className: "btn btn-default" + (changedFields.length === 0 || mode === 'View' ? ' disabled' : ''), onClick: function () {
232
+ if (changedFields.length > 0 && mode === 'Edit')
233
+ setEditValues(values);
234
+ }, onMouseEnter: function () { return setHover('Clear'); }, onMouseLeave: function () { return setHover('None'); }, "data-tooltip": 'Reset' }, "Reset")),
235
+ React.createElement(react_interactive_1.ToolTip, { Show: hover === 'Clear' && (mode === 'View' || changedFields.length > 0), Position: 'top', Theme: 'dark', Target: 'Reset' },
236
+ mode === 'View' ? React.createElement("p", null, " To change any Fields switch to Edit mode by clicking on the Edit Button on the upper right corner.") : null,
237
+ changedFields.length > 0 ? changedFields.map(function (fld, i) { return React.createElement("p", { key: i },
238
+ gpa_symbols_1.Warning,
239
+ " Changes to '",
240
+ fld,
241
+ "' will be lost. "); }) : null)),
242
+ React.createElement(react_interactive_1.Warning, { Show: showWarning, Title: 'Delete ' + newField.FieldName, Message: "This will delete all instances of '" + newField.FieldName + "' and will also delete all information assigned to these fields.", CallBack: function (confirm) { if (confirm)
243
+ dispatch(props.AdditionalFieldSlice.FieldAction({ Verb: 'DELETE', Record: newField })); setShowWarning(false); } }),
244
+ React.createElement(react_interactive_1.Modal, { Title: 'Additional Field', ConfirmText: 'Save', ShowX: true, ShowCancel: false, ConfirmBtnClass: 'btn-primary' + (fieldErrors.length > 0 ? ' disabled' : ''), Show: showEdit, Size: 'lg', CallBack: function (confirmation) {
245
+ if (confirmation) {
246
+ if (props.FieldKeySelector(newField) === "new")
247
+ dispatch(props.AdditionalFieldSlice.FieldAction({ Verb: "POST", Record: newField }));
248
+ else
249
+ dispatch(props.AdditionalFieldSlice.FieldAction({ Verb: "PATCH", Record: newField }));
250
+ }
251
+ setShowEdit(false);
252
+ }, ConfirmShowToolTip: fieldErrors.length > 0, ConfirmToolTipContent: fieldErrors.map(function (t, i) { return React.createElement("p", { key: i },
253
+ gpa_symbols_1.CrossMark,
254
+ " ",
255
+ t,
256
+ " "); }) },
257
+ React.createElement(react_forms_1.Input, { Record: newField, Field: 'FieldName', Valid: function (field) {
258
+ return newField.FieldName != null && newField.FieldName.length > 0
259
+ && fields.findIndex(function (f) { return f.FieldName.toLowerCase() === newField.FieldName.toLowerCase() && props.FieldKeySelector(f) !== props.FieldKeySelector(newField); }) < 0;
260
+ }, Label: "Field Name", Setter: setNewField, Feedback: 'The additional field needs to have a unique Field Name' }),
261
+ React.createElement(react_forms_1.Select, { Record: newField, Field: 'Type', Options: typeOptions, Label: "Field Type", Setter: setNewField }),
262
+ props.FieldUI !== undefined ? props.FieldUI(newField, setNewField) : null)));
263
+ }
264
+ exports.default = AdditionalField;
265
+ function ValueDisplay(props) {
266
+ React.useEffect(function () {
267
+ if (props.Type === 'integer' || props.Type === 'number' || props.Type === 'string')
268
+ return;
269
+ else if (props.Type !== 'boolean' &&
270
+ props.ValueListItems.findIndex(function (i) { return i.Value.toLowerCase() === props.Value.Value.toString().toLowerCase(); }) < 0
271
+ && props.ValueListItems.length > 0)
272
+ props.Setter(__assign(__assign({}, props.Value), { Value: props.ValueListItems[0].Value }));
273
+ }, [props.Type, props.Value, props.ValueListItems]);
274
+ if (props.Mode === 'View') {
275
+ if (props.Type === 'boolean')
276
+ return React.createElement("span", null, props.Value.Value.toString().toLowerCase() === "true" ? "true" : "false");
277
+ else
278
+ return React.createElement("span", null, props.Value.Value);
279
+ }
280
+ if (props.Type === 'number')
281
+ return React.createElement(react_forms_1.Input, { Record: props.Value, Field: 'Value', Valid: function () { return (0, helper_functions_1.IsInteger)(props.Value.Value); }, Label: '', Type: 'number', Setter: props.Setter, Feedback: 'Thi Field is a numeric field.' });
282
+ if (props.Type === 'integer')
283
+ return React.createElement(react_forms_1.Input, { Record: props.Value, Field: 'Value', Valid: function () { return (0, helper_functions_1.IsNumber)(props.Value.Value); }, Label: '', Type: 'number', Setter: props.Setter, Feedback: 'Thi Field is an integer field.' });
284
+ else if (props.Type === 'string')
285
+ return React.createElement(react_forms_1.Input, { Record: props.Value, Field: 'Value', Valid: function () { return true; }, Label: '', Type: 'text', Setter: props.Setter });
286
+ else if (props.Type === 'boolean')
287
+ return React.createElement(react_forms_1.CheckBox, { Record: props.Value, Field: 'Value', Label: '', Setter: props.Setter });
288
+ else
289
+ return React.createElement(react_forms_1.Select, { EmptyOption: true, Record: props.Value, Field: 'Value', Label: '', Setter: props.Setter, Options: props.ValueListItems.map(function (x) { return ({ Value: x.ID.toString(), Label: x.Value }); }) });
290
+ }