44 lines
1.6 KiB
TypeScript
44 lines
1.6 KiB
TypeScript
import { ActivityTargetChips } from '@/activities/components/ActivityTargetChips';
|
|
import { EditableField } from '@/ui/editable-field/components/EditableField';
|
|
import { FieldContext } from '@/ui/editable-field/states/FieldContext';
|
|
import { IconArrowUpRight } from '@/ui/icon';
|
|
import { RelationPickerHotkeyScope } from '@/ui/input/relation-picker/types/RelationPickerHotkeyScope';
|
|
import { RecoilScope } from '@/ui/utilities/recoil-scope/components/RecoilScope';
|
|
import { Activity, ActivityTarget, Company, Person } from '~/generated/graphql';
|
|
|
|
import { ActivityRelationEditableFieldEditMode } from './ActivityRelationEditableFieldEditMode';
|
|
|
|
type OwnProps = {
|
|
activity?: Pick<Activity, 'id'> & {
|
|
activityTargets?: Array<
|
|
Pick<ActivityTarget, 'id' | 'personId' | 'companyId'> & {
|
|
person?: Pick<Person, 'id' | 'displayName'>;
|
|
company?: Pick<Company, 'id' | 'domainName' | 'name'>;
|
|
}
|
|
> | null;
|
|
};
|
|
};
|
|
|
|
export function ActivityRelationEditableField({ activity }: OwnProps) {
|
|
return (
|
|
<RecoilScope SpecificContext={FieldContext}>
|
|
<RecoilScope>
|
|
<EditableField
|
|
useEditButton
|
|
customEditHotkeyScope={{
|
|
scope: RelationPickerHotkeyScope.RelationPicker,
|
|
}}
|
|
iconLabel={<IconArrowUpRight />}
|
|
editModeContent={
|
|
<ActivityRelationEditableFieldEditMode activity={activity} />
|
|
}
|
|
label="Relations"
|
|
displayModeContent={
|
|
<ActivityTargetChips targets={activity?.activityTargets} />
|
|
}
|
|
/>
|
|
</RecoilScope>
|
|
</RecoilScope>
|
|
);
|
|
}
|