AddUser.js 36.2 KB
Newer Older
d.arizona's avatar
d.arizona committed
1
import React, { Component } from 'react';
a.bairuha's avatar
a.bairuha committed
2
import { TextField, Divider, Typography, Checkbox, withStyles, Collapse, Snackbar } from '@material-ui/core';
d.arizona's avatar
d.arizona committed
3
import api from '../../../api';
d.arizona's avatar
d.arizona committed
4 5
import Autocomplete from '@material-ui/lab/Autocomplete';
import { titleCase } from '../../../library/Utils';
d.arizona's avatar
d.arizona committed
6 7
import localeID from "date-fns/locale/id"
import format from "date-fns/format";
d.arizona's avatar
d.arizona committed
8 9 10
import RemoveIcon from '@material-ui/icons/Remove';
import AddIcon from '@material-ui/icons/Add';
import { DatePicker } from '@material-ui/pickers';
d.arizona's avatar
d.arizona committed
11
import * as R from 'ramda'
d.arizona's avatar
d.arizona committed
12
import Images from '../../../assets/Images';
a.bairuha's avatar
a.bairuha committed
13
import MuiAlert from '@material-ui/lab/Alert';
d.arizona's avatar
d.arizona committed
14 15 16 17

const CustomCheckbox = withStyles({
    root: {
        color: '#51c6ea',
Deni Rinaldi's avatar
Deni Rinaldi committed
18 19 20
        '&$checked': {
            color: '#51c6ea',
        },
d.arizona's avatar
d.arizona committed
21 22
    },
    checked: {},
Deni Rinaldi's avatar
Deni Rinaldi committed
23 24 25 26 27 28 29 30 31 32 33
})((props) => <Checkbox color="default" {...props} />);

const CustomCheckboxDisabled = withStyles({
    root: {
        color: '#d5d5d5',
        '&$checked': {
            color: '#d5d5d5',
        },
    },
    checked: {},
})((props) => <Checkbox color="default" {...props} />);
d.arizona's avatar
d.arizona committed
34

a.bairuha's avatar
a.bairuha committed
35 36 37
const Alert = withStyles({
})((props) => <MuiAlert elevation={6} variant="filled" {...props} />);

d.arizona's avatar
d.arizona committed
38
export default class AddUser extends Component {
Deni Rinaldi's avatar
Deni Rinaldi committed
39

d.arizona's avatar
d.arizona committed
40 41 42 43 44 45
    constructor(props) {
        super(props)
        this.state = {
            paramsId: this.props.data,
            tempData: null,
            menuData: null,
d.arizona's avatar
d.arizona committed
46 47 48 49 50 51 52
            checked: false,
            fullname: '',
            email: '',
            role: null,
            startDate: null,
            endDate: null,
            company: [],
d.arizona's avatar
d.arizona committed
53
            listCompany: [],
d.arizona's avatar
d.arizona committed
54
            listRole: null,
d.arizona's avatar
d.arizona committed
55
            selectedIndex: 0,
d.arizona's avatar
d.arizona committed
56
            date: new Date(),
d.arizona's avatar
d.arizona committed
57 58 59 60 61 62 63 64 65 66
            errorFullname: false,
            errorEmail: false,
            errorRoleName: false,
            errorStartDate: false,
            errorEndDate: false,
            msgErrorFN: '',
            msgErrorEM: '',
            msgErrorRN: '',
            msgErrorSD: '',
            msgErrorED: '',
a.bairuha's avatar
a.bairuha committed
67 68 69
            alert: false,
            tipeAlert: '',
            messageAlert: ''
d.arizona's avatar
d.arizona committed
70 71 72 73
        }
    }

