'use client'; import clsx from 'clsx'; import { motion } from 'framer-motion'; import { useMemo, useState } from 'react'; import { useConceptOptions } from '@/context/OptionsContext'; import { ConstituentaID, IConstituenta, IRSForm } from '@/models/rsform'; import { animateSideView } from '@/styling/animations'; import ConstituentsSearch from './ConstituentsSearch'; import ConstituentsTable from './ConstituentsTable'; // Window width cutoff for expression show const COLUMN_EXPRESSION_HIDE_THRESHOLD = 1500; interface ViewConstituentsProps { expression: string; isBottom?: boolean; activeCst?: IConstituenta; schema?: IRSForm; onOpenEdit: (cstID: ConstituentaID) => void; } function ViewConstituents({ expression, schema, activeCst, isBottom, onOpenEdit }: ViewConstituentsProps) { const { calculateHeight } = useConceptOptions(); const [filteredData, setFilteredData] = useState(schema?.items ?? []); const table = useMemo( () => ( ), [isBottom, filteredData, activeCst, onOpenEdit, calculateHeight] ); return ( {table} ); } export default ViewConstituents;