|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import ClearAllPointsInVideoButton from '@/common/components/annotations/ClearAllPointsInVideoButton'; |
|
|
import ObjectThumbnail from '@/common/components/annotations/ObjectThumbnail'; |
|
|
import {OBJECT_TOOLBAR_INDEX} from '@/common/components/toolbar/ToolbarConfig'; |
|
|
import {BaseTracklet} from '@/common/tracker/Tracker'; |
|
|
import {activeTrackletObjectIdAtom, trackletObjectsAtom} from '@/demo/atoms'; |
|
|
import {spacing} from '@/theme/tokens.stylex'; |
|
|
import stylex from '@stylexjs/stylex'; |
|
|
import {useAtomValue, useSetAtom} from 'jotai'; |
|
|
|
|
|
const styles = stylex.create({ |
|
|
container: { |
|
|
display: 'flex', |
|
|
padding: spacing[5], |
|
|
borderTop: '1px solid #DEE3E9', |
|
|
}, |
|
|
trackletsContainer: { |
|
|
flexGrow: 1, |
|
|
display: 'flex', |
|
|
alignItems: 'center', |
|
|
gap: spacing[5], |
|
|
}, |
|
|
}); |
|
|
|
|
|
type Props = { |
|
|
showActiveObject: () => void; |
|
|
onTabChange: (newIndex: number) => void; |
|
|
}; |
|
|
|
|
|
export default function MobileObjectsList({ |
|
|
showActiveObject, |
|
|
onTabChange, |
|
|
}: Props) { |
|
|
const tracklets = useAtomValue(trackletObjectsAtom); |
|
|
const setActiveTrackletId = useSetAtom(activeTrackletObjectIdAtom); |
|
|
|
|
|
function handleSelectObject(tracklet: BaseTracklet) { |
|
|
setActiveTrackletId(tracklet.id); |
|
|
showActiveObject(); |
|
|
} |
|
|
|
|
|
return ( |
|
|
<div {...stylex.props(styles.container)}> |
|
|
<div {...stylex.props(styles.trackletsContainer)}> |
|
|
{tracklets.map(tracklet => { |
|
|
const {id, color, thumbnail} = tracklet; |
|
|
return ( |
|
|
<ObjectThumbnail |
|
|
key={id} |
|
|
color={color} |
|
|
thumbnail={thumbnail} |
|
|
onClick={() => { |
|
|
handleSelectObject(tracklet); |
|
|
}} |
|
|
/> |
|
|
); |
|
|
})} |
|
|
</div> |
|
|
<ClearAllPointsInVideoButton |
|
|
onRestart={() => onTabChange(OBJECT_TOOLBAR_INDEX)} |
|
|
/> |
|
|
</div> |
|
|
); |
|
|
} |
|
|
|