    handleChecked() {
Deni Rinaldi's avatar
Deni Rinaldi committed
74
        this.setState({ checked: !this.state.checked })
d.arizona's avatar
d.arizona committed
75
    }
Deni Rinaldi's avatar
Deni Rinaldi committed
76

d.arizona's avatar
d.arizona committed
77
    componentDidMount() {
d.arizona's avatar
d.arizona committed
78
        this.getRole()
d.arizona's avatar
d.arizona committed
79
        this.getPerusahaan()
a.bairuha's avatar
a.bairuha committed
80 81 82 83 84 85 86 87 88 89
        if (this.props.type === 'edit') {
            //
        } else {
            let date = format(new Date, 'yyyy-MM-dd')
            console.log(date);
            this.setState({
                startDate: date,
                endDate: date
            })
        }
d.arizona's avatar
d.arizona committed
90 91
    }

d.arizona's avatar
d.arizona committed
92
    handleChange(e, type) {
d.arizona's avatar
d.arizona committed
93
        let data = this.state
d.arizona's avatar
d.arizona committed
94
        let isDate = type !== '' ? true : false
d.arizona's avatar
d.arizona committed
95
        if (isDate && type === 'start_date') {
d.arizona's avatar
d.arizona committed
96
            this.setState({ ...data, startDate: format(e, 'yyyy-MM-dd'), endDate: null,
a.bairuha's avatar
a.bairuha committed
97 98
                errorFullname: false,
                errorEmail: false,
d.arizona's avatar
d.arizona committed
99 100 101
                errorRoleName: false,
                errorStartDate: false,
                errorEndDate: false,
a.bairuha's avatar
a.bairuha committed
102 103
                msgErrorFN: '',
                msgErrorEM: '',
d.arizona's avatar
d.arizona committed
104 105 106 107
                msgErrorRN: '',
                msgErrorSD: '',
                msgErrorED: '',
            })
d.arizona's avatar
d.arizona committed
108
        } else if (isDate && type === 'end_date') {
d.arizona's avatar
d.arizona committed
109
            this.setState({ ...data, endDate: format(e, 'yyyy-MM-dd') ,
a.bairuha's avatar
a.bairuha committed
110 111
                errorFullname: false,
                errorEmail: false,
d.arizona's avatar
d.arizona committed
112 113 114
                errorRoleName: false,
                errorStartDate: false,
                errorEndDate: false,
a.bairuha's avatar
a.bairuha committed
115 116
                msgErrorFN: '',
                msgErrorEM: '',
d.arizona's avatar
d.arizona committed
117 118 119 120 121 122
                msgErrorRN: '',
                msgErrorSD: '',
                msgErrorED: '',
            })
        } else {
            this.setState({ ...data, [e.target.name]: e.target.value, 
a.bairuha's avatar
a.bairuha committed
123 124
                errorFullname: false,
                errorEmail: false,
d.arizona's avatar
d.arizona committed
125 126 127
                errorRoleName: false,
                errorStartDate: false,
                errorEndDate: false,
a.bairuha's avatar
a.bairuha committed
128 129
                msgErrorFN: '',
                msgErrorEM: '',
d.arizona's avatar
d.arizona committed
130 131
                msgErrorRN: '',
                msgErrorSD: '',
Deni Rinaldi's avatar
Deni Rinaldi committed
132
                msgErrorED: '',
d.arizona's avatar
d.arizona committed
133 134 135 136
            })
        }
    }

a.bairuha's avatar
a.bairuha committed
137 138 139 140 141 142 143 144 145 146 147 148 149 150 151
    clearError() {
        this.setState({
                errorFullname: false,
                errorEmail: false,
                errorRoleName: false,
                errorStartDate: false,
                errorEndDate: false,
                msgErrorFN: '',
                msgErrorEM: '',
                msgErrorRN: '',
                msgErrorSD: '',
                msgErrorED: '',
            })
    }

a.bairuha's avatar
a.bairuha committed
152 153 154 155 156
    isEmail(email) {
        const re = /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
        return re.test(String(email).toLowerCase());
    }

d.arizona's avatar
d.arizona committed
157
    validasi() {
a.bairuha's avatar
a.bairuha committed
158 159 160
        var isEmail = this.isEmail(this.state.email)

        if (R.isEmpty(this.state.fullname)) {
161
            this.setState({ errorFullname: true, msgErrorFN: 'Fullname Cannot be Empty.' })
a.bairuha's avatar
a.bairuha committed
162
        } else if (R.isEmpty(this.state.email)) {
163
            this.setState({ errorEmail: true, msgErrorEM: 'Email Cannot be Empty.' })
a.bairuha's avatar
a.bairuha committed
164
        } else if (!isEmail) {
165
            this.setState({ errorEmail: true, msgErrorEM: 'Email Format Not Recognized.' })
a.bairuha's avatar
a.bairuha committed
166
        } else if (R.isNil(this.state.role)) {
167
            this.setState({ errorRoleName: true, msgErrorRN: 'Role Name Cannot be Empty.' })
a.bairuha's avatar
a.bairuha committed
168
        } else if (R.isNil(this.state.startDate)) {
169
            this.setState({ errorStartDate: true, msgErrorSD: 'Valid From Cannot be Empty.' })
a.bairuha's avatar
a.bairuha committed
170
        } else if (R.isNil(this.state.endDate)) {
171
            this.setState({ errorEndDate: true, msgErrorED: 'Valid To Cannot be Empty.' })
a.bairuha's avatar
a.bairuha committed
172 173 174 175 176
        }
        // else if (this.state.privileges.length < 1) {
        //     alert('Hak Akses belum di pilih !!')
        // } 
        else {
d.arizona's avatar
d.arizona committed
177
        this.createUser()
a.bairuha's avatar
a.bairuha committed
178
        }
d.arizona's avatar
d.arizona committed
179 180
    }

d.arizona's avatar
d.arizona committed
181
    createUser() {
d.arizona's avatar
d.arizona committed
182
        let payload = {
d.arizona's avatar
d.arizona committed
183 184 185 186 187 188 189
            "role_id": this.state.role.role_id,
            "email": this.state.email,
            "fullname": this.state.fullname,
            "password": this.state.fullname,
            "company": this.state.company,
            "start_date": this.state.startDate,
            "end_date": this.state.endDate
d.arizona's avatar
d.arizona committed
190
        }
d.arizona's avatar
d.arizona committed
191
        api.create().createUser(payload).then((response) => {
d.arizona's avatar
d.arizona committed
192 193
            // console.log(response)
            // if (String(response.data.status).toLocaleUpperCase === 'Success' || String(response.data.status).toLocaleUpperCase === 'success') {
a.bairuha's avatar
a.bairuha committed
194 195 196 197
            if (response.data) {
                if (response.ok) {
                    if (response.data.status === 'success') {
                        this.setState({ alert: true, messageAlert: response.data.message, tipeAlert: 'success' })
d.arizona's avatar
d.arizona committed
198 199 200 201
                        setTimeout(() => {
                            this.props.onClickClose()
                            this.props.refresh()
                        }, 750);
a.bairuha's avatar
a.bairuha committed
202 203 204 205 206 207 208 209 210 211
                    } else {
                        this.setState({ alert: true, messageAlert: response.data.message, tipeAlert: 'warning' })
                    }
                } else {
                    this.setState({ alert: true, messageAlert: response.data.message, tipeAlert: 'error' })
                }
            } else {
                this.setState({ alert: true, messageAlert: response.problem, tipeAlert: 'error' })
            }
            
d.arizona's avatar
d.arizona committed
212
            // } else {
Deni Rinaldi's avatar
Deni Rinaldi committed
213
            // alert(response.data.message)
d.arizona's avatar
d.arizona committed
214 215 216
            //     this.props.onClickClose()
            //     this.props.refresh()
            // }
d.arizona's avatar
d.arizona committed
217
        })
d.arizona's avatar
d.arizona committed
218 219
    }

d.arizona's avatar
d.arizona committed
220
    getRole() {
221
        api.create().getRoleActive().then((response) => {
a.bairuha's avatar
a.bairuha committed
222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238
            if (response.data) {
                if (response.ok) {
                    if (response.data.status === 'success') {
                        let data = response.data.data
                        let roleData = data.map((item) => {
                            return {
                                role_id: item.role_id,
                                role_name: item.role_name
                            }
                        })
                        let defaultProps = {
                            options: roleData,
                            getOptionLabel: (option) => titleCase(option.role_name),
                        };
                        this.setState({ listRole: defaultProps })
                    } else {
                        this.setState({ alert: true, messageAlert: response.data.message, tipeAlert: 'warning' })
d.arizona's avatar
d.arizona committed
239
                    }
a.bairuha's avatar
a.bairuha committed
240 241 242
                } else {
                    this.setState({ alert: true, messageAlert: response.data.message, tipeAlert: 'error' })
                }
d.arizona's avatar
d.arizona committed
243
            } else {
a.bairuha's avatar
a.bairuha committed
244
                this.setState({ alert: true, messageAlert: response.problem, tipeAlert: 'error' })
d.arizona's avatar
d.arizona committed
245 246 247 248
            }
        })
    }

d.arizona's avatar
d.arizona committed
249 250
    getPerusahaan() {
        api.create().getPerusahaanHierarki().then((response) => {
a.bairuha's avatar
a.bairuha committed
251 252 253 254 255 256 257 258 259 260 261 262 263
            if (response.data) {
                if (response.ok) {
                    if (response.data.status === 'success') {
                        this.setState({ listCompany: response.data.data })
                        console.log(response.data.data)
                    } else {
                        this.setState({ alert: true, messageAlert: response.data.message, tipeAlert: 'warning' })
                    }
                } else {
                    this.setState({ alert: true, messageAlert: response.data.message, tipeAlert: 'error' })
                }
            } else {
                this.setState({ alert: true, messageAlert: response.problem, tipeAlert: 'error' })
d.arizona's avatar
d.arizona committed
264 265 266 267 268
            }
        })
    }

