import { callDirection } from '@ringcentral-integration/commons/enums/callDirections'; import type { RcPaletteKeys } from '@ringcentral/juno'; import { RcIcon } from '@ringcentral/juno'; import { IncallBorder, MissedcallBorder, OutcallBorder, } from '@ringcentral/juno-icon'; import type { FunctionComponent } from 'react'; import React, { useMemo } from 'react'; export type CallIconProps = { direction?: string; active?: boolean; missed?: boolean; title?: string; }; export const CallIcon: FunctionComponent = ({ direction, active, missed, title, }) => { const icon = (() => { if (missed) { return MissedcallBorder; } switch (direction) { case callDirection.inbound: return IncallBorder; case callDirection.outbound: return OutcallBorder; default: return null; } })(); const color = ((): RcPaletteKeys => { if (active) { return 'success.b04'; } if (missed) { return 'danger.b04'; } return 'neutral.f04'; })(); return ( ); };