@plusscommunities/pluss-maintenance-app 6.0.19 → 6.0.21-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.
- package/dist/module/actions/JobActions.js +4 -4
- package/dist/module/actions/JobActions.js.map +1 -1
- package/dist/module/actions/index.js +1 -1
- package/dist/module/actions/index.js.map +1 -1
- package/dist/module/actions/types.js +1 -1
- package/dist/module/actions/types.js.map +1 -1
- package/dist/module/apis/index.js +3 -3
- package/dist/module/apis/index.js.map +1 -1
- package/dist/module/apis/maintenanceActions.js +36 -36
- package/dist/module/apis/maintenanceActions.js.map +1 -1
- package/dist/module/apis/userActions.js +5 -5
- package/dist/module/apis/userActions.js.map +1 -1
- package/dist/module/components/FilterPopupMenu.js +49 -49
- package/dist/module/components/FilterPopupMenu.js.map +1 -1
- package/dist/module/components/MaintenanceList.js +38 -38
- package/dist/module/components/MaintenanceList.js.map +1 -1
- package/dist/module/components/MaintenanceListItem.js +62 -62
- package/dist/module/components/MaintenanceListItem.js.map +1 -1
- package/dist/module/components/MaintenanceWidgetItem.js +27 -27
- package/dist/module/components/MaintenanceWidgetItem.js.map +1 -1
- package/dist/module/components/PrioritySelectorPopup.js +15 -15
- package/dist/module/components/PrioritySelectorPopup.js.map +1 -1
- package/dist/module/components/StatusSelectorPopup.js +16 -16
- package/dist/module/components/StatusSelectorPopup.js.map +1 -1
- package/dist/module/components/WidgetLarge.js +2 -2
- package/dist/module/components/WidgetLarge.js.map +1 -1
- package/dist/module/components/WidgetSmall.js +19 -19
- package/dist/module/components/WidgetSmall.js.map +1 -1
- package/dist/module/core.config.js +1 -1
- package/dist/module/core.config.js.map +1 -1
- package/dist/module/feature.config.js +17 -17
- package/dist/module/feature.config.js.map +1 -1
- package/dist/module/helper.js +10 -10
- package/dist/module/helper.js.map +1 -1
- package/dist/module/index.js +11 -11
- package/dist/module/index.js.map +1 -1
- package/dist/module/reducers/JobsReducer.js +13 -13
- package/dist/module/reducers/JobsReducer.js.map +1 -1
- package/dist/module/screens/JobTypePicker.js +17 -17
- package/dist/module/screens/JobTypePicker.js.map +1 -1
- package/dist/module/screens/MaintenancePage.js +10 -10
- package/dist/module/screens/MaintenancePage.js.map +1 -1
- package/dist/module/screens/MaintenanceUserPicker.js +129 -22
- package/dist/module/screens/MaintenanceUserPicker.js.map +1 -1
- package/dist/module/screens/RequestDetail.js +146 -146
- package/dist/module/screens/RequestDetail.js.map +1 -1
- package/dist/module/screens/RequestNotes.js +59 -59
- package/dist/module/screens/RequestNotes.js.map +1 -1
- package/dist/module/screens/ServiceRequest.js +187 -187
- package/dist/module/screens/ServiceRequest.js.map +1 -1
- package/dist/module/values.config.a.js +30 -30
- package/dist/module/values.config.a.js.map +1 -1
- package/dist/module/values.config.default.js +34 -34
- package/dist/module/values.config.default.js.map +1 -1
- package/dist/module/values.config.enquiry.js +34 -34
- package/dist/module/values.config.enquiry.js.map +1 -1
- package/dist/module/values.config.feedback.js +34 -34
- package/dist/module/values.config.feedback.js.map +1 -1
- package/dist/module/values.config.food.js +34 -34
- package/dist/module/values.config.food.js.map +1 -1
- package/dist/module/values.config.forms.js +34 -34
- package/dist/module/values.config.forms.js.map +1 -1
- package/dist/module/values.config.js +34 -34
- package/dist/module/values.config.js.map +1 -1
- package/package.json +51 -51
- package/src/actions/JobActions.js +67 -60
- package/src/actions/index.js +1 -1
- package/src/actions/types.js +1 -2
- package/src/apis/index.js +3 -3
- package/src/apis/maintenanceActions.js +189 -178
- package/src/apis/userActions.js +17 -17
- package/src/components/FilterPopupMenu.js +313 -256
- package/src/components/MaintenanceList.js +396 -317
- package/src/components/MaintenanceListItem.js +347 -288
- package/src/components/MaintenanceWidgetItem.js +145 -124
- package/src/components/PrioritySelectorPopup.js +81 -68
- package/src/components/StatusSelectorPopup.js +81 -70
- package/src/components/WidgetLarge.js +5 -5
- package/src/components/WidgetSmall.js +153 -133
- package/src/core.config.js +27 -3
- package/src/feature.config.js +62 -62
- package/src/helper.js +58 -53
- package/src/index.js +22 -22
- package/src/reducers/JobsReducer.js +85 -66
- package/src/screens/JobTypePicker.js +115 -92
- package/src/screens/MaintenancePage.js +89 -80
- package/src/screens/MaintenanceUserPicker.js +252 -100
- package/src/screens/RequestDetail.js +1348 -1125
- package/src/screens/RequestNotes.js +950 -806
- package/src/screens/ServiceRequest.js +1778 -1550
- package/src/values.config.a.js +33 -33
- package/src/values.config.default.js +39 -39
- package/src/values.config.enquiry.js +39 -39
- package/src/values.config.feedback.js +39 -39
- package/src/values.config.food.js +39 -39
- package/src/values.config.forms.js +39 -39
- package/src/values.config.js +39 -39
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_","REHYDRATE","JOBS_LOADED","JOB_ADDED","JOBS_ADDED","JOBS_STATUSES_LOADED","JOBS_HIDE_SEEN","JOB_FILTER_LOADED","ActionTypes","values","REDUCER_KEY","reducerKey","INITIAL_STATE","jobs","jobstatuses","hideSeen","jobfilters","status","statusText","priority","priorityText","type","assignee","assigneeName","state","action","updateJobs","index","LOGOUT","CHANGE_ROLE","payload","map","job","title","description","unionWith","j1","j2","id","findIndex","item","push","orderBy","v1","v2","text"],"sources":["JobsReducer.js"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport _ from
|
|
1
|
+
{"version":3,"names":["_","REHYDRATE","JOBS_LOADED","JOB_ADDED","JOBS_ADDED","JOBS_STATUSES_LOADED","JOBS_HIDE_SEEN","JOB_FILTER_LOADED","ActionTypes","values","REDUCER_KEY","reducerKey","INITIAL_STATE","jobs","jobstatuses","hideSeen","jobfilters","status","statusText","priority","priorityText","type","assignee","assigneeName","state","action","updateJobs","index","LOGOUT","CHANGE_ROLE","payload","map","job","title","description","unionWith","j1","j2","id","findIndex","item","push","orderBy","v1","v2","text"],"sources":["JobsReducer.js"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport _ from \"lodash\";\nimport { REHYDRATE } from \"redux-persist\";\nimport {\n\tJOBS_LOADED,\n\tJOB_ADDED,\n\tJOBS_ADDED,\n\tJOBS_STATUSES_LOADED,\n\tJOBS_HIDE_SEEN,\n\tJOB_FILTER_LOADED,\n} from \"../actions/types\";\nimport { ActionTypes } from \"../core.config\";\nimport { values } from \"../values.config\";\n\nconst REDUCER_KEY = values.reducerKey;\n\nconst INITIAL_STATE = {\n\tjobs: [],\n\tjobstatuses: [],\n\thideSeen: false,\n\tjobfilters: {\n\t\tstatus: \"\",\n\t\tstatusText: \"\",\n\t\tpriority: \"\",\n\t\tpriorityText: \"\",\n\t\ttype: \"\",\n\t\tassignee: \"\",\n\t\tassigneeName: \"\",\n\t},\n};\n\nexport default (state = INITIAL_STATE, action) => {\n\tlet updateJobs = [];\n\tlet index = 0;\n\tlet jobstatuses = [];\n\n\tswitch (action.type) {\n\t\tcase ActionTypes.LOGOUT:\n\t\tcase ActionTypes.CHANGE_ROLE:\n\t\t\treturn INITIAL_STATE;\n\t\tcase JOBS_LOADED:\n\t\t\treturn {\n\t\t\t\t...state,\n\t\t\t\tjobs: action.payload.map((job) => ({\n\t\t\t\t\ttitle: job.title || job.description,\n\t\t\t\t\t...job,\n\t\t\t\t})),\n\t\t\t};\n\t\tcase JOBS_ADDED:\n\t\t\tupdateJobs = action.payload.map((job) => ({\n\t\t\t\ttitle: job.title || job.description,\n\t\t\t\t...job,\n\t\t\t}));\n\t\t\tupdateJobs = _.unionWith(updateJobs, state.jobs, (j1, j2) => {\n\t\t\t\treturn j1.id === j2.id;\n\t\t\t});\n\t\t\treturn { ...state, jobs: updateJobs };\n\t\tcase JOB_ADDED:\n\t\t\tupdateJobs = [...state.jobs];\n\t\t\tindex = updateJobs.findIndex((item) => item.id === action.payload.id);\n\t\t\tif (index > -1) {\n\t\t\t\tupdateJobs[index] = action.payload;\n\t\t\t} else {\n\t\t\t\tupdateJobs.push(action.payload);\n\t\t\t}\n\t\t\treturn { ...state, jobs: updateJobs };\n\t\tcase JOBS_STATUSES_LOADED:\n\t\t\tjobstatuses = _.orderBy(\n\t\t\t\t_.unionWith(action.payload, state.jobstatuses, (v1, v2) => {\n\t\t\t\t\treturn v1 != null && v2 != null && v1.text === v2.text;\n\t\t\t\t}),\n\t\t\t\t\"order\",\n\t\t\t\t\"asc\",\n\t\t\t);\n\t\t\treturn { ...state, jobstatuses };\n\t\tcase JOBS_HIDE_SEEN:\n\t\t\treturn { ...state, hideSeen: action.payload };\n\t\tcase JOB_FILTER_LOADED:\n\t\t\treturn {\n\t\t\t\t...state,\n\t\t\t\tjobfilters: action.payload || INITIAL_STATE.jobfilters,\n\t\t\t};\n\t\tcase REHYDRATE:\n\t\t\tif (!action.payload) return state;\n\t\t\tif (action.payload[REDUCER_KEY]) {\n\t\t\t\tif (action.payload[REDUCER_KEY].jobs == null) {\n\t\t\t\t\taction.payload[REDUCER_KEY].jobs = [];\n\t\t\t\t}\n\t\t\t\treturn action.payload[REDUCER_KEY];\n\t\t\t}\n\t\t\treturn state;\n\t\tdefault:\n\t\t\treturn state;\n\t}\n};\n"],"mappings":"AAAA;AACA,OAAOA,CAAC,MAAM,QAAQ;AACtB,SAASC,SAAS,QAAQ,eAAe;AACzC,SACCC,WAAW,EACXC,SAAS,EACTC,UAAU,EACVC,oBAAoB,EACpBC,cAAc,EACdC,iBAAiB,QACX,kBAAkB;AACzB,SAASC,WAAW,QAAQ,gBAAgB;AAC5C,SAASC,MAAM,QAAQ,kBAAkB;AAEzC,MAAMC,WAAW,GAAGD,MAAM,CAACE,UAAU;AAErC,MAAMC,aAAa,GAAG;EACrBC,IAAI,EAAE,EAAE;EACRC,WAAW,EAAE,EAAE;EACfC,QAAQ,EAAE,KAAK;EACfC,UAAU,EAAE;IACXC,MAAM,EAAE,EAAE;IACVC,UAAU,EAAE,EAAE;IACdC,QAAQ,EAAE,EAAE;IACZC,YAAY,EAAE,EAAE;IAChBC,IAAI,EAAE,EAAE;IACRC,QAAQ,EAAE,EAAE;IACZC,YAAY,EAAE;EACf;AACD,CAAC;AAED,eAAe,CAACC,KAAK,GAAGZ,aAAa,EAAEa,MAAM,KAAK;EACjD,IAAIC,UAAU,GAAG,EAAE;EACnB,IAAIC,KAAK,GAAG,CAAC;EACb,IAAIb,WAAW,GAAG,EAAE;EAEpB,QAAQW,MAAM,CAACJ,IAAI;IAClB,KAAKb,WAAW,CAACoB,MAAM;IACvB,KAAKpB,WAAW,CAACqB,WAAW;MAC3B,OAAOjB,aAAa;IACrB,KAAKV,WAAW;MACf,OAAO;QACN,GAAGsB,KAAK;QACRX,IAAI,EAAEY,MAAM,CAACK,OAAO,CAACC,GAAG,CAAEC,GAAG,KAAM;UAClCC,KAAK,EAAED,GAAG,CAACC,KAAK,IAAID,GAAG,CAACE,WAAW;UACnC,GAAGF;QACJ,CAAC,CAAC;MACH,CAAC;IACF,KAAK5B,UAAU;MACdsB,UAAU,GAAGD,MAAM,CAACK,OAAO,CAACC,GAAG,CAAEC,GAAG,KAAM;QACzCC,KAAK,EAAED,GAAG,CAACC,KAAK,IAAID,GAAG,CAACE,WAAW;QACnC,GAAGF;MACJ,CAAC,CAAC,CAAC;MACHN,UAAU,GAAG1B,CAAC,CAACmC,SAAS,CAACT,UAAU,EAAEF,KAAK,CAACX,IAAI,EAAE,CAACuB,EAAE,EAAEC,EAAE,KAAK;QAC5D,OAAOD,EAAE,CAACE,EAAE,KAAKD,EAAE,CAACC,EAAE;MACvB,CAAC,CAAC;MACF,OAAO;QAAE,GAAGd,KAAK;QAAEX,IAAI,EAAEa;MAAW,CAAC;IACtC,KAAKvB,SAAS;MACbuB,UAAU,GAAG,CAAC,GAAGF,KAAK,CAACX,IAAI,CAAC;MAC5Bc,KAAK,GAAGD,UAAU,CAACa,SAAS,CAAEC,IAAI,IAAKA,IAAI,CAACF,EAAE,KAAKb,MAAM,CAACK,OAAO,CAACQ,EAAE,CAAC;MACrE,IAAIX,KAAK,GAAG,CAAC,CAAC,EAAE;QACfD,UAAU,CAACC,KAAK,CAAC,GAAGF,MAAM,CAACK,OAAO;MACnC,CAAC,MAAM;QACNJ,UAAU,CAACe,IAAI,CAAChB,MAAM,CAACK,OAAO,CAAC;MAChC;MACA,OAAO;QAAE,GAAGN,KAAK;QAAEX,IAAI,EAAEa;MAAW,CAAC;IACtC,KAAKrB,oBAAoB;MACxBS,WAAW,GAAGd,CAAC,CAAC0C,OAAO,CACtB1C,CAAC,CAACmC,SAAS,CAACV,MAAM,CAACK,OAAO,EAAEN,KAAK,CAACV,WAAW,EAAE,CAAC6B,EAAE,EAAEC,EAAE,KAAK;QAC1D,OAAOD,EAAE,IAAI,IAAI,IAAIC,EAAE,IAAI,IAAI,IAAID,EAAE,CAACE,IAAI,KAAKD,EAAE,CAACC,IAAI;MACvD,CAAC,CAAC,EACF,OAAO,EACP,KACD,CAAC;MACD,OAAO;QAAE,GAAGrB,KAAK;QAAEV;MAAY,CAAC;IACjC,KAAKR,cAAc;MAClB,OAAO;QAAE,GAAGkB,KAAK;QAAET,QAAQ,EAAEU,MAAM,CAACK;MAAQ,CAAC;IAC9C,KAAKvB,iBAAiB;MACrB,OAAO;QACN,GAAGiB,KAAK;QACRR,UAAU,EAAES,MAAM,CAACK,OAAO,IAAIlB,aAAa,CAACI;MAC7C,CAAC;IACF,KAAKf,SAAS;MACb,IAAI,CAACwB,MAAM,CAACK,OAAO,EAAE,OAAON,KAAK;MACjC,IAAIC,MAAM,CAACK,OAAO,CAACpB,WAAW,CAAC,EAAE;QAChC,IAAIe,MAAM,CAACK,OAAO,CAACpB,WAAW,CAAC,CAACG,IAAI,IAAI,IAAI,EAAE;UAC7CY,MAAM,CAACK,OAAO,CAACpB,WAAW,CAAC,CAACG,IAAI,GAAG,EAAE;QACtC;QACA,OAAOY,MAAM,CAACK,OAAO,CAACpB,WAAW,CAAC;MACnC;MACA,OAAOc,KAAK;IACb;MACC,OAAOA,KAAK;EACd;AACD,CAAC","ignoreList":[]}
|
|
@@ -1,13 +1,13 @@
|
|
|
1
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
2
|
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : 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
|
-
import React, { Component } from
|
|
5
|
-
import _ from
|
|
6
|
-
import { TouchableOpacity, View, ScrollView, Text } from
|
|
7
|
-
import { connect } from
|
|
8
|
-
import { Icon } from
|
|
9
|
-
import { Services } from
|
|
10
|
-
import { Components, Colours } from
|
|
4
|
+
import React, { Component } from "react";
|
|
5
|
+
import _ from "lodash";
|
|
6
|
+
import { TouchableOpacity, View, ScrollView, Text } from "react-native";
|
|
7
|
+
import { connect } from "react-redux";
|
|
8
|
+
import { Icon } from "react-native-elements";
|
|
9
|
+
import { Services } from "../feature.config";
|
|
10
|
+
import { Components, Colours } from "../core.config";
|
|
11
11
|
class JobTypePicker extends Component {
|
|
12
12
|
constructor(...args) {
|
|
13
13
|
super(...args);
|
|
@@ -69,7 +69,7 @@ class JobTypePicker extends Component {
|
|
|
69
69
|
,
|
|
70
70
|
type: "font-awesome",
|
|
71
71
|
iconStyle: [{
|
|
72
|
-
color:
|
|
72
|
+
color: "#d5d9e0",
|
|
73
73
|
fontSize: 20
|
|
74
74
|
}, rep.typeName === this.state.currentType && {
|
|
75
75
|
color: Colours.COLOUR_GREEN
|
|
@@ -96,33 +96,33 @@ class JobTypePicker extends Component {
|
|
|
96
96
|
const styles = {
|
|
97
97
|
container: {
|
|
98
98
|
flex: 1,
|
|
99
|
-
position:
|
|
100
|
-
backgroundColor:
|
|
99
|
+
position: "relative",
|
|
100
|
+
backgroundColor: "#f0f0f5"
|
|
101
101
|
},
|
|
102
102
|
row: {
|
|
103
|
-
flexDirection:
|
|
104
|
-
alignItems:
|
|
103
|
+
flexDirection: "row",
|
|
104
|
+
alignItems: "center",
|
|
105
105
|
minHeight: 22
|
|
106
106
|
},
|
|
107
107
|
text: {
|
|
108
108
|
flex: 1,
|
|
109
|
-
fontFamily:
|
|
109
|
+
fontFamily: "sf-regular",
|
|
110
110
|
fontSize: 14,
|
|
111
111
|
color: Colours.TEXT_DARK
|
|
112
112
|
},
|
|
113
113
|
labelContainer: {
|
|
114
|
-
flexDirection:
|
|
115
|
-
justifyContent:
|
|
114
|
+
flexDirection: "row",
|
|
115
|
+
justifyContent: "space-between"
|
|
116
116
|
},
|
|
117
117
|
labelText: {
|
|
118
|
-
fontFamily:
|
|
118
|
+
fontFamily: "sf-medium",
|
|
119
119
|
fontSize: 16,
|
|
120
120
|
color: Colours.TEXT_DARK
|
|
121
121
|
},
|
|
122
122
|
description: {
|
|
123
123
|
marginTop: 5,
|
|
124
124
|
fontSize: 14,
|
|
125
|
-
fontFamily:
|
|
125
|
+
fontFamily: "sf-regular",
|
|
126
126
|
color: Colours.TEXT_DARK
|
|
127
127
|
}
|
|
128
128
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","Component","_","TouchableOpacity","View","ScrollView","Text","connect","Icon","Services","Components","Colours","JobTypePicker","constructor","args","_defineProperty","currentType","UNSAFE_componentWillMount","setState","props","onPressBack","navigation","goBack","onTypePress","type","onSelectType","setTimeout","renderMain","isEmpty","types","createElement","style","marginTop","Spinner","FormCard","renderOptions","map","rep","index","key","onPress","bind","typeName","FormCardSection","label","labelStyle","height","margin","hasUnderline","hasContent","styles","labelContainer","labelText","name","iconStyle","color","fontSize","state","COLOUR_GREEN","description","render","container","Header","leftIcon","onPressLeft","text","flex","position","backgroundColor","row","flexDirection","alignItems","minHeight","fontFamily","TEXT_DARK","justifyContent"],"sources":["JobTypePicker.js"],"sourcesContent":["import React, { Component } from
|
|
1
|
+
{"version":3,"names":["React","Component","_","TouchableOpacity","View","ScrollView","Text","connect","Icon","Services","Components","Colours","JobTypePicker","constructor","args","_defineProperty","currentType","UNSAFE_componentWillMount","setState","props","onPressBack","navigation","goBack","onTypePress","type","onSelectType","setTimeout","renderMain","isEmpty","types","createElement","style","marginTop","Spinner","FormCard","renderOptions","map","rep","index","key","onPress","bind","typeName","FormCardSection","label","labelStyle","height","margin","hasUnderline","hasContent","styles","labelContainer","labelText","name","iconStyle","color","fontSize","state","COLOUR_GREEN","description","render","container","Header","leftIcon","onPressLeft","text","flex","position","backgroundColor","row","flexDirection","alignItems","minHeight","fontFamily","TEXT_DARK","justifyContent"],"sources":["JobTypePicker.js"],"sourcesContent":["import React, { Component } from \"react\";\nimport _ from \"lodash\";\nimport { TouchableOpacity, View, ScrollView, Text } from \"react-native\";\nimport { connect } from \"react-redux\";\nimport { Icon } from \"react-native-elements\";\nimport { Services } from \"../feature.config\";\nimport { Components, Colours } from \"../core.config\";\n\nclass JobTypePicker extends Component {\n\tstate = {\n\t\tcurrentType: null,\n\t};\n\n\tUNSAFE_componentWillMount() {\n\t\tthis.setState({ currentType: this.props.currentType });\n\t}\n\n\tonPressBack() {\n\t\tServices.navigation.goBack();\n\t}\n\n\tonTypePress(type) {\n\t\tthis.props.onSelectType(type);\n\t\tthis.setState({ currentType: type });\n\t\tsetTimeout(() => {\n\t\t\tthis.onPressBack();\n\t\t}, 200);\n\t}\n\n\trenderMain() {\n\t\tif (_.isEmpty(this.props.types)) {\n\t\t\treturn (\n\t\t\t\t<View style={{ marginTop: 16 }}>\n\t\t\t\t\t<Components.Spinner />\n\t\t\t\t</View>\n\t\t\t);\n\t\t}\n\n\t\treturn (\n\t\t\t<Components.FormCard style={{ marginTop: 16 }}>\n\t\t\t\t{this.renderOptions()}\n\t\t\t</Components.FormCard>\n\t\t);\n\t}\n\n\trenderOptions() {\n\t\treturn this.props.types.map((rep, index) => {\n\t\t\treturn (\n\t\t\t\t<TouchableOpacity\n\t\t\t\t\tkey={index}\n\t\t\t\t\tonPress={this.onTypePress.bind(this, rep.typeName)}\n\t\t\t\t>\n\t\t\t\t\t<Components.FormCardSection\n\t\t\t\t\t\tlabel={rep.typeName}\n\t\t\t\t\t\tlabelStyle={{ height: 0, margin: 0 }}\n\t\t\t\t\t\thasUnderline\n\t\t\t\t\t\thasContent\n\t\t\t\t\t>\n\t\t\t\t\t\t<View style={styles.labelContainer}>\n\t\t\t\t\t\t\t<Text style={styles.labelText}>{rep.typeName}</Text>\n\t\t\t\t\t\t\t<Icon\n\t\t\t\t\t\t\t\tname=\"check-circle\"\n\t\t\t\t\t\t\t\t//style={styles.uploadButtonInner}\n\t\t\t\t\t\t\t\ttype=\"font-awesome\"\n\t\t\t\t\t\t\t\ticonStyle={[\n\t\t\t\t\t\t\t\t\t{ color: \"#d5d9e0\", fontSize: 20 },\n\t\t\t\t\t\t\t\t\trep.typeName === this.state.currentType && {\n\t\t\t\t\t\t\t\t\t\tcolor: Colours.COLOUR_GREEN,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t]}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</View>\n\t\t\t\t\t\t{!_.isEmpty(rep.description) && (\n\t\t\t\t\t\t\t<Text style={styles.description}>{rep.description}</Text>\n\t\t\t\t\t\t)}\n\t\t\t\t\t</Components.FormCardSection>\n\t\t\t\t</TouchableOpacity>\n\t\t\t);\n\t\t});\n\t}\n\n\trender() {\n\t\treturn (\n\t\t\t<View style={styles.container}>\n\t\t\t\t<Components.Header\n\t\t\t\t\tleftIcon=\"angle-left\"\n\t\t\t\t\tonPressLeft={this.onPressBack.bind(this)}\n\t\t\t\t\ttext=\"Select type\"\n\t\t\t\t/>\n\t\t\t\t<ScrollView style={{ flex: 1 }}>{this.renderMain()}</ScrollView>\n\t\t\t</View>\n\t\t);\n\t}\n}\n\nconst styles = {\n\tcontainer: {\n\t\tflex: 1,\n\t\tposition: \"relative\",\n\t\tbackgroundColor: \"#f0f0f5\",\n\t},\n\trow: {\n\t\tflexDirection: \"row\",\n\t\talignItems: \"center\",\n\t\tminHeight: 22,\n\t},\n\ttext: {\n\t\tflex: 1,\n\t\tfontFamily: \"sf-regular\",\n\t\tfontSize: 14,\n\t\tcolor: Colours.TEXT_DARK,\n\t},\n\tlabelContainer: {\n\t\tflexDirection: \"row\",\n\t\tjustifyContent: \"space-between\",\n\t},\n\tlabelText: {\n\t\tfontFamily: \"sf-medium\",\n\t\tfontSize: 16,\n\t\tcolor: Colours.TEXT_DARK,\n\t},\n\tdescription: {\n\t\tmarginTop: 5,\n\t\tfontSize: 14,\n\t\tfontFamily: \"sf-regular\",\n\t\tcolor: Colours.TEXT_DARK,\n\t},\n};\n\nexport default connect(null, {})(JobTypePicker);\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,14 +1,14 @@
|
|
|
1
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
2
|
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : 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
|
-
import React, { Component } from
|
|
5
|
-
import { View, StyleSheet } from
|
|
6
|
-
import { connect } from
|
|
7
|
-
import _ from
|
|
8
|
-
import MaintenanceList from
|
|
9
|
-
import { Services, BaseComponents } from
|
|
10
|
-
import { Components, Helper, Styles, Config } from
|
|
11
|
-
import { values } from
|
|
4
|
+
import React, { Component } from "react";
|
|
5
|
+
import { View, StyleSheet } from "react-native";
|
|
6
|
+
import { connect } from "react-redux";
|
|
7
|
+
import _ from "lodash";
|
|
8
|
+
import MaintenanceList from "../components/MaintenanceList";
|
|
9
|
+
import { Services, BaseComponents } from "../feature.config";
|
|
10
|
+
import { Components, Helper, Styles, Config } from "../core.config";
|
|
11
|
+
import { values } from "../values.config";
|
|
12
12
|
class MaintenancePage extends Component {
|
|
13
13
|
constructor(props) {
|
|
14
14
|
super(props);
|
|
@@ -36,7 +36,7 @@ class MaintenancePage extends Component {
|
|
|
36
36
|
if (this.state.isHomeTab) {
|
|
37
37
|
return /*#__PURE__*/React.createElement(Components.Header, {
|
|
38
38
|
text: title,
|
|
39
|
-
rightContent: _.includes(this.props.user.hidden,
|
|
39
|
+
rightContent: _.includes(this.props.user.hidden, "notifications") ? null : /*#__PURE__*/React.createElement(View, {
|
|
40
40
|
style: styles.notificationContainer
|
|
41
41
|
}, /*#__PURE__*/React.createElement(BaseComponents.NotificationBell, {
|
|
42
42
|
colourBrandingHeader: this.props.colourBrandingHeader,
|
|
@@ -71,7 +71,7 @@ const styles = StyleSheet.create({
|
|
|
71
71
|
flex: 1
|
|
72
72
|
},
|
|
73
73
|
notificationContainer: {
|
|
74
|
-
position:
|
|
74
|
+
position: "absolute",
|
|
75
75
|
top: 0,
|
|
76
76
|
bottom: 0,
|
|
77
77
|
right: 0,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","Component","View","StyleSheet","connect","_","MaintenanceList","Services","BaseComponents","Components","Helper","Styles","Config","values","MaintenancePage","constructor","props","_defineProperty","navigation","goBack","loading","setState","state","isHomeTab","componentDidMount","getParentRoute","renderHeader","title","strings","featureKey","textFeatureTitle","createElement","Header","text","rightContent","includes","user","hidden","style","styles","notificationContainer","NotificationBell","colourBrandingHeader","containerStyle","notificationBell","leftIcon","onPressLeft","onPressBack","render","container","LoadingIndicator","visible","maintenanceList","onLoadingChanged","enableAdd","options","create","flex","position","top","bottom","right","paddingTop","StatusBarHeight","marginTop","mapStateToProps","_state$strings","config"],"sources":["MaintenancePage.js"],"sourcesContent":["import React, { Component } from
|
|
1
|
+
{"version":3,"names":["React","Component","View","StyleSheet","connect","_","MaintenanceList","Services","BaseComponents","Components","Helper","Styles","Config","values","MaintenancePage","constructor","props","_defineProperty","navigation","goBack","loading","setState","state","isHomeTab","componentDidMount","getParentRoute","renderHeader","title","strings","featureKey","textFeatureTitle","createElement","Header","text","rightContent","includes","user","hidden","style","styles","notificationContainer","NotificationBell","colourBrandingHeader","containerStyle","notificationBell","leftIcon","onPressLeft","onPressBack","render","container","LoadingIndicator","visible","maintenanceList","onLoadingChanged","enableAdd","options","create","flex","position","top","bottom","right","paddingTop","StatusBarHeight","marginTop","mapStateToProps","_state$strings","config"],"sources":["MaintenancePage.js"],"sourcesContent":["import React, { Component } from \"react\";\nimport { View, StyleSheet } from \"react-native\";\nimport { connect } from \"react-redux\";\nimport _ from \"lodash\";\nimport MaintenanceList from \"../components/MaintenanceList\";\nimport { Services, BaseComponents } from \"../feature.config\";\nimport { Components, Helper, Styles, Config } from \"../core.config\";\nimport { values } from \"../values.config\";\n\nclass MaintenancePage extends Component {\n\tconstructor(props) {\n\t\tsuper(props);\n\t\tthis.state = {\n\t\t\tisHomeTab: false,\n\t\t\tloading: false,\n\t\t};\n\t}\n\n\tcomponentDidMount() {\n\t\t// console.log('!Services.navigation.getParentRoute()', !Services.navigation.getParentRoute());\n\t\tthis.setState({ isHomeTab: !Services.navigation.getParentRoute() });\n\t}\n\n\tonPressBack = () => {\n\t\tServices.navigation.goBack();\n\t};\n\n\tonLoadingChanged = (loading) => {\n\t\tthis.setState({ loading });\n\t};\n\n\trenderHeader() {\n\t\tconst title =\n\t\t\tthis.props.title ||\n\t\t\tthis.props.strings[`${values.featureKey}_textFeatureTitle`] ||\n\t\t\tvalues.textFeatureTitle;\n\t\tif (this.state.isHomeTab) {\n\t\t\treturn (\n\t\t\t\t<Components.Header\n\t\t\t\t\ttext={title}\n\t\t\t\t\trightContent={\n\t\t\t\t\t\t_.includes(this.props.user.hidden, \"notifications\") ? null : (\n\t\t\t\t\t\t\t<View style={styles.notificationContainer}>\n\t\t\t\t\t\t\t\t<BaseComponents.NotificationBell\n\t\t\t\t\t\t\t\t\tcolourBrandingHeader={this.props.colourBrandingHeader}\n\t\t\t\t\t\t\t\t\tcontainerStyle={Styles.notificationBell}\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</View>\n\t\t\t\t\t\t)\n\t\t\t\t\t}\n\t\t\t\t/>\n\t\t\t);\n\t\t}\n\t\treturn (\n\t\t\t<Components.Header\n\t\t\t\tleftIcon=\"angle-left\"\n\t\t\t\tonPressLeft={this.onPressBack}\n\t\t\t\ttext={values.textFeatureTitle}\n\t\t\t/>\n\t\t);\n\t}\n\n\trender() {\n\t\tconst { isHomeTab } = this.state;\n\n\t\treturn (\n\t\t\t<View style={styles.container}>\n\t\t\t\t{this.renderHeader()}\n\t\t\t\t<Components.LoadingIndicator visible={this.state.loading} />\n\t\t\t\t<MaintenanceList\n\t\t\t\t\tstyle={styles.maintenanceList}\n\t\t\t\t\tonLoadingChanged={this.onLoadingChanged}\n\t\t\t\t\tenableAdd={!isHomeTab}\n\t\t\t\t\toptions={this.props.options}\n\t\t\t\t/>\n\t\t\t\t{/* {isHomeTab && <Components.AddContentButton />} */}\n\t\t\t</View>\n\t\t);\n\t}\n}\n\nconst styles = StyleSheet.create({\n\tcontainer: {\n\t\tflex: 1,\n\t},\n\tnotificationContainer: {\n\t\tposition: \"absolute\",\n\t\ttop: 0,\n\t\tbottom: 0,\n\t\tright: 0,\n\t\tpaddingTop: Helper.StatusBarHeight(0),\n\t},\n\tmaintenanceList: {\n\t\tmarginTop: 12,\n\t},\n});\n\nconst mapStateToProps = (state) => {\n\treturn {\n\t\tuser: state.user,\n\t\tstrings: state.strings?.config || {},\n\t};\n};\n\nexport default connect(mapStateToProps, {})(MaintenancePage);\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,25 +1,85 @@
|
|
|
1
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
2
|
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : 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
|
-
import React, { Component } from
|
|
5
|
-
import _ from
|
|
6
|
-
import { TouchableOpacity, View, ScrollView, Text } from
|
|
7
|
-
import { connect } from
|
|
8
|
-
import { Icon } from
|
|
9
|
-
import { Services } from
|
|
10
|
-
import { Components, Colours } from
|
|
4
|
+
import React, { Component } from "react";
|
|
5
|
+
import _ from "lodash";
|
|
6
|
+
import { TouchableOpacity, View, ScrollView, Text, TextInput } from "react-native";
|
|
7
|
+
import { connect } from "react-redux";
|
|
8
|
+
import { Icon } from "react-native-elements";
|
|
9
|
+
import { Services } from "../feature.config";
|
|
10
|
+
import { Components, Colours, Fonts } from "../core.config";
|
|
11
11
|
class MaintenanceUserPicker extends Component {
|
|
12
12
|
constructor(...args) {
|
|
13
13
|
super(...args);
|
|
14
14
|
_defineProperty(this, "state", {
|
|
15
|
-
currentUser: null
|
|
15
|
+
currentUser: null,
|
|
16
|
+
searchText: '',
|
|
17
|
+
filteredUsers: []
|
|
18
|
+
});
|
|
19
|
+
_defineProperty(this, "onChangeSearch", text => {
|
|
20
|
+
this.setState({
|
|
21
|
+
searchText: text,
|
|
22
|
+
filteredUsers: this.getFilteredUsers(text)
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
_defineProperty(this, "getFilteredUsers", (searchText, users) => {
|
|
26
|
+
const usersList = users || this.props.users || [];
|
|
27
|
+
if (!searchText || searchText.length === 0) {
|
|
28
|
+
return usersList;
|
|
29
|
+
}
|
|
30
|
+
if (!usersList || usersList.length === 0) {
|
|
31
|
+
return [];
|
|
32
|
+
}
|
|
33
|
+
return usersList.filter(user => {
|
|
34
|
+
const displayName = user.displayName || '';
|
|
35
|
+
const unit = user.unit || '';
|
|
36
|
+
const searchLower = searchText.toLowerCase();
|
|
37
|
+
return displayName.toLowerCase().includes(searchLower) || unit.toLowerCase().includes(searchLower);
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
_defineProperty(this, "renderSearch", () => {
|
|
41
|
+
return /*#__PURE__*/React.createElement(View, {
|
|
42
|
+
style: styles.searchContainer
|
|
43
|
+
}, /*#__PURE__*/React.createElement(Fonts.PlIcon, {
|
|
44
|
+
name: "nav-search",
|
|
45
|
+
style: styles.searchIcon
|
|
46
|
+
}), /*#__PURE__*/React.createElement(TextInput, {
|
|
47
|
+
placeholder: "Search by name or unit",
|
|
48
|
+
autoCorrect: false,
|
|
49
|
+
placeholderTextColor: 'rgba(60, 60, 80, .1)',
|
|
50
|
+
onChangeText: this.onChangeSearch,
|
|
51
|
+
value: this.state.searchText,
|
|
52
|
+
style: styles.searchText,
|
|
53
|
+
underlineColorAndroid: 'rgba(0,0,0,0)',
|
|
54
|
+
returnKeyType: "search"
|
|
55
|
+
}), this.state.searchText.length > 0 && /*#__PURE__*/React.createElement(TouchableOpacity, {
|
|
56
|
+
onPress: () => this.onChangeSearch(''),
|
|
57
|
+
style: styles.clearButton
|
|
58
|
+
}, /*#__PURE__*/React.createElement(Icon, {
|
|
59
|
+
name: "times-circle",
|
|
60
|
+
type: "font-awesome",
|
|
61
|
+
iconStyle: styles.clearIcon
|
|
62
|
+
})));
|
|
16
63
|
});
|
|
17
64
|
}
|
|
18
65
|
UNSAFE_componentWillMount() {
|
|
19
66
|
this.setState({
|
|
20
|
-
currentUser: this.props.currentUser
|
|
67
|
+
currentUser: this.props.currentUser,
|
|
68
|
+
filteredUsers: this.props.users || []
|
|
21
69
|
});
|
|
22
70
|
}
|
|
71
|
+
UNSAFE_componentWillReceiveProps(nextProps) {
|
|
72
|
+
if (nextProps.users !== this.props.users) {
|
|
73
|
+
this.setState({
|
|
74
|
+
filteredUsers: this.getFilteredUsers(this.state.searchText, nextProps.users)
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
if (nextProps.currentUser !== this.props.currentUser) {
|
|
78
|
+
this.setState({
|
|
79
|
+
currentUser: nextProps.currentUser
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
}
|
|
23
83
|
onPressBack() {
|
|
24
84
|
Services.navigation.goBack();
|
|
25
85
|
}
|
|
@@ -47,7 +107,15 @@ class MaintenanceUserPicker extends Component {
|
|
|
47
107
|
}, this.renderOptions());
|
|
48
108
|
}
|
|
49
109
|
renderOptions() {
|
|
50
|
-
|
|
110
|
+
const users = this.state.filteredUsers;
|
|
111
|
+
if (users.length === 0 && this.state.searchText.length > 0) {
|
|
112
|
+
return /*#__PURE__*/React.createElement(View, {
|
|
113
|
+
style: styles.noResultsContainer
|
|
114
|
+
}, /*#__PURE__*/React.createElement(Text, {
|
|
115
|
+
style: styles.noResultsText
|
|
116
|
+
}, "No users found matching \"", this.state.searchText, "\""));
|
|
117
|
+
}
|
|
118
|
+
return users.map((user, index) => {
|
|
51
119
|
return /*#__PURE__*/React.createElement(TouchableOpacity, {
|
|
52
120
|
key: index,
|
|
53
121
|
onPress: this.onUserPress.bind(this, user)
|
|
@@ -72,7 +140,7 @@ class MaintenanceUserPicker extends Component {
|
|
|
72
140
|
name: "check-circle",
|
|
73
141
|
type: "font-awesome",
|
|
74
142
|
iconStyle: [{
|
|
75
|
-
color:
|
|
143
|
+
color: "#d5d9e0",
|
|
76
144
|
fontSize: 20
|
|
77
145
|
}, _.isEqual(user, this.state.currentUser) && {
|
|
78
146
|
color: Colours.COLOUR_GREEN
|
|
@@ -87,7 +155,7 @@ class MaintenanceUserPicker extends Component {
|
|
|
87
155
|
leftIcon: "angle-left",
|
|
88
156
|
onPressLeft: this.onPressBack.bind(this),
|
|
89
157
|
text: "Select user"
|
|
90
|
-
}), /*#__PURE__*/React.createElement(ScrollView, {
|
|
158
|
+
}), this.renderSearch(), /*#__PURE__*/React.createElement(ScrollView, {
|
|
91
159
|
style: {
|
|
92
160
|
flex: 1
|
|
93
161
|
}
|
|
@@ -97,33 +165,72 @@ class MaintenanceUserPicker extends Component {
|
|
|
97
165
|
const styles = {
|
|
98
166
|
container: {
|
|
99
167
|
flex: 1,
|
|
100
|
-
position:
|
|
101
|
-
backgroundColor:
|
|
168
|
+
position: "relative",
|
|
169
|
+
backgroundColor: "#f0f0f5"
|
|
102
170
|
},
|
|
103
171
|
row: {
|
|
104
|
-
flexDirection:
|
|
105
|
-
alignItems:
|
|
172
|
+
flexDirection: "row",
|
|
173
|
+
alignItems: "center",
|
|
106
174
|
minHeight: 22
|
|
107
175
|
},
|
|
108
176
|
text: {
|
|
109
177
|
flex: 1,
|
|
110
|
-
fontFamily:
|
|
178
|
+
fontFamily: "sf-regular",
|
|
111
179
|
fontSize: 14,
|
|
112
180
|
color: Colours.TEXT_DARK
|
|
113
181
|
},
|
|
114
182
|
rowContainer: {
|
|
115
|
-
flexDirection:
|
|
116
|
-
justifyContent:
|
|
183
|
+
flexDirection: "row",
|
|
184
|
+
justifyContent: "space-between"
|
|
117
185
|
},
|
|
118
186
|
userContainer: {
|
|
119
|
-
flexDirection:
|
|
120
|
-
alignItems:
|
|
187
|
+
flexDirection: "row",
|
|
188
|
+
alignItems: "center"
|
|
121
189
|
},
|
|
122
190
|
labelText: {
|
|
123
|
-
fontFamily:
|
|
191
|
+
fontFamily: "sf-medium",
|
|
124
192
|
fontSize: 16,
|
|
125
193
|
color: Colours.TEXT_DARK,
|
|
126
194
|
marginLeft: 8
|
|
195
|
+
},
|
|
196
|
+
searchContainer: {
|
|
197
|
+
flexDirection: 'row',
|
|
198
|
+
alignItems: 'center',
|
|
199
|
+
paddingHorizontal: 16,
|
|
200
|
+
paddingVertical: 12,
|
|
201
|
+
backgroundColor: '#fff',
|
|
202
|
+
borderBottomWidth: 1,
|
|
203
|
+
borderBottomColor: '#f0f0f5'
|
|
204
|
+
},
|
|
205
|
+
searchIcon: {
|
|
206
|
+
fontSize: 20,
|
|
207
|
+
marginRight: 10,
|
|
208
|
+
color: 'rgba(90, 90, 110, .5)'
|
|
209
|
+
},
|
|
210
|
+
searchText: {
|
|
211
|
+
flex: 1,
|
|
212
|
+
fontSize: 16,
|
|
213
|
+
fontFamily: 'sf-regular',
|
|
214
|
+
color: Colours.TEXT_DARK
|
|
215
|
+
},
|
|
216
|
+
clearButton: {
|
|
217
|
+
padding: 8
|
|
218
|
+
},
|
|
219
|
+
clearIcon: {
|
|
220
|
+
fontSize: 18,
|
|
221
|
+
color: 'rgba(90, 90, 110, .5)'
|
|
222
|
+
},
|
|
223
|
+
noResultsContainer: {
|
|
224
|
+
flex: 1,
|
|
225
|
+
alignItems: 'center',
|
|
226
|
+
justifyContent: 'center',
|
|
227
|
+
paddingVertical: 40
|
|
228
|
+
},
|
|
229
|
+
noResultsText: {
|
|
230
|
+
fontSize: 16,
|
|
231
|
+
fontFamily: 'sf-regular',
|
|
232
|
+
color: Colours.TEXT_LIGHT,
|
|
233
|
+
textAlign: 'center'
|
|
127
234
|
}
|
|
128
235
|
};
|
|
129
236
|
export default connect(null, {})(MaintenanceUserPicker);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","Component","_","TouchableOpacity","View","ScrollView","Text","connect","Icon","Services","Components","Colours","MaintenanceUserPicker","constructor","args","_defineProperty","currentUser","UNSAFE_componentWillMount","setState","props","onPressBack","navigation","goBack","onUserPress","user","onSelectUser","setTimeout","renderMain","isEmpty","users","createElement","style","marginTop","Spinner","FormCard","renderOptions","map","index","key","onPress","bind","FormCardSection","label","displayName","labelStyle","height","margin","hasUnderline","hasContent","styles","rowContainer","userContainer","ProfilePic","profilePic","Diameter","labelText","name","type","iconStyle","color","fontSize","isEqual","state","COLOUR_GREEN","render","container","Header","leftIcon","onPressLeft","text","flex","position","backgroundColor","row","flexDirection","alignItems","minHeight","fontFamily","TEXT_DARK","justifyContent","marginLeft"],"sources":["MaintenanceUserPicker.js"],"sourcesContent":["import React, { Component } from 'react';\nimport _ from 'lodash';\nimport { TouchableOpacity, View, ScrollView, Text } from 'react-native';\nimport { connect } from 'react-redux';\nimport { Icon } from 'react-native-elements';\nimport { Services } from '../feature.config';\nimport { Components, Colours } from '../core.config';\n\nclass MaintenanceUserPicker extends Component {\n state = {\n currentUser: null,\n };\n\n UNSAFE_componentWillMount() {\n this.setState({ currentUser: this.props.currentUser });\n }\n\n onPressBack() {\n Services.navigation.goBack();\n }\n\n onUserPress(user) {\n this.props.onSelectUser(user);\n this.setState({ currentUser: user });\n setTimeout(() => {\n this.onPressBack();\n }, 200);\n }\n\n renderMain() {\n if (_.isEmpty(this.props.users)) {\n return (\n <View style={{ marginTop: 16 }}>\n <Components.Spinner />\n </View>\n );\n }\n\n return <Components.FormCard style={{ marginTop: 16 }}>{this.renderOptions()}</Components.FormCard>;\n }\n\n renderOptions() {\n return this.props.users.map((user, index) => {\n return (\n <TouchableOpacity key={index} onPress={this.onUserPress.bind(this, user)}>\n <Components.FormCardSection label={user.displayName} labelStyle={{ height: 0, margin: 0 }} hasUnderline hasContent>\n <View style={styles.rowContainer}>\n <View style={styles.userContainer}>\n <Components.ProfilePic ProfilePic={user.profilePic} Diameter={30} />\n <Text style={styles.labelText}>{user.displayName}</Text>\n </View>\n <Icon\n name=\"check-circle\"\n type=\"font-awesome\"\n iconStyle={[{ color: '#d5d9e0', fontSize: 20 }, _.isEqual(user, this.state.currentUser) && { color: Colours.COLOUR_GREEN }]}\n />\n </View>\n </Components.FormCardSection>\n </TouchableOpacity>\n );\n });\n }\n\n render() {\n return (\n <View style={styles.container}>\n <Components.Header leftIcon=\"angle-left\" onPressLeft={this.onPressBack.bind(this)} text=\"Select user\" />\n <ScrollView style={{ flex: 1 }}>{this.renderMain()}</ScrollView>\n </View>\n );\n }\n}\n\nconst styles = {\n container: {\n flex: 1,\n position: 'relative',\n backgroundColor: '#f0f0f5',\n },\n row: {\n flexDirection: 'row',\n alignItems: 'center',\n minHeight: 22,\n },\n text: {\n flex: 1,\n fontFamily: 'sf-regular',\n fontSize: 14,\n color: Colours.TEXT_DARK,\n },\n rowContainer: {\n flexDirection: 'row',\n justifyContent: 'space-between',\n },\n userContainer: {\n flexDirection: 'row',\n alignItems: 'center',\n },\n labelText: {\n fontFamily: 'sf-medium',\n fontSize: 16,\n color: Colours.TEXT_DARK,\n marginLeft: 8,\n },\n};\n\nexport default connect(null, {})(MaintenanceUserPicker);"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["React","Component","_","TouchableOpacity","View","ScrollView","Text","TextInput","connect","Icon","Services","Components","Colours","Fonts","MaintenanceUserPicker","constructor","args","_defineProperty","currentUser","searchText","filteredUsers","text","setState","getFilteredUsers","users","usersList","props","length","filter","user","displayName","unit","searchLower","toLowerCase","includes","createElement","style","styles","searchContainer","PlIcon","name","searchIcon","placeholder","autoCorrect","placeholderTextColor","onChangeText","onChangeSearch","value","state","underlineColorAndroid","returnKeyType","onPress","clearButton","type","iconStyle","clearIcon","UNSAFE_componentWillMount","UNSAFE_componentWillReceiveProps","nextProps","onPressBack","navigation","goBack","onUserPress","onSelectUser","setTimeout","renderMain","isEmpty","marginTop","Spinner","FormCard","renderOptions","noResultsContainer","noResultsText","map","index","key","bind","FormCardSection","label","labelStyle","height","margin","hasUnderline","hasContent","rowContainer","userContainer","ProfilePic","profilePic","Diameter","labelText","color","fontSize","isEqual","COLOUR_GREEN","render","container","Header","leftIcon","onPressLeft","renderSearch","flex","position","backgroundColor","row","flexDirection","alignItems","minHeight","fontFamily","TEXT_DARK","justifyContent","marginLeft","paddingHorizontal","paddingVertical","borderBottomWidth","borderBottomColor","marginRight","padding","TEXT_LIGHT","textAlign"],"sources":["MaintenanceUserPicker.js"],"sourcesContent":["import React, { Component } from \"react\";\nimport _ from \"lodash\";\nimport { TouchableOpacity, View, ScrollView, Text, TextInput } from \"react-native\";\nimport { connect } from \"react-redux\";\nimport { Icon } from \"react-native-elements\";\nimport { Services } from \"../feature.config\";\nimport { Components, Colours, Fonts } from \"../core.config\";\n\nclass MaintenanceUserPicker extends Component {\n\tstate = {\n\t\tcurrentUser: null,\n\t\tsearchText: '',\n\t\tfilteredUsers: []\n\t};\n\n\tUNSAFE_componentWillMount() {\n\t\tthis.setState({\n\t\t\tcurrentUser: this.props.currentUser,\n\t\t\tfilteredUsers: this.props.users || []\n\t\t});\n\t}\n\n\tUNSAFE_componentWillReceiveProps(nextProps) {\n\t\tif (nextProps.users !== this.props.users) {\n\t\t\tthis.setState({\n\t\t\t\tfilteredUsers: this.getFilteredUsers(this.state.searchText, nextProps.users)\n\t\t\t});\n\t\t}\n\t\tif (nextProps.currentUser !== this.props.currentUser) {\n\t\t\tthis.setState({\n\t\t\t\tcurrentUser: nextProps.currentUser\n\t\t\t});\n\t\t}\n\t}\n\n\tonPressBack() {\n\t\tServices.navigation.goBack();\n\t}\n\n\tonUserPress(user) {\n\t\tthis.props.onSelectUser(user);\n\t\tthis.setState({ currentUser: user });\n\t\tsetTimeout(() => {\n\t\t\tthis.onPressBack();\n\t\t}, 200);\n\t}\n\n\tonChangeSearch = (text) => {\n\t\tthis.setState({\n\t\t\tsearchText: text,\n\t\t\tfilteredUsers: this.getFilteredUsers(text)\n\t\t});\n\t}\n\n\tgetFilteredUsers = (searchText, users) => {\n\t\tconst usersList = users || this.props.users || [];\n\n\t\tif (!searchText || searchText.length === 0) {\n\t\t\treturn usersList;\n\t\t}\n\n\t\tif (!usersList || usersList.length === 0) {\n\t\t\treturn [];\n\t\t}\n\n\t\treturn usersList.filter(user => {\n\t\t\tconst displayName = user.displayName || '';\n\t\t\tconst unit = user.unit || '';\n\t\t\tconst searchLower = searchText.toLowerCase();\n\n\t\t\treturn displayName.toLowerCase().includes(searchLower) ||\n\t\t\t\tunit.toLowerCase().includes(searchLower);\n\t\t});\n\t}\n\n\trenderSearch = () => {\n\t\treturn (\n\t\t\t<View style={styles.searchContainer}>\n\t\t\t\t<Fonts.PlIcon name=\"nav-search\" style={styles.searchIcon} />\n\t\t\t\t<TextInput\n\t\t\t\t\tplaceholder='Search by name or unit'\n\t\t\t\t\tautoCorrect={false}\n\t\t\t\t\tplaceholderTextColor={'rgba(60, 60, 80, .1)'}\n\t\t\t\t\tonChangeText={this.onChangeSearch}\n\t\t\t\t\tvalue={this.state.searchText}\n\t\t\t\t\tstyle={styles.searchText}\n\t\t\t\t\tunderlineColorAndroid={'rgba(0,0,0,0)'}\n\t\t\t\t\treturnKeyType=\"search\"\n\t\t\t\t/>\n\t\t\t\t{this.state.searchText.length > 0 && (\n\t\t\t\t\t<TouchableOpacity\n\t\t\t\t\t\tonPress={() => this.onChangeSearch('')}\n\t\t\t\t\t\tstyle={styles.clearButton}\n\t\t\t\t\t>\n\t\t\t\t\t\t<Icon\n\t\t\t\t\t\t\tname=\"times-circle\"\n\t\t\t\t\t\t\ttype=\"font-awesome\"\n\t\t\t\t\t\t\ticonStyle={styles.clearIcon}\n\t\t\t\t\t\t/>\n\t\t\t\t\t</TouchableOpacity>\n\t\t\t\t)}\n\t\t\t</View>\n\t\t);\n\t}\n\n\trenderMain() {\n\t\tif (_.isEmpty(this.props.users)) {\n\t\t\treturn (\n\t\t\t\t<View style={{ marginTop: 16 }}>\n\t\t\t\t\t<Components.Spinner />\n\t\t\t\t</View>\n\t\t\t);\n\t\t}\n\n\t\treturn (\n\t\t\t<Components.FormCard style={{ marginTop: 16 }}>\n\t\t\t\t{this.renderOptions()}\n\t\t\t</Components.FormCard>\n\t\t);\n\t}\n\n\trenderOptions() {\n\t\tconst users = this.state.filteredUsers;\n\n\t\tif (users.length === 0 && this.state.searchText.length > 0) {\n\t\t\treturn (\n\t\t\t\t<View style={styles.noResultsContainer}>\n\t\t\t\t\t<Text style={styles.noResultsText}>\n\t\t\t\t\t\tNo users found matching \"{this.state.searchText}\"\n\t\t\t\t\t</Text>\n\t\t\t\t</View>\n\t\t\t);\n\t\t}\n\n\t\treturn users.map((user, index) => {\n\t\t\treturn (\n\t\t\t\t<TouchableOpacity\n\t\t\t\t\tkey={index}\n\t\t\t\t\tonPress={this.onUserPress.bind(this, user)}\n\t\t\t\t>\n\t\t\t\t\t<Components.FormCardSection\n\t\t\t\t\t\tlabel={user.displayName}\n\t\t\t\t\t\tlabelStyle={{ height: 0, margin: 0 }}\n\t\t\t\t\t\thasUnderline\n\t\t\t\t\t\thasContent\n\t\t\t\t\t>\n\t\t\t\t\t\t<View style={styles.rowContainer}>\n\t\t\t\t\t\t\t<View style={styles.userContainer}>\n\t\t\t\t\t\t\t\t<Components.ProfilePic\n\t\t\t\t\t\t\t\t\tProfilePic={user.profilePic}\n\t\t\t\t\t\t\t\t\tDiameter={30}\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t<Text style={styles.labelText}>{user.displayName}</Text>\n\t\t\t\t\t\t\t</View>\n\t\t\t\t\t\t\t<Icon\n\t\t\t\t\t\t\t\tname=\"check-circle\"\n\t\t\t\t\t\t\t\ttype=\"font-awesome\"\n\t\t\t\t\t\t\t\ticonStyle={[\n\t\t\t\t\t\t\t\t\t{ color: \"#d5d9e0\", fontSize: 20 },\n\t\t\t\t\t\t\t\t\t_.isEqual(user, this.state.currentUser) && {\n\t\t\t\t\t\t\t\t\t\tcolor: Colours.COLOUR_GREEN,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t]}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</View>\n\t\t\t\t\t</Components.FormCardSection>\n\t\t\t\t</TouchableOpacity>\n\t\t\t);\n\t\t});\n\t}\n\n\trender() {\n\t\treturn (\n\t\t\t<View style={styles.container}>\n\t\t\t\t<Components.Header\n\t\t\t\t\tleftIcon=\"angle-left\"\n\t\t\t\t\tonPressLeft={this.onPressBack.bind(this)}\n\t\t\t\t\ttext=\"Select user\"\n\t\t\t\t/>\n\t\t\t\t{this.renderSearch()}\n\t\t\t\t<ScrollView style={{ flex: 1 }}>{this.renderMain()}</ScrollView>\n\t\t\t</View>\n\t\t);\n\t}\n}\n\nconst styles = {\n\tcontainer: {\n\t\tflex: 1,\n\t\tposition: \"relative\",\n\t\tbackgroundColor: \"#f0f0f5\",\n\t},\n\trow: {\n\t\tflexDirection: \"row\",\n\t\talignItems: \"center\",\n\t\tminHeight: 22,\n\t},\n\ttext: {\n\t\tflex: 1,\n\t\tfontFamily: \"sf-regular\",\n\t\tfontSize: 14,\n\t\tcolor: Colours.TEXT_DARK,\n\t},\n\trowContainer: {\n\t\tflexDirection: \"row\",\n\t\tjustifyContent: \"space-between\",\n\t},\n\tuserContainer: {\n\t\tflexDirection: \"row\",\n\t\talignItems: \"center\",\n\t},\n\tlabelText: {\n\t\tfontFamily: \"sf-medium\",\n\t\tfontSize: 16,\n\t\tcolor: Colours.TEXT_DARK,\n\t\tmarginLeft: 8,\n\t},\n\tsearchContainer: {\n\t\tflexDirection: 'row',\n\t\talignItems: 'center',\n\t\tpaddingHorizontal: 16,\n\t\tpaddingVertical: 12,\n\t\tbackgroundColor: '#fff',\n\t\tborderBottomWidth: 1,\n\t\tborderBottomColor: '#f0f0f5'\n\t},\n\tsearchIcon: {\n\t\tfontSize: 20,\n\t\tmarginRight: 10,\n\t\tcolor: 'rgba(90, 90, 110, .5)'\n\t},\n\tsearchText: {\n\t\tflex: 1,\n\t\tfontSize: 16,\n\t\tfontFamily: 'sf-regular',\n\t\tcolor: Colours.TEXT_DARK\n\t},\n\tclearButton: {\n\t\tpadding: 8\n\t},\n\tclearIcon: {\n\t\tfontSize: 18,\n\t\tcolor: 'rgba(90, 90, 110, .5)'\n\t},\n\tnoResultsContainer: {\n\t\tflex: 1,\n\t\talignItems: 'center',\n\t\tjustifyContent: 'center',\n\t\tpaddingVertical: 40\n\t},\n\tnoResultsText: {\n\t\tfontSize: 16,\n\t\tfontFamily: 'sf-regular',\n\t\tcolor: Colours.TEXT_LIGHT,\n\t\ttextAlign: 'center'\n\t}\n};\n\nexport default connect(null, {})(MaintenanceUserPicker);\n"],"mappings":"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","ignoreList":[]}
|