    handleItemChecked(item) {
d.arizona's avatar
d.arizona committed
269
        let indexID = this.state.company.findIndex((val) => val === item.id)
d.arizona's avatar
d.arizona committed
270
        return indexID === -1 ? false : true
d.arizona's avatar
d.arizona committed
271 272 273
    }

    handleItemClick(item) {
d.arizona's avatar
d.arizona committed
274
        let indexID = this.state.company.findIndex((val) => val === item.id)
d.arizona's avatar
d.arizona committed
275
        let listCompany = this.state.listCompany
d.arizona's avatar
d.arizona committed
276
        let company = this.state.company
d.arizona's avatar
d.arizona committed
277
        if (indexID === -1) {
d.arizona's avatar
d.arizona committed
278
            company.push(item.id)
d.arizona's avatar
d.arizona committed
279 280 281 282 283 284 285 286 287 288 289 290 291 292
            if (item.parent !== null) {
                let indexIDs = this.state.company.findIndex((val) => val === item.parent)
                if (indexIDs === -1) {
                    company.push(item.parent)
                }
            }

            if (item.children !== null) {
                if (item.children.length > 0) {
                    item.children.map((items,indexs) => {
                        this.handleItemClick(items)
                    })
                }
            }
d.arizona's avatar
d.arizona committed
293 294
        } else {
            company.splice(indexID, 1)
d.arizona's avatar
d.arizona committed
295 296 297 298 299 300 301 302 303 304 305 306 307
            if (item.parent !== null) {
                let indexIDs = this.state.company.findIndex((val) => val === item.parent)
                if (indexIDs !== -1) {
                    company.splice(indexIDs, 1)
                } 
                if (item.children !== null) {
                    if (item.children.length > 0) {
                        item.children.map((items,indexs) => {
                            this.handleItemClick(items)
                        })
                    }
                }
            }
d.arizona's avatar
d.arizona committed
308 309 310
        }
        this.setState({ company })
    }
d.arizona's avatar
d.arizona committed
311

d.arizona's avatar
d.arizona committed
312 313 314 315 316
    renderChildren = (item, pad) => {
        let padding = null
        if (pad !== undefined) {
            padding = pad
        } else {
d.arizona's avatar
d.arizona committed
317
            padding = 30
d.arizona's avatar
d.arizona committed
318 319
        }
        return (
a.bairuha's avatar
a.bairuha committed
320 321 322 323 324 325 326
            <div>
                {item.children.length > 0 && (
                    <ul>
                        {item.children.map((data, index) => {
                            return (
                                // <li>
                                <Collapse key={index} timeout="auto" unmountOnExit in={item.collapse}>
d.arizona's avatar
d.arizona committed
327
                                    <div style={{ display: 'flex', flexDirection: 'row', alignItems: 'center', justifyContent: 'flex-start', paddingLeft: !R.isNil(data.children)? (data.children.length > 0? padding : padding + 30) : padding + 30}}>
a.bairuha's avatar
a.bairuha committed
328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353
                                        {R.isNil(data.children) ?
                                            null
                                            :
                                            data.children.length < 1 ?
                                                null
                                                :
                                                <span onClick={() => this.handleCollapse(data)} style={{ marginLeft: 7, marginRight: 2 }}>
                                                    {data.collapse ? <RemoveIcon color={'action'} fontSize={'small'} /> : <AddIcon color={'action'} fontSize={'small'} />}
                                                </span>
                                        }
                                        <span>
                                            {this.state.role ? this.state.role.role_id === 1 ?
                                                <CustomCheckboxDisabled
                                                    disabled={true}
                                                    checked={true}
                                                // onChange={() => this.handleItemClick(item)}
                                                /> :
                                                <CustomCheckbox
                                                    checked={this.handleItemChecked(data)}
                                                    onChange={() => this.handleItemClick(data)}
                                                /> :
                                                <CustomCheckbox
                                                    checked={this.handleItemChecked(data)}
                                                    onChange={() => this.handleItemClick(data)}
                                                />
                                            }
Deni Rinaldi's avatar
Deni Rinaldi committed
354
                                        </span>
a.bairuha's avatar
a.bairuha committed
355 356
                                        <Typography style={{ fontSize: 12 }}>{titleCase(data.company_name)}</Typography>
                                    </div>
d.arizona's avatar
d.arizona committed
357
                                    {!R.isNil(data.children) && this.renderChildren(data, padding + 30)}
a.bairuha's avatar
a.bairuha committed
358 359 360 361 362 363 364
                                </Collapse>
                                // </li>
                            )
                        })}
                    </ul>
                )}
            </div>
d.arizona's avatar
d.arizona committed
365 366 367 368
        )
    }

