@plusscommunities/pluss-maintenance-app 6.0.6-auth.0 → 6.1.2-beta.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 (71) hide show
  1. package/dist/module/actions/types.js +4 -3
  2. package/dist/module/actions/types.js.map +1 -1
  3. package/dist/module/apis/{maintenanceActions.js → generalActions.js} +51 -33
  4. package/dist/module/apis/generalActions.js.map +1 -0
  5. package/dist/module/apis/index.js +1 -1
  6. package/dist/module/apis/index.js.map +1 -1
  7. package/dist/module/components/FilterPopupMenu.js +12 -48
  8. package/dist/module/components/FilterPopupMenu.js.map +1 -1
  9. package/dist/module/components/MaintenanceList.js +19 -52
  10. package/dist/module/components/MaintenanceList.js.map +1 -1
  11. package/dist/module/components/MaintenanceListItem.js +17 -15
  12. package/dist/module/components/MaintenanceListItem.js.map +1 -1
  13. package/dist/module/components/MaintenanceWidgetItem.js +9 -4
  14. package/dist/module/components/MaintenanceWidgetItem.js.map +1 -1
  15. package/dist/module/components/StatusSelectorPopup.js +1 -2
  16. package/dist/module/components/StatusSelectorPopup.js.map +1 -1
  17. package/dist/module/components/WidgetSmall.js +10 -7
  18. package/dist/module/components/WidgetSmall.js.map +1 -1
  19. package/dist/module/feature.config.js +18 -33
  20. package/dist/module/feature.config.js.map +1 -1
  21. package/dist/module/helper.js +2 -10
  22. package/dist/module/helper.js.map +1 -1
  23. package/dist/module/index.js +15 -10
  24. package/dist/module/index.js.map +1 -1
  25. package/dist/module/reducers/JobsReducer.js +2 -2
  26. package/dist/module/reducers/JobsReducer.js.map +1 -1
  27. package/dist/module/screens/JobTypePicker.js +2 -2
  28. package/dist/module/screens/MaintenancePage.js +9 -5
  29. package/dist/module/screens/MaintenancePage.js.map +1 -1
  30. package/dist/module/screens/RequestDetail.js +44 -145
  31. package/dist/module/screens/RequestDetail.js.map +1 -1
  32. package/dist/module/screens/RequestNotes.js +8 -7
  33. package/dist/module/screens/RequestNotes.js.map +1 -1
  34. package/dist/module/screens/ServiceRequest.js +12 -9
  35. package/dist/module/screens/ServiceRequest.js.map +1 -1
  36. package/dist/module/values.config.a.js +28 -0
  37. package/dist/module/values.config.a.js.map +1 -0
  38. package/dist/module/values.config.b.js +28 -0
  39. package/dist/module/values.config.b.js.map +1 -0
  40. package/dist/module/values.config.c.js +28 -0
  41. package/dist/module/values.config.c.js.map +1 -0
  42. package/dist/module/values.config.d.js +28 -0
  43. package/dist/module/values.config.d.js.map +1 -0
  44. package/dist/module/values.config.default.js +28 -0
  45. package/dist/module/values.config.default.js.map +1 -0
  46. package/dist/module/values.config.js +28 -0
  47. package/dist/module/values.config.js.map +1 -0
  48. package/package.json +13 -9
  49. package/src/actions/types.js +5 -3
  50. package/src/apis/{maintenanceActions.js → generalActions.js} +50 -30
  51. package/src/apis/index.js +1 -1
  52. package/src/components/FilterPopupMenu.js +7 -39
  53. package/src/components/MaintenanceList.js +21 -59
  54. package/src/components/MaintenanceListItem.js +10 -13
  55. package/src/components/MaintenanceWidgetItem.js +3 -2
  56. package/src/components/StatusSelectorPopup.js +1 -2
  57. package/src/components/WidgetSmall.js +8 -5
  58. package/src/feature.config.js +18 -30
  59. package/src/helper.js +2 -11
  60. package/src/index.js +15 -8
  61. package/src/screens/MaintenancePage.js +5 -4
  62. package/src/screens/RequestDetail.js +19 -135
  63. package/src/screens/RequestNotes.js +6 -5
  64. package/src/screens/ServiceRequest.js +8 -6
  65. package/src/values.config.a.js +28 -0
  66. package/src/values.config.b.js +28 -0
  67. package/src/values.config.c.js +28 -0
  68. package/src/values.config.d.js +28 -0
  69. package/src/values.config.default.js +28 -0
  70. package/src/values.config.js +28 -0
  71. package/dist/module/apis/maintenanceActions.js.map +0 -1
@@ -1,4 +1,5 @@
1
- export const JOBS_LOADED = 'JOBS_LOADED';
2
- export const JOB_ADDED = 'JOB_ADDED';
3
- export const JOBS_ADDED = 'JOBS_ADDED';
1
+ import { values } from '../values.config';
2
+ export const JOBS_LOADED = values.actionJobsLoaded;
3
+ export const JOB_ADDED = values.actionJobAdded;
4
+ export const JOBS_ADDED = values.actionJobsAdded;
4
5
  //# sourceMappingURL=types.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["JOBS_LOADED","JOB_ADDED","JOBS_ADDED"],"sources":["types.js"],"sourcesContent":["export const JOBS_LOADED = 'JOBS_LOADED';\nexport const JOB_ADDED = 'JOB_ADDED';\nexport const JOBS_ADDED = 'JOBS_ADDED';\n"],"mappings":"AAAA,OAAO,MAAMA,WAAW,GAAG,aAAa;AACxC,OAAO,MAAMC,SAAS,GAAG,WAAW;AACpC,OAAO,MAAMC,UAAU,GAAG,YAAY","ignoreList":[]}
1
+ {"version":3,"names":["values","JOBS_LOADED","actionJobsLoaded","JOB_ADDED","actionJobAdded","JOBS_ADDED","actionJobsAdded"],"sources":["types.js"],"sourcesContent":["import { values } from '../values.config';\n\nexport const JOBS_LOADED = values.actionJobsLoaded;\nexport const JOB_ADDED = values.actionJobAdded;\nexport const JOBS_ADDED = values.actionJobsAdded;\n"],"mappings":"AAAA,SAASA,MAAM,QAAQ,kBAAkB;AAEzC,OAAO,MAAMC,WAAW,GAAGD,MAAM,CAACE,gBAAgB;AAClD,OAAO,MAAMC,SAAS,GAAGH,MAAM,CAACI,cAAc;AAC9C,OAAO,MAAMC,UAAU,GAAGL,MAAM,CAACM,eAAe","ignoreList":[]}
@@ -1,9 +1,13 @@
1
+ // import axios from 'axios';
2
+ // import { getUrl } from './helper';
3
+ // import { authedFunction } from '../js';
1
4
  import { Helper, Session } from '../core.config';
