- 
                Notifications
    You must be signed in to change notification settings 
- Fork 0
Home
A production-ready micro frontend (MFE) shell built with React, TypeScript, and modern tooling. This shell provides a comprehensive design system, shared components, and utilities for building scalable micro frontend applications.
The React MFE Shell serves as the foundation for micro frontend architectures, providing:
- Design Token System: Comprehensive design tokens with theme support
- Component Library: Atomic design system with reusable components
- Theme Management: Light, dark, and system theme modes with persistence
- Accessibility First: WCAG AA compliance across all components
- Responsive Design: Mobile-first approach with consistent breakpoints
- Modern Tooling: React 18, TypeScript, Vite, Tailwind CSS
- Quality Assurance: 90%+ test coverage with comprehensive testing
- Performance: Tree-shaking, optimized bundles, and fast builds
The interactive demo showcases all components and features:
- Complete component library with atomic design system
- Theme switching (light/dark/system modes)
- Accessibility features and keyboard navigation
- Responsive design across all screen sizes
- Real-time component interactions
Demo is automatically deployed on every push to main branch.
- Node.js 22.x LTS or higher
- npm 10.x or higher
# Clone the repository
git clone https://github.com/jonmatum/react-mfe-shell.git
cd react-mfe-shell
# Install dependencies
npm install
# Start development server
npm run devnpm install @jonmatum/react-mfe-shellimport React from 'react';
import { 
  SettingsProvider, 
  Button, 
  Input, 
  Badge,
  useSettings 
} from '@jonmatum/react-mfe-shell';
function App() {
  return (
    <SettingsProvider>
      <MyMicroFrontend />
    </SettingsProvider>
  );
}
function MyMicroFrontend() {
  const { settings, updateSettings } = useSettings();
  
  return (
    <div className="p-4 space-y-4">
      <Button 
        variant="primary"
        onClick={() => updateSettings({ 
          theme: settings.theme === 'light' ? 'dark' : 'light' 
        })}
      >
        Toggle Theme
      </Button>
      
      <Input 
        label="Email"
        type="email"
        placeholder="Enter your email"
      />
      
      <Badge variant="success">
        Active
      </Badge>
    </div>
  );
}- Button: Multiple variants, sizes, loading states, and icon support
- Input: Form inputs with validation, icons, and accessibility features
- Badge: Status indicators with variants and removable functionality
- LoadingSpinner: Animated loading indicators with customizable appearance
- Switch: Toggle switches with proper form integration
- Modal: Accessible dialogs with backdrop, keyboard navigation, and focus management
- Card: Layout containers with compound patterns (Header, Body, Footer)
- SettingsProvider: Global state management for theme and layout preferences
Complete design token system with:
- Colors: Base colors, semantic colors, and theme-aware color system
- Typography: Font families, sizes, weights, and letter spacing
- Spacing: Consistent spacing scale from 0px to 24rem
- Shadows: Box and drop shadows for elevation
- Border Radius: Consistent corner rounding
- Breakpoints: Mobile-first responsive design
- Animation: Duration and timing functions
- Z-Index: Layering hierarchy
import { tokens } from '@jonmatum/react-mfe-shell';
// Access design tokens
const primaryColor = tokens.colors.semantic.primary[500];
const baseSpacing = tokens.spacing[4];
const mediumShadow = tokens.shadows.box.md;Comprehensive theme management with:
import { setupThemeManagement } from '@jonmatum/react-mfe-shell';
// Set up theme management
const { setTheme, cleanup } = setupThemeManagement((mode, resolvedTheme) => {
  console.log(`Theme changed to ${mode} (resolved: ${resolvedTheme})`);
});
// Change themes
setTheme('dark');    // Dark mode
setTheme('light');   // Light mode
setTheme('system');  // Follow system preferenceAvailable themes:
- 
light: Light theme with high contrast
- 
dark: Dark theme optimized for low light
- 
system: Automatically follows system preference
# Development
npm run dev              # Start development server
npm run dev:demo         # Start demo only
npm run build           # Build library for production
npm run build:lib       # Build library only
npm run build:demo      # Build demo only
# Quality Assurance
npm run test            # Run tests in watch mode
npm run test:run        # Run tests once
npm run test:coverage   # Run tests with coverage report
npm run lint            # Run ESLint
npm run lint:fix        # Fix ESLint issues
npm run type-check      # TypeScript type checking
# Formatting
npm run format          # Format with Prettier
npm run format:check    # Check formatting- Test Coverage: 90%+ across statements, branches, functions, and lines
- Type Safety: Strict TypeScript with comprehensive type definitions
- Accessibility: WCAG AA compliance with proper ARIA attributes
- Performance: Optimized bundle sizes and runtime performance
- Code Analysis: Automated complexity and quality metrics
Follow atomic design principles:
- 
Create the component in the appropriate directory: src/components/ ├── atoms/ # Basic building blocks ├── molecules/ # Simple combinations └── organisms/ # Complex combinations
- 
Add comprehensive tests with 90%+ coverage 
- 
Export the component in src/index.ts
- 
Update documentation and add to demo 
Example component structure:
// src/components/atoms/NewComponent.tsx
import React from 'react';
import { BaseComponentProps } from '../../types';
import { classNames } from '../../utils';
interface NewComponentProps extends BaseComponentProps {
  variant?: 'default' | 'primary' | 'secondary';
  size?: 'sm' | 'md' | 'lg';
}
const NewComponent = React.memo<NewComponentProps>(({ 
  variant = 'default',
  size = 'md',
  className,
  children,
  ...props 
}) => {
  return (
    <div
      className={classNames(
        'base-styles',
        {
          'size-sm': size === 'sm',
          'size-md': size === 'md',
          'size-lg': size === 'lg',
        },
        {
          'variant-default': variant === 'default',
          'variant-primary': variant === 'primary',
          'variant-secondary': variant === 'secondary',
        },
        className
      )}
      {...props}
    >
      {children}
    </div>
  );
});
NewComponent.displayName = 'NewComponent';
export default NewComponent;Using Vitest with comprehensive testing requirements:
// Example test structure
describe('Component', () => {
  it('renders correctly', () => {
    render(<Component>Test</Component>);
    expect(screen.getByText('Test')).toBeInTheDocument();
  });
  it('applies variants correctly', () => {
    render(<Component variant="primary">Primary</Component>);
    expect(screen.getByText('Primary')).toHaveClass('variant-primary');
  });
  it('handles interactions', () => {
    const handleClick = vi.fn();
    render(<Component onClick={handleClick}>Click</Component>);
    
    fireEvent.click(screen.getByText('Click'));
    expect(handleClick).toHaveBeenCalled();
  });
  it('supports accessibility', () => {
    render(<Component aria-label="Test component">Content</Component>);
    expect(screen.getByLabelText('Test component')).toBeInTheDocument();
  });
});npm run build:libCreates optimized builds:
- 
ESM: dist/index.js(modern bundlers)
- 
CJS: dist/index.cjs(Node.js compatibility)
- 
Types: dist/index.d.ts(TypeScript definitions)
- 
Styles: dist/style.css(CSS bundle)
Current bundle sizes:
- ESM: ~47KB (gzipped: ~15KB)
- CJS: ~51KB (gzipped: ~16KB)
- CSS: ~35KB (gzipped: ~6.5KB)
npm install @jonmatum/react-mfe-shell// Complete integration example
import React from 'react';
import { 
  SettingsProvider, 
  Button, 
  Modal, 
  Card,
  tokens,
  useSettings 
} from '@jonmatum/react-mfe-shell';
function MicroFrontendApp() {
  return (
    <SettingsProvider>
      <div className="min-h-screen bg-background-primary">
        <Header />
        <MainContent />
        <Footer />
      </div>
    </SettingsProvider>
  );
}
function Header() {
  const { settings, updateSettings } = useSettings();
  
  return (
    <header className="bg-surface-primary border-b border-border-primary p-4">
      <div className="flex items-center justify-between">
        <h1 className="text-text-primary font-semibold">My MFE App</h1>
        <Button
          variant="ghost"
          onClick={() => updateSettings({ 
            theme: settings.theme === 'light' ? 'dark' : 'light' 
          })}
        >
          Toggle Theme
        </Button>
      </div>
    </header>
  );
}The design tokens are automatically integrated with Tailwind CSS:
// Use theme-aware classes
<div className="bg-surface-primary text-text-primary border border-border-primary">
  Content adapts to theme automatically
</div>
// Use design token utilities
<div className="p-4 rounded-md shadow-md">
  Consistent spacing and styling
</div>// tailwind.config.js
import { tokens } from '@jonmatum/react-mfe-shell';
export default {
  theme: {
    extend: {
      colors: tokens.colors.base,
      spacing: tokens.spacing,
      fontFamily: tokens.typography.fontFamily,
    },
  },
};- Design Tokens: Comprehensive design token documentation
- Implementation Guide: Detailed implementation instructions
- GitHub Pages Setup: Demo deployment guide
We welcome contributions! Please see CONTRIBUTING.md for guidelines.
- Fork the repository
- Create a feature branch: git checkout -b feature/amazing-feature
- Make your changes with tests
- Run quality checks: npm run test:run && npm run lint && npm run type-check
- Commit using conventional commits: git commit -m "feat: add amazing feature"
- Push and create a pull request
This project is licensed under the MIT License. See LICENSE for details.
Built with care for the micro frontend community
Pura Vida & Happy Coding!
Getting Started
Design System
Deployment
Reference
Quick Install
npm install @jonmatum/react-mfe-shell