123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 |
- 'use client'
- import { useTranslation } from 'react-i18next'
- import { Fragment } from 'react'
- import Link from 'next/link'
- import { useSWRConfig } from 'swr'
- import { EllipsisHorizontalIcon } from '@heroicons/react/24/solid'
- import { Menu, Transition } from '@headlessui/react'
- import cn from 'classnames'
- import s from './index.module.css'
- import { apiPrefix } from '@/config'
- import { syncDataSourceNotion, updateDataSourceNotionAction } from '@/service/common'
- import Toast from '@/app/components/base/toast'
- import type { DataSourceNotion } from '@/models/common'
- type OperateProps = {
- workspace: DataSourceNotion
- }
- export default function Operate({
- workspace,
- }: OperateProps) {
- const itemClassName = `
- flex px-3 py-2 hover:bg-gray-50 text-sm text-gray-700
- cursor-pointer
- `
- const itemIconClassName = `
- mr-2 mt-[2px] w-4 h-4
- `
- const { t } = useTranslation()
- const { mutate } = useSWRConfig()
- const updateIntegrates = () => {
- Toast.notify({
- type: 'success',
- message: t('common.api.success'),
- })
- mutate({ url: 'data-source/integrates' })
- }
- const handleSync = async () => {
- await syncDataSourceNotion({ url: `/oauth/data-source/notion/${workspace.id}/sync` })
- updateIntegrates()
- }
- const handleRemove = async () => {
- await updateDataSourceNotionAction({ url: `/data-source/integrates/${workspace.id}/disable` })
- updateIntegrates()
- }
- return (
- <Menu as="div" className="relative inline-block text-left">
- {
- ({ open }) => (
- <>
- <Menu.Button className={`flex items-center justify-center w-8 h-8 rounded-lg hover:bg-gray-100 ${open && 'bg-gray-100'}`}>
- <EllipsisHorizontalIcon className='w-4 h-4' />
- </Menu.Button>
- <Transition
- as={Fragment}
- enter="transition ease-out duration-100"
- enterFrom="transform opacity-0 scale-95"
- enterTo="transform opacity-100 scale-100"
- leave="transition ease-in duration-75"
- leaveFrom="transform opacity-100 scale-100"
- leaveTo="transform opacity-0 scale-95"
- >
- <Menu.Items
- className="
- absolute right-0 top-9 w-60 max-w-80
- divide-y divide-gray-100 origin-top-right rounded-lg bg-white
- shadow-[0_10px_15px_-3px_rgba(0,0,0,0.1),0_4px_6px_rgba(0,0,0,0.05)]
- "
- >
- <div className="px-1 py-1">
- <Menu.Item>
- <Link
- className={itemClassName}
- href={`${apiPrefix}/oauth/data-source/notion`}>
- <div className={cn(s['file-icon'], itemIconClassName)}></div>
- <div>
- <div className='leading-5'>{t('common.dataSource.notion.changeAuthorizedPages')}</div>
- <div className='leading-5 text-xs text-gray-500'>
- {workspace.source_info.total} {t('common.dataSource.notion.pagesAuthorized')}
- </div>
- </div>
- </Link>
- </Menu.Item>
- <Menu.Item>
- <div className={itemClassName} onClick={handleSync}>
- <div className={cn(s['sync-icon'], itemIconClassName)} />
- <div className='leading-5'>{t('common.dataSource.notion.sync')}</div>
- </div>
- </Menu.Item>
- </div>
- <Menu.Item>
- <div className='p-1'>
- <div className={itemClassName} onClick={handleRemove}>
- <div className={cn(s['trash-icon'], itemIconClassName)} />
- <div className='leading-5'>{t('common.dataSource.notion.remove')}</div>
- </div>
- </div>
- </Menu.Item>
- </Menu.Items>
- </Transition>
- </>
- )
- }
- </Menu>
- )
- }
|