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 🙏

© 2025 – Pkg Stats / Ryan Hefner

vue-chat-button-simple

v1.4.2

Published

Vue 2 & Vue 3 compatible chat button components with badge support, modal popup, fixed positioning, environment configuration, and customizable themes

Readme

Vue Chat Button

Vue 3 聊天按钮组件,支持徽章、弹窗、固定定位、环境配置和自定义主题。

安装

npm i vue-chat-button-simple
# 或
yarn add vue-chat-button-simple
# 或
pnpm add vue-chat-button-simple

使用方法

全局注册

import { createApp } from 'vue'
import VueChatButton from 'vue-chat-button'
import 'vue-chat-button/dist/vue-chat-button.css'

const app = createApp(App)
app.use(VueChatButton)
app.mount('#app')

组件单独使用

<template>
  <div class="container">
    <!-- 默认配置 -->
    <chat-button-with-badge :params="params" />

    <!-- 设置固定位置 -->
    <chat-button-with-badge :fixedOffset="{ x: 80, y: 100 }" :params="params" />

    <div class="section">
      <h2>发送订单/销售单, 发送订单时,params</h2>
      <chat-button-with-badge :is-fixed="false" :show-badge="false" :autoOpenModal="false" :params="params" isOrder />
    </div>

    <div class="section">
      <h2>自定义颜色</h2>
      <chat-button-with-badge icon-color="#000" theme-color="white" :is-fixed="false" :params="params" />
    </div>

    <div class="section">
      <h2>在新标签页显示</h2>

      <div>
        <h3>默认跳转当前会话页面</h3>
        <chat-button-with-badge :is-fixed="false" isOpenTab :params="params" />

        <h3>跳转指定页面</h3>
        <chat-button-with-badge :is-fixed="false" isOpenTab :params="params" isOrder path="/chat?customer_id=123" />
      </div>
    </div>

    <!-- 聊天模态框测试 -->
    <div class="section">
      <h2>聊天模态框</h2>
      <div class="demo-area">
        <button @click="openModal" class="open-modal-btn">打开聊天窗口</button>
      </div>
    </div>

    <!-- 聊天模态框组件 -->
    <chat-modal v-model:visible="modalVisible" :title="modalTitle" @message-sent="handleMessageSent" @modal-close="handleModalClose" />
  </div>
</template>

<script setup lang="ts">
import { ref } from 'vue'
import { ChatButtonWithBadge, ChatModal } from 'vue-chat-button-simple'
import 'vue-chat-button-simple/dist/vue-chat-button-simple.css'

const modalVisible = ref(false)
const modalTitle = ref('在线客服')

const params = ref({
  source_sys: 'CLNT', //来源系统(必填,有效值:XUAN-选品网、CLNT-客户后台、OPER-新运营平台)
  source_page: window.location.href,
  custom_params: {
    // 【选填】
    uid: 'WM202505221529531472', //客户uid
    order_number: 'BXY2507041337460', //订单编号
    after_sale_number: 'AS202507041508577628', //售后单号
  }, //第三方自定义参数
})

const handleMessageSent = (message: string) => {
  console.log(`发送消息: ${message}`)
}

const handleModalClose = () => {
  console.log('模态框被关闭')
  modalVisible.value = false
}

const openModal = () => {
  modalVisible.value = true
  console.log('模态框已打开')
}
</script>

Vue2 引用

<script src="./dist-vue2/vue-chat-button-global.iife.js"></script>
<link rel="stylesheet" href="./dist-vue2/vue-chat-button-global.css" />

全局 Loading 功能

组件支持全局请求 loading 功能,可以在所有 API 请求时显示全屏 loading 遮罩层。

配置选项

| 属性 | 类型 | 默认值 | 说明 | | -------------------- | --------- | ------ | ----------------------------- | | showGlobalLoading | boolean | true | 是否显示全局 loading | | globalLoadingText | string | '' | 全局 loading 文字 | | globalLoadingDelay | number | 100 | 全局 loading 延迟显示时间(ms) |

使用示例

<template>
  <!-- 基础用法 -->
  <chat-button-with-badge :params="params" token="your-token" showGlobalLoading />

  <!-- 自定义配置 -->
  <chat-button-with-badge :params="params" token="your-token" showGlobalLoading globalLoadingText="加载中..." globalLoadingDelay="300" theme-color="#ff4757" />
