* Begin adding show view and refactoring threads to become notes * Progress on design * Progress redesign timeline * Dropdown button, design improvement * Open comment thread edit mode in drawer * Autosave local storage and commentThreadcount * Improve display and fix missing key issue * Remove some hardcoded CSS properties * Create button * Split company show into ui/business + fix eslint * Fix font weight * Begin auto-save on edit mode * Save server-side query result to Apollo cache * Fix save behavior * Refetch timeline after creating note * Rename createCommentThreadWithComment * Improve styling * Revert "Improve styling" This reverts commit 9fbbf2db006e529330edc64f3eb8ff9ecdde6bb0. * Improve CSS styling * Bring back border radius inadvertently removed * padding adjustment * Improve blocknote design * Improve edit mode display * Remove Comments.tsx * Remove irrelevant comment stories * Removed un-necessary panel component * stop using fragment, move trash icon * Add a basic story for CompanyShow * Add a basic People show view * Fix storybook tests * Add very basic Person story * Refactor PR1 * Refactor part 2 * Refactor part 3 * Refactor part 4 * Fix tests --------- Co-authored-by: Charles Bochet <charles@twenty.com>
76 lines
2.8 KiB
TypeScript
76 lines
2.8 KiB
TypeScript
import { useParams } from 'react-router-dom';
|
|
import { useTheme } from '@emotion/react';
|
|
|
|
import { Timeline } from '@/comments/components/timeline/Timeline';
|
|
import { useCompanyQuery } from '@/companies/services';
|
|
import { useHotkeysScopeOnMountOnly } from '@/hotkeys/hooks/useHotkeysScopeOnMountOnly';
|
|
import { InternalHotkeysScope } from '@/hotkeys/types/internal/InternalHotkeysScope';
|
|
import { RawLink } from '@/ui/components/links/RawLink';
|
|
import { PropertyBox } from '@/ui/components/property-box/PropertyBox';
|
|
import { PropertyBoxItem } from '@/ui/components/property-box/PropertyBoxItem';
|
|
import { IconBuildingSkyscraper, IconLink, IconMap } from '@/ui/icons/index';
|
|
import { WithTopBarContainer } from '@/ui/layout/containers/WithTopBarContainer';
|
|
import { ShowPageLeftContainer } from '@/ui/layout/show-page/containers/ShowPageLeftContainer';
|
|
import { ShowPageRightContainer } from '@/ui/layout/show-page/containers/ShowPageRightContainer';
|
|
import { ShowPageSummaryCard } from '@/ui/layout/show-page/ShowPageSummaryCard';
|
|
import { getLogoUrlFromDomainName } from '@/utils/utils';
|
|
import { CommentableType } from '~/generated/graphql';
|
|
|
|
export function CompanyShow() {
|
|
const companyId = useParams().companyId ?? '';
|
|
|
|
useHotkeysScopeOnMountOnly({
|
|
scope: InternalHotkeysScope.ShowPage,
|
|
customScopes: { 'command-menu': true, goto: true },
|
|
});
|
|
|
|
const { data } = useCompanyQuery(companyId);
|
|
const company = data?.findUniqueCompany;
|
|
|
|
const theme = useTheme();
|
|
|
|
return (
|
|
<WithTopBarContainer
|
|
title={company?.name ?? ''}
|
|
icon={<IconBuildingSkyscraper size={theme.icon.size.md} />}
|
|
>
|
|
<>
|
|
<ShowPageLeftContainer>
|
|
<ShowPageSummaryCard
|
|
logoOrAvatar={getLogoUrlFromDomainName(company?.domainName ?? '')}
|
|
title={company?.name ?? 'No name'}
|
|
date={company?.createdAt ?? ''}
|
|
/>
|
|
<PropertyBox extraPadding={true}>
|
|
<>
|
|
<PropertyBoxItem
|
|
icon={<IconLink />}
|
|
value={
|
|
<RawLink
|
|
href={
|
|
company?.domainName
|
|
? 'https://' + company?.domainName
|
|
: ''
|
|
}
|
|
>
|
|
{company?.domainName}
|
|
</RawLink>
|
|
}
|
|
/>
|
|
<PropertyBoxItem
|
|
icon={<IconMap />}
|
|
value={company?.address ? company?.address : 'No address'}
|
|
/>
|
|
</>
|
|
</PropertyBox>
|
|
</ShowPageLeftContainer>
|
|
<ShowPageRightContainer>
|
|
<Timeline
|
|
entity={{ id: company?.id ?? '', type: CommentableType.Company }}
|
|
/>
|
|
</ShowPageRightContainer>
|
|
</>
|
|
</WithTopBarContainer>
|
|
);
|
|
}
|