/*
	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 query = require("../../../lib/query");
const { isValidDomainBlock, hasBetterScope } = require("../../../lib/domain-block");
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 FormWithData = require("../../../lib/form/form-with-data");
module.exports = React.memo(
	function ProcessImport({ list }) {
		return (
			
				
			
		);
	}
);
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" });
	const form = {
		domains: useCheckListInput("domains", { entries: list }),
		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 DomainCheckList({ field, blockedInstances, commentType }) {
	const getExtraProps = React.useCallback((entry) => {
		return {
			comment: entry[commentType],
			alreadyExists: blockedInstances[entry.domain] != undefined
		};
	}, [blockedInstances, commentType]);
	const entriesWithSuggestions = React.useMemo(() => (
		Object.values(field.value).filter((entry) => entry.suggest)
	), [field.value]);
	return (
		<>
			
					Domain
					
					
						{commentType == "public_comment" && "Public comment"}
						{commentType == "private_comment" && "Private comment"}
					
				>}
				EntryComponent={DomainEntry}
				getExtraProps={getExtraProps}
			/>
			
		>
	);
}
const UpdateHint = React.memo(
	function UpdateHint({ entries, updateEntry, updateMultiple }) {
		if (entries.length == 0) {
			return null;
		}
		function changeAll() {
			updateMultiple(
				entries.map((entry) => [entry.key, { domain: entry.suggest, suggest: null }])
			);
		}
		return (
			
				
					{entries.length} {entries.length == 1 ? "entry uses" : "entries use"} a specific subdomain,
					which you might want to change to the main domain, as that includes all it's (future) subdomains.
				
				
					{entries.map((entry) => (
						
					))}
				
				{entries.length > 0 && 
change all}
			
 
		);
	}
);
const UpdateableEntry = React.memo(
	function UpdateableEntry({ entry, updateEntry }) {
		return (
			<>
				{entry.domain}
				
				{entry.suggest}
				
					updateEntry(entry.key, { domain: entry.suggest, suggest: null })
				}>change
			>
		);
	}
);
function domainValidationError(isValid) {
	return isValid ? "" : "Invalid domain";
}
function DomainEntry({ entry, onChange, extraProps: { alreadyExists, comment } }) {
	const domainField = useTextInput("domain", {
		defaultValue: entry.domain,
		showValidation: entry.checked,
		initValidation: domainValidationError(entry.valid),
		validator: (value) => domainValidationError(isValidDomainBlock(value))
	});
	React.useEffect(() => {
		if (entry.valid != domainField.valid) {
			onChange({ valid: domainField.valid });
		}
	}, [onChange, entry.valid, domainField.valid]);
	React.useEffect(() => {
		if (entry.domain != domainField.value) {
			domainField.setter(entry.domain);
		}
		// domainField.setter is enough, eslint wants domainField
		// eslint-disable-next-line react-hooks/exhaustive-deps
	}, [entry.domain, domainField.setter]);
	React.useEffect(() => {
		onChange({ suggest: hasBetterScope(domainField.value) });
		// only need this update if it's the entry.checked that updated, not onChange
		// eslint-disable-next-line react-hooks/exhaustive-deps
	}, [domainField.value]);
	function clickIcon(e) {
		if (entry.suggest) {
			e.stopPropagation();
			e.preventDefault();
			domainField.setter(entry.suggest);
			onChange({ domain: entry.suggest, checked: true });
		}
	}
	return (
		<>
			 {
					domainField.onChange(e);
					onChange({ domain: e.target.value, checked: true });
				}}
			/>
			
				
			
			{comment}
		>
	);
}
function DomainEntryIcon({ alreadyExists, suggestion }) {
	let icon;
	let text;
	if (suggestion) {
		icon = "fa-info-circle suggest-changes";
		text = `Entry targets a specific subdomain, consider changing it to '${suggestion}'.`;
	} else if (alreadyExists) {
		icon = "fa-history already-blocked";
		text = "Domain block already exists.";
	}
	if (!icon) {
		return null;
	}
	return (
		<>
			
			{text}
		>
	);
}