1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- 'use client'
- import React, { useEffect, useState } from 'react'
- import { useTranslation } from 'react-i18next'
- import { XMarkIcon } from '@heroicons/react/20/solid'
- import s from './index.module.css'
- import cn from '@/utils/classnames'
- import type { NotionPage } from '@/models/common'
- import NotionIcon from '@/app/components/base/notion-icon'
- import { fetchNotionPagePreview } from '@/service/datasets'
- type IProps = {
- currentPage?: NotionPage
- hidePreview: () => void
- }
- const NotionPagePreview = ({
- currentPage,
- hidePreview,
- }: IProps) => {
- const { t } = useTranslation()
- const [previewContent, setPreviewContent] = useState('')
- const [loading, setLoading] = useState(true)
- const getPreviewContent = async () => {
- if (!currentPage)
- return
- try {
- const res = await fetchNotionPagePreview({
- workspaceID: currentPage.workspace_id,
- pageID: currentPage.page_id,
- pageType: currentPage.type,
- })
- setPreviewContent(res.content)
- setLoading(false)
- }
- catch { }
- }
- useEffect(() => {
- if (currentPage) {
- setLoading(true)
- getPreviewContent()
- }
- }, [currentPage])
- return (
- <div className={cn(s.filePreview)}>
- <div className={cn(s.previewHeader)}>
- <div className={cn(s.title)}>
- <span>{t('datasetCreation.stepOne.pagePreview')}</span>
- <div className='flex items-center justify-center w-6 h-6 cursor-pointer' onClick={hidePreview}>
- <XMarkIcon className='h-4 w-4'></XMarkIcon>
- </div>
- </div>
- <div className={cn(s.fileName)}>
- <NotionIcon
- className='shrink-0 mr-1'
- type='page'
- src={currentPage?.page_icon}
- />
- {currentPage?.page_name}
- </div>
- </div>
- <div className={cn(s.previewContent)}>
- {loading && <div className={cn(s.loading)} />}
- {!loading && (
- <div className={cn(s.fileContent)}>{previewContent}</div>
- )}
- </div>
- </div>
- )
- }
- export default NotionPagePreview
|