Fix remote timeline pages

This commit is contained in:
Alex Gleason 2023-09-23 20:56:37 -05:00
parent 3b630ed8fb
commit 17bcd68d73
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7
2 changed files with 5 additions and 8 deletions

View file

@ -8,10 +8,8 @@ import { useInstance } from 'soapbox/hooks';
import type { Map as ImmutableMap } from 'immutable'; import type { Map as ImmutableMap } from 'immutable';
const hasRestrictions = (remoteInstance: ImmutableMap<string, any>): boolean => { const hasRestrictions = (remoteInstance: ImmutableMap<string, any>): boolean => {
return remoteInstance const { accept, reject_deletes, report_removal, ...federation } = remoteInstance.get('federation');
.get('federation') return !!Object.values(federation).reduce((acc, value) => Boolean(acc || value), false);
.deleteAll(['accept', 'reject_deletes', 'report_removal'])
.reduce((acc: boolean, value: boolean) => acc || value, false);
}; };
interface IRestriction { interface IRestriction {

View file

@ -1,4 +1,3 @@
import { Map as ImmutableMap } from 'immutable';
import React, { useState, useEffect, useCallback } from 'react'; import React, { useState, useEffect, useCallback } from 'react';
import { defineMessages, FormattedMessage, useIntl } from 'react-intl'; import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
@ -31,10 +30,10 @@ const EditFederationModal: React.FC<IEditFederationModal> = ({ host, onClose })
const getRemoteInstance = useCallback(makeGetRemoteInstance(), []); const getRemoteInstance = useCallback(makeGetRemoteInstance(), []);
const remoteInstance = useAppSelector(state => getRemoteInstance(state, host)); const remoteInstance = useAppSelector(state => getRemoteInstance(state, host));
const [data, setData] = useState(ImmutableMap<string, any>()); const [data, setData] = useState({} as any);
useEffect(() => { useEffect(() => {
setData(remoteInstance.get('federation') as any); setData(remoteInstance.get('federation'));
}, [remoteInstance]); }, [remoteInstance]);
const handleDataChange = (key: string): React.ChangeEventHandler<HTMLInputElement> => { const handleDataChange = (key: string): React.ChangeEventHandler<HTMLInputElement> => {
@ -69,7 +68,7 @@ const EditFederationModal: React.FC<IEditFederationModal> = ({ host, onClose })
media_nsfw, media_nsfw,
media_removal, media_removal,
reject, reject,
} = data.toJS() as Record<string, boolean>; } = data;
const fullMediaRemoval = avatar_removal && banner_removal && media_removal; const fullMediaRemoval = avatar_removal && banner_removal && media_removal;