edit-row.tsx 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. 'use client'
  2. import type { FC } from 'react'
  3. import React from 'react'
  4. import { type MetadataItemWithEdit, UpdateType } from '../types'
  5. import Label from './label'
  6. import { RiDeleteBinLine } from '@remixicon/react'
  7. import cn from '@/utils/classnames'
  8. import InputHasSetMultipleValue from './input-has-set-multiple-value'
  9. import InputCombined from './input-combined'
  10. import EditedBeacon from './edited-beacon'
  11. type Props = {
  12. payload: MetadataItemWithEdit
  13. onChange: (payload: MetadataItemWithEdit) => void
  14. onRemove: (id: string) => void
  15. onReset: (id: string) => void
  16. }
  17. const EditMetadatabatchItem: FC<Props> = ({
  18. payload,
  19. onChange,
  20. onRemove,
  21. onReset,
  22. }) => {
  23. const isUpdated = payload.isUpdated
  24. const isDeleted = payload.updateType === UpdateType.delete
  25. return (
  26. <div className='flex h-6 items-center space-x-0.5'>
  27. {isUpdated ? <EditedBeacon onReset={() => onReset(payload.id)} /> : <div className='shrink-0 size-4' />}
  28. <Label text={payload.name} isDeleted={isDeleted} />
  29. {payload.isMultipleValue
  30. ? <InputHasSetMultipleValue
  31. onClear={() => onChange({ ...payload, value: null, isMultipleValue: false })}
  32. readOnly={isDeleted}
  33. />
  34. : <InputCombined
  35. type={payload.type}
  36. value={payload.value}
  37. onChange={v => onChange({ ...payload, value: v as string })}
  38. readOnly={isDeleted}
  39. />}
  40. <div
  41. className={
  42. cn(
  43. 'p-1 rounded-md text-text-tertiary hover:bg-state-destructive-hover hover:text-text-destructive cursor-pointer',
  44. isDeleted && 'cursor-default bg-state-destructive-hover text-text-destructive')
  45. }
  46. onClick={() => onRemove(payload.id)}
  47. >
  48. <RiDeleteBinLine className='size-4' />
  49. </div>
  50. </div>
  51. )
  52. }
  53. export default React.memo(EditMetadatabatchItem)