xincheng
2 years ago
16 changed files with 1032 additions and 17 deletions
@ -0,0 +1,590 @@ |
|||||
|
// components/picker-timer/picker-time.js
|
||||
|
|
||||
|
Component({ |
||||
|
/** |
||||
|
* 组件的属性列表 |
||||
|
*/ |
||||
|
properties: { |
||||
|
pickerShow: { |
||||
|
type: Boolean, |
||||
|
observer: function (val) { //弹出动画
|
||||
|
if (val) { |
||||
|
let animation = wx.createAnimation({ |
||||
|
duration: 500, |
||||
|
timingFunction: "ease" |
||||
|
}); |
||||
|
let animationOpacity = wx.createAnimation({ |
||||
|
duration: 500, |
||||
|
timingFunction: "ease" |
||||
|
}); |
||||
|
setTimeout(() => { |
||||
|
animation.bottom(0).step(); |
||||
|
animationOpacity.opacity(0.7).step(); |
||||
|
this.setData({ |
||||
|
animationOpacity: animationOpacity.export(), |
||||
|
animationData: animation.export() |
||||
|
}) |
||||
|
}, 0); |
||||
|
} else { |
||||
|
let animation = wx.createAnimation({ |
||||
|
duration: 100, |
||||
|
timingFunction: "ease" |
||||
|
}); |
||||
|
let animationOpacity = wx.createAnimation({ |
||||
|
duration: 500, |
||||
|
timingFunction: "ease" |
||||
|
}); |
||||
|
animation.bottom(-320).step(); |
||||
|
animationOpacity.opacity(0).step(); |
||||
|
this.setData({ |
||||
|
animationOpacity: animationOpacity.export(), |
||||
|
animationData: animation.export() |
||||
|
}); |
||||
|
} |
||||
|
|
||||
|
// 在picker滚动未停止前点确定,会使startValue数组各项归零,发生错误,这里判断并重新初始化
|
||||
|
// 微信新增了picker滚动的回调函数,已进行兼容
|
||||
|
if (this.data.startValue && this.data.endValue) { |
||||
|
let s = 0, e = 0; |
||||
|
let conf = this.data.config; |
||||
|
|
||||
|
this.data.startValue.map(val => { |
||||
|
if (val == 0) { |
||||
|
s++ |
||||
|
} |
||||
|
}) |
||||
|
this.data.endValue.map(val => { |
||||
|
if (val == 0) { |
||||
|
e++; |
||||
|
} |
||||
|
}); |
||||
|
let tmp = { |
||||
|
hour: 4, |
||||
|
minute: 5, |
||||
|
second: 6 |
||||
|
} |
||||
|
let n = tmp[conf.column]; |
||||
|
if (s >= n || e >= n) { |
||||
|
this.initPick(this.data.config); |
||||
|
this.setData({ |
||||
|
startValue: this.data.startValue, |
||||
|
endValue: this.data.endValue, |
||||
|
}); |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
|
||||
|
} |
||||
|
}, |
||||
|
config: Object |
||||
|
}, |
||||
|
|
||||
|
/** |
||||
|
* 组件的初始数据 |
||||
|
*/ |
||||
|
data: { |
||||
|
// pickerShow:true
|
||||
|
// limitStartTime: new Date().getTime()-1000*60*60*24*30,
|
||||
|
// limitEndTime: new Date().getTime(),
|
||||
|
// yearStart:2000,
|
||||
|
// yearEnd:2100
|
||||
|
}, |
||||
|
detached: function () { |
||||
|
console.log("dele"); |
||||
|
}, |
||||
|
attached: function () { }, |
||||
|
ready: function () { |
||||
|
this.readConfig(); |
||||
|
this.initPick(this.data.config || null); |
||||
|
this.setData({ |
||||
|
startValue: this.data.startValue, |
||||
|
endValue: this.data.endValue, |
||||
|
}); |
||||
|
|
||||
|
|
||||
|
|
||||
|
|
||||
|
}, |
||||
|
/** |
||||
|
* 组件的方法列表 |
||||
|
*/ |
||||
|
methods: { |
||||
|
//阻止滑动事件
|
||||
|
onCatchTouchMove(e) { |
||||
|
|
||||
|
}, |
||||
|
//读取配置项
|
||||
|
readConfig() { |
||||
|
let limitEndTime = new Date().getTime(); |
||||
|
let limitStartTime = new Date().getTime() - 1000 * 60 * 60 * 24 * 30; |
||||
|
if (this.data.config) { |
||||
|
let conf = this.data.config; |
||||
|
|
||||
|
if (typeof conf.dateLimit == "number") { |
||||
|
limitStartTime = |
||||
|
new Date().getTime() - 1000 * 60 * 60 * 24 * conf.dateLimit; |
||||
|
} |
||||
|
if (conf.limitStartTime) { |
||||
|
|
||||
|
limitStartTime = new Date(conf.limitStartTime.replace(/-/g, '/')).getTime(); |
||||
|
} |
||||
|
|
||||
|
if (conf.limitEndTime) { |
||||
|
limitEndTime = new Date(conf.limitEndTime.replace(/-/g, '/')).getTime(); |
||||
|
} |
||||
|
|
||||
|
this.setData({ |
||||
|
yearStart: conf.yearStart || 2000, |
||||
|
yearEnd: conf.yearEnd || 2100, |
||||
|
endDate: conf.endDate || false, |
||||
|
dateLimit: conf.dateLimit || false, |
||||
|
hourColumn: |
||||
|
conf.column == "hour" || |
||||
|
conf.column == "minute" || |
||||
|
conf.column == "second", |
||||
|
minColumn: conf.column == "minute" || conf.column == "second", |
||||
|
secColumn: conf.column == "second" |
||||
|
}); |
||||
|
} |
||||
|
|
||||
|
let limitStartTimeArr = formatTime(limitStartTime); |
||||
|
let limitEndTimeArr = formatTime(limitEndTime); |
||||
|
|
||||
|
this.setData({ |
||||
|
limitStartTime, |
||||
|
limitStartTimeArr, |
||||
|
limitEndTime, |
||||
|
limitEndTimeArr |
||||
|
}); |
||||
|
}, |
||||
|
//滚动开始
|
||||
|
handlePickStart: function (e) { |
||||
|
this.setData({ |
||||
|
isPicking: true |
||||
|
}) |
||||
|
}, |
||||
|
//滚动结束
|
||||
|
handlePickEnd: function (e) { |
||||
|
this.setData({ |
||||
|
isPicking: false |
||||
|
}) |
||||
|
}, |
||||
|
onConfirm: function () { |
||||
|
//滚动未结束时不能确认
|
||||
|
if (this.data.isPicking) { return } |
||||
|
let startTime = new Date(this.data.startPickTime.replace(/-/g, "/")); |
||||
|
let endTime = new Date(this.data.endPickTime.replace(/-/g, "/")); |
||||
|
if (startTime <= endTime || !this.data.endDate) { |
||||
|
this.setData({ |
||||
|
startTime, |
||||
|
endTime |
||||
|
}); |
||||
|
let startArr = formatTime(startTime).arr; |
||||
|
let endArr = formatTime(endTime).arr; |
||||
|
let format0 = function (num) { |
||||
|
return num < 10 ? '0' + num : num |
||||
|
} |
||||
|
|
||||
|
let startTimeBack = |
||||
|
startArr[0] + |
||||
|
"-" + |
||||
|
format0(startArr[1]) + |
||||
|
"-" + |
||||
|
format0(startArr[2]) |
||||
|
// +
|
||||
|
// " " +
|
||||
|
// (this.data.hourColumn ? format0(startArr[3]) : "00") +
|
||||
|
// ":" +
|
||||
|
// (this.data.minColumn ? format0(startArr[4]) : "00") +
|
||||
|
// ":" +
|
||||
|
// (this.data.secColumn ? format0(startArr[5]) : "00")
|
||||
|
; |
||||
|
|
||||
|
let endTimeBack = |
||||
|
endArr[0] + |
||||
|
"-" + |
||||
|
format0(endArr[1]) + |
||||
|
"-" + |
||||
|
format0(endArr[2]) |
||||
|
// +
|
||||
|
// " " +
|
||||
|
// (this.data.hourColumn ? format0(endArr[3]) : "00") +
|
||||
|
// ":" +
|
||||
|
// (this.data.minColumn ? format0(endArr[4]) : "00") +
|
||||
|
// ":" +
|
||||
|
// (this.data.secColumn ? format0(endArr[5]) : "00")
|
||||
|
; |
||||
|
|
||||
|
let time = { |
||||
|
startTime: startTimeBack, |
||||
|
endTime: endTimeBack |
||||
|
}; |
||||
|
|
||||
|
//触发自定义事件
|
||||
|
this.triggerEvent("setPickerTime", time); |
||||
|
this.triggerEvent("hidePicker", {}); |
||||
|
} else { |
||||
|
wx.showToast({ |
||||
|
icon: "none", |
||||
|
title: "开始时间必须小于结束时间" |
||||
|
}); |
||||
|
} |
||||
|
}, |
||||
|
hideModal: function () { |
||||
|
|
||||
|
this.triggerEvent("hidePicker", {}); |
||||
|
}, |
||||
|
changeStartDateTime: function (e) { |
||||
|
let val = e.detail.value; |
||||
|
|
||||
|
this.compareTime(val, "start"); |
||||
|
}, |
||||
|
|
||||
|
changeEndDateTime: function (e) { |
||||
|
let val = e.detail.value; |
||||
|
this.compareTime(val, "end"); |
||||
|
}, |
||||
|
//比较时间是否在范围内
|
||||
|
compareTime(val, type) { |
||||
|
let h = val[3] ? this.data.HourList[val[3]] : "00"; |
||||
|
let m = val[4] ? this.data.MinuteList[val[4]] : "00"; |
||||
|
let s = val[5] ? this.data.SecondList[val[5]] : "00"; |
||||
|
let time = |
||||
|
this.data.YearList[val[0]] + |
||||
|
"-" + |
||||
|
this.data.MonthList[val[1]] + |
||||
|
"-" + |
||||
|
this.data.DayList[val[2]] + |
||||
|
" " + |
||||
|
h + |
||||
|
":" + |
||||
|
m + |
||||
|
":" + |
||||
|
s; |
||||
|
|
||||
|
let start = this.data.limitStartTime; |
||||
|
let end = this.data.limitEndTime; |
||||
|
let timeNum = new Date(time.replace(/-/g, '/')).getTime(); |
||||
|
let year, month, day, hour, min, sec, limitDate; |
||||
|
let tempArr = [] |
||||
|
|
||||
|
// if (!this.data.dateLimit){
|
||||
|
// limitDate = [
|
||||
|
// this.data.YearList[val[0]],
|
||||
|
// this.data.MonthList[val[1]],
|
||||
|
// this.data.DayList[val[2]],
|
||||
|
// this.data.HourList[val[3]],
|
||||
|
// this.data.MinuteList[val[4]],
|
||||
|
// this.data.SecondList[val[5]]]
|
||||
|
// } else if (type == "start" && timeNum > new Date(this.data.endPickTime.replace(/-/g, '/')) && this.data.config.endDate) {
|
||||
|
// limitDate = formatTime(this.data.endPickTime).arr;
|
||||
|
|
||||
|
// } else if (type == "end" && timeNum < new Date(this.data.startPickTime.replace(/-/g, '/'))) {
|
||||
|
// limitDate = formatTime(this.data.startPickTime).arr;
|
||||
|
|
||||
|
// } else if (timeNum < start) {
|
||||
|
// limitDate = this.data.limitStartTimeArr.arr;
|
||||
|
|
||||
|
// } else if (timeNum > end) {
|
||||
|
// limitDate = this.data.limitEndTimeArr.arr;
|
||||
|
|
||||
|
// } else {
|
||||
|
// limitDate = [
|
||||
|
// this.data.YearList[val[0]],
|
||||
|
// this.data.MonthList[val[1]],
|
||||
|
// this.data.DayList[val[2]],
|
||||
|
// this.data.HourList[val[3]],
|
||||
|
// this.data.MinuteList[val[4]],
|
||||
|
// this.data.SecondList[val[5]]
|
||||
|
// ]
|
||||
|
|
||||
|
// }
|
||||
|
|
||||
|
if (!this.data.dateLimit) { |
||||
|
limitDate = [ |
||||
|
this.data.YearList[val[0]], |
||||
|
this.data.MonthList[val[1]], |
||||
|
this.data.DayList[val[2]], |
||||
|
this.data.HourList[val[3]], |
||||
|
this.data.MinuteList[val[4]], |
||||
|
this.data.SecondList[val[5]]] |
||||
|
} else { |
||||
|
limitDate = [ |
||||
|
this.data.YearList[val[0]], |
||||
|
this.data.MonthList[val[1]], |
||||
|
this.data.DayList[val[2]], |
||||
|
this.data.HourList[val[3]], |
||||
|
this.data.MinuteList[val[4]], |
||||
|
this.data.SecondList[val[5]] |
||||
|
] |
||||
|
|
||||
|
} |
||||
|
|
||||
|
year = limitDate[0]; |
||||
|
month = limitDate[1]; |
||||
|
day = limitDate[2]; |
||||
|
hour = limitDate[3]; |
||||
|
min = limitDate[4]; |
||||
|
sec = limitDate[5]; |
||||
|
|
||||
|
if (type == "start") { |
||||
|
this.setStartDate(year, month, day, hour, min, sec); |
||||
|
} else if (type == "end") { |
||||
|
this.setEndDate(year, month, day, hour, min, sec); |
||||
|
} |
||||
|
}, |
||||
|
getDays: function (year, month) { |
||||
|
let daysInMonth = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]; |
||||
|
if (month === 2) { |
||||
|
return (year % 4 === 0 && year % 100 !== 0) || year % 400 === 0 |
||||
|
? 29 |
||||
|
: 28; |
||||
|
} else { |
||||
|
return daysInMonth[month - 1]; |
||||
|
} |
||||
|
}, |
||||
|
initPick: function (initData) { |
||||
|
const date = initData.initStartTime ? new Date(initData.initStartTime.replace(/-/g, '/')) : new Date(); |
||||
|
const endDate = initData.initEndTime ? new Date(initData.initEndTime.replace(/-/g, '/')) : new Date(); |
||||
|
// const startDate = new Date(date.getTime() - 1000 * 60 * 60 * 24);
|
||||
|
const startDate = date; |
||||
|
const startYear = date.getFullYear(); |
||||
|
const startMonth = date.getMonth() + 1; |
||||
|
const startDay = date.getDate(); |
||||
|
const startHour = date.getHours(); |
||||
|
const startMinute = date.getMinutes(); |
||||
|
const startSecond = date.getSeconds(); |
||||
|
|
||||
|
const endYear = endDate.getFullYear(); |
||||
|
const endMonth = endDate.getMonth() + 1; |
||||
|
const endDay = endDate.getDate(); |
||||
|
const endHour = endDate.getHours(); |
||||
|
const endMinute = endDate.getMinutes(); |
||||
|
const endSecond = endDate.getSeconds(); |
||||
|
|
||||
|
let YearList = []; |
||||
|
let MonthList = []; |
||||
|
let DayList = []; |
||||
|
let HourList = []; |
||||
|
let MinuteList = []; |
||||
|
let SecondList = []; |
||||
|
|
||||
|
//设置年份列表
|
||||
|
for (let i = this.data.yearStart; i <= this.data.yearEnd; i++) { |
||||
|
YearList.push(i); |
||||
|
} |
||||
|
|
||||
|
// 设置月份列表
|
||||
|
for (let i = 1; i <= 12; i++) { |
||||
|
MonthList.push(i); |
||||
|
} |
||||
|
// 设置日期列表
|
||||
|
for (let i = 1; i <= 31; i++) { |
||||
|
DayList.push(i); |
||||
|
} |
||||
|
// 设置时列表
|
||||
|
for (let i = 0; i <= 23; i++) { |
||||
|
if (0 <= i && i < 10) { |
||||
|
i = "0" + i; |
||||
|
} |
||||
|
HourList.push(i); |
||||
|
} |
||||
|
// 分|秒
|
||||
|
for (let i = 0; i <= 59; i++) { |
||||
|
if (0 <= i && i < 10) { |
||||
|
i = "0" + i; |
||||
|
} |
||||
|
MinuteList.push(i); |
||||
|
SecondList.push(i); |
||||
|
} |
||||
|
|
||||
|
this.setData({ |
||||
|
YearList, |
||||
|
MonthList, |
||||
|
DayList, |
||||
|
HourList, |
||||
|
MinuteList, |
||||
|
SecondList |
||||
|
}); |
||||
|
|
||||
|
this.setStartDate(startYear, startMonth, startDay, startHour, startMinute, startSecond); |
||||
|
this.setEndDate(endYear, endMonth, endDay, endHour, endMinute, endSecond); |
||||
|
|
||||
|
//!!!
|
||||
|
// setTimeout(() => {
|
||||
|
// this.setStartDate(nowYear, nowMonth, nowDay, nowHour, nowMinute)
|
||||
|
// this.setEndDate(nowYear, nowMonth, nowDay, nowHour, nowMinute)
|
||||
|
// }, 0);
|
||||
|
}, |
||||
|
setPickerDateArr(type, year, month, day, hour, minute, second) { |
||||
|
let yearIdx = 0; |
||||
|
let monthIdx = 0; |
||||
|
let dayIdx = 0; |
||||
|
let hourIdx = 0; |
||||
|
let minuteIdx = 0; |
||||
|
let secondIdx = 0; |
||||
|
|
||||
|
this.data.YearList.map((v, idx) => { |
||||
|
if (parseInt(v) === year) { |
||||
|
yearIdx = idx; |
||||
|
} |
||||
|
}); |
||||
|
|
||||
|
this.data.MonthList.map((v, idx) => { |
||||
|
if (parseInt(v) === month) { |
||||
|
monthIdx = idx; |
||||
|
} |
||||
|
}); |
||||
|
|
||||
|
// 重新设置日期列表
|
||||
|
let DayList = []; |
||||
|
for (let i = 1; i <= this.getDays(year, month); i++) { |
||||
|
DayList.push(i); |
||||
|
} |
||||
|
|
||||
|
DayList.map((v, idx) => { |
||||
|
if (parseInt(v) === day) { |
||||
|
dayIdx = idx; |
||||
|
} |
||||
|
}); |
||||
|
if (type == "start") { |
||||
|
this.setData({ startDayList: DayList }); |
||||
|
} else if (type == "end") { |
||||
|
this.setData({ endDayList: DayList }); |
||||
|
} |
||||
|
|
||||
|
this.data.HourList.map((v, idx) => { |
||||
|
if (parseInt(v) === parseInt(hour)) { |
||||
|
hourIdx = idx; |
||||
|
} |
||||
|
}); |
||||
|
|
||||
|
this.data.MinuteList.map((v, idx) => { |
||||
|
if (parseInt(v) === parseInt(minute)) { |
||||
|
minuteIdx = idx; |
||||
|
} |
||||
|
}); |
||||
|
this.data.SecondList.map((v, idx) => { |
||||
|
if (parseInt(v) === parseInt(second)) { |
||||
|
secondIdx = idx; |
||||
|
} |
||||
|
}); |
||||
|
|
||||
|
return { |
||||
|
yearIdx, |
||||
|
monthIdx, |
||||
|
dayIdx, |
||||
|
hourIdx, |
||||
|
minuteIdx, |
||||
|
secondIdx |
||||
|
}; |
||||
|
}, |
||||
|
setStartDate: function (year, month, day, hour, minute, second) { |
||||
|
let pickerDateArr = this.setPickerDateArr( |
||||
|
"start", |
||||
|
year, |
||||
|
month, |
||||
|
day, |
||||
|
hour, |
||||
|
minute, |
||||
|
second |
||||
|
); |
||||
|
this.setData({ |
||||
|
startYearList: this.data.YearList, |
||||
|
startMonthList: this.data.MonthList, |
||||
|
// startDayList: this.data.DayList,
|
||||
|
startHourList: this.data.HourList, |
||||
|
startMinuteList: this.data.MinuteList, |
||||
|
startSecondList: this.data.SecondList, |
||||
|
startValue: [ |
||||
|
pickerDateArr.yearIdx, |
||||
|
pickerDateArr.monthIdx, |
||||
|
pickerDateArr.dayIdx, |
||||
|
pickerDateArr.hourIdx, |
||||
|
pickerDateArr.minuteIdx, |
||||
|
pickerDateArr.secondIdx |
||||
|
], |
||||
|
startPickTime: |
||||
|
this.data.YearList[pickerDateArr.yearIdx] + |
||||
|
"-" + |
||||
|
this.data.MonthList[pickerDateArr.monthIdx] + |
||||
|
"-" + |
||||
|
this.data.DayList[pickerDateArr.dayIdx] + |
||||
|
" " + |
||||
|
this.data.HourList[pickerDateArr.hourIdx] + |
||||
|
":" + |
||||
|
this.data.MinuteList[pickerDateArr.minuteIdx] + |
||||
|
":" + |
||||
|
this.data.SecondList[pickerDateArr.secondIdx] |
||||
|
}); |
||||
|
}, |
||||
|
setEndDate: function (year, month, day, hour, minute, second) { |
||||
|
let pickerDateArr = this.setPickerDateArr( |
||||
|
"end", |
||||
|
year, |
||||
|
month, |
||||
|
day, |
||||
|
hour, |
||||
|
minute, |
||||
|
second |
||||
|
); |
||||
|
|
||||
|
this.setData({ |
||||
|
endYearList: this.data.YearList, |
||||
|
endMonthList: this.data.MonthList, |
||||
|
// endDayList: this.data.DayList,
|
||||
|
endHourList: this.data.HourList, |
||||
|
endMinuteList: this.data.MinuteList, |
||||
|
endSecondList: this.data.SecondList, |
||||
|
endValue: [ |
||||
|
pickerDateArr.yearIdx, |
||||
|
pickerDateArr.monthIdx, |
||||
|
pickerDateArr.dayIdx, |
||||
|
pickerDateArr.hourIdx, |
||||
|
pickerDateArr.minuteIdx, |
||||
|
pickerDateArr.secondIdx |
||||
|
], |
||||
|
endPickTime: |
||||
|
this.data.YearList[pickerDateArr.yearIdx] + |
||||
|
"-" + |
||||
|
this.data.MonthList[pickerDateArr.monthIdx] + |
||||
|
"-" + |
||||
|
this.data.DayList[pickerDateArr.dayIdx] + |
||||
|
" " + |
||||
|
this.data.HourList[pickerDateArr.hourIdx] + |
||||
|
":" + |
||||
|
this.data.MinuteList[pickerDateArr.minuteIdx] + |
||||
|
":" + |
||||
|
this.data.SecondList[pickerDateArr.secondIdx] |
||||
|
}); |
||||
|
}, |
||||
|
} |
||||
|
}); |
||||
|
|
||||
|
|
||||
|
function formatTime(date) { |
||||
|
|
||||
|
if (typeof date == 'string' || 'number') { |
||||
|
try { |
||||
|
date = date.replace(/-/g, '/')//兼容ios
|
||||
|
} catch (error) { |
||||
|
} |
||||
|
date = new Date(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 { |
||||
|
str: [year, month, day].map(formatNumber).join('-') + ' ' + [hour, minute, second].map(formatNumber).join(':'), |
||||
|
arr: [year, month, day, hour, minute, second] |
||||
|
} |
||||
|
} |
||||
|
function formatNumber(n) { |
||||
|
n = n.toString() |
||||
|
return n[1] ? n : '0' + n |
||||
|
} |
@ -0,0 +1,3 @@ |
|||||
|
{ |
||||
|
"component": true |
||||
|
} |
@ -0,0 +1,75 @@ |
|||||
|
<!--components/timePicker/timePicker.wxml--> |
||||
|
<!-- 自定义时间筛选器 --> |
||||
|
<view hidden="{{!pickerShow}}"> |
||||
|
<view class="picker-container {{pickerShow?'show_picker':'hide_picker'}}" animation="{{animationData}}"> |
||||
|
<!-- 取消 --> |
||||
|
<view class="btn-box" catchtouchmove="onCatchTouchMove"> |
||||
|
<view class="pick_btn" bindtap="hideModal"> |
||||
|
<image src="../../images/approvalCenter/close.svg" class="img-32"></image> |
||||
|
</view> |
||||
|
<!-- <view class='pick_btn' style="color: #6068B2" bindtap="onConfirm">确定</view> --> |
||||
|
</view> |
||||
|
<view class="time-part"> |
||||
|
<view class="left"> |
||||
|
<!-- style="height: {{endDate?'120px':'250px'}};" --> |
||||
|
<picker-view class='sensorTypePicker' indicator-style='height: 35px;' bindchange="changeStartDateTime" |
||||
|
value="{{startValue}}" bindpickstart="handlePickStart" bindpickend="handlePickEnd"> |
||||
|
<picker-view-column style="min-width: 70px;flex-shrink: 0"> |
||||
|
<view class='picker-item' wx:for="{{startYearList}}" wx:key='*this'>{{item}}年</view> |
||||
|
</picker-view-column> |
||||
|
<picker-view-column> |
||||
|
<view class='picker-item' wx:for="{{startMonthList}}" wx:key='*this'>{{item}}月</view> |
||||
|
</picker-view-column> |
||||
|
<picker-view-column> |
||||
|
<view class='picker-item' wx:for="{{startDayList}}" wx:key='*this'>{{item}}日</view> |
||||
|
</picker-view-column> |
||||
|
<!-- <picker-view-column hidden="{{!hourColumn}}"> |
||||
|
<view class='picker-item' wx:for="{{startHourList}}" wx:key='*this'>{{item}}时</view> |
||||
|
</picker-view-column> |
||||
|
<picker-view-column hidden="{{!minColumn}}"> |
||||
|
<view class='picker-item' wx:for="{{startMinuteList}}" wx:key='*this'>{{item}}分</view> |
||||
|
</picker-view-column> |
||||
|
<picker-view-column hidden="{{!secColumn}}"> |
||||
|
<view class='picker-item' wx:for="{{startSecondList}}" wx:key='*this'>{{item}}秒</view> |
||||
|
</picker-view-column> --> |
||||
|
</picker-view> |
||||
|
</view> |
||||
|
<view class='to' style='margin-top: 4px;margin-bottom: 4px;'>至</view> |
||||
|
<view class="right"> |
||||
|
<view wx:if="{{endDate}}"> |
||||
|
<picker-view class='sensorTypePicker' indicator-style='height: 35px;' bindchange="changeEndDateTime" |
||||
|
bindpickstart="handlePickStart" bindpickend="handlePickEnd" value="{{endValue}}"> |
||||
|
<picker-view-column style="min-width: 70px;flex-shrink: 0"> |
||||
|
<view class='picker-item' wx:for="{{endYearList}}" wx:key='*this' style="min-width: 70px;">{{item}}年 |
||||
|
</view> |
||||
|
</picker-view-column> |
||||
|
<picker-view-column> |
||||
|
<view class='picker-item' wx:for="{{endMonthList}}" wx:key='*this'>{{item}}月</view> |
||||
|
</picker-view-column> |
||||
|
|
||||
|
|
||||
|
<picker-view-column> |
||||
|
<view class='picker-item' wx:for="{{endDayList}}" wx:key='*this'>{{item}}日</view> |
||||
|
</picker-view-column> |
||||
|
<!-- <picker-view-column hidden="{{!hourColumn}}" > |
||||
|
<view class='picker-item' wx:for="{{endHourList}}" wx:key='*this'>{{item}}时</view> |
||||
|
</picker-view-column> |
||||
|
<picker-view-column hidden="{{!minColumn}}"> |
||||
|
<view class='picker-item' wx:for="{{endMinuteList}}" wx:key='*this'>{{item}}分</view> |
||||
|
</picker-view-column> |
||||
|
<picker-view-column hidden="{{!secColumn}}"> |
||||
|
<view class='picker-item' wx:for="{{startSecondList}}" wx:key='*this'>{{item}}秒</view> |
||||
|
</picker-view-column> --> |
||||
|
</picker-view> |
||||
|
</view> |
||||
|
</view> |
||||
|
|
||||
|
</view> |
||||
|
<view class="btn-bottom"> |
||||
|
<button class="bottom-btn" bindtap="onConfirm">确定</button> |
||||
|
</view> |
||||
|
</view> |
||||
|
<!-- 遮罩 --> |
||||
|
<view class="sensorType-screen" bindtap="hideModal" catchtouchmove="onCatchTouchMove" |
||||
|
animation="{{animationOpacity}}" /> |
||||
|
</view> |
@ -0,0 +1,133 @@ |
|||||
|
/* components/timePicker/timePicker.wxss */ |
||||
|
|
||||
|
.picker-item { |
||||
|
line-height: 100rpx; |
||||
|
display: flex; |
||||
|
justify-content: center; |
||||
|
align-items: center; |
||||
|
} |
||||
|
|
||||
|
/* 自定义时间 */ |
||||
|
.picker-container { |
||||
|
display: flex; |
||||
|
flex-direction: column; |
||||
|
/* justify-content: center; */ |
||||
|
align-items: center; |
||||
|
|
||||
|
width: 100%; |
||||
|
overflow: hidden; |
||||
|
position: fixed; |
||||
|
bottom: -640rpx; |
||||
|
left: 0; |
||||
|
/* height: 0; */ |
||||
|
transition: height 0.5s; |
||||
|
z-index: 2000; |
||||
|
background: white; |
||||
|
border-top: 1px solid #EFEFF4; |
||||
|
} |
||||
|
|
||||
|
.time-part { |
||||
|
display: flex; |
||||
|
flex-direction: row; |
||||
|
justify-content: space-between; |
||||
|
align-items: center; |
||||
|
width: 100%; |
||||
|
padding: 10rpx; |
||||
|
} |
||||
|
|
||||
|
.sensorType-screen { |
||||
|
width: 100vw; |
||||
|
position: fixed; |
||||
|
top: 0; |
||||
|
right: 0; |
||||
|
bottom: 0; |
||||
|
left: 0; |
||||
|
background: #000; |
||||
|
opacity: 0; |
||||
|
overflow: hidden; |
||||
|
z-index: 1999; |
||||
|
color: #fff; |
||||
|
} |
||||
|
|
||||
|
.left { |
||||
|
width: 40%; |
||||
|
/* border: 1px solid red; */ |
||||
|
} |
||||
|
|
||||
|
.right { |
||||
|
width: 40%; |
||||
|
/* border: 1px solid red; */ |
||||
|
} |
||||
|
|
||||
|
.sensorTypePicker { |
||||
|
height: 250rpx; |
||||
|
margin: 0 auto; |
||||
|
} |
||||
|
|
||||
|
.picker-item { |
||||
|
line-height: 100rpx; |
||||
|
display: flex; |
||||
|
justify-content: center; |
||||
|
align-items: center; |
||||
|
font-size: 32rpx; |
||||
|
/* overflow: hidden; */ |
||||
|
} |
||||
|
|
||||
|
.box { |
||||
|
padding: 0 20rpx; |
||||
|
} |
||||
|
|
||||
|
/* 至 */ |
||||
|
.to { |
||||
|
width: 10%; |
||||
|
display: flex; |
||||
|
justify-content: center; |
||||
|
align-items: center; |
||||
|
font-size: 32rpx; |
||||
|
font-weight: 600; |
||||
|
color: #282828; |
||||
|
/* border: 1px solid #000; */ |
||||
|
} |
||||
|
|
||||
|
|
||||
|
.btn-box { |
||||
|
width: 100%; |
||||
|
display: flex; |
||||
|
justify-content: flex-end; |
||||
|
align-items: center; |
||||
|
border-bottom: 2rpx solid #eee; |
||||
|
} |
||||
|
|
||||
|
.pick_btn { |
||||
|
padding: 14rpx 30rpx; |
||||
|
color: #ccc; |
||||
|
/* background-color: #159; */ |
||||
|
} |
||||
|
|
||||
|
.show_picker { |
||||
|
height: 320px; |
||||
|
} |
||||
|
|
||||
|
.hide_picker { |
||||
|
height: 0; |
||||
|
} |
||||
|
|
||||
|
.img-32 { |
||||
|
width: 32rpx; |
||||
|
height: 32rpx; |
||||
|
} |
||||
|
|
||||
|
.bottom-btn { |
||||
|
width: 710rpx; |
||||
|
height: 90rpx; |
||||
|
background: #2F54FF; |
||||
|
border-radius: 54px; |
||||
|
line-height: 90rpx; |
||||
|
font-size: 32rpx; |
||||
|
font-weight: 600; |
||||
|
color: #FFFFFF; |
||||
|
} |
||||
|
|
||||
|
.btn-bottom { |
||||
|
margin: auto 20rpx 40rpx; |
||||
|
} |
After Width: | Height: | Size: 795 B |
After Width: | Height: | Size: 362 B |
@ -1,10 +1,6 @@ |
|||||
{ |
{ |
||||
"description": "项目私有配置文件。此文件中的内容将覆盖 project.config.json 中的相同字段。项目的改动优先同步到此文件中。详见文档:https://developers.weixin.qq.com/miniprogram/dev/devtools/projectconfig.html", |
"description": "项目私有配置文件。此文件中的内容将覆盖 project.config.json 中的相同字段。项目的改动优先同步到此文件中。详见文档:https://developers.weixin.qq.com/miniprogram/dev/devtools/projectconfig.html", |
||||
"projectname": "%E5%B7%A1%E6%A3%80%E5%B0%8F%E7%A8%8B%E5%BA%8F", |
|
||||
"setting": { |
"setting": { |
||||
"compileHotReLoad": false, |
|
||||
"urlCheck": false |
"urlCheck": false |
||||
}, |
} |
||||
"condition": {}, |
|
||||
"libVersion": "2.29.0" |
|
||||
} |
} |
Loading…
Reference in new issue