import { Component, InfernoMouseEvent, linkEvent } from "inferno"; import { Prompt } from "inferno-router"; import { CreateSite, EditSite, GetSiteResponse, ListingType, RegistrationMode, } from "lemmy-js-client"; import { i18n } from "../../i18next"; import { WebSocketService } from "../../services"; import { capitalizeFirstLetter, fetchThemeList, myAuth, wsClient, } from "../../utils"; import { Icon, Spinner } from "../common/icon"; import { ImageUploadForm } from "../common/image-upload-form"; import { LanguageSelect } from "../common/language-select"; import { ListingTypeSelect } from "../common/listing-type-select"; import { MarkdownTextArea } from "../common/markdown-textarea"; interface SiteFormProps { siteRes: GetSiteResponse; showLocal?: boolean; } interface SiteFormState { siteForm: EditSite; loading: boolean; themeList?: string[]; } export class SiteForm extends Component { state: SiteFormState = { siteForm: { auth: "TODO", }, loading: false, }; constructor(props: any, context: any) { super(props, context); this.handleSiteSidebarChange = this.handleSiteSidebarChange.bind(this); this.handleSiteLegalInfoChange = this.handleSiteLegalInfoChange.bind(this); this.handleSiteApplicationQuestionChange = this.handleSiteApplicationQuestionChange.bind(this); this.handleIconUpload = this.handleIconUpload.bind(this); this.handleIconRemove = this.handleIconRemove.bind(this); this.handleBannerUpload = this.handleBannerUpload.bind(this); this.handleBannerRemove = this.handleBannerRemove.bind(this); this.handleDefaultPostListingTypeChange = this.handleDefaultPostListingTypeChange.bind(this); this.handleDiscussionLanguageChange = this.handleDiscussionLanguageChange.bind(this); let site = this.props.siteRes.site_view.site; let ls = this.props.siteRes.site_view.local_site; let lsrl = this.props.siteRes.site_view.local_site_rate_limit; this.state = { ...this.state, siteForm: { name: site.name, sidebar: site.sidebar, description: site.description, enable_downvotes: ls.enable_downvotes, registration_mode: ls.registration_mode, enable_nsfw: ls.enable_nsfw, community_creation_admin_only: ls.community_creation_admin_only, icon: site.icon, banner: site.banner, require_email_verification: ls.require_email_verification, application_question: ls.application_question, private_instance: ls.private_instance, default_theme: ls.default_theme, default_post_listing_type: ls.default_post_listing_type, legal_information: ls.legal_information, application_email_admins: ls.application_email_admins, hide_modlog_mod_names: ls.hide_modlog_mod_names, discussion_languages: this.props.siteRes.discussion_languages, slur_filter_regex: ls.slur_filter_regex, actor_name_max_length: ls.actor_name_max_length, rate_limit_message: lsrl.message, rate_limit_message_per_second: lsrl.message_per_second, rate_limit_comment: lsrl.comment, rate_limit_comment_per_second: lsrl.comment_per_second, rate_limit_image: lsrl.image, rate_limit_image_per_second: lsrl.image_per_second, rate_limit_post: lsrl.post, rate_limit_post_per_second: lsrl.post_per_second, rate_limit_register: lsrl.register, rate_limit_register_per_second: lsrl.register_per_second, rate_limit_search: lsrl.search, rate_limit_search_per_second: lsrl.search_per_second, federation_enabled: ls.federation_enabled, federation_debug: ls.federation_debug, federation_worker_count: ls.federation_worker_count, captcha_enabled: ls.captcha_enabled, captcha_difficulty: ls.captcha_difficulty, allowed_instances: this.props.siteRes.federated_instances?.allowed, blocked_instances: this.props.siteRes.federated_instances?.blocked, taglines: this.props.siteRes.taglines?.map(x => x.content), auth: "TODO", }, }; } async componentDidMount() { this.setState({ themeList: await fetchThemeList() }); } // Necessary to stop the loading componentWillReceiveProps() { this.setState({ loading: false }); } componentDidUpdate() { if ( !this.state.loading && !this.props.siteRes.site_view.local_site.site_setup && (this.state.siteForm.name || this.state.siteForm.sidebar || this.state.siteForm.application_question || this.state.siteForm.description) ) { window.onbeforeunload = () => true; } else { window.onbeforeunload = null; } } componentWillUnmount() { window.onbeforeunload = null; } render() { let siteSetup = this.props.siteRes.site_view.local_site.site_setup; return ( <>
{`${ siteSetup ? capitalizeFirstLetter(i18n.t("save")) : capitalizeFirstLetter(i18n.t("name")) } ${i18n.t("your_site")}`}
{this.state.siteForm.registration_mode == RegistrationMode.RequireApplication && (
)}
{this.props.showLocal && (
)}
{this.state.siteForm.federation_enabled && ( <>
)}
{this.state.siteForm.captcha_enabled && (
)}
{i18n.t("taglines")}
{this.state.siteForm.taglines?.map((cv, index) => ( ))}
this.handleTaglineChange(this, index, s) } hideNavigationWarnings allLanguages={this.props.siteRes.all_languages} siteLanguages={ this.props.siteRes.discussion_languages } />
); } handleCreateSiteSubmit(i: SiteForm, event: any) { event.preventDefault(); i.setState({ loading: true }); let auth = myAuth() ?? "TODO"; i.setState(s => ((s.siteForm.auth = auth), s)); if (i.props.siteRes.site_view.local_site.site_setup) { WebSocketService.Instance.send(wsClient.editSite(i.state.siteForm)); } else { let sForm = i.state.siteForm; let form: CreateSite = { name: sForm.name ?? "My site", sidebar: sForm.sidebar, description: sForm.description, icon: sForm.icon, banner: sForm.banner, community_creation_admin_only: sForm.community_creation_admin_only, enable_nsfw: sForm.enable_nsfw, enable_downvotes: sForm.enable_downvotes, application_question: sForm.application_question, registration_mode: sForm.registration_mode, require_email_verification: sForm.require_email_verification, private_instance: sForm.private_instance, default_theme: sForm.default_theme, default_post_listing_type: sForm.default_post_listing_type, application_email_admins: sForm.application_email_admins, hide_modlog_mod_names: sForm.hide_modlog_mod_names, legal_information: sForm.legal_information, slur_filter_regex: sForm.slur_filter_regex, actor_name_max_length: sForm.actor_name_max_length, rate_limit_message: sForm.rate_limit_message, rate_limit_message_per_second: sForm.rate_limit_message_per_second, rate_limit_comment: sForm.rate_limit_comment, rate_limit_comment_per_second: sForm.rate_limit_comment_per_second, rate_limit_image: sForm.rate_limit_image, rate_limit_image_per_second: sForm.rate_limit_image_per_second, rate_limit_post: sForm.rate_limit_post, rate_limit_post_per_second: sForm.rate_limit_post_per_second, rate_limit_register: sForm.rate_limit_register, rate_limit_register_per_second: sForm.rate_limit_register_per_second, rate_limit_search: sForm.rate_limit_search, rate_limit_search_per_second: sForm.rate_limit_search_per_second, federation_enabled: sForm.federation_enabled, federation_debug: sForm.federation_debug, federation_worker_count: sForm.federation_worker_count, captcha_enabled: sForm.captcha_enabled, captcha_difficulty: sForm.captcha_difficulty, allowed_instances: sForm.allowed_instances, blocked_instances: sForm.blocked_instances, discussion_languages: sForm.discussion_languages, taglines: sForm.taglines, auth, }; WebSocketService.Instance.send(wsClient.createSite(form)); } i.setState(i.state); } instancesToString(opt?: string[]): string { return opt ? opt.join(",") : ""; } handleSiteAllowedInstances(i: SiteForm, event: any) { let list = splitToList(event.target.value); i.setState(s => ((s.siteForm.allowed_instances = list), s)); } handleSiteBlockedInstances(i: SiteForm, event: any) { let list = splitToList(event.target.value); i.setState(s => ((s.siteForm.blocked_instances = list), s)); } handleSiteNameChange(i: SiteForm, event: any) { i.state.siteForm.name = event.target.value; i.setState(i.state); } handleSiteSidebarChange(val: string) { this.setState(s => ((s.siteForm.sidebar = val), s)); } handleSiteLegalInfoChange(val: string) { this.setState(s => ((s.siteForm.legal_information = val), s)); } handleTaglineChange(i: SiteForm, index: number, val: string) { let taglines = i.state.siteForm.taglines; if (taglines) { taglines[index] = val; i.setState(i.state); } } handleDeleteTaglineClick( i: SiteForm, index: number, event: InfernoMouseEvent ) { event.preventDefault(); let taglines = i.state.siteForm.taglines; if (taglines) { taglines.splice(index, 1); i.state.siteForm.taglines = undefined; i.setState(i.state); i.state.siteForm.taglines = taglines; i.setState(i.state); } } handleAddTaglineClick( i: SiteForm, event: InfernoMouseEvent ) { event.preventDefault(); if (!i.state.siteForm.taglines) { i.state.siteForm.taglines = []; } i.state.siteForm.taglines.push(""); i.setState(i.state); } handleSiteApplicationQuestionChange(val: string) { this.setState(s => ((s.siteForm.application_question = val), s)); } handleSiteDescChange(i: SiteForm, event: any) { i.state.siteForm.description = event.target.value; i.setState(i.state); } handleSiteEnableNsfwChange(i: SiteForm, event: any) { i.state.siteForm.enable_nsfw = event.target.checked; i.setState(i.state); } handleSiteRegistrationModeChange(i: SiteForm, event: any) { i.state.siteForm.registration_mode = event.target.value; i.setState(i.state); } handleSiteCommunityCreationAdminOnly(i: SiteForm, event: any) { i.state.siteForm.community_creation_admin_only = event.target.checked; i.setState(i.state); } handleSiteEnableDownvotesChange(i: SiteForm, event: any) { i.state.siteForm.enable_downvotes = event.target.checked; i.setState(i.state); } handleSiteRequireEmailVerification(i: SiteForm, event: any) { i.state.siteForm.require_email_verification = event.target.checked; i.setState(i.state); } handleSiteApplicationEmailAdmins(i: SiteForm, event: any) { i.state.siteForm.application_email_admins = event.target.checked; i.setState(i.state); } handleSitePrivateInstance(i: SiteForm, event: any) { i.state.siteForm.private_instance = event.target.checked; i.setState(i.state); } handleSiteHideModlogModNames(i: SiteForm, event: any) { i.state.siteForm.hide_modlog_mod_names = event.target.checked; i.setState(i.state); } handleSiteDefaultTheme(i: SiteForm, event: any) { i.state.siteForm.default_theme = event.target.value; i.setState(i.state); } handleIconUpload(url: string) { this.setState(s => ((s.siteForm.icon = url), s)); } handleIconRemove() { this.setState(s => ((s.siteForm.icon = ""), s)); } handleBannerUpload(url: string) { this.setState(s => ((s.siteForm.banner = url), s)); } handleBannerRemove() { this.setState(s => ((s.siteForm.banner = ""), s)); } handleSiteSlurFilterRegex(i: SiteForm, event: any) { i.setState(s => ((s.siteForm.slur_filter_regex = event.target.value), s)); } handleSiteActorNameMaxLength(i: SiteForm, event: any) { i.setState( s => ((s.siteForm.actor_name_max_length = Number(event.target.value)), s) ); } handleSiteRateLimitMessage(i: SiteForm, event: any) { i.setState( s => ((s.siteForm.rate_limit_message = Number(event.target.value)), s) ); } handleSiteRateLimitMessagePerSecond(i: SiteForm, event: any) { i.setState( s => ( (s.siteForm.rate_limit_message_per_second = Number(event.target.value)), s ) ); } handleSiteRateLimitPost(i: SiteForm, event: any) { i.setState( s => ((s.siteForm.rate_limit_post = Number(event.target.value)), s) ); } handleSiteRateLimitPostPerSecond(i: SiteForm, event: any) { i.setState( s => ( (s.siteForm.rate_limit_post_per_second = Number(event.target.value)), s ) ); } handleSiteRateLimitImage(i: SiteForm, event: any) { i.setState( s => ((s.siteForm.rate_limit_image = Number(event.target.value)), s) ); } handleSiteRateLimitImagePerSecond(i: SiteForm, event: any) { i.setState( s => ( (s.siteForm.rate_limit_image_per_second = Number(event.target.value)), s ) ); } handleSiteRateLimitComment(i: SiteForm, event: any) { i.setState( s => ((s.siteForm.rate_limit_comment = Number(event.target.value)), s) ); } handleSiteRateLimitCommentPerSecond(i: SiteForm, event: any) { i.setState( s => ( (s.siteForm.rate_limit_comment_per_second = Number(event.target.value)), s ) ); } handleSiteRateLimitSearch(i: SiteForm, event: any) { i.setState( s => ((s.siteForm.rate_limit_search = Number(event.target.value)), s) ); } handleSiteRateLimitSearchPerSecond(i: SiteForm, event: any) { i.setState( s => ( (s.siteForm.rate_limit_search_per_second = Number(event.target.value)), s ) ); } handleSiteRateLimitRegister(i: SiteForm, event: any) { i.setState( s => ((s.siteForm.rate_limit_register = Number(event.target.value)), s) ); } handleSiteRateLimitRegisterPerSecond(i: SiteForm, event: any) { i.setState( s => ( (s.siteForm.rate_limit_register_per_second = Number( event.target.value )), s ) ); } handleSiteFederationEnabled(i: SiteForm, event: any) { i.state.siteForm.federation_enabled = event.target.checked; i.setState(i.state); } handleSiteFederationDebug(i: SiteForm, event: any) { i.state.siteForm.federation_debug = event.target.checked; i.setState(i.state); } handleSiteFederationWorkerCount(i: SiteForm, event: any) { i.setState( s => ( (s.siteForm.federation_worker_count = Number(event.target.value)), s ) ); } handleSiteCaptchaEnabled(i: SiteForm, event: any) { i.state.siteForm.captcha_enabled = event.target.checked; i.setState(i.state); } handleSiteCaptchaDifficulty(i: SiteForm, event: any) { i.setState(s => ((s.siteForm.captcha_difficulty = event.target.value), s)); } handleDiscussionLanguageChange(val: number[]) { this.setState(s => ((s.siteForm.discussion_languages = val), s)); } handleDefaultPostListingTypeChange(val: ListingType) { this.setState( s => ( (s.siteForm.default_post_listing_type = ListingType[ListingType[val]]), s ) ); } } function splitToList(commaList: string): string[] { if (commaList !== "") { let list = commaList.trim().split(","); return list; } else { return []; } }