From 255c505fc92cc727e8fa1a2b49a1168c84b7feda Mon Sep 17 00:00:00 2001 From: Ubuntu Date: Sat, 29 May 2021 07:14:02 +0000 Subject: [PATCH] disable save settings button unless something changed --- src/components/App/App.tsx | 1 - src/components/Settings/SettingsTab.tsx | 45 ++++++++++++------------- 2 files changed, 22 insertions(+), 24 deletions(-) diff --git a/src/components/App/App.tsx b/src/components/App/App.tsx index 80a23d7c33..638ec49d86 100644 --- a/src/components/App/App.tsx +++ b/src/components/App/App.tsx @@ -214,7 +214,6 @@ export default class App extends React.Component { this.setRoomLink(this.getRoomLink(data.vanity)); this.setIsChatDisabled(data.isChatDisabled); window.history.replaceState('', '', this.getRoomLink(data.vanity)); - this.setIsChatDisabled(data.isChatDisabled); }; componentWillUnmount() { diff --git a/src/components/Settings/SettingsTab.tsx b/src/components/Settings/SettingsTab.tsx index 12cf3e19c8..4880b647a6 100644 --- a/src/components/Settings/SettingsTab.tsx +++ b/src/components/Settings/SettingsTab.tsx @@ -56,6 +56,7 @@ export const SettingsTab = ({ const [permModalOpen, setPermModalOpen] = useState(false); const [validVanity, setValidVanity] = useState(true); const [validVanityLoading, setValidVanityLoading] = useState(false); + const [adminSettingsChanged, setAdminSettingsChanged] = useState(false); const setRoomState = useCallback( async (data: any) => { @@ -85,12 +86,16 @@ export const SettingsTab = ({ setValidVanity(true); return; } + setValidVanity(false); setValidVanityLoading(true); const response = await axios.get(serverPath + '/resolveRoom/' + input); const data = response.data; setValidVanityLoading(false); - // console.log(data.vanity, vanity); - if (data && data.vanity && data.vanity !== vanity) { + if ( + data && + data.vanity && + data.vanity !== roomLink.split('/').slice(-1)[0] + ) { // Already exists and doesn't match current room setValidVanity(false); } else { @@ -162,7 +167,11 @@ export const SettingsTab = ({ content={ setPassword(e.target.value)} + size="mini" + onChange={(e) => { + setAdminSettingsChanged(true); + setPassword(e.target.value); + }} fluid /> } @@ -176,7 +185,10 @@ export const SettingsTab = ({ description="Prevent users from sending messages in chat." checked={Boolean(isChatDisabled)} disabled={false} - onChange={(_e, data) => setIsChatDisabled(Boolean(data.checked))} + onChange={(_e, data) => { + setAdminSettingsChanged(true); + setIsChatDisabled(Boolean(data.checked)); + }} /> )} {owner && owner === user?.uid && ( @@ -212,6 +224,7 @@ export const SettingsTab = ({ value={vanity} disabled={!isSubscriber} onChange={(e) => { + setAdminSettingsChanged(true); checkValidVanity(e.target.value); setVanity(e.target.value); }} @@ -228,21 +241,6 @@ export const SettingsTab = ({ ) } > - -

} /> @@ -251,17 +249,18 @@ export const SettingsTab = ({ {owner && owner === user?.uid && (