You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

create-card.tsx 1.7KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. import React, { useCallback, useState } from 'react'
  2. import { useTranslation } from 'react-i18next'
  3. import { RiAddCircleLine } from '@remixicon/react'
  4. import CreateFromScratchModal from '../create-options/create-from-scratch-modal'
  5. const CreateCard = () => {
  6. const { t } = useTranslation()
  7. const [showCreateModal, setShowCreateModal] = useState(false)
  8. const openCreateFromScratch = useCallback(() => {
  9. setShowCreateModal(true)
  10. }, [])
  11. const closeCreateFromScratch = useCallback(() => {
  12. setShowCreateModal(false)
  13. }, [])
  14. return (
  15. <div
  16. className='group relative flex h-[132px] cursor-pointer flex-col rounded-xl border-[0.5px] border-components-panel-border bg-components-panel-on-panel-item-bg pb-3 shadow-xs shadow-shadow-shadow-3'
  17. onClick={openCreateFromScratch}
  18. >
  19. <div className='flex items-center gap-x-3 p-4 pb-2'>
  20. <div className='flex size-10 shrink-0 items-center justify-center rounded-[10px] border border-dashed border-divider-regular bg-background-section group-hover:border-state-accent-hover-alt group-hover:bg-state-accent-hover'>
  21. <RiAddCircleLine className='size-5 text-text-quaternary group-hover:text-text-accent' />
  22. </div>
  23. <div className='system-md-semibold truncate text-text-primary'>
  24. {t('datasetPipeline.creation.createFromScratch.title')}
  25. </div>
  26. </div>
  27. <p className='system-xs-regular line-clamp-3 px-4 py-1 text-text-tertiary'>
  28. {t('datasetPipeline.creation.createFromScratch.description')}
  29. </p>
  30. <CreateFromScratchModal
  31. show={showCreateModal}
  32. onClose={closeCreateFromScratch}
  33. />
  34. </div>
  35. )
  36. }
  37. export default React.memo(CreateCard)