/*
	GoToSocial
	Copyright (C) 2021-2023 GoToSocial Authors admin@gotosocial.org
	This program is free software: you can redistribute it and/or modify
	it under the terms of the GNU Affero General Public License as published by
	the Free Software Foundation, either version 3 of the License, or
	(at your option) any later version.
	This program is distributed in the hope that it will be useful,
	but WITHOUT ANY WARRANTY; without even the implied warranty of
	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
	GNU Affero General Public License for more details.
	You should have received a copy of the GNU Affero General Public License
	along with this program.  If not, see .
*/
"use strict";
const React = require("react");
const { Switch, Route, Redirect, useLocation } = require("wouter");
const query = require("../../lib/query");
const {
	useTextInput,
	useBoolInput,
	useRadioInput,
	useCheckListInput
} = require("../../lib/form");
const useFormSubmit = require("../../lib/form/submit");
const {
	TextInput,
	TextArea,
	Checkbox,
	Select,
	RadioGroup
} = require("../../components/form/inputs");
const CheckList = require("../../components/check-list");
const MutationButton = require("../../components/form/mutation-button");
const isValidDomain = require("is-valid-domain");
const FormWithData = require("../../lib/form/form-with-data");
const { Error } = require("../../components/error");
const ExportFormatTable = require("./export-format-table");
const baseUrl = "/settings/admin/federation/import-export";
module.exports = function ImportExport() {
	const [updateFromFile, setUpdateFromFile] = React.useState(false);
	const form = {
		domains: useTextInput("domains"),
		exportType: useTextInput("exportType", { defaultValue: "plain", dontReset: true })
	};
	const [submitParse, parseResult] = useFormSubmit(form, query.useProcessDomainListMutation());
	const [submitExport, exportResult] = useFormSubmit(form, query.useExportDomainListMutation());
	function fileChanged(e) {
		const reader = new FileReader();
		reader.onload = function (read) {
			form.domains.setter(read.target.result);
			setUpdateFromFile(true);
		};
		reader.readAsText(e.target.files[0]);
	}
	React.useEffect(() => {
		if (exportResult.isSuccess) {
			form.domains.setter(exportResult.data);
		}
		/* eslint-disable-next-line react-hooks/exhaustive-deps */
	}, [exportResult]);
	const [_location, setLocation] = useLocation();
	if (updateFromFile) {
		setUpdateFromFile(false);
		submitParse();
	}
	return (
		
			
				{!parseResult.isSuccess && }
				
					 {
						parseResult.reset();
						setLocation(baseUrl);
					}}>
						< back
					 Confirm import:
				
				
			
			
				{parseResult.isSuccess && }
				Import / Export suspended domains
				
					This page can be used to import and export lists of domains to suspend.
					Exports can be done in various formats, with varying functionality and support in other software.
					Imports will automatically detect what format is being processed.
				
				
				
					
					
						 submitParse()} result={parseResult} showError={false} />
						 submitExport("export")} result={exportResult} showError={false} />
					
					
					{parseResult.error && 
}
					{exportResult.error && 
}
				
 
			
		
	);
};
function ImportList({ list, data: blockedInstances }) {
	const hasComment = React.useMemo(() => {
		let hasPublic = false;
		let hasPrivate = false;
		list.some((entry) => {
			if (entry.public_comment?.length > 0) {
				hasPublic = true;
			}
			if (entry.private_comment?.length > 0) {
				hasPrivate = true;
			}
			return hasPublic && hasPrivate;
		});
		if (hasPublic && hasPrivate) {
			return { both: true };
		} else if (hasPublic) {
			return { type: "public_comment" };
		} else if (hasPrivate) {
			return { type: "private_comment" };
		} else {
			return {};
		}
	}, [list]);
	const showComment = useTextInput("showComment", { defaultValue: hasComment.type ?? "public_comment" });
	let commentName = "";
	if (showComment.value == "public_comment") { commentName = "Public comment"; }
	if (showComment.value == "private_comment") { commentName = "Private comment"; }
	const form = {
		domains: useCheckListInput("domains", {
			entries: list,
			uniqueKey: "domain"
		}),
		obfuscate: useBoolInput("obfuscate"),
		privateComment: useTextInput("private_comment", {
			defaultValue: `Imported on ${new Date().toLocaleString()}`
		}),
		privateCommentBehavior: useRadioInput("private_comment_behavior", {
			defaultValue: "append",
			options: {
				append: "Append to",
				replace: "Replace"
			}
		}),
		publicComment: useTextInput("public_comment"),
		publicCommentBehavior: useRadioInput("public_comment_behavior", {
			defaultValue: "append",
			options: {
				append: "Append to",
				replace: "Replace"
			}
		}),
	};
	const [importDomains, importResult] = useFormSubmit(form, query.useImportDomainListMutation(), { changedOnly: false });
	return (
		<>
			
		>
	);
}
function DomainEntry({ entry, onChange, blockedInstances, commentType }) {
	const domainField = useTextInput("domain", {
		defaultValue: entry.domain,
		validator: (value) => {
			return (entry.checked && !isValidDomain(value, { wildcard: true, allowUnicode: true }))
				? "Invalid domain"
				: "";
		}
	});
	React.useEffect(() => {
		onChange({ valid: domainField.valid });
		/* eslint-disable-next-line react-hooks/exhaustive-deps */
	}, [domainField.valid]);
	let icon = null;
	if (blockedInstances[domainField.value] != undefined) {
		icon = (
			<>
				
				Domain block already exists.
			>
		);
	}
	return (
		<>
			 {
					domainField.onChange(e);
					onChange({ domain: e.target.value, checked: true });
				}}
			/>
			{icon}
			{entry[commentType]}
		>
	);
}