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: []
		};
	}
	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);
	};
	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.",
		});
		this.setState({
			files: [],
		});
		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 } = 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 thumbs = files.map((file, index) => (
			
				  {file.name}
				
			
		));
		const thumbsBA = filesBeritaAcara.map((file, index) => (
			
				  {file.name}
				
			
		));
		return (
			
		);
	}
}
export default UploadSurat;