Files
metabuilder/qml/hybrid/Table/Table.jsx
johndoe6345789 c406b8df96 refactor: Reorganize FakeMUI by implementation type
Move FakeMUI content to appropriate root-level folders by implementation:

**React Components → components/fakemui/**
- 537 components (inputs, surfaces, layout, data-display, feedback,
  navigation, utils, atoms, lab, x, email, workflows)
- 416 SVG icons
- Full barrel exports in components/fakemui/index.ts

**QML Components → qml/**
- 104 Material Design 3 components (11 categories)
- 7 hybrid application views
- 8 desktop widgets
- qmldir module registration

**Python Bindings → python/fakemui/**
- 15 PyQt6 modules (120+ components)
- Full Python package structure with pyproject.toml

**SCSS/Styles → fakemui/** (renamed purpose)
- scss/ - Material Design 3 stylesheets
- styles/ - Component SCSS modules
- src/utils/ - Accessibility utilities
- index.ts now re-exports from components/fakemui/

This separation allows:
- React: import { Button } from '@metabuilder/components/fakemui'
- QML: import QmlComponents 1.0
- Python: from fakemui import Button, Card
- Backward compat: import { Button } from '@metabuilder/fakemui'

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-02 12:59:24 +00:00

47 lines
1.1 KiB
JavaScript

'use client';
import { classNames } from '../utils';
import styles from './Table.module.scss';
export function Table({ children, className }) {
return (
<div className={styles.tableWrapper}>
<table className={classNames(styles.table, className)}>
{children}
</table>
</div>
);
}
export function TableHead({ children, className }) {
return <thead className={classNames(styles.thead, className)}>{children}</thead>;
}
export function TableBody({ children, className }) {
return <tbody className={classNames(styles.tbody, className)}>{children}</tbody>;
}
export function TableRow({ children, className, onClick }) {
return (
<tr
className={classNames(
styles.tr,
onClick && styles['tr--clickable'],
className
)}
onClick={onClick}
>
{children}
</tr>
);
}
export function TableCell({ children, className, header = false, align = 'left' }) {
const Tag = header ? 'th' : 'td';
return (
<Tag className={classNames(styles.cell, styles[`cell--${align}`], className)}>
{children}
</Tag>
);
}