Convert Figma logo to code with AI

bestguy logosveltestrap

Bootstrap 4 & 5 components for Svelte

1,306
183
1,306
124

Top Related Projects

SvelteUI Monorepo

Svelte implementation of the Carbon Design System

Official Svelte components built for Flowbite and Tailwind CSS

A complete design system and component solution, built on Tailwind.

Svelte Material UI Components

[DEPRECATED, see readme] A pretty cool UI kit for Svelte

Quick Overview

Sveltestrap is a Svelte component library that provides Bootstrap 5 components for Svelte applications. It allows developers to use Bootstrap's popular UI components in a Svelte-friendly way, without the need for jQuery or Bootstrap's JavaScript.

Pros

  • Easy integration of Bootstrap components in Svelte projects
  • Fully typed components for better development experience
  • Regular updates and maintenance
  • Customizable components through props and slots

Cons

  • Limited to Bootstrap 5 styling and components
  • May have a learning curve for developers not familiar with Bootstrap
  • Some complex Bootstrap components might not be fully implemented
  • Potential performance overhead compared to native Svelte components

Code Examples

  1. Using a Button component:
<script>
  import { Button } from 'sveltestrap';
</script>

<Button color="primary">Click me!</Button>
  1. Creating a responsive layout with Row and Col components:
<script>
  import { Container, Row, Col } from 'sveltestrap';
</script>

<Container>
  <Row>
    <Col sm={6} md={4}>Column 1</Col>
    <Col sm={6} md={4}>Column 2</Col>
    <Col sm={12} md={4}>Column 3</Col>
  </Row>
</Container>
  1. Implementing a modal dialog:
<script>
  import { Button, Modal, ModalBody, ModalFooter, ModalHeader } from 'sveltestrap';
  let open = false;
  const toggle = () => (open = !open);
</script>

<Button on:click={toggle}>Open Modal</Button>
<Modal {open} {toggle}>
  <ModalHeader {toggle}>Modal Title</ModalHeader>
  <ModalBody>
    This is the modal content.
  </ModalBody>
  <ModalFooter>
    <Button color="secondary" on:click={toggle}>Close</Button>
  </ModalFooter>
</Modal>

Getting Started

  1. Install sveltestrap and its peer dependencies:
npm install sveltestrap bootstrap
  1. Import the CSS in your app's entry point (e.g., src/main.js):
import 'bootstrap/dist/css/bootstrap.min.css';
  1. Use sveltestrap components in your Svelte files:
<script>
  import { Button } from 'sveltestrap';
</script>

<Button color="success">Get Started</Button>

Competitor Comparisons

SvelteUI Monorepo

Pros of SvelteUI

  • More comprehensive component library with a wider range of UI elements
  • Offers a theming system for easier customization and consistent styling
  • Includes accessibility features out-of-the-box for many components

Cons of SvelteUI

  • Larger bundle size due to more extensive feature set
  • Steeper learning curve for developers new to the library
  • Less established community compared to Sveltestrap

Code Comparison

SvelteUI:

<Button variant="filled" color="primary" size="md">
  Click me
</Button>

Sveltestrap:

<Button color="primary">
  Click me
</Button>

SvelteUI offers more customization options directly in the component props, while Sveltestrap provides a simpler API. SvelteUI's approach allows for more fine-grained control but may require more configuration. Sveltestrap's implementation is more straightforward but may need additional CSS for advanced styling.

Both libraries provide essential UI components for Svelte applications, but SvelteUI offers a more feature-rich experience at the cost of complexity, while Sveltestrap focuses on simplicity and ease of use.

Svelte implementation of the Carbon Design System

Pros of carbon-components-svelte

  • Comprehensive design system based on IBM's Carbon Design System
  • Extensive set of accessible and customizable components
  • Strong focus on enterprise-level applications and scalability

Cons of carbon-components-svelte

  • Steeper learning curve due to its comprehensive nature
  • May be overkill for smaller projects or simpler applications
  • Less flexibility in terms of customization outside the Carbon design system

