@agilemotion/oui-react-js 1.3.8 → 1.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (230) hide show
  1. package/README.TXT +1 -0
  2. package/dist/{ApplicationContext.js → ApplicationManager.js} +334 -335
  3. package/dist/BasicApp.js +67 -64
  4. package/dist/BasicAppHome.js +90 -110
  5. package/dist/BusinessPortalApp.js +1 -1
  6. package/dist/BusinessPortalAppHome.js +15 -50
  7. package/dist/DynamicJS.js +24 -52
  8. package/dist/RestUtils.js +90 -116
  9. package/dist/Utils.js +49 -37
  10. package/dist/WithRouter.js +34 -0
  11. package/dist/assets/jss/components/authNavbarStyle.js +34 -35
  12. package/dist/assets/jss/components/cardHeaderStyle.js +12 -12
  13. package/dist/assets/jss/components/customDropdownStyle.js +26 -26
  14. package/dist/assets/jss/components/customInputStyle.js +2 -8
  15. package/dist/assets/jss/components/dropdownStyle.js +10 -15
  16. package/dist/assets/jss/components/footerStyle.js +12 -18
  17. package/dist/assets/jss/components/headerLinksStyle.js +7 -13
  18. package/dist/assets/jss/components/headerStyle.js +24 -25
  19. package/dist/assets/jss/components/navbarLinksStyle.js +7 -13
  20. package/dist/assets/jss/components/navbarStyle.js +24 -25
  21. package/dist/assets/jss/components/sidebarStyle.js +41 -43
  22. package/dist/assets/jss/components/typographyStyle.js +2 -8
  23. package/dist/assets/jss/rootStyle.js +32 -47
  24. package/dist/assets/jss/views/layoutStyle.js +6 -11
  25. package/dist/assets/jss/views/loginStyle.js +4 -10
  26. package/dist/assets/lotties/call-loading.json +1 -0
  27. package/dist/assets/lotties/calling-2.json +1 -0
  28. package/dist/assets/lotties/calling.json +1 -0
  29. package/dist/assets/lotties/calling2.json +1 -0
  30. package/dist/assets/lotties/chat.json +1 -0
  31. package/dist/assets/lotties/join.json +1 -0
  32. package/dist/assets/lotties/loading.json +1 -0
  33. package/dist/assets/lotties/msg2.json +1 -0
  34. package/dist/assets/lotties/recording.json +1 -0
  35. package/dist/assets/lotties/waiting.json +1 -0
  36. package/dist/assets/scss/black-dashboard-react/bootstrap/_card.scss +5 -5
  37. package/dist/assets/scss/black-dashboard-react/bootstrap/_carousel.scss +2 -2
  38. package/dist/assets/scss/black-dashboard-react/bootstrap/_custom-forms.scss +3 -3
  39. package/dist/assets/scss/black-dashboard-react/bootstrap/_functions.scss +1 -1
  40. package/dist/assets/scss/black-dashboard-react/bootstrap/_images.scss +1 -1
  41. package/dist/assets/scss/black-dashboard-react/bootstrap/_jumbotron.scss +1 -1
  42. package/dist/assets/scss/black-dashboard-react/bootstrap/_popover.scss +7 -5
  43. package/dist/assets/scss/black-dashboard-react/bootstrap/_tooltip.scss +4 -4
  44. package/dist/assets/scss/black-dashboard-react/bootstrap/_variables.scss +5 -5
  45. package/dist/assets/scss/black-dashboard-react/bootstrap/mixins/_grid-framework.scss +2 -2
  46. package/dist/assets/scss/black-dashboard-react/bootstrap/mixins/_grid.scss +11 -9
  47. package/dist/assets/scss/black-dashboard-react/bootstrap/utilities/_embed.scss +6 -4
  48. package/dist/assets/scss/black-dashboard-react/custom/_sidebar-and-main-panel.scss +1 -1
  49. package/dist/assets/scss/black-dashboard-react/custom/_variables.scss +1 -1
  50. package/dist/components/AlertBar.js +39 -80
  51. package/dist/components/AlertItem.js +4 -26
  52. package/dist/components/Button.js +49 -52
  53. package/dist/components/Calendar.js +442 -0
  54. package/dist/components/Calender.css +244 -0
  55. package/dist/components/ConfirmationDialog.js +5 -29
  56. package/dist/components/DataGrid.js +207 -345
  57. package/dist/components/DataGridColumn.js +6 -29
  58. package/dist/components/DataGridFilter.js +48 -116
  59. package/dist/components/DataGridHeading.js +11 -19
  60. package/dist/components/Dialog.js +27 -121
  61. package/dist/components/DocumentViewer.js +12 -38
  62. package/dist/components/DocumentViewerComponent.js +2 -20
  63. package/dist/components/FileThumb.js +126 -0
  64. package/dist/components/Graph.js +33 -75
  65. package/dist/components/GraphNode.js +5 -22
  66. package/dist/components/HtmlPanel.js +68 -82
  67. package/dist/components/Icon.js +107 -1
  68. package/dist/components/LoadingIndicator.js +4 -4
  69. package/dist/components/LottieIcon.js +134 -0
  70. package/dist/components/PopupView.js +3 -21
  71. package/dist/components/Portlet.js +100 -0
  72. package/dist/components/RegularButton.js +15 -19
  73. package/dist/components/SignaturePanel.js +9 -40
  74. package/dist/components/SocketManager.js +170 -0
  75. package/dist/components/StepperTitleBar.js +33 -59
  76. package/dist/components/TabPage.js +6 -9
  77. package/dist/components/TabPanel.js +49 -98
  78. package/dist/components/TableCellContent.js +31 -39
  79. package/dist/components/TemplateDesigner.js +114 -158
  80. package/dist/components/TemplateItemEventHandler.js +33 -100
  81. package/dist/components/TemplateTable.js +6 -42
  82. package/dist/components/TitleBar.js +38 -54
  83. package/dist/components/Toolbar.js +67 -182
  84. package/dist/components/Tree.js +29 -66
  85. package/dist/components/card/Card.js +16 -20
  86. package/dist/components/card/CardAvatar.js +9 -13
  87. package/dist/components/card/CardBody.js +13 -17
  88. package/dist/components/card/CardFooter.js +12 -16
  89. package/dist/components/card/CardHeader.js +13 -17
  90. package/dist/components/card/CardIcon.js +6 -10
  91. package/dist/components/card/CardText.js +6 -10
  92. package/dist/components/customInput/CustomInput.js +12 -10
  93. package/dist/components/dashboard/BasicBusinessAppDashboard.js +85 -159
  94. package/dist/components/dashboard/BusinessPortalAppDashboard.js +30 -75
  95. package/dist/components/dashboard/components/Header.js +9 -26
  96. package/dist/components/dashboard/components/LeftDrawer.js +3 -1
  97. package/dist/components/dashboard/components/blackDashboard/fixedPlugin/FixedPlugin.js +1 -1
  98. package/dist/components/dashboard/components/blackDashboard/sidebar/Sidebar.css +7 -0
  99. package/dist/components/dashboard/components/blackDashboard/sidebar/Sidebar.js +189 -79
  100. package/dist/components/footer/Footer.js +6 -18
  101. package/dist/components/form/AddressSearch.js +32 -66
  102. package/dist/components/form/AutoComplete.js +161 -0
  103. package/dist/components/form/BaseField.js +89 -107
  104. package/dist/components/form/DatePicker.js +8 -23
  105. package/dist/components/form/FieldSet.js +161 -191
  106. package/dist/components/form/Form.css +1 -1
  107. package/dist/components/form/Form.js +153 -479
  108. package/dist/components/form/GridField.js +46 -146
  109. package/dist/components/form/IconField.js +35 -0
  110. package/dist/components/form/ImageEditor.js +22 -60
  111. package/dist/components/form/LookupField.js +8 -29
  112. package/dist/components/form/MultiFileUploadField.js +187 -0
  113. package/dist/components/form/RadioGroup.js +10 -26
  114. package/dist/components/form/Section.js +40 -91
  115. package/dist/components/form/SelectItem.js +14 -33
  116. package/dist/components/form/SignatureTemplateDesignerField.js +0 -1
  117. package/dist/components/form/Switch.js +53 -0
  118. package/dist/components/form/TextField.js +10 -17
  119. package/dist/components/form/TimePicker.js +8 -1
  120. package/dist/components/form/TransferList.css +2 -2
  121. package/dist/components/form/TransferList.js +67 -125
  122. package/dist/components/form/UploadField.js +132 -177
  123. package/dist/components/form/fieldset.css +8 -0
  124. package/dist/components/grid/GridContainer.js +5 -9
  125. package/dist/components/grid/GridItem.js +5 -9
  126. package/dist/components/layout/CollapsiblePanel.js +11 -33
  127. package/dist/components/layout/Layout.js +228 -290
  128. package/dist/components/layout/VC.css +17 -0
  129. package/dist/components/layout/View.css +18 -1
  130. package/dist/components/layout/View.js +80 -200
  131. package/dist/components/layout/ViewContainer.css +3 -0
  132. package/dist/components/layout/ViewContainer.js +59 -0
  133. package/dist/components/layout/ViewPort.js +50 -80
  134. package/dist/components/layout/Window.css +18 -0
  135. package/dist/components/layout/Window.js +287 -0
  136. package/dist/components/layout/WindowViewPort.js +71 -0
  137. package/dist/components/loader.css +1 -1
  138. package/dist/components/media/ClosablePanel.css +37 -0
  139. package/dist/components/media/ClosablePanel.js +53 -0
  140. package/dist/components/media/LobbyWaitingList.js +91 -0
  141. package/dist/components/media/MediaSoupHelper.js +223 -0
  142. package/dist/components/media/Recorder.js +235 -0
  143. package/dist/components/media/SideBarContent.css +54 -0
  144. package/dist/components/media/SideBarContent.js +46 -0
  145. package/dist/components/media/SocketRequest.js +20 -0
  146. package/dist/components/media/SocketResponse.js +16 -0
  147. package/dist/components/media/Timer.css +30 -0
  148. package/dist/components/media/Timer.js +88 -0
  149. package/dist/components/media/Toolbar.css +35 -0
  150. package/dist/components/media/Toolbar.js +494 -0
  151. package/dist/components/media/Tracks.js +39 -0
  152. package/dist/components/media/TrainingRoom.js +608 -0
  153. package/dist/components/media/Transports.js +35 -0
  154. package/dist/components/media/VCEventManager.js +74 -0
  155. package/dist/components/media/VCEventType.js +164 -0
  156. package/dist/components/media/VCParticipantList.css +72 -0
  157. package/dist/components/media/VCParticipantList.js +56 -0
  158. package/dist/components/media/VCParticipantListItem.css +73 -0
  159. package/dist/components/media/VCParticipantListItem.js +319 -0
  160. package/dist/components/media/VCRoom.css +42 -0
  161. package/dist/components/media/VCRoom.js +90 -0
  162. package/dist/components/media/VCRoomParticipant.css +25 -0
  163. package/dist/components/media/VCRoomParticipant.js +808 -0
  164. package/dist/components/media/VCRoomRecorder.js +223 -0
  165. package/dist/components/media/VCRoomWorkspace.css +86 -0
  166. package/dist/components/media/VCRoomWorkspace.js +666 -0
  167. package/dist/components/media/Video.css +4 -0
  168. package/dist/components/media/Video.js +131 -0
  169. package/dist/components/media/VideoPlayer.css +10 -0
  170. package/dist/components/media/VideoPlayer.js +86 -0
  171. package/dist/components/media/chat/ChatRoom.js +926 -0
  172. package/dist/components/media/chat/ChatRoomItem.js +83 -0
  173. package/dist/components/media/chat/ChatRoomList.js +78 -0
  174. package/dist/components/media/chat/ChatRooms.scss +567 -0
  175. package/dist/components/menu/CollapsibleMenu.js +2 -19
  176. package/dist/components/menu/MenuBars.js +6 -33
  177. package/dist/components/menu/MenuButton.js +27 -39
  178. package/dist/components/menu/MenuItem.js +3 -20
  179. package/dist/components/menu/MenuLink.js +22 -13
  180. package/dist/components/navbars/AuthNavbar.js +5 -18
  181. package/dist/components/navbars/HomeNavbar.js +5 -7
  182. package/dist/components/navbars/PortalNavbar.js +7 -25
  183. package/dist/components/signatures/AgilitySignaturePanel.js +38 -104
  184. package/dist/components/signatures/AlertItem.js +3 -24
  185. package/dist/components/signatures/DocumentContainer.js +47 -134
  186. package/dist/components/signatures/ImageSignatureInput.js +11 -38
  187. package/dist/components/signatures/MenuButton.js +1 -16
  188. package/dist/components/signatures/Prompt.js +3 -24
  189. package/dist/components/signatures/ResponsiveTable.js +42 -83
  190. package/dist/components/signatures/SearchView.js +13 -50
  191. package/dist/components/signatures/SignatorySearch.js +83 -99
  192. package/dist/components/signatures/SignatorySearchForm.js +11 -17
  193. package/dist/components/signatures/SignatureInput.js +18 -47
  194. package/dist/components/signatures/SignatureInputProps.js +18 -60
  195. package/dist/components/signatures/SignatureTemplateDesigner.js +151 -239
  196. package/dist/components/signatures/Toolbar.js +7 -34
  197. package/dist/components/signatures/ViewUtils.js +2 -6
  198. package/dist/components/typography/Danger.js +3 -1
  199. package/dist/components/typography/Info.js +3 -1
  200. package/dist/components/typography/Link.js +6 -2
  201. package/dist/event/ActionHandlers.js +6 -6
  202. package/dist/event/EventType.js +7 -1
  203. package/dist/event/LoadDataActionHandler.js +1 -1
  204. package/dist/event/Observable.js +80 -174
  205. package/dist/event/RouteActionHandler.js +74 -31
  206. package/dist/event/ServiceCallActionHandler.js +36 -24
  207. package/dist/event/SignalGraphActionHandler.js +2 -2
  208. package/dist/js/Addresses.js +10 -8
  209. package/dist/js/Calendar.js +220 -0
  210. package/dist/js/Media.js +157 -0
  211. package/dist/redux/store/ConfigureStore.js +3 -9
  212. package/dist/redux/store/DashboardStore.js +42 -94
  213. package/dist/redux/store/SecurityStore.js +15 -50
  214. package/dist/view/Dashboard.js +256 -171
  215. package/dist/view/Views.js +30 -0
  216. package/dist/view/security/ChangePasswordBasic.js +29 -80
  217. package/dist/view/security/ForgotPassword.js +13 -46
  218. package/dist/view/security/ForgotPasswordBasic.js +12 -45
  219. package/dist/view/security/Login.js +15 -51
  220. package/dist/view/security/LoginBasic.js +13 -46
  221. package/dist/view/security/LoginBusinessPortal.js +12 -45
  222. package/dist/view/security/ResetPassword.js +13 -51
  223. package/dist/view/security/ResetPasswordBasic.js +27 -75
  224. package/dist/view/security/Security.js +1 -0
  225. package/package.json +31 -25
  226. package/README.md +0 -1623
  227. package/dist/components/dashboard/BasicApp.js +0 -140
  228. package/dist/components/navbars/NavbarLinks.js +0 -212
  229. package/dist/components/signatures/OLD.js +0 -1138
  230. package/gulpfile.js +0 -77
