承接 mrshanebarron/toggle 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

mrshanebarron/toggle

最新稳定版本:v1.0.1

Composer 安装命令:

composer require mrshanebarron/toggle

包简介

Toggle switch component for Laravel - supports Livewire and Vue

README 文档

README

A switch/toggle component for Laravel applications. Perfect for boolean settings and on/off states. Works with Livewire and Vue 3.

Installation

composer require mrshanebarron/toggle

Livewire Usage

Basic Usage

<livewire:sb-toggle wire:model="notifications" />

With Label

<livewire:sb-toggle wire:model="darkMode" label="Enable Dark Mode" />

Different Sizes

<livewire:sb-toggle wire:model="setting" size="sm" />
<livewire:sb-toggle wire:model="setting" size="md" />
<livewire:sb-toggle wire:model="setting" size="lg" />

Disabled State

<livewire:sb-toggle wire:model="locked" :disabled="true" />

Livewire Props

Prop Type Default Description
wire:model boolean required Bound value
label string null Label text beside toggle
size string 'md' Size: sm, md, lg
disabled boolean false Disable interaction

Vue 3 Usage

Setup

import { SbToggle } from './vendor/sb-toggle';
app.component('SbToggle', SbToggle);

Basic Usage

<template>
  <SbToggle v-model="enabled" />
</template>

<script setup>
import { ref } from 'vue';
const enabled = ref(false);
</script>

With Label

<template>
  <SbToggle v-model="notifications" label="Enable Notifications" />
</template>

Sizes

<template>
  <SbToggle v-model="value" size="sm" label="Small" />
  <SbToggle v-model="value" size="md" label="Medium" />
  <SbToggle v-model="value" size="lg" label="Large" />
</template>

In a Form

<template>
  <form @submit.prevent="save">
    <div class="space-y-4">
      <SbToggle v-model="settings.darkMode" label="Dark Mode" />
      <SbToggle v-model="settings.notifications" label="Push Notifications" />
      <SbToggle v-model="settings.marketing" label="Marketing Emails" />
    </div>
    <button type="submit">Save Settings</button>
  </form>
</template>

Vue Props

Prop Type Default Description
modelValue Boolean false Bound value (v-model)
disabled Boolean false Disable toggle
size String 'md' Size: sm, md, lg
label String null Label text

Events

Event Payload Description
update:modelValue boolean Emitted when toggled

Sizes Reference

Size Track Thumb
sm 32x16px 12x12px
md 44x24px 20x20px
lg 56x28px 24x24px

Accessibility

  • role="switch" attribute
  • aria-checked reflects state
  • Focus ring for keyboard navigation
  • Keyboard support (Enter/Space)

Styling

Uses Tailwind CSS:

  • Blue background when on
  • Gray background when off
  • White thumb with shadow
  • Smooth transition animation

Requirements

  • PHP 8.1+
  • Laravel 10, 11, or 12
  • Tailwind CSS 3.x

License

MIT License

统计信息

  • 总下载量: 6
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: Vue

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-12-16