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

pw-open-js

v0.0.7

Published

pw-open-js

Downloads

0

Readme

pw-open-js

pw-open-js

NPM JavaScript Style Guide

Install

npm install --save pw-open-js

Usage

返回结果以 callback 形式回传至 H5,所有方法可以通过传递 onSuccess/onFail 参数拿到结果/处理失败情况

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| onSuccess | Func | false | | 方法调查成功回调 onFail | Func | false | | 方法调查失败回调

app

getVersion

返回 app 原生版本号

pw.app.getVersion({
    onSuccess: function(data) {
        alert(`appVersion:${data}`)
    }
})

getJSVersion

返回 jsbundle 版本号

pw.app.getJSVersion({
    onSuccess: function(data) {
        alert(`jsVersion:${data}`)
    }
})

share

调起分享菜单,可以分享 url 至微信/朋友圈/微博/QQ/qzone

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| title | String | true | | 分享标题 description | String | true | | 分享描述 url | String | true | | 分享url thumbImage | String | false | https://dakaapp.troila.com/static/icon.png | 分享图标 options | Array | false | ['wechat', 'friend', 'weibo', 'qq', 'qzone'] | 分享目标

options 对应选项

key | target --|:--:| wechat | 微信 friend | 朋友圈 weibo | 微博 qq | QQ qzone | qzone

pw.app.share({
    title: 'test',
    description: 'des',
    url: 'www.baidu.com',
    onSuccess: function(data){
        alert('success')
    },
    onFail: function(err){
        alert(err.message)
    }
})

scan

扫码二维码或从相册识别二维码

pw.app.scan({
    onSuccess: function(data) {
        alert(`scanResult:${data}`)
    }
})

getPhoneInfo

获取手机信息

返回数据 data:

key | type | description --|:--:|--:| uniqueId | String | uuid deviceId | String | 设备id systemName | String | 系统名称 Android/iOS systemVersion | String | 系统版本 version | String | app版本 brand | String | 手机品牌 model | String | 手机型号 screenHeight | number | 屏幕高度 screenWeight | number | 屏幕宽度

pw.app.getPhoneInfo({
    onSuccess: function(data) {
        alert(`uniqueId:${data.uniqueId}`)
    }
})

getNetworkInfo

获取手机信息

返回数据 data:

key | type | description --|:--:|--:| type | String | 网络类型 isConnected | boolean | 网络是否连接,注意此状态不代表是否可以访问网络 isInternetReachable | boolean | 是否可以访问网络 isWifiEnabled | boolean | 是否连接至wifi(Android Only) details | object | 详细信息,根据type返回对应字段

pw.app.getNetworkInfo({
    onSuccess: function(data) {
        alert(`type:${data.type}`)
    }
})

vibrate

调用手机震动

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| duration | number | false | | 震动时长(Android Only, iOS默认400ms)

pw.app.vibrate({
    onSuccess: function(data) {
        alert(`success`)
    }
})

showLoading

显示 loading 动画

pw.app.showLoading({
    onSuccess: function(data) {
        alert(`success`)
    }
})

hideLoading

隐藏 loading 动画

pw.app.hideLoading({
    onSuccess: function(data) {
        alert(`success`)
    }
})

toast

弹出 toast 提示信息

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| text | String | true | | 提示信息

pw.app.toast({
    text: 'toast',
    onSuccess: function(data) {
        alert(`success`)
    }
})

alert

弹出 alert 提示框

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| title | String | true | | 提示框标题 content | String | true | | 提示框内容 icon | String | false | none | 提示框图标 confirmText | String | false | 确定 | 提示框确定文本 cancelText | String | false | 取消 | 提示框取消文本, 不传不显示取消按钮

pw.app.alert({
    title: 'title',
    content: 'centent',
    icon: 'none',
    confirmText: '确定',
    cancelText: '取消',
    onSuccess: function(data) {
        if (data === 'confirm') {
            alert(`用户点击确定`)
        }
        if (data === 'cancel') {
            alert(`用户点击取消`)
        }
    }
})

setItem

app 存储数据

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| key | String | true | | 数据存储key value | any | true | | 数据存储value

pw.app.setItem({
    key: 'key',
    value: 'value',
    onSuccess: function(data) {
        alert(`success`)
    }
})

getItem

app 获取存储数据

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| key | String | true | | 数据存储key

pw.app.getItem({
    key: 'key',
    onSuccess: function(data) {
        alert(`data: ${data}`)
    }
})

removeItem

app 移除存储数据

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| key | String | true | | 数据存储key

pw.app.removeItem({
    key: 'key',
    onSuccess: function(data) {
        alert(`success`)
    }
})

getCurrentLocation

获取一次当前地点

返回数据 data:

key | type | description --|:--:|--:| latitude | number | 经度 longitude | number | 纬度 accuracy | number | 精度 altitude | number | 海拔(米) speed | number | 速度(m/s) direction | number | 方向

pw.app.getCurrentLocation({
    onSuccess: function(data) {
        alert(`Current Latitude: ${data.latitude}`)
    }
})

startLocationListener

开启定位监听,持续获取当前位置

返回数据 data:

key | type | description --|:--:|--:| latitude | number | 经度 longitude | number | 纬度 accuracy | number | 精度 altitude | number | 海拔(米) speed | number | 速度(m/s) direction | number | 方向

pw.app.startLocationListener({
    onSuccess: function(data) {
        alert(`Keep Getting Current Latitude: ${data.latitude}`)
    }
})

removeLocationListener

移除定位监听,停止定位

pw.app.removeLocationListener({
    onSuccess: function(data) {
        alert(`Success`)
    }
})

previewImage

预览图片

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| imageArray | Array<String> | true | | 预览图片的url数组 index | number | false | 0 | 预览图片序号 showCount | boolean | false | false | 是否显示底部计数