Code Comparison

carbon-components-svelte:

<script>
import { Button } from "carbon-components-svelte";
</script>

<Button>Click me</Button>

sveltestrap:

<script>
import { Button } from "sveltestrap";
</script>

<Button color="primary">Click me</Button>

Both libraries offer similar component usage, but carbon-components-svelte follows the Carbon design system conventions, while sveltestrap aligns more closely with Bootstrap's approach. The carbon-components-svelte example doesn't require specifying a color, as it adheres to the Carbon design system's default styling.

Official Svelte components built for Flowbite and Tailwind CSS

Pros of Flowbite-svelte

  • Built on Tailwind CSS, offering a utility-first approach and extensive customization options
  • Includes a wider range of pre-built components and templates
  • Active development with frequent updates and new features

Cons of Flowbite-svelte

  • Steeper learning curve for developers unfamiliar with Tailwind CSS
  • Larger bundle size due to the inclusion of Tailwind CSS utilities
  • Less established in the Svelte ecosystem compared to Sveltestrap

Code Comparison

Flowbite-svelte button example:

<script>
  import { Button } from 'flowbite-svelte';
</script>

<Button color="blue">Click me</Button>

Sveltestrap button example:

<script>
  import { Button } from 'sveltestrap';
</script>

<Button color="primary">Click me</Button>

Both libraries offer similar component APIs, but Flowbite-svelte leverages Tailwind CSS classes for styling, while Sveltestrap uses Bootstrap's class naming conventions. Flowbite-svelte provides more customization options through Tailwind, whereas Sveltestrap offers a more familiar Bootstrap-like experience for developers transitioning from other frameworks.

A complete design system and component solution, built on Tailwind.

Pros of Skeleton

  • Offers a more comprehensive design system with pre-built components and utility classes
  • Provides a dark mode and theming capabilities out of the box
  • Includes additional features like animations and interactive components

Cons of Skeleton

  • Larger bundle size due to more extensive feature set
  • Steeper learning curve for developers new to the system
  • Less flexibility for custom designs without overriding styles

Code Comparison

Sveltestrap:

<Button color="primary">Click me</Button>

Skeleton:

<button class="btn variant-filled-primary">Click me</button>

Both libraries provide easy-to-use components, but Skeleton relies more on utility classes for styling, while Sveltestrap uses props for customization.

Summary

Skeleton offers a more feature-rich design system with built-in theming and animations, making it suitable for rapid development of visually appealing applications. However, this comes at the cost of a larger bundle size and potentially less flexibility for highly custom designs. Sveltestrap, on the other hand, provides a lighter-weight solution that closely mirrors Bootstrap's API, making it easier for developers familiar with Bootstrap to adopt. The choice between the two depends on project requirements, desired level of customization, and developer preferences.

Svelte Material UI Components

Pros of svelte-material-ui

  • Implements the official Material Design components, providing a more authentic Material Design experience
  • Offers a wider range of components, including more complex ones like data tables and dialogs
  • Better TypeScript support with comprehensive type definitions

Cons of svelte-material-ui

  • Larger bundle size due to the comprehensive implementation of Material Design
  • Steeper learning curve, especially for developers not familiar with Material Design principles
  • Less frequent updates compared to sveltestrap

Code Comparison

svelte-material-ui:

<script>
  import Button from '@smui/button';
</script>

<Button on:click={() => alert('Clicked!')}>
  Click me
</Button>

sveltestrap:

<script>
  import { Button } from 'sveltestrap';
</script>

<Button color="primary" on:click={() => alert('Clicked!')}>
  Click me
</Button>

Both libraries offer similar ease of use in terms of importing and using components. However, svelte-material-ui follows Material Design principles more closely, while sveltestrap provides Bootstrap-style components with additional color options.

[DEPRECATED, see readme] A pretty cool UI kit for Svelte