@@ -0,0 +1,442 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _react = _interopRequireWildcard(require("react"));
9
+
10
+ var _Utils = _interopRequireDefault(require("../Utils"));
11
+
12
+ var _Observable = _interopRequireDefault(require("../event/Observable"));
13
+
14
+ var _react2 = _interopRequireDefault(require("@fullcalendar/react"));
15
+
16
+ var _list = _interopRequireDefault(require("@fullcalendar/list"));
17
+
18
+ var _rrule = _interopRequireDefault(require("@fullcalendar/rrule"));
19
+
20
+ var _daygrid = _interopRequireDefault(require("@fullcalendar/daygrid"));
21
+
22
+ var _timegrid = _interopRequireDefault(require("@fullcalendar/timegrid"));
23
+
24
+ var _interaction = _interopRequireDefault(require("@fullcalendar/interaction"));
25
+
26
+ require("./Calender.css");
27
+
28
+ var _moment = _interopRequireDefault(require("moment"));
29
+
30
+ var _reactHotToast = _interopRequireDefault(require("react-hot-toast"));
31
+
32
+ var _Event = _interopRequireDefault(require("../event/Event"));
33
+
34
+ var _EventType = _interopRequireDefault(require("../event/EventType"));
35
+
36
+ var _ApplicationManager = _interopRequireDefault(require("../ApplicationManager"));
37
+
38
+ var _Dialog = _interopRequireDefault(require("@material-ui/core/Dialog"));
39
+
40
+ var _withStyles = _interopRequireDefault(require("@material-ui/core/styles/withStyles"));
41
+
42
+ var _IconButton = _interopRequireDefault(require("@material-ui/core/IconButton"));
43
+
44
+ var _Icon = _interopRequireDefault(require("./Icon"));
45
+
46
+ var _Button = _interopRequireDefault(require("@material-ui/core/Button"));
47
+
48
+ var _Calendar = _interopRequireDefault(require("../js/Calendar"));
49
+
50
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
51
+
52
+ function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function () { return cache; }; return cache; }
53
+
54
+ function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
55
+
56
+ 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); }
57
+
58
+ const eventTemplate = {
59
+ id: '',
60
+ title: '',
61
+ start: '',
62
+ end: '',
63
+ allDay: false,
64
+ extendedProps: {
65
+ description: '',
66
+ attendees: [{
67
+ id: '',
68
+ identifier: '',
69
+ name: '',
70
+ optional: false
71
+ }],
72
+ schedule: {
73
+ id: '',
74
+ startDate: '',
75
+ endDate: '',
76
+ startTime: '',
77
+ endTime: ''
78
+ },
79
+ locations: [{
80
+ id: '',
81
+ name: ''
82
+ }]
83
+ }
84
+ };
85
+
86
+ const status = response => {
87
+ if (response.ok) {
88
+ return Promise.resolve(response);
89
+ } else {
90
+ let error = new Error(response.statusText);
91
+ error.code = response.status;
92
+ return Promise.reject(error);
93
+ }
94
+ };
95
+
96
+ const json = response => {
97
+ return response.text();
98
+ };
99
+
100
+ const location = window.location.protocol + "//" + window.location.hostname;
101
+
102
+ const Calendar = props => {
103
+ const {
104
+ isRtl
105
+ } = props;
106
+ const [events, setEvents] = (0, _react.useState)([]);
107
+ const [loading, setLoading] = (0, _react.useState)(true);
108
+ const [open, setOpen] = (0, _react.useState)(false);
109
+ const [selectedEvent, setSelectedEvent] = (0, _react.useState)(null);
110
+ const calendarRef = (0, _react.useRef)(null);
111
+ const dialogRef = (0, _react.useRef)(null);
112
+ const [dialogTop, setDialogTop] = (0, _react.useState)(null);
113
+ const [dialogLeft, setDialogLeft] = (0, _react.useState)(null);
114
+ const StyledDialog = (0, _withStyles.default)({
115
+ root: {
116
+ pointerEvents: "none"
117
+ },
118
+ paper: {
119
+ pointerEvents: 'auto',
120
+ width: '400px',
121
+ height: '228px',
122
+ minWidth: '400px',
123
+ padding: '0',
124
+ overflow: 'hidden',
125
+ position: 'absolute',
126
+ top: dialogTop,
127
+ left: dialogLeft,
128
+ borderRadius: '4px'
129
+ }
130
+ })(props => /*#__PURE__*/_react.default.createElement(_Dialog.default, _extends({
131
+ hideBackdrop: true
132
+ }, props)));
133
+
134
+ const loadEvents = (track = true) => {
135
+ fetch(encodeURI(location + _ApplicationManager.default.getContextRoot() + '/calendar/api/v1/event/list'), {
136
+ method: 'GET',
137
+ headers: {
138
+ 'Accept': 'application/json',
139
+ 'Content-Type': 'application/json',
140
+ 'Authorization': 'Bearer ' + sessionStorage.getItem("accessToken"),
141
+ 'idToken': sessionStorage.getItem("idToken")
142
+ }
143
+ }).then(status).then(json).then(response => {
144
+ setEvents(JSON.parse(response));
145
+ }).catch(ignored => {});
146
+ };
147
+
148
+ (0, _react.useEffect)(() => {
149
+ loadEvents();
150
+ }, []);
151
+
152
+ const calenderScrollListener = () => {
153
+ setOpen(false);
154
+ };
155
+
156
+ const calendarOptions = {
157
+ events: events,
158
+ plugins: [_interaction.default, _daygrid.default, _timegrid.default, _list.default, _rrule.default],
159
+ initialView: 'dayGridMonth',
160
+ headerToolbar: {
161
+ start: 'sidebarToggle, prev,next, title',
162
+ end: 'dayGridMonth,timeGridWeek,timeGridDay,listMonth'
163
+ },
164
+
165
+ /*
166
+ Enable dragging and resizing event
167
+ ? Docs: https://fullcalendar.io/docs/editable
168
+ */
169
+ editable: true,
170
+ height: '100%',
171
+ stickyHeaderDates: true,
172
+ eventTimeFormat: {
173
+ // like '14:30:00'
174
+ hour: "2-digit",
175
+ minute: "2-digit",
176
+ hour12: false
177
+ },
178
+
179
+ /*
180
+ Enable resizing event from start
181
+ ? Docs: https://fullcalendar.io/docs/eventResizableFromStart
182
+ */
183
+ eventResizableFromStart: true,
184
+
185
+ /*
186
+ Automatically scroll the scroll-containers during event drag-and-drop and date selecting
187
+ ? Docs: https://fullcalendar.io/docs/dragScroll
188
+ */
189
+ dragScroll: true,
190
+
191
+ /*
192
+ Max number of events within a given day
193
+ ? Docs: https://fullcalendar.io/docs/dayMaxEvents
194
+ */
195
+ dayMaxEvents: 2,
196
+
197
+ /*
198
+ Determines if day names and week names are clickable
199
+ ? Docs: https://fullcalendar.io/docs/navLinks
200
+ */
201
+ navLinks: true,
202
+
203
+ eventClassNames({
204
+ event: calendarEvent
205
+ }) {
206
+ // eslint-disable-next-line no-underscore-dangle
207
+ const colorName = '#945c33';
208
+ return ["bg-light-".concat(colorName)];
209
+ },
210
+
211
+ viewDidMount() {
212
+ setOpen(false);
213
+ },
214
+
215
+ eventClick({
216
+ el: el,
217
+ event: event
218
+ }) {
219
+ // * Only grab required field otherwise it goes in infinity loop
220
+ // ! Always grab all fields rendered by form (even if it get `undefined`) otherwise due to Vue3/Composition API you might get: "object is not extensible"
221
+ // event.value = grabEventDataFromEventApi(clickedEvent)
222
+ // eslint-disable-next-line no-use-before-define
223
+ // isAddNewEventSidebarActive.value = true
224
+ setOpen(true);
225
+ var rect = el.getBoundingClientRect();
226
+ let topOffset = rect.bottom + 250 > document.body.getBoundingClientRect().bottom ? -1 * (rect.bottom + 250 - document.body.getBoundingClientRect().bottom) : 8;
227
+ let leftOffset = rect.right + 400 > document.body.getBoundingClientRect().right ? rect.right + 400 - document.body.getBoundingClientRect().right : 64;
228
+ setDialogTop(rect.top + topOffset + 'px');
229
+ setDialogLeft(rect.left - leftOffset + 'px');
230
+ setSelectedEvent(event);
231
+ let elementsByClassName = document.getElementsByClassName('fc-scroller-liquid-absolute');
232
+
233
+ if (elementsByClassName && elementsByClassName.length > 0) {
234
+ elementsByClassName[0].removeEventListener("scroll", calenderScrollListener);
235
+ elementsByClassName[0].addEventListener('scroll', calenderScrollListener);
236
+ }
237
+
238
+ elementsByClassName = document.getElementsByClassName('fc-scroller-liquid');
239
+
240
+ if (elementsByClassName && elementsByClassName.length > 0) {
241
+ elementsByClassName[0].removeEventListener("scroll", calenderScrollListener);
242
+ elementsByClassName[0].addEventListener('scroll', calenderScrollListener);
243
+ }
244
+ },
245
+
246
+ dateClick(info) {
247
+ let date = new Date(info.dateStr);
248
+ let timeDate = new Date();
249
+ let startTime = (0, _moment.default)(info.dateStr, 'ddd MMM D YYYY HH:mm:ss ZZ');
250
+ timeDate.setHours(timeDate.getHours() + 1);
251
+ startTime.set({
252
+ h: timeDate.getHours(),
253
+ m: 0
254
+ });
255
+ let endTime = (0, _moment.default)(info.dateStr, 'ddd MMM D YYYY HH:mm:ss ZZ');
256
+ timeDate.setHours(timeDate.getHours() + 1);
257
+ endTime.set({
258
+ h: timeDate.getHours(),
259
+ m: 0
260
+ });
261
+ const calendarEvent = { ...eventTemplate,
262
+ schedule: {
263
+ startDate: date,
264
+ endDate: date,
265
+ startTime: startTime.toDate(),
266
+ endTime: endTime.toDate(),
267
+ recurringStartDate: date,
268
+ recurringEndDate: date
269
+ },
270
+ eventType: _Utils.default.getComponentAttribute(props.config, 'eventType', 'TRAINING')
271
+ };
272
+
273
+ if (_Utils.default.isStringEmpty(calendarEvent.id)) {
274
+ calendarEvent.id = null;
275
+ }
276
+
277
+ if (!open && (0, _moment.default)(new Date()).startOf('day') <= (0, _moment.default)(date).startOf('day')) {
278
+ console.log("CALENDAR DATE CLICK");
279
+ let event = new _Event.default(props.handle, props.viewId, calendarEvent);
280
+
281
+ _Observable.default.fireEvent(_EventType.default.CALENDAR_DATE_CLICK, event);
282
+ }
283
+ },
284
+
285
+ /*
286
+ Handle event drop (Also include dragged event)
287
+ ? Docs: https://fullcalendar.io/docs/eventDrop
288
+ ? We can use `eventDragStop` but it doesn't return updated event so we have to use `eventDrop` which returns updated event
289
+ */
290
+ eventDrop({
291
+ event: droppedEvent
292
+ }) {
293
+ //dispatch(updateEvent(droppedEvent));
294
+ _reactHotToast.default.success('Event Updated');
295
+ },
296
+
297
+ /*
298
+ Handle event resize
299
+ ? Docs: https://fullcalendar.io/docs/eventResize
300
+ */
301
+ eventResize({
302
+ event: resizedEvent
303
+ }) {
304
+ //dispatch(updateEvent(resizedEvent));
305
+ _reactHotToast.default.success('Event Updated');
306
+ },
307
+
308
+ /*
309
+ Handle event mouse enter
310
+ ? Docs: https://fullcalendar.io/docs/eventMouseEnter
311
+ */
312
+ eventMouseEnter({
313
+ el: el,
314
+ event: event
315
+ }) {},
316
+
317
+ /*
318
+ Handle event mouse enter
319
+ ? Docs: https://fullcalendar.io/docs/eventMouseEnter
320
+ */
321
+ eventMouseLeave({
322
+ el: el
323
+ }) {},
324
+
325
+ ref: calendarRef,
326
+ // Get direction from app state (store)
327
+ direction: isRtl ? 'rtl' : 'ltr'
328
+ };
329
+
330
+ _react.default.useEffect(() => {
331
+ props.handle.api = api();
332
+
333
+ let parsedConfig = _Utils.default.parseConfig(props.config, props.viewId);
334
+
335
+ let eventHandlingConfig = _Utils.default.isNull(parsedConfig.eventHandlingConfig) ? {} : parsedConfig.eventHandlingConfig;
336
+ eventHandlingConfig.subscriptions = _Utils.default.isNull(eventHandlingConfig.subscriptions) ? [] : eventHandlingConfig.subscriptions;
337
+
338
+ _Observable.default.addSubscriptions(eventHandlingConfig, props.handle, props.viewId);
339
+
340
+ _Observable.default.addSystemSubscriptions(props.viewId, parsedConfig);
341
+ }, []);
342
+
343
+ const toDateTimeString = date => {
344
+ let dateStr = selectedEvent.start.toLocaleDateString();
345
+ let timeStrTokens = selectedEvent.start.toLocaleTimeString().split(':');
346
+ return dateStr + ' ' + timeStrTokens[0] + ':' + timeStrTokens[1];
347
+ };
348
+
349
+ const getFormObject = event => {
350
+ return _Calendar.default.calendarEventToFormObject(event);
351
+ };
352
+
353
+ const api = () => {
354
+ return {
355
+ get id() {
356
+ return props.config.id;
357
+ },
358
+
359
+ getChildren: () => {
360
+ return [];
361
+ }
362
+ };
363
+ };
364
+
365
+ const createEventPopup = el => {
366
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, selectedEvent && /*#__PURE__*/_react.default.createElement("div", {
367
+ className: 'event-popup'
368
+ }, /*#__PURE__*/_react.default.createElement("div", {
369
+ className: 'top-toolbar row no-padding no-margin'
370
+ }, /*#__PURE__*/_react.default.createElement("div", {
371
+ className: 'left col no-padding no-margin'
372
+ }, /*#__PURE__*/_react.default.createElement(_IconButton.default, {
373
+ onClick: () => setOpen(false)
374
+ }, /*#__PURE__*/_react.default.createElement(_Icon.default, {
375
+ id: 'CLOSE',
376
+ color: '#01476C'
377
+ }))), /*#__PURE__*/_react.default.createElement("div", {
378
+ className: 'right col no-padding no-margin'
379
+ }, /*#__PURE__*/_react.default.createElement(_IconButton.default, {
380
+ onClick: () => {
381
+ console.log("SELECTED EVENT : ", getFormObject(selectedEvent));
382
+ let event = new _Event.default(props.handle, props.viewId, getFormObject(selectedEvent));
383
+
384
+ _Observable.default.fireEvent(_EventType.default.CALENDAR_DATE_CLICK, event);
385
+ }
386
+ }, /*#__PURE__*/_react.default.createElement(_Icon.default, {
387
+ id: 'MAXIMIZE',
388
+ color: '#01476C'
389
+ })))), /*#__PURE__*/_react.default.createElement("div", {
390
+ className: 'summary'
391
+ }, /*#__PURE__*/_react.default.createElement("div", {
392
+ className: 'modal-title'
393
+ }, selectedEvent.title), /*#__PURE__*/_react.default.createElement("div", null, toDateTimeString(selectedEvent.start)), /*#__PURE__*/_react.default.createElement("div", {
394
+ className: 'organiser'
395
+ }, "Organiser: ", selectedEvent.extendedProps.host.name), /*#__PURE__*/_react.default.createElement("div", {
396
+ style: {
397
+ marginTop: '16px'
398
+ }
399
+ }, /*#__PURE__*/_react.default.createElement(_Button.default, {
400
+ variant: 'contained',
401
+ size: "large",
402
+ color: "primary",
403
+ style: {
404
+ borderRadius: '4px',
405
+ marginRight: '2px'
406
+ },
407
+ onClick: e => {
408
+ setOpen(false);
409
+ let event = new _Event.default(props.handle, props.viewId, getFormObject(selectedEvent));
410
+
411
+ _Observable.default.fireEvent(_EventType.default.CALENDAR_EVENT_START, event);
412
+ }
413
+ }, "JOIN")))));
414
+ };
415
+
416
+ return /*#__PURE__*/_react.default.createElement("div", {
417
+ className: props.className,
418
+ style: _Utils.default.mergeStyles({
419
+ padding: '16px 0',
420
+ margin: '0',
421
+ overflow: 'auto',
422
+ width: '100%',
423
+ height: '100%',
424
+ maxHeight: '100%'
425
+ }, props.config)
426
+ }, /*#__PURE__*/_react.default.createElement(_react2.default, calendarOptions), ' ', /*#__PURE__*/_react.default.createElement(StyledDialog, {
427
+ open: open,
428
+ ref: dialogRef,
429
+ onClose: () => {
430
+ setOpen(false);
431
+ },
432
+ "aria-labelledby": "alert-dialog-title",
433
+ "aria-describedby": "alert-dialog-description",
434
+ "aria-modal": false,
435
+ fullWidth: true
436
+ }, /*#__PURE__*/_react.default.createElement("div", {
437
+ className: 'w-100 h-100'
438
+ }, createEventPopup())));
439
+ };
440
+
441
+ var _default = Calendar;
442
+ exports.default = _default;
@@ -0,0 +1,244 @@
1
+ .no-margin {
2
+ margin-left: 0 !important;
3
+ margin-right: 0 !important;
4
+ }
5
+
6
+ .no-padding {
7
+ padding-left: 0 !important;
8
+ padding-right: 0 !important;
9
+ }
10
+
11
+ .app-calendar,
12
+ .fc-view-harness {
13
+ margin: unset !important;
14
+ }
15
+
16
+ .fc-header-toolbar button:hover {
17
+ transform: scale(1);
18
+ }
19
+
20
+ .event-popup {
21
+ background-color: #ffffff;
22
+ height: 100%;
23
+ width: 100%;
24
+ padding: 8px;
25
+ margin-left: 0 !important;
26
+ margin-right: 0 !important;
27
+ }
28
+
29
+ .fc-popover-body .fc-event-time,
30
+ .fc-popover-body .fc-event-title {
31
+ color: #01476C;
32
+ }
33
+
34
+ .event-popup .pointer {
35
+ width: 100%;
36
+ height: 8px;
37
+ }
38
+
39
+ .event-popup .top-toolbar {
40
+ width: 100%;
41
+ height: 48px;
42
+ }
43
+
44
+ .event-popup .top-toolbar .left {
45
+ width: 50%;
46
+ display: flex;
47
+ justify-content: flex-start;
48
+ }
49
+
50
+ .event-popup .top-toolbar .right {
51
+ width: 50%;
52
+ display: flex;
53
+ justify-content: flex-end;
54
+ }
55
+
56
+ .event-popup .summary {
57
+ width: 376px;
58
+ height: calc(100% - 72px);
59
+ padding: 16px;
60
+ }
61
+
62
+ .event-popup .summary .title {
63
+ font-size: 20px;
64
+ font-weight: 600;
65
+ white-space: nowrap;
66
+ overflow: hidden;
67
+ text-overflow: ellipsis;
68
+ }
69
+
70
+ .event-popup .summary .organiser {
71
+ font-size: 16px;
72
+ font-weight: 600;
73
+ }
74
+
75
+ .event-button {
76
+ width: 50%;
77
+ border-radius: 4px;
78
+ background-color: #01476C;
79
+ color: #ffffff;
80
+ }
81
+
82
+ .fc-button-group .fc-toolbar-title {
83
+ padding: 8px;
84
+ }
85
+
86
+ .fc-direction-ltr .fc-list-day-text,
87
+ .fc-event-main-frame,
88
+ .fc-header-toolbar .fc-toolbar-chunk:nth-of-type(3) .fc-button-group button {
89
+ border-color: #dfe8ed !important;
90
+ color: #01476C !important;
91
+ }
92
+
93
+ .fc .fc-daygrid-event-harness {
94
+ margin: 0 8px 0 4px;
95
+ }
96
+
97
+ .fc .fc-daygrid-event-harness .fc-event:hover {
98
+ background-color: #dfe8ed !important;
99
+ border-color: #dfe8ed !important;
100
+ }
101
+
102
+ .fc .fc-toolbar .fc-button-group .fc-button-primary:not(.fc-prev-button):not(.fc-next-button).fc-button-active,
103
+ .fc .fc-toolbar .fc-button-group .fc-button-primary:not(.fc-prev-button):not(.fc-next-button):hover {
104
+ border-color: #dfe8ed !important;
105
+ color: #01476C !important;
106
+ background-color: rgba(1, 71, 108, 0.2) !important;
107
+ }
108
+
109
+ .fc .fc-toolbar .fc-next-button .fc-icon,
110
+ .fc .fc-toolbar .fc-prev-button .fc-icon {
111
+ border-color: #dfe8ed !important;
112
+ color: #01476C !important;
113
+ background-color: transparent !important;
114
+ }
115
+
116
+ .fc .fc-button-primary {
117
+ background-color: unset !important;
118
+ border-color: unset !important;
119
+ }
120
+
121
+ .fc-daygrid-day-top a {
122
+ color: #6e6b7b;
123
+ }
124
+
125
+ .fc-daygrid-day-top a:hover {
126
+ color: #4BB543;
127
+ }
128
+
129
+ .app-calendar .fc-day-past .fc-daygrid-day-number,
130
+ .app-calendar .fc-day-future .fc-daygrid-day-number {
131
+ color: #6e6b7b !important;
132
+ }
133
+
134
+ .fc .fc-day-other .fc-daygrid-day-top,
135
+ .fc .fc-day-other .fc-daygrid-day-botton {
136
+ opacity: .5;
137
+ }
138
+
139
+ .fc-button:hover {
140
+ }
141
+
142
+ .fc-v-event {
143
+ display: block;
144
+ border: none !important;
145
+ background-color: unset !important;
146
+ }
147
+
148
+ .modal-title {
149
+ font-family: "Roboto", "Helvetica", "Arial", sans-serif;
150
+ font-style: normal;
151
+ font-weight: 400;
152
+ font-size: 28px;
153
+ line-height: 36px;
154
+ color: #3E435D;
155
+ }
156
+
157
+ button:focus {
158
+ outline: none !important;
159
+ }
160
+
161
+ .fc-daygrid-day-events a {
162
+ color: #01476C;
163
+ border: 4px solid #dfe8ed;
164
+ background-color: #dfe8ed !important;
165
+ border-radius: 4px !important;
166
+ }
167
+
168
+ .fc-daygrid-body table {
169
+ border-bottom: 1px solid #ebe9f1 !important;
170
+ }
171
+
172
+ .fc-view-harness,
173
+ .fc-view-harness-active {
174
+ min-height: unset !important;
175
+ }
176
+
177
+ .fc-daygrid-dot-event .fc-event-title {
178
+ font-weight: 500 !important;
179
+ }
180
+
181
+ .fc .fc-daygrid-event-harness .fc-event {
182
+ width: 100%;
183
+ max-width: 100%;
184
+ white-space: nowrap;
185
+ overflow: hidden;
186
+ text-overflow: ellipsis;
187
+ background-color: #dfe8ed !important;
188
+ font-weight: 500 !important;
189
+ }
190
+
191
+
192
+ .fc-daygrid-day-events a:hover,
193
+ .fc-daygrid-day-events a:focus {
194
+ color: #01476C !important;
195
+ border-color: #dfe8ed !important;
196
+ }
197
+
198
+ .fc-daygrid-event-dot {
199
+ border-color: #01476C;
200
+ display: none;
201
+ }
202
+
203
+ .fc-daygrid-event-dot:hover {
204
+ border-color: #dfe8ed;
205
+ display: none;
206
+ }
207
+
208
+ .fc-daygrid-day-events a:hover .fc-daygrid-event-dot {
209
+ border-color: #ffffff !important;
210
+ }
211
+
212
+ .fc-sidebarToggle-button {
213
+ display: none !important;
214
+ }
215
+
216
+ .fc .fc-list-event-dot {
217
+ border: 5px solid #dfe8ed !important;
218
+ }
219
+
220
+ .fc-scrollgrid-section-body table {
221
+ background-repeat: no-repeat;
222
+ background-size: 28% auto;
223
+ background-attachment: fixed;
224
+ background-position: center;
225
+ }
226
+
227
+ .fc .fc-daygrid-day.fc-day-today {
228
+ background-color: rgba(234, 223, 213, .5) !important;
229
+ }
230
+
231
+ .app-calendar .fc-day-past .fc-daygrid-day-number {
232
+ color: #000000
233
+ }
234
+
235
+ .fc .fc-day-other .fc-daygrid-day-top, .fc .fc-day-other .fc-daygrid-day-botton {
236
+ opacity: .5
237
+ }
238
+
239
+ /*
240
+
241
+ .fc-day-past {
242
+ color: #6e6b7b
243
+ }
244
+ */