pw.app.previewImage({
    imageArray: ['someImageUrl.png'],
    index: 0,
    showCount: false,
    onSuccess: function(data) {
        alert(`Success`)
    }
})

openFile

打开文件

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| url | String | true | | 文件下载地址 type | String | true | | 文件类型后缀名 size | number | true | | 文件大小 name | String | true | | 文件名称

pw.app.openFile({
    url: 'someFileUrl.xlsx',
    type: 'xlsx',
    size: 0,
    name: 'fileName',
    onSuccess: function(data) {
        alert(`Success`)
    }
})

user

getUserId

获取当前 userid

pw.user.getUserId({
    onSuccess: function(data) {
        alert(`userid: ${data}`)
    }
})

getToken

获取 token

pw.user.getToken({
    onSuccess: function(data) {
        alert(`token: ${data}`)
    }
})

getCurrentEnterpriseInfo

获取用户当前企业信息,返回数据结构同接口数据

pw.user.getCurrentEnterpriseInfo({
    onSuccess: function(data) {
        alert(JSON.stringify(data))
    }
})

getEmployeeInfoByIds

通过员工 id 获取员工信息

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| enterprise_id | String | true | | 企业id employee_ids | Array | true | | 员工id数组

pw.user.getEmployeeInfoByIds({
    enterprise_id: 'id',
    employee_ids: ['ids'],
    onSuccess: function(data) {
        alert(JSON.stringify(data))
    }
})

getDepartmentInfoByIds

通过部门 id 获取部门信息

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| enterprise_id | String | true | | 企业id department_ids | Array | true | | 部门id数组

pw.user.getDepartmentInfoByIds({
    enterprise_id: 'id',
    department_ids: ['ids'],
    onSuccess: function(data) {
        alert(JSON.stringify(data))
    }
})

getAllEmployeeInfo

通过部门 id 获取部门信息

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| enterprise_id | String | true | | 企业id

pw.user.getAllEmployeeInfo({
    enterprise_id: 'id',
    onSuccess: function(data) {
        alert(JSON.stringify(data))
    }
})

navigation

navigate

跳转 app 页面

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| page | String | true | | 页面名称 pageParams | object | false | undefined | 页面参数

pw.navigation.navigate({
    page: 'SomePage',
    pageParams: { params: 'params' }
    onSuccess: function(data) {
        alert(`success`)
    }
})

replace

跳转 app 页面并关闭当前页面

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| page | String | true | | 页面名称 pageParams | object | false | undefined | 页面参数

pw.navigation.replace({
    page: 'SomePage',
    pageParams: { params: 'params' }
    onSuccess: function(data) {
        alert(`success`)
    }
})

goBack

关闭当前页面

pw.navigation.goBack({
    onSuccess: function(data) {
        alert(`success`)
    }
})

openWebPage

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| url | String | true | | 路径地址 enterprise_id | String | false | `` | 企业id

打开另一个web页面

pw.navigation.openWebPage({
    url: 'http://someUrl.com',
    enterprise_id: 'id',
    onSuccess: function(data) {
        alert(`success`)
    }
})

setRightButton

设置标题栏右侧按钮

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| display | boolean | true | false | 是否显示按钮 title | String | false | | 按钮文字 color | String | false | | 按钮文字颜色

pw.navigation.setRightButton({
    display: true,
    title: '',
    color: '#333',
    onSuccess: function(data) {
        alert(`buttonClick`)
    }
})

setTitle

设置标题

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| title | String | true | | 标题文字

pw.navigation.setTitle({
    title: 'title',
    onSuccess: function(data) {
        alert(`success`)
    }
})

setCloseButton

设置左侧关闭按钮

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| show | boolean | true | false | 是否显示关闭按钮

pw.navigation.setCloseButton({
    show: true,
    onSuccess: function(data) {
        alert(`success`)
    }
})

setHeaderStyle

设置标题栏样式

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| headerStyle | object | false | | 标题栏容器样式 headerTintColor | String | false | | 标题栏图标、字体颜色 headerTitleStyle | object | false | | 标题文字样式

pw.navigation.setHeaderStyle({
    headerStyle: { backgroundColor: '#586BFB' },
    headerTintColor: '#fff',
    headerTitleStyle: { fontSize: 24 }
    onSuccess: function(data) {
        alert(`success`)
    }
})

selectEmployee

跳转 app 选择员工页面并返回选择结果

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| enterprise_id | String | true | | 企业id title | String | false | 请选择 | 选人页面标题 radio | boolean | false | false | 是否单选 maxLength | number | false | | 最多选择数量 selectedIds | array | false | | 已选择员工id列表 filterIds | array | false | | 筛选不显示的员工id

返回数据: 员工 object 的列表,object 结构同接口结构

pw.navigation.selectEmployee({
    enterprise_id: '121',
    title: '请选择',
    radio: false,
    maxLength: 5,
    selectedIds: ['1'],
    filterIds: ['2', '3'],
    onSuccess: function(data) {
        alert(JSON.stringify(data))
    }
})

selectDepartment

跳转 app 选择部门页面并返回选择结果

参数对象:

key | type | require | default | description --|:--:|--:|--:|--:| enterprise_id | String | true | | 企业id title | String | false | 请选择 | 选人页面标题 radio | boolean | false | false | 是否单选 maxLength | number | false | | 最多选择数量 selectedIds | array | false | | 已选择员工id列表

返回数据: 部门object的列表,object结构同接口结构

pw.navigation.selectDepartment({
    enterprise_id: '121',
    title: '请选择',
    radio: false,
    maxLength: 5,
    selectedIds: ['1'],
    onSuccess: function(data) {
        alert(JSON.stringify(data))
    }
})

License

MIT ©