npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@cesarchamal/single-spa-layout-app

v1.0.18

Published

Vue application with header, navbar and footer for be included in a single-spa application as registered app.

Readme

single-spa-layout-app

npm version

Part of Demo Microfrontends - A comprehensive Single-SPA microfrontend architecture demonstration

A Vue.js layout microfrontend for Single-SPA providing shared navigation, header, and footer components across the entire application.

🏗️ Microfrontend Architecture

This application is one of 12 microfrontends in the demo-microfrontends project:

| Microfrontend | Framework | Port | Route | Repository | |---------------|-----------|------|-------|------------| | 🎯 Root App | Single-SPA | 8080 | Orchestrator | single-spa-root | | 🔐 Auth App | Vue.js | 4201 | /login | single-spa-auth-app | | 🎨 Layout App | Vue.js | 4202 | All routes | This repo | | 🏠 Home App | AngularJS | 4203 | / | single-spa-home-app | | 🅰️ Angular App | Angular 8 | 4204 | /angular/* | single-spa-angular-app | | 💚 Vue App | Vue.js 2 | 4205 | /vue/* | single-spa-vue-app | | ⚛️ React App | React 16 | 4206 | /react/* | single-spa-react-app | | 🍦 Vanilla App | ES2020+ | 4207 | /vanilla/* | single-spa-vanilla-app | | 🧩 Web Components | Lit | 4208 | /webcomponents/* | single-spa-webcomponents-app | | 📘 TypeScript App | TypeScript | 4209 | /typescript/* | single-spa-typescript-app | | 💎 jQuery App | jQuery 3.6 | 4210 | /jquery/* | single-spa-jquery-app | | 🔥 Svelte App | Svelte 3 | 4211 | /svelte/* | single-spa-svelte-app |

Main Repository: demo-microfrontends

Features

  • Shared Layout: Common header, navigation, and footer components
  • Vue.js 2: Progressive JavaScript framework
  • Bootstrap Vue: Responsive UI components and grid system
  • FontAwesome Icons: Comprehensive icon library
  • Responsive Design: Mobile-first responsive layout
  • Navigation Management: Dynamic menu and routing integration

Technology Stack

  • Framework: Vue.js 2.6.11
  • UI Library: Bootstrap Vue 2.2.2
  • Build Tool: Vue CLI 4 with library target
  • Styling: SCSS with Bootstrap integration
  • Icons: FontAwesome with Vue integration
  • Integration: Single-SPA Vue adapter

Development

Prerequisites

  • Node.js (v18.0.0 or higher)
  • npm (v8.0.0 or higher)

Installation

npm install

Development Server

npm start
# Runs on http://localhost:4202

Build

npm run build
# Outputs to dist/single-spa-layout-app.umd.js

Layout Components

Header Component

  • Application branding and logo
  • User authentication status
  • Global navigation menu
  • Responsive hamburger menu

Navigation Component

  • Primary navigation menu
  • Active route highlighting
  • Dropdown submenus
  • Mobile-responsive design

Footer Component

  • Copyright information
  • Links and social media
  • Contact information
  • Responsive layout

Sidebar (Optional)

  • Secondary navigation
  • Collapsible design
  • Context-sensitive content
  • Mobile drawer functionality

Single-SPA Integration

This microfrontend exports the required Single-SPA lifecycle functions:

export const bootstrap = vueLifecycles.bootstrap;
export const mount = vueLifecycles.mount;
export const unmount = vueLifecycles.unmount;

Mount Point

The application mounts to the DOM element with ID layout-app:

<div id="layout-app"></div>

Route Configuration

Configured to be active on all routes except /login:

singleSpa.registerApplication(
  'layout',
  () => loadApp('single-spa-layout-app'),
  showWhenNotAnyOf(['/login'])
);

Global Layout Strategy

  • Always visible except on login page
  • Provides consistent user experience
  • Shared navigation state
  • Responsive breakpoints

Vue Configuration

External Dependencies

The application uses webpack externals for shared dependencies:

config.externals([
  'vue',
  'bootstrap-vue',
  'single-spa-vue',
  '@fortawesome/fontawesome-svg-core',
  '@fortawesome/free-brands-svg-icons',
  '@fortawesome/free-solid-svg-icons'
]);

Library Build

Built as UMD library for Single-SPA consumption:

configureWebpack: {
  output: {
    library: 'single-spa-layout-app',
    libraryTarget: 'umd',
    filename: 'single-spa-layout-app.js'
  }
}

Layout Features

Responsive Design

  • Mobile-first approach
  • Bootstrap grid system
  • Flexible breakpoints
  • Touch-friendly navigation

Navigation Management

  • Dynamic menu generation
  • Route-based active states
  • Breadcrumb navigation
  • Search functionality

User Interface

  • Consistent branding
  • Accessibility compliant
  • Dark/light theme support
  • Loading states

Performance

  • Lazy-loaded components
  • Optimized bundle size
  • Efficient re-renders
  • Memory management

Styling Architecture

SCSS Structure

// Variables and mixins
@import 'variables';
@import 'mixins';

// Bootstrap customization
@import 'bootstrap-overrides';

// Component styles
@import 'components/header';
@import 'components/navigation';
@import 'components/footer';

CSS Classes

  • BEM methodology
  • Utility classes
  • Component-scoped styles
  • Responsive utilities

File Structure

single-spa-layout-app/
├── src/
│   ├── components/           # Layout components
│   │   ├── Header.vue       # Header component
│   │   ├── Navigation.vue   # Navigation component
│   │   └── Footer.vue       # Footer component
│   ├── styles/              # SCSS stylesheets
│   │   ├── variables.scss   # SCSS variables
│   │   └── styles.scss      # Main styles
│   ├── App.vue              # Root layout component
│   └── singleSpaEntry.js    # Single-SPA integration
├── dist/                    # Build output directory
├── package.json             # Dependencies and scripts
├── vue.config.js           # Vue CLI configuration
├── .gitignore              # Git ignore rules
└── README.md               # This file

Configuration

Vue CLI Configuration (vue.config.js)

module.exports = {
  configureWebpack: {
    output: {
      library: 'single-spa-layout-app',
      libraryTarget: 'umd'
    },
    plugins: [
      new webpack.optimize.LimitChunkCountPlugin({
        maxChunks: 1
      })
    ]
  }
};

Bootstrap Integration

  • Custom theme variables
  • Component overrides
  • Responsive utilities
  • Grid system customization

Accessibility

WCAG Compliance

  • Semantic HTML structure
  • ARIA labels and roles
  • Keyboard navigation
  • Screen reader support

Navigation Accessibility

  • Skip links
  • Focus management
  • High contrast support
  • Reduced motion support

Performance Optimization

  • Bundle Size: ~1.5MB (UMD build with styles)
  • Load Time: Optimized with external dependencies
  • Runtime: Efficient Vue.js updates
  • Memory: Proper component cleanup

Browser Support

  • Modern browsers (ES2015+)
  • IE11+ with polyfills
  • Mobile browsers
  • Progressive enhancement

Customization

Theming

// Override Bootstrap variables
$primary: #007bff;
$secondary: #6c757d;
$success: #28a745;

// Custom layout variables
$header-height: 60px;
$sidebar-width: 250px;

Component Props

// Navigation component props
props: {
  menuItems: Array,
  activeRoute: String,
  collapsed: Boolean
}

Testing

Unit Tests

npm run test:unit

Component Tests

npm run test:components

Linting

npm run lint

Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Follow Vue.js and Bootstrap best practices
  4. Ensure responsive design
  5. Test across different screen sizes
  6. Submit a pull request

License

MIT License - see LICENSE file for details.

Related Projects

🚀 Quick Start

Run the complete microfrontend system:

# Clone main repository
git clone https://github.com/cesarchamal/demo-microfrontends.git
cd demo-microfrontends

# Start all microfrontends
./run.sh local dev

Run this microfrontend individually:

npm install
npm start
# Visit http://localhost:4202

Author

Cesar Francisco Chavez Maldonado - Vue.js Layout Microfrontend