123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253 |
- // pages/login/login.js
- import WxValidate from '../../utils/wxValidate'
- const app = getApp()
- var type = "";//用来保存picker组件选中的类别id
- Page({
- /**
- * 页面的初始数据
- */
- data: {
- frameStyle: { useTop: true, name: '比赛修改', leftArrow: true, useBar: false },
- // 主体高度
- infoHeight: '',
- ids: '',
- form: {},
- cateArray: [
- { id: '0', type: '未开始' }, { id: '1', type: '报名中' }, { id: '2', type: '待比赛' }, { id: '3', type: '进行中' }, { id: '4', type: '已结束' }],
- cateIndex: 0,
- starttime: '2018-01-01',//默认起始时间
- endtime: '2018-01-24',//默认结束时间
- timedate: '2018-09-01',
- time: '12:01',
- // 赛制信息
- // 默认值
- szValue: [],
- // 赛制选择信息
- valueList: [],
- // 原数据
- levelArray: [
- ['淘汰制', '循环制'],
- ['单败淘汰', '双败淘汰', '交叉淘汰'],
- ['单循环', '双循环', '四循环']
- ],
- // 赛制储存信息
- szList: [],
- },
- //验证是否输入
- initValidate() {
- const rules = { name: { required: true }, match_time: { required: true, }, single_time: { required: true }, address: { required: true, }, format: { required: true } }
- // 验证字段的提示信息,若不传则调用默认的信息
- const messages = { name: { required: '请输入比赛名称', }, match_time: { required: '请输入时间', }, single_time: { required: '请输入单场时间', }, address: { required: '请输入地点', }, format: { required: '请选择赛制', } };
- this.WxValidate = new WxValidate(rules, messages)
- },
- //当用户点击确定时,执行的事件
- bindCatePickerChange: function (e) {
- var cid = this.data.cateArray[e.detail.value].id;
- type = cid
- //下面重新赋值必须有,页面显示的信息才会改为刚刚选中的值
- this.setData({
- cateIndex: e.detail.value,
- })
- },
- // 确定选择
- szChange: function (e) {
- const that = this;
- let value = e.detail.value;
- let list = that.data.valueList;
- let data = []
- for (let [index, val] of value.entries()) {
- if (list[index][val]) data.push(list[index][val])
- else data.push(list[index][0])
- }
- //存值
- let sz = [...that.data.szList, { type: data[0], name: data[1] }]
- that.setData({ szList: sz })
- that.setData({ szValue: data })
- that.search();
- },
- // 列值改变时
- columnChange: function (e) {
- const that = this;
- let array = that.data.levelArray;
- let list = that.data.valueList;
- if (e.detail.column == '0') list[1] = array[parseInt(e.detail.value) + 1];
- that.setData({ valueList: list });
- },
- //删除
- toDel: function (e) {
- const that = this;
- let list = that.data.szList;
- let value = e.currentTarget.dataset.index;
- let data = list.filter((i, index) => index != value)
- this.setData({ szList: data })
- },
- bindDateChange3: function (e) {
- this.setData({
- timedate: e.detail.value
- })
- },
- bindTimeChange: function (e) {
- this.setData({
- time: e.detail.value
- })
- },
- // 时间段选择
- bindDateChange(e) {
- let that = this;
- that.setData({
- starttime: e.detail.value,
- })
- },
- bindDateChange2(e) {
- let that = this;
- that.setData({
- endtime: e.detail.value,
- })
- },
- //提交
- formSubmit: function (e) {
- const value = e.detail.value;
- value.match_time = this.data.starttime + ' - ' + this.data.endtime;
- value.single_time = this.data.timedate + ' ' + this.data.time;
- value.format = this.data.szList;
- value.status = this.data.cateIndex;
- var id = this.data.ids;
- if (!this.WxValidate.checkForm(value)) {
- const error = this.WxValidate.errorList[0];
- wx.showToast({ title: `${error.msg}`, icon: 'error', duration: 2000 })
- return false
- } else {
- wx.getStorage({
- key: 'token',
- success: function (res) {
- wx.request({
- url: `${app.globalData.publicUrl}/courtAdmin/api/match/${id}`,
- method: 'post',
- data: value,
- success(res) {
- console.log(res.data.data);
- wx.showToast({ title: `修改比赛成功`, icon: 'success', duration: 2000 })
- }
- })
- }
- })
- }
- },
- back: function () {
- wx.navigateBack({ url: '/pages/home/index' })
- },
- /**
- * 生命周期函数--监听页面加载
- */
- onLoad: function (options) {
- const that = this;
- that.setData({ ids: options.id })
- //选择器
- var cindex = that.data.cateIndex
- type = that.data.cateArray[cindex].id
- // 监听用户是否登录
- that.watchLogin();
- //验证规则函数
- that.initValidate()
- // 计算高度
- that.searchHeight()
- // 初始化数据
- that.search();
- },
- // 监听用户是否登录
- watchLogin: function () {
- var that = this;
- var id = that.data.ids;
- wx.getStorage({
- key: 'token',
- success: res => {
- wx.request({
- url: `${app.globalData.publicUrl}/courtAdmin/api/match/${id}`,
- method: 'get',
- data: {},
- success(res) {
- that.setData({
- form: res.data.data,
- timedate: res.data.data.single_time.substring(0, 10),
- time: res.data.data.single_time.substring(11, 16),
- starttime: res.data.data.match_time.substring(0, 10),
- endtime: res.data.data.match_time.substring(13, 28),
- cateIndex: res.data.data.status,
- szList: res.data.data.format
- });
- }
- })
- },
- fail: res => {
- return wx.redirectTo({ url: '/pages/login/index', })
- }
- })
- },
- //查找选择器的值
- search: function () {
- const that = this;
- let data = that.data.levelArray;
- that.setData({ valueList: [data[0], data[1]] })
- },
- // 计算高度
- searchHeight: function () {
- let frameStyle = this.data.frameStyle;
- let client = app.globalData.client;
- let infoHeight = client.windowHeight;
- // 是否去掉状态栏
- if (frameStyle.useTop) infoHeight = infoHeight - (client.statusBarHeight + client.getMenu.height + (client.getMenu.top - client.statusBarHeight) * 2);
- // 是否减去底部菜单
- if (frameStyle.useBar) infoHeight = infoHeight - 50;
- if (infoHeight) this.setData({ infoHeight: infoHeight })
- },
- /**
- * 生命周期函数--监听页面初次渲染完成
- */
- onReady: function () {
- },
- /**
- * 生命周期函数--监听页面显示
- */
- onShow: function () {
- },
- /**
- * 生命周期函数--监听页面隐藏
- */
- onHide: function () {
- },
- /**
- * 生命周期函数--监听页面卸载
- */
- onUnload: function () {
- },
- /**
- * 页面相关事件处理函数--监听用户下拉动作
- */
- onPullDownRefresh: function () {
- },
- /**
- * 页面上拉触底事件的处理函数
- */
- onReachBottom: function () {
- },
- /**
- * 用户点击右上角分享
- */
- onShareAppMessage: function () {
- }
- })
|