2
- export const maintenanceActions = {
5
+ import { values } from '../values.config';
6
+ export const generalActions = {
3
7
  getJob: (site, id) => {
4
8
  return Session.authedFunction({
5
9
  method: 'POST',
6
- url: Helper.getUrl('maintenance', 'getJob'),
10
+ url: Helper.getUrl(values.serviceKey, 'getJob'),
7
11
  data: {
8
12
  site,
9
13
  id
@@ -13,7 +17,7 @@ export const maintenanceActions = {
13
17
  getJobByJobId: (site, jobId) => {
14
18
  return Session.authedFunction({
15
19
  method: 'POST',
16
- url: Helper.getUrl('maintenance', 'getJob'),
20
+ url: Helper.getUrl(values.serviceKey, 'getJob'),
17
21
  data: {
18
22
  site,
19
23
  jobId
@@ -23,7 +27,7 @@ export const maintenanceActions = {
23
27
  getJobs: (site, status = '', type = '') => {
24
28
  return Session.authedFunction({
25
29
  method: 'POST',
26
- url: Helper.getUrl('maintenance', 'getJobs'),
30
+ url: Helper.getUrl(values.serviceKey, 'getJobs'),
27
31
  data: {
28
32
  site,
29
33
  status,
@@ -46,24 +50,24 @@ export const maintenanceActions = {
46
50
  }
47
51
  return Session.authedFunction({
48
52
  method: 'GET',
49
- url: Helper.getUrl('maintenance', 'get/requests', query)
53
+ url: Helper.getUrl(values.serviceKey, 'get/requests', query)
50
54
  });
51
55
  },
52
56
  getJobsRecursive: (site, status, type, lastKey, jobs = []) => {
53
57
  return new Promise(resolve => {
54
- maintenanceActions.getJobs2(site, status, type, lastKey).then(jobRes => {
58
+ generalActions.getJobs2(site, status, type, lastKey).then(jobRes => {
55
59
  const newJobs = [...jobs, ...jobRes.data.Items];
56
60
  if (!jobRes.data.LastKey) {
57
61
  return resolve(newJobs);
58
62
  }
59
- return resolve(maintenanceActions.getJobsRecursive(site, status, type, jobRes.data.LastKey, newJobs));
63
+ return resolve(generalActions.getJobsRecursive(site, status, type, jobRes.data.LastKey, newJobs));
60
64
  });
61
65
  });
62
66
  },
63
67
  sendMaintenanceRequest: (userID, userName, phone, room, title, description, date, type, images, location, isHome, homeText) => {
64
68
  const request = {
65
69
  method: 'POST',
66
- url: Helper.getUrl('maintenance', 'sendMaintenance'),
70
+ url: Helper.getUrl(values.serviceKey, 'sendMaintenance'),
67
71
  data: {
68
72
  userID,
69
73
  userName,
@@ -84,7 +88,7 @@ export const maintenanceActions = {
84
88
  editJob: (job, site) => {
85
89
  return Session.authedFunction({
86
90
  method: 'POST',
87
- url: Helper.getUrl('maintenance', 'editJob'),
91
+ url: Helper.getUrl(values.serviceKey, 'editJob'),
88
92
  data: {
89
93
  job,
90
94
  site
@@ -94,35 +98,17 @@ export const maintenanceActions = {
94
98
  editJobStatus: (id, status) => {
95
99
  return Session.authedFunction({
96
100
  method: 'POST',
97
- url: Helper.getUrl('maintenance', 'editJobStatus'),
101
+ url: Helper.getUrl(values.serviceKey, 'editJobStatus'),
98
102
  data: {
99
103
  id,
100
104
  status
101
105
  }
102
106
  });
103
107
  },
104
- assignJob: (jobId, userId) => {
105
- return Session.authedFunction({
106
- method: 'POST',
107
- url: Helper.getUrl('maintenance', 'update/assign'),
108
- data: {
109
- id: jobId,
110
- userId
111
- }
112
- });
113
- },
114
- getAssignees: site => {
115
- return Session.authedFunction({
116
- method: 'GET',
117
- url: Helper.getUrl('maintenance', 'get/assignees', {
118
- site
119
- })
120
- });
121
- },
122
108
  addNote: (jobId, note, attachments) => {
123
109
  return Session.authedFunction({
124
110
  method: 'POST',
125
- url: Helper.getUrl('maintenance', 'requests/note'),
111
+ url: Helper.getUrl(values.serviceKey, 'requests/note'),
126
112
  data: {
127
113
  id: jobId,
128
114
  note,
@@ -134,7 +120,7 @@ export const maintenanceActions = {
134
120
  editNote: (jobId, noteId, note, attachments) => {
135
121
  return Session.authedFunction({
136
122
  method: 'POST',
137
- url: Helper.getUrl('maintenance', 'requests/note'),
123
+ url: Helper.getUrl(values.serviceKey, 'requests/note'),
138
124
  data: {
139
125
  id: jobId,
140
126
  note,
@@ -147,7 +133,7 @@ export const maintenanceActions = {
147
133
  deleteNote: (jobId, noteId) => {
148
134
  return Session.authedFunction({
149
135
  method: 'POST',
150
- url: Helper.getUrl('maintenance', 'requests/note'),
136
+ url: Helper.getUrl(values.serviceKey, 'requests/note'),
151
137
  data: {
152
138
  id: jobId,
153
139
  noteId,
@@ -155,8 +141,12 @@ export const maintenanceActions = {
155
141
  }
156
142
  });
157
143
  },
144
+ // getWeeklyMenu: async time => {
145
+ // //deprecated
146
+ // return null;
147
+ // },
158
148
  getJobTypes: async site => {
159
- const url = Helper.getUrl('maintenance', 'getjobtypes');
149
+ const url = Helper.getUrl(values.serviceKey, 'getjobtypes');
160
150
  return Session.authedFunction({
161
151
  method: 'POST',
162
152
  url,
@@ -165,5 +155,33 @@ export const maintenanceActions = {
165
155
  }
166
156
  });
167
157
  }
158
+ // sendBookingRequest: async bookingInfo => {
159
+ // return authedFunction({
160
+ // method: 'POST',
161
+ // data: {
162
+ // bookingInfo,
163
+ // },
164
+ // url: getUrl('utility', 'sendBookingRequest'),
165
+ // });
166
+ // },
167
+ // getString: async (site, id, useDefault) => {
168
+ // return axios({
169
+ // method: 'GET',
170
+ // url: getUrl('strings', `get/${site}_${id}`, useDefault ? { useDefault } : undefined),
171
+ // }).catch(error => {
172
+ // console.log('getString error', error);
173
+ // throw error;
174
+ // });
175
+ // },
176
+ // getGeneralTerms: async () => {
177
+ // return axios({
178
+ // method: 'GET',
179
+ // url: 'https://pluss.plussapp.com.au/strings-prd/get/plussSpace_termsofuse',
180
+ // });
181
+ // },
182
+ // declineTerms: async (site, userID) => {
183
+ // //deprecated
184
+ // return null;
185
+ // },
168
186
  };
169
- //# sourceMappingURL=maintenanceActions.js.map
187
+ //# sourceMappingURL=generalActions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["Helper","Session","values","generalActions","getJob","site","id","authedFunction","method","url","getUrl","serviceKey","data","getJobByJobId","jobId","getJobs","status","type","getJobs2","lastKey","query","JSON","stringify","getJobsRecursive","jobs","Promise","resolve","then","jobRes","newJobs","Items","LastKey","sendMaintenanceRequest","userID","userName","phone","room","title","description","date","images","location","isHome","homeText","request","editJob","job","editJobStatus","addNote","note","attachments","action","editNote","noteId","deleteNote","getJobTypes"],"sources":["generalActions.js"],"sourcesContent":["// import axios from 'axios';\n// import { getUrl } from './helper';\n// import { authedFunction } from '../js';\nimport { Helper, Session } from '../core.config';\nimport { values } from '../values.config';\n\nexport const generalActions = {\n getJob: (site, id) => {\n return Session.authedFunction({\n method: 'POST',\n url: Helper.getUrl(values.serviceKey, 'getJob'),\n data: { site, id },\n });\n },\n getJobByJobId: (site, jobId) => {\n return Session.authedFunction({\n method: 'POST',\n url: Helper.getUrl(values.serviceKey, 'getJob'),\n data: { site, jobId },\n });\n },\n getJobs: (site, status = '', type = '') => {\n return Session.authedFunction({\n method: 'POST',\n url: Helper.getUrl(values.serviceKey, 'getJobs'),\n data: { site, status, type },\n });\n },\n getJobs2: (site, status, type, lastKey) => {\n const query = { site };\n if (status) {\n query.status = status;\n }\n if (type) {\n query.type = type;\n }\n if (lastKey) {\n query.lastKey = JSON.stringify(lastKey);\n }\n return Session.authedFunction({\n method: 'GET',\n url: Helper.getUrl(values.serviceKey, 'get/requests', query),\n });\n },\n getJobsRecursive: (site, status, type, lastKey, jobs = []) => {\n return new Promise(resolve => {\n generalActions.getJobs2(site, status, type, lastKey).then(jobRes => {\n const newJobs = [...jobs, ...jobRes.data.Items];\n if (!jobRes.data.LastKey) {\n return resolve(newJobs);\n }\n return resolve(generalActions.getJobsRecursive(site, status, type, jobRes.data.LastKey, newJobs));\n });\n });\n },\n sendMaintenanceRequest: (userID, userName, phone, room, title, description, date, type, images, location, isHome, homeText) => {\n const request = {\n method: 'POST',\n url: Helper.getUrl(values.serviceKey, 'sendMaintenance'),\n data: {\n userID,\n userName,\n phone,\n room,\n title,\n description,\n date,\n type,\n images,\n location,\n isHome,\n homeText,\n },\n };\n return Session.authedFunction(request);\n },\n editJob: (job, site) => {\n return Session.authedFunction({\n method: 'POST',\n url: Helper.getUrl(values.serviceKey, 'editJob'),\n data: { job, site },\n });\n },\n editJobStatus: (id, status) => {\n return Session.authedFunction({\n method: 'POST',\n url: Helper.getUrl(values.serviceKey, 'editJobStatus'),\n data: { id, status },\n });\n },\n addNote: (jobId, note, attachments) => {\n return Session.authedFunction({\n method: 'POST',\n url: Helper.getUrl(values.serviceKey, 'requests/note'),\n data: {\n id: jobId,\n note,\n attachments,\n action: 'AddNote',\n },\n });\n },\n editNote: (jobId, noteId, note, attachments) => {\n return Session.authedFunction({\n method: 'POST',\n url: Helper.getUrl(values.serviceKey, 'requests/note'),\n data: {\n id: jobId,\n note,\n attachments,\n noteId,\n action: 'EditNote',\n },\n });\n },\n deleteNote: (jobId, noteId) => {\n return Session.authedFunction({\n method: 'POST',\n url: Helper.getUrl(values.serviceKey, 'requests/note'),\n data: {\n id: jobId,\n noteId,\n action: 'DeleteNote',\n },\n });\n },\n // getWeeklyMenu: async time => {\n // //deprecated\n // return null;\n // },\n getJobTypes: async site => {\n const url = Helper.getUrl(values.serviceKey, 'getjobtypes');\n return Session.authedFunction({\n method: 'POST',\n url,\n data: { site },\n });\n },\n // sendBookingRequest: async bookingInfo => {\n // return authedFunction({\n // method: 'POST',\n // data: {\n // bookingInfo,\n // },\n // url: getUrl('utility', 'sendBookingRequest'),\n // });\n // },\n // getString: async (site, id, useDefault) => {\n // return axios({\n // method: 'GET',\n // url: getUrl('strings', `get/${site}_${id}`, useDefault ? { useDefault } : undefined),\n // }).catch(error => {\n // console.log('getString error', error);\n // throw error;\n // });\n // },\n // getGeneralTerms: async () => {\n // return axios({\n // method: 'GET',\n // url: 'https://pluss.plussapp.com.au/strings-prd/get/plussSpace_termsofuse',\n // });\n // },\n // declineTerms: async (site, userID) => {\n // //deprecated\n // return null;\n // },\n};\n"],"mappings":"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","ignoreList":[]}
@@ -1,2 +1,2 @@
1
- export * from './maintenanceActions';
1
+ export * from './generalActions';
2
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"names":[],"sources":["index.js"],"sourcesContent":["export * from './maintenanceActions';\n"],"mappings":"AAAA,cAAc,sBAAsB","ignoreList":[]}
1
+ {"version":3,"names":[],"sources":["index.js"],"sourcesContent":["export * from './generalActions';\n"],"mappings":"AAAA,cAAc,kBAAkB","ignoreList":[]}
@@ -1,46 +1,19 @@
1
- function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
2
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
1
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
2
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
3
3
  function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
4
4
  import React, { Component } from 'react';
5
- import { View, Text, TouchableOpacity, Modal, ScrollView, Dimensions } from 'react-native';
5
+ import { View, Text, TouchableOpacity, Modal } from 'react-native';
6
6
  import { connect } from 'react-redux';
7
7
  import _ from 'lodash';
8
- import { maintenanceActions } from '../apis';
8
+ import { generalActions } from '../apis';
9
9
  import { Colours, Helper } from '../core.config';
10
- const SCREEN_HEIGHT = Dimensions.get('window').height;
11
10
  class FilterPopupMenu extends Component {
12
11
  constructor(props) {
13
12
  super(props);
14
- _defineProperty(this, "getAssignees", async () => {
15
- try {
16
- const res = await maintenanceActions.getAssignees(this.props.site);
17
- let assignees = res.data.Users.map(t => {
18
- return {
19
- label: t.displayName,
20
- value: t.id
21
- };
22
- });
23
- assignees = _.orderBy(assignees, 'label');
24
- assignees.splice(0, 0, {
25
- label: 'All',
26
- value: ''
27
- });
28
- const newState = {
29
- assignees
30
- };
31
- if (!assignees.some(a => a.value === this.state.selectedAssignee)) {
32
- newState.selectedAssignee = '';
33
- }
34
- // console.log('refreshassignees', assignees);
35
- this.setState(newState);
36
- } catch (error) {
37
- console.error('getAssignees', error);
38
- }
39
- });
40
13
  _defineProperty(this, "refreshTypes", async () => {
41
14
  const {
42
15
  data
43
- } = await maintenanceActions.getJobTypes(Helper.getSite(this.props.site));
16
+ } = await generalActions.getJobTypes(Helper.getSite(this.props.site));
44
17
  const types = data.map(t => {
45
18
  return {
46
19
  label: t.typeName,
@@ -62,29 +35,22 @@ class FilterPopupMenu extends Component {
62
35
  this.setState(newState);
63
36
  });
64
37
  _defineProperty(this, "onDone", () => {
65
- var _this$statusOptions$f, _this$state$assignees;
66
38
  const {
67
39
  onClose
68
40
  } = this.props;
69
41
  const {
70
42
  selectedStatus,
71
- selectedType,
72
- selectedAssignee
43
+ selectedType
73
44
  } = this.state;
74
45
  if (onClose) onClose({
75
46
  status: selectedStatus,
76
- statusText: (_this$statusOptions$f = this.statusOptions.find(o => o.value === selectedStatus)) === null || _this$statusOptions$f === void 0 ? void 0 : _this$statusOptions$f.label,
77
- type: selectedType,
78
- assignee: selectedAssignee,
79
- assigneeName: (_this$state$assignees = this.state.assignees.find(a => a.value === selectedAssignee)) === null || _this$state$assignees === void 0 ? void 0 : _this$state$assignees.label
47
+ type: selectedType
80
48
  });
81
49
  });
82
50
  this.state = {
83
51
  types: props.types || [],
84
52
  selectedStatus: props.status || '',
85
- selectedType: props.type || '',
86
- selectedAssignee: props.assignee || '',
87
- assignees: []
53
+ selectedType: props.type || ''
88
54
  };
89
55
  this.statusOptions = [{
90
56
  label: 'All',
@@ -93,7 +59,7 @@ class FilterPopupMenu extends Component {
93
59
  label: 'Incomplete',
94
60
  value: 'Unassigned|In Progress'
95
61
  }, {
96
- label: 'Open',
62
+ label: 'Unassigned',
97
63
  value: 'Unassigned'
98
64
  }, {
99
65
  label: 'In Progress',
@@ -104,7 +70,6 @@ class FilterPopupMenu extends Component {
104
70
  }];
105
71
  }
106
72
  componentDidMount() {
107
- this.getAssignees();
108
73
  if (_.isEmpty(this.state.types)) this.refreshTypes();
109
74
  }
110
75
  componentDidUpdate(prevProps) {
@@ -176,9 +141,9 @@ class FilterPopupMenu extends Component {
176
141
  style: styles.container
177
142
  }, /*#__PURE__*/React.createElement(View, {
178
143
  style: styles.menu
179
- }, this.renderTitle(), /*#__PURE__*/React.createElement(ScrollView, {
144
+ }, this.renderTitle(), /*#__PURE__*/React.createElement(View, {
180
145
  style: styles.optionContent
181
- }, this.renderOptions('Status', this.statusOptions, 'selectedStatus'), this.renderOptions('Type', this.state.types, 'selectedType'), this.renderOptions('Assigned To', this.state.assignees, 'selectedAssignee')), this.renderCancel())));
146
+ }, this.renderOptions('Status', this.statusOptions, 'selectedStatus'), this.renderOptions('Type', this.state.types, 'selectedType')), this.renderCancel())));
182
147
  }
183
148
  }
184
149
  const styles = {
@@ -198,8 +163,7 @@ const styles = {
198
163
  right: 0,
199
164
  backgroundColor: '#fff',
200
165
  borderTopLeftRadius: 12,
201
- borderTopRightRadius: 12,
202
- maxHeight: SCREEN_HEIGHT * 0.8
166
+ borderTopRightRadius: 12
203
167
  },
204
168
  cancelContainer: {
205
169
  paddingVertical: 16,
@@ -1 +1 @@
1
- {"version":3,"names":["React","Component","View","Text","TouchableOpacity","Modal","ScrollView","Dimensions","connect","_","maintenanceActions","Colours","Helper","SCREEN_HEIGHT","get","height","FilterPopupMenu","constructor","props","_defineProperty","res","getAssignees","site","assignees","data","Users","map","t","label","displayName","value","id","orderBy","splice","newState","some","a","state","selectedAssignee","setState","error","console","getJobTypes","getSite","types","typeName","key","_this$statusOptions$f","_this$state$assignees","onClose","selectedStatus","selectedType","status","statusText","statusOptions","find","o","type","assignee","assigneeName","componentDidMount","isEmpty","refreshTypes","componentDidUpdate","prevProps","renderTitle","title","createElement","style","styles","titleContainer","titleText","renderCancel","colourBrandingMain","cancelText","onPress","onDone","cancelContainer","color","renderOptions","options","selectedKey","optionsContainer","optionsTitle","selected","backgroundColor","onSelectOption","optionContainer","borderColor","optionText","render","visible","transparent","animationType","onRequestClose","container","menu","optionContent","position","bottom","left","right","top","zIndex","borderTopLeftRadius","borderTopRightRadius","maxHeight","paddingVertical","LINEGREY","borderTopWidth","paddingHorizontal","fontFamily","fontSize","textAlign","TEXT_DARK","padding","borderBottomWidth","marginHorizontal","marginBottom","flex","flexDirection","flexWrap","alignItems","justifyContent","minWidth","borderRadius","borderWidth","marginRight","mapStateToProps","user","getMainBrandingColourFromState"],"sources":["FilterPopupMenu.js"],"sourcesContent":["import React, { Component } from 'react';\nimport { View, Text, TouchableOpacity, Modal, ScrollView, Dimensions } from 'react-native';\nimport { connect } from 'react-redux';\nimport _ from 'lodash';\nimport { maintenanceActions } from '../apis';\nimport { Colours, Helper } from '../core.config';\n\nconst SCREEN_HEIGHT = Dimensions.get('window').height;\n\nclass FilterPopupMenu extends Component {\n constructor(props) {\n super(props);\n\n this.state = {\n types: props.types || [],\n selectedStatus: props.status || '',\n selectedType: props.type || '',\n selectedAssignee: props.assignee || '',\n assignees: [],\n };\n this.statusOptions = [\n {\n label: 'All',\n value: '',\n },\n {\n label: 'Incomplete',\n value: 'Unassigned|In Progress',\n },\n {\n label: 'Open',\n value: 'Unassigned',\n },\n {\n label: 'In Progress',\n value: 'In Progress',\n },\n {\n label: 'Completed',\n value: 'Completed',\n },\n ];\n }\n\n componentDidMount() {\n this.getAssignees();\n if (_.isEmpty(this.state.types)) this.refreshTypes();\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.site !== this.props.site) {\n this.refreshTypes();\n }\n }\n\n getAssignees = async () => {\n try {\n const res = await maintenanceActions.getAssignees(this.props.site);\n let assignees = res.data.Users.map(t => {\n return { label: t.displayName, value: t.id };\n });\n assignees = _.orderBy(assignees, 'label');\n\n assignees.splice(0, 0, { label: 'All', value: '' });\n\n const newState = { assignees };\n\n if (!assignees.some(a => a.value === this.state.selectedAssignee)) {\n newState.selectedAssignee = '';\n }\n // console.log('refreshassignees', assignees);\n this.setState(newState);\n } catch (error) {\n console.error('getAssignees', error);\n }\n };\n\n refreshTypes = async () => {\n const { data } = await maintenanceActions.getJobTypes(Helper.getSite(this.props.site));\n const types = data.map(t => {\n return { label: t.typeName, value: t.typeName };\n });\n types.splice(0, 0, { label: 'All', value: '' });\n // console.log('refreshTypes', types);\n this.setState({ types });\n };\n\n onSelectOption = (key, value) => {\n const newState = {};\n newState[key] = value;\n this.setState(newState);\n };\n\n onDone = () => {\n const { onClose } = this.props;\n const { selectedStatus, selectedType, selectedAssignee } = this.state;\n if (onClose)\n onClose({\n status: selectedStatus,\n statusText: this.statusOptions.find(o => o.value === selectedStatus)?.label,\n type: selectedType,\n assignee: selectedAssignee,\n assigneeName: this.state.assignees.find(a => a.value === selectedAssignee)?.label,\n });\n };\n\n renderTitle() {\n const { title } = this.props;\n return (\n <View style={styles.titleContainer}>\n <Text style={styles.titleText}>{title || 'Filter By'}</Text>\n </View>\n );\n }\n\n renderCancel() {\n const { colourBrandingMain, cancelText } = this.props;\n return (\n <TouchableOpacity onPress={this.onDone}>\n <View style={styles.cancelContainer}>\n <Text style={[styles.cancelText, { color: colourBrandingMain }]}>{cancelText || 'Done'}</Text>\n </View>\n </TouchableOpacity>\n );\n }\n\n renderOptions(title, options, selectedKey) {\n const { colourBrandingMain } = this.props;\n return (\n <View style={styles.optionsContainer}>\n <Text style={styles.optionsTitle}>{title}</Text>\n <View style={styles.options}>\n {options.map(o => {\n const selected = this.state[selectedKey];\n const backgroundColor = o.value === selected ? colourBrandingMain : '#fff';\n const color = o.value === selected ? '#fff' : colourBrandingMain;\n return (\n <TouchableOpacity key={o.label} onPress={() => this.onSelectOption(selectedKey, o.value)}>\n <View style={[styles.optionContainer, { backgroundColor, borderColor: colourBrandingMain }]}>\n <Text style={[styles.optionText, { color }]}>{o.label}</Text>\n </View>\n </TouchableOpacity>\n );\n })}\n </View>\n </View>\n );\n }\n\n render() {\n return (\n <Modal visible transparent animationType=\"slide\" onRequestClose={this.onDone}>\n <View style={styles.container}>\n <View style={styles.menu}>\n {this.renderTitle()}\n <ScrollView style={styles.optionContent}>\n {this.renderOptions('Status', this.statusOptions, 'selectedStatus')}\n {this.renderOptions('Type', this.state.types, 'selectedType')}\n {this.renderOptions('Assigned To', this.state.assignees, 'selectedAssignee')}\n </ScrollView>\n {this.renderCancel()}\n </View>\n </View>\n </Modal>\n );\n }\n}\n\nconst styles = {\n container: {\n position: 'absolute',\n bottom: 0,\n left: 0,\n right: 0,\n top: 0,\n backgroundColor: 'rgba(0,0,0,0.5)',\n zIndex: 1000,\n },\n menu: {\n position: 'absolute',\n bottom: 0,\n left: 0,\n right: 0,\n backgroundColor: '#fff',\n borderTopLeftRadius: 12,\n borderTopRightRadius: 12,\n maxHeight: SCREEN_HEIGHT * 0.8,\n },\n cancelContainer: {\n paddingVertical: 16,\n borderColor: Colours.LINEGREY,\n borderTopWidth: 1,\n paddingHorizontal: 16,\n },\n cancelText: {\n fontFamily: 'sf-medium',\n fontSize: 16,\n textAlign: 'center',\n color: Colours.TEXT_DARK,\n },\n titleContainer: {\n padding: 16,\n borderColor: Colours.LINEGREY,\n borderBottomWidth: 1,\n },\n titleText: {\n fontFamily: 'sf-semibold',\n fontSize: 16,\n textAlign: 'center',\n color: Colours.TEXT_DARK,\n },\n optionContent: {\n paddingVertical: 10,\n },\n optionsContainer: {\n marginHorizontal: 14,\n },\n optionsTitle: {\n fontFamily: 'sf-semibold',\n marginBottom: 4,\n },\n options: {\n flex: 1,\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n optionContainer: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n minWidth: 50,\n height: 30,\n paddingHorizontal: 8,\n borderRadius: 4,\n borderWidth: 1,\n marginRight: 8,\n marginBottom: 8,\n },\n optionText: {\n color: '#fff',\n textAlign: 'center',\n fontFamily: 'sf-semibold',\n fontSize: 13,\n },\n};\n\nconst mapStateToProps = state => {\n const { user } = state;\n\n return {\n site: user.site,\n colourBrandingMain: Colours.getMainBrandingColourFromState(state),\n };\n};\n\nexport default connect(mapStateToProps, {})(FilterPopupMenu);\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["React","Component","View","Text","TouchableOpacity","Modal","connect","_","generalActions","Colours","Helper","FilterPopupMenu","constructor","props","_defineProperty","data","getJobTypes","getSite","site","types","map","t","label","typeName","value","splice","setState","key","newState","onClose","selectedStatus","selectedType","state","status","type","statusOptions","componentDidMount","isEmpty","refreshTypes","componentDidUpdate","prevProps","renderTitle","title","createElement","style","styles","titleContainer","titleText","renderCancel","colourBrandingMain","cancelText","onPress","onDone","cancelContainer","color","renderOptions","options","selectedKey","optionsContainer","optionsTitle","o","selected","backgroundColor","onSelectOption","optionContainer","borderColor","optionText","render","visible","transparent","animationType","onRequestClose","container","menu","optionContent","position","bottom","left","right","top","zIndex","borderTopLeftRadius","borderTopRightRadius","paddingVertical","LINEGREY","borderTopWidth","paddingHorizontal","fontFamily","fontSize","textAlign","TEXT_DARK","padding","borderBottomWidth","marginHorizontal","marginBottom","flex","flexDirection","flexWrap","alignItems","justifyContent","minWidth","height","borderRadius","borderWidth","marginRight","mapStateToProps","user","getMainBrandingColourFromState"],"sources":["FilterPopupMenu.js"],"sourcesContent":["import React, { Component } from 'react';\nimport { View, Text, TouchableOpacity, Modal } from 'react-native';\nimport { connect } from 'react-redux';\nimport _ from 'lodash';\nimport { generalActions } from '../apis';\nimport { Colours, Helper } from '../core.config';\n\nclass FilterPopupMenu extends Component {\n constructor(props) {\n super(props);\n\n this.state = {\n types: props.types || [],\n selectedStatus: props.status || '',\n selectedType: props.type || '',\n };\n this.statusOptions = [\n {\n label: 'All',\n value: '',\n },\n {\n label: 'Incomplete',\n value: 'Unassigned|In Progress',\n },\n {\n label: 'Unassigned',\n value: 'Unassigned',\n },\n {\n label: 'In Progress',\n value: 'In Progress',\n },\n {\n label: 'Completed',\n value: 'Completed',\n },\n ];\n }\n\n componentDidMount() {\n if (_.isEmpty(this.state.types)) this.refreshTypes();\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.site !== this.props.site) {\n this.refreshTypes();\n }\n }\n\n refreshTypes = async () => {\n const { data } = await generalActions.getJobTypes(Helper.getSite(this.props.site));\n const types = data.map(t => {\n return { label: t.typeName, value: t.typeName };\n });\n types.splice(0, 0, { label: 'All', value: '' });\n // console.log('refreshTypes', types);\n this.setState({ types });\n };\n\n onSelectOption = (key, value) => {\n const newState = {};\n newState[key] = value;\n this.setState(newState);\n };\n\n onDone = () => {\n const { onClose } = this.props;\n const { selectedStatus, selectedType } = this.state;\n if (onClose)\n onClose({\n status: selectedStatus,\n type: selectedType,\n });\n };\n\n renderTitle() {\n const { title } = this.props;\n return (\n <View style={styles.titleContainer}>\n <Text style={styles.titleText}>{title || 'Filter By'}</Text>\n </View>\n );\n }\n\n renderCancel() {\n const { colourBrandingMain, cancelText } = this.props;\n return (\n <TouchableOpacity onPress={this.onDone}>\n <View style={styles.cancelContainer}>\n <Text style={[styles.cancelText, { color: colourBrandingMain }]}>{cancelText || 'Done'}</Text>\n </View>\n </TouchableOpacity>\n );\n }\n\n renderOptions(title, options, selectedKey) {\n const { colourBrandingMain } = this.props;\n return (\n <View style={styles.optionsContainer}>\n <Text style={styles.optionsTitle}>{title}</Text>\n <View style={styles.options}>\n {options.map(o => {\n const selected = this.state[selectedKey];\n const backgroundColor = o.value === selected ? colourBrandingMain : '#fff';\n const color = o.value === selected ? '#fff' : colourBrandingMain;\n return (\n <TouchableOpacity key={o.label} onPress={() => this.onSelectOption(selectedKey, o.value)}>\n <View style={[styles.optionContainer, { backgroundColor, borderColor: colourBrandingMain }]}>\n <Text style={[styles.optionText, { color }]}>{o.label}</Text>\n </View>\n </TouchableOpacity>\n );\n })}\n </View>\n </View>\n );\n }\n\n render() {\n return (\n <Modal visible transparent animationType=\"slide\" onRequestClose={this.onDone}>\n <View style={styles.container}>\n <View style={styles.menu}>\n {this.renderTitle()}\n <View style={styles.optionContent}>\n {this.renderOptions('Status', this.statusOptions, 'selectedStatus')}\n {this.renderOptions('Type', this.state.types, 'selectedType')}\n </View>\n {this.renderCancel()}\n </View>\n </View>\n </Modal>\n );\n }\n}\n\nconst styles = {\n container: {\n position: 'absolute',\n bottom: 0,\n left: 0,\n right: 0,\n top: 0,\n backgroundColor: 'rgba(0,0,0,0.5)',\n zIndex: 1000,\n },\n menu: {\n position: 'absolute',\n bottom: 0,\n left: 0,\n right: 0,\n backgroundColor: '#fff',\n borderTopLeftRadius: 12,\n borderTopRightRadius: 12,\n },\n cancelContainer: {\n paddingVertical: 16,\n borderColor: Colours.LINEGREY,\n borderTopWidth: 1,\n paddingHorizontal: 16,\n },\n cancelText: {\n fontFamily: 'sf-medium',\n fontSize: 16,\n textAlign: 'center',\n color: Colours.TEXT_DARK,\n },\n titleContainer: {\n padding: 16,\n borderColor: Colours.LINEGREY,\n borderBottomWidth: 1,\n },\n titleText: {\n fontFamily: 'sf-semibold',\n fontSize: 16,\n textAlign: 'center',\n color: Colours.TEXT_DARK,\n },\n optionContent: {\n paddingVertical: 10,\n },\n optionsContainer: {\n marginHorizontal: 14,\n },\n optionsTitle: {\n fontFamily: 'sf-semibold',\n marginBottom: 4,\n },\n options: {\n flex: 1,\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n optionContainer: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n minWidth: 50,\n height: 30,\n paddingHorizontal: 8,\n borderRadius: 4,\n borderWidth: 1,\n marginRight: 8,\n marginBottom: 8,\n },\n optionText: {\n color: '#fff',\n textAlign: 'center',\n fontFamily: 'sf-semibold',\n fontSize: 13,\n },\n};\n\nconst mapStateToProps = state => {\n const { user } = state;\n\n return {\n site: user.site,\n colourBrandingMain: Colours.getMainBrandingColourFromState(state),\n };\n};\n\nexport default connect(mapStateToProps, {})(FilterPopupMenu);\n"],"mappings":";;;AAAA,OAAOA,KAAK,IAAIC,SAAS,QAAQ,OAAO;AACxC,SAASC,IAAI,EAAEC,IAAI,EAAEC,gBAAgB,EAAEC,KAAK,QAAQ,cAAc;AAClE,SAASC,OAAO,QAAQ,aAAa;AACrC,OAAOC,CAAC,MAAM,QAAQ;AACtB,SAASC,cAAc,QAAQ,SAAS;AACxC,SAASC,OAAO,EAAEC,MAAM,QAAQ,gBAAgB;AAEhD,MAAMC,eAAe,SAASV,SAAS,CAAC;EACtCW,WAAWA,CAACC,KAAK,EAAE;IACjB,KAAK,CAACA,KAAK,CAAC;IAACC,eAAA,uBAyCA,YAAY;MACzB,MAAM;QAAEC;MAAK,CAAC,GAAG,MAAMP,cAAc,CAACQ,WAAW,CAACN,MAAM,CAACO,OAAO,CAAC,IAAI,CAACJ,KAAK,CAACK,IAAI,CAAC,CAAC;MAClF,MAAMC,KAAK,GAAGJ,IAAI,CAACK,GAAG,CAACC,CAAC,IAAI;QAC1B,OAAO;UAAEC,KAAK,EAAED,CAAC,CAACE,QAAQ;UAAEC,KAAK,EAAEH,CAAC,CAACE;QAAS,CAAC;MACjD,CAAC,CAAC;MACFJ,KAAK,CAACM,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE;QAAEH,KAAK,EAAE,KAAK;QAAEE,KAAK,EAAE;MAAG,CAAC,CAAC;MAC/C;MACA,IAAI,CAACE,QAAQ,CAAC;QAAEP;MAAM,CAAC,CAAC;IAC1B,CAAC;IAAAL,eAAA,yBAEgB,CAACa,GAAG,EAAEH,KAAK,KAAK;MAC/B,MAAMI,QAAQ,GAAG,CAAC,CAAC;MACnBA,QAAQ,CAACD,GAAG,CAAC,GAAGH,KAAK;MACrB,IAAI,CAACE,QAAQ,CAACE,QAAQ,CAAC;IACzB,CAAC;IAAAd,eAAA,iBAEQ,MAAM;MACb,MAAM;QAAEe;MAAQ,CAAC,GAAG,IAAI,CAAChB,KAAK;MAC9B,MAAM;QAAEiB,cAAc;QAAEC;MAAa,CAAC,GAAG,IAAI,CAACC,KAAK;MACnD,IAAIH,OAAO,EACTA,OAAO,CAAC;QACNI,MAAM,EAAEH,cAAc;QACtBI,IAAI,EAAEH;MACR,CAAC,CAAC;IACN,CAAC;IA/DC,IAAI,CAACC,KAAK,GAAG;MACXb,KAAK,EAAEN,KAAK,CAACM,KAAK,IAAI,EAAE;MACxBW,cAAc,EAAEjB,KAAK,CAACoB,MAAM,IAAI,EAAE;MAClCF,YAAY,EAAElB,KAAK,CAACqB,IAAI,IAAI;IAC9B,CAAC;IACD,IAAI,CAACC,aAAa,GAAG,CACnB;MACEb,KAAK,EAAE,KAAK;MACZE,KAAK,EAAE;IACT,CAAC,EACD;MACEF,KAAK,EAAE,YAAY;MACnBE,KAAK,EAAE;IACT,CAAC,EACD;MACEF,KAAK,EAAE,YAAY;MACnBE,KAAK,EAAE;IACT,CAAC,EACD;MACEF,KAAK,EAAE,aAAa;MACpBE,KAAK,EAAE;IACT,CAAC,EACD;MACEF,KAAK,EAAE,WAAW;MAClBE,KAAK,EAAE;IACT,CAAC,CACF;EACH;EAEAY,iBAAiBA,CAAA,EAAG;IAClB,IAAI7B,CAAC,CAAC8B,OAAO,CAAC,IAAI,CAACL,KAAK,CAACb,KAAK,CAAC,EAAE,IAAI,CAACmB,YAAY,CAAC,CAAC;EACtD;EAEAC,kBAAkBA,CAACC,SAAS,EAAE;IAC5B,IAAIA,SAAS,CAACtB,IAAI,KAAK,IAAI,CAACL,KAAK,CAACK,IAAI,EAAE;MACtC,IAAI,CAACoB,YAAY,CAAC,CAAC;IACrB;EACF;EA4BAG,WAAWA,CAAA,EAAG;IACZ,MAAM;MAAEC;IAAM,CAAC,GAAG,IAAI,CAAC7B,KAAK;IAC5B,oBACEb,KAAA,CAAA2C,aAAA,CAACzC,IAAI;MAAC0C,KAAK,EAAEC,MAAM,CAACC;IAAe,gBACjC9C,KAAA,CAAA2C,aAAA,CAACxC,IAAI;MAACyC,KAAK,EAAEC,MAAM,CAACE;IAAU,GAAEL,KAAK,IAAI,WAAkB,CACvD,CAAC;EAEX;EAEAM,YAAYA,CAAA,EAAG;IACb,MAAM;MAAEC,kBAAkB;MAAEC;IAAW,CAAC,GAAG,IAAI,CAACrC,KAAK;IACrD,oBACEb,KAAA,CAAA2C,aAAA,CAACvC,gBAAgB;MAAC+C,OAAO,EAAE,IAAI,CAACC;IAAO,gBACrCpD,KAAA,CAAA2C,aAAA,CAACzC,IAAI;MAAC0C,KAAK,EAAEC,MAAM,CAACQ;IAAgB,gBAClCrD,KAAA,CAAA2C,aAAA,CAACxC,IAAI;MAACyC,KAAK,EAAE,CAACC,MAAM,CAACK,UAAU,EAAE;QAAEI,KAAK,EAAEL;MAAmB,CAAC;IAAE,GAAEC,UAAU,IAAI,MAAa,CACzF,CACU,CAAC;EAEvB;EAEAK,aAAaA,CAACb,KAAK,EAAEc,OAAO,EAAEC,WAAW,EAAE;IACzC,MAAM;MAAER;IAAmB,CAAC,GAAG,IAAI,CAACpC,KAAK;IACzC,oBACEb,KAAA,CAAA2C,aAAA,CAACzC,IAAI;MAAC0C,KAAK,EAAEC,MAAM,CAACa;IAAiB,gBACnC1D,KAAA,CAAA2C,aAAA,CAACxC,IAAI;MAACyC,KAAK,EAAEC,MAAM,CAACc;IAAa,GAAEjB,KAAY,CAAC,eAChD1C,KAAA,CAAA2C,aAAA,CAACzC,IAAI;MAAC0C,KAAK,EAAEC,MAAM,CAACW;IAAQ,GACzBA,OAAO,CAACpC,GAAG,CAACwC,CAAC,IAAI;MAChB,MAAMC,QAAQ,GAAG,IAAI,CAAC7B,KAAK,CAACyB,WAAW,CAAC;MACxC,MAAMK,eAAe,GAAGF,CAAC,CAACpC,KAAK,KAAKqC,QAAQ,GAAGZ,kBAAkB,GAAG,MAAM;MAC1E,MAAMK,KAAK,GAAGM,CAAC,CAACpC,KAAK,KAAKqC,QAAQ,GAAG,MAAM,GAAGZ,kBAAkB;MAChE,oBACEjD,KAAA,CAAA2C,aAAA,CAACvC,gBAAgB;QAACuB,GAAG,EAAEiC,CAAC,CAACtC,KAAM;QAAC6B,OAAO,EAAEA,CAAA,KAAM,IAAI,CAACY,cAAc,CAACN,WAAW,EAAEG,CAAC,CAACpC,KAAK;MAAE,gBACvFxB,KAAA,CAAA2C,aAAA,CAACzC,IAAI;QAAC0C,KAAK,EAAE,CAACC,MAAM,CAACmB,eAAe,EAAE;UAAEF,eAAe;UAAEG,WAAW,EAAEhB;QAAmB,CAAC;MAAE,gBAC1FjD,KAAA,CAAA2C,aAAA,CAACxC,IAAI;QAACyC,KAAK,EAAE,CAACC,MAAM,CAACqB,UAAU,EAAE;UAAEZ;QAAM,CAAC;MAAE,GAAEM,CAAC,CAACtC,KAAY,CACxD,CACU,CAAC;IAEvB,CAAC,CACG,CACF,CAAC;EAEX;EAEA6C,MAAMA,CAAA,EAAG;IACP,oBACEnE,KAAA,CAAA2C,aAAA,CAACtC,KAAK;MAAC+D,OAAO;MAACC,WAAW;MAACC,aAAa,EAAC,OAAO;MAACC,cAAc,EAAE,IAAI,CAACnB;IAAO,gBAC3EpD,KAAA,CAAA2C,aAAA,CAACzC,IAAI;MAAC0C,KAAK,EAAEC,MAAM,CAAC2B;IAAU,gBAC5BxE,KAAA,CAAA2C,aAAA,CAACzC,IAAI;MAAC0C,KAAK,EAAEC,MAAM,CAAC4B;IAAK,GACtB,IAAI,CAAChC,WAAW,CAAC,CAAC,eACnBzC,KAAA,CAAA2C,aAAA,CAACzC,IAAI;MAAC0C,KAAK,EAAEC,MAAM,CAAC6B;IAAc,GAC/B,IAAI,CAACnB,aAAa,CAAC,QAAQ,EAAE,IAAI,CAACpB,aAAa,EAAE,gBAAgB,CAAC,EAClE,IAAI,CAACoB,aAAa,CAAC,MAAM,EAAE,IAAI,CAACvB,KAAK,CAACb,KAAK,EAAE,cAAc,CACxD,CAAC,EACN,IAAI,CAAC6B,YAAY,CAAC,CACf,CACF,CACD,CAAC;EAEZ;AACF;AAEA,MAAMH,MAAM,GAAG;EACb2B,SAAS,EAAE;IACTG,QAAQ,EAAE,UAAU;IACpBC,MAAM,EAAE,CAAC;IACTC,IAAI,EAAE,CAAC;IACPC,KAAK,EAAE,CAAC;IACRC,GAAG,EAAE,CAAC;IACNjB,eAAe,EAAE,iBAAiB;IAClCkB,MAAM,EAAE;EACV,CAAC;EACDP,IAAI,EAAE;IACJE,QAAQ,EAAE,UAAU;IACpBC,MAAM,EAAE,CAAC;IACTC,IAAI,EAAE,CAAC;IACPC,KAAK,EAAE,CAAC;IACRhB,eAAe,EAAE,MAAM;IACvBmB,mBAAmB,EAAE,EAAE;IACvBC,oBAAoB,EAAE;EACxB,CAAC;EACD7B,eAAe,EAAE;IACf8B,eAAe,EAAE,EAAE;IACnBlB,WAAW,EAAExD,OAAO,CAAC2E,QAAQ;IAC7BC,cAAc,EAAE,CAAC;IACjBC,iBAAiB,EAAE;EACrB,CAAC;EACDpC,UAAU,EAAE;IACVqC,UAAU,EAAE,WAAW;IACvBC,QAAQ,EAAE,EAAE;IACZC,SAAS,EAAE,QAAQ;IACnBnC,KAAK,EAAE7C,OAAO,CAACiF;EACjB,CAAC;EACD5C,cAAc,EAAE;IACd6C,OAAO,EAAE,EAAE;IACX1B,WAAW,EAAExD,OAAO,CAAC2E,QAAQ;IAC7BQ,iBAAiB,EAAE;EACrB,CAAC;EACD7C,SAAS,EAAE;IACTwC,UAAU,EAAE,aAAa;IACzBC,QAAQ,EAAE,EAAE;IACZC,SAAS,EAAE,QAAQ;IACnBnC,KAAK,EAAE7C,OAAO,CAACiF;EACjB,CAAC;EACDhB,aAAa,EAAE;IACbS,eAAe,EAAE;EACnB,CAAC;EACDzB,gBAAgB,EAAE;IAChBmC,gBAAgB,EAAE;EACpB,CAAC;EACDlC,YAAY,EAAE;IACZ4B,UAAU,EAAE,aAAa;IACzBO,YAAY,EAAE;EAChB,CAAC;EACDtC,OAAO,EAAE;IACPuC,IAAI,EAAE,CAAC;IACPC,aAAa,EAAE,KAAK;IACpBC,QAAQ,EAAE;EACZ,CAAC;EACDjC,eAAe,EAAE;IACfgC,aAAa,EAAE,KAAK;IACpBE,UAAU,EAAE,QAAQ;IACpBC,cAAc,EAAE,QAAQ;IACxBC,QAAQ,EAAE,EAAE;IACZC,MAAM,EAAE,EAAE;IACVf,iBAAiB,EAAE,CAAC;IACpBgB,YAAY,EAAE,CAAC;IACfC,WAAW,EAAE,CAAC;IACdC,WAAW,EAAE,CAAC;IACdV,YAAY,EAAE;EAChB,CAAC;EACD5B,UAAU,EAAE;IACVZ,KAAK,EAAE,MAAM;IACbmC,SAAS,EAAE,QAAQ;IACnBF,UAAU,EAAE,aAAa;IACzBC,QAAQ,EAAE;EACZ;AACF,CAAC;AAED,MAAMiB,eAAe,GAAGzE,KAAK,IAAI;EAC/B,MAAM;IAAE0E;EAAK,CAAC,GAAG1E,KAAK;EAEtB,OAAO;IACLd,IAAI,EAAEwF,IAAI,CAACxF,IAAI;IACf+B,kBAAkB,EAAExC,OAAO,CAACkG,8BAA8B,CAAC3E,KAAK;EAClE,CAAC;AACH,CAAC;AAED,eAAe1B,OAAO,CAACmG,eAAe,EAAE,CAAC,CAAC,CAAC,CAAC9F,eAAe,CAAC","ignoreList":[]}
@@ -1,15 +1,16 @@
1
- function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
2
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
1
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
2
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
3
3
  function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
4
4
  import React, { Component } from 'react';
5
5
  import { View, StyleSheet, FlatList, TouchableOpacity, Text } from 'react-native';
6
6
  import _ from 'lodash';
7
7
  import { connect } from 'react-redux';
8
- import { maintenanceActions } from '../apis';
8
+ import { generalActions } from '../apis';
9
9
  import { jobsLoaded, jobAdded, jobsAdded } from '../actions';
10
10
  import MaintenanceListItem from '../components/MaintenanceListItem';
11
11
  import FilterPopupMenu from './FilterPopupMenu';
12
12
  import { Components, Colours, Config, Helper } from '../core.config';
13
+ import { values } from '../values.config';
13
14
  class MaintenanceList extends Component {
14
15
  constructor(props) {
15
16
  super(props);
@@ -21,8 +22,8 @@ class MaintenanceList extends Component {
21
22
  selectedType
22
23
  } = this.state;
23
24
  // console.log('filters', { selectedStatus, selectedType });
24
- const res = await maintenanceActions.getJobsRecursive(this.props.site, selectedStatus, selectedType);
25
- // console.log('refresh', res?.data);
25
+ const res = await generalActions.getJobsRecursive(this.props.site, selectedStatus, selectedType);
26
+ // console.log('refresh', JSON.stringify(res, null, 2));
26
27
  if (selectedStatus !== this.initialStatus || !_.isEmpty(selectedType)) {
27
28
  this.props.jobsAdded(res);
28
29
  } else {
@@ -38,7 +39,7 @@ class MaintenanceList extends Component {
38
39
  _defineProperty(this, "refreshTypes", async () => {
39
40
  const {
40
41
  data
41
- } = await maintenanceActions.getJobTypes(Helper.getSite(this.props.site));
42
+ } = await generalActions.getJobTypes(Helper.getSite(this.props.site));
42
43
  const types = data.map(t => {
43
44
  return {
44
45
  label: t.typeName,
@@ -58,7 +59,7 @@ class MaintenanceList extends Component {
58
59
  if (this.state.loading) return;
59
60
  this.onLoadingChanged(true, async () => {
60
61
  try {
61
- const job = await maintenanceActions.getJobByJobId(this.props.site, jobId);
62
+ const job = await generalActions.getJobByJobId(this.props.site, jobId);
62
63
  // console.log('fetchJob', job?.data);
63
64
  this.props.jobAdded(job.data);
64
65
  } catch (error) {
@@ -72,8 +73,7 @@ class MaintenanceList extends Component {
72
73
  const {
73
74
  searchText,
74
75
  selectedStatus,
75
- selectedType,
76
- selectedAssignee
76
+ selectedType
77
77
  } = this.state;
78
78
  const {
79
79
  jobs
@@ -92,7 +92,6 @@ class MaintenanceList extends Component {
92
92
  }
93
93
  if (selectedStatus) filteredList = filteredList.filter(j => selectedStatus.includes(j.status));
94
94
  if (selectedType) filteredList = filteredList.filter(j => selectedType.includes(j.type));
95
- if (selectedAssignee) filteredList = filteredList.filter(j => selectedAssignee.includes(j.AssigneeId));
96
95
  if (jobIdMatch) {
97
96
  const jobIndex = filteredList.indexOf(jobIdMatch);
98
97
  if (jobIndex > -1) {
@@ -131,40 +130,13 @@ class MaintenanceList extends Component {
131
130
  _defineProperty(this, "onSelectFilter", selected => {
132
131
  this.setState({
133
132
  selectedStatus: selected.status,
134
- selectedStatusText: selected.statusText,
135
- selectedType: selected.type,
136
- selectedAssignee: selected.assignee,
137
- selectedAssigneeName: selected.assigneeName
133
+ selectedType: selected.type
138
134
  }, () => {
139
135
  this.resetDataSource();
140
136
  this.onToggleFilter();
141
137
  });
142
138
  });
143
- _defineProperty(this, "getFilterButtonText", () => {
144
- const {
145
- selectedStatus,
146
- selectedStatusText,
147
- selectedType,
148
- selectedAssignee,
149
- selectedAssigneeName
150
- } = this.state;
151
- const filterTexts = [];
152
- if (!_.isEmpty(selectedStatus)) {
153
- filterTexts.push(selectedStatusText);
154
- }
155
- if (!_.isEmpty(selectedType)) {
156
- filterTexts.push(selectedType);
157
- }
158
- if (!_.isEmpty(selectedAssignee)) {
159
- filterTexts.push(selectedAssigneeName);
160
- }
161
- if (_.isEmpty(filterTexts)) {
162
- return 'Filter';
163
- }
164
- return `Filtering by ${filterTexts.join(', ')}`;
165
- });
166
139
  this.initialStatus = props.hasPermission ? 'Unassigned|In Progress' : '';
167
- this.initialStatusText = props.hasPermission ? 'Incomplete' : '';
168
140
  this.state = {
169
141
  types: [],
170
142
  filteredList: props.jobs,
@@ -172,10 +144,7 @@ class MaintenanceList extends Component {
172
144
  searchText: '',
173
145
  showFilterPopup: false,
174
146
  selectedStatus: this.initialStatus,
175
- selectedStatusText: this.initialStatusText,
176
- selectedType: '',
177
- selectedAssignee: '',
178
- selectedAssigneeName: ''
147
+ selectedType: ''
179
148
  };
180
149
  }
181
150
  componentDidMount() {
@@ -210,7 +179,7 @@ class MaintenanceList extends Component {
210
179
  style: [styles.filterButtonText, {
211
180
  color: this.props.colourBrandingMain
212
181
  }]
213
- }, this.getFilterButtonText())));
182
+ }, "Filter")));
214
183
  }
215
184
  renderSearch() {
216
185
  if (!this.props.hasPermission) return null;
@@ -234,7 +203,7 @@ class MaintenanceList extends Component {
234
203
  } = this.props;
235
204
  return /*#__PURE__*/React.createElement(View, null, ListHeaderComponent ? ListHeaderComponent : /*#__PURE__*/React.createElement(View, {
236
205
  style: {
237
- height: 8
206
+ height: 32
238
207
  }
239
208
  }), this.renderFilterButton(), this.renderSearch());
240
209
  }
@@ -267,15 +236,13 @@ class MaintenanceList extends Component {
267
236
  showFilterPopup,
268
237
  types,
269
238
  selectedStatus,
270
- selectedType,
271
- selectedAssignee
239
+ selectedType
272
240
  } = this.state;
273
241
  if (!showFilterPopup) return null;
274
242
  return /*#__PURE__*/React.createElement(FilterPopupMenu, {
275
243
  site: this.props.site,
276
244
  types: types,
277
245
  status: selectedStatus,
278
- assignee: selectedAssignee,
279
246
  type: selectedType,
280
247
  onClose: this.onSelectFilter
281
248
  });
@@ -323,9 +290,9 @@ const styles = StyleSheet.create({
323
290
  paddingHorizontal: 16
324
291
  },
325
292
  filterButton: {
326
- paddingBottom: 8,
327
- paddingHorizontal: 16,
328
- flexDirection: 'row-reverse'
293
+ position: 'absolute',
294
+ right: 20,
295
+ top: -32
329
296
  },
330
297
  filterButtonText: {
331
298
  fontFamily: 'sf-semibold',
@@ -335,9 +302,9 @@ const styles = StyleSheet.create({
335
302
  const mapStateToProps = state => {
336
303
  const {
337
304
  user,
338
- jobs,
339
305
  notifications
340
306
  } = state;
307
+ const jobs = state[values.reducerKey];
341
308
  const jobsOrdered = _.orderBy(jobs.jobs, ['createdUnix'], ['desc']);
342
309
  const hasPermission = _.includes(user.permissions, 'maintenanceTracking');
343
310
  return {
@@ -346,7 +313,7 @@ const mapStateToProps = state => {
346
313
  site: user.site,
347
314
  userCategory: user.category,
348
315
  colourBrandingMain: Colours.getMainBrandingColourFromState(state),
349
- dataUpdated: notifications.dataUpdated['jobs']
316
+ dataUpdated: notifications.dataUpdated[values.updateKey]
350
317
  };
351
318
  };
352
319
  export default connect(mapStateToProps, {