1 import { Component, linkEvent } from "inferno";
4 BlockCommunityResponse,
19 } from "lemmy-js-client";
20 import { Subscription } from "rxjs";
21 import { i18n, languages } from "../../i18next";
22 import { UserService, WebSocketService } from "../../services";
25 capitalizeFirstLetter,
50 import { HtmlTags } from "../common/html-tags";
51 import { Icon, Spinner } from "../common/icon";
52 import { ImageUploadForm } from "../common/image-upload-form";
53 import { ListingTypeSelect } from "../common/listing-type-select";
54 import { MarkdownTextArea } from "../common/markdown-textarea";
55 import { SortSelect } from "../common/sort-select";
56 import { CommunityLink } from "../community/community-link";
57 import { PersonListing } from "./person-listing";
61 Choices = require("choices.js");
64 interface SettingsState {
65 saveUserSettingsForm: SaveUserSettings;
66 changePasswordForm: ChangePassword;
67 saveUserSettingsLoading: boolean;
68 changePasswordLoading: boolean;
69 deleteAccountLoading: boolean;
70 deleteAccountShowConfirm: boolean;
71 deleteAccountForm: DeleteAccount;
72 personBlocks: PersonBlockView[];
73 blockPersonId: number;
74 blockPerson?: PersonViewSafe;
75 communityBlocks: CommunityBlockView[];
76 blockCommunityId: number;
77 blockCommunity?: CommunityView;
79 siteRes: GetSiteResponse;
82 export class Settings extends Component<any, SettingsState> {
83 private isoData = setIsoData(this.context);
84 private blockPersonChoices: any;
85 private blockCommunityChoices: any;
86 private subscription: Subscription;
87 private emptyState: SettingsState = {
88 saveUserSettingsForm: {
89 auth: authField(false),
93 new_password_verify: null,
95 auth: authField(false),
97 saveUserSettingsLoading: null,
98 changePasswordLoading: false,
99 deleteAccountLoading: null,
100 deleteAccountShowConfirm: false,
103 auth: authField(false),
109 currentTab: "settings",
110 siteRes: this.isoData.site_res,
113 constructor(props: any, context: any) {
114 super(props, context);
116 this.state = this.emptyState;
117 this.handleSortTypeChange = this.handleSortTypeChange.bind(this);
118 this.handleListingTypeChange = this.handleListingTypeChange.bind(this);
119 this.handleBioChange = this.handleBioChange.bind(this);
121 this.handleAvatarUpload = this.handleAvatarUpload.bind(this);
122 this.handleAvatarRemove = this.handleAvatarRemove.bind(this);
124 this.handleBannerUpload = this.handleBannerUpload.bind(this);
125 this.handleBannerRemove = this.handleBannerRemove.bind(this);
127 this.parseMessage = this.parseMessage.bind(this);
128 this.subscription = wsSubscribe(this.parseMessage);
133 componentDidMount() {
137 componentWillUnmount() {
138 this.subscription.unsubscribe();
141 get documentTitle(): string {
142 return i18n.t("settings");
147 <div class="container">
150 title={this.documentTitle}
151 path={this.context.router.route.match.url}
152 description={this.documentTitle}
153 image={this.state.saveUserSettingsForm.avatar}
155 <ul class="nav nav-tabs mb-2">
156 <li class="nav-item">
158 class={`nav-link btn ${
159 this.state.currentTab == "settings" && "active"
162 { ctx: this, tab: "settings" },
169 <li class="nav-item">
171 class={`nav-link btn ${
172 this.state.currentTab == "blocks" && "active"
175 { ctx: this, tab: "blocks" },
183 {this.state.currentTab == "settings" && this.userSettings()}
184 {this.state.currentTab == "blocks" && this.blockCards()}
193 <div class="col-12 col-md-6">
194 <div class="card border-secondary mb-3">
195 <div class="card-body">{this.saveUserSettingsHtmlForm()}</div>
198 <div class="col-12 col-md-6">
199 <div class="card border-secondary mb-3">
200 <div class="card-body">{this.changePasswordHtmlForm()}</div>
210 <div class="col-12 col-md-6">
211 <div class="card border-secondary mb-3">
212 <div class="card-body">{this.blockUserCard()}</div>
215 <div class="col-12 col-md-6">
216 <div class="card border-secondary mb-3">
217 <div class="card-body">{this.blockCommunityCard()}</div>
224 changePasswordHtmlForm() {
227 <h5>{i18n.t("change_password")}</h5>
228 <form onSubmit={linkEvent(this, this.handleChangePasswordSubmit)}>
229 <div class="form-group row">
230 <label class="col-sm-5 col-form-label" htmlFor="user-password">
231 {i18n.t("new_password")}
233 <div class="col-sm-7">
238 value={this.state.changePasswordForm.new_password}
239 autoComplete="new-password"
241 onInput={linkEvent(this, this.handleNewPasswordChange)}
245 <div class="form-group row">
247 class="col-sm-5 col-form-label"
248 htmlFor="user-verify-password"
250 {i18n.t("verify_password")}
252 <div class="col-sm-7">
255 id="user-verify-password"
257 value={this.state.changePasswordForm.new_password_verify}
258 autoComplete="new-password"
260 onInput={linkEvent(this, this.handleNewPasswordVerifyChange)}
264 <div class="form-group row">
265 <label class="col-sm-5 col-form-label" htmlFor="user-old-password">
266 {i18n.t("old_password")}
268 <div class="col-sm-7">
271 id="user-old-password"
273 value={this.state.changePasswordForm.old_password}
274 autoComplete="new-password"
276 onInput={linkEvent(this, this.handleOldPasswordChange)}
280 <div class="form-group">
281 <button type="submit" class="btn btn-block btn-secondary mr-4">
282 {this.state.changePasswordLoading ? (
285 capitalizeFirstLetter(i18n.t("save"))
297 {this.blockUserForm()}
298 {this.blockedUsersList()}
306 <h5>{i18n.t("blocked_users")}</h5>
307 <ul class="list-unstyled mb-0">
308 {this.state.personBlocks.map(pb => (
311 <PersonListing person={pb.target} />
313 className="btn btn-sm"
315 { ctx: this, recipientId: pb.target.id },
316 this.handleUnblockPerson
318 data-tippy-content={i18n.t("unblock_user")}
320 <Icon icon="x" classes="icon-inline" />
332 <div class="form-group row">
333 <label class="col-md-4 col-form-label" htmlFor="block-person-filter">
334 {i18n.t("block_user")}
336 <div class="col-md-8">
339 id="block-person-filter"
340 value={this.state.blockPersonId}
342 <option value="0">—</option>
343 {this.state.blockPerson && (
344 <option value={this.state.blockPerson.person.id}>
345 {personSelectName(this.state.blockPerson)}
354 blockCommunityCard() {
357 {this.blockCommunityForm()}
358 {this.blockedCommunitiesList()}
363 blockedCommunitiesList() {
366 <h5>{i18n.t("blocked_communities")}</h5>
367 <ul class="list-unstyled mb-0">
368 {this.state.communityBlocks.map(cb => (
371 <CommunityLink community={cb.community} />
373 className="btn btn-sm"
375 { ctx: this, communityId: cb.community.id },
376 this.handleUnblockCommunity
378 data-tippy-content={i18n.t("unblock_community")}
380 <Icon icon="x" classes="icon-inline" />
390 blockCommunityForm() {
392 <div class="form-group row">
393 <label class="col-md-4 col-form-label" htmlFor="block-community-filter">
394 {i18n.t("block_community")}
396 <div class="col-md-8">
399 id="block-community-filter"
400 value={this.state.blockCommunityId}
402 <option value="0">—</option>
403 {this.state.blockCommunity && (
404 <option value={this.state.blockCommunity.community.id}>
405 {communitySelectName(this.state.blockCommunity)}
414 saveUserSettingsHtmlForm() {
417 <h5>{i18n.t("settings")}</h5>
418 <form onSubmit={linkEvent(this, this.handleSaveSettingsSubmit)}>
419 <div class="form-group row">
420 <label class="col-sm-5 col-form-label" htmlFor="display-name">
421 {i18n.t("display_name")}
423 <div class="col-sm-7">
428 placeholder={i18n.t("optional")}
429 value={this.state.saveUserSettingsForm.display_name}
430 onInput={linkEvent(this, this.handleDisplayNameChange)}
431 pattern="^(?!@)(.+)$"
436 <div class="form-group row">
437 <label class="col-sm-3 col-form-label" htmlFor="user-bio">
440 <div class="col-sm-9">
442 initialContent={this.state.saveUserSettingsForm.bio}
443 onContentChange={this.handleBioChange}
445 hideNavigationWarnings
449 <div class="form-group row">
450 <label class="col-sm-3 col-form-label" htmlFor="user-email">
453 <div class="col-sm-9">
458 placeholder={i18n.t("optional")}
459 value={this.state.saveUserSettingsForm.email}
460 onInput={linkEvent(this, this.handleEmailChange)}
465 <div class="form-group row">
466 <label class="col-sm-5 col-form-label" htmlFor="matrix-user-id">
467 <a href={elementUrl} rel="noopener">
468 {i18n.t("matrix_user_id")}
471 <div class="col-sm-7">
476 placeholder="@user:example.com"
477 value={this.state.saveUserSettingsForm.matrix_user_id}
478 onInput={linkEvent(this, this.handleMatrixUserIdChange)}
479 pattern="^@[A-Za-z0-9._=-]+:[A-Za-z0-9.-]+\.[A-Za-z]{2,}$"
483 <div class="form-group row">
484 <label class="col-sm-3">{i18n.t("avatar")}</label>
485 <div class="col-sm-9">
487 uploadTitle={i18n.t("upload_avatar")}
488 imageSrc={this.state.saveUserSettingsForm.avatar}
489 onUpload={this.handleAvatarUpload}
490 onRemove={this.handleAvatarRemove}
495 <div class="form-group row">
496 <label class="col-sm-3">{i18n.t("banner")}</label>
497 <div class="col-sm-9">
499 uploadTitle={i18n.t("upload_banner")}
500 imageSrc={this.state.saveUserSettingsForm.banner}
501 onUpload={this.handleBannerUpload}
502 onRemove={this.handleBannerRemove}
506 <div class="form-group row">
507 <label class="col-sm-3" htmlFor="user-language">
510 <div class="col-sm-9">
513 value={this.state.saveUserSettingsForm.lang}
514 onChange={linkEvent(this, this.handleLangChange)}
515 class="custom-select w-auto"
517 <option disabled aria-hidden="true">
520 <option value="browser">{i18n.t("browser_default")}</option>
521 <option disabled aria-hidden="true">
525 .sort((a, b) => a.code.localeCompare(b.code))
527 <option value={lang.code}>{lang.name}</option>
532 <div class="form-group row">
533 <label class="col-sm-3" htmlFor="user-theme">
536 <div class="col-sm-9">
539 value={this.state.saveUserSettingsForm.theme}
540 onChange={linkEvent(this, this.handleThemeChange)}
541 class="custom-select w-auto"
543 <option disabled aria-hidden="true">
546 <option value="browser">{i18n.t("browser_default")}</option>
547 {themes.map(theme => (
548 <option value={theme}>{theme}</option>
553 <form className="form-group row">
554 <label class="col-sm-3">{i18n.t("type")}</label>
555 <div class="col-sm-9">
558 Object.values(ListingType)[
559 this.state.saveUserSettingsForm.default_listing_type
562 showLocal={showLocal(this.isoData)}
563 onChange={this.handleListingTypeChange}
567 <form className="form-group row">
568 <label class="col-sm-3">{i18n.t("sort_type")}</label>
569 <div class="col-sm-9">
572 Object.values(SortType)[
573 this.state.saveUserSettingsForm.default_sort_type
576 onChange={this.handleSortTypeChange}
580 {this.state.siteRes.site_view.site.enable_nsfw && (
581 <div class="form-group">
582 <div class="form-check">
584 class="form-check-input"
587 checked={this.state.saveUserSettingsForm.show_nsfw}
588 onChange={linkEvent(this, this.handleShowNsfwChange)}
590 <label class="form-check-label" htmlFor="user-show-nsfw">
591 {i18n.t("show_nsfw")}
596 <div class="form-group">
597 <div class="form-check">
599 class="form-check-input"
600 id="user-show-scores"
602 checked={this.state.saveUserSettingsForm.show_scores}
603 onChange={linkEvent(this, this.handleShowScoresChange)}
605 <label class="form-check-label" htmlFor="user-show-scores">
606 {i18n.t("show_scores")}
610 <div class="form-group">
611 <div class="form-check">
613 class="form-check-input"
614 id="user-show-avatars"
616 checked={this.state.saveUserSettingsForm.show_avatars}
617 onChange={linkEvent(this, this.handleShowAvatarsChange)}
619 <label class="form-check-label" htmlFor="user-show-avatars">
620 {i18n.t("show_avatars")}
624 <div class="form-group">
625 <div class="form-check">
627 class="form-check-input"
628 id="user-bot-account"
630 checked={this.state.saveUserSettingsForm.bot_account}
631 onChange={linkEvent(this, this.handleBotAccount)}
633 <label class="form-check-label" htmlFor="user-bot-account">
634 {i18n.t("bot_account")}
638 <div class="form-group">
639 <div class="form-check">
641 class="form-check-input"
642 id="user-show-bot-accounts"
644 checked={this.state.saveUserSettingsForm.show_bot_accounts}
645 onChange={linkEvent(this, this.handleShowBotAccounts)}
647 <label class="form-check-label" htmlFor="user-show-bot-accounts">
648 {i18n.t("show_bot_accounts")}
652 <div class="form-group">
653 <div class="form-check">
655 class="form-check-input"
656 id="user-show-read-posts"
658 checked={this.state.saveUserSettingsForm.show_read_posts}
659 onChange={linkEvent(this, this.handleReadPosts)}
661 <label class="form-check-label" htmlFor="user-show-read-posts">
662 {i18n.t("show_read_posts")}
666 <div class="form-group">
667 <div class="form-check">
669 class="form-check-input"
670 id="user-show-new-post-notifs"
672 checked={this.state.saveUserSettingsForm.show_new_post_notifs}
673 onChange={linkEvent(this, this.handleShowNewPostNotifs)}
676 class="form-check-label"
677 htmlFor="user-show-new-post-notifs"
679 {i18n.t("show_new_post_notifs")}
683 <div class="form-group">
684 <div class="form-check">
686 class="form-check-input"
687 id="user-send-notifications-to-email"
689 disabled={!this.state.saveUserSettingsForm.email}
691 this.state.saveUserSettingsForm.send_notifications_to_email
695 this.handleSendNotificationsToEmailChange
699 class="form-check-label"
700 htmlFor="user-send-notifications-to-email"
702 {i18n.t("send_notifications_to_email")}
706 <div class="form-group">
707 <button type="submit" class="btn btn-block btn-secondary mr-4">
708 {this.state.saveUserSettingsLoading ? (
711 capitalizeFirstLetter(i18n.t("save"))
716 <div class="form-group">
718 class="btn btn-block btn-danger"
721 this.handleDeleteAccountShowConfirmToggle
724 {i18n.t("delete_account")}
726 {this.state.deleteAccountShowConfirm && (
728 <div class="my-2 alert alert-danger" role="alert">
729 {i18n.t("delete_account_confirm")}
733 value={this.state.deleteAccountForm.password}
734 autoComplete="new-password"
738 this.handleDeleteAccountPasswordChange
740 class="form-control my-2"
743 class="btn btn-danger mr-4"
744 disabled={!this.state.deleteAccountForm.password}
745 onClick={linkEvent(this, this.handleDeleteAccount)}
747 {this.state.deleteAccountLoading ? (
750 capitalizeFirstLetter(i18n.t("delete"))
754 class="btn btn-secondary"
757 this.handleDeleteAccountShowConfirmToggle
770 setupBlockPersonChoices() {
772 let selectId: any = document.getElementById("block-person-filter");
774 this.blockPersonChoices = new Choices(selectId, choicesConfig);
775 this.blockPersonChoices.passedElement.element.addEventListener(
778 this.handleBlockPerson(Number(e.detail.choice.value));
782 this.blockPersonChoices.passedElement.element.addEventListener(
784 debounce(async (e: any) => {
786 let persons = (await fetchUsers(e.detail.value)).users;
787 let choices = persons.map(pvs => personToChoice(pvs));
788 this.blockPersonChoices.setChoices(
804 setupBlockCommunityChoices() {
806 let selectId: any = document.getElementById("block-community-filter");
808 this.blockCommunityChoices = new Choices(selectId, choicesConfig);
809 this.blockCommunityChoices.passedElement.element.addEventListener(
812 this.handleBlockCommunity(Number(e.detail.choice.value));
816 this.blockCommunityChoices.passedElement.element.addEventListener(
818 debounce(async (e: any) => {
820 let communities = (await fetchCommunities(e.detail.value))
822 let choices = communities.map(cv => communityToChoice(cv));
823 this.blockCommunityChoices.setChoices(
839 handleBlockPerson(personId: number) {
841 let blockUserForm: BlockPerson = {
846 WebSocketService.Instance.send(wsClient.blockPerson(blockUserForm));
850 handleUnblockPerson(i: { ctx: Settings; recipientId: number }) {
851 let blockUserForm: BlockPerson = {
852 person_id: i.recipientId,
856 WebSocketService.Instance.send(wsClient.blockPerson(blockUserForm));
859 handleBlockCommunity(community_id: number) {
860 if (community_id != 0) {
861 let blockCommunityForm: BlockCommunity = {
866 WebSocketService.Instance.send(
867 wsClient.blockCommunity(blockCommunityForm)
872 handleUnblockCommunity(i: { ctx: Settings; communityId: number }) {
873 let blockCommunityForm: BlockCommunity = {
874 community_id: i.communityId,
878 WebSocketService.Instance.send(wsClient.blockCommunity(blockCommunityForm));
881 handleShowNsfwChange(i: Settings, event: any) {
882 i.state.saveUserSettingsForm.show_nsfw = event.target.checked;
886 handleShowAvatarsChange(i: Settings, event: any) {
887 i.state.saveUserSettingsForm.show_avatars = event.target.checked;
888 UserService.Instance.myUserInfo.local_user_view.local_user.show_avatars =
889 event.target.checked; // Just for instant updates
893 handleBotAccount(i: Settings, event: any) {
894 i.state.saveUserSettingsForm.bot_account = event.target.checked;
898 handleShowBotAccounts(i: Settings, event: any) {
899 i.state.saveUserSettingsForm.show_bot_accounts = event.target.checked;
903 handleReadPosts(i: Settings, event: any) {
904 i.state.saveUserSettingsForm.show_read_posts = event.target.checked;
908 handleShowNewPostNotifs(i: Settings, event: any) {
909 i.state.saveUserSettingsForm.show_new_post_notifs = event.target.checked;
913 handleShowScoresChange(i: Settings, event: any) {
914 i.state.saveUserSettingsForm.show_scores = event.target.checked;
915 UserService.Instance.myUserInfo.local_user_view.local_user.show_scores =
916 event.target.checked; // Just for instant updates
920 handleSendNotificationsToEmailChange(i: Settings, event: any) {
921 i.state.saveUserSettingsForm.send_notifications_to_email =
922 event.target.checked;
926 handleThemeChange(i: Settings, event: any) {
927 i.state.saveUserSettingsForm.theme = event.target.value;
928 setTheme(event.target.value, true);
932 handleLangChange(i: Settings, event: any) {
933 i.state.saveUserSettingsForm.lang = event.target.value;
934 i18n.changeLanguage(getLanguages(i.state.saveUserSettingsForm.lang)[0]);
938 handleSortTypeChange(val: SortType) {
939 this.state.saveUserSettingsForm.default_sort_type =
940 Object.keys(SortType).indexOf(val);
941 this.setState(this.state);
944 handleListingTypeChange(val: ListingType) {
945 this.state.saveUserSettingsForm.default_listing_type =
946 Object.keys(ListingType).indexOf(val);
947 this.setState(this.state);
950 handleEmailChange(i: Settings, event: any) {
951 i.state.saveUserSettingsForm.email = event.target.value;
955 handleBioChange(val: string) {
956 this.state.saveUserSettingsForm.bio = val;
957 this.setState(this.state);
960 handleAvatarUpload(url: string) {
961 this.state.saveUserSettingsForm.avatar = url;
962 this.setState(this.state);
965 handleAvatarRemove() {
966 this.state.saveUserSettingsForm.avatar = "";
967 this.setState(this.state);
970 handleBannerUpload(url: string) {
971 this.state.saveUserSettingsForm.banner = url;
972 this.setState(this.state);
975 handleBannerRemove() {
976 this.state.saveUserSettingsForm.banner = "";
977 this.setState(this.state);
980 handleDisplayNameChange(i: Settings, event: any) {
981 i.state.saveUserSettingsForm.display_name = event.target.value;
985 handleMatrixUserIdChange(i: Settings, event: any) {
986 i.state.saveUserSettingsForm.matrix_user_id = event.target.value;
988 i.state.saveUserSettingsForm.matrix_user_id == "" &&
989 !UserService.Instance.myUserInfo.local_user_view.person.matrix_user_id
991 i.state.saveUserSettingsForm.matrix_user_id = undefined;
996 handleNewPasswordChange(i: Settings, event: any) {
997 i.state.changePasswordForm.new_password = event.target.value;
998 if (i.state.changePasswordForm.new_password == "") {
999 i.state.changePasswordForm.new_password = undefined;
1001 i.setState(i.state);
1004 handleNewPasswordVerifyChange(i: Settings, event: any) {
1005 i.state.changePasswordForm.new_password_verify = event.target.value;
1006 if (i.state.changePasswordForm.new_password_verify == "") {
1007 i.state.changePasswordForm.new_password_verify = undefined;
1009 i.setState(i.state);
1012 handleOldPasswordChange(i: Settings, event: any) {
1013 i.state.changePasswordForm.old_password = event.target.value;
1014 if (i.state.changePasswordForm.old_password == "") {
1015 i.state.changePasswordForm.old_password = undefined;
1017 i.setState(i.state);
1020 handleSaveSettingsSubmit(i: Settings, event: any) {
1021 event.preventDefault();
1022 i.state.saveUserSettingsLoading = true;
1023 i.setState(i.state);
1025 WebSocketService.Instance.send(
1026 wsClient.saveUserSettings(i.state.saveUserSettingsForm)
1030 handleChangePasswordSubmit(i: Settings, event: any) {
1031 event.preventDefault();
1032 i.state.changePasswordLoading = true;
1033 i.setState(i.state);
1035 WebSocketService.Instance.send(
1036 wsClient.changePassword(i.state.changePasswordForm)
1040 handleDeleteAccountShowConfirmToggle(i: Settings, event: any) {
1041 event.preventDefault();
1042 i.state.deleteAccountShowConfirm = !i.state.deleteAccountShowConfirm;
1043 i.setState(i.state);
1046 handleDeleteAccountPasswordChange(i: Settings, event: any) {
1047 i.state.deleteAccountForm.password = event.target.value;
1048 i.setState(i.state);
1051 handleDeleteAccount(i: Settings, event: any) {
1052 event.preventDefault();
1053 i.state.deleteAccountLoading = true;
1054 i.setState(i.state);
1056 WebSocketService.Instance.send(
1057 wsClient.deleteAccount(i.state.deleteAccountForm)
1061 handleSwitchTab(i: { ctx: Settings; tab: string }) {
1062 i.ctx.setState({ currentTab: i.tab });
1064 if (i.ctx.state.currentTab == "blocks") {
1065 i.ctx.setupBlockPersonChoices();
1066 i.ctx.setupBlockCommunityChoices();
1071 let luv = UserService.Instance.myUserInfo.local_user_view;
1072 this.state.saveUserSettingsForm.show_nsfw = luv.local_user.show_nsfw;
1073 this.state.saveUserSettingsForm.theme = luv.local_user.theme
1074 ? luv.local_user.theme
1076 this.state.saveUserSettingsForm.default_sort_type =
1077 luv.local_user.default_sort_type;
1078 this.state.saveUserSettingsForm.default_listing_type =
1079 luv.local_user.default_listing_type;
1080 this.state.saveUserSettingsForm.lang = luv.local_user.lang;
1081 this.state.saveUserSettingsForm.avatar = luv.person.avatar;
1082 this.state.saveUserSettingsForm.banner = luv.person.banner;
1083 this.state.saveUserSettingsForm.display_name = luv.person.display_name;
1084 this.state.saveUserSettingsForm.show_avatars = luv.local_user.show_avatars;
1085 this.state.saveUserSettingsForm.bot_account = luv.person.bot_account;
1086 this.state.saveUserSettingsForm.show_bot_accounts =
1087 luv.local_user.show_bot_accounts;
1088 this.state.saveUserSettingsForm.show_scores = luv.local_user.show_scores;
1089 this.state.saveUserSettingsForm.show_read_posts =
1090 luv.local_user.show_read_posts;
1091 this.state.saveUserSettingsForm.show_new_post_notifs =
1092 luv.local_user.show_new_post_notifs;
1093 this.state.saveUserSettingsForm.email = luv.local_user.email;
1094 this.state.saveUserSettingsForm.bio = luv.person.bio;
1095 this.state.saveUserSettingsForm.send_notifications_to_email =
1096 luv.local_user.send_notifications_to_email;
1097 this.state.saveUserSettingsForm.matrix_user_id = luv.person.matrix_user_id;
1098 this.state.personBlocks = UserService.Instance.myUserInfo.person_blocks;
1099 this.state.communityBlocks =
1100 UserService.Instance.myUserInfo.community_blocks;
1103 parseMessage(msg: any) {
1104 let op = wsUserOp(msg);
1108 saveUserSettingsLoading: false,
1109 changePasswordLoading: false,
1110 deleteAccountLoading: false,
1112 toast(i18n.t(msg.error), "danger");
1114 } else if (op == UserOperation.SaveUserSettings) {
1115 let data = wsJsonToRes<LoginResponse>(msg).data;
1116 UserService.Instance.login(data);
1117 this.state.saveUserSettingsLoading = false;
1118 this.setState(this.state);
1120 window.scrollTo(0, 0);
1121 } else if (op == UserOperation.ChangePassword) {
1122 let data = wsJsonToRes<LoginResponse>(msg).data;
1123 UserService.Instance.login(data);
1124 this.state.changePasswordLoading = false;
1125 this.setState(this.state);
1126 window.scrollTo(0, 0);
1127 toast(i18n.t("password_changed"));
1128 } else if (op == UserOperation.DeleteAccount) {
1130 deleteAccountLoading: false,
1131 deleteAccountShowConfirm: false,
1133 UserService.Instance.logout();
1134 window.location.href = "/";
1136 } else if (op == UserOperation.BlockPerson) {
1137 let data = wsJsonToRes<BlockPersonResponse>(msg).data;
1138 this.setState({ personBlocks: updatePersonBlock(data) });
1139 } else if (op == UserOperation.BlockCommunity) {
1140 let data = wsJsonToRes<BlockCommunityResponse>(msg).data;
1141 this.setState({ communityBlocks: updateCommunityBlock(data) });