@agilemotion/oui-react-js 1.6.3 → 1.6.5
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 +675 -1044
- package/dist/BasicApp.js +7 -27
- package/dist/BasicAppHome.js +27 -101
- package/dist/DynamicJS.js +109 -197
- package/dist/InteractionPortalApp.js +7 -27
- package/dist/InteractionPortalAppHome.js +21 -87
- package/dist/InteractionPortalApp_old.js +60 -122
- package/dist/RestUtils.js +269 -410
- package/dist/TypedValue.js +20 -26
- package/dist/Utils.js +295 -481
- package/dist/WithRouter.js +9 -17
- package/dist/assets/jss/components/authNavbarStyle.js +168 -171
- package/dist/assets/jss/components/buttonStyle.js +2 -5
- package/dist/assets/jss/components/cardAvatarStyle.js +2 -5
- package/dist/assets/jss/components/cardBodyStyle.js +2 -5
- package/dist/assets/jss/components/cardFooterStyle.js +2 -5
- package/dist/assets/jss/components/cardHeaderStyle.js +20 -17
- package/dist/assets/jss/components/cardIconStyle.js +2 -5
- package/dist/assets/jss/components/cardStyle.js +2 -5
- package/dist/assets/jss/components/cardTextStyle.js +2 -5
- package/dist/assets/jss/components/customDropdownStyle.js +171 -173
- package/dist/assets/jss/components/customInputStyle.js +5 -13
- package/dist/assets/jss/components/dropdownStyle.js +71 -74
- package/dist/assets/jss/components/footerStyle.js +14 -23
- package/dist/assets/jss/components/headerLinksStyle.js +52 -53
- package/dist/assets/jss/components/headerStyle.js +68 -73
- package/dist/assets/jss/components/navbarLinksStyle.js +81 -74
- package/dist/assets/jss/components/navbarStyle.js +79 -84
- package/dist/assets/jss/components/sidebarStyle.js +438 -441
- package/dist/assets/jss/components/typographyStyle.js +5 -13
- package/dist/assets/jss/rootStyle.js +85 -151
- package/dist/assets/jss/views/layoutStyle.js +45 -51
- package/dist/assets/jss/views/loginBasicStyle.js +2 -5
- package/dist/assets/jss/views/loginBusinessPortalStyle.js +2 -5
- package/dist/assets/jss/views/loginStyle.js +80 -87
- package/dist/components/AlertBar.js +20 -75
- package/dist/components/AlertItem.js +13 -49
- package/dist/components/AlertTemplate.js +12 -18
- package/dist/components/Button.js +41 -112
- package/dist/components/Calendar.js +99 -208
- package/dist/components/ConfirmationDialog.js +13 -54
- package/dist/components/DataGrid.js +271 -695
- package/dist/components/DataGridColumn.js +24 -74
- package/dist/components/DataGridFilter.js +107 -245
- package/dist/components/DataGridHeading.js +34 -78
- package/dist/components/Dialog.js +37 -130
- package/dist/components/DocumentTemplateDesigner.js +16 -57
- package/dist/components/DocumentTemplateDesignerComponent.js +47 -141
- package/dist/components/DocumentTemplatePlaceholderDialog.js +34 -67
- package/dist/components/DocumentViewer.js +25 -65
- package/dist/components/DocumentViewerComponent.js +13 -44
- package/dist/components/ElementResizeHandler.js +148 -200
- package/dist/components/FileThumb.js +15 -56
- package/dist/components/Graph.js +98 -203
- package/dist/components/GraphNode.js +20 -61
- package/dist/components/HtmlPanel.js +38 -105
- package/dist/components/Icon.js +174 -253
- package/dist/components/LoadingIndicator.js +4 -11
- package/dist/components/LottieIcon.js +63 -60
- package/dist/components/PopupView.js +21 -60
- package/dist/components/Portlet.js +18 -60
- package/dist/components/RegularButton.js +34 -42
- package/dist/components/SignaturePanel.js +19 -67
- package/dist/components/SocketManager.js +133 -228
- package/dist/components/StepperTitleBar.js +48 -99
- package/dist/components/TabPage.js +30 -47
- package/dist/components/TabPanel.js +35 -122
- package/dist/components/TableCellContent.js +34 -98
- package/dist/components/TemplateDesigner.js +115 -230
- package/dist/components/TemplateItemEventHandler.js +298 -481
- package/dist/components/TemplateTable.js +117 -218
- package/dist/components/TitleBar.js +15 -53
- package/dist/components/Toolbar.js +44 -110
- package/dist/components/Tooltip.js +37 -56
- package/dist/components/Tree.js +50 -143
- package/dist/components/UseIsVisible.js +5 -25
- package/dist/components/card/Card.js +35 -39
- package/dist/components/card/CardAvatar.js +21 -32
- package/dist/components/card/CardBody.js +29 -36
- package/dist/components/card/CardFooter.js +26 -35
- package/dist/components/card/CardHeader.js +29 -36
- package/dist/components/card/CardIcon.js +15 -29
- package/dist/components/card/CardText.js +15 -29
- package/dist/components/customInput/CustomInput.js +38 -40
- package/dist/components/dashboard/FoldingSideTabDashboard.js +65 -184
- package/dist/components/dashboard/SideMenuModuleDashboard.js +67 -185
- package/dist/components/dashboard/TopMenuModuleDashboard.js +22 -63
- package/dist/components/dashboard/components/Header.js +15 -52
- package/dist/components/dashboard/components/LeftDrawer.js +9 -23
- package/dist/components/dashboard/components/UserIdentity.js +4 -12
- package/dist/components/dashboard/components/blackDashboard/fixedPlugin/FixedPlugin.js +115 -155
- package/dist/components/dashboard/components/blackDashboard/sidebar/FoldingTabSidebar.js +344 -419
- package/dist/components/dashboard/components/blackDashboard/sidebar/ModuleMenu.js +15 -29
- package/dist/components/dashboard/components/blackDashboard/sidebar/ModuleMenuSidebar.js +405 -485
- package/dist/components/dashboard/components/portal/Timeline.js +3 -8
- package/dist/components/dashboard/components/portal/Workspace.js +4 -13
- package/dist/components/footer/Footer.js +23 -45
- package/dist/components/footer/HomeFooter.js +38 -78
- package/dist/components/form/AddressSearch.js +26 -76
- package/dist/components/form/AutoComplete.js +54 -168
- package/dist/components/form/BaseField.js +59 -189
- package/dist/components/form/Checkbox.js +11 -24
- package/dist/components/form/DatePicker.js +28 -82
- package/dist/components/form/FieldSet.js +84 -300
- package/dist/components/form/Form.js +206 -501
- package/dist/components/form/GridField.js +83 -243
- package/dist/components/form/IconField.js +10 -21
- package/dist/components/form/ImageEditor.js +98 -208
- package/dist/components/form/LabelField.js +13 -28
- package/dist/components/form/LookupField.js +36 -102
- package/dist/components/form/MultiFileUploadField.js +67 -134
- package/dist/components/form/RadioGroup.js +20 -57
- package/dist/components/form/Section.js +33 -118
- package/dist/components/form/SelectItem.js +36 -83
- package/dist/components/form/SignatureTemplateDesignerField.js +12 -26
- package/dist/components/form/Switch.js +11 -24
- package/dist/components/form/TextField.js +19 -55
- package/dist/components/form/TimePicker.js +18 -43
- package/dist/components/form/TransferList.js +76 -200
- package/dist/components/form/UploadField.js +134 -256
- package/dist/components/grid/GridContainer.js +10 -23
- package/dist/components/grid/GridItem.js +10 -23
- package/dist/components/layout/CollapsiblePanel.js +20 -59
- package/dist/components/layout/Layout.js +40 -149
- package/dist/components/layout/View.js +65 -195
- package/dist/components/layout/ViewContainer.js +13 -33
- package/dist/components/layout/ViewPort.js +14 -48
- package/dist/components/layout/Window.js +62 -135
- package/dist/components/layout/WindowViewPort.js +18 -63
- package/dist/components/media/ClosablePanel.js +9 -18
- package/dist/components/media/LobbyWaitingList.js +11 -17
- package/dist/components/media/MediaSoupHelper.js +173 -401
- package/dist/components/media/SideBarContent.js +17 -34
- package/dist/components/media/SocketRequest.js +7 -18
- package/dist/components/media/SocketResponse.js +5 -14
- package/dist/components/media/Timer.js +18 -54
- package/dist/components/media/Toolbar.js +97 -254
- package/dist/components/media/ToolbarButton.js +34 -95
- package/dist/components/media/Toolbar_bck.js +70 -186
- package/dist/components/media/Tracks.js +19 -33
- package/dist/components/media/TrainingRoom.js +121 -374
- package/dist/components/media/Transports.js +17 -29
- package/dist/components/media/VCEventManager.js +45 -116
- package/dist/components/media/VCEventType.js +82 -168
- package/dist/components/media/VCParticipantList.js +16 -51
- package/dist/components/media/VCParticipantListItem.js +44 -141
- package/dist/components/media/VCRoom.js +14 -58
- package/dist/components/media/VCRoomParticipant.js +235 -556
- package/dist/components/media/VCRoomRecorder.js +106 -204
- package/dist/components/media/VCRoomWorkspace.js +248 -584
- package/dist/components/media/Video.js +27 -112
- package/dist/components/media/VideoPlayer.js +23 -91
- package/dist/components/media/chat/ChatRoom.js +143 -361
- package/dist/components/media/chat/ChatRoomItem.js +17 -58
- package/dist/components/media/chat/ChatRoomList.js +15 -60
- package/dist/components/menu/CollapsibleMenu.js +22 -52
- package/dist/components/menu/MenuBars.js +50 -116
- package/dist/components/menu/MenuButton.js +53 -130
- package/dist/components/menu/MenuItem.js +11 -51
- package/dist/components/menu/MenuLink.js +13 -41
- package/dist/components/menu/PopupMenu.js +13 -25
- package/dist/components/navbars/AuthNavbar.js +21 -56
- package/dist/components/navbars/HomeNavbar.js +213 -290
- package/dist/components/navbars/PortalNavbar.js +26 -81
- package/dist/components/signatures/AgilitySignaturePanel.js +41 -135
- package/dist/components/signatures/AlertItem.js +14 -50
- package/dist/components/signatures/Card.js +6 -16
- package/dist/components/signatures/DocumentContainer.js +57 -165
- package/dist/components/signatures/ImageSignatureInput.js +64 -124
- package/dist/components/signatures/MenuButton.js +28 -63
- package/dist/components/signatures/Prompt.js +6 -41
- package/dist/components/signatures/ResponsiveTable.js +181 -370
- package/dist/components/signatures/SearchView.js +34 -112
- package/dist/components/signatures/SignatorySearch.js +11 -44
- package/dist/components/signatures/SignatorySearchForm.js +19 -50
- package/dist/components/signatures/SignatureInput.js +28 -91
- package/dist/components/signatures/SignatureInputProps.js +49 -144
- package/dist/components/signatures/SignatureTemplateDesigner.js +230 -430
- package/dist/components/signatures/Toolbar.js +99 -173
- package/dist/components/signatures/ViewUtils.js +207 -313
- package/dist/components/typography/Danger.js +6 -11
- package/dist/components/typography/Info.js +7 -11
- package/dist/components/typography/Link.js +6 -12
- package/dist/event/ActionHandlers.js +48 -87
- package/dist/event/Event.js +21 -25
- package/dist/event/EventListener.js +54 -48
- package/dist/event/EventType.js +18 -40
- package/dist/event/LoadDataActionHandler.js +10 -31
- package/dist/event/Observable.js +204 -396
- package/dist/event/RouteActionHandler.js +119 -171
- package/dist/event/ScriptActionHandler.js +10 -32
- package/dist/event/ServiceCallActionHandler.js +37 -64
- package/dist/event/SignalGraphActionHandler.js +9 -31
- package/dist/js/Addresses.js +23 -42
- package/dist/js/Calendar.js +41 -89
- package/dist/js/DynamicLib.js +11 -23
- package/dist/js/Media.js +80 -174
- package/dist/js/Validators.js +6 -12
- package/dist/js/Windows.js +22 -40
- package/dist/redux/store/ConfigureStore.js +12 -29
- package/dist/redux/store/DashboardStore.js +47 -120
- package/dist/redux/store/History.js +2 -5
- package/dist/redux/store/SecurityStore.js +22 -65
- package/dist/security/TokenManager.js +29 -53
- package/dist/theme-default.js +3 -8
- package/dist/view/Dashboard.js +140 -308
- package/dist/view/PortalDashboard.js +6 -13
- package/dist/view/Settings.js +3 -11
- package/dist/view/Views.js +15 -35
- package/dist/view/security/ChangePasswordBasic.js +41 -147
- package/dist/view/security/ForgotPassword.js +26 -106
- package/dist/view/security/ForgotPasswordBasic.js +22 -96
- package/dist/view/security/Login.js +29 -117
- package/dist/view/security/LoginBasic.js +28 -108
- package/dist/view/security/LoginInteractionPortal.js +28 -106
- package/dist/view/security/ResetPassword.js +25 -110
- package/dist/view/security/ResetPasswordBasic.js +39 -142
- package/dist/view/security/Security.js +14 -26
- package/package.json +26 -21
|
@@ -4,54 +4,39 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
|
|
8
7
|
var _react = _interopRequireDefault(require("react"));
|
|
9
|
-
|
|
10
8
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
11
|
-
|
|
12
9
|
var _Typography = _interopRequireDefault(require("@material-ui/core/Typography"));
|
|
13
|
-
|
|
14
10
|
var _Box = _interopRequireDefault(require("@material-ui/core/Box"));
|
|
15
|
-
|
|
16
11
|
var _styles = require("@material-ui/core/styles");
|
|
17
|
-
|
|
18
12
|
var _Utils = _interopRequireDefault(require("../Utils"));
|
|
19
|
-
|
|
20
|
-
function
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
var TabPage = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
|
|
48
|
-
var children = props.children,
|
|
49
|
-
value = props.value,
|
|
50
|
-
index = props.index,
|
|
51
|
-
other = _objectWithoutProperties(props, ["children", "value", "index"]);
|
|
52
|
-
|
|
53
|
-
var classes = useStyles();
|
|
54
|
-
var componentKey = 0;
|
|
13
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
14
|
+
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); }
|
|
15
|
+
const useStyles = (0, _styles.makeStyles)(theme => ({
|
|
16
|
+
formTabContainer: {
|
|
17
|
+
height: 'inherit !important',
|
|
18
|
+
overflow: 'hidden !important',
|
|
19
|
+
width: '100%',
|
|
20
|
+
zIndex: '0',
|
|
21
|
+
paddingLeft: '16px'
|
|
22
|
+
},
|
|
23
|
+
formTabPanel: {
|
|
24
|
+
width: '100%',
|
|
25
|
+
height: 'inherit !important',
|
|
26
|
+
overflow: 'hidden !important',
|
|
27
|
+
zIndex: '0',
|
|
28
|
+
paddingLeft: "0px"
|
|
29
|
+
}
|
|
30
|
+
}));
|
|
31
|
+
const TabPage = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.default.forwardRef((props, ref) => {
|
|
32
|
+
const {
|
|
33
|
+
children,
|
|
34
|
+
value,
|
|
35
|
+
index,
|
|
36
|
+
...other
|
|
37
|
+
} = props;
|
|
38
|
+
const classes = useStyles();
|
|
39
|
+
let componentKey = 0;
|
|
55
40
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
56
41
|
ref: ref,
|
|
57
42
|
style: {
|
|
@@ -62,18 +47,16 @@ var TabPage = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.default.forw
|
|
|
62
47
|
className: "w-100",
|
|
63
48
|
role: "tabpanel",
|
|
64
49
|
hidden: value !== index,
|
|
65
|
-
id:
|
|
66
|
-
"aria-labelledby":
|
|
50
|
+
id: `simple-tabpanel-${index}`,
|
|
51
|
+
"aria-labelledby": `simple-tab-${index}`
|
|
67
52
|
}, other), /*#__PURE__*/_react.default.createElement(_Box.default, {
|
|
68
53
|
p: 3,
|
|
69
54
|
className: classes.formTabPanel
|
|
70
55
|
}, children)));
|
|
71
56
|
}));
|
|
72
|
-
|
|
73
57
|
TabPage.propTypes = {
|
|
74
58
|
children: _propTypes.default.node,
|
|
75
59
|
index: _propTypes.default.any.isRequired,
|
|
76
60
|
value: _propTypes.default.any.isRequired
|
|
77
61
|
};
|
|
78
|
-
var _default = TabPage;
|
|
79
|
-
exports.default = _default;
|
|
62
|
+
var _default = exports.default = TabPage;
|
|
@@ -4,121 +4,63 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
|
|
8
7
|
var _react = _interopRequireDefault(require("react"));
|
|
9
|
-
|
|
10
8
|
var _Utils = _interopRequireDefault(require("../Utils"));
|
|
11
|
-
|
|
12
9
|
var _AppBar = _interopRequireDefault(require("@material-ui/core/AppBar"));
|
|
13
|
-
|
|
14
10
|
var _Tab = _interopRequireDefault(require("@material-ui/core/Tab"));
|
|
15
|
-
|
|
16
11
|
var _Tabs = _interopRequireDefault(require("@material-ui/core/Tabs"));
|
|
17
|
-
|
|
18
12
|
var _TabPage = _interopRequireDefault(require("./TabPage"));
|
|
19
|
-
|
|
20
13
|
var _Section = _interopRequireDefault(require("./form/Section"));
|
|
21
|
-
|
|
22
14
|
var _Toolbar = _interopRequireDefault(require("./Toolbar"));
|
|
23
|
-
|
|
24
15
|
var _ApplicationManager = _interopRequireDefault(require("../ApplicationManager"));
|
|
25
|
-
|
|
26
16
|
var _Layout = require("./layout/Layout");
|
|
27
|
-
|
|
28
|
-
function
|
|
29
|
-
|
|
30
|
-
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
31
|
-
|
|
32
|
-
function _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
|
|
33
|
-
|
|
34
|
-
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
35
|
-
|
|
36
|
-
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."); }
|
|
37
|
-
|
|
38
|
-
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); }
|
|
39
|
-
|
|
40
|
-
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; }
|
|
41
|
-
|
|
42
|
-
function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
|
|
43
|
-
|
|
44
|
-
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
45
|
-
|
|
17
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
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); }
|
|
46
19
|
function a11yProps(index) {
|
|
47
20
|
return {
|
|
48
|
-
id:
|
|
49
|
-
'aria-controls':
|
|
21
|
+
id: `simple-tab-${index}`,
|
|
22
|
+
'aria-controls': `simple-tabpanel-${index}`
|
|
50
23
|
};
|
|
51
24
|
}
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
setTabValue = _React$useState2[1];
|
|
58
|
-
|
|
59
|
-
var _React$useState3 = _react.default.useState({}),
|
|
60
|
-
_React$useState4 = _slicedToArray(_React$useState3, 2),
|
|
61
|
-
errors = _React$useState4[0],
|
|
62
|
-
setErrors = _React$useState4[1];
|
|
63
|
-
|
|
64
|
-
var _React$useState5 = _react.default.useState({}),
|
|
65
|
-
_React$useState6 = _slicedToArray(_React$useState5, 1),
|
|
66
|
-
componentHandles = _React$useState6[0];
|
|
67
|
-
|
|
68
|
-
var handleTabChange = function handleTabChange(event, newValue) {
|
|
25
|
+
const TabPanel = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.default.forwardRef((props, ref) => {
|
|
26
|
+
const [tabValue, setTabValue] = _react.default.useState(0);
|
|
27
|
+
const [errors, setErrors] = _react.default.useState({});
|
|
28
|
+
const [componentHandles] = _react.default.useState({});
|
|
29
|
+
const handleTabChange = (event, newValue) => {
|
|
69
30
|
setTabValue(newValue);
|
|
70
31
|
};
|
|
71
|
-
|
|
72
|
-
var createComponentHandle = function createComponentHandle(component) {
|
|
32
|
+
const createComponentHandle = component => {
|
|
73
33
|
if (_Utils.default.isNull(componentHandles[component.id])) {
|
|
74
|
-
|
|
34
|
+
let handle = {};
|
|
75
35
|
componentHandles[component.id] = handle;
|
|
76
36
|
return handle;
|
|
77
37
|
}
|
|
78
|
-
|
|
79
38
|
return componentHandles[component.id];
|
|
80
39
|
};
|
|
81
|
-
|
|
82
|
-
_react.default.useEffect(function () {
|
|
40
|
+
_react.default.useEffect(() => {
|
|
83
41
|
props.handle.api = api();
|
|
84
42
|
});
|
|
85
|
-
|
|
86
|
-
_react.default.useEffect(function () {
|
|
43
|
+
_react.default.useEffect(() => {
|
|
87
44
|
if (!_Utils.default.isNull(props.form)) {
|
|
88
|
-
props.form().setContainerErrorHandler(
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
try {
|
|
96
|
-
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
97
|
-
var property = _step.value;
|
|
98
|
-
|
|
99
|
-
if (errors[property] !== containerErrors[property]) {
|
|
100
|
-
shouldRefresh = true;
|
|
101
|
-
break;
|
|
102
|
-
}
|
|
45
|
+
props.form().setContainerErrorHandler(containerErrors => {
|
|
46
|
+
let shouldRefresh = false;
|
|
47
|
+
let properties = Object.getOwnPropertyNames(containerErrors);
|
|
48
|
+
for (const property of properties) {
|
|
49
|
+
if (errors[property] !== containerErrors[property]) {
|
|
50
|
+
shouldRefresh = true;
|
|
51
|
+
break;
|
|
103
52
|
}
|
|
104
|
-
} catch (err) {
|
|
105
|
-
_iterator.e(err);
|
|
106
|
-
} finally {
|
|
107
|
-
_iterator.f();
|
|
108
53
|
}
|
|
109
|
-
|
|
110
54
|
if (_ApplicationManager.default.isFormMarkersEnabled() && shouldRefresh) {
|
|
111
55
|
setErrors(JSON.parse(JSON.stringify(containerErrors)));
|
|
112
56
|
}
|
|
113
57
|
});
|
|
114
58
|
}
|
|
115
59
|
}, []);
|
|
116
|
-
|
|
117
60
|
function renderTabPageComponent(component, tabId, index) {
|
|
118
61
|
if (_Utils.default.isNull(component.id)) {
|
|
119
62
|
component.id = index + '-tab-content';
|
|
120
63
|
}
|
|
121
|
-
|
|
122
64
|
return component.type === 'formSection' ? /*#__PURE__*/_react.default.createElement(_Section.default, {
|
|
123
65
|
keyHandler: props.keyHandler,
|
|
124
66
|
key: index,
|
|
@@ -143,62 +85,36 @@ var TabPanel = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.default.for
|
|
|
143
85
|
viewId: props.viewId
|
|
144
86
|
}) : /*#__PURE__*/_react.default.createElement("div", null, 'Unsupported component type ' + component.type);
|
|
145
87
|
}
|
|
146
|
-
|
|
147
88
|
function renderPage(page, pageIndex) {
|
|
148
89
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
149
90
|
style: {
|
|
150
91
|
margin: '16px'
|
|
151
92
|
}
|
|
152
|
-
}, page.components.map(
|
|
93
|
+
}, page.components.map((component, index) => {
|
|
153
94
|
return renderTabPageComponent(component, page.id, pageIndex + index);
|
|
154
95
|
}));
|
|
155
96
|
}
|
|
156
|
-
|
|
157
|
-
var api = function api() {
|
|
97
|
+
const api = () => {
|
|
158
98
|
return {
|
|
159
|
-
getId:
|
|
99
|
+
getId: () => {
|
|
160
100
|
return props.config.id;
|
|
161
101
|
},
|
|
162
|
-
getChildren:
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
var property = _step2.value;
|
|
172
|
-
var componentHandle = componentHandles[property];
|
|
173
|
-
children.push(componentHandle);
|
|
174
|
-
|
|
175
|
-
if (!_Utils.default.isNull(componentHandle.api.getChildren)) {
|
|
176
|
-
var _iterator3 = _createForOfIteratorHelper(componentHandle.api.getChildren()),
|
|
177
|
-
_step3;
|
|
178
|
-
|
|
179
|
-
try {
|
|
180
|
-
for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
|
|
181
|
-
var child = _step3.value;
|
|
182
|
-
children.push(child);
|
|
183
|
-
}
|
|
184
|
-
} catch (err) {
|
|
185
|
-
_iterator3.e(err);
|
|
186
|
-
} finally {
|
|
187
|
-
_iterator3.f();
|
|
188
|
-
}
|
|
102
|
+
getChildren: () => {
|
|
103
|
+
let children = [];
|
|
104
|
+
let properties = Object.getOwnPropertyNames(componentHandles);
|
|
105
|
+
for (const property of properties) {
|
|
106
|
+
let componentHandle = componentHandles[property];
|
|
107
|
+
children.push(componentHandle);
|
|
108
|
+
if (!_Utils.default.isNull(componentHandle.api.getChildren)) {
|
|
109
|
+
for (const child of componentHandle.api.getChildren()) {
|
|
110
|
+
children.push(child);
|
|
189
111
|
}
|
|
190
112
|
}
|
|
191
|
-
} catch (err) {
|
|
192
|
-
_iterator2.e(err);
|
|
193
|
-
} finally {
|
|
194
|
-
_iterator2.f();
|
|
195
113
|
}
|
|
196
|
-
|
|
197
114
|
return children;
|
|
198
115
|
}
|
|
199
116
|
};
|
|
200
117
|
};
|
|
201
|
-
|
|
202
118
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
203
119
|
ref: ref,
|
|
204
120
|
style: _Utils.default.mergeStyles({
|
|
@@ -218,7 +134,7 @@ var TabPanel = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.default.for
|
|
|
218
134
|
indicatorColor: "primary",
|
|
219
135
|
textColor: "primary",
|
|
220
136
|
"aria-label": "tabs"
|
|
221
|
-
}, !_Utils.default.isNull(props.config) && !_Utils.default.isNull(props.config.tabPages) && props.config.tabPages.length > 0 ? props.config.tabPages.map(
|
|
137
|
+
}, !_Utils.default.isNull(props.config) && !_Utils.default.isNull(props.config.tabPages) && props.config.tabPages.length > 0 ? props.config.tabPages.map((page, index) => {
|
|
222
138
|
return /*#__PURE__*/_react.default.createElement(_Tab.default, _extends({
|
|
223
139
|
label: page.attributes['label']
|
|
224
140
|
}, a11yProps(index), {
|
|
@@ -227,11 +143,10 @@ var TabPanel = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.default.for
|
|
|
227
143
|
color: _ApplicationManager.default.isFormMarkersEnabled() && !_Utils.default.isNull(props.form) && errors !== null && errors[page.id] === true ? '#ed5249' : null
|
|
228
144
|
}
|
|
229
145
|
}));
|
|
230
|
-
}) : null)), !_Utils.default.isNull(props.config) && !_Utils.default.isNull(props.config.tabPages) && props.config.tabPages.length > 0 ? props.config.tabPages.map(
|
|
146
|
+
}) : null)), !_Utils.default.isNull(props.config) && !_Utils.default.isNull(props.config.tabPages) && props.config.tabPages.length > 0 ? props.config.tabPages.map((page, index) => {
|
|
231
147
|
if (_Utils.default.isNull(page.id)) {
|
|
232
148
|
page.id = index + '-tab-page';
|
|
233
149
|
}
|
|
234
|
-
|
|
235
150
|
return /*#__PURE__*/_react.default.createElement(_TabPage.default, {
|
|
236
151
|
value: tabValue,
|
|
237
152
|
key: index,
|
|
@@ -239,6 +154,4 @@ var TabPanel = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.default.for
|
|
|
239
154
|
}, renderPage(page, index));
|
|
240
155
|
}) : null);
|
|
241
156
|
}));
|
|
242
|
-
|
|
243
|
-
var _default = TabPanel;
|
|
244
|
-
exports.default = _default;
|
|
157
|
+
var _default = exports.default = TabPanel;
|
|
@@ -4,140 +4,89 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
|
|
8
7
|
var _react = _interopRequireDefault(require("react"));
|
|
9
|
-
|
|
10
8
|
var _TextField = _interopRequireDefault(require("./form/TextField"));
|
|
11
|
-
|
|
12
9
|
var _DatePicker = _interopRequireDefault(require("./form/DatePicker"));
|
|
13
|
-
|
|
14
10
|
var _SelectItem = _interopRequireDefault(require("./form/SelectItem"));
|
|
15
|
-
|
|
16
11
|
var _Utils = _interopRequireDefault(require("../Utils"));
|
|
17
|
-
|
|
18
12
|
var _LookupField = _interopRequireDefault(require("./form/LookupField"));
|
|
19
|
-
|
|
20
13
|
var _Error = _interopRequireDefault(require("@material-ui/icons/Error"));
|
|
21
|
-
|
|
22
14
|
var _Tooltip = _interopRequireDefault(require("./Tooltip"));
|
|
23
|
-
|
|
24
15
|
var _ApplicationManager = _interopRequireDefault(require("../ApplicationManager"));
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
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."); }
|
|
33
|
-
|
|
34
|
-
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); }
|
|
35
|
-
|
|
36
|
-
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; }
|
|
37
|
-
|
|
38
|
-
function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
|
|
39
|
-
|
|
40
|
-
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
41
|
-
|
|
42
|
-
var TableCellContent = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
|
|
43
|
-
var _React$useState = _react.default.useState(props.contentType),
|
|
44
|
-
_React$useState2 = _slicedToArray(_React$useState, 1),
|
|
45
|
-
contentType = _React$useState2[0];
|
|
46
|
-
|
|
47
|
-
var _React$useState3 = _react.default.useState(true),
|
|
48
|
-
_React$useState4 = _slicedToArray(_React$useState3, 2),
|
|
49
|
-
refresher = _React$useState4[0],
|
|
50
|
-
setRefresher = _React$useState4[1];
|
|
51
|
-
|
|
52
|
-
var validate = function validate(value) {
|
|
53
|
-
var validator = props.validator;
|
|
54
|
-
var errors = props.row.errors;
|
|
55
|
-
|
|
16
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
17
|
+
const TableCellContent = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.default.forwardRef((props, ref) => {
|
|
18
|
+
const [contentType] = _react.default.useState(props.contentType);
|
|
19
|
+
const [refresher, setRefresher] = _react.default.useState(true);
|
|
20
|
+
const validate = value => {
|
|
21
|
+
let validator = props.validator;
|
|
22
|
+
let errors = props.row.errors;
|
|
56
23
|
if (!_Utils.default.isNull(errors)) {
|
|
57
|
-
errors = errors.filter(
|
|
24
|
+
errors = errors.filter(error => {
|
|
58
25
|
return error.column !== props.dataBinding;
|
|
59
26
|
});
|
|
60
27
|
props.row.errors = errors;
|
|
61
28
|
}
|
|
62
|
-
|
|
63
29
|
if (!_Utils.default.isNull(validator)) {
|
|
64
|
-
|
|
65
|
-
|
|
30
|
+
let required = false;
|
|
66
31
|
if (!_Utils.default.isNull(validator.nullable)) {
|
|
67
|
-
|
|
32
|
+
let nullableExpression = validator.nullable.replace(/\[#i]/g, `[${props.row.index}]`);
|
|
68
33
|
required = !_Utils.default.evaluateBooleanExpression(nullableExpression, props.dataBinding);
|
|
69
34
|
}
|
|
70
|
-
|
|
71
|
-
var validation = _Utils.default.validateField(props.dataBinding, required, props.formValues, value, validator);
|
|
72
|
-
|
|
35
|
+
let validation = _Utils.default.validateField(props.dataBinding, required, props.formValues, value, validator);
|
|
73
36
|
if (!validation.valid) {
|
|
74
|
-
|
|
37
|
+
let error = {};
|
|
75
38
|
error.column = props.dataBinding;
|
|
76
39
|
error.message = validation.message;
|
|
77
|
-
|
|
78
40
|
if (_Utils.default.isNull(errors)) {
|
|
79
41
|
errors = [];
|
|
80
42
|
props.row.errors = errors;
|
|
81
43
|
}
|
|
82
|
-
|
|
83
44
|
props.row.errors.push(error);
|
|
84
45
|
return error;
|
|
85
46
|
}
|
|
86
47
|
}
|
|
87
|
-
|
|
88
48
|
return null;
|
|
89
49
|
};
|
|
90
|
-
|
|
91
|
-
var valueChangeHandler = function valueChangeHandler(value) {
|
|
50
|
+
const valueChangeHandler = value => {
|
|
92
51
|
validate(value);
|
|
93
52
|
props.valueChangeHandler(props.row.id, props.dataBinding, value);
|
|
94
53
|
};
|
|
95
|
-
|
|
96
|
-
_react.default.useEffect(function () {
|
|
54
|
+
_react.default.useEffect(() => {
|
|
97
55
|
if (!_Utils.default.isNull(ref.current)) {
|
|
98
56
|
props.refCallback(props.row, props.dataBinding, {
|
|
99
57
|
'api': api
|
|
100
58
|
});
|
|
101
59
|
}
|
|
102
60
|
}, [ref.current]);
|
|
103
|
-
|
|
104
|
-
_react.default.useEffect(function () {
|
|
61
|
+
_react.default.useEffect(() => {
|
|
105
62
|
if (!_Utils.default.isNull(props.editor)) {
|
|
106
63
|
props.editor.id = props.editor.id.replace('.', '_');
|
|
107
|
-
|
|
108
64
|
if (_Utils.default.isNull(props.editor.attributes)) {
|
|
109
65
|
props.editor.attributes = {};
|
|
110
66
|
}
|
|
111
|
-
|
|
112
67
|
props.editor.attributes['minWidth'] = 0;
|
|
113
|
-
|
|
68
|
+
let value = props.row[props.dataBinding];
|
|
114
69
|
valueChangeHandler(_Utils.default.isNull(value) ? null : value);
|
|
115
70
|
}
|
|
116
71
|
}, [props.editor]);
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
var tokens = props.dataBinding.split('.');
|
|
122
|
-
|
|
72
|
+
const getStaticDisplayValue = () => {
|
|
73
|
+
let displayValue;
|
|
74
|
+
let contentValue;
|
|
75
|
+
let tokens = props.dataBinding.split('.');
|
|
123
76
|
if (tokens.length === 1) {
|
|
124
77
|
contentValue = props.row[props.dataBinding];
|
|
125
78
|
} else {
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
for (var i = 0; i < tokens.length - 1; i++) {
|
|
79
|
+
let parent = props.row;
|
|
80
|
+
for (let i = 0; i < tokens.length - 1; i++) {
|
|
129
81
|
parent = parent[tokens[i]];
|
|
130
|
-
|
|
131
82
|
if (!parent) {
|
|
132
83
|
break;
|
|
133
84
|
}
|
|
134
85
|
}
|
|
135
|
-
|
|
136
86
|
if (parent) {
|
|
137
87
|
contentValue = parent[tokens[tokens.length - 1]];
|
|
138
88
|
}
|
|
139
89
|
}
|
|
140
|
-
|
|
141
90
|
if (props.columnConfig.cellFormat === 'MONEY' || props.columnConfig.cellFormat === 'NUMBER') {
|
|
142
91
|
return _Utils.default.isNull(contentValue) ? '' : contentValue.toFixed(2);
|
|
143
92
|
} else {
|
|
@@ -148,25 +97,22 @@ var TableCellContent = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.def
|
|
|
148
97
|
} else if (contentType === 'TIME') {
|
|
149
98
|
displayValue = new Date(contentValue).toLocaleTimeString();
|
|
150
99
|
} else {
|
|
151
|
-
if (
|
|
100
|
+
if (typeof contentValue === 'object') {
|
|
152
101
|
// TODO : First check if the editor has a display template. If it does, use it to get the display value
|
|
153
102
|
displayValue = contentValue.dataRecordDescription;
|
|
154
103
|
} else {
|
|
155
104
|
displayValue = contentValue;
|
|
156
105
|
}
|
|
157
106
|
}
|
|
158
|
-
|
|
159
107
|
return displayValue;
|
|
160
108
|
}
|
|
161
109
|
};
|
|
162
|
-
|
|
163
|
-
var doRender = function doRender() {
|
|
110
|
+
const doRender = () => {
|
|
164
111
|
if (!props.selected) {
|
|
165
112
|
return getStaticDisplayValue();
|
|
166
113
|
} else {
|
|
167
114
|
if (!_Utils.default.isNull(props.editor)) {
|
|
168
115
|
props.formValues[props.editor.id] = props.row[props.dataBinding];
|
|
169
|
-
|
|
170
116
|
if (props.editor.fieldType === 'TEXT_FIELD') {
|
|
171
117
|
return /*#__PURE__*/_react.default.createElement(_TextField.default, {
|
|
172
118
|
valueChangeHandler: valueChangeHandler,
|
|
@@ -190,14 +136,12 @@ var TableCellContent = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.def
|
|
|
190
136
|
viewId: props.viewId
|
|
191
137
|
});
|
|
192
138
|
} else if (props.editor.fieldType === 'SELECT') {
|
|
193
|
-
|
|
194
|
-
|
|
139
|
+
let objectReference = props.row[props.dataBinding];
|
|
195
140
|
if (!_Utils.default.isNull(objectReference)) {
|
|
196
|
-
objectReference.toString =
|
|
141
|
+
objectReference.toString = () => {
|
|
197
142
|
return objectReference.label;
|
|
198
143
|
};
|
|
199
144
|
}
|
|
200
|
-
|
|
201
145
|
return /*#__PURE__*/_react.default.createElement(_SelectItem.default, {
|
|
202
146
|
valueChangeHandler: valueChangeHandler,
|
|
203
147
|
config: props.editor,
|
|
@@ -210,19 +154,16 @@ var TableCellContent = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.def
|
|
|
210
154
|
viewId: props.viewId
|
|
211
155
|
});
|
|
212
156
|
} else if (props.editor.fieldType === 'LOOKUP') {
|
|
213
|
-
|
|
214
|
-
|
|
157
|
+
let data = props.row[props.dataBinding];
|
|
215
158
|
if (!_Utils.default.isNull(data)) {
|
|
216
159
|
if (!_Utils.default.isNull(data.map)) {
|
|
217
160
|
data = data.map;
|
|
218
161
|
props.formValues[props.editor.id] = data;
|
|
219
162
|
}
|
|
220
|
-
|
|
221
|
-
data.toString = function () {
|
|
163
|
+
data.toString = () => {
|
|
222
164
|
return data.label;
|
|
223
165
|
};
|
|
224
166
|
}
|
|
225
|
-
|
|
226
167
|
return /*#__PURE__*/_react.default.createElement(_LookupField.default, {
|
|
227
168
|
valueChangeHandler: valueChangeHandler,
|
|
228
169
|
config: props.editor,
|
|
@@ -240,10 +181,9 @@ var TableCellContent = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.def
|
|
|
240
181
|
}
|
|
241
182
|
}
|
|
242
183
|
};
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
var hasError = !_Utils.default.isNull(error);
|
|
184
|
+
const render = () => {
|
|
185
|
+
let error = validate(props.row[props.dataBinding]);
|
|
186
|
+
let hasError = !_Utils.default.isNull(error);
|
|
247
187
|
return /*#__PURE__*/_react.default.createElement("table", {
|
|
248
188
|
className: 'tableCellContentContainer',
|
|
249
189
|
border: "0",
|
|
@@ -269,11 +209,9 @@ var TableCellContent = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.def
|
|
|
269
209
|
}
|
|
270
210
|
}, doRender()))));
|
|
271
211
|
};
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
refresh: function refresh() {
|
|
212
|
+
const api = {
|
|
213
|
+
refresh: () => {
|
|
275
214
|
setRefresher(!refresher);
|
|
276
|
-
|
|
277
215
|
if (_Utils.default.isNull(props.editor)) {
|
|
278
216
|
valueChangeHandler(props.row[props.dataBinding]);
|
|
279
217
|
}
|
|
@@ -281,6 +219,4 @@ var TableCellContent = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.def
|
|
|
281
219
|
};
|
|
282
220
|
return render();
|
|
283
221
|
}));
|
|
284
|
-
|
|
285
|
-
var _default = TableCellContent;
|
|
286
|
-
exports.default = _default;
|
|
222
|
+
var _default = exports.default = TableCellContent;
|