mirror of
https://github.com/ilyakooo0/urbit.git
synced 2025-01-07 07:30:23 +03:00
Merge pull request #4580 from tylershuster/comment-crash
interface: removed conditional hooks
This commit is contained in:
commit
c0d68120c1
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
|
||||||
|
@ -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'}`,
|
||||||
|
@ -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} />;
|
||||||
|
@ -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,6 +47,7 @@ export function Skeleton(props: SkeletonProps): ReactElement {
|
|||||||
}
|
}
|
||||||
gridTemplateRows="100%"
|
gridTemplateRows="100%"
|
||||||
>
|
>
|
||||||
|
<ErrorBoundary>
|
||||||
<Sidebar
|
<Sidebar
|
||||||
api={props.api}
|
api={props.api}
|
||||||
recentGroups={props.recentGroups}
|
recentGroups={props.recentGroups}
|
||||||
@ -56,6 +58,7 @@ export function Skeleton(props: SkeletonProps): ReactElement {
|
|||||||
workspace={props.workspace}
|
workspace={props.workspace}
|
||||||
history={props.history}
|
history={props.history}
|
||||||
/>
|
/>
|
||||||
|
</ErrorBoundary>
|
||||||
{props.children}
|
{props.children}
|
||||||
</Body>
|
</Body>
|
||||||
);
|
);
|
||||||
|
Loading…
Reference in New Issue
Block a user