Pros of Attractions

  • More comprehensive documentation with interactive examples
  • Smaller bundle size and better performance optimization
  • Offers unique components like Drawer and Autocomplete

Cons of Attractions

  • Fewer components overall compared to Sveltestrap
  • Less frequent updates and potentially slower bug fixes
  • Smaller community and fewer third-party resources

Code Comparison

Sveltestrap button example:

<script>
  import { Button } from 'sveltestrap';
</script>

<Button color="primary">Click me</Button>

Attractions button example:

<script>
  import { Button } from 'attractions';
</script>

<Button primary>Click me</Button>

Both libraries offer similar syntax for basic components, but Attractions often provides more customization options through props. Sveltestrap follows Bootstrap's naming conventions more closely, while Attractions has its own unique styling approach.

Sveltestrap is better suited for developers familiar with Bootstrap, offering a wide range of components and frequent updates. Attractions, on the other hand, provides a more optimized and customizable solution with detailed documentation, making it ideal for projects prioritizing performance and unique design.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

sveltestrap

Important Note: This project is now hosted at https://github.com/sveltestrap/sveltestrap

This repo is the legacy repo for Sveltestrap 5 for use with Svelte 3. No new development will happen here.

sveltestrap.js.org docs now point to @sveltestrap/sveltestrap v6, and the new install/import for sveltestrap v6+ is npm install @sveltestrap/sveltestrap (You can still use sveltestrap v5.x via npm install sveltestrap)

We were unable to migrate this repo to the sponsor's org, so please update your imports, stars, bookmarks, etc to https://github.com/sveltestrap/sveltestrap. Our apologies for any confusion. This repo will eventually be archived.


Bootstrap 5 components for Svelte v3

The goal of this library is to provide all Bootstrap 5 components for a Svelte app. Sveltestrap makes it easy to use Bootstrap since there is no need to use Bootstrap component classes, to include Bootstrap's JavaScript, nor depend on jQuery. Sveltestrap is free, open-source software published under the permissive MIT license. This library was inspired by the reactstrap library for React.

To make using Bootstrap themes easier, this library does not embed Bootstrap styles directly and you will need to include Bootstrap 5 CSS in your page.

Demo page


Install

npm install svelte sveltestrap

Usage

You need to include a link to Bootstrap 5 stylesheet in your page - these components do not include or embed any Bootstrap styles automatically.

Either in your HTML layout:

<head>
  <link
    rel="stylesheet"
    href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css"
  />
</head>

Or from your Svelte app, either:

<svelte:head>
  <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css">
</svelte:head>

or:

<style>
  @import 'https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css';
</style>

or alternately, use the Styles component:

<script>
  import { Styles } from 'sveltestrap';
</script>

<Styles />

Then use sveltestrap components in your svelte component:

<script>
  import { Button, Col, Row } from 'sveltestrap';
</script>

<Row>
  <Col>
    <Button color="primary" outline>Hello World!</Button>
  </Col>
</Row>

Note on Icons

If you wish to use the Icon component, you also must include a link to Bootstrap Icon CSS, for example:

<svelte:head>
  <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.10.5/font/bootstrap-icons.css">
</svelte:head>

or:

<link
  rel="stylesheet"
  href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.10.5/font/bootstrap-icons.css"
/>

or the Styles component includes the Bootstrap Icon CSS by default:

<script>
  import { Styles } from 'sveltestrap';
</script>
<Styles />

Note on usage with Sapper

If you are using Sveltestrap with Sapper, it's recommended you import the component source directly. Note that this issue does not affect SvelteKit. For example:

<script>
  import { Button, Col, Row } from 'sveltestrap/src';
</script>

<Row>
  <Col>
    <Button color="primary" outline>Hello World!</Button>
  </Col>
</Row>

if you prefer the 'sveltestrap' import, you can move the package to devDependencies block in your package.json so that sapper will parse the es bundle

"devDependencies": {
    "sveltestrap": "*.*.*",
    ...
  },

NPM DownloadsLast 30 Days