diff --git a/app.js b/app.js new file mode 100644 index 0000000..547c939 --- /dev/null +++ b/app.js @@ -0,0 +1,44 @@ +//app.js +App({ + onLaunch: function () { + wx.cloud.init( + { + env:"lwcsjzz-5ggmp946d4da554c" + } + ) + // 展示本地存储能力 + var logs = wx.getStorageSync('logs') || [] + logs.unshift(Date.now()) + wx.setStorageSync('logs', logs) + + // 登录 + wx.login({ + success: res => { + // 发送 res.code 到后台换取 openId, sessionKey, unionId + } + }) + // 获取用户信息 + wx.getSetting({ + success: res => { + if (res.authSetting['scope.userInfo']) { + // 已经授权,可以直接调用 getUserInfo 获取头像昵称,不会弹框 + wx.getUserInfo({ + success: res => { + // 可以将 res 发送给后台解码出 unionId + this.globalData.userInfo = res.userInfo + + // 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回 + // 所以此处加入 callback 以防止这种情况 + if (this.userInfoReadyCallback) { + this.userInfoReadyCallback(res) + } + } + }) + } + } + }) + }, + globalData: { + userInfo: null + } +}) \ No newline at end of file diff --git a/app.json b/app.json new file mode 100644 index 0000000..8fc2fe4 --- /dev/null +++ b/app.json @@ -0,0 +1,48 @@ +{ + "pages":[ + "pages/me/me", + "pages/map/map", + "pages/index/index", + "pages/logs/logs", + "pages/login/login", + "pages/zhuce/zhuce", + "pages/admin/admin", + "pages/home/home", + "pages/setting/setting", + "pages/mima/mima" + + + ], + + "permission":{ + "scope.userLocation":{ + "desc": "你的位置信息将用于小程序位置接口的效果展示" + } + }, + + "window":{ + "backgroundTextStyle":"light", + "navigationBarBackgroundColor": "#fff", + "navigationBarTitleText": "云大人脸门禁", + "navigationBarTextStyle":"black" + }, +"tabBar": { + "list": [ + { + "pagePath": "pages/me/me", + "text": "主页", + "iconPath": "photo/home_.png", + "selectedIconPath": "photo/home.png" + }, + { + "pagePath": "pages/map/map", + "text": "地图", + "iconPath": "photo/map_.png", + "selectedIconPath": "photo/map.png" + } +], + "color":"#0094ff" +}, + "style": "v2", + "sitemapLocation": "sitemap.json" +} \ No newline at end of file diff --git a/app.wxss b/app.wxss new file mode 100644 index 0000000..f58bfe5 --- /dev/null +++ b/app.wxss @@ -0,0 +1,11 @@ +/**app.wxss**/ +@import 'style/weui.wxss'; +.container { + height: 100%; + display: flex; + flex-direction: column; + align-items: center; + justify-content: space-between; + padding: 200rpx 0; + box-sizing: border-box; +} diff --git a/config/appConfig.js b/config/appConfig.js new file mode 100644 index 0000000..8a7c95d --- /dev/null +++ b/config/appConfig.js @@ -0,0 +1,9 @@ +export const CDN_PATH = 'https://3gimg.qq.com/lightmap/xcx/demoCenter/images'; +export const PLUGIN_KEY = 'your key'; +export const MOYUAN_KEY = 'your key'; +export const BAIQIAN_KEY = 'your key'; +export const YULU_KEY = 'your key'; +export const DIFUNI_KEY = 'your key'; +export const INDOOR_KEY = 'your key'; +export const REFERER = '腾讯位置服务示例中心小程序'; +export const WEBSERVICE_APPID = 'wxc1c68623b7bdea7b'; diff --git a/pages/admin/admin.js b/pages/admin/admin.js new file mode 100644 index 0000000..d0596ae --- /dev/null +++ b/pages/admin/admin.js @@ -0,0 +1,54 @@ +// pages/admin/admin.js +const app=getApp(); +const db=wx.cloud.database(); +const _=db.command; +Page({ + //获取学号 + getName(event) { + console.log('获取输入的学号', event.detail.value) + this.setData({ + xuehao: event.detail.value + }) + }, + tijiao() { + let xuehao = this.data.xuehao + console.log("点击了提交") + console.log("xuehao", xuehao) + //校验学号 + if (xuehao.length < 11) { + wx.showToast({ + icon: 'none', + title: '学号只能11位', + }) + return + } + if (xuehao.length > 11) { + wx.showToast({ + icon: 'none', + title: '学号只能11位', + }) + return + } + + + db.collection('user').where({ + xuehao: xuehao + }).get({ + success(res) { + console.log("获取数据成功", res) + let user = res.data[0] + console.log("user", user) + db.collection('user').doc(user._id).update({ + data:{ + admin:1 + } + }) + }, + fail(res) { + console.log("获取数据失败", res) + } + }) + + } + +}) \ No newline at end of file diff --git a/pages/admin/admin.json b/pages/admin/admin.json new file mode 100644 index 0000000..8835af0 --- /dev/null +++ b/pages/admin/admin.json @@ -0,0 +1,3 @@ +{ + "usingComponents": {} +} \ No newline at end of file diff --git a/pages/admin/admin.wxml b/pages/admin/admin.wxml new file mode 100644 index 0000000..6379807 --- /dev/null +++ b/pages/admin/admin.wxml @@ -0,0 +1,3 @@ +输入要赋予开门权限的学生学号 + + \ No newline at end of file diff --git a/pages/admin/admin.wxss b/pages/admin/admin.wxss new file mode 100644 index 0000000..df7f99c --- /dev/null +++ b/pages/admin/admin.wxss @@ -0,0 +1,5 @@ +/* pages/admin/admin.wxss */ +.input{ + border: 1px solid gainsboro; + margin: 15rpx; +} \ No newline at end of file diff --git a/pages/home/home.js b/pages/home/home.js new file mode 100644 index 0000000..457c27d --- /dev/null +++ b/pages/home/home.js @@ -0,0 +1,380 @@ +const config = require('../../utils/config.js'); +// pages/home/home.js +const cfg = require('../../utils/config.js'); +const moment = require('../../utils/moment.min.js'); +const app = getApp() +const db = wx.cloud.database() +const _ = db.command; +Page({ + data: { + isCamera: false, + src: '', + c: '', + a: false + }, + + // 重拍 + reTakePhoto() { + this.setData({ + isCamera: false + }); + }, + + + // 拍照 + takePhoto() { + let that = this; + const ctx = wx.createCameraContext() + let src = this.data.src + ctx.takePhoto({ + quality: 'high', + success: (res) => { + this.setData({ + src: res.tempImagePath, + isCamera: true + }) + + this.init() + }, + fail: function (res) { + wx.showToast({ + title: '拍照错误', + icon: 'none', + duration: 2000 + }); + } + }) + }, + error(e) { + wx.showToast({ + title: '请允许小程序使用摄像头', + icon: 'none', + duration: 2000 + }); + }, + + + // wx.cloud.downloadFile({ + // fileID: user.src, + // success: res => { + // // get temp file path + // that.setData({ + // tempFilePath: res.tempFilePath + // }) + // console.log('res.tempFilePath',res.tempFilePath) + // }, + // fail: err => { + // // handle error + // console.log('图片读取失败') + // wx.showToast({ + // icon: 'none', + // title: '图片读取失败', + // }) + // } + // }) + + + + + shibie() { + let that = this; + let c =this.data.c + + wx.uploadFile({ + url: cfg.BaseURL + '/v1/login', + filePath: c, + name: 'file', + success: function (res) { + console.log('res',res); + var data = JSON.parse(res.data); + if (res.statusCode == 200) { + wx.showToast({ + title: '识别成功', + icon: 'success', + duration: 2000 + }); + this.data({ + a:true + }) + console.log('a',a) + data.face_url = cfg.BaseURL + data.face_url; + } else { + wx.showToast({ + title: '识别失败', + icon: 'none', + duration: 2000 + }); + } + }, + fail: function () { + wx.showToast({ + title: '登录请求错误', + icon: 'none', + duration: 2000 + }); + }, + complete: function () { + wx.hideLoading(); + } + }) +}, + + + + + + + async init() { + + let user = wx.getStorageSync('user') + let that = this; + let src = this.data.src + let c = this.data.c + + // wx.cloud.getTempFileURL({ + + // fileList: [user.src], + // success: res => { + // // get temp file URL + // console.log('res.fileList', res.fileList) + // this.setData({ + // c:res.fileList[0].tempFileURL + // }) + // }, + // fail: err => { + // // handle error + // console.log('err', err) + // } + // }) + + wx.cloud.downloadFile({ + fileID: user.src, + success: res => { + console.log('res.tempFilePath',res.tempFilePath) + this.setData({ + c:res.tempFilePath + }); + }, + fail: err => { + console.log('err',err) + // handle error + } + }) + + + + wx.uploadFile({ + url: cfg.BaseURL + '/v1/user', + filePath: that.data.src, + name: 'file', + formData: { + 'username':parseInt(100*Math.random()), + 'password': user.password + }, + success: function (res) { + console.log('res:',res); + var data = JSON.parse(res.data); + if(res.statusCode == 200){ + wx.showToast({ + title: '人脸添加成功', + icon: 'success', + duration: 2000 + }); + // wx.switchTab({ + // url: '/pages/user/user' + // }) + }else{ + wx.showToast({ + title: '人脸添加失败', + icon: 'none', + duration: 2000 + }); + } + } + }) + + + + + + }, + openBluetooth: function () { + + let user = wx.getStorageSync('user') + + if (user) { + let src = this.data.src + let c = this.data.c + console.log('c', c) + console.log('src', src) + let a = this.data.a + if (a) { + + if (user.admin > 0) { + console.log("开始启动蓝牙"); + wx.openBluetoothAdapter({ + complete() { + console.log("蓝牙启动完成"); + wx.showToast({ + icon: 'loading', + title: '蓝牙启动完成', + }) + }, + success(res) { + console.log("蓝牙启动成功"); + wx.showToast({ + icon: 'loading', + title: '蓝牙启动成功', + }) + console.log(res); + var blueToothCount = 0; + wx.startBluetoothDevicesDiscovery({ + allowDuplicatesKey: false, + success(res) { + console.log("启动蓝牙发现服务"); + console.log(res); + wx.showToast({ + icon: 'loading', + title: '正在搜索门禁', + }) + wx.onBluetoothDeviceFound(function (res) { + var devices = res.devices; + blueToothCount += devices.length; + console.log('new device list has founded,total Count:' + blueToothCount); + console.log(devices); + devices.forEach(element => { + if (element.name.startsWith("door")) { + console.log("实验室门禁蓝牙设备已找到"); + wx.showToast({ + title: '门已打开', + }) + console.log(element); + // 找到实验室门门禁就关闭 + wx.stopBluetoothDevicesDiscovery({ + success(res) { + console.log("关闭蓝牙发现器"); + console.log(res) + } + }); + } + }); + + }); + }, + fail(res) { + console.log("启动发现服务失败"); + console.log(res); + wx.showToast({ + title: '启动发现服务失败', + }) + } + }); + }, + fail(res) { + console.log("蓝牙启动失败"); + console.log(res); + wx.showToast({ + title: '蓝牙启动失败', + }) + } + }); + + } else { + console.log('抱歉您没有权限开门') + wx.showToast({ + title: '抱歉您没有权限开门', + }) + } + }else{ + console.log('人脸不匹配') + wx.showToast({ + icon: 'none', + title: '请先识别匹配的人脸', + }) + } + + + } else { + console.log('请先登录') + wx.showToast({ + icon: 'none', + title: '请先登录', + }) + } + }, + + + + + /** + * 页面的初始数据 + */ + + /** + * 生命周期函数--监听页面加载 + */ + onLoad: function (options) { + + }, + + /** + * 生命周期函数--监听页面初次渲染完成 + */ + onReady: function () { + + }, + + /** + * 生命周期函数--监听页面显示 + */ + onShow: function () { + this.setData({ + isCamera: false, + userinfo: null + }); + }, + + /** + * 生命周期函数--监听页面隐藏 + */ + onHide: function () { + this.setData({ + isCamera: true + }); + }, + + /** + * 生命周期函数--监听页面卸载 + */ + onUnload: function () { + + }, + + /** + * 页面相关事件处理函数--监听用户下拉动作 + */ + onPullDownRefresh: function () { + + }, + + /** + * 页面上拉触底事件的处理函数 + */ + onReachBottom: function () { + + }, + + /** + * 用户点击右上角分享 + */ + onShareAppMessage: function () { + + }, + wode() { + wx.navigateTo({ + url: '/pages/index/index', + }) + }, + + +}) \ No newline at end of file diff --git a/pages/home/home.json b/pages/home/home.json new file mode 100644 index 0000000..8835af0 --- /dev/null +++ b/pages/home/home.json @@ -0,0 +1,3 @@ +{ + "usingComponents": {} +} \ No newline at end of file diff --git a/pages/home/home.wxml b/pages/home/home.wxml new file mode 100644 index 0000000..b94a60a --- /dev/null +++ b/pages/home/home.wxml @@ -0,0 +1,27 @@ + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/pages/home/home.wxss b/pages/home/home.wxss new file mode 100644 index 0000000..05f58e3 --- /dev/null +++ b/pages/home/home.wxss @@ -0,0 +1,54 @@ +/* pages/home/home.wxss */ +image{ + width: 100%; +} +.home{ + width: 100vw; + overflow: hidden; + min-height: 100vh; +} + +.home .msg{ + width: 100vw; + height: 38rpx; + font-size: 24rpx; + line-height: 38rpx; + background: #FF6666; + margin-bottom: 20rpx; + color: #333333; + padding-left: 20rpx; +} + +.home .camera,.preview{ + width: 90vw; + margin: 0 auto; +} + +.home .userinfo{ + display: flex; +} + +.home .userinfo .l{ + flex: 2; + padding: 20rpx; + font-size: 28rpx; + line-height: 80rpx; + color: #666666; +} + +.home .userinfo .r{ + flex: 1; + height: 110px; + padding: 20rpx; +} + +.home .bottom{ + width: 100vw; + position: fixed; + bottom: 5vw; +} + +.home .bottom button{ + width: 90vw; + margin: 0 auto; +} \ No newline at end of file diff --git a/pages/index/index.js b/pages/index/index.js new file mode 100644 index 0000000..29bb22c --- /dev/null +++ b/pages/index/index.js @@ -0,0 +1,112 @@ +//index.js +//获取应用实例 +const app = getApp() + +Page({ + data: { + motto: '欢迎使用云大人脸门禁系统', + userInfo: {}, + hasUserInfo: false, + canIUse: wx.canIUse('button.open-type.getUserInfo'), + loginOK: false, + xuehao:'' + + }, + //事件处理函数 + bindViewTap: function() { + wx.navigateTo({ + url: '../logs/logs' + }) + }, + onLoad: function () { + if (app.globalData.userInfo) { + this.setData({ + userInfo: app.globalData.userInfo, + hasUserInfo: true + }) + } else if (this.data.canIUse){ + // 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回 + // 所以此处加入 callback 以防止这种情况 + app.userInfoReadyCallback = res => { + this.setData({ + userInfo: res.userInfo, + hasUserInfo: true + }) + } + } else { + // 在没有 open-type=getUserInfo 版本的兼容处理 + wx.getUserInfo({ + success: res => { + app.globalData.userInfo = res.userInfo + this.setData({ + userInfo: res.userInfo, + hasUserInfo: true + }) + } + }) + } + }, + getUserInfo: function(e) { + console.log(e) + app.globalData.userInfo = e.detail.userInfo + this.setData({ + userInfo: e.detail.userInfo, + hasUserInfo: true + }) + }, + //去登陆页 +denglu() { + wx.redirectTo({ + url: '/pages/login/login', + }) + }, + //去注册页 + zhuce() { + wx.navigateTo({ + url: '/pages/zhuce/zhuce', + }) + }, + guanli(){ + let user = wx.getStorageSync('user') + if (user.admin == 2){ + wx.redirectTo({ + url: '/pages/admin/admin', + })} + else{ + console.log('抱歉您不是管理员') + wx.showToast({ + icon: 'none', + title: '抱歉您不是管理员或未登录', + }) + } +}, + onShow() { + let user = wx.getStorageSync('user') + if (user && user.xuehao) { + this.setData({ + loginOK: true, + xuehao: user.xuehao + }) + } else { + this.setData({ + loginOK: false + }) + } + }, + + //退出登陆 + tuichu() { + wx.setStorageSync('user', null) + let user = wx.getStorageSync('user') + if (user && user.xuehao) { + this.setData({ + loginOK: true, + xuehao: user.xuehao + }) + } else { + this.setData({ + loginOK: false + }) + } + } +}) diff --git a/pages/index/index.json b/pages/index/index.json new file mode 100644 index 0000000..8835af0 --- /dev/null +++ b/pages/index/index.json @@ -0,0 +1,3 @@ +{ + "usingComponents": {} +} \ No newline at end of file diff --git a/pages/index/index.wxml b/pages/index/index.wxml new file mode 100644 index 0000000..cdbbeb2 --- /dev/null +++ b/pages/index/index.wxml @@ -0,0 +1,29 @@ + + + + + + + {{userInfo.nickName}} + + + + + + + + + 登录成功 + + + {{xuehao}} + + + + + + + {{motto}} + + + diff --git a/pages/index/index.wxss b/pages/index/index.wxss new file mode 100644 index 0000000..d969d9b --- /dev/null +++ b/pages/index/index.wxss @@ -0,0 +1,21 @@ +/**index.wxss**/ +.userinfo { + display: flex; + flex-direction: column; + align-items: center; +} + +.userinfo-avatar { + width: 128rpx; + height: 128rpx; + margin: 20rpx; + border-radius: 50%; +} + +.userinfo-nickname { + color: #aaa; +} + +.usermotto { + margin-top: 200px; +} diff --git a/pages/login/login.js b/pages/login/login.js new file mode 100644 index 0000000..23be342 --- /dev/null +++ b/pages/login/login.js @@ -0,0 +1,76 @@ +Page({ + data: { + username: '', + password: '' + }, + //获取输入的账号 + getZhanghao(event) { + //console.log('账号', event.detail.value) + this.setData({ + username: event.detail.value + }) + + }, + //获取输入的密码 + getMima(event) { + // console.log('密码', event.detail.value) + this.setData({ + password: event.detail.value + }) + }, + //点击登陆 + login() { + let username = this.data.username + let password = this.data.password + console.log('账号', username, '密码', password) + // if (zhanghao.length < 4) { + // wx.showToast({ + // icon: 'none', + // title: '账号至少4位', + // }) + // return + // } + // if (mima.length < 4) { + // wx.showToast({ + // icon: 'none', + // title: '账号至少4位', + // }) + // return + // } + + //登陆 + wx.cloud.database().collection('user').where({ + username: username + }).get({ + success(res) { + console.log("获取数据成功", res) + let user = res.data[0] + console.log("user", user) + if (password == user.password) { + console.log('登录成功') + wx.showToast({ + title: '登录成功', + }) + // wx.navigateTo({ + // url: '../home/home?name=' + user.name, + // }) + wx.switchTab({ + url: '/pages/me/me', + }) + //保存用户登陆状态 + wx.setStorageSync('user', user) + } else { + console.log('登陆失败') + wx.showToast({ + icon: 'none', + title: '账号或密码不正确', + }) + } + }, + fail(res) { + console.log("获取数据失败", res) + } + }) + + } + }) \ No newline at end of file diff --git a/pages/login/login.json b/pages/login/login.json new file mode 100644 index 0000000..8835af0 --- /dev/null +++ b/pages/login/login.json @@ -0,0 +1,3 @@ +{ + "usingComponents": {} +} \ No newline at end of file diff --git a/pages/login/login.wxml b/pages/login/login.wxml new file mode 100644 index 0000000..af8aef6 --- /dev/null +++ b/pages/login/login.wxml @@ -0,0 +1,6 @@ + +输入用户名: + +输入密码: + + \ No newline at end of file diff --git a/pages/login/login.wxss b/pages/login/login.wxss new file mode 100644 index 0000000..2c01333 --- /dev/null +++ b/pages/login/login.wxss @@ -0,0 +1,5 @@ +/* pages/login/login.wxss */ +.input{ + border: 1px solid gainsboro; + margin: 20rpx; +} \ No newline at end of file diff --git a/pages/logs/logs.js b/pages/logs/logs.js new file mode 100644 index 0000000..b2b967d --- /dev/null +++ b/pages/logs/logs.js @@ -0,0 +1,15 @@ +//logs.js +const util = require('../../utils/util.js') + +Page({ + data: { + logs: [] + }, + onLoad: function () { + this.setData({ + logs: (wx.getStorageSync('logs') || []).map(log => { + return util.formatTime(new Date(log)) + }) + }) + } +}) diff --git a/pages/logs/logs.json b/pages/logs/logs.json new file mode 100644 index 0000000..3ee76c1 --- /dev/null +++ b/pages/logs/logs.json @@ -0,0 +1,4 @@ +{ + "navigationBarTitleText": "查看启动日志", + "usingComponents": {} +} \ No newline at end of file diff --git a/pages/logs/logs.wxml b/pages/logs/logs.wxml new file mode 100644 index 0000000..b5a85ac --- /dev/null +++ b/pages/logs/logs.wxml @@ -0,0 +1,6 @@ + + + + {{index + 1}}. {{log}} + + diff --git a/pages/logs/logs.wxss b/pages/logs/logs.wxss new file mode 100644 index 0000000..94d4b88 --- /dev/null +++ b/pages/logs/logs.wxss @@ -0,0 +1,8 @@ +.log-list { + display: flex; + flex-direction: column; + padding: 40rpx; +} +.log-item { + margin: 10rpx; +} diff --git a/pages/map/map.js b/pages/map/map.js new file mode 100644 index 0000000..7fe6054 --- /dev/null +++ b/pages/map/map.js @@ -0,0 +1,132 @@ +import {CDN_PATH} from '../../config/appConfig'; +const RADIUS = 4; +const INIT_MARKER = { + callout: { + content: '云大信息学院', + padding: 10, + borderRadius: 2, + display: 'ALWAYS' + }, + latitude: 24.824806, + longitude: 102.850957, + iconPath: '/photo/Marker1_Activated@3x.png', + width: '34px', + height: '34px', + rotate: 0, + alpha: 1 +}; +const INIT_CALLOUT = { + content: '云大信息学院', + padding: 12, + display: 'ALWAYS', + fontSize: 14, + textAlign: 'left', + borderRadius: RADIUS, + borderWidth: 2, + bgColor: '#ffffff' +}; +const INIT_CALLOUT_MARKER = { + callout: { + ...INIT_CALLOUT + }, + latitude: 24.824806, + longitude: 102.850957, +}; +Page({ + data: { + markers: [{ + ...INIT_MARKER + }], + calloutMarkers: [{ + ...INIT_CALLOUT_MARKER + }], + longitude:0, + latitude:0 + }, + + /** + * 页面的初始数据 + */ + // data: { + // longitude:0, + // latitude:0 + // }, + bindcontroltap: function(e) { + + }, + + /** + * 生命周期函数--监听页面加载 + */ + onLoad: function (options) { + this.timer = options.timer; + wx.getLocation({ + success: (res)=> { + this.setData({ + longitude : res.longitude, + latitude : res.latitude + }) + }, + }) + wx.getSystemInfo({ + success: (res)=> { + this.setData({ + + }) + }, + }) + }, + + /** + * 生命周期函数--监听页面初次渲染完成 + */ + onReady: function () { + + }, + movetoCenter: function () { + this.mapctx.moveToLocation(); + }, + + /** + * 生命周期函数--监听页面显示 + */ + onShow: function () { + this.mapctx = wx.createMapContext("map"); + this.movetoCenter(); + }, + + /** + * 生命周期函数--监听页面隐藏 + */ + onHide: function () { + + }, + + /** + * 生命周期函数--监听页面卸载 + */ + onUnload: function () { + + }, + + /** + * 页面相关事件处理函数--监听用户下拉动作 + */ + onPullDownRefresh: function () { + + }, + + /** + * 页面上拉触底事件的处理函数 + */ + onReachBottom: function () { + + }, + + /** + * 用户点击右上角分享 + */ + onShareAppMessage: function () { + + } +}) \ No newline at end of file diff --git a/pages/map/map.json b/pages/map/map.json new file mode 100644 index 0000000..8835af0 --- /dev/null +++ b/pages/map/map.json @@ -0,0 +1,3 @@ +{ + "usingComponents": {} +} \ No newline at end of file diff --git a/pages/map/map.wxml b/pages/map/map.wxml new file mode 100644 index 0000000..c1be1e7 --- /dev/null +++ b/pages/map/map.wxml @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/pages/map/map.wxss b/pages/map/map.wxss new file mode 100644 index 0000000..7672430 --- /dev/null +++ b/pages/map/map.wxss @@ -0,0 +1,8 @@ +.container{ + height: 100vh; + width: 100%; +} +#map{ + height: 100%; + width: 100%; +} \ No newline at end of file diff --git a/pages/me/me.js b/pages/me/me.js new file mode 100644 index 0000000..ebc70fd --- /dev/null +++ b/pages/me/me.js @@ -0,0 +1,182 @@ +Page({ + data: { + imgUrls: [ + 'https://ss0.bdstatic.com/70cFvHSh_Q1YnxGkpoWK1HF6hhy/it/u=3090651753,1191520533&fm=26&gp=0.jpg', + 'https://ss1.bdstatic.com/70cFvXSh_Q1YnxGkpoWK1HF6hhy/it/u=259648009,747507726&fm=26&gp=0.jpg', + 'https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1604830692855&di=9c567bd091f085d23d321d98183fc57c&imgtype=0&src=http%3A%2F%2Ft1.focus-img.cn%2Fsh740wsh%2Fxf%2Fdt%2Ffe488523-f446-446a-a3de-83de73dfc454.JPEG' + ], + list: ['📣云大人脸门禁系统', '📣祝腾讯小程序大赛圆满举办', '敬请期待'], + indicatorDots: true, + autoplay: true, + interval: 5000, + interval2: 11000, + duration: 1000, + duration2: 2000, + windowHeight: wx.getSystemInfoSync().windowHeight, + windowWidth: wx.getSystemInfoSync().windowWidth, + btnSize: 0, + token: wx.getStorageSync('token'), + status: 2, + latitude: 0, + longitude: 0 + }, + onLoad() { + var that = this; + this.setData({ + btnSize: 0.8 * 0.32 * this.data.windowHeight, + }) + const token = wx.getStorageSync('token') + if (token == '') { + wx.navigateTo({ + url: '../index/index', + }) + } + }, + onShow() { + var that = this; + that.setData({ + token: wx.getStorageSync('token') + }) + }, + onHide: function () { + this.setData({ + status: 2 + }) + }, + + toIndex() { + wx.navigateTo({ + url: '../index/index', + }) + }, + toDenglu() { + wx.navigateTo({ + url: '../login/login', + }) + }, + toAdmin() { + let user = wx.getStorageSync('user') + if (user.admin == 2) { + wx.navigateTo({ + url: '../admin/admin', + + }) + } else { + console.log('抱歉您不是管理员') + wx.showToast({ + icon: 'none', + title: '抱歉您不是管理员或未登录', + }) + } + + }, + toSetting() { + wx.navigateTo({ + url: '../setting/setting', + }) + }, + toHome() { + // 获取当前经纬度 + const that = this; + // 获取当前经纬度 + wx.getLocation({ + type: 'wgs84', + success: (res) => { + var latitude = res.latitude + var longitude = res.longitude + this.setData({ + latitude: latitude, + longitude: longitude + }); + // let latitude = this.data.latitude + // let longitude = this.data.longitude + // 0.00003 1 + console.log(latitude) + console.log(longitude) + let user = wx.getStorageSync('user') + if (user) { + if (((latitude - 24.824806)* (latitude - 24.824806) + (longitude - 102.850957 )* (longitude - 102.850957 )) < 0.00003) { + if (user.admin > 0) { + wx.checkIsSoterEnrolledInDevice({ + checkAuthMode: 'facial', + success(res) { + wx.startSoterAuthentication({ + requestAuthModes: ['facial'], + challenge: '123456', + authContent: '请用人脸解锁', + success(res) { + wx.navigateTo({ + url: '../home/home', + }) + } + }) + }, + fail(res) { + wx.checkIsSoterEnrolledInDevice({ + checkAuthMode: 'fingerPrint', + success(res) { + wx.startSoterAuthentication({ + requestAuthModes: ['fingerPrint'], + challenge: '123456', + authContent: '请用指纹解锁', + success(res) { + wx.navigateTo({ + url: '../home/home', + }) + } + }) + }, + fail(res) { + wx.navigateTo({ + url: '../mima/mima', + }) + + } + }) + } + }) + } else { + console.log('抱歉您没有权限') + wx.showToast({ + icon: 'none', + title: '抱歉您没有权限或未登录', + }) + } + } else { + console.log('距离门禁位置太远,请点击地图,查看并移动到门禁位置附近。') + wx.showToast({ + icon: 'none', + title: '距离门禁位置太远,请点击地图,查看并移动到门禁位置附近。', + }) + } + } else { + console.log('抱歉您没有登录') + wx.showToast({ + icon: 'none', + title: '请先登录', + }) + } + } + }) + + // wx.navigateTo({ + // url: '../home/home', + // }) + } + + // test0(){ + // wx.navigateTo({ + // url: '../user/user', + // }) + // }, + // test1(){ + // wx.navigateTo({ + // url: '../guest/guest', + // }) + // }, + // test2() { + // wx.navigateTo({ + // url: '../entrance/entrance', + // }) + // } +}) \ No newline at end of file diff --git a/pages/me/me.json b/pages/me/me.json new file mode 100644 index 0000000..8835af0 --- /dev/null +++ b/pages/me/me.json @@ -0,0 +1,3 @@ +{ + "usingComponents": {} +} \ No newline at end of file diff --git a/pages/me/me.wxml b/pages/me/me.wxml new file mode 100644 index 0000000..0953f23 --- /dev/null +++ b/pages/me/me.wxml @@ -0,0 +1,67 @@ + + + + + + + + + + + + + + YNU AI + 公告 + + + + + + + {{item}} + + + + + + + + + + + + + 我的 + + + + 登录 + + + + + + + 管理 + + + + + 设置 + + + + + + + + + + 开门 + + + + + + \ No newline at end of file diff --git a/pages/me/me.wxss b/pages/me/me.wxss new file mode 100644 index 0000000..89359c2 --- /dev/null +++ b/pages/me/me.wxss @@ -0,0 +1,116 @@ +page { + height: 100%; + width: 100%; +} +.buttons { + display: flex; + flex-direction: column; + align-items: center; + justify-content: space-around; + margin: auto auto; + background-color: #FFFFFF; +} +.button-top{ + display: flex; + flex-direction: row; + justify-content: space-around; + align-items: center; +} +.button-top-left { + width: 290rpx; + height: 290rpx; + background-color: #F2F2F2; + border-radius: 15px; + display: flex; + flex-direction: column; + justify-content: center; + align-items: center; +} +.button-top-right { + width: 290rpx; + height: 290rpx; + background-color: #F2F2F2; + border-radius: 15px; + display: flex; + flex-direction: column; + justify-content: center; + align-items: center; +} +.button-bottom { + display: flex; + flex-direction: row; + justify-content: space-around; + align-items: center; +} +.button-bottom-left { + width: 290rpx; + height: 290rpx; + background-color: #F2F2F2; + border-radius: 15px; + display: flex; + flex-direction: column; + justify-content: center; + align-items: center; +} +.button-bottom-right { + width: 290rpx; + height: 290rpx; + background-color: #F2F2F2; + + border-radius: 15px; + display: flex; + flex-direction: column; + justify-content: center; + align-items: center; +} +.button-center{ + background-color: #FFFFFF; + position: relative; + border-radius: 50%; + display: flex; + justify-content: center; + margin: 0 auto; +} +.button-center-inner { + width: 80%; + height: 80%; + background-color: #F2F2F2; + border-radius: 50%; + margin: auto auto; + display: flex; + flex-direction: column; + justify-content: center; + align-items: center; +} +.index-logo { + width: 86rpx; + height: 86rpx; +} + +/* 公告 */ +.board { + height: 9vh; + width: 100%; + background-color: white; + display: flex; + flex-direction: row; + align-items: center; + border-bottom: 4px solid lightgray; +} +.board-title { + + width: 40%; + display: flex; + flex-direction: row; + justify-content: center; + align-items: center +} +.board text { + font-family: Impact, Haettenschweiler, 'Arial Narrow Bold', sans-serif; +} +.board-content { + font-size: 25rpx; + flex:1; + height: 100%; + line-height: 100%; +} \ No newline at end of file diff --git a/pages/mima/mima.js b/pages/mima/mima.js new file mode 100644 index 0000000..9071315 --- /dev/null +++ b/pages/mima/mima.js @@ -0,0 +1,30 @@ +// pages/mima/mima.js +Page({ + data: { + Mima: '' + }, + getMima(event) { + console.log('获取输入的密码', event.detail.value) + this.setData({ + Mima: event.detail.value + }) + }, + + tijiao() { + let Mima = this.data.Mima + console.log("Mima", Mima) + if (Mima == "010116") + { + wx.redirectTo({ + url: '../home/home', + }) + }else + { + console.log('密码错误') + wx.showToast({ + icon: 'none', + title: '密码错误', + }) + } + } +}) \ No newline at end of file diff --git a/pages/mima/mima.json b/pages/mima/mima.json new file mode 100644 index 0000000..8835af0 --- /dev/null +++ b/pages/mima/mima.json @@ -0,0 +1,3 @@ +{ + "usingComponents": {} +} \ No newline at end of file diff --git a/pages/mima/mima.wxml b/pages/mima/mima.wxml new file mode 100644 index 0000000..d075f4e --- /dev/null +++ b/pages/mima/mima.wxml @@ -0,0 +1,3 @@ +检测到您的设备不支持人脸或指纹识别,请输入实验室独立密码 + + \ No newline at end of file diff --git a/pages/mima/mima.wxss b/pages/mima/mima.wxss new file mode 100644 index 0000000..1f92593 --- /dev/null +++ b/pages/mima/mima.wxss @@ -0,0 +1,5 @@ +/* pages/mima/mima.wxss */ +.input{ + border: 1px solid gainsboro; + margin: 20rpx; +} \ No newline at end of file diff --git a/pages/setting/setting.js b/pages/setting/setting.js new file mode 100644 index 0000000..15cd5c2 --- /dev/null +++ b/pages/setting/setting.js @@ -0,0 +1,66 @@ +// pages/setting/setting.js +Page({ + + /** + * 页面的初始数据 + */ + data: { + + }, + + /** + * 生命周期函数--监听页面加载 + */ + onLoad: function (options) { + + }, + + /** + * 生命周期函数--监听页面初次渲染完成 + */ + onReady: function () { + + }, + + /** + * 生命周期函数--监听页面显示 + */ + onShow: function () { + + }, + + /** + * 生命周期函数--监听页面隐藏 + */ + onHide: function () { + + }, + + /** + * 生命周期函数--监听页面卸载 + */ + onUnload: function () { + + }, + + /** + * 页面相关事件处理函数--监听用户下拉动作 + */ + onPullDownRefresh: function () { + + }, + + /** + * 页面上拉触底事件的处理函数 + */ + onReachBottom: function () { + + }, + + /** + * 用户点击右上角分享 + */ + onShareAppMessage: function () { + + } +}) \ No newline at end of file diff --git a/pages/setting/setting.json b/pages/setting/setting.json new file mode 100644 index 0000000..8835af0 --- /dev/null +++ b/pages/setting/setting.json @@ -0,0 +1,3 @@ +{ + "usingComponents": {} +} \ No newline at end of file diff --git a/pages/setting/setting.wxml b/pages/setting/setting.wxml new file mode 100644 index 0000000..d9eeca7 --- /dev/null +++ b/pages/setting/setting.wxml @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/pages/setting/setting.wxss b/pages/setting/setting.wxss new file mode 100644 index 0000000..0ca1e85 --- /dev/null +++ b/pages/setting/setting.wxss @@ -0,0 +1 @@ +/* pages/setting/setting.wxss */ \ No newline at end of file diff --git a/pages/zhuce/zhuce.js b/pages/zhuce/zhuce.js new file mode 100644 index 0000000..49b911d --- /dev/null +++ b/pages/zhuce/zhuce.js @@ -0,0 +1,281 @@ +// pages/add/add.js +const cfg = require('../../utils/config.js'); + +Page({ + + /** + * 页面的初始数据 + */ + data: { + isCamera: false, + src: [], + xuehao: '', + username: '', + password: '', + c:'' + }, + + /** + * 生命周期函数--监听页面加载 + */ + onLoad: function (options) { + + }, + + /** + * 生命周期函数--监听页面初次渲染完成 + */ + onReady: function () { + + }, + + /** + * 生命周期函数--监听页面显示 + */ + onShow: function () { + + }, + + /** + * 生命周期函数--监听页面隐藏 + */ + onHide: function () { + + }, + + /** + * 生命周期函数--监听页面卸载 + */ + onUnload: function () { + + }, + + /** + * 页面相关事件处理函数--监听用户下拉动作 + */ + onPullDownRefresh: function () { + + }, + + /** + * 页面上拉触底事件的处理函数 + */ + onReachBottom: function () { + + }, + + /** + * 用户点击右上角分享 + */ + onShareAppMessage: function () { + + }, + bindInputXuehao(e) { + this.setData({ + xuehao: e.detail.value + }) + }, + + // 用户名输入 + bindInputUser(e) { + this.setData({ + username: e.detail.value + }) + }, + + // 密码输入 + bindInputPwd(e) { + this.setData({ + password: e.detail.value + }) + }, + bindInputadmin(event) { + console.log('获取输入管理员验证码', event.detail.value) + this.setData({ + admin: event.detail.value + }) + }, + + // 保存用户 + addUser(e) { + var that = this; + let username = this.data.username + let password = this.data.password + let xuehao = this.data.xuehao + let admin = this.data.admin + let src = this.data.c + console.log("点击了注册") + console.log("username", username) + console.log("password", password) + console.log("xuehao", xuehao) + console.log("admin", admin) + console.log("src", src) + if (src == '') { + wx.showToast({ + title: '请先拍照', + icon: 'none', + duration: 2000 + }); + return; + } + if (that.data.username == '') { + wx.showToast({ + title: '请输入用户名', + icon: 'none', + duration: 2000 + }); + return; + } + if (xuehao.length < 11) { + wx.showToast({ + icon: 'none', + title: '学号只能11位', + }) + return + } + if (xuehao.length > 11) { + wx.showToast({ + icon: 'none', + title: '学号只能11位', + }) + return + } + //校验管理员权限 + if (admin == "010116") { + admin = 2 + } else { + admin = 0 + } + wx.cloud.database().collection('user').add({ + data: { + username: username, + password: password, + xuehao: xuehao, + admin: admin, + src: src + }, + success(res) { + console.log('注册成功', res) + wx.showToast({ + title: '注册成功', + }); + wx.redirectTo({ + url: '../login/login', + }); + }, + fail(res) { + console.log('注册失败', res) + }, + }); + }, + + // 重拍 + reTakePhoto() { + this.setData({ + isCamera: false + }); + }, + // 上传照片 + uploadImage: function (imgs) { + console.log(imgs) + wx.showLoading({ + title: '上传图片中', + mask: true, + }) + // TODO 照片上传至云存储 + + wx.cloud.uploadFile({ + cloudPath: `photos/${Date.now()}-${Math.floor(Math.random(0,1)*1000)}.png`, + + filePath: imgs, // 文件路径 + success: res => { + + wx.showToast({ + title: '上传图片成功' + }) + console.log('res:', res) + wx.hideLoading(); + // get resource ID + console.log(res.fileID) + this.setData({ + c: res.fileID, + }) + }, + fail: err => { + // handle error + console.log('err:', err) + wx.hideLoading(); + wx.showToast({ + title: '上传图片错误', + icon: 'error' + }) + } + }) + + // const uploadTasks = imgs.map(item => { + // return wx.cloud.uploadFile({ + // cloudPath: `photos/${Date.now()}-${Math.floor(Math.random(0,1)*1000)}.png`, + // filePath: item + // }) + // }); + // Promise.all(uploadTasks).then(result => { + // this.addPhotos(result); + // }).catch(err => { + // wx.hideLoading(); + // wx.showToast({ + // title: '上传图片错误', + // icon: 'error' + // }) + // }) + }, + // 添加图片数据至数据库 + // addPhotos(photos) { + // wx.showLoading({ + // title: '添加图片中', + // mask: true + // }) + // // 构造照片数据结构体,保存到数据库 + // const albumPhotos = photos.map(src => ({ + // fileID: src.fileID, + // comments: '' + // })); + // db.collection('user').doc(app.globalData.id).update({ + // data: { + // src: _.push(albumPhotos) + // } + // }).then(result => { + // console.log(result); + // this.init(); + // }) + // }, + // 拍照 + takePhoto() { + const ctx = wx.createCameraContext() + ctx.takePhoto({ + quality: 'high', + success: (res) => { + console.log('res:', res) + this.setData({ + src: res.tempImagePath, + isCamera: true + }) + this.uploadImage(res.tempImagePath) + }, + fail: function (res) { + wx.showToast({ + title: '拍照错误', + icon: 'none', + duration: 2000 + }); + } + }) + }, + error(e) { + wx.showToast({ + title: '请允许小程序使用摄像头', + icon: 'none', + duration: 2000 + }); + } + +}) \ No newline at end of file diff --git a/pages/zhuce/zhuce.json b/pages/zhuce/zhuce.json new file mode 100644 index 0000000..8835af0 --- /dev/null +++ b/pages/zhuce/zhuce.json @@ -0,0 +1,3 @@ +{ + "usingComponents": {} +} \ No newline at end of file diff --git a/pages/zhuce/zhuce.wxml b/pages/zhuce/zhuce.wxml new file mode 100644 index 0000000..e73ce8d --- /dev/null +++ b/pages/zhuce/zhuce.wxml @@ -0,0 +1,56 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + +请正对人脸,并保持光线充足 + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/pages/zhuce/zhuce.wxss b/pages/zhuce/zhuce.wxss new file mode 100644 index 0000000..a13a11b --- /dev/null +++ b/pages/zhuce/zhuce.wxss @@ -0,0 +1,22 @@ +/* pages/zhuce/zhuce.wxss */ +.add{ + width: 100vw; + min-height: 100vh; +} + +.add .camera,.preview,.btn{ + width: 90vw; + margin: 0 auto; + margin-top: 20rpx; +} + +.add .bottom{ + width: 100vw; + position: fixed; + bottom: 5vw; +} + +.add .bottom button{ + width: 90vw; + margin: 0 auto; +} diff --git a/photo/Marker1_Activated@3x.png b/photo/Marker1_Activated@3x.png new file mode 100644 index 0000000..6b4b554 Binary files /dev/null and b/photo/Marker1_Activated@3x.png differ diff --git a/photo/denglu.png b/photo/denglu.png new file mode 100644 index 0000000..72ff4cf Binary files /dev/null and b/photo/denglu.png differ diff --git a/photo/guanlifuwu.png b/photo/guanlifuwu.png new file mode 100644 index 0000000..9f822b5 Binary files /dev/null and b/photo/guanlifuwu.png differ diff --git a/photo/home.png b/photo/home.png new file mode 100644 index 0000000..bf17564 Binary files /dev/null and b/photo/home.png differ diff --git a/photo/home_.png b/photo/home_.png new file mode 100644 index 0000000..6a034ed Binary files /dev/null and b/photo/home_.png differ diff --git a/photo/kaimen.png b/photo/kaimen.png new file mode 100644 index 0000000..98c96b2 Binary files /dev/null and b/photo/kaimen.png differ diff --git a/photo/location.png b/photo/location.png new file mode 100644 index 0000000..3da849f Binary files /dev/null and b/photo/location.png differ diff --git a/photo/map.png b/photo/map.png new file mode 100644 index 0000000..aab95ed Binary files /dev/null and b/photo/map.png differ diff --git a/photo/map_.png b/photo/map_.png new file mode 100644 index 0000000..c5d8b6f Binary files /dev/null and b/photo/map_.png differ diff --git a/photo/me.png b/photo/me.png new file mode 100644 index 0000000..714fec1 Binary files /dev/null and b/photo/me.png differ diff --git a/photo/me_.png b/photo/me_.png new file mode 100644 index 0000000..3db61b6 Binary files /dev/null and b/photo/me_.png differ diff --git a/photo/photo.png b/photo/photo.png new file mode 100644 index 0000000..49a2b03 Binary files /dev/null and b/photo/photo.png differ diff --git a/photo/shezhi.png b/photo/shezhi.png new file mode 100644 index 0000000..4ef5def Binary files /dev/null and b/photo/shezhi.png differ diff --git a/photo/use.png b/photo/use.png new file mode 100644 index 0000000..03c2f22 Binary files /dev/null and b/photo/use.png differ diff --git a/project.config.json b/project.config.json new file mode 100644 index 0000000..3f37b51 --- /dev/null +++ b/project.config.json @@ -0,0 +1,70 @@ +{ + "description": "项目配置文件", + "packOptions": { + "ignore": [] + }, + "setting": { + "urlCheck": true, + "es6": true, + "enhance": true, + "postcss": true, + "preloadBackgroundData": false, + "minified": true, + "newFeature": false, + "coverView": true, + "nodeModules": true, + "autoAudits": false, + "showShadowRootInWxmlPanel": true, + "scopeDataCheck": false, + "uglifyFileName": false, + "checkInvalidKey": true, + "checkSiteMap": true, + "uploadWithSourceMap": true, + "compileHotReLoad": false, + "useMultiFrameRuntime": false, + "useApiHook": true, + "babelSetting": { + "ignore": [], + "disablePlugins": [], + "outputPath": "" + }, + "useIsolateContext": true, + "useCompilerModule": true, + "userConfirmedUseCompilerModuleSwitch": false, + "packNpmManually": false, + "packNpmRelationList": [], + "minifyWXSS": true + }, + "compileType": "miniprogram", + "libVersion": "2.13.2", + "appid": "wxea7382d1e9ad46b2", + "projectname": "2", + "debugOptions": { + "hidedInDevtools": [] + }, + "scripts": {}, + "isGameTourist": false, + "simulatorType": "wechat", + "simulatorPluginLibVersion": {}, + "condition": { + "plugin": { + "list": [] + }, + "game": { + "list": [] + }, + "gamePlugin": { + "list": [] + }, + "miniprogram": { + "list": [ + { + "name": "pages/map/map", + "pathName": "pages/home/home", + "query": "", + "scene": null + } + ] + } + } +} \ No newline at end of file diff --git a/sitemap.json b/sitemap.json new file mode 100644 index 0000000..ca02add --- /dev/null +++ b/sitemap.json @@ -0,0 +1,7 @@ +{ + "desc": "关于本文件的更多信息,请参考文档 https://developers.weixin.qq.com/miniprogram/dev/framework/sitemap.html", + "rules": [{ + "action": "allow", + "page": "*" + }] +} \ No newline at end of file diff --git a/style/base/fn.wxss b/style/base/fn.wxss new file mode 100644 index 0000000..e69de29 diff --git a/style/base/mixin/setArrow.wxss b/style/base/mixin/setArrow.wxss new file mode 100644 index 0000000..e69de29 diff --git a/style/base/mixin/setOnepx.wxss b/style/base/mixin/setOnepx.wxss new file mode 100644 index 0000000..e69de29 diff --git a/style/base/mixin/text.wxss b/style/base/mixin/text.wxss new file mode 100644 index 0000000..e69de29 diff --git a/style/base/reset.wxss b/style/base/reset.wxss new file mode 100644 index 0000000..2b668a9 --- /dev/null +++ b/style/base/reset.wxss @@ -0,0 +1,7 @@ +page { + line-height: 1.6; + font-family: -apple-system-font, "Helvetica Neue", sans-serif; +} +icon { + vertical-align: middle; +} diff --git a/style/base/variable/color.wxss b/style/base/variable/color.wxss new file mode 100644 index 0000000..e69de29 diff --git a/style/base/variable/global.wxss b/style/base/variable/global.wxss new file mode 100644 index 0000000..e69de29 diff --git a/style/base/variable/weui-button.wxss b/style/base/variable/weui-button.wxss new file mode 100644 index 0000000..e69de29 diff --git a/style/base/variable/weui-cell.wxss b/style/base/variable/weui-cell.wxss new file mode 100644 index 0000000..e69de29 diff --git a/style/base/variable/weui-dialog.wxss b/style/base/variable/weui-dialog.wxss new file mode 100644 index 0000000..e69de29 diff --git a/style/base/variable/weui-grid.wxss b/style/base/variable/weui-grid.wxss new file mode 100644 index 0000000..e69de29 diff --git a/style/base/variable/weui-msg.wxss b/style/base/variable/weui-msg.wxss new file mode 100644 index 0000000..e69de29 diff --git a/style/base/variable/weui-progress.wxss b/style/base/variable/weui-progress.wxss new file mode 100644 index 0000000..e69de29 diff --git a/style/weui.wxss b/style/weui.wxss new file mode 100644 index 0000000..01e78ed --- /dev/null +++ b/style/weui.wxss @@ -0,0 +1,1040 @@ +page { + line-height: 1.6; + font-family: -apple-system-font, "Helvetica Neue", sans-serif; +} +icon { + vertical-align: middle; +} +.weui-cells { + position: relative; + margin-top: 1.17647059em; + background-color: #FFFFFF; + line-height: 1.41176471; + font-size: 17px; +} +.weui-cells:before { + content: " "; + position: absolute; + left: 0; + top: 0; + right: 0; + height: 1px; + border-top: 1rpx solid #D9D9D9; + color: #D9D9D9; +} +.weui-cells:after { + content: " "; + position: absolute; + left: 0; + bottom: 0; + right: 0; + height: 1px; + border-bottom: 1rpx solid #D9D9D9; + color: #D9D9D9; +} +.weui-cells__title { + margin-top: .77em; + margin-bottom: .3em; + padding-left: 15px; + padding-right: 15px; + color: #999999; + font-size: 14px; +} +.weui-cells_after-title { + margin-top: 0; +} +.weui-cells__tips { + margin-top: .3em; + color: #999999; + padding-left: 15px; + padding-right: 15px; + font-size: 14px; +} +.weui-cell { + padding: 10px 15px; + position: relative; + display: -webkit-box; + display: -webkit-flex; + display: flex; + -webkit-box-align: center; + -webkit-align-items: center; + align-items: center; +} +.weui-cell:before { + content: " "; + position: absolute; + left: 0; + top: 0; + right: 0; + height: 1px; + border-top: 1rpx solid #D9D9D9; + color: #D9D9D9; + left: 15px; +} +.weui-cell:first-child:before { + display: none; +} +.weui-cell_active { + background-color: #ECECEC; +} +.weui-cell_primary { + -webkit-box-align: start; + -webkit-align-items: flex-start; + align-items: flex-start; +} +.weui-cell__bd { + -webkit-box-flex: 1; + -webkit-flex: 1; + flex: 1; +} +.weui-cell__ft { + text-align: right; + color: #999999; +} +.weui-cell_access { + color: inherit; +} +.weui-cell__ft_in-access { + padding-right: 13px; + position: relative; +} +.weui-cell__ft_in-access:after { + content: " "; + display: inline-block; + height: 6px; + width: 6px; + border-width: 2px 2px 0 0; + border-color: #C8C8CD; + border-style: solid; + -webkit-transform: matrix(0.71, 0.71, -0.71, 0.71, 0, 0); + transform: matrix(0.71, 0.71, -0.71, 0.71, 0, 0); + position: relative; + top: -2px; + position: absolute; + top: 50%; + margin-top: -4px; + right: 2px; +} +.weui-cell_link { + color: #586C94; + font-size: 14px; +} +.weui-cell_link:active { + background-color: #ECECEC; +} +.weui-cell_link:first-child:before { + display: block; +} +.weui-icon-radio { + margin-left: 3.2px; + margin-right: 3.2px; +} +.weui-icon-checkbox_circle, +.weui-icon-checkbox_success { + margin-left: 4.6px; + margin-right: 4.6px; +} +.weui-check__label:active { + background-color: #ECECEC; +} +.weui-check { + position: absolute; + left: -9999px; +} +.weui-check__hd_in-checkbox { + padding-right: 0.35em; +} +.weui-cell__ft_in-radio { + padding-left: 0.35em; +} +.weui-cell_input { + padding-top: 0; + padding-bottom: 0; +} +.weui-label { + width: 105px; + word-wrap: break-word; + word-break: break-all; +} +.weui-input { + height: 2.58823529em; + min-height: 2.58823529em; + line-height: 2.58823529em; +} +.weui-toptips { + position: fixed; + -webkit-transform: translateZ(0); + transform: translateZ(0); + top: 0; + left: 0; + right: 0; + padding: 5px; + font-size: 14px; + text-align: center; + color: #FFFFFF; + z-index: 5000; + word-wrap: break-word; + word-break: break-all; +} +.weui-toptips_warn { + background-color: #E64340; +} +.weui-textarea { + display: block; + width: 100%; +} +.weui-textarea-counter { + color: #B2B2B2; + text-align: right; +} +.weui-textarea-counter_warn { + color: #E64340; +} +.weui-cell_warn { + color: #E64340; +} +.weui-form-preview { + position: relative; + background-color: #FFFFFF; +} +.weui-form-preview:before { + content: " "; + position: absolute; + left: 0; + top: 0; + right: 0; + height: 1px; + border-top: 1rpx solid #D9D9D9; + color: #D9D9D9; +} +.weui-form-preview:after { + content: " "; + position: absolute; + left: 0; + bottom: 0; + right: 0; + height: 1px; + border-bottom: 1rpx solid #D9D9D9; + color: #D9D9D9; +} +.weui-form-preview__value { + font-size: 14px; +} +.weui-form-preview__value_in-hd { + font-size: 26px; +} +.weui-form-preview__hd { + position: relative; + padding: 10px 15px; + text-align: right; + line-height: 2.5em; +} +.weui-form-preview__hd:after { + content: " "; + position: absolute; + left: 0; + bottom: 0; + right: 0; + height: 1px; + border-bottom: 1rpx solid #D9D9D9; + color: #D9D9D9; + left: 15px; +} +.weui-form-preview__bd { + padding: 10px 15px; + font-size: .9em; + text-align: right; + color: #999999; + line-height: 2; +} +.weui-form-preview__ft { + position: relative; + line-height: 50px; + display: -webkit-box; + display: -webkit-flex; + display: flex; +} +.weui-form-preview__ft:after { + content: " "; + position: absolute; + left: 0; + top: 0; + right: 0; + height: 1px; + border-top: 1rpx solid #D5D5D6; + color: #D5D5D6; +} +.weui-form-preview__item { + overflow: hidden; +} +.weui-form-preview__label { + float: left; + margin-right: 1em; + min-width: 4em; + color: #999999; + text-align: justify; + text-align-last: justify; +} +.weui-form-preview__value { + display: block; + overflow: hidden; + word-break: normal; + word-wrap: break-word; +} +.weui-form-preview__btn { + position: relative; + display: block; + -webkit-box-flex: 1; + -webkit-flex: 1; + flex: 1; + color: #3CC51F; + text-align: center; +} +.weui-form-preview__btn:after { + content: " "; + position: absolute; + left: 0; + top: 0; + width: 1px; + bottom: 0; + border-left: 1rpx solid #D5D5D6; + color: #D5D5D6; +} +.weui-form-preview__btn:first-child:after { + display: none; +} +.weui-form-preview__btn_active { + background-color: #EEEEEE; +} +.weui-form-preview__btn_default { + color: #999999; +} +.weui-form-preview__btn_primary { + color: #0BB20C; +} +.weui-cell_select { + padding: 0; +} +.weui-select { + position: relative; + padding-left: 15px; + padding-right: 30px; + height: 2.58823529em; + min-height: 2.58823529em; + line-height: 2.58823529em; + border-right: 1rpx solid #D9D9D9; +} +.weui-select:before { + content: " "; + display: inline-block; + height: 6px; + width: 6px; + border-width: 2px 2px 0 0; + border-color: #C8C8CD; + border-style: solid; + -webkit-transform: matrix(0.71, 0.71, -0.71, 0.71, 0, 0); + transform: matrix(0.71, 0.71, -0.71, 0.71, 0, 0); + position: relative; + top: -2px; + position: absolute; + top: 50%; + right: 15px; + margin-top: -4px; +} +.weui-select_in-select-after { + padding-left: 0; +} +.weui-cell__hd_in-select-after, +.weui-cell__bd_in-select-before { + padding-left: 15px; +} +.weui-cell_vcode { + padding-right: 0; +} +.weui-vcode-img { + margin-left: 5px; + height: 2.58823529em; + vertical-align: middle; +} +.weui-vcode-btn { + display: inline-block; + height: 2.58823529em; + margin-left: 5px; + padding: 0 0.6em 0 0.7em; + border-left: 1px solid #E5E5E5; + line-height: 2.58823529em; + vertical-align: middle; + font-size: 17px; + color: #3CC51F; + white-space: nowrap; +} +.weui-vcode-btn:active { + color: #52a341; +} +.weui-cell_switch { + padding-top: 6px; + padding-bottom: 6px; +} +.weui-uploader__hd { + display: -webkit-box; + display: -webkit-flex; + display: flex; + padding-bottom: 10px; + -webkit-box-align: center; + -webkit-align-items: center; + align-items: center; +} +.weui-uploader__title { + -webkit-box-flex: 1; + -webkit-flex: 1; + flex: 1; +} +.weui-uploader__info { + color: #B2B2B2; +} +.weui-uploader__bd { + margin-bottom: -4px; + margin-right: -9px; + overflow: hidden; +} +.weui-uploader__file { + float: left; + margin-right: 9px; + margin-bottom: 9px; +} +.weui-uploader__img { + display: block; + width: 79px; + height: 79px; +} +.weui-uploader__file_status { + position: relative; +} +.weui-uploader__file_status:before { + content: " "; + position: absolute; + top: 0; + right: 0; + bottom: 0; + left: 0; + background-color: rgba(0, 0, 0, 0.5); +} +.weui-uploader__file-content { + position: absolute; + top: 50%; + left: 50%; + -webkit-transform: translate(-50%, -50%); + transform: translate(-50%, -50%); + color: #FFFFFF; +} +.weui-uploader__input-box { + float: left; + position: relative; + margin-right: 9px; + margin-bottom: 9px; + width: 77px; + height: 77px; + border: 1px solid #D9D9D9; +} +.weui-uploader__input-box:before, +.weui-uploader__input-box:after { + content: " "; + position: absolute; + top: 50%; + left: 50%; + -webkit-transform: translate(-50%, -50%); + transform: translate(-50%, -50%); + background-color: #D9D9D9; +} +.weui-uploader__input-box:before { + width: 2px; + height: 39.5px; +} +.weui-uploader__input-box:after { + width: 39.5px; + height: 2px; +} +.weui-uploader__input-box:active { + border-color: #999999; +} +.weui-uploader__input-box:active:before, +.weui-uploader__input-box:active:after { + background-color: #999999; +} +.weui-uploader__input { + position: absolute; + z-index: 1; + top: 0; + left: 0; + width: 100%; + height: 100%; + opacity: 0; +} +.weui-article { + padding: 20px 15px; + font-size: 15px; +} +.weui-article__section { + margin-bottom: 1.5em; +} +.weui-article__h1 { + font-size: 18px; + font-weight: 400; + margin-bottom: .9em; +} +.weui-article__h2 { + font-size: 16px; + font-weight: 400; + margin-bottom: .34em; +} +.weui-article__h3 { + font-weight: 400; + font-size: 15px; + margin-bottom: .34em; +} +.weui-article__p { + margin: 0 0 .8em; +} +.weui-msg { + padding-top: 36px; + text-align: center; +} +.weui-msg__link { + display: inline; + color: #586C94; +} +.weui-msg__icon-area { + margin-bottom: 30px; +} +.weui-msg__text-area { + margin-bottom: 25px; + padding: 0 20px; +} +.weui-msg__title { + margin-bottom: 5px; + font-weight: 400; + font-size: 20px; +} +.weui-msg__desc { + font-size: 14px; + color: #999999; +} +.weui-msg__opr-area { + margin-bottom: 25px; +} +.weui-msg__extra-area { + margin-bottom: 15px; + font-size: 14px; + color: #999999; +} +@media screen and (min-height: 438px) { + .weui-msg__extra-area { + position: fixed; + left: 0; + bottom: 0; + width: 100%; + text-align: center; + } +} +.weui-flex { + display: -webkit-box; + display: -webkit-flex; + display: flex; +} +.weui-flex__item { + -webkit-box-flex: 1; + -webkit-flex: 1; + flex: 1; +} +.weui-btn { + margin-top: 15px; +} +.weui-btn:first-child { + margin-top: 0; +} +.weui-btn-area { + margin: 1.17647059em 15px 0.3em; +} +.weui-agree { + display: block; + padding: .5em 15px; + font-size: 13px; +} +.weui-agree__text { + color: #999999; +} +.weui-agree__link { + display: inline; + color: #586C94; +} +.weui-agree__checkbox { + position: absolute; + left: -9999px; +} +.weui-agree__checkbox-icon { + position: relative; + top: 2px; + display: inline-block; + border: 1px solid #D1D1D1; + background-color: #FFFFFF; + border-radius: 3px; + width: 11px; + height: 11px; +} +.weui-agree__checkbox-icon-check { + position: absolute; + top: 1px; + left: 1px; +} +.weui-footer { + color: #999999; + font-size: 14px; + text-align: center; +} +.weui-footer_fixed-bottom { + position: fixed; + bottom: .52em; + left: 0; + right: 0; +} +.weui-footer__links { + font-size: 0; +} +.weui-footer__link { + display: inline-block; + vertical-align: top; + margin: 0 .62em; + position: relative; + font-size: 14px; + color: #586C94; +} +.weui-footer__link:before { + content: " "; + position: absolute; + left: 0; + top: 0; + width: 1px; + bottom: 0; + border-left: 1rpx solid #C7C7C7; + color: #C7C7C7; + left: -0.65em; + top: .36em; + bottom: .36em; +} +.weui-footer__link:first-child:before { + display: none; +} +.weui-footer__text { + padding: 0 .34em; + font-size: 12px; +} +.weui-grids { + border-top: 1rpx solid #D9D9D9; + border-left: 1rpx solid #D9D9D9; + overflow: hidden; +} +.weui-grid { + position: relative; + float: left; + padding: 20px 10px; + width: 33.33333333%; + box-sizing: border-box; + border-right: 1rpx solid #D9D9D9; + border-bottom: 1rpx solid #D9D9D9; +} +.weui-grid_active { + background-color: #ECECEC; +} +.weui-grid__icon { + display: block; + width: 28px; + height: 28px; + margin: 0 auto; +} +.weui-grid__label { + margin-top: 5px; + display: block; + text-align: center; + color: #000000; + font-size: 14px; + white-space: nowrap; + text-overflow: ellipsis; + overflow: hidden; +} +.weui-loading { + margin: 0 5px; + width: 20px; + height: 20px; + display: inline-block; + vertical-align: middle; + -webkit-animation: weuiLoading 1s steps(12, end) infinite; + animation: weuiLoading 1s steps(12, end) infinite; + background: transparent url() no-repeat; + background-size: 100%; +} +.weui-loading.weui-loading_transparent { + background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 100 100'%3E%3Cpath fill='none' d='M0 0h100v100H0z'/%3E%3Crect xmlns='http://www.w3.org/2000/svg' width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.56)' rx='5' ry='5' transform='translate(0 -30)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.5)' rx='5' ry='5' transform='rotate(30 105.98 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.43)' rx='5' ry='5' transform='rotate(60 75.98 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.38)' rx='5' ry='5' transform='rotate(90 65 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.32)' rx='5' ry='5' transform='rotate(120 58.66 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.28)' rx='5' ry='5' transform='rotate(150 54.02 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.25)' rx='5' ry='5' transform='rotate(180 50 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.2)' rx='5' ry='5' transform='rotate(-150 45.98 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.17)' rx='5' ry='5' transform='rotate(-120 41.34 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.14)' rx='5' ry='5' transform='rotate(-90 35 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.1)' rx='5' ry='5' transform='rotate(-60 24.02 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.03)' rx='5' ry='5' transform='rotate(-30 -5.98 65)'/%3E%3C/svg%3E"); +} +@-webkit-keyframes weuiLoading { + 0% { + -webkit-transform: rotate3d(0, 0, 1, 0deg); + transform: rotate3d(0, 0, 1, 0deg); + } + 100% { + -webkit-transform: rotate3d(0, 0, 1, 360deg); + transform: rotate3d(0, 0, 1, 360deg); + } +} +@keyframes weuiLoading { + 0% { + -webkit-transform: rotate3d(0, 0, 1, 0deg); + transform: rotate3d(0, 0, 1, 0deg); + } + 100% { + -webkit-transform: rotate3d(0, 0, 1, 360deg); + transform: rotate3d(0, 0, 1, 360deg); + } +} +.weui-badge { + display: inline-block; + padding: .15em .4em; + min-width: 8px; + border-radius: 18px; + background-color: #E64340; + color: #FFFFFF; + line-height: 1.2; + text-align: center; + font-size: 12px; + vertical-align: middle; +} +.weui-badge_dot { + padding: .4em; + min-width: 0; +} +.weui-loadmore { + width: 65%; + margin: 1.5em auto; + line-height: 1.6em; + font-size: 14px; + text-align: center; +} +.weui-loadmore__tips { + display: inline-block; + vertical-align: middle; +} +.weui-loadmore_line { + border-top: 1px solid #E5E5E5; + margin-top: 2.4em; +} +.weui-loadmore__tips_in-line { + position: relative; + top: -0.9em; + padding: 0 .55em; + background-color: #FFFFFF; + color: #999999; +} +.weui-loadmore__tips_in-dot { + position: relative; + padding: 0 .16em; + width: 4px; + height: 1.6em; +} +.weui-loadmore__tips_in-dot:before { + content: " "; + position: absolute; + top: 50%; + left: 50%; + margin-top: -1px; + margin-left: -2px; + width: 4px; + height: 4px; + border-radius: 50%; + background-color: #E5E5E5; +} +.weui-panel { + background-color: #FFFFFF; + margin-top: 10px; + position: relative; + overflow: hidden; +} +.weui-panel:first-child { + margin-top: 0; +} +.weui-panel:before { + content: " "; + position: absolute; + left: 0; + top: 0; + right: 0; + height: 1px; + border-top: 1rpx solid #E5E5E5; + color: #E5E5E5; +} +.weui-panel:after { + content: " "; + position: absolute; + left: 0; + bottom: 0; + right: 0; + height: 1px; + border-bottom: 1rpx solid #E5E5E5; + color: #E5E5E5; +} +.weui-panel__hd { + padding: 14px 15px 10px; + color: #999999; + font-size: 13px; + position: relative; +} +.weui-panel__hd:after { + content: " "; + position: absolute; + left: 0; + bottom: 0; + right: 0; + height: 1px; + border-bottom: 1rpx solid #E5E5E5; + color: #E5E5E5; + left: 15px; +} +.weui-media-box { + padding: 15px; + position: relative; +} +.weui-media-box:before { + content: " "; + position: absolute; + left: 0; + top: 0; + right: 0; + height: 1px; + border-top: 1rpx solid #E5E5E5; + color: #E5E5E5; + left: 15px; +} +.weui-media-box:first-child:before { + display: none; +} +.weui-media-box__title { + font-weight: 400; + font-size: 17px; + width: auto; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + word-wrap: normal; + word-wrap: break-word; + word-break: break-all; +} +.weui-media-box__desc { + color: #999999; + font-size: 13px; + line-height: 1.2; + overflow: hidden; + text-overflow: ellipsis; + display: -webkit-box; + -webkit-box-orient: vertical; + -webkit-line-clamp: 2; +} +.weui-media-box__info { + margin-top: 15px; + padding-bottom: 5px; + font-size: 13px; + color: #CECECE; + line-height: 1em; + list-style: none; + overflow: hidden; +} +.weui-media-box__info__meta { + float: left; + padding-right: 1em; +} +.weui-media-box__info__meta_extra { + padding-left: 1em; + border-left: 1px solid #CECECE; +} +.weui-media-box__title_in-text { + margin-bottom: 8px; +} +.weui-media-box_appmsg { + display: -webkit-box; + display: -webkit-flex; + display: flex; + -webkit-box-align: center; + -webkit-align-items: center; + align-items: center; +} +.weui-media-box__thumb { + width: 100%; + height: 100%; + vertical-align: top; +} +.weui-media-box__hd_in-appmsg { + margin-right: .8em; + width: 60px; + height: 60px; + line-height: 60px; + text-align: center; +} +.weui-media-box__bd_in-appmsg { + -webkit-box-flex: 1; + -webkit-flex: 1; + flex: 1; + min-width: 0; +} +.weui-media-box_small-appmsg { + padding: 0; +} +.weui-cells_in-small-appmsg { + margin-top: 0; +} +.weui-cells_in-small-appmsg:before { + display: none; +} +.weui-progress { + display: -webkit-box; + display: -webkit-flex; + display: flex; + -webkit-box-align: center; + -webkit-align-items: center; + align-items: center; +} +.weui-progress__bar { + -webkit-box-flex: 1; + -webkit-flex: 1; + flex: 1; +} +.weui-progress__opr { + margin-left: 15px; + font-size: 0; +} +.weui-navbar { + display: -webkit-box; + display: -webkit-flex; + display: flex; + position: absolute; + z-index: 500; + top: 0; + width: 100%; + border-bottom: 1rpx solid #CCCCCC; +} +.weui-navbar__item { + position: relative; + display: block; + -webkit-box-flex: 1; + -webkit-flex: 1; + flex: 1; + padding: 13px 0; + text-align: center; + font-size: 0; +} +.weui-navbar__item.weui-bar__item_on { + color: #1AAD19; +} +.weui-navbar__slider { + position: absolute; + content: " "; + left: 0; + bottom: 0; + width: 6em; + height: 3px; + background-color: #1AAD19; + -webkit-transition: -webkit-transform .3s; + transition: -webkit-transform .3s; + transition: transform .3s; + transition: transform .3s, -webkit-transform .3s; +} +.weui-navbar__title { + display: inline-block; + font-size: 15px; + max-width: 8em; + width: auto; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + word-wrap: normal; +} +.weui-tab { + position: relative; + height: 100%; +} +.weui-tab__panel { + box-sizing: border-box; + height: 100%; + padding-top: 50px; + overflow: auto; + -webkit-overflow-scrolling: touch; +} +.weui-search-bar { + position: relative; + padding: 8px 10px; + display: -webkit-box; + display: -webkit-flex; + display: flex; + box-sizing: border-box; + background-color: #EFEFF4; + border-top: 1rpx solid #D7D6DC; + border-bottom: 1rpx solid #D7D6DC; +} +.weui-icon-search { + margin-right: 8px; + font-size: inherit; +} +.weui-icon-search_in-box { + position: absolute; + left: 10px; + top: 7px; +} +.weui-search-bar__text { + display: inline-block; + font-size: 14px; + vertical-align: middle; +} +.weui-search-bar__form { + position: relative; + -webkit-box-flex: 1; + -webkit-flex: auto; + flex: auto; + border-radius: 5px; + background: #FFFFFF; + border: 1rpx solid #E6E6EA; +} +.weui-search-bar__box { + position: relative; + padding-left: 30px; + padding-right: 30px; + width: 100%; + box-sizing: border-box; + z-index: 1; +} +.weui-search-bar__input { + height: 28px; + line-height: 28px; + font-size: 14px; +} +.weui-icon-clear { + position: absolute; + top: 0; + right: 0; + padding: 7px 8px; + font-size: 0; +} +.weui-search-bar__label { + position: absolute; + top: 0; + right: 0; + bottom: 0; + left: 0; + z-index: 2; + border-radius: 3px; + text-align: center; + color: #9B9B9B; + background: #FFFFFF; + line-height: 28px; +} +.weui-search-bar__cancel-btn { + margin-left: 10px; + line-height: 28px; + color: #09BB07; + white-space: nowrap; +} diff --git a/style/widget/weui-agree/weui-agree.wxss b/style/widget/weui-agree/weui-agree.wxss new file mode 100644 index 0000000..ff2a6a3 --- /dev/null +++ b/style/widget/weui-agree/weui-agree.wxss @@ -0,0 +1,31 @@ +.weui-agree { + display: block; + padding: .5em 15px; + font-size: 13px; +} +.weui-agree__text { + color: #999999; +} +.weui-agree__link { + display: inline; + color: #586C94; +} +.weui-agree__checkbox { + position: absolute; + left: -9999px; +} +.weui-agree__checkbox-icon { + position: relative; + top: 2px; + display: inline-block; + border: 1px solid #D1D1D1; + background-color: #FFFFFF; + border-radius: 3px; + width: 11px; + height: 11px; +} +.weui-agree__checkbox-icon-check { + position: absolute; + top: 1px; + left: 1px; +} diff --git a/style/widget/weui-animate/weui-animate.wxss b/style/widget/weui-animate/weui-animate.wxss new file mode 100644 index 0000000..566599a --- /dev/null +++ b/style/widget/weui-animate/weui-animate.wxss @@ -0,0 +1,88 @@ +@-webkit-keyframes slideUp { + from { + -webkit-transform: translate3d(0, 100%, 0); + transform: translate3d(0, 100%, 0); + } + to { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + } +} +@keyframes slideUp { + from { + -webkit-transform: translate3d(0, 100%, 0); + transform: translate3d(0, 100%, 0); + } + to { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + } +} +.weui-animate-slide-up { + -webkit-animation: slideUp ease .3s forwards; + animation: slideUp ease .3s forwards; +} +@-webkit-keyframes slideDown { + from { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + } + to { + -webkit-transform: translate3d(0, 100%, 0); + transform: translate3d(0, 100%, 0); + } +} +@keyframes slideDown { + from { + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + } + to { + -webkit-transform: translate3d(0, 100%, 0); + transform: translate3d(0, 100%, 0); + } +} +.weui-animate-slide-down { + -webkit-animation: slideDown ease .3s forwards; + animation: slideDown ease .3s forwards; +} +@-webkit-keyframes fadeIn { + from { + opacity: 0; + } + to { + opacity: 1; + } +} +@keyframes fadeIn { + from { + opacity: 0; + } + to { + opacity: 1; + } +} +.weui-animate-fade-in { + -webkit-animation: fadeIn ease .3s forwards; + animation: fadeIn ease .3s forwards; +} +@-webkit-keyframes fadeOut { + from { + opacity: 1; + } + to { + opacity: 0; + } +} +@keyframes fadeOut { + from { + opacity: 1; + } + to { + opacity: 0; + } +} +.weui-animate-fade-out { + -webkit-animation: fadeOut ease .3s forwards; + animation: fadeOut ease .3s forwards; +} diff --git a/style/widget/weui-button/weui-button.wxss b/style/widget/weui-button/weui-button.wxss new file mode 100644 index 0000000..2eee2ce --- /dev/null +++ b/style/widget/weui-button/weui-button.wxss @@ -0,0 +1,9 @@ +.weui-btn { + margin-top: 15px; +} +.weui-btn:first-child { + margin-top: 0; +} +.weui-btn-area { + margin: 1.17647059em 15px 0.3em; +} diff --git a/style/widget/weui-cell/weui-access.wxss b/style/widget/weui-cell/weui-access.wxss new file mode 100644 index 0000000..d333752 --- /dev/null +++ b/style/widget/weui-cell/weui-access.wxss @@ -0,0 +1,34 @@ +.weui-cell_access { + color: inherit; +} +.weui-cell__ft_in-access { + padding-right: 13px; + position: relative; +} +.weui-cell__ft_in-access:after { + content: " "; + display: inline-block; + height: 6px; + width: 6px; + border-width: 2px 2px 0 0; + border-color: #C8C8CD; + border-style: solid; + -webkit-transform: matrix(0.71, 0.71, -0.71, 0.71, 0, 0); + transform: matrix(0.71, 0.71, -0.71, 0.71, 0, 0); + position: relative; + top: -2px; + position: absolute; + top: 50%; + margin-top: -4px; + right: 2px; +} +.weui-cell_link { + color: #586C94; + font-size: 14px; +} +.weui-cell_link:active { + background-color: #ECECEC; +} +.weui-cell_link:first-child:before { + display: block; +} diff --git a/style/widget/weui-cell/weui-cell.wxss b/style/widget/weui-cell/weui-cell.wxss new file mode 100644 index 0000000..c877e4c --- /dev/null +++ b/style/widget/weui-cell/weui-cell.wxss @@ -0,0 +1,86 @@ +.weui-cells { + position: relative; + margin-top: 1.17647059em; + background-color: #FFFFFF; + line-height: 1.41176471; + font-size: 17px; +} +.weui-cells:before { + content: " "; + position: absolute; + left: 0; + top: 0; + right: 0; + height: 1px; + border-top: 1rpx solid #D9D9D9; + color: #D9D9D9; +} +.weui-cells:after { + content: " "; + position: absolute; + left: 0; + bottom: 0; + right: 0; + height: 1px; + border-bottom: 1rpx solid #D9D9D9; + color: #D9D9D9; +} +.weui-cells__title { + margin-top: .77em; + margin-bottom: .3em; + padding-left: 15px; + padding-right: 15px; + color: #999999; + font-size: 14px; +} +.weui-cells_after-title { + margin-top: 0; +} +.weui-cells__tips { + margin-top: .3em; + color: #999999; + padding-left: 15px; + padding-right: 15px; + font-size: 14px; +} +.weui-cell { + padding: 10px 15px; + position: relative; + display: -webkit-box; + display: -webkit-flex; + display: flex; + -webkit-box-align: center; + -webkit-align-items: center; + align-items: center; +} +.weui-cell:before { + content: " "; + position: absolute; + left: 0; + top: 0; + right: 0; + height: 1px; + border-top: 1rpx solid #D9D9D9; + color: #D9D9D9; + left: 15px; +} +.weui-cell:first-child:before { + display: none; +} +.weui-cell_active { + background-color: #ECECEC; +} +.weui-cell_primary { + -webkit-box-align: start; + -webkit-align-items: flex-start; + align-items: flex-start; +} +.weui-cell__bd { + -webkit-box-flex: 1; + -webkit-flex: 1; + flex: 1; +} +.weui-cell__ft { + text-align: right; + color: #999999; +} diff --git a/style/widget/weui-cell/weui-check.wxss b/style/widget/weui-cell/weui-check.wxss new file mode 100644 index 0000000..1302acd --- /dev/null +++ b/style/widget/weui-cell/weui-check.wxss @@ -0,0 +1,22 @@ +.weui-icon-radio { + margin-left: 3.2px; + margin-right: 3.2px; +} +.weui-icon-checkbox_circle, +.weui-icon-checkbox_success { + margin-left: 4.6px; + margin-right: 4.6px; +} +.weui-check__label:active { + background-color: #ECECEC; +} +.weui-check { + position: absolute; + left: -9999px; +} +.weui-check__hd_in-checkbox { + padding-right: 0.35em; +} +.weui-cell__ft_in-radio { + padding-left: 0.35em; +} diff --git a/style/widget/weui-cell/weui-form.wxss b/style/widget/weui-cell/weui-form.wxss new file mode 100644 index 0000000..5a94dcc --- /dev/null +++ b/style/widget/weui-cell/weui-form.wxss @@ -0,0 +1,224 @@ +.weui-cell_input { + padding-top: 0; + padding-bottom: 0; +} +.weui-label { + width: 105px; + word-wrap: break-word; + word-break: break-all; +} +.weui-input { + height: 2.58823529em; + min-height: 2.58823529em; + line-height: 2.58823529em; +} +.weui-toptips { + position: fixed; + -webkit-transform: translateZ(0); + transform: translateZ(0); + top: 0; + left: 0; + right: 0; + padding: 5px; + font-size: 14px; + text-align: center; + color: #FFFFFF; + z-index: 5000; + word-wrap: break-word; + word-break: break-all; +} +.weui-toptips_warn { + background-color: #E64340; +} +.weui-textarea { + display: block; + width: 100%; +} +.weui-textarea-counter { + color: #B2B2B2; + text-align: right; +} +.weui-textarea-counter_warn { + color: #E64340; +} +.weui-cell_warn { + color: #E64340; +} +.weui-form-preview { + position: relative; + background-color: #FFFFFF; +} +.weui-form-preview:before { + content: " "; + position: absolute; + left: 0; + top: 0; + right: 0; + height: 1px; + border-top: 1rpx solid #D9D9D9; + color: #D9D9D9; +} +.weui-form-preview:after { + content: " "; + position: absolute; + left: 0; + bottom: 0; + right: 0; + height: 1px; + border-bottom: 1rpx solid #D9D9D9; + color: #D9D9D9; +} +.weui-form-preview__value { + font-size: 14px; +} +.weui-form-preview__value_in-hd { + font-size: 26px; +} +.weui-form-preview__hd { + position: relative; + padding: 10px 15px; + text-align: right; + line-height: 2.5em; +} +.weui-form-preview__hd:after { + content: " "; + position: absolute; + left: 0; + bottom: 0; + right: 0; + height: 1px; + border-bottom: 1rpx solid #D9D9D9; + color: #D9D9D9; + left: 15px; +} +.weui-form-preview__bd { + padding: 10px 15px; + font-size: .9em; + text-align: right; + color: #999999; + line-height: 2; +} +.weui-form-preview__ft { + position: relative; + line-height: 50px; + display: -webkit-box; + display: -webkit-flex; + display: flex; +} +.weui-form-preview__ft:after { + content: " "; + position: absolute; + left: 0; + top: 0; + right: 0; + height: 1px; + border-top: 1rpx solid #D5D5D6; + color: #D5D5D6; +} +.weui-form-preview__item { + overflow: hidden; +} +.weui-form-preview__label { + float: left; + margin-right: 1em; + min-width: 4em; + color: #999999; + text-align: justify; + text-align-last: justify; +} +.weui-form-preview__value { + display: block; + overflow: hidden; + word-break: normal; + word-wrap: break-word; +} +.weui-form-preview__btn { + position: relative; + display: block; + -webkit-box-flex: 1; + -webkit-flex: 1; + flex: 1; + color: #3CC51F; + text-align: center; +} +.weui-form-preview__btn:after { + content: " "; + position: absolute; + left: 0; + top: 0; + width: 1px; + bottom: 0; + border-left: 1rpx solid #D5D5D6; + color: #D5D5D6; +} +.weui-form-preview__btn:first-child:after { + display: none; +} +.weui-form-preview__btn_active { + background-color: #EEEEEE; +} +.weui-form-preview__btn_default { + color: #999999; +} +.weui-form-preview__btn_primary { + color: #0BB20C; +} +.weui-cell_select { + padding: 0; +} +.weui-select { + position: relative; + padding-left: 15px; + padding-right: 30px; + height: 2.58823529em; + min-height: 2.58823529em; + line-height: 2.58823529em; + border-right: 1rpx solid #D9D9D9; +} +.weui-select:before { + content: " "; + display: inline-block; + height: 6px; + width: 6px; + border-width: 2px 2px 0 0; + border-color: #C8C8CD; + border-style: solid; + -webkit-transform: matrix(0.71, 0.71, -0.71, 0.71, 0, 0); + transform: matrix(0.71, 0.71, -0.71, 0.71, 0, 0); + position: relative; + top: -2px; + position: absolute; + top: 50%; + right: 15px; + margin-top: -4px; +} +.weui-select_in-select-after { + padding-left: 0; +} +.weui-cell__hd_in-select-after, +.weui-cell__bd_in-select-before { + padding-left: 15px; +} +.weui-cell_vcode { + padding-right: 0; +} +.weui-vcode-img { + margin-left: 5px; + height: 2.58823529em; + vertical-align: middle; +} +.weui-vcode-btn { + display: inline-block; + height: 2.58823529em; + margin-left: 5px; + padding: 0 0.6em 0 0.7em; + border-left: 1px solid #E5E5E5; + line-height: 2.58823529em; + vertical-align: middle; + font-size: 17px; + color: #3CC51F; + white-space: nowrap; +} +.weui-vcode-btn:active { + color: #52a341; +} diff --git a/style/widget/weui-cell/weui-form/weui-form-preview.wxss b/style/widget/weui-cell/weui-form/weui-form-preview.wxss new file mode 100644 index 0000000..d229906 --- /dev/null +++ b/style/widget/weui-cell/weui-form/weui-form-preview.wxss @@ -0,0 +1,119 @@ +.weui-form-preview { + position: relative; + background-color: #FFFFFF; +} +.weui-form-preview:before { + content: " "; + position: absolute; + left: 0; + top: 0; + right: 0; + height: 1px; + border-top: 1rpx solid #D9D9D9; + color: #D9D9D9; +} +.weui-form-preview:after { + content: " "; + position: absolute; + left: 0; + bottom: 0; + right: 0; + height: 1px; + border-bottom: 1rpx solid #D9D9D9; + color: #D9D9D9; +} +.weui-form-preview__value { + font-size: 14px; +} +.weui-form-preview__value_in-hd { + font-size: 26px; +} +.weui-form-preview__hd { + position: relative; + padding: 10px 15px; + text-align: right; + line-height: 2.5em; +} +.weui-form-preview__hd:after { + content: " "; + position: absolute; + left: 0; + bottom: 0; + right: 0; + height: 1px; + border-bottom: 1rpx solid #D9D9D9; + color: #D9D9D9; + left: 15px; +} +.weui-form-preview__bd { + padding: 10px 15px; + font-size: .9em; + text-align: right; + color: #999999; + line-height: 2; +} +.weui-form-preview__ft { + position: relative; + line-height: 50px; + display: -webkit-box; + display: -webkit-flex; + display: flex; +} +.weui-form-preview__ft:after { + content: " "; + position: absolute; + left: 0; + top: 0; + right: 0; + height: 1px; + border-top: 1rpx solid #D5D5D6; + color: #D5D5D6; +} +.weui-form-preview__item { + overflow: hidden; +} +.weui-form-preview__label { + float: left; + margin-right: 1em; + min-width: 4em; + color: #999999; + text-align: justify; + text-align-last: justify; +} +.weui-form-preview__value { + display: block; + overflow: hidden; + word-break: normal; + word-wrap: break-word; +} +.weui-form-preview__btn { + position: relative; + display: block; + -webkit-box-flex: 1; + -webkit-flex: 1; + flex: 1; + color: #3CC51F; + text-align: center; +} +.weui-form-preview__btn:after { + content: " "; + position: absolute; + left: 0; + top: 0; + width: 1px; + bottom: 0; + border-left: 1rpx solid #D5D5D6; + color: #D5D5D6; +} +.weui-form-preview__btn:first-child:after { + display: none; +} +.weui-form-preview__btn_active { + background-color: #EEEEEE; +} +.weui-form-preview__btn_default { + color: #999999; +} +.weui-form-preview__btn_primary { + color: #0BB20C; +} diff --git a/style/widget/weui-cell/weui-form/weui-form_common.wxss b/style/widget/weui-cell/weui-form/weui-form_common.wxss new file mode 100644 index 0000000..b9195e8 --- /dev/null +++ b/style/widget/weui-cell/weui-form/weui-form_common.wxss @@ -0,0 +1,46 @@ +.weui-cell_input { + padding-top: 0; + padding-bottom: 0; +} +.weui-label { + width: 105px; + word-wrap: break-word; + word-break: break-all; +} +.weui-input { + height: 2.58823529em; + min-height: 2.58823529em; + line-height: 2.58823529em; +} +.weui-toptips { + position: fixed; + -webkit-transform: translateZ(0); + transform: translateZ(0); + top: 0; + left: 0; + right: 0; + padding: 5px; + font-size: 14px; + text-align: center; + color: #FFFFFF; + z-index: 5000; + word-wrap: break-word; + word-break: break-all; +} +.weui-toptips_warn { + background-color: #E64340; +} +.weui-textarea { + display: block; + width: 100%; +} +.weui-textarea-counter { + color: #B2B2B2; + text-align: right; +} +.weui-textarea-counter_warn { + color: #E64340; +} +.weui-cell_warn { + color: #E64340; +} diff --git a/style/widget/weui-cell/weui-form/weui-select.wxss b/style/widget/weui-cell/weui-form/weui-select.wxss new file mode 100644 index 0000000..6cb48f7 --- /dev/null +++ b/style/widget/weui-cell/weui-form/weui-select.wxss @@ -0,0 +1,36 @@ +.weui-cell_select { + padding: 0; +} +.weui-select { + position: relative; + padding-left: 15px; + padding-right: 30px; + height: 2.58823529em; + min-height: 2.58823529em; + line-height: 2.58823529em; + border-right: 1rpx solid #D9D9D9; +} +.weui-select:before { + content: " "; + display: inline-block; + height: 6px; + width: 6px; + border-width: 2px 2px 0 0; + border-color: #C8C8CD; + border-style: solid; + -webkit-transform: matrix(0.71, 0.71, -0.71, 0.71, 0, 0); + transform: matrix(0.71, 0.71, -0.71, 0.71, 0, 0); + position: relative; + top: -2px; + position: absolute; + top: 50%; + right: 15px; + margin-top: -4px; +} +.weui-select_in-select-after { + padding-left: 0; +} +.weui-cell__hd_in-select-after, +.weui-cell__bd_in-select-before { + padding-left: 15px; +} diff --git a/style/widget/weui-cell/weui-form/weui-vcode.wxss b/style/widget/weui-cell/weui-form/weui-vcode.wxss new file mode 100644 index 0000000..430848c --- /dev/null +++ b/style/widget/weui-cell/weui-form/weui-vcode.wxss @@ -0,0 +1,23 @@ +.weui-cell_vcode { + padding-right: 0; +} +.weui-vcode-img { + margin-left: 5px; + height: 2.58823529em; + vertical-align: middle; +} +.weui-vcode-btn { + display: inline-block; + height: 2.58823529em; + margin-left: 5px; + padding: 0 0.6em 0 0.7em; + border-left: 1px solid #E5E5E5; + line-height: 2.58823529em; + vertical-align: middle; + font-size: 17px; + color: #3CC51F; + white-space: nowrap; +} +.weui-vcode-btn:active { + color: #52a341; +} diff --git a/style/widget/weui-cell/weui-switch.wxss b/style/widget/weui-cell/weui-switch.wxss new file mode 100644 index 0000000..e876948 --- /dev/null +++ b/style/widget/weui-cell/weui-switch.wxss @@ -0,0 +1,4 @@ +.weui-cell_switch { + padding-top: 6px; + padding-bottom: 6px; +} diff --git a/style/widget/weui-cell/weui-uploader.wxss b/style/widget/weui-cell/weui-uploader.wxss new file mode 100644 index 0000000..9300d34 --- /dev/null +++ b/style/widget/weui-cell/weui-uploader.wxss @@ -0,0 +1,95 @@ +.weui-uploader__hd { + display: -webkit-box; + display: -webkit-flex; + display: flex; + padding-bottom: 10px; + -webkit-box-align: center; + -webkit-align-items: center; + align-items: center; +} +.weui-uploader__title { + -webkit-box-flex: 1; + -webkit-flex: 1; + flex: 1; +} +.weui-uploader__info { + color: #B2B2B2; +} +.weui-uploader__bd { + margin-bottom: -4px; + margin-right: -9px; + overflow: hidden; +} +.weui-uploader__file { + float: left; + margin-right: 9px; + margin-bottom: 9px; +} +.weui-uploader__img { + display: block; + width: 79px; + height: 79px; +} +.weui-uploader__file_status { + position: relative; +} +.weui-uploader__file_status:before { + content: " "; + position: absolute; + top: 0; + right: 0; + bottom: 0; + left: 0; + background-color: rgba(0, 0, 0, 0.5); +} +.weui-uploader__file-content { + position: absolute; + top: 50%; + left: 50%; + -webkit-transform: translate(-50%, -50%); + transform: translate(-50%, -50%); + color: #FFFFFF; +} +.weui-uploader__input-box { + float: left; + position: relative; + margin-right: 9px; + margin-bottom: 9px; + width: 77px; + height: 77px; + border: 1px solid #D9D9D9; +} +.weui-uploader__input-box:before, +.weui-uploader__input-box:after { + content: " "; + position: absolute; + top: 50%; + left: 50%; + -webkit-transform: translate(-50%, -50%); + transform: translate(-50%, -50%); + background-color: #D9D9D9; +} +.weui-uploader__input-box:before { + width: 2px; + height: 39.5px; +} +.weui-uploader__input-box:after { + width: 39.5px; + height: 2px; +} +.weui-uploader__input-box:active { + border-color: #999999; +} +.weui-uploader__input-box:active:before, +.weui-uploader__input-box:active:after { + background-color: #999999; +} +.weui-uploader__input { + position: absolute; + z-index: 1; + top: 0; + left: 0; + width: 100%; + height: 100%; + opacity: 0; +} diff --git a/style/widget/weui-flex/weui-flex.wxss b/style/widget/weui-flex/weui-flex.wxss new file mode 100644 index 0000000..a4fc144 --- /dev/null +++ b/style/widget/weui-flex/weui-flex.wxss @@ -0,0 +1,10 @@ +.weui-flex { + display: -webkit-box; + display: -webkit-flex; + display: flex; +} +.weui-flex__item { + -webkit-box-flex: 1; + -webkit-flex: 1; + flex: 1; +} diff --git a/style/widget/weui-footer/weui-footer.wxss b/style/widget/weui-footer/weui-footer.wxss new file mode 100644 index 0000000..271bdec --- /dev/null +++ b/style/widget/weui-footer/weui-footer.wxss @@ -0,0 +1,42 @@ +.weui-footer { + color: #999999; + font-size: 14px; + text-align: center; +} +.weui-footer_fixed-bottom { + position: fixed; + bottom: .52em; + left: 0; + right: 0; +} +.weui-footer__links { + font-size: 0; +} +.weui-footer__link { + display: inline-block; + vertical-align: top; + margin: 0 .62em; + position: relative; + font-size: 14px; + color: #586C94; +} +.weui-footer__link:before { + content: " "; + position: absolute; + left: 0; + top: 0; + width: 1px; + bottom: 0; + border-left: 1rpx solid #C7C7C7; + color: #C7C7C7; + left: -0.65em; + top: .36em; + bottom: .36em; +} +.weui-footer__link:first-child:before { + display: none; +} +.weui-footer__text { + padding: 0 .34em; + font-size: 12px; +} diff --git a/style/widget/weui-grid/weui-grid.wxss b/style/widget/weui-grid/weui-grid.wxss new file mode 100644 index 0000000..d8f7b91 --- /dev/null +++ b/style/widget/weui-grid/weui-grid.wxss @@ -0,0 +1,33 @@ +.weui-grids { + border-top: 1rpx solid #D9D9D9; + border-left: 1rpx solid #D9D9D9; + overflow: hidden; +} +.weui-grid { + position: relative; + float: left; + padding: 20px 10px; + width: 33.33333333%; + box-sizing: border-box; + border-right: 1rpx solid #D9D9D9; + border-bottom: 1rpx solid #D9D9D9; +} +.weui-grid_active { + background-color: #ECECEC; +} +.weui-grid__icon { + display: block; + width: 28px; + height: 28px; + margin: 0 auto; +} +.weui-grid__label { + margin-top: 5px; + display: block; + text-align: center; + color: #000000; + font-size: 14px; + white-space: nowrap; + text-overflow: ellipsis; + overflow: hidden; +} diff --git a/style/widget/weui-loading/weui-loading.wxss b/style/widget/weui-loading/weui-loading.wxss new file mode 100644 index 0000000..3fec603 --- /dev/null +++ b/style/widget/weui-loading/weui-loading.wxss @@ -0,0 +1,34 @@ +.weui-loading { + margin: 0 5px; + width: 20px; + height: 20px; + display: inline-block; + vertical-align: middle; + -webkit-animation: weuiLoading 1s steps(12, end) infinite; + animation: weuiLoading 1s steps(12, end) infinite; + background: transparent url() no-repeat; + background-size: 100%; +} +.weui-loading.weui-loading_transparent { + background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 100 100'%3E%3Cpath fill='none' d='M0 0h100v100H0z'/%3E%3Crect xmlns='http://www.w3.org/2000/svg' width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.56)' rx='5' ry='5' transform='translate(0 -30)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.5)' rx='5' ry='5' transform='rotate(30 105.98 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.43)' rx='5' ry='5' transform='rotate(60 75.98 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.38)' rx='5' ry='5' transform='rotate(90 65 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.32)' rx='5' ry='5' transform='rotate(120 58.66 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.28)' rx='5' ry='5' transform='rotate(150 54.02 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.25)' rx='5' ry='5' transform='rotate(180 50 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.2)' rx='5' ry='5' transform='rotate(-150 45.98 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.17)' rx='5' ry='5' transform='rotate(-120 41.34 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.14)' rx='5' ry='5' transform='rotate(-90 35 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.1)' rx='5' ry='5' transform='rotate(-60 24.02 65)'/%3E%3Crect width='7' height='20' x='46.5' y='40' fill='rgba(255,255,255,.03)' rx='5' ry='5' transform='rotate(-30 -5.98 65)'/%3E%3C/svg%3E"); +} +@-webkit-keyframes weuiLoading { + 0% { + -webkit-transform: rotate3d(0, 0, 1, 0deg); + transform: rotate3d(0, 0, 1, 0deg); + } + 100% { + -webkit-transform: rotate3d(0, 0, 1, 360deg); + transform: rotate3d(0, 0, 1, 360deg); + } +} +@keyframes weuiLoading { + 0% { + -webkit-transform: rotate3d(0, 0, 1, 0deg); + transform: rotate3d(0, 0, 1, 0deg); + } + 100% { + -webkit-transform: rotate3d(0, 0, 1, 360deg); + transform: rotate3d(0, 0, 1, 360deg); + } +} diff --git a/style/widget/weui-media-box/weui-media-box.wxss b/style/widget/weui-media-box/weui-media-box.wxss new file mode 100644 index 0000000..b214781 --- /dev/null +++ b/style/widget/weui-media-box/weui-media-box.wxss @@ -0,0 +1,94 @@ +.weui-media-box { + padding: 15px; + position: relative; +} +.weui-media-box:before { + content: " "; + position: absolute; + left: 0; + top: 0; + right: 0; + height: 1px; + border-top: 1rpx solid #E5E5E5; + color: #E5E5E5; + left: 15px; +} +.weui-media-box:first-child:before { + display: none; +} +.weui-media-box__title { + font-weight: 400; + font-size: 17px; + width: auto; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + word-wrap: normal; + word-wrap: break-word; + word-break: break-all; +} +.weui-media-box__desc { + color: #999999; + font-size: 13px; + line-height: 1.2; + overflow: hidden; + text-overflow: ellipsis; + display: -webkit-box; + -webkit-box-orient: vertical; + -webkit-line-clamp: 2; +} +.weui-media-box__info { + margin-top: 15px; + padding-bottom: 5px; + font-size: 13px; + color: #CECECE; + line-height: 1em; + list-style: none; + overflow: hidden; +} +.weui-media-box__info__meta { + float: left; + padding-right: 1em; +} +.weui-media-box__info__meta_extra { + padding-left: 1em; + border-left: 1px solid #CECECE; +} +.weui-media-box__title_in-text { + margin-bottom: 8px; +} +.weui-media-box_appmsg { + display: -webkit-box; + display: -webkit-flex; + display: flex; + -webkit-box-align: center; + -webkit-align-items: center; + align-items: center; +} +.weui-media-box__thumb { + width: 100%; + height: 100%; + vertical-align: top; +} +.weui-media-box__hd_in-appmsg { + margin-right: .8em; + width: 60px; + height: 60px; + line-height: 60px; + text-align: center; +} +.weui-media-box__bd_in-appmsg { + -webkit-box-flex: 1; + -webkit-flex: 1; + flex: 1; + min-width: 0; +} +.weui-media-box_small-appmsg { + padding: 0; +} +.weui-cells_in-small-appmsg { + margin-top: 0; +} +.weui-cells_in-small-appmsg:before { + display: none; +} diff --git a/style/widget/weui-page/weui-article.wxss b/style/widget/weui-page/weui-article.wxss new file mode 100644 index 0000000..2aa3640 --- /dev/null +++ b/style/widget/weui-page/weui-article.wxss @@ -0,0 +1,25 @@ +.weui-article { + padding: 20px 15px; + font-size: 15px; +} +.weui-article__section { + margin-bottom: 1.5em; +} +.weui-article__h1 { + font-size: 18px; + font-weight: 400; + margin-bottom: .9em; +} +.weui-article__h2 { + font-size: 16px; + font-weight: 400; + margin-bottom: .34em; +} +.weui-article__h3 { + font-weight: 400; + font-size: 15px; + margin-bottom: .34em; +} +.weui-article__p { + margin: 0 0 .8em; +} diff --git a/style/widget/weui-page/weui-msg.wxss b/style/widget/weui-page/weui-msg.wxss new file mode 100644 index 0000000..c5765fa --- /dev/null +++ b/style/widget/weui-page/weui-msg.wxss @@ -0,0 +1,41 @@ +.weui-msg { + padding-top: 36px; + text-align: center; +} +.weui-msg__link { + display: inline; + color: #586C94; +} +.weui-msg__icon-area { + margin-bottom: 30px; +} +.weui-msg__text-area { + margin-bottom: 25px; + padding: 0 20px; +} +.weui-msg__title { + margin-bottom: 5px; + font-weight: 400; + font-size: 20px; +} +.weui-msg__desc { + font-size: 14px; + color: #999999; +} +.weui-msg__opr-area { + margin-bottom: 25px; +} +.weui-msg__extra-area { + margin-bottom: 15px; + font-size: 14px; + color: #999999; +} +@media screen and (min-height: 438px) { + .weui-msg__extra-area { + position: fixed; + left: 0; + bottom: 0; + width: 100%; + text-align: center; + } +} diff --git a/style/widget/weui-panel/weui-panel.wxss b/style/widget/weui-panel/weui-panel.wxss new file mode 100644 index 0000000..1429b03 --- /dev/null +++ b/style/widget/weui-panel/weui-panel.wxss @@ -0,0 +1,46 @@ +.weui-panel { + background-color: #FFFFFF; + margin-top: 10px; + position: relative; + overflow: hidden; +} +.weui-panel:first-child { + margin-top: 0; +} +.weui-panel:before { + content: " "; + position: absolute; + left: 0; + top: 0; + right: 0; + height: 1px; + border-top: 1rpx solid #E5E5E5; + color: #E5E5E5; +} +.weui-panel:after { + content: " "; + position: absolute; + left: 0; + bottom: 0; + right: 0; + height: 1px; + border-bottom: 1rpx solid #E5E5E5; + color: #E5E5E5; +} +.weui-panel__hd { + padding: 14px 15px 10px; + color: #999999; + font-size: 13px; + position: relative; +} +.weui-panel__hd:after { + content: " "; + position: absolute; + left: 0; + bottom: 0; + right: 0; + height: 1px; + border-bottom: 1rpx solid #E5E5E5; + color: #E5E5E5; + left: 15px; +} diff --git a/style/widget/weui-progress/weui-progress.wxss b/style/widget/weui-progress/weui-progress.wxss new file mode 100644 index 0000000..cb47ad3 --- /dev/null +++ b/style/widget/weui-progress/weui-progress.wxss @@ -0,0 +1,17 @@ +.weui-progress { + display: -webkit-box; + display: -webkit-flex; + display: flex; + -webkit-box-align: center; + -webkit-align-items: center; + align-items: center; +} +.weui-progress__bar { + -webkit-box-flex: 1; + -webkit-flex: 1; + flex: 1; +} +.weui-progress__opr { + margin-left: 15px; + font-size: 0; +} diff --git a/style/widget/weui-searchbar/weui-searchbar.wxss b/style/widget/weui-searchbar/weui-searchbar.wxss new file mode 100644 index 0000000..10bf43d --- /dev/null +++ b/style/widget/weui-searchbar/weui-searchbar.wxss @@ -0,0 +1,73 @@ +.weui-search-bar { + position: relative; + padding: 8px 10px; + display: -webkit-box; + display: -webkit-flex; + display: flex; + box-sizing: border-box; + background-color: #EFEFF4; + border-top: 1rpx solid #D7D6DC; + border-bottom: 1rpx solid #D7D6DC; +} +.weui-icon-search { + margin-right: 8px; + font-size: inherit; +} +.weui-icon-search_in-box { + position: absolute; + left: 10px; + top: 7px; +} +.weui-search-bar__text { + display: inline-block; + font-size: 14px; + vertical-align: middle; +} +.weui-search-bar__form { + position: relative; + -webkit-box-flex: 1; + -webkit-flex: auto; + flex: auto; + border-radius: 5px; + background: #FFFFFF; + border: 1rpx solid #E6E6EA; +} +.weui-search-bar__box { + position: relative; + padding-left: 30px; + padding-right: 30px; + width: 100%; + box-sizing: border-box; + z-index: 1; +} +.weui-search-bar__input { + height: 28px; + line-height: 28px; + font-size: 14px; +} +.weui-icon-clear { + position: absolute; + top: 0; + right: 0; + padding: 7px 8px; + font-size: 0; +} +.weui-search-bar__label { + position: absolute; + top: 0; + right: 0; + bottom: 0; + left: 0; + z-index: 2; + border-radius: 3px; + text-align: center; + color: #9B9B9B; + background: #FFFFFF; + line-height: 28px; +} +.weui-search-bar__cancel-btn { + margin-left: 10px; + line-height: 28px; + color: #09BB07; + white-space: nowrap; +} diff --git a/style/widget/weui-tab/weui-navbar.wxss b/style/widget/weui-tab/weui-navbar.wxss new file mode 100644 index 0000000..2a98ce2 --- /dev/null +++ b/style/widget/weui-tab/weui-navbar.wxss @@ -0,0 +1,46 @@ +.weui-navbar { + display: -webkit-box; + display: -webkit-flex; + display: flex; + position: absolute; + z-index: 500; + top: 0; + width: 100%; + border-bottom: 1rpx solid #CCCCCC; +} +.weui-navbar__item { + position: relative; + display: block; + -webkit-box-flex: 1; + -webkit-flex: 1; + flex: 1; + padding: 13px 0; + text-align: center; + font-size: 0; +} +.weui-navbar__item.weui-bar__item_on { + color: #1AAD19; +} +.weui-navbar__slider { + position: absolute; + content: " "; + left: 0; + bottom: 0; + width: 6em; + height: 3px; + background-color: #1AAD19; + -webkit-transition: -webkit-transform .3s; + transition: -webkit-transform .3s; + transition: transform .3s; + transition: transform .3s, -webkit-transform .3s; +} +.weui-navbar__title { + display: inline-block; + font-size: 15px; + max-width: 8em; + width: auto; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + word-wrap: normal; +} diff --git a/style/widget/weui-tab/weui-tab.wxss b/style/widget/weui-tab/weui-tab.wxss new file mode 100644 index 0000000..fe44e1d --- /dev/null +++ b/style/widget/weui-tab/weui-tab.wxss @@ -0,0 +1,57 @@ +.weui-navbar { + display: -webkit-box; + display: -webkit-flex; + display: flex; + position: absolute; + z-index: 500; + top: 0; + width: 100%; + border-bottom: 1rpx solid #CCCCCC; +} +.weui-navbar__item { + position: relative; + display: block; + -webkit-box-flex: 1; + -webkit-flex: 1; + flex: 1; + padding: 13px 0; + text-align: center; + font-size: 0; +} +.weui-navbar__item.weui-bar__item_on { + color: #1AAD19; +} +.weui-navbar__slider { + position: absolute; + content: " "; + left: 0; + bottom: 0; + width: 6em; + height: 3px; + background-color: #1AAD19; + -webkit-transition: -webkit-transform .3s; + transition: -webkit-transform .3s; + transition: transform .3s; + transition: transform .3s, -webkit-transform .3s; +} +.weui-navbar__title { + display: inline-block; + font-size: 15px; + max-width: 8em; + width: auto; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + word-wrap: normal; +} +.weui-tab { + position: relative; + height: 100%; +} +.weui-tab__panel { + box-sizing: border-box; + height: 100%; + padding-top: 50px; + overflow: auto; + -webkit-overflow-scrolling: touch; +} diff --git a/style/widget/weui-tips/weui-badge.wxss b/style/widget/weui-tips/weui-badge.wxss new file mode 100644 index 0000000..f6c5a35 --- /dev/null +++ b/style/widget/weui-tips/weui-badge.wxss @@ -0,0 +1,16 @@ +.weui-badge { + display: inline-block; + padding: .15em .4em; + min-width: 8px; + border-radius: 18px; + background-color: #E64340; + color: #FFFFFF; + line-height: 1.2; + text-align: center; + font-size: 12px; + vertical-align: middle; +} +.weui-badge_dot { + padding: .4em; + min-width: 0; +} diff --git a/style/widget/weui-tips/weui-loadmore.wxss b/style/widget/weui-tips/weui-loadmore.wxss new file mode 100644 index 0000000..0271d3a --- /dev/null +++ b/style/widget/weui-tips/weui-loadmore.wxss @@ -0,0 +1,40 @@ +.weui-loadmore { + width: 65%; + margin: 1.5em auto; + line-height: 1.6em; + font-size: 14px; + text-align: center; +} +.weui-loadmore__tips { + display: inline-block; + vertical-align: middle; +} +.weui-loadmore_line { + border-top: 1px solid #E5E5E5; + margin-top: 2.4em; +} +.weui-loadmore__tips_in-line { + position: relative; + top: -0.9em; + padding: 0 .55em; + background-color: #FFFFFF; + color: #999999; +} +.weui-loadmore__tips_in-dot { + position: relative; + padding: 0 .16em; + width: 4px; + height: 1.6em; +} +.weui-loadmore__tips_in-dot:before { + content: " "; + position: absolute; + top: 50%; + left: 50%; + margin-top: -1px; + margin-left: -2px; + width: 4px; + height: 4px; + border-radius: 50%; + background-color: #E5E5E5; +} diff --git a/utils/config.js b/utils/config.js new file mode 100644 index 0000000..38f76d5 --- /dev/null +++ b/utils/config.js @@ -0,0 +1,3 @@ +module.exports = { + BaseURL : "http://140.143.234.132:8088" +} \ No newline at end of file diff --git a/utils/moment.min.js b/utils/moment.min.js new file mode 100644 index 0000000..b63c6bb --- /dev/null +++ b/utils/moment.min.js @@ -0,0 +1,1376 @@ +//! moment.js +//! version : 2.10.6 +//! authors : Tim Wood, Iskren Chernev, Moment.js contributors +//! license : MIT +//! momentjs.com +! function (a, b) { + "object" == typeof exports && "undefined" != typeof module ? module.exports = b() : "function" == typeof define && define.amd ? define(b) : a.moment = b() +}(this, function () { + "use strict"; + + function a() { + return Hc.apply(null, arguments) + } + + function b(a) { + Hc = a + } + + function c(a) { + return "[object Array]" === Object.prototype.toString.call(a) + } + + function d(a) { + return a instanceof Date || "[object Date]" === Object.prototype.toString.call(a) + } + + function e(a, b) { + var c, d = []; + for (c = 0; c < a.length; ++c) d.push(b(a[c], c)); + return d + } + + function f(a, b) { + return Object.prototype.hasOwnProperty.call(a, b) + } + + function g(a, b) { + for (var c in b) f(b, c) && (a[c] = b[c]); + return f(b, "toString") && (a.toString = b.toString), f(b, "valueOf") && (a.valueOf = b.valueOf), a + } + + function h(a, b, c, d) { + return Ca(a, b, c, d, !0).utc() + } + + function i() { + return { + empty: !1, + unusedTokens: [], + unusedInput: [], + overflow: -2, + charsLeftOver: 0, + nullInput: !1, + invalidMonth: null, + invalidFormat: !1, + userInvalidated: !1, + iso: !1 + } + } + + function j(a) { + return null == a._pf && (a._pf = i()), a._pf + } + + function k(a) { + if (null == a._isValid) { + var b = j(a); + a._isValid = !(isNaN(a._d.getTime()) || !(b.overflow < 0) || b.empty || b.invalidMonth || b.invalidWeekday || b.nullInput || b.invalidFormat || b.userInvalidated), a._strict && (a._isValid = a._isValid && 0 === b.charsLeftOver && 0 === b.unusedTokens.length && void 0 === b.bigHour) + } + return a._isValid + } + + function l(a) { + var b = h(NaN); + return null != a ? g(j(b), a) : j(b).userInvalidated = !0, b + } + + function m(a, b) { + var c, d, e; + if ("undefined" != typeof b._isAMomentObject && (a._isAMomentObject = b._isAMomentObject), "undefined" != typeof b._i && (a._i = b._i), "undefined" != typeof b._f && (a._f = b._f), "undefined" != typeof b._l && (a._l = b._l), "undefined" != typeof b._strict && (a._strict = b._strict), "undefined" != typeof b._tzm && (a._tzm = b._tzm), "undefined" != typeof b._isUTC && (a._isUTC = b._isUTC), "undefined" != typeof b._offset && (a._offset = b._offset), "undefined" != typeof b._pf && (a._pf = j(b)), "undefined" != typeof b._locale && (a._locale = b._locale), Jc.length > 0) + for (c in Jc) d = Jc[c], e = b[d], "undefined" != typeof e && (a[d] = e); + return a + } + + function n(b) { + m(this, b), this._d = new Date(null != b._d ? b._d.getTime() : NaN), Kc === !1 && (Kc = !0, a.updateOffset(this), Kc = !1) + } + + function o(a) { + return a instanceof n || null != a && null != a._isAMomentObject + } + + function p(a) { + return 0 > a ? Math.ceil(a) : Math.floor(a) + } + + function q(a) { + var b = +a, + c = 0; + return 0 !== b && isFinite(b) && (c = p(b)), c + } + + function r(a, b, c) { + var d, e = Math.min(a.length, b.length), + f = Math.abs(a.length - b.length), + g = 0; + for (d = 0; e > d; d++)(c && a[d] !== b[d] || !c && q(a[d]) !== q(b[d])) && g++; + return g + f + } + + function s() {} + + function t(a) { + return a ? a.toLowerCase().replace("_", "-") : a + } + + function u(a) { + for (var b, c, d, e, f = 0; f < a.length;) { + for (e = t(a[f]).split("-"), b = e.length, c = t(a[f + 1]), c = c ? c.split("-") : null; b > 0;) { + if (d = v(e.slice(0, b).join("-"))) return d; + if (c && c.length >= b && r(e, c, !0) >= b - 1) break; + b-- + } + f++ + } + return null + } + + function v(a) { + var b = null; + if (!Lc[a] && "undefined" != typeof module && module && module.exports) try { + b = Ic._abbr, require("./locale/" + a), w(b) + } catch (c) {} + return Lc[a] + } + + function w(a, b) { + var c; + return a && (c = "undefined" == typeof b ? y(a) : x(a, b), c && (Ic = c)), Ic._abbr + } + + function x(a, b) { + return null !== b ? (b.abbr = a, Lc[a] = Lc[a] || new s, Lc[a].set(b), w(a), Lc[a]) : (delete Lc[a], null) + } + + function y(a) { + var b; + if (a && a._locale && a._locale._abbr && (a = a._locale._abbr), !a) return Ic; + if (!c(a)) { + if (b = v(a)) return b; + a = [a] + } + return u(a) + } + + function z(a, b) { + var c = a.toLowerCase(); + Mc[c] = Mc[c + "s"] = Mc[b] = a + } + + function A(a) { + return "string" == typeof a ? Mc[a] || Mc[a.toLowerCase()] : void 0 + } + + function B(a) { + var b, c, d = {}; + for (c in a) f(a, c) && (b = A(c), b && (d[b] = a[c])); + return d + } + + function C(b, c) { + return function (d) { + return null != d ? (E(this, b, d), a.updateOffset(this, c), this) : D(this, b) + } + } + + function D(a, b) { + return a._d["get" + (a._isUTC ? "UTC" : "") + b]() + } + + function E(a, b, c) { + return a._d["set" + (a._isUTC ? "UTC" : "") + b](c) + } + + function F(a, b) { + var c; + if ("object" == typeof a) + for (c in a) this.set(c, a[c]); + else if (a = A(a), "function" == typeof this[a]) return this[a](b); + return this + } + + function G(a, b, c) { + var d = "" + Math.abs(a), + e = b - d.length, + f = a >= 0; + return (f ? c ? "+" : "" : "-") + Math.pow(10, Math.max(0, e)).toString().substr(1) + d + } + + function H(a, b, c, d) { + var e = d; + "string" == typeof d && (e = function () { + return this[d]() + }), a && (Qc[a] = e), b && (Qc[b[0]] = function () { + return G(e.apply(this, arguments), b[1], b[2]) + }), c && (Qc[c] = function () { + return this.localeData().ordinal(e.apply(this, arguments), a) + }) + } + + function I(a) { + return a.match(/\[[\s\S]/) ? a.replace(/^\[|\]$/g, "") : a.replace(/\\/g, "") + } + + function J(a) { + var b, c, d = a.match(Nc); + for (b = 0, c = d.length; c > b; b++) Qc[d[b]] ? d[b] = Qc[d[b]] : d[b] = I(d[b]); + return function (e) { + var f = ""; + for (b = 0; c > b; b++) f += d[b] instanceof Function ? d[b].call(e, a) : d[b]; + return f + } + } + + function K(a, b) { + return a.isValid() ? (b = L(b, a.localeData()), Pc[b] = Pc[b] || J(b), Pc[b](a)) : a.localeData().invalidDate() + } + + function L(a, b) { + function c(a) { + return b.longDateFormat(a) || a + } + var d = 5; + for (Oc.lastIndex = 0; d >= 0 && Oc.test(a);) a = a.replace(Oc, c), Oc.lastIndex = 0, d -= 1; + return a + } + + function M(a) { + return "function" == typeof a && "[object Function]" === Object.prototype.toString.call(a) + } + + function N(a, b, c) { + dd[a] = M(b) ? b : function (a) { + return a && c ? c : b + } + } + + function O(a, b) { + return f(dd, a) ? dd[a](b._strict, b._locale) : new RegExp(P(a)) + } + + function P(a) { + return a.replace("\\", "").replace(/\\(\[)|\\(\])|\[([^\]\[]*)\]|\\(.)/g, function (a, b, c, d, e) { + return b || c || d || e + }).replace(/[-\/\\^$*+?.()|[\]{}]/g, "\\$&") + } + + function Q(a, b) { + var c, d = b; + for ("string" == typeof a && (a = [a]), "number" == typeof b && (d = function (a, c) { + c[b] = q(a) + }), c = 0; c < a.length; c++) ed[a[c]] = d + } + + function R(a, b) { + Q(a, function (a, c, d, e) { + d._w = d._w || {}, b(a, d._w, d, e) + }) + } + + function S(a, b, c) { + null != b && f(ed, a) && ed[a](b, c._a, c, a) + } + + function T(a, b) { + return new Date(Date.UTC(a, b + 1, 0)).getUTCDate() + } + + function U(a) { + return this._months[a.month()] + } + + function V(a) { + return this._monthsShort[a.month()] + } + + function W(a, b, c) { + var d, e, f; + for (this._monthsParse || (this._monthsParse = [], this._longMonthsParse = [], this._shortMonthsParse = []), d = 0; 12 > d; d++) { + if (e = h([2e3, d]), c && !this._longMonthsParse[d] && (this._longMonthsParse[d] = new RegExp("^" + this.months(e, "").replace(".", "") + "$", "i"), this._shortMonthsParse[d] = new RegExp("^" + this.monthsShort(e, "").replace(".", "") + "$", "i")), c || this._monthsParse[d] || (f = "^" + this.months(e, "") + "|^" + this.monthsShort(e, ""), this._monthsParse[d] = new RegExp(f.replace(".", ""), "i")), c && "MMMM" === b && this._longMonthsParse[d].test(a)) return d; + if (c && "MMM" === b && this._shortMonthsParse[d].test(a)) return d; + if (!c && this._monthsParse[d].test(a)) return d + } + } + + function X(a, b) { + var c; + return "string" == typeof b && (b = a.localeData().monthsParse(b), "number" != typeof b) ? a : (c = Math.min(a.date(), T(a.year(), b)), a._d["set" + (a._isUTC ? "UTC" : "") + "Month"](b, c), a) + } + + function Y(b) { + return null != b ? (X(this, b), a.updateOffset(this, !0), this) : D(this, "Month") + } + + function Z() { + return T(this.year(), this.month()) + } + + function $(a) { + var b, c = a._a; + return c && -2 === j(a).overflow && (b = c[gd] < 0 || c[gd] > 11 ? gd : c[hd] < 1 || c[hd] > T(c[fd], c[gd]) ? hd : c[id] < 0 || c[id] > 24 || 24 === c[id] && (0 !== c[jd] || 0 !== c[kd] || 0 !== c[ld]) ? id : c[jd] < 0 || c[jd] > 59 ? jd : c[kd] < 0 || c[kd] > 59 ? kd : c[ld] < 0 || c[ld] > 999 ? ld : -1, j(a)._overflowDayOfYear && (fd > b || b > hd) && (b = hd), j(a).overflow = b), a + } + + function _(b) { + a.suppressDeprecationWarnings === !1 && "undefined" != typeof console && console.warn && console.warn("Deprecation warning: " + b) + } + + function aa(a, b) { + var c = !0; + return g(function () { + return c && (_(a + "\n" + (new Error).stack), c = !1), b.apply(this, arguments) + }, b) + } + + function ba(a, b) { + od[a] || (_(b), od[a] = !0) + } + + function ca(a) { + var b, c, d = a._i, + e = pd.exec(d); + if (e) { + for (j(a).iso = !0, b = 0, c = qd.length; c > b; b++) + if (qd[b][1].exec(d)) { + a._f = qd[b][0]; + break + } for (b = 0, c = rd.length; c > b; b++) + if (rd[b][1].exec(d)) { + a._f += (e[6] || " ") + rd[b][0]; + break + } d.match(ad) && (a._f += "Z"), va(a) + } else a._isValid = !1 + } + + function da(b) { + var c = sd.exec(b._i); + return null !== c ? void(b._d = new Date(+c[1])) : (ca(b), void(b._isValid === !1 && (delete b._isValid, a.createFromInputFallback(b)))) + } + + function ea(a, b, c, d, e, f, g) { + var h = new Date(a, b, c, d, e, f, g); + return 1970 > a && h.setFullYear(a), h + } + + function fa(a) { + var b = new Date(Date.UTC.apply(null, arguments)); + return 1970 > a && b.setUTCFullYear(a), b + } + + function ga(a) { + return ha(a) ? 366 : 365 + } + + function ha(a) { + return a % 4 === 0 && a % 100 !== 0 || a % 400 === 0 + } + + function ia() { + return ha(this.year()) + } + + function ja(a, b, c) { + var d, e = c - b, + f = c - a.day(); + return f > e && (f -= 7), e - 7 > f && (f += 7), d = Da(a).add(f, "d"), { + week: Math.ceil(d.dayOfYear() / 7), + year: d.year() + } + } + + function ka(a) { + return ja(a, this._week.dow, this._week.doy).week + } + + function la() { + return this._week.dow + } + + function ma() { + return this._week.doy + } + + function na(a) { + var b = this.localeData().week(this); + return null == a ? b : this.add(7 * (a - b), "d") + } + + function oa(a) { + var b = ja(this, 1, 4).week; + return null == a ? b : this.add(7 * (a - b), "d") + } + + function pa(a, b, c, d, e) { + var f, g = 6 + e - d, + h = fa(a, 0, 1 + g), + i = h.getUTCDay(); + return e > i && (i += 7), c = null != c ? 1 * c : e, f = 1 + g + 7 * (b - 1) - i + c, { + year: f > 0 ? a : a - 1, + dayOfYear: f > 0 ? f : ga(a - 1) + f + } + } + + function qa(a) { + var b = Math.round((this.clone().startOf("day") - this.clone().startOf("year")) / 864e5) + 1; + return null == a ? b : this.add(a - b, "d") + } + + function ra(a, b, c) { + return null != a ? a : null != b ? b : c + } + + function sa(a) { + var b = new Date; + return a._useUTC ? [b.getUTCFullYear(), b.getUTCMonth(), b.getUTCDate()] : [b.getFullYear(), b.getMonth(), b.getDate()] + } + + function ta(a) { + var b, c, d, e, f = []; + if (!a._d) { + for (d = sa(a), a._w && null == a._a[hd] && null == a._a[gd] && ua(a), a._dayOfYear && (e = ra(a._a[fd], d[fd]), a._dayOfYear > ga(e) && (j(a)._overflowDayOfYear = !0), c = fa(e, 0, a._dayOfYear), a._a[gd] = c.getUTCMonth(), a._a[hd] = c.getUTCDate()), b = 0; 3 > b && null == a._a[b]; ++b) a._a[b] = f[b] = d[b]; + for (; 7 > b; b++) a._a[b] = f[b] = null == a._a[b] ? 2 === b ? 1 : 0 : a._a[b]; + 24 === a._a[id] && 0 === a._a[jd] && 0 === a._a[kd] && 0 === a._a[ld] && (a._nextDay = !0, a._a[id] = 0), a._d = (a._useUTC ? fa : ea).apply(null, f), null != a._tzm && a._d.setUTCMinutes(a._d.getUTCMinutes() - a._tzm), a._nextDay && (a._a[id] = 24) + } + } + + function ua(a) { + var b, c, d, e, f, g, h; + b = a._w, null != b.GG || null != b.W || null != b.E ? (f = 1, g = 4, c = ra(b.GG, a._a[fd], ja(Da(), 1, 4).year), d = ra(b.W, 1), e = ra(b.E, 1)) : (f = a._locale._week.dow, g = a._locale._week.doy, c = ra(b.gg, a._a[fd], ja(Da(), f, g).year), d = ra(b.w, 1), null != b.d ? (e = b.d, f > e && ++d) : e = null != b.e ? b.e + f : f), h = pa(c, d, e, g, f), a._a[fd] = h.year, a._dayOfYear = h.dayOfYear + } + + function va(b) { + if (b._f === a.ISO_8601) return void ca(b); + b._a = [], j(b).empty = !0; + var c, d, e, f, g, h = "" + b._i, + i = h.length, + k = 0; + for (e = L(b._f, b._locale).match(Nc) || [], c = 0; c < e.length; c++) f = e[c], d = (h.match(O(f, b)) || [])[0], d && (g = h.substr(0, h.indexOf(d)), g.length > 0 && j(b).unusedInput.push(g), h = h.slice(h.indexOf(d) + d.length), k += d.length), Qc[f] ? (d ? j(b).empty = !1 : j(b).unusedTokens.push(f), S(f, d, b)) : b._strict && !d && j(b).unusedTokens.push(f); + j(b).charsLeftOver = i - k, h.length > 0 && j(b).unusedInput.push(h), j(b).bigHour === !0 && b._a[id] <= 12 && b._a[id] > 0 && (j(b).bigHour = void 0), b._a[id] = wa(b._locale, b._a[id], b._meridiem), ta(b), $(b) + } + + function wa(a, b, c) { + var d; + return null == c ? b : null != a.meridiemHour ? a.meridiemHour(b, c) : null != a.isPM ? (d = a.isPM(c), d && 12 > b && (b += 12), d || 12 !== b || (b = 0), b) : b + } + + function xa(a) { + var b, c, d, e, f; + if (0 === a._f.length) return j(a).invalidFormat = !0, void(a._d = new Date(NaN)); + for (e = 0; e < a._f.length; e++) f = 0, b = m({}, a), null != a._useUTC && (b._useUTC = a._useUTC), b._f = a._f[e], va(b), k(b) && (f += j(b).charsLeftOver, f += 10 * j(b).unusedTokens.length, j(b).score = f, (null == d || d > f) && (d = f, c = b)); + g(a, c || b) + } + + function ya(a) { + if (!a._d) { + var b = B(a._i); + a._a = [b.year, b.month, b.day || b.date, b.hour, b.minute, b.second, b.millisecond], ta(a) + } + } + + function za(a) { + var b = new n($(Aa(a))); + return b._nextDay && (b.add(1, "d"), b._nextDay = void 0), b + } + + function Aa(a) { + var b = a._i, + e = a._f; + return a._locale = a._locale || y(a._l), null === b || void 0 === e && "" === b ? l({ + nullInput: !0 + }) : ("string" == typeof b && (a._i = b = a._locale.preparse(b)), o(b) ? new n($(b)) : (c(e) ? xa(a) : e ? va(a) : d(b) ? a._d = b : Ba(a), a)) + } + + function Ba(b) { + var f = b._i; + void 0 === f ? b._d = new Date : d(f) ? b._d = new Date(+f) : "string" == typeof f ? da(b) : c(f) ? (b._a = e(f.slice(0), function (a) { + return parseInt(a, 10) + }), ta(b)) : "object" == typeof f ? ya(b) : "number" == typeof f ? b._d = new Date(f) : a.createFromInputFallback(b) + } + + function Ca(a, b, c, d, e) { + var f = {}; + return "boolean" == typeof c && (d = c, c = void 0), f._isAMomentObject = !0, f._useUTC = f._isUTC = e, f._l = c, f._i = a, f._f = b, f._strict = d, za(f) + } + + function Da(a, b, c, d) { + return Ca(a, b, c, d, !1) + } + + function Ea(a, b) { + var d, e; + if (1 === b.length && c(b[0]) && (b = b[0]), !b.length) return Da(); + for (d = b[0], e = 1; e < b.length; ++e)(!b[e].isValid() || b[e][a](d)) && (d = b[e]); + return d + } + + function Fa() { + var a = [].slice.call(arguments, 0); + return Ea("isBefore", a) + } + + function Ga() { + var a = [].slice.call(arguments, 0); + return Ea("isAfter", a) + } + + function Ha(a) { + var b = B(a), + c = b.year || 0, + d = b.quarter || 0, + e = b.month || 0, + f = b.week || 0, + g = b.day || 0, + h = b.hour || 0, + i = b.minute || 0, + j = b.second || 0, + k = b.millisecond || 0; + this._milliseconds = +k + 1e3 * j + 6e4 * i + 36e5 * h, this._days = +g + 7 * f, this._months = +e + 3 * d + 12 * c, this._data = {}, this._locale = y(), this._bubble() + } + + function Ia(a) { + return a instanceof Ha + } + + function Ja(a, b) { + H(a, 0, 0, function () { + var a = this.utcOffset(), + c = "+"; + return 0 > a && (a = -a, c = "-"), c + G(~~(a / 60), 2) + b + G(~~a % 60, 2) + }) + } + + function Ka(a) { + var b = (a || "").match(ad) || [], + c = b[b.length - 1] || [], + d = (c + "").match(xd) || ["-", 0, 0], + e = +(60 * d[1]) + q(d[2]); + return "+" === d[0] ? e : -e + } + + function La(b, c) { + var e, f; + return c._isUTC ? (e = c.clone(), f = (o(b) || d(b) ? +b : +Da(b)) - +e, e._d.setTime(+e._d + f), a.updateOffset(e, !1), e) : Da(b).local() + } + + function Ma(a) { + return 15 * -Math.round(a._d.getTimezoneOffset() / 15) + } + + function Na(b, c) { + var d, e = this._offset || 0; + return null != b ? ("string" == typeof b && (b = Ka(b)), Math.abs(b) < 16 && (b = 60 * b), !this._isUTC && c && (d = Ma(this)), this._offset = b, this._isUTC = !0, null != d && this.add(d, "m"), e !== b && (!c || this._changeInProgress ? bb(this, Ya(b - e, "m"), 1, !1) : this._changeInProgress || (this._changeInProgress = !0, a.updateOffset(this, !0), this._changeInProgress = null)), this) : this._isUTC ? e : Ma(this) + } + + function Oa(a, b) { + return null != a ? ("string" != typeof a && (a = -a), this.utcOffset(a, b), this) : -this.utcOffset() + } + + function Pa(a) { + return this.utcOffset(0, a) + } + + function Qa(a) { + return this._isUTC && (this.utcOffset(0, a), this._isUTC = !1, a && this.subtract(Ma(this), "m")), this + } + + function Ra() { + return this._tzm ? this.utcOffset(this._tzm) : "string" == typeof this._i && this.utcOffset(Ka(this._i)), this + } + + function Sa(a) { + return a = a ? Da(a).utcOffset() : 0, (this.utcOffset() - a) % 60 === 0 + } + + function Ta() { + return this.utcOffset() > this.clone().month(0).utcOffset() || this.utcOffset() > this.clone().month(5).utcOffset() + } + + function Ua() { + if ("undefined" != typeof this._isDSTShifted) return this._isDSTShifted; + var a = {}; + if (m(a, this), a = Aa(a), a._a) { + var b = a._isUTC ? h(a._a) : Da(a._a); + this._isDSTShifted = this.isValid() && r(a._a, b.toArray()) > 0 + } else this._isDSTShifted = !1; + return this._isDSTShifted + } + + function Va() { + return !this._isUTC + } + + function Wa() { + return this._isUTC + } + + function Xa() { + return this._isUTC && 0 === this._offset + } + + function Ya(a, b) { + var c, d, e, g = a, + h = null; + return Ia(a) ? g = { + ms: a._milliseconds, + d: a._days, + M: a._months + } : "number" == typeof a ? (g = {}, b ? g[b] = a : g.milliseconds = a) : (h = yd.exec(a)) ? (c = "-" === h[1] ? -1 : 1, g = { + y: 0, + d: q(h[hd]) * c, + h: q(h[id]) * c, + m: q(h[jd]) * c, + s: q(h[kd]) * c, + ms: q(h[ld]) * c + }) : (h = zd.exec(a)) ? (c = "-" === h[1] ? -1 : 1, g = { + y: Za(h[2], c), + M: Za(h[3], c), + d: Za(h[4], c), + h: Za(h[5], c), + m: Za(h[6], c), + s: Za(h[7], c), + w: Za(h[8], c) + }) : null == g ? g = {} : "object" == typeof g && ("from" in g || "to" in g) && (e = _a(Da(g.from), Da(g.to)), g = {}, g.ms = e.milliseconds, g.M = e.months), d = new Ha(g), Ia(a) && f(a, "_locale") && (d._locale = a._locale), d + } + + function Za(a, b) { + var c = a && parseFloat(a.replace(",", ".")); + return (isNaN(c) ? 0 : c) * b + } + + function $a(a, b) { + var c = { + milliseconds: 0, + months: 0 + }; + return c.months = b.month() - a.month() + 12 * (b.year() - a.year()), a.clone().add(c.months, "M").isAfter(b) && --c.months, c.milliseconds = +b - +a.clone().add(c.months, "M"), c + } + + function _a(a, b) { + var c; + return b = La(b, a), a.isBefore(b) ? c = $a(a, b) : (c = $a(b, a), c.milliseconds = -c.milliseconds, c.months = -c.months), c + } + + function ab(a, b) { + return function (c, d) { + var e, f; + return null === d || isNaN(+d) || (ba(b, "moment()." + b + "(period, number) is deprecated. Please use moment()." + b + "(number, period)."), f = c, c = d, d = f), c = "string" == typeof c ? +c : c, e = Ya(c, d), bb(this, e, a), this + } + } + + function bb(b, c, d, e) { + var f = c._milliseconds, + g = c._days, + h = c._months; + e = null == e ? !0 : e, f && b._d.setTime(+b._d + f * d), g && E(b, "Date", D(b, "Date") + g * d), h && X(b, D(b, "Month") + h * d), e && a.updateOffset(b, g || h) + } + + function cb(a, b) { + var c = a || Da(), + d = La(c, this).startOf("day"), + e = this.diff(d, "days", !0), + f = -6 > e ? "sameElse" : -1 > e ? "lastWeek" : 0 > e ? "lastDay" : 1 > e ? "sameDay" : 2 > e ? "nextDay" : 7 > e ? "nextWeek" : "sameElse"; + return this.format(b && b[f] || this.localeData().calendar(f, this, Da(c))) + } + + function db() { + return new n(this) + } + + function eb(a, b) { + var c; + return b = A("undefined" != typeof b ? b : "millisecond"), "millisecond" === b ? (a = o(a) ? a : Da(a), +this > +a) : (c = o(a) ? +a : +Da(a), c < +this.clone().startOf(b)) + } + + function fb(a, b) { + var c; + return b = A("undefined" != typeof b ? b : "millisecond"), "millisecond" === b ? (a = o(a) ? a : Da(a), +a > +this) : (c = o(a) ? +a : +Da(a), +this.clone().endOf(b) < c) + } + + function gb(a, b, c) { + return this.isAfter(a, c) && this.isBefore(b, c) + } + + function hb(a, b) { + var c; + return b = A(b || "millisecond"), "millisecond" === b ? (a = o(a) ? a : Da(a), +this === +a) : (c = +Da(a), +this.clone().startOf(b) <= c && c <= +this.clone().endOf(b)) + } + + function ib(a, b, c) { + var d, e, f = La(a, this), + g = 6e4 * (f.utcOffset() - this.utcOffset()); + return b = A(b), "year" === b || "month" === b || "quarter" === b ? (e = jb(this, f), "quarter" === b ? e /= 3 : "year" === b && (e /= 12)) : (d = this - f, e = "second" === b ? d / 1e3 : "minute" === b ? d / 6e4 : "hour" === b ? d / 36e5 : "day" === b ? (d - g) / 864e5 : "week" === b ? (d - g) / 6048e5 : d), c ? e : p(e) + } + + function jb(a, b) { + var c, d, e = 12 * (b.year() - a.year()) + (b.month() - a.month()), + f = a.clone().add(e, "months"); + return 0 > b - f ? (c = a.clone().add(e - 1, "months"), d = (b - f) / (f - c)) : (c = a.clone().add(e + 1, "months"), d = (b - f) / (c - f)), -(e + d) + } + + function kb() { + return this.clone().locale("en").format("ddd MMM DD YYYY HH:mm:ss [GMT]ZZ") + } + + function lb() { + var a = this.clone().utc(); + return 0 < a.year() && a.year() <= 9999 ? "function" == typeof Date.prototype.toISOString ? this.toDate().toISOString() : K(a, "YYYY-MM-DD[T]HH:mm:ss.SSS[Z]") : K(a, "YYYYYY-MM-DD[T]HH:mm:ss.SSS[Z]") + } + + function mb(b) { + var c = K(this, b || a.defaultFormat); + return this.localeData().postformat(c) + } + + function nb(a, b) { + return this.isValid() ? Ya({ + to: this, + from: a + }).locale(this.locale()).humanize(!b) : this.localeData().invalidDate() + } + + function ob(a) { + return this.from(Da(), a) + } + + function pb(a, b) { + return this.isValid() ? Ya({ + from: this, + to: a + }).locale(this.locale()).humanize(!b) : this.localeData().invalidDate() + } + + function qb(a) { + return this.to(Da(), a) + } + + function rb(a) { + var b; + return void 0 === a ? this._locale._abbr : (b = y(a), null != b && (this._locale = b), this) + } + + function sb() { + return this._locale + } + + function tb(a) { + switch (a = A(a)) { + case "year": + this.month(0); + case "quarter": + case "month": + this.date(1); + case "week": + case "isoWeek": + case "day": + this.hours(0); + case "hour": + this.minutes(0); + case "minute": + this.seconds(0); + case "second": + this.milliseconds(0) + } + return "week" === a && this.weekday(0), "isoWeek" === a && this.isoWeekday(1), "quarter" === a && this.month(3 * Math.floor(this.month() / 3)), this + } + + function ub(a) { + return a = A(a), void 0 === a || "millisecond" === a ? this : this.startOf(a).add(1, "isoWeek" === a ? "week" : a).subtract(1, "ms") + } + + function vb() { + return +this._d - 6e4 * (this._offset || 0) + } + + function wb() { + return Math.floor(+this / 1e3) + } + + function xb() { + return this._offset ? new Date(+this) : this._d + } + + function yb() { + var a = this; + return [a.year(), a.month(), a.date(), a.hour(), a.minute(), a.second(), a.millisecond()] + } + + function zb() { + var a = this; + return { + years: a.year(), + months: a.month(), + date: a.date(), + hours: a.hours(), + minutes: a.minutes(), + seconds: a.seconds(), + milliseconds: a.milliseconds() + } + } + + function Ab() { + return k(this) + } + + function Bb() { + return g({}, j(this)) + } + + function Cb() { + return j(this).overflow + } + + function Db(a, b) { + H(0, [a, a.length], 0, b) + } + + function Eb(a, b, c) { + return ja(Da([a, 11, 31 + b - c]), b, c).week + } + + function Fb(a) { + var b = ja(this, this.localeData()._week.dow, this.localeData()._week.doy).year; + return null == a ? b : this.add(a - b, "y") + } + + function Gb(a) { + var b = ja(this, 1, 4).year; + return null == a ? b : this.add(a - b, "y") + } + + function Hb() { + return Eb(this.year(), 1, 4) + } + + function Ib() { + var a = this.localeData()._week; + return Eb(this.year(), a.dow, a.doy) + } + + function Jb(a) { + return null == a ? Math.ceil((this.month() + 1) / 3) : this.month(3 * (a - 1) + this.month() % 3) + } + + function Kb(a, b) { + return "string" != typeof a ? a : isNaN(a) ? (a = b.weekdaysParse(a), "number" == typeof a ? a : null) : parseInt(a, 10) + } + + function Lb(a) { + return this._weekdays[a.day()] + } + + function Mb(a) { + return this._weekdaysShort[a.day()] + } + + function Nb(a) { + return this._weekdaysMin[a.day()] + } + + function Ob(a) { + var b, c, d; + for (this._weekdaysParse = this._weekdaysParse || [], b = 0; 7 > b; b++) + if (this._weekdaysParse[b] || (c = Da([2e3, 1]).day(b), d = "^" + this.weekdays(c, "") + "|^" + this.weekdaysShort(c, "") + "|^" + this.weekdaysMin(c, ""), this._weekdaysParse[b] = new RegExp(d.replace(".", ""), "i")), this._weekdaysParse[b].test(a)) return b + } + + function Pb(a) { + var b = this._isUTC ? this._d.getUTCDay() : this._d.getDay(); + return null != a ? (a = Kb(a, this.localeData()), this.add(a - b, "d")) : b + } + + function Qb(a) { + var b = (this.day() + 7 - this.localeData()._week.dow) % 7; + return null == a ? b : this.add(a - b, "d") + } + + function Rb(a) { + return null == a ? this.day() || 7 : this.day(this.day() % 7 ? a : a - 7) + } + + function Sb(a, b) { + H(a, 0, 0, function () { + return this.localeData().meridiem(this.hours(), this.minutes(), b) + }) + } + + function Tb(a, b) { + return b._meridiemParse + } + + function Ub(a) { + return "p" === (a + "").toLowerCase().charAt(0) + } + + function Vb(a, b, c) { + return a > 11 ? c ? "pm" : "PM" : c ? "am" : "AM" + } + + function Wb(a, b) { + b[ld] = q(1e3 * ("0." + a)) + } + + function Xb() { + return this._isUTC ? "UTC" : "" + } + + function Yb() { + return this._isUTC ? "Coordinated Universal Time" : "" + } + + function Zb(a) { + return Da(1e3 * a) + } + + function $b() { + return Da.apply(null, arguments).parseZone() + } + + function _b(a, b, c) { + var d = this._calendar[a]; + return "function" == typeof d ? d.call(b, c) : d + } + + function ac(a) { + var b = this._longDateFormat[a], + c = this._longDateFormat[a.toUpperCase()]; + return b || !c ? b : (this._longDateFormat[a] = c.replace(/MMMM|MM|DD|dddd/g, function (a) { + return a.slice(1) + }), this._longDateFormat[a]) + } + + function bc() { + return this._invalidDate + } + + function cc(a) { + return this._ordinal.replace("%d", a) + } + + function dc(a) { + return a + } + + function ec(a, b, c, d) { + var e = this._relativeTime[c]; + return "function" == typeof e ? e(a, b, c, d) : e.replace(/%d/i, a) + } + + function fc(a, b) { + var c = this._relativeTime[a > 0 ? "future" : "past"]; + return "function" == typeof c ? c(b) : c.replace(/%s/i, b) + } + + function gc(a) { + var b, c; + for (c in a) b = a[c], "function" == typeof b ? this[c] = b : this["_" + c] = b; + this._ordinalParseLenient = new RegExp(this._ordinalParse.source + "|" + /\d{1,2}/.source) + } + + function hc(a, b, c, d) { + var e = y(), + f = h().set(d, b); + return e[c](f, a) + } + + function ic(a, b, c, d, e) { + if ("number" == typeof a && (b = a, a = void 0), a = a || "", null != b) return hc(a, b, c, e); + var f, g = []; + for (f = 0; d > f; f++) g[f] = hc(a, f, c, e); + return g + } + + function jc(a, b) { + return ic(a, b, "months", 12, "month") + } + + function kc(a, b) { + return ic(a, b, "monthsShort", 12, "month") + } + + function lc(a, b) { + return ic(a, b, "weekdays", 7, "day") + } + + function mc(a, b) { + return ic(a, b, "weekdaysShort", 7, "day") + } + + function nc(a, b) { + return ic(a, b, "weekdaysMin", 7, "day") + } + + function oc() { + var a = this._data; + return this._milliseconds = Wd(this._milliseconds), this._days = Wd(this._days), this._months = Wd(this._months), a.milliseconds = Wd(a.milliseconds), a.seconds = Wd(a.seconds), a.minutes = Wd(a.minutes), a.hours = Wd(a.hours), a.months = Wd(a.months), a.years = Wd(a.years), this + } + + function pc(a, b, c, d) { + var e = Ya(b, c); + return a._milliseconds += d * e._milliseconds, a._days += d * e._days, a._months += d * e._months, a._bubble() + } + + function qc(a, b) { + return pc(this, a, b, 1) + } + + function rc(a, b) { + return pc(this, a, b, -1) + } + + function sc(a) { + return 0 > a ? Math.floor(a) : Math.ceil(a) + } + + function tc() { + var a, b, c, d, e, f = this._milliseconds, + g = this._days, + h = this._months, + i = this._data; + return f >= 0 && g >= 0 && h >= 0 || 0 >= f && 0 >= g && 0 >= h || (f += 864e5 * sc(vc(h) + g), g = 0, h = 0), i.milliseconds = f % 1e3, a = p(f / 1e3), i.seconds = a % 60, b = p(a / 60), i.minutes = b % 60, c = p(b / 60), i.hours = c % 24, g += p(c / 24), e = p(uc(g)), h += e, g -= sc(vc(e)), d = p(h / 12), h %= 12, i.days = g, i.months = h, i.years = d, this + } + + function uc(a) { + return 4800 * a / 146097 + } + + function vc(a) { + return 146097 * a / 4800 + } + + function wc(a) { + var b, c, d = this._milliseconds; + if (a = A(a), "month" === a || "year" === a) return b = this._days + d / 864e5, c = this._months + uc(b), "month" === a ? c : c / 12; + switch (b = this._days + Math.round(vc(this._months)), a) { + case "week": + return b / 7 + d / 6048e5; + case "day": + return b + d / 864e5; + case "hour": + return 24 * b + d / 36e5; + case "minute": + return 1440 * b + d / 6e4; + case "second": + return 86400 * b + d / 1e3; + case "millisecond": + return Math.floor(864e5 * b) + d; + default: + throw new Error("Unknown unit " + a) + } + } + + function xc() { + return this._milliseconds + 864e5 * this._days + this._months % 12 * 2592e6 + 31536e6 * q(this._months / 12) + } + + function yc(a) { + return function () { + return this.as(a) + } + } + + function zc(a) { + return a = A(a), this[a + "s"]() + } + + function Ac(a) { + return function () { + return this._data[a] + } + } + + function Bc() { + return p(this.days() / 7) + } + + function Cc(a, b, c, d, e) { + return e.relativeTime(b || 1, !!c, a, d) + } + + function Dc(a, b, c) { + var d = Ya(a).abs(), + e = ke(d.as("s")), + f = ke(d.as("m")), + g = ke(d.as("h")), + h = ke(d.as("d")), + i = ke(d.as("M")), + j = ke(d.as("y")), + k = e < le.s && ["s", e] || 1 === f && ["m"] || f < le.m && ["mm", f] || 1 === g && ["h"] || g < le.h && ["hh", g] || 1 === h && ["d"] || h < le.d && ["dd", h] || 1 === i && ["M"] || i < le.M && ["MM", i] || 1 === j && ["y"] || ["yy", j]; + return k[2] = b, k[3] = +a > 0, k[4] = c, Cc.apply(null, k) + } + + function Ec(a, b) { + return void 0 === le[a] ? !1 : void 0 === b ? le[a] : (le[a] = b, !0) + } + + function Fc(a) { + var b = this.localeData(), + c = Dc(this, !a, b); + return a && (c = b.pastFuture(+this, c)), b.postformat(c) + } + + function Gc() { + var a, b, c, d = me(this._milliseconds) / 1e3, + e = me(this._days), + f = me(this._months); + a = p(d / 60), b = p(a / 60), d %= 60, a %= 60, c = p(f / 12), f %= 12; + var g = c, + h = f, + i = e, + j = b, + k = a, + l = d, + m = this.asSeconds(); + return m ? (0 > m ? "-" : "") + "P" + (g ? g + "Y" : "") + (h ? h + "M" : "") + (i ? i + "D" : "") + (j || k || l ? "T" : "") + (j ? j + "H" : "") + (k ? k + "M" : "") + (l ? l + "S" : "") : "P0D" + } + var Hc, Ic, Jc = a.momentProperties = [], + Kc = !1, + Lc = {}, + Mc = {}, + Nc = /(\[[^\[]*\])|(\\)?(Mo|MM?M?M?|Do|DDDo|DD?D?D?|ddd?d?|do?|w[o|w]?|W[o|W]?|Q|YYYYYY|YYYYY|YYYY|YY|gg(ggg?)?|GG(GGG?)?|e|E|a|A|hh?|HH?|mm?|ss?|S{1,9}|x|X|zz?|ZZ?|.)/g, + Oc = /(\[[^\[]*\])|(\\)?(LTS|LT|LL?L?L?|l{1,4})/g, + Pc = {}, + Qc = {}, + Rc = /\d/, + Sc = /\d\d/, + Tc = /\d{3}/, + Uc = /\d{4}/, + Vc = /[+-]?\d{6}/, + Wc = /\d\d?/, + Xc = /\d{1,3}/, + Yc = /\d{1,4}/, + Zc = /[+-]?\d{1,6}/, + $c = /\d+/, + _c = /[+-]?\d+/, + ad = /Z|[+-]\d\d:?\d\d/gi, + bd = /[+-]?\d+(\.\d{1,3})?/, + cd = /[0-9]*['a-z\u00A0-\u05FF\u0700-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+|[\u0600-\u06FF\/]+(\s*?[\u0600-\u06FF]+){1,2}/i, + dd = {}, + ed = {}, + fd = 0, + gd = 1, + hd = 2, + id = 3, + jd = 4, + kd = 5, + ld = 6; + H("M", ["MM", 2], "Mo", function () { + return this.month() + 1 + }), H("MMM", 0, 0, function (a) { + return this.localeData().monthsShort(this, a) + }), H("MMMM", 0, 0, function (a) { + return this.localeData().months(this, a) + }), z("month", "M"), N("M", Wc), N("MM", Wc, Sc), N("MMM", cd), N("MMMM", cd), Q(["M", "MM"], function (a, b) { + b[gd] = q(a) - 1 + }), Q(["MMM", "MMMM"], function (a, b, c, d) { + var e = c._locale.monthsParse(a, d, c._strict); + null != e ? b[gd] = e : j(c).invalidMonth = a + }); + var md = "January_February_March_April_May_June_July_August_September_October_November_December".split("_"), + nd = "Jan_Feb_Mar_Apr_May_Jun_Jul_Aug_Sep_Oct_Nov_Dec".split("_"), + od = {}; + a.suppressDeprecationWarnings = !1; + var pd = /^\s*(?:[+-]\d{6}|\d{4})-(?:(\d\d-\d\d)|(W\d\d$)|(W\d\d-\d)|(\d\d\d))((T| )(\d\d(:\d\d(:\d\d(\.\d+)?)?)?)?([\+\-]\d\d(?::?\d\d)?|\s*Z)?)?$/, + qd = [ + ["YYYYYY-MM-DD", /[+-]\d{6}-\d{2}-\d{2}/], + ["YYYY-MM-DD", /\d{4}-\d{2}-\d{2}/], + ["GGGG-[W]WW-E", /\d{4}-W\d{2}-\d/], + ["GGGG-[W]WW", /\d{4}-W\d{2}/], + ["YYYY-DDD", /\d{4}-\d{3}/] + ], + rd = [ + ["HH:mm:ss.SSSS", /(T| )\d\d:\d\d:\d\d\.\d+/], + ["HH:mm:ss", /(T| )\d\d:\d\d:\d\d/], + ["HH:mm", /(T| )\d\d:\d\d/], + ["HH", /(T| )\d\d/] + ], + sd = /^\/?Date\((\-?\d+)/i; + a.createFromInputFallback = aa("moment construction falls back to js Date. This is discouraged and will be removed in upcoming major release. Please refer to https://github.com/moment/moment/issues/1407 for more info.", function (a) { + a._d = new Date(a._i + (a._useUTC ? " UTC" : "")) + }), H(0, ["YY", 2], 0, function () { + return this.year() % 100 + }), H(0, ["YYYY", 4], 0, "year"), H(0, ["YYYYY", 5], 0, "year"), H(0, ["YYYYYY", 6, !0], 0, "year"), z("year", "y"), N("Y", _c), N("YY", Wc, Sc), N("YYYY", Yc, Uc), N("YYYYY", Zc, Vc), N("YYYYYY", Zc, Vc), Q(["YYYYY", "YYYYYY"], fd), Q("YYYY", function (b, c) { + c[fd] = 2 === b.length ? a.parseTwoDigitYear(b) : q(b) + }), Q("YY", function (b, c) { + c[fd] = a.parseTwoDigitYear(b) + }), a.parseTwoDigitYear = function (a) { + return q(a) + (q(a) > 68 ? 1900 : 2e3) + }; + var td = C("FullYear", !1); + H("w", ["ww", 2], "wo", "week"), H("W", ["WW", 2], "Wo", "isoWeek"), z("week", "w"), z("isoWeek", "W"), N("w", Wc), N("ww", Wc, Sc), N("W", Wc), N("WW", Wc, Sc), R(["w", "ww", "W", "WW"], function (a, b, c, d) { + b[d.substr(0, 1)] = q(a) + }); + var ud = { + dow: 0, + doy: 6 + }; + H("DDD", ["DDDD", 3], "DDDo", "dayOfYear"), z("dayOfYear", "DDD"), N("DDD", Xc), N("DDDD", Tc), Q(["DDD", "DDDD"], function (a, b, c) { + c._dayOfYear = q(a) + }), a.ISO_8601 = function () {}; + var vd = aa("moment().min is deprecated, use moment.min instead. https://github.com/moment/moment/issues/1548", function () { + var a = Da.apply(null, arguments); + return this > a ? this : a + }), + wd = aa("moment().max is deprecated, use moment.max instead. https://github.com/moment/moment/issues/1548", function () { + var a = Da.apply(null, arguments); + return a > this ? this : a + }); + Ja("Z", ":"), Ja("ZZ", ""), N("Z", ad), N("ZZ", ad), Q(["Z", "ZZ"], function (a, b, c) { + c._useUTC = !0, c._tzm = Ka(a) + }); + var xd = /([\+\-]|\d\d)/gi; + a.updateOffset = function () {}; + var yd = /(\-)?(?:(\d*)\.)?(\d+)\:(\d+)(?:\:(\d+)\.?(\d{3})?)?/, + zd = /^(-)?P(?:(?:([0-9,.]*)Y)?(?:([0-9,.]*)M)?(?:([0-9,.]*)D)?(?:T(?:([0-9,.]*)H)?(?:([0-9,.]*)M)?(?:([0-9,.]*)S)?)?|([0-9,.]*)W)$/; + Ya.fn = Ha.prototype; + var Ad = ab(1, "add"), + Bd = ab(-1, "subtract"); + a.defaultFormat = "YYYY-MM-DDTHH:mm:ssZ"; + var Cd = aa("moment().lang() is deprecated. Instead, use moment().localeData() to get the language configuration. Use moment().locale() to change languages.", function (a) { + return void 0 === a ? this.localeData() : this.locale(a) + }); + H(0, ["gg", 2], 0, function () { + return this.weekYear() % 100 + }), H(0, ["GG", 2], 0, function () { + return this.isoWeekYear() % 100 + }), Db("gggg", "weekYear"), Db("ggggg", "weekYear"), Db("GGGG", "isoWeekYear"), Db("GGGGG", "isoWeekYear"), z("weekYear", "gg"), z("isoWeekYear", "GG"), N("G", _c), N("g", _c), N("GG", Wc, Sc), N("gg", Wc, Sc), N("GGGG", Yc, Uc), N("gggg", Yc, Uc), N("GGGGG", Zc, Vc), N("ggggg", Zc, Vc), R(["gggg", "ggggg", "GGGG", "GGGGG"], function (a, b, c, d) { + b[d.substr(0, 2)] = q(a) + }), R(["gg", "GG"], function (b, c, d, e) { + c[e] = a.parseTwoDigitYear(b) + }), H("Q", 0, 0, "quarter"), z("quarter", "Q"), N("Q", Rc), Q("Q", function (a, b) { + b[gd] = 3 * (q(a) - 1) + }), H("D", ["DD", 2], "Do", "date"), z("date", "D"), N("D", Wc), N("DD", Wc, Sc), N("Do", function (a, b) { + return a ? b._ordinalParse : b._ordinalParseLenient + }), Q(["D", "DD"], hd), Q("Do", function (a, b) { + b[hd] = q(a.match(Wc)[0], 10) + }); + var Dd = C("Date", !0); + H("d", 0, "do", "day"), H("dd", 0, 0, function (a) { + return this.localeData().weekdaysMin(this, a) + }), H("ddd", 0, 0, function (a) { + return this.localeData().weekdaysShort(this, a) + }), H("dddd", 0, 0, function (a) { + return this.localeData().weekdays(this, a) + }), H("e", 0, 0, "weekday"), H("E", 0, 0, "isoWeekday"), z("day", "d"), z("weekday", "e"), z("isoWeekday", "E"), N("d", Wc), N("e", Wc), N("E", Wc), N("dd", cd), N("ddd", cd), N("dddd", cd), R(["dd", "ddd", "dddd"], function (a, b, c) { + var d = c._locale.weekdaysParse(a); + null != d ? b.d = d : j(c).invalidWeekday = a + }), R(["d", "e", "E"], function (a, b, c, d) { + b[d] = q(a) + }); + var Ed = "Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"), + Fd = "Sun_Mon_Tue_Wed_Thu_Fri_Sat".split("_"), + Gd = "Su_Mo_Tu_We_Th_Fr_Sa".split("_"); + H("H", ["HH", 2], 0, "hour"), H("h", ["hh", 2], 0, function () { + return this.hours() % 12 || 12 + }), Sb("a", !0), Sb("A", !1), z("hour", "h"), N("a", Tb), N("A", Tb), N("H", Wc), N("h", Wc), N("HH", Wc, Sc), N("hh", Wc, Sc), Q(["H", "HH"], id), Q(["a", "A"], function (a, b, c) { + c._isPm = c._locale.isPM(a), c._meridiem = a + }), Q(["h", "hh"], function (a, b, c) { + b[id] = q(a), j(c).bigHour = !0 + }); + var Hd = /[ap]\.?m?\.?/i, + Id = C("Hours", !0); + H("m", ["mm", 2], 0, "minute"), z("minute", "m"), N("m", Wc), N("mm", Wc, Sc), Q(["m", "mm"], jd); + var Jd = C("Minutes", !1); + H("s", ["ss", 2], 0, "second"), z("second", "s"), N("s", Wc), N("ss", Wc, Sc), Q(["s", "ss"], kd); + var Kd = C("Seconds", !1); + H("S", 0, 0, function () { + return ~~(this.millisecond() / 100) + }), H(0, ["SS", 2], 0, function () { + return ~~(this.millisecond() / 10) + }), H(0, ["SSS", 3], 0, "millisecond"), H(0, ["SSSS", 4], 0, function () { + return 10 * this.millisecond() + }), H(0, ["SSSSS", 5], 0, function () { + return 100 * this.millisecond() + }), H(0, ["SSSSSS", 6], 0, function () { + return 1e3 * this.millisecond() + }), H(0, ["SSSSSSS", 7], 0, function () { + return 1e4 * this.millisecond() + }), H(0, ["SSSSSSSS", 8], 0, function () { + return 1e5 * this.millisecond() + }), H(0, ["SSSSSSSSS", 9], 0, function () { + return 1e6 * this.millisecond() + }), z("millisecond", "ms"), N("S", Xc, Rc), N("SS", Xc, Sc), N("SSS", Xc, Tc); + var Ld; + for (Ld = "SSSS"; Ld.length <= 9; Ld += "S") N(Ld, $c); + for (Ld = "S"; Ld.length <= 9; Ld += "S") Q(Ld, Wb); + var Md = C("Milliseconds", !1); + H("z", 0, 0, "zoneAbbr"), H("zz", 0, 0, "zoneName"); + var Nd = n.prototype; + Nd.add = Ad, Nd.calendar = cb, Nd.clone = db, Nd.diff = ib, Nd.endOf = ub, Nd.format = mb, Nd.from = nb, Nd.fromNow = ob, Nd.to = pb, Nd.toNow = qb, Nd.get = F, Nd.invalidAt = Cb, Nd.isAfter = eb, Nd.isBefore = fb, Nd.isBetween = gb, Nd.isSame = hb, Nd.isValid = Ab, Nd.lang = Cd, Nd.locale = rb, Nd.localeData = sb, Nd.max = wd, Nd.min = vd, Nd.parsingFlags = Bb, Nd.set = F, Nd.startOf = tb, Nd.subtract = Bd, Nd.toArray = yb, Nd.toObject = zb, Nd.toDate = xb, Nd.toISOString = lb, Nd.toJSON = lb, Nd.toString = kb, Nd.unix = wb, Nd.valueOf = vb, Nd.year = td, Nd.isLeapYear = ia, Nd.weekYear = Fb, Nd.isoWeekYear = Gb, Nd.quarter = Nd.quarters = Jb, Nd.month = Y, Nd.daysInMonth = Z, Nd.week = Nd.weeks = na, Nd.isoWeek = Nd.isoWeeks = oa, Nd.weeksInYear = Ib, Nd.isoWeeksInYear = Hb, Nd.date = Dd, Nd.day = Nd.days = Pb, Nd.weekday = Qb, Nd.isoWeekday = Rb, Nd.dayOfYear = qa, Nd.hour = Nd.hours = Id, Nd.minute = Nd.minutes = Jd, Nd.second = Nd.seconds = Kd, + Nd.millisecond = Nd.milliseconds = Md, Nd.utcOffset = Na, Nd.utc = Pa, Nd.local = Qa, Nd.parseZone = Ra, Nd.hasAlignedHourOffset = Sa, Nd.isDST = Ta, Nd.isDSTShifted = Ua, Nd.isLocal = Va, Nd.isUtcOffset = Wa, Nd.isUtc = Xa, Nd.isUTC = Xa, Nd.zoneAbbr = Xb, Nd.zoneName = Yb, Nd.dates = aa("dates accessor is deprecated. Use date instead.", Dd), Nd.months = aa("months accessor is deprecated. Use month instead", Y), Nd.years = aa("years accessor is deprecated. Use year instead", td), Nd.zone = aa("moment().zone is deprecated, use moment().utcOffset instead. https://github.com/moment/moment/issues/1779", Oa); + var Od = Nd, + Pd = { + sameDay: "[Today at] LT", + nextDay: "[Tomorrow at] LT", + nextWeek: "dddd [at] LT", + lastDay: "[Yesterday at] LT", + lastWeek: "[Last] dddd [at] LT", + sameElse: "L" + }, + Qd = { + LTS: "h:mm:ss A", + LT: "h:mm A", + L: "MM/DD/YYYY", + LL: "MMMM D, YYYY", + LLL: "MMMM D, YYYY h:mm A", + LLLL: "dddd, MMMM D, YYYY h:mm A" + }, + Rd = "Invalid date", + Sd = "%d", + Td = /\d{1,2}/, + Ud = { + future: "in %s", + past: "%s ago", + s: "a few seconds", + m: "a minute", + mm: "%d minutes", + h: "an hour", + hh: "%d hours", + d: "a day", + dd: "%d days", + M: "a month", + MM: "%d months", + y: "a year", + yy: "%d years" + }, + Vd = s.prototype; + Vd._calendar = Pd, Vd.calendar = _b, Vd._longDateFormat = Qd, Vd.longDateFormat = ac, Vd._invalidDate = Rd, Vd.invalidDate = bc, Vd._ordinal = Sd, Vd.ordinal = cc, Vd._ordinalParse = Td, Vd.preparse = dc, Vd.postformat = dc, Vd._relativeTime = Ud, Vd.relativeTime = ec, Vd.pastFuture = fc, Vd.set = gc, Vd.months = U, Vd._months = md, Vd.monthsShort = V, Vd._monthsShort = nd, Vd.monthsParse = W, Vd.week = ka, Vd._week = ud, Vd.firstDayOfYear = ma, Vd.firstDayOfWeek = la, Vd.weekdays = Lb, Vd._weekdays = Ed, Vd.weekdaysMin = Nb, Vd._weekdaysMin = Gd, Vd.weekdaysShort = Mb, Vd._weekdaysShort = Fd, Vd.weekdaysParse = Ob, Vd.isPM = Ub, Vd._meridiemParse = Hd, Vd.meridiem = Vb, w("en", { + ordinalParse: /\d{1,2}(th|st|nd|rd)/, + ordinal: function (a) { + var b = a % 10, + c = 1 === q(a % 100 / 10) ? "th" : 1 === b ? "st" : 2 === b ? "nd" : 3 === b ? "rd" : "th"; + return a + c + } + }), a.lang = aa("moment.lang is deprecated. Use moment.locale instead.", w), a.langData = aa("moment.langData is deprecated. Use moment.localeData instead.", y); + var Wd = Math.abs, + Xd = yc("ms"), + Yd = yc("s"), + Zd = yc("m"), + $d = yc("h"), + _d = yc("d"), + ae = yc("w"), + be = yc("M"), + ce = yc("y"), + de = Ac("milliseconds"), + ee = Ac("seconds"), + fe = Ac("minutes"), + ge = Ac("hours"), + he = Ac("days"), + ie = Ac("months"), + je = Ac("years"), + ke = Math.round, + le = { + s: 45, + m: 45, + h: 22, + d: 26, + M: 11 + }, + me = Math.abs, + ne = Ha.prototype; + ne.abs = oc, ne.add = qc, ne.subtract = rc, ne.as = wc, ne.asMilliseconds = Xd, ne.asSeconds = Yd, ne.asMinutes = Zd, ne.asHours = $d, ne.asDays = _d, ne.asWeeks = ae, ne.asMonths = be, ne.asYears = ce, ne.valueOf = xc, ne._bubble = tc, ne.get = zc, ne.milliseconds = de, ne.seconds = ee, ne.minutes = fe, ne.hours = ge, ne.days = he, ne.weeks = Bc, ne.months = ie, ne.years = je, ne.humanize = Fc, ne.toISOString = Gc, ne.toString = Gc, ne.toJSON = Gc, ne.locale = rb, ne.localeData = sb, ne.toIsoString = aa("toIsoString() is deprecated. Please use toISOString() instead (notice the capitals)", Gc), ne.lang = Cd, H("X", 0, 0, "unix"), H("x", 0, 0, "valueOf"), N("x", _c), N("X", bd), Q("X", function (a, b, c) { + c._d = new Date(1e3 * parseFloat(a, 10)) + }), Q("x", function (a, b, c) { + c._d = new Date(q(a)) + }), a.version = "2.10.6", b(Da), a.fn = Od, a.min = Fa, a.max = Ga, a.utc = h, a.unix = Zb, a.months = jc, a.isDate = d, a.locale = w, a.invalid = l, a.duration = Ya, a.isMoment = o, a.weekdays = lc, a.parseZone = $b, a.localeData = y, a.isDuration = Ia, a.monthsShort = kc, a.weekdaysMin = nc, a.defineLocale = x, a.weekdaysShort = mc, a.normalizeUnits = A, a.relativeTimeThreshold = Ec; + var oe = a; + return oe +}); \ No newline at end of file diff --git a/utils/util.js b/utils/util.js new file mode 100644 index 0000000..dbadbb8 --- /dev/null +++ b/utils/util.js @@ -0,0 +1,19 @@ +const formatTime = date => { + const year = date.getFullYear() + const month = date.getMonth() + 1 + const day = date.getDate() + const hour = date.getHours() + const minute = date.getMinutes() + const second = date.getSeconds() + + return [year, month, day].map(formatNumber).join('/') + ' ' + [hour, minute, second].map(formatNumber).join(':') +} + +const formatNumber = n => { + n = n.toString() + return n[1] ? n : '0' + n +} + +module.exports = { + formatTime: formatTime +}