    handleCollapse(item) {
Deni Rinaldi's avatar
Deni Rinaldi committed
369
        let path = this.searchIt({ children: this.state.listCompany }, item.id)
d.arizona's avatar
d.arizona committed
370 371 372 373 374
        let listCompany = this.state.listCompany
        let arrayPath = []

        if (path.length > 1) {
            arrayPath = path.split('-');
Deni Rinaldi's avatar
Deni Rinaldi committed
375
            arrayPath = arrayPath.map((item) => { return item })
d.arizona's avatar
d.arizona committed
376 377 378 379 380 381
        } else {
            arrayPath.push(path)
        }

        let pathSelect = null
        if (arrayPath.length == 1) {
Deni Rinaldi's avatar
Deni Rinaldi committed
382
            pathSelect = listCompany[arrayPath[0]]
d.arizona's avatar
d.arizona committed
383
        } else if (arrayPath.length == 2) {
Deni Rinaldi's avatar
Deni Rinaldi committed
384
            pathSelect = listCompany[arrayPath[0]].children[arrayPath[1]]
d.arizona's avatar
d.arizona committed
385
        } else if (arrayPath.length == 3) {
Deni Rinaldi's avatar
Deni Rinaldi committed
386
            pathSelect = listCompany[arrayPath[0]].children[arrayPath[1]].children[arrayPath[2]]
d.arizona's avatar
d.arizona committed
387
        } else if (arrayPath.length == 4) {
Deni Rinaldi's avatar
Deni Rinaldi committed
388
            pathSelect = listCompany[arrayPath[0]].children[arrayPath[1]].children[arrayPath[2]].children[arrayPath[3]]
d.arizona's avatar
d.arizona committed
389
        } else if (arrayPath.length == 5) {
Deni Rinaldi's avatar
Deni Rinaldi committed
390
            pathSelect = listCompany[arrayPath[0]].children[arrayPath[1]].children[arrayPath[2]].children[arrayPath[3]].children[arrayPath[4]]
d.arizona's avatar
d.arizona committed
391
        } else if (arrayPath.length == 6) {
Deni Rinaldi's avatar
Deni Rinaldi committed
392
            pathSelect = listCompany[arrayPath[0]].children[arrayPath[1]].children[arrayPath[2]].children[arrayPath[3]].children[arrayPath[4]].children[arrayPath[5]]
d.arizona's avatar
d.arizona committed
393
        } else if (arrayPath.length == 7) {
Deni Rinaldi's avatar
Deni Rinaldi committed
394
            pathSelect = listCompany[arrayPath[0]].children[arrayPath[1]].children[arrayPath[2]].children[arrayPath[3]].children[arrayPath[4]].children[arrayPath[5]].children[arrayPath[6]]
d.arizona's avatar
d.arizona committed
395 396 397 398
        }

        pathSelect.collapse = !pathSelect.collapse
        // console.log(pathSelect.collapse)
Deni Rinaldi's avatar
Deni Rinaldi committed
399
        this.setState({ listCompany }, () => console.log(pathSelect))
d.arizona's avatar
d.arizona committed
400 401 402
    }

    searchIt = (node, search, path = '', position = 0) => {
Deni Rinaldi's avatar
Deni Rinaldi committed
403 404
        if (node.id && node.id === search) { return path !== '' ? `${path}-${position}` : position; }
        if (!node.children) { return false }
d.arizona's avatar
d.arizona committed
405
        const index = node.children.findIndex((x) => x.id && x.id === search);
d.arizona's avatar
d.arizona committed
406
        if (index >= 0) {
Deni Rinaldi's avatar
Deni Rinaldi committed
407
            return path !== '' ? `${path}-${index}` : index;
d.arizona's avatar
d.arizona committed
408
        }
d.arizona's avatar
d.arizona committed
409
        for (let i = 0; i < node.children.length; i++) {
Deni Rinaldi's avatar
Deni Rinaldi committed
410 411 412 413
            const result = this.searchIt(node.children[i], search, path !== '' ? `${path}-${i}` : i, i);
            if (result) {
                return result;
            }
d.arizona's avatar
d.arizona committed
414 415 416 417
        }
        return false;
    };

a.bairuha's avatar
a.bairuha committed
418 419 420 421
    closeAlert() {
      this.setState({ alert: false })
    }

d.arizona's avatar
d.arizona committed
422 423 424
    render() {
        return (
            <div className="test app-popup-show">
a.bairuha's avatar
a.bairuha committed
425 426 427 428 429
                <Snackbar open={this.state.alert} autoHideDuration={6000} onClose={() => this.closeAlert()}>
                    <Alert onClose={() => this.closeAlert()} severity={this.state.tipeAlert}>
                        {this.state.messageAlert}
                    </Alert>
                </Snackbar>
d.arizona's avatar
d.arizona committed
430
                <div className="popup-content background-white border-radius" style={{ borderRadius: 8 }}>
431
                    <div className="popup-panel grid grid-2x main-color" style={{ height: 64, borderTopRightRadius: 8, borderTopLeftRadius: 8 }}>
d.arizona's avatar
d.arizona committed
432 433
                        <div className="col-1" style={{ maxWidth: "inherit", display: 'flex', alignItems: 'center' }}>
                            <div className="popup-title">
d.arizona's avatar
d.arizona committed
434
                                <span style={{ color: '#fff', fontSize: 16, fontWeight: 'bold' }}>Create Data</span>
d.arizona's avatar
d.arizona committed
435 436 437 438 439 440 441 442
                            </div>
                        </div>
                        <div className="col-2 content-right" style={{ maxWidth: "inherit", alignSelf: 'center' }}>
                            <button
                                type="button"
                                className="btn btn-circle btn-white"
                                onClick={() => this.props.onClickClose()}
                            >
Deni Rinaldi's avatar
Deni Rinaldi committed
443
                                <img src={Images.close} />
d.arizona's avatar
d.arizona committed
444 445 446 447 448 449
                            </button>
                        </div>
                    </div>

                    <div className="grid grid-2x grid-mobile-none gap-15px" style={{ padding: 20 }}>
                        <div className="column-1">
d.arizona's avatar
d.arizona committed
450
                            <div className="">
d.arizona's avatar
d.arizona committed
451 452 453 454 455 456 457
                                <TextField
                                    style={{ width: '100%' }}
                                    id="id"
                                    label="ID"
                                    disabled
                                    // id="outlined-read-only-input"
                                    variant="filled"
d.arizona's avatar
d.arizona committed
458
                                    value={'-'}
d.arizona's avatar
d.arizona committed
459
                                    onChange={(e) => null}
a.bairuha's avatar
a.bairuha committed
460 461 462 463 464 465 466 467 468 469 470 471 472
                                    inputProps={{
                                        style: {
                                            fontSize: 11,
                                            fontFamily: 'Nunito Sans, sans-serif',
                                        }
                                    }}
                                    InputLabelProps={{
                                        style: {
                                            fontSize: 11,
                                            fontFamily: 'Nunito Sans, sans-serif',
                                            color: '#7e8085',
                                        }
                                    }}
d.arizona's avatar
d.arizona committed
473 474 475 476 477 478 479 480 481 482 483
                                >
                                    {/* {periode.map((option) => (
                                        <MenuItem key={option.value} value={option.value}>
                                            {option.label}
                                        </MenuItem>
                                    ))} */}
                                </TextField>
                            </div>
                        </div>

                        <div className="column-2">
d.arizona's avatar
d.arizona committed
484 485 486 487 488
                            <div className="">
                                <TextField
                                style={{ width: '100%' , marginTop: 7}}
                                id="fullname"
                                name="fullname"
d.arizona's avatar
d.arizona committed
489
                                label="Full Name"
d.arizona's avatar
d.arizona committed
490
                                value={this.state.fullname}
a.bairuha's avatar
a.bairuha committed
491 492
                                error={this.state.errorFullname}
                                helperText={this.state.msgErrorFN}
d.arizona's avatar
d.arizona committed
493
                                onChange={(e) => this.handleChange(e, '')}
a.bairuha's avatar
a.bairuha committed
494 495 496 497 498 499 500 501 502 503 504 505 506
                                inputProps={{
                                    style: {
                                        fontSize: 11,
                                        fontFamily: 'Nunito Sans, sans-serif',
                                    }
                                }}
                                InputLabelProps={{
                                    style: {
                                        fontSize: 11,
                                        fontFamily: 'Nunito Sans, sans-serif',
                                        color: '#7e8085',
                                    }
                                }}
d.arizona's avatar
d.arizona committed
507 508 509 510 511 512 513 514 515
                                // defaultValue="Default Value"
                                // helperText="Some important text"
                                />
                            </div>
                        </div>
                    </div>

                    <div className="grid grid-2x grid-mobile-none gap-15px" style={{ paddingLeft: 20, paddingRight: 20 }}>
                        <div className="column-1">
d.arizona's avatar
d.arizona committed
516 517 518
                            <div className="margin-bottom-20px">
                                <TextField
                                style={{ width: '100%' , marginTop: 7}}
d.arizona's avatar
d.arizona committed
519 520 521
                                id="email"
                                name="email"
                                label="Email"
d.arizona's avatar
d.arizona committed
522
                                value={this.state.email}
a.bairuha's avatar
a.bairuha committed
523 524
                                error={this.state.errorEmail}
                                helperText={this.state.msgErrorEM}
d.arizona's avatar
d.arizona committed
525
                                onChange={(e) => this.handleChange(e, '')}
a.bairuha's avatar
a.bairuha committed
526 527 528 529 530 531 532 533 534 535 536 537 538
                                inputProps={{
                                    style: {
                                        fontSize: 11,
                                        fontFamily: 'Nunito Sans, sans-serif',
                                    }
                                }}
                                InputLabelProps={{
                                    style: {
                                        fontSize: 11,
                                        fontFamily: 'Nunito Sans, sans-serif',
                                        color: '#7e8085',
                                    }
                                }}
d.arizona's avatar
d.arizona committed
539 540 541 542 543
                                // defaultValue="Default Value"
                                // helperText="Some important text"
                                />
                            </div>
                        </div>
d.arizona's avatar
d.arizona committed
544 545 546 547 548 549

                        <div className="column-2">
                            <div className="margin-bottom-20px">
                                <Autocomplete
                                    {...this.state.listRole}
                                    id="role"
a.bairuha's avatar
a.bairuha committed
550
                                    onChange={(event, newInputValue) => this.setState({ role: newInputValue }, ()=> this.clearError())}
d.arizona's avatar
d.arizona committed
551
                                    debug
a.bairuha's avatar
a.bairuha committed
552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569
                                    renderInput={(params) => 
                                    <TextField 
                                        {...params} 
                                        label="Role" 
                                        margin="normal" 
                                        style={{marginTop: 7}}
                                        onChange={(e) => this.handleChange(e, '')}
                                        error={this.state.errorRoleName}
                                        helperText={this.state.msgErrorRN}
                                        InputLabelProps={{
                                            style: {
                                                fontSize: 11,
                                                fontFamily: 'Nunito Sans, sans-serif',
                                                color: '#7e8085'
                                            }
                                        }}
                                        InputProps={{ ...params.InputProps, style: { fontSize: 11, fontFamily: 'Nunito Sans, sans-serif' } }}
                                        />}
d.arizona's avatar
d.arizona committed
570 571 572 573
                                    value={this.state.role}
                                />
                            </div>
                        </div>
d.arizona's avatar
d.arizona committed
574 575 576
                    </div>

                    <div className="grid grid-2x grid-mobile-none gap-15px" style={{ paddingLeft: 20, paddingRight: 20 }}>
Deni Rinaldi's avatar
Deni Rinaldi committed
577
                        <div className="column-1">
d.arizona's avatar
d.arizona committed
578
                            <div className="margin-bottom-20px">
d.arizona's avatar
d.arizona committed
579 580 581
                                <DatePicker
                                    margin="normal"
                                    id="startDate"
582
                                    label="Valid From"
d.arizona's avatar
d.arizona committed
583 584 585 586 587 588 589 590
                                    format="dd MMMM yyyy"
                                    value={this.state.startDate}
                                    error={this.state.errorStartDate}
                                    helperText={this.state.msgErrorSD}
                                    onChange={(e) => this.handleChange(e, 'start_date')}
                                    KeyboardButtonProps={{
                                        'aria-label': 'change date',
                                    }}
a.bairuha's avatar
a.bairuha committed
591 592 593 594 595 596 597 598 599 600 601 602 603
                                    inputProps={{
                                        style: {
                                            fontSize: 11,
                                            fontFamily: 'Nunito Sans, sans-serif',
                                        }
                                    }}
                                    InputLabelProps={{
                                        style: {
                                            fontSize: 11,
                                            color: '#7e8085',
                                            fontFamily: 'Nunito Sans, sans-serif',
                                        }
                                    }}
d.arizona's avatar
d.arizona committed
604 605

                                    style={{ padding: 0, margin: 0, width: '100%' }}
d.arizona's avatar
d.arizona committed
606 607 608 609 610 611
                                />
                            </div>
                        </div>

                        <div className="column-2">
                            <div className="margin-bottom-20px">
d.arizona's avatar
d.arizona committed
612 613 614
                                <DatePicker
                                    margin="normal"
                                    id="endDate"
615
                                    label="Valid To"
d.arizona's avatar
d.arizona committed
616 617 618 619 620 621 622 623 624
                                    format="dd MMMM yyyy"
                                    value={this.state.endDate}
                                    error={this.state.errorEndDate}
                                    helperText={this.state.msgErrorED}
                                    minDate={this.state.startDate}
                                    onChange={(e) => this.handleChange(e, 'end_date')}
                                    KeyboardButtonProps={{
                                        'aria-label': 'change date',
                                    }}
a.bairuha's avatar
a.bairuha committed
625 626 627 628 629 630 631 632 633 634 635 636 637
                                    inputProps={{
                                        style: {
                                            fontSize: 11,
                                            fontFamily: 'Nunito Sans, sans-serif',
                                        }
                                    }}
                                    InputLabelProps={{
                                        style: {
                                            fontSize: 11,
                                            color: '#7e8085',
                                            fontFamily: 'Nunito Sans, sans-serif',
                                        }
                                    }}
d.arizona's avatar
d.arizona committed
638 639

                                    style={{ padding: 0, margin: 0, width: '100%' }}
d.arizona's avatar
d.arizona committed
640 641 642 643 644 645 646 647 648 649 650 651 652 653 654
                                />
                            </div>
                        </div>
                    </div>

                    <div className="grid grid-2x grid-mobile-none gap-15px" style={{ paddingLeft: 20, paddingRight: 20 }}>
                        <div className="column-1">
                            <div className="margin-bottom-20px">
                                <TextField
                                    style={{ width: '100%' }}
                                    id="status"
                                    label="Status"
                                    disabled
                                    // id="outlined-read-only-input"
                                    variant="filled"
d.arizona's avatar
d.arizona committed
655
                                    value={'Active'}
a.bairuha's avatar
a.bairuha committed
656 657 658 659 660 661 662 663 664 665 666 667 668
                                    inputProps={{
                                        style: {
                                            fontSize: 11,
                                            fontFamily: 'Nunito Sans, sans-serif',
                                        }
                                    }}
                                    InputLabelProps={{
                                        style: {
                                            fontSize: 11,
                                            color: '#7e8085',
                                            fontFamily: 'Nunito Sans, sans-serif',
                                        }
                                    }}
d.arizona's avatar
d.arizona committed
669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688
                                >
                                    {/* {periode.map((option) => (
                                        <MenuItem key={option.value} value={option.value}>
                                            {option.label}
                                        </MenuItem>
                                    ))} */}
                                </TextField>
                            </div>
                        </div>

                        <div className="column-2">
                            <div className="margin-bottom-20px">
                                <TextField
                                    style={{ width: '100%' }}
                                    id="is_expired"
                                    name="is_expired"
                                    label="Expired"
                                    disabled
                                    // id="outlined-read-only-input"
                                    variant="filled"
d.arizona's avatar
d.arizona committed
689
                                    value={'N'}
a.bairuha's avatar
a.bairuha committed
690 691 692 693 694 695 696 697 698 699 700 701 702
                                    inputProps={{
                                        style: {
                                            fontSize: 11,
                                            fontFamily: 'Nunito Sans, sans-serif',
                                        }
                                    }}
                                    InputLabelProps={{
                                        style: {
                                            fontSize: 11,
                                            color: '#7e8085',
                                            fontFamily: 'Nunito Sans, sans-serif',
                                        }
                                    }}
d.arizona's avatar
d.arizona committed
703 704 705 706 707 708 709 710 711 712
                                >
                                    {/* {periode.map((option) => (
                                        <MenuItem key={option.value} value={option.value}>
                                            {option.label}
                                        </MenuItem>
                                    ))} */}
                                </TextField>
                            </div>
                        </div>
                    </div>
d.arizona's avatar
d.arizona committed
713
                    {/* <div style={{ flexDirection: 'column', display: 'flex', paddingLeft: 20, paddingRight: 20 }}>
a.bairuha's avatar
a.bairuha committed
714 715
                        <Typography style={{ fontSize: 12 }}>{`Dibuat: `}</Typography>
                        <Typography style={{fontSize: 12}}>{`Diubah: `}</Typography>
d.arizona's avatar
d.arizona committed
716
                    </div> */}
Deni Rinaldi's avatar
Deni Rinaldi committed
717 718
                    <Divider style={{ margin: 20 }} />
                    <div style={{ paddingLeft: 20, paddingRight: 20 }}>
d.arizona's avatar
d.arizona committed
719
                        <h5>Authorization Company</h5>
Deni Rinaldi's avatar
Deni Rinaldi committed
720 721 722
                        <div style={{ paddingLeft: 10, overflow: 'scroll', height: '25vh' }}>
                            {this.state.listCompany.map((item, index) => {
                                return (
d.arizona's avatar
d.arizona committed
723
                                    <div>
d.arizona's avatar
d.arizona committed
724 725
                                        {/* <ul>
                                            <li> */}
Deni Rinaldi's avatar
Deni Rinaldi committed
726
                                        <div style={{ display: 'flex', flexDirection: 'row', alignItems: 'center', justifyContent: 'flex-start' }}>
727
                                            {item.children && item.children.length > 0 && <span onClick={() => this.handleCollapse(item)} style={{ marginLeft: 7, marginRight: 2 }}>
Deni Rinaldi's avatar
Deni Rinaldi committed
728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750
                                                {item.collapse ? <RemoveIcon color={'action'} fontSize={'small'} /> : <AddIcon color={'action'} fontSize={'small'} />}
                                            </span>}
                                            <span>
                                                {this.state.role ? this.state.role.role_id === 1 ?
                                                    <CustomCheckboxDisabled
                                                        disabled={true}
                                                        checked={true}
                                                    // onChange={() => this.handleItemClick(item)}
                                                    /> :
                                                    <CustomCheckbox
                                                        checked={this.handleItemChecked(item)}
                                                        onChange={() => this.handleItemClick(item)}
                                                    /> :
                                                    <CustomCheckbox
                                                        checked={this.handleItemChecked(item)}
                                                        onChange={() => this.handleItemClick(item)}
                                                    />
                                                }
                                            </span>
                                            <Typography style={{ fontSize: 12 }}>{titleCase(item.company_name)}</Typography>
                                        </div>
                                        {!R.isNil(item.children) && this.renderChildren(item)}
                                        {/* </li>
d.arizona's avatar
d.arizona committed
751
                                        </ul> */}
d.arizona's avatar
d.arizona committed
752 753 754 755
                                    </div>
                                )
                            })}
                        </div>
d.arizona's avatar
d.arizona committed
756 757 758
                    </div>
                    <div className="border-top grid grid-2x" style={{ height: 56, backgroundColor: '#f5f5f5', paddingLeft: 20, paddingRight: 20 }}>
                        <div className="column-1" style={{ alignSelf: 'center' }}>
d.arizona's avatar
d.arizona committed
759 760
                            <button onClick={() => this.props.onClickClose()}>
                                <div style={{ width: 102, height: 30, border: 'solid 1px #354960', borderRadius: 5, alignItems: 'center', display: 'flex', justifyContent: 'center' }}>
d.arizona's avatar
d.arizona committed
761
                                    <span style={{ color: '#354960', fontSize: 11 }}>Cancel</span>
d.arizona's avatar
d.arizona committed
762 763
                                </div>
                            </button>
d.arizona's avatar
d.arizona committed
764
                        </div>
Deni Rinaldi's avatar
Deni Rinaldi committed
765
                        <div className="column-2" style={{ display: 'flex', justifyContent: 'flex-end', alignItems: 'center' }}>
d.arizona's avatar
d.arizona committed
766 767
                            <button onClick={() => this.validasi()}>
                                <div style={{ width: 102, height: 30, backgroundColor: '#354960', borderRadius: 5, alignItems: 'center', display: 'flex', justifyContent: 'center' }}>
d.arizona's avatar
d.arizona committed
768
                                    <span style={{ color: '#fff', fontSize: 11 }}>Save</span>
d.arizona's avatar
d.arizona committed
769 770
                                </div>
                            </button>
d.arizona's avatar
d.arizona committed
771 772 773 774 775 776 777
                        </div>
                    </div>
                </div>
            </div>
        );
    }
}