</template>

组件 API

ChatButtonWithBadge

带徽章的聊天按钮组件。点击组件默认弹窗弹窗,弹窗相关属性请看下面的 Modal 属性

Props

| 属性 | 类型 | 默认值 | 说明 | | ----------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------ | ---------------------------------------------------------- | | badgeCount | number | 0 | 徽章数量 | | showBadge | boolean | true | 是否显示角标数量 | | badgeColor | string | '#ff4d4f' | 徽章颜色 | | iconColor | string | '#fff' | icon颜色 | | themeColor | string | '#1890ff' | 主题颜色 | | iconUrl | string | '' | 自定义图标URL | | isFixed | boolean | true | 是否固定定位 | | fixedPosition | 'bottom-right' \| 'bottom-left' \| 'top-right' \| 'top-left' | 'bottom-right' | 固定位置 | | fixedOffset | { x?: number; y?: number } | { x: 20, y: 60 } | 固定位置偏移 | | autoFetch | boolean | true | 是否自动获取徽章数量 | | fetchInterval | number | 30000 | 获取间隔(毫秒) | | enablePolling | boolean | true | 是否启用轮询 | | pollingInterval | number | 30000 | 轮询间隔(毫秒) | | environment | 'development' \|'test' \| 'production' \| 'uat' | 'development' | 环境配置 | | params | {"source_sys": "CLNT", //来源系统(必填,有效值:XUAN-选品网、CLNT-客户后台、OPER-新运营平台) "source_page": window.location.href,"custom_params": { // 【选填】 "uid": "WM202505221529531472", //客户uid "order_number": "BXY2507041337460", //订单编号 "after_sale_number": "AS202507041508577628" //售后单号} //第三方自定义参数 | undefined | 请求参数 (必传,不是订单的,可不传订单等信息) | | isOpenTab | boolean | false | 是否打开新标签页显示窗口 | | path | string | '/chat' | 打开新标签页需要跳转到对应页面时必传,默认跳转当前会话页面 | | token | string | '' | token, 必传 | | showIcon | boolean | true | 是否显示图标 |

Events

| 事件名 | 参数 | 说明 | | -------------- | --------------------------------------------- | ---------------- | | click | - | 按钮点击事件 | | badgeUpdate | count: number | 徽章数量更新事件 | | pollingStart | - | 轮询开始事件 | | pollingStop | - | 轮询停止事件 | | openModal | openModal(url: string, title: string) => {} | 打开弹窗 | | closeModal | | 关闭弹窗 | | error | | 异常 | | orderSent | | 发送订单结果 |

Methods

| 方法名 | 参数 | 返回值 | 说明 | | ----------------------- | ------------------ | --------------- | ---------------- | | fetchBadgeCount | - | Promise<void> | 手动获取徽章数量 | | setBadgeCount | count: number | void | 设置徽章数量 | | startPolling | - | void | 开始轮询 | | stopPolling | - | void | 停止轮询 | | updatePollingInterval | interval: number | void | 更新轮询间隔 |

ChatModal

聊天弹窗组件。

Props

| 属性 | 类型 | 默认值 | 说明 | | ------------------ | ------------------------------------- | --------- | ---------------------------------- | | visible | boolean | false | 是否显示弹窗 | | modalPosition | 'right' \| 'center' \| 'fullscreen' | 'right' | 弹窗位置 | | width | string | '400px' | 弹窗宽度 | | height | string | '600px' | 弹窗高度 | | closeOnOverlay | boolean | true | 点击遮罩是否关闭 | | closeOnEscape | boolean | true | 按ESC是否关闭 | | showFullscreen | boolean | false | 是否显示全屏按钮 | | enableAdjustSize | boolean | false | 是否可以调整窗口大小(窗口右下角) |

Events

| 事件名 | 参数 | 说明 | | ---------------- | ---------------------------------- | -------------- | | update:visible | value: boolean | 可见性更新事件 | | open | open(url: string, title: string) | 弹窗打开事件 | | close | - | 弹窗关闭事件 |

Methods

| 方法名 | 参数 | 返回值 | 说明 | | -------- | ---- | ------ | ------------ | | open | - | void | 打开弹窗 | | close | - | void | 关闭弹窗 | | toggle | - | void | 切换弹窗状态 |