import React, { Component } from "react";
import { Row, Col, Input, FormGroup, Label, Progress } from "reactstrap";
import Select from "react-select";
import DatePicker from "react-datepicker";
import "react-datepicker/dist/react-datepicker.css";
// import "react-datepicker/dist/react-datepicker.css";
import ms from "ms";
import { addDays, addMonths } from 'date-fns';
import id from 'date-fns/locale/id';
// registerLocale('id', id)
import { getAutoSave, inputAutoSave } from "@/actions/autosave";
let Dropzone = null;
class DropzoneWrapper extends Component {
state = {
isClient: false,
};
componentDidMount = () => {
Dropzone = require("react-dropzone").default;
this.setState({ isClient: true });
};
render() {
return Dropzone ? {this.props.children} : null;
}
}
const data = [
{
value: "Sanksi Administratif Sedang",
// label_sanksi: "- Sanksi Administratif ringan"
},
{
sanksi: "Penghentian Pembinaan PT",
value: "Penghentian Pembinaan PT",
label_sanksi: "- Sanksi Administratif Berat",
},
{
sanksi: "Pencabutan Izin Perguruan Tinggi Swasta",
value: "Pencabutan Izin Perguruan Tinggi Swasta",
label_sanksi: "- Sanksi Administratif Berat",
},
{
sanksi: "Penghentian Pembinaan Program Studi",
value: "Penghentian Pembinaan Program Studi",
label_sanksi: "- Sanksi Administratif Berat",
},
{
sanksi: "Pencabutan Izin Program Studi",
value: "Pencabutan Izin Program Studi",
label_sanksi: "- Sanksi Administratif Berat",
},
{
sanksi: "Pembubaran Perguruan Tinggi Negeri",
value: "Pembubaran Perguruan Tinggi Negeri",
label_sanksi: "- Sanksi Administratif Berat",
},
];
const listSanksi = data.map((d) => ({
value: d.value,
label: d.sanksi,
label_sanksi: d.label_sanksi,
}));
const formatOptionLabel = ({ value, sanksi, label_sanksi }) => (
);
export class UploadSurat extends Component {
constructor(props) {
super(props);
const tmt_awal = new Date();
this.state = {
files: [],
nomorSanksi: "",
keterangan: "",
listSanksi: "",
startDay: tmt_awal,
maxDay: "",
isiTmt: "",
awalsanksi: "",
akhirsanksi: "",
tmtCheck: false,
filesBeritaAcara: [],
saveData: [],
terimaSuratSanksi: "",
tglAkhirKeberatan: "",
filesTandaTerimaSS: [],
};
}
onDrop = (files) => {
this.setState({
files: files.map((file) =>
Object.assign(file, {
preview: URL.createObjectURL(file),
})
),
stat: "Added " + files.length + " file(s)",
});
this.props.setUploadSuratSanksi(this.state);
};
onDropBA = (filesBeritaAcara) => {
this.setState({
filesBeritaAcara: filesBeritaAcara.map((file) =>
Object.assign(file, {
preview: URL.createObjectURL(file),
})
),
stat: "Added " + filesBeritaAcara.length + " file(s)",
});
this.props.setUploadSuratSanksi(this.state);
};
onDropTandaTerimaSS = (filesTandaTerimaSS) => {
this.setState({
filesTandaTerimaSS: filesTandaTerimaSS.map((file) =>
Object.assign(file, {
preview: URL.createObjectURL(file),
})
),
stat: "Added " + filesTandaTerimaSS.length + " file(s)",
});
this.props.setUploadSuratSanksi(this.state);
};
componentDidMount = async () => {
const { query, token } = this.props;
const { id } = query;
const getDataSave = await getAutoSave({ token, id, laporan: true });
const saveData = getDataSave.data?.penetapanSanksi;
this.setState(saveData)
}
// handleAutoSave = async () => {
// const { query, token } = this.props;
// const { id } = query;
// const { nomorSanksi, keterangan } = this.state
// const saveData = await inputAutoSave({ data: { penetapanSanksi: { nomorSanksi, keterangan } }, token, id, laporan: true })
// }
uploadFiles = (e) => {
e.preventDefault();
e.stopPropagation();
this.setState({
stat: this.state.files.length ? "Dropzone ready to upload " + this.state.files.length + " file(s)" : "No files added.",
});
this.props.setUploadSuratSanksi(this.state);
};
clearFiles = (e) => {
e.preventDefault();
e.stopPropagation();
this.setState({
stat: this.state.files.length ? this.state.files.length + " file(s) cleared." : "No files to clear.",
stat: this.state.filesBeritaAcara.length ? this.state.filesBeritaAcara.length + " file(s) cleared." : "No files to clear.",
});
this.setState({
files: [],
filesBeritaAcara: [],
});
this.props.setUploadSuratSanksi(this.state);
};
clearFilesBA = (e) => {
e.preventDefault();
e.stopPropagation();
this.setState({
stat: this.state.filesBeritaAcara.length ? this.state.filesBeritaAcara.length + " file(s) cleared." : "No files to clear.",
});
this.setState({
filesBeritaAcara: [],
});
this.props.setUploadSuratSanksi(this.state);
};
clearFilesTerimaSanksi = (e) => {
e.preventDefault();
e.stopPropagation();
this.setState({
stat: this.state.filesTandaTerimaSS.length ? this.state.filesTandaTerimaSS.length + " file(s) cleared." : "No files to clear.",
});
this.setState({
filesTandaTerimaSS: [],
});
this.props.setUploadSuratSanksi(this.state);
};
toRingkasan = () => {
this.props.setUploadSuratSanksi(this.state);
};
setNomorSanksi = (e) => {
this.setState({ nomorSanksi: e.target.value }, this.toRingkasan);
};
setKeterangan = (e) => {
this.setState({ keterangan: e.target.value }, this.toRingkasan);
};
setListSanksi = (ls) => {
this.setState({ listSanksi: ls.target.value }, this.toRingkasan);
};
handleChangeListSanksi = (listSanksi) => {
this.setState({ listSanksi }, this.toRingkasan);
};
handleTmtCheck = () => {
this.setState({ tmtCheck: !this.state.tmtCheck }, this.toRingkasan);
}
render() {
const { files, filesBeritaAcara, terimaSuratSanksi, tglAkhirKeberatan, filesTandaTerimaSS, tmtCheck } = this.state;
const removeFile = file => () => {
const newFiles = [...files]
newFiles.splice(newFiles.indexOf(file), 1)
this.setState({
files: newFiles,
});
}
const removeFileBA = file => () => {
const newFiles = [...filesBeritaAcara]
newFiles.splice(newFiles.indexOf(file), 1)
this.setState({
filesBeritaAcara: newFiles,
});
}
const removeFileTandaTerimaSS = file => () => {
const newFiles = [...filesTandaTerimaSS]
newFiles.splice(newFiles.indexOf(file), 1)
this.setState({
filesTandaTerimaSS: newFiles,
});
}
const thumbs = files.map((file, index) => (
{file.name}
));
const thumbsBA = filesBeritaAcara.map((file, index) => (
{file.name}
));
const thumbsTandaTerimaSS = filesTandaTerimaSS.map((file, index) => (
{file.name}
));
return (
);
}
}
export default UploadSurat;