123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600 |
- ! function(e, t, i, n) {
- var a = 30,
- r = 90,
- s = 40,
- c = 10,
- l = e.rad2deg = function(e) {
- return e / (Math.PI / 180)
- },
- o = (e.deg2rad = function(e) {
- return e * (Math.PI / 180)
- }, navigator.platform.toLowerCase()),
- d = navigator.userAgent.toLowerCase(),
- u = (d.indexOf("iphone") > -1 || d.indexOf("ipad") > -1 || d.indexOf("ipod") > -1) && (o.indexOf("iphone") > -
- 1 || o.indexOf("ipad") > -1 || o.indexOf("ipod") > -1),
- p = e.Picker = function(e, t) {
- var i = this;
- i.holder = e, i.options = t || {}, i.init(), i.initInertiaParams(), i.calcElementItemPostion(!0), i
- .bindEvent()
- };
- p.prototype.findElementItems = function() {
- var e = this;
- return e.elementItems = [].slice.call(e.holder.querySelectorAll("li")), e.elementItems
- }, p.prototype.init = function() {
- var e = this;
- e.list = e.holder.querySelector("ul"), e.findElementItems(), e.height = e.holder.offsetHeight, e.r = e
- .height / 2 - c, e.d = 2 * e.r, e.itemHeight = e.elementItems.length > 0 ? e.elementItems[0]
- .offsetHeight : s, e.itemAngle = parseInt(e.calcAngle(.8 * e.itemHeight)), e.hightlightRange = e
- .itemAngle / 2, e.visibleRange = r, e.beginAngle = 0, e.beginExceed = e.beginAngle - a, e.list.angle = e
- .beginAngle, u && (e.list.style.webkitTransformOrigin = "center center " + e.r + "px")
- }, p.prototype.calcElementItemPostion = function(e) {
- var t = this;
- e && (t.items = []), t.elementItems.forEach(function(i) {
- var n = t.elementItems.indexOf(i);
- if (t.endAngle = t.itemAngle * n, i.angle = t.endAngle, i.style.webkitTransformOrigin =
- "center center -" + t.r + "px", i.style.webkitTransform = "translateZ(" + t.r +
- "px) rotateX(" + -t.endAngle + "deg)", e) {
- var a = {};
- a.text = i.innerHTML || "", a.value = i.getAttribute("data-value") || a.text, t.items.push(
- a)
- }
- }), t.endExceed = t.endAngle + a, t.calcElementItemVisibility(t.beginAngle)
- }, p.prototype.calcAngle = function(e) {
- var t = this,
- i = b = parseFloat(t.r);
- e = Math.abs(e);
- var n = 180 * parseInt(e / t.d);
- e %= t.d;
- var a = (i * i + b * b - e * e) / (2 * i * b),
- r = n + l(Math.acos(a));
- return r
- }, p.prototype.calcElementItemVisibility = function(e) {
- var t = this;
- t.elementItems.forEach(function(i) {
- var n = Math.abs(i.angle - e);
- n < t.hightlightRange ? i.classList.add("highlight") : n < t.visibleRange ? (i.classList.add(
- "visible"), i.classList.remove("highlight")) : (i.classList.remove("highlight"), i
- .classList.remove("visible"))
- })
- }, p.prototype.setAngle = function(e) {
- var t = this;
- t.list.angle = e, t.list.style.webkitTransform = "perspective(1000px) rotateY(0deg) rotateX(" + e + "deg)",
- t.calcElementItemVisibility(e)
- }, p.prototype.bindEvent = function() {
- var t = this,
- i = 0,
- n = null,
- a = !1;
- t.holder.addEventListener(e.EVENT_START, function(e) {
- a = !0, e.preventDefault(), t.list.style.webkitTransition = "", n = (e.changedTouches ? e
- .changedTouches[0] : e).pageY, i = t.list.angle, t.updateInertiaParams(e, !0)
- }, !1), t.holder.addEventListener(e.EVENT_END, function(e) {
- a = !1, e.preventDefault(), t.startInertiaScroll(e)
- }, !1), t.holder.addEventListener(e.EVENT_CANCEL, function(e) {
- a = !1, e.preventDefault(), t.startInertiaScroll(e)
- }, !1), t.holder.addEventListener(e.EVENT_MOVE, function(e) {
- if (a) {
- e.preventDefault();
- var r = (e.changedTouches ? e.changedTouches[0] : e).pageY,
- s = r - n,
- c = t.calcAngle(s),
- l = s > 0 ? i - c : i + c;
- l > t.endExceed && (l = t.endExceed), l < t.beginExceed && (l = t.beginExceed), t.setAngle(
- l), t.updateInertiaParams(e)
- }
- }, !1), t.list.addEventListener("tap", function(e) {
- elementItem = e.target, "LI" == elementItem.tagName && t.setSelectedIndex(t.elementItems
- .indexOf(elementItem), 200)
- }, !1)
- }, p.prototype.initInertiaParams = function() {
- var e = this;
- e.lastMoveTime = 0, e.lastMoveStart = 0, e.stopInertiaMove = !1
- }, p.prototype.updateInertiaParams = function(e, t) {
- var i = this,
- n = e.changedTouches ? e.changedTouches[0] : e;
- if (t) i.lastMoveStart = n.pageY, i.lastMoveTime = e.timeStamp || Date.now(), i.startAngle = i.list.angle;
- else {
- var a = e.timeStamp || Date.now();
- a - i.lastMoveTime > 300 && (i.lastMoveTime = a, i.lastMoveStart = n.pageY)
- }
- i.stopInertiaMove = !0
- }, p.prototype.startInertiaScroll = function(e) {
- var t = this,
- i = e.changedTouches ? e.changedTouches[0] : e,
- n = e.timeStamp || Date.now(),
- a = (i.pageY - t.lastMoveStart) / (n - t.lastMoveTime),
- r = a > 0 ? -1 : 1,
- s = 6e-4 * r * -1,
- c = Math.abs(a / s),
- l = a * c / 2,
- o = t.list.angle,
- d = t.calcAngle(l) * r,
- u = d;
- return o + d < t.beginExceed && (d = t.beginExceed - o, c = c * (d / u) * .6), o + d > t.endExceed && (d = t
- .endExceed - o, c = c * (d / u) * .6), 0 == d ? void t.endScroll() : void t.scrollDistAngle(n, o, d,
- c)
- }, p.prototype.scrollDistAngle = function(e, t, i, n) {
- var a = this;
- a.stopInertiaMove = !1,
- function(e, t, i, n) {
- var r = 13,
- s = n / r,
- c = 0;
- ! function l() {
- if (!a.stopInertiaMove) {
- var e = a.quartEaseOut(c, t, i, s);
- return a.setAngle(e), c++, c > s - 1 || e < a.beginExceed || e > a.endExceed ? void a
- .endScroll() : void setTimeout(l, r)
- }
- }()
- }(e, t, i, n)
- }, p.prototype.quartEaseOut = function(e, t, i, n) {
- return -i * ((e = e / n - 1) * e * e * e - 1) + t
- }, p.prototype.endScroll = function() {
- var e = this;
- if (e.list.angle < e.beginAngle) e.list.style.webkitTransition = "150ms ease-out", e.setAngle(e.beginAngle);
- else if (e.list.angle > e.endAngle) e.list.style.webkitTransition = "150ms ease-out", e.setAngle(e
- .endAngle);
- else {
- var t = parseInt((e.list.angle / e.itemAngle).toFixed(0));
- e.list.style.webkitTransition = "100ms ease-out", e.setAngle(e.itemAngle * t)
- }
- e.triggerChange()
- }, p.prototype.triggerChange = function(t) {
- var i = this;
- setTimeout(function() {
- var n = i.getSelectedIndex(),
- a = i.items[n];
- !e.trigger || n == i.lastIndex && t !== !0 || e.trigger(i.holder, "change", {
- index: n,
- item: a
- }), i.lastIndex = n, "function" == typeof t && t()
- }, 0)
- }, p.prototype.correctAngle = function(e) {
- var t = this;
- return e < t.beginAngle ? t.beginAngle : e > t.endAngle ? t.endAngle : e
- }, p.prototype.setItems = function(e) {
- var t = this;
- t.items = e || [];
- var i = [];
- t.items.forEach(function(e) {
- null !== e && e !== n && i.push("<li>" + (e.text || e) + "</li>")
- }), t.list.innerHTML = i.join(""), t.findElementItems(), t.calcElementItemPostion(), t.setAngle(t
- .correctAngle(t.list.angle)), t.triggerChange(!0)
- }, p.prototype.getItems = function() {
- var e = this;
- return e.items
- }, p.prototype.getSelectedIndex = function() {
- var e = this;
- return parseInt((e.list.angle / e.itemAngle).toFixed(0))
- }, p.prototype.setSelectedIndex = function(e, t, i) {
- var n = this;
- n.list.style.webkitTransition = "";
- var a = n.correctAngle(n.itemAngle * e);
- if (t && t > 0) {
- var r = a - n.list.angle;
- n.scrollDistAngle(Date.now(), n.list.angle, r, t)
- } else n.setAngle(a);
- n.triggerChange(i)
- }, p.prototype.getSelectedItem = function() {
- var e = this;
- return e.items[e.getSelectedIndex()]
- }, p.prototype.getSelectedValue = function() {
- var e = this;
- return (e.items[e.getSelectedIndex()] || {}).value
- }, p.prototype.getSelectedText = function() {
- var e = this;
- return (e.items[e.getSelectedIndex()] || {}).text
- }, p.prototype.setSelectedValue = function(e, t, i) {
- var n = this;
- for (var a in n.items) {
- var r = n.items[a];
- if (r.value == e) return void n.setSelectedIndex(a, t, i)
- }
- }, e.fn && (e.fn.picker = function(e) {
- return this.each(function(t, i) {
- if (!i.picker)
- if (e) i.picker = new p(i, e);
- else {
- var n = i.getAttribute("data-picker-options"),
- a = n ? JSON.parse(n) : {};
- i.picker = new p(i, a)
- }
- }), this[0] ? this[0].picker : null
- }, e.ready(function() {
- e(".mui-picker").picker()
- }))
- }(window.mui || window, window, document, void 0),
- function(e, t) {
- e.dom = function(i) {
- return "string" != typeof i ? i instanceof Array || i[0] && i.length ? [].slice.call(i) : [i] : (e
- .__create_dom_div__ || (e.__create_dom_div__ = t.createElement("div")), e.__create_dom_div__
- .innerHTML = i, [].slice.call(e.__create_dom_div__.childNodes))
- };
- var i =
- '<div class="mui-poppicker"> <div class="mui-poppicker-header"> <button class="mui-btn mui-poppicker-btn-cancel">取消</button> <button class="mui-btn mui-btn-blue mui-poppicker-btn-ok">确定</button> <div class="mui-poppicker-clear"></div> </div> <div class="mui-poppicker-body"> </div> </div>',
- n =
- '<div class="mui-picker"> <div class="mui-picker-inner"> <div class="mui-pciker-rule mui-pciker-rule-ft"></div> <ul class="mui-pciker-list"> </ul> <div class="mui-pciker-rule mui-pciker-rule-bg"></div> </div> </div>';
- e.PopPicker = e.Class.extend({
- init: function(n) {
- var a = this;
- a.options = n || {}, a.options.buttons = a.options.buttons || ["取消", "确定"], a.panel = e.dom(i)[
- 0], t.body.appendChild(a.panel), a.ok = a.panel.querySelector(".mui-poppicker-btn-ok"),
- a.cancel = a.panel.querySelector(".mui-poppicker-btn-cancel"), a.body = a.panel
- .querySelector(".mui-poppicker-body"), a.mask = e.createMask(), a.cancel.innerText = a
- .options.buttons[0], a.ok.innerText = a.options.buttons[1], a.cancel.addEventListener("tap",
- function(e) {
- a.hide()
- }, !1), a.ok.addEventListener("tap", function(e) {
- if (a.callback) {
- var t = a.callback(a.getSelectedItems());
- t !== !1 && a.hide()
- }
- }, !1), a.mask[0].addEventListener("tap", function() {
- a.hide()
- }, !1), a._createPicker(), a.panel.addEventListener(e.EVENT_START, function(e) {
- e.preventDefault()
- }, !1), a.panel.addEventListener(e.EVENT_MOVE, function(e) {
- e.preventDefault()
- }, !1)
- },
- _createPicker: function() {
- var t = this,
- i = t.options.layer || 1,
- a = 100 / i + "%";
- t.pickers = [];
- for (var r = 1; i >= r; r++) {
- var s = e.dom(n)[0];
- s.style.width = a, t.body.appendChild(s);
- var c = e(s).picker();
- t.pickers.push(c), s.addEventListener("change", function(e) {
- var t = this.nextSibling;
- if (t && t.picker) {
- var i = e.detail || {},
- n = i.item || {};
- t.picker.setItems(n.children)
- }
- }, !1)
- }
- },
- setData: function(e) {
- var t = this;
- e = e || [], t.pickers[0].setItems(e)
- },
- getSelectedItems: function() {
- var e = this,
- t = [];
- for (var i in e.pickers) {
- var n = e.pickers[i];
- t.push(n.getSelectedItem() || {})
- }
- return t
- },
- show: function(i) {
- var n = this;
- n.callback = i, n.mask.show(), t.body.classList.add(e.className("poppicker-active-for-page")), n
- .panel.classList.add(e.className("active")), n.__back = e.back, e.back = function() {
- n.hide()
- }
- },
- hide: function() {
- var i = this;
- i.disposed || (i.panel.classList.remove(e.className("active")), i.mask.close(), t.body.classList
- .remove(e.className("poppicker-active-for-page")), e.back = i.__back)
- },
- dispose: function() {
- var e = this;
- e.hide(), setTimeout(function() {
- e.panel.parentNode.removeChild(e.panel);
- for (var t in e) e[t] = null, delete e[t];
- e.disposed = !0
- }, 300)
- }
- })
- }(mui, document),
- function(e, t) {
- e.dom = function(i) {
- return "string" != typeof i ? i instanceof Array || i[0] && i.length ? [].slice.call(i) : [i] : (e
- .__create_dom_div__ || (e.__create_dom_div__ = t.createElement("div")), e.__create_dom_div__
- .innerHTML = i, [].slice.call(e.__create_dom_div__.childNodes))
- };
- var i =
- '<div class="mui-dtpicker" data-type="datetime"> <div class="mui-dtpicker-header"> <button data-id="btn-cancel" class="mui-btn">取消</button> <button data-id="btn-ok" class="mui-btn mui-btn-blue">确定</button> </div> <div class="mui-dtpicker-title"><h5 data-id="title-y" style="width: 100%;">年</h5><h5 data-id="title-d">日</h5><h5 data-id="title-h">时</h5><h5 data-id="title-i">分</h5></div> <div class="mui-dtpicker-body"> <div data-id="picker-y" class="mui-picker" style="width: 100%!important;"> <div class="mui-picker-inner"> <div class="mui-pciker-rule mui-pciker-rule-ft"></div> <ul class="mui-pciker-list"> </ul> <div class="mui-pciker-rule mui-pciker-rule-bg"></div> </div> </div> <div data-id="picker-m" class="mui-picker" style="display: none;"> <div class="mui-picker-inner"> <div class="mui-pciker-rule mui-pciker-rule-ft"></div> <ul class="mui-pciker-list"> </ul> <div class="mui-pciker-rule mui-pciker-rule-bg"></div> </div> </div> <div data-id="picker-d" class="mui-picker"> <div class="mui-picker-inner"> <div class="mui-pciker-rule mui-pciker-rule-ft"></div> <ul class="mui-pciker-list"> </ul> <div class="mui-pciker-rule mui-pciker-rule-bg"></div> </div> </div> <div data-id="picker-h" class="mui-picker"> <div class="mui-picker-inner"> <div class="mui-pciker-rule mui-pciker-rule-ft"></div> <ul class="mui-pciker-list"> </ul> <div class="mui-pciker-rule mui-pciker-rule-bg"></div> </div> </div> <div data-id="picker-i" class="mui-picker"> <div class="mui-picker-inner"> <div class="mui-pciker-rule mui-pciker-rule-ft"></div> <ul class="mui-pciker-list"> </ul> <div class="mui-pciker-rule mui-pciker-rule-bg"></div> </div> </div> </div> </div>';
- e.DtPicker = e.Class.extend({
- init: function(n) {
- var a = this,
- r = e.dom(i)[0];
- t.body.appendChild(r), e('[data-id*="picker"]', r).picker();
- var s = a.ui = {
- picker: r,
- mask: e.createMask(),
- ok: e('[data-id="btn-ok"]', r)[0],
- cancel: e('[data-id="btn-cancel"]', r)[0],
- y: e('[data-id="picker-y"]', r)[0],
- m: e('[data-id="picker-m"]', r)[0],
- d: e('[data-id="picker-d"]', r)[0],
- h: e('[data-id="picker-h"]', r)[0],
- i: e('[data-id="picker-i"]', r)[0],
- labels: e('[data-id*="title-"]', r)
- };
- s.cancel.addEventListener("tap", function() {
- a.hide()
- }, !1), s.ok.addEventListener("tap", function() {
- var e = a.callback(a.getSelected());
- e !== !1 && a.hide()
- }, !1), s.y.addEventListener("change", function(e) {
- a.options.beginMonth || a.options.endMonth ? a._createMonth() : a._createDay()
- }, !1), s.m.addEventListener("change", function(e) {
- a._createDay()
- }, !1), s.d.addEventListener("change", function(e) {
- (a.options.beginMonth || a.options.endMonth) && a._createHours()
- }, !1), s.h.addEventListener("change", function(e) {
- (a.options.beginMonth || a.options.endMonth) && a._createMinutes()
- }, !1), s.mask[0].addEventListener("tap", function() {
- a.hide()
- }, !1), a._create(n), a.ui.picker.addEventListener(e.EVENT_START, function(e) {
- e.preventDefault()
- }, !1), a.ui.picker.addEventListener(e.EVENT_MOVE, function(e) {
- e.preventDefault()
- }, !1)
- },
- getSelected: function() {
- var e = this,
- t = e.ui,
- i = e.options.type,
- n = {
- type: i,
- y: t.y.picker.getSelectedItem(),
- m: t.m.picker.getSelectedItem(),
- d: t.d.picker.getSelectedItem(),
- h: t.h.picker.getSelectedItem(),
- i: t.i.picker.getSelectedItem(),
- toString: function() {
- return this.value
- }
- };
- switch (i) {
- case "datetime":
- n.value = n.y.value + "-" + n.m.value + "-" + n.d.value + " " + n.h.value + ":" + n.i
- .value, n.text = n.y.text + "-" + n.m.text + "-" + n.d.text + " " + n.h.text + ":" +
- n.i.text;
- break;
- case "date":
- n.value = n.y.value + "-" + n.m.value + "-" + n.d.value, n.text = n.y.text + "-" + n.m
- .text + "-" + n.d.text;
- break;
- case "time":
- n.value = n.h.value + ":" + n.i.value, n.text = n.h.text + ":" + n.i.text;
- break;
- case "month":
- n.value = n.y.value;
- break;
- case "hour":
- n.value = n.y.value + "-" + n.m.value + "-" + n.d.value + " " + n.h.value, n.text = n.y
- .text + "-" + n.m.text + "-" + n.d.text + " " + n.h.text
- }
- return n
- },
- setSelectedValue: function(e) {
- var t = this,
- i = t.ui,
- n = t._parseValue(e);
- i.y.picker.setSelectedValue(n.y, 0, function() {
- i.m.picker.setSelectedValue(n.m, 0, function() {
- i.d.picker.setSelectedValue(n.d, 0, function() {
- i.h.picker.setSelectedValue(n.h, 0, function() {
- i.i.picker.setSelectedValue(n.i, 0)
- })
- })
- })
- })
- },
- isLeapYear: function(e) {
- return e % 4 == 0 && e % 100 != 0 || e % 400 == 0
- },
- _inArray: function(e, t) {
- for (var i in e) {
- var n = e[i];
- if (n === t) return !0
- }
- return !1
- },
- getDayNum: function(e, t) {
- var i = this;
- return i._inArray([1, 3, 5, 7, 8, 10, 12], t) ? 31 : i._inArray([4, 6, 9, 11], t) ? 30 : i
- .isLeapYear(e) ? 29 : 28
- },
- _fill: function(e) {
- return e = e.toString(), e.length < 2 && (e = 0 + e), e
- },
- _isBeginYear: function() {
- return this.options.beginYear === parseInt(this.ui.y.picker.getSelectedValue())
- },
- _isBeginMonth: function() {
- return this.options.beginMonth && this._isBeginYear() && this.options.beginMonth === parseInt(
- this.ui.m.picker.getSelectedValue())
- },
- _isBeginDay: function() {
- return this._isBeginMonth() && this.options.beginDay === parseInt(this.ui.d.picker
- .getSelectedValue())
- },
- _isBeginHours: function() {
- return this._isBeginDay() && this.options.beginHours === parseInt(this.ui.h.picker
- .getSelectedValue())
- },
- _isEndYear: function() {
- return this.options.endYear === parseInt(this.ui.y.picker.getSelectedValue())
- },
- _isEndMonth: function() {
- return this.options.endMonth && this._isEndYear() && this.options.endMonth === parseInt(this.ui
- .m.picker.getSelectedValue())
- },
- _isEndDay: function() {
- return this._isEndMonth() && this.options.endDay === parseInt(this.ui.d.picker
- .getSelectedValue())
- },
- _isEndHours: function() {
- return this._isEndDay() && this.options.endHours === parseInt(this.ui.h.picker
- .getSelectedValue())
- },
- _createYear: function(e) {
- var t = this,
- i = t.options,
- n = t.ui,
- a = [];
- if (i.customData.y) a = i.customData.y;
- else
- for (var r = i.beginYear, s = i.endYear, c = r; s >= c; c++) a.push({
- text: c + "",
- value: c
- });
- n.y.picker.setItems(a)
- },
- _createMonth: function(e) {
- var t = this,
- i = t.options,
- n = t.ui,
- a = [];
- if (i.customData.m) a = i.customData.m;
- else
- for (var r = i.beginMonth && t._isBeginYear() ? i.beginMonth : 1, s = i.endMonth && t
- ._isEndYear() ? i.endMonth : 12; s >= r; r++) {
- var c = t._fill(r);
- a.push({
- text: c,
- value: c
- })
- }
- n.m.picker.setItems(a)
- },
- _createDay: function(e) {
- var t = this,
- i = t.options,
- n = t.ui,
- a = [];
- if (i.customData.d) a = i.customData.d;
- else
- for (var r = t._isBeginMonth() ? i.beginDay : 1, s = t._isEndMonth() ? i.endDay : t
- .getDayNum(parseInt(this.ui.y.picker.getSelectedValue()), parseInt(this.ui.m.picker
- .getSelectedValue())); s >= r; r++) {
- var c = t._fill(r);
- a.push({
- text: c,
- value: c
- })
- }
- n.d.picker.setItems(a), e = e || n.d.picker.getSelectedValue()
- },
- _createHours: function(e) {
- var t = this,
- i = t.options,
- n = t.ui,
- a = [];
- if (i.customData.h) a = i.customData.h;
- else
- for (var r = t._isBeginDay() ? i.beginHours : 0, s = t._isEndDay() ? i.endHours : 23; s >=
- r; r++) {
- var c = t._fill(r);
- a.push({
- text: c,
- value: c
- })
- }
- n.h.picker.setItems(a)
- },
- _createMinutes: function(e) {
- var t = this,
- i = t.options,
- n = t.ui,
- a = [];
- if (i.customData.i) a = i.customData.i;
- else
- for (var r = t._isBeginHours() ? i.beginMinutes : 0, s = t._isEndHours() ? i.endMinutes :
- 59; s >= r; r++) {
- var c = t._fill(r);
- a.push({
- text: c,
- value: c
- })
- }
- n.i.picker.setItems(a)
- },
- _setLabels: function() {
- var e = this,
- t = e.options,
- i = e.ui;
- i.labels.each(function(e, i) {
- i.innerText = t.labels[e]
- })
- },
- _setButtons: function() {
- var e = this,
- t = e.options,
- i = e.ui;
- i.cancel.innerText = t.buttons[0], i.ok.innerText = t.buttons[1]
- },
- _parseValue: function(e) {
- var t = {};
- if (e) {
- var i = e.replace(":", "-").replace(" ", "-").split("-");
- t.y = i[0], t.m = i[1], t.d = i[2], t.h = i[3], t.i = i[4]
- } else {
- var n = new Date;
- t.y = n.getFullYear(), t.m = n.getMonth() + 1, t.d = n.getDate(), t.h = n.getHours(), t.i =
- n.getMinutes()
- }
- return t
- },
- _create: function(e) {
- var t = this;
- e = e || {}, e.labels = e.labels || ["年", "月", "日", "时", "分"], e.buttons = e.buttons || ["取消",
- "确定"
- ], e.type = e.type || "datetime", e.customData = e.customData || {}, t.options = e;
- var i = new Date,
- n = e.beginDate;
- n instanceof Date && !isNaN(n.valueOf()) && (e.beginYear = n.getFullYear(), e.beginMonth = n
- .getMonth() + 1, e.beginDay = n.getDate(), e.beginHours = n.getHours(), e.beginMinutes =
- n.getMinutes());
- var a = e.endDate;
- a instanceof Date && !isNaN(a.valueOf()) && (e.endYear = a.getFullYear(), e.endMonth = a
- .getMonth() + 1, e.endDay = a.getDate(), e.endHours = a.getHours(), e.endMinutes = a
- .getMinutes()), e.beginYear = e.beginYear || i.getFullYear() - 5, e.endYear = e
- .endYear || i.getFullYear() + 5;
- var r = t.ui;
- t._setLabels(), t._setButtons(), r.picker.setAttribute("data-type", e.type), t._createYear(), t
- ._createMonth(), t._createDay(), t._createHours(), t._createMinutes(), t.setSelectedValue(e
- .value)
- },
- show: function(i) {
- var n = this,
- a = n.ui;
- n.callback = i || e.noop, a.mask.show(), t.body.classList.add(e.className(
- "dtpicker-active-for-page")), a.picker.classList.add(e.className("active")), n.__back =
- e.back, e.back = function() {
- n.hide()
- }
- },
- hide: function() {
- var i = this;
- if (!i.disposed) {
- var n = i.ui;
- n.picker.classList.remove(e.className("active")), n.mask.close(), t.body.classList.remove(e
- .className("dtpicker-active-for-page")), e.back = i.__back
- }
- },
- dispose: function() {
- var e = this;
- e.hide(), setTimeout(function() {
- e.ui.picker.parentNode.removeChild(e.ui.picker);
- for (var t in e) e[t] = null, delete e[t];
- e.disposed = !0
- }, 300)
- }
- })
- }(mui, document);
|