| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | import { memo } from 'react' | 
					
						
							|  |  |  | import { useTranslation } from 'react-i18next' | 
					
						
							|  |  |  | import { useWorkflow } from '../hooks' | 
					
						
							|  |  |  | import { useStore } from '@/app/components/workflow/store' | 
					
						
							| 
									
										
										
										
											2024-05-04 16:15:32 +08:00
										 |  |  | import useTimestamp from '@/hooks/use-timestamp' | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | const EditingTitle = () => { | 
					
						
							|  |  |  |   const { t } = useTranslation() | 
					
						
							| 
									
										
										
										
											2024-05-04 16:15:32 +08:00
										 |  |  |   const { formatTime } = useTimestamp() | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |   const { formatTimeFromNow } = useWorkflow() | 
					
						
							|  |  |  |   const draftUpdatedAt = useStore(state => state.draftUpdatedAt) | 
					
						
							|  |  |  |   const publishedAt = useStore(state => state.publishedAt) | 
					
						
							| 
									
										
										
										
											2024-06-12 16:35:19 +08:00
										 |  |  |   const isSyncingWorkflowDraft = useStore(s => s.isSyncingWorkflowDraft) | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <div className='flex items-center h-[18px] text-xs text-gray-500'> | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  |         !!draftUpdatedAt && ( | 
					
						
							|  |  |  |           <> | 
					
						
							| 
									
										
										
										
											2024-05-04 16:15:32 +08:00
										 |  |  |             {t('workflow.common.autoSaved')} {formatTime(draftUpdatedAt / 1000, 'HH:mm:ss')} | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |           </> | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       <span className='flex items-center mx-1'>·</span> | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  |         publishedAt | 
					
						
							|  |  |  |           ? `${t('workflow.common.published')} ${formatTimeFromNow(publishedAt)}` | 
					
						
							|  |  |  |           : t('workflow.common.unpublished') | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-06-12 16:35:19 +08:00
										 |  |  |       { | 
					
						
							|  |  |  |         isSyncingWorkflowDraft && ( | 
					
						
							|  |  |  |           <> | 
					
						
							|  |  |  |             <span className='flex items-center mx-1'>·</span> | 
					
						
							|  |  |  |             {t('workflow.common.syncingData')} | 
					
						
							|  |  |  |           </> | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-04-08 18:51:46 +08:00
										 |  |  |     </div> | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default memo(EditingTitle) |