Merge pull request #4580 from tylershuster/comment-crash

interface: removed conditional hooks
This commit is contained in:
matildepark 2021-03-10 19:52:48 -05:00 committed by GitHub
commit c0d68120c1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 20 additions and 20 deletions

View File

@ -383,7 +383,8 @@ export function pluralize(text: string, isPlural = false, vowel = false) {
// Hide is an optional second parameter for when this function is used in class components // Hide is an optional second parameter for when this function is used in class components
export function useShowNickname(contact: Contact | null, hide?: boolean): boolean { export function useShowNickname(contact: Contact | null, hide?: boolean): boolean {
const hideNicknames = typeof hide !== 'undefined' ? hide : useSettingsState(state => state.calm.hideNicknames); const hideState = useSettingsState(state => state.calm.hideNicknames);
const hideNicknames = typeof hide !== 'undefined' ? hide : hideState;
return !!(contact && contact.nickname && !hideNicknames); return !!(contact && contact.nickname && !hideNicknames);
} }

View File

@ -86,10 +86,11 @@ export default function LaunchApp(props) {
} }
}, [query]); }, [query]);
const { hideUtilities } = useSettingsState(selectCalmState); const calmState = useSettingsState(selectCalmState);
const { hideUtilities } = calmState;
const { tutorialProgress, nextTutStep } = useLocalState(tutSelector); const { tutorialProgress, nextTutStep } = useLocalState(tutSelector);
let { hideGroups } = useLocalState(tutSelector); let { hideGroups } = useLocalState(tutSelector);
!hideGroups ? { hideGroups } = useSettingsState(selectCalmState) : null; !hideGroups ? { hideGroups } = calmState : null;
const waiter = useWaitForProps(props); const waiter = useWaitForProps(props);

View File

@ -46,12 +46,8 @@ interface SidebarProps {
export function Sidebar(props: SidebarProps): ReactElement | null { export function Sidebar(props: SidebarProps): ReactElement | null {
const { selected, workspace } = props; const { selected, workspace } = props;
const associations = useMetadataState(state => state.associations);
const groupPath = getGroupFromWorkspace(workspace); const groupPath = getGroupFromWorkspace(workspace);
const display = props.mobileHide ? ['none', 'flex'] : 'flex'; const display = props.mobileHide ? ['none', 'flex'] : 'flex';
if (!associations) {
return null;
}
const [config, setConfig] = useLocalStorageState<SidebarListConfig>( const [config, setConfig] = useLocalStorageState<SidebarListConfig>(
`group-config:${groupPath || 'home'}`, `group-config:${groupPath || 'home'}`,

View File

@ -47,6 +47,8 @@ export function SidebarItem(props: {
const groupPath = association?.group; const groupPath = association?.group;
const groups = useGroupState(state => state.groups); const groups = useGroupState(state => state.groups);
const anchorRef = useRef<HTMLElement | null>(null); const anchorRef = useRef<HTMLElement | null>(null);
const { hideAvatars, hideNicknames } = useSettingsState(selectCalmState);
const contacts = useContactState(state => state.contacts);
useTutorialModal( useTutorialModal(
mod as any, mod as any,
groupPath === `/ship/${TUTORIAL_HOST}/${TUTORIAL_GROUP}`, groupPath === `/ship/${TUTORIAL_HOST}/${TUTORIAL_GROUP}`,
@ -58,7 +60,6 @@ export function SidebarItem(props: {
return null; return null;
} }
const DM = (isUnmanaged && props.workspace?.type === 'messages'); const DM = (isUnmanaged && props.workspace?.type === 'messages');
const { hideAvatars, hideNicknames } = useSettingsState(selectCalmState);
const itemStatus = app.getStatus(path); const itemStatus = app.getStatus(path);
const hasUnread = itemStatus === 'unread' || itemStatus === 'mention'; const hasUnread = itemStatus === 'unread' || itemStatus === 'mention';
@ -85,8 +86,6 @@ export function SidebarItem(props: {
let img = null; let img = null;
const contacts = useContactState(state => state.contacts);
if (urbitOb.isValidPatp(title)) { if (urbitOb.isValidPatp(title)) {
if (contacts?.[title]?.avatar && !hideAvatars) { if (contacts?.[title]?.avatar && !hideAvatars) {
img = <BaseImage src={contacts[title].avatar} width='16px' height='16px' borderRadius={2} />; img = <BaseImage src={contacts[title].avatar} width='16px' height='16px' borderRadius={2} />;

View File

@ -11,6 +11,7 @@ import { Body } from '~/views/components/Body';
import { Workspace } from '~/types/workspace'; import { Workspace } from '~/types/workspace';
import useGraphState from '~/logic/state/graph'; import useGraphState from '~/logic/state/graph';
import useHarkState from '~/logic/state/hark'; import useHarkState from '~/logic/state/hark';
import ErrorBoundary from '~/views/components/ErrorBoundary';
interface SkeletonProps { interface SkeletonProps {
children: ReactNode; children: ReactNode;
@ -46,16 +47,18 @@ export function Skeleton(props: SkeletonProps): ReactElement {
} }
gridTemplateRows="100%" gridTemplateRows="100%"
> >
<Sidebar <ErrorBoundary>
api={props.api} <Sidebar
recentGroups={props.recentGroups} api={props.api}
selected={props.selected} recentGroups={props.recentGroups}
apps={config} selected={props.selected}
baseUrl={props.baseUrl} apps={config}
mobileHide={props.mobileHide} baseUrl={props.baseUrl}
workspace={props.workspace} mobileHide={props.mobileHide}
history={props.history} workspace={props.workspace}
/> history={props.history}
/>
</ErrorBoundary>
{props.children} {props.children}
</Body> </Body>
); );