jquery-weui.js 109 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153
  1. /**
  2. * jQuery WeUI V0.6.0
  3. * By 言川
  4. * http://lihongxun945.github.io/jquery-weui/
  5. */
  6. /* global $:true */
  7. /* global WebKitCSSMatrix:true */
  8. (function($) {
  9. "use strict";
  10. $.fn.transitionEnd = function(callback) {
  11. var events = ['webkitTransitionEnd', 'transitionend', 'oTransitionEnd', 'MSTransitionEnd', 'msTransitionEnd'],
  12. i, dom = this;
  13. function fireCallBack(e) {
  14. /*jshint validthis:true */
  15. if (e.target !== this) return;
  16. callback.call(this, e);
  17. for (i = 0; i < events.length; i++) {
  18. dom.off(events[i], fireCallBack);
  19. }
  20. }
  21. if (callback) {
  22. for (i = 0; i < events.length; i++) {
  23. dom.on(events[i], fireCallBack);
  24. }
  25. }
  26. return this;
  27. };
  28. $.support = (function() {
  29. var support = {
  30. touch: !!(('ontouchstart' in window) || window.DocumentTouch && document instanceof window.DocumentTouch)
  31. };
  32. return support;
  33. })();
  34. $.touchEvents = {
  35. start: $.support.touch ? 'touchstart' : 'mousedown',
  36. move: $.support.touch ? 'touchmove' : 'mousemove',
  37. end: $.support.touch ? 'touchend' : 'mouseup'
  38. };
  39. $.getTouchPosition = function(e) {
  40. e = e.originalEvent || e; //jquery wrap the originevent
  41. if(e.type === 'touchstart' || e.type === 'touchmove' || e.type === 'touchend') {
  42. return {
  43. x: e.targetTouches[0].pageX,
  44. y: e.targetTouches[0].pageY
  45. };
  46. } else {
  47. return {
  48. x: e.pageX,
  49. y: e.pageY
  50. };
  51. }
  52. };
  53. $.fn.scrollHeight = function() {
  54. return this[0].scrollHeight;
  55. };
  56. $.fn.transform = function(transform) {
  57. for (var i = 0; i < this.length; i++) {
  58. var elStyle = this[i].style;
  59. elStyle.webkitTransform = elStyle.MsTransform = elStyle.msTransform = elStyle.MozTransform = elStyle.OTransform = elStyle.transform = transform;
  60. }
  61. return this;
  62. };
  63. $.fn.transition = function(duration) {
  64. if (typeof duration !== 'string') {
  65. duration = duration + 'ms';
  66. }
  67. for (var i = 0; i < this.length; i++) {
  68. var elStyle = this[i].style;
  69. elStyle.webkitTransitionDuration = elStyle.MsTransitionDuration = elStyle.msTransitionDuration = elStyle.MozTransitionDuration = elStyle.OTransitionDuration = elStyle.transitionDuration = duration;
  70. }
  71. return this;
  72. };
  73. $.getTranslate = function (el, axis) {
  74. var matrix, curTransform, curStyle, transformMatrix;
  75. // automatic axis detection
  76. if (typeof axis === 'undefined') {
  77. axis = 'x';
  78. }
  79. curStyle = window.getComputedStyle(el, null);
  80. if (window.WebKitCSSMatrix) {
  81. // Some old versions of Webkit choke when 'none' is passed; pass
  82. // empty string instead in this case
  83. transformMatrix = new WebKitCSSMatrix(curStyle.webkitTransform === 'none' ? '' : curStyle.webkitTransform);
  84. }
  85. else {
  86. transformMatrix = curStyle.MozTransform || curStyle.OTransform || curStyle.MsTransform || curStyle.msTransform || curStyle.transform || curStyle.getPropertyValue('transform').replace('translate(', 'matrix(1, 0, 0, 1,');
  87. matrix = transformMatrix.toString().split(',');
  88. }
  89. if (axis === 'x') {
  90. //Latest Chrome and webkits Fix
  91. if (window.WebKitCSSMatrix)
  92. curTransform = transformMatrix.m41;
  93. //Crazy IE10 Matrix
  94. else if (matrix.length === 16)
  95. curTransform = parseFloat(matrix[12]);
  96. //Normal Browsers
  97. else
  98. curTransform = parseFloat(matrix[4]);
  99. }
  100. if (axis === 'y') {
  101. //Latest Chrome and webkits Fix
  102. if (window.WebKitCSSMatrix)
  103. curTransform = transformMatrix.m42;
  104. //Crazy IE10 Matrix
  105. else if (matrix.length === 16)
  106. curTransform = parseFloat(matrix[13]);
  107. //Normal Browsers
  108. else
  109. curTransform = parseFloat(matrix[5]);
  110. }
  111. return curTransform || 0;
  112. };
  113. $.requestAnimationFrame = function (callback) {
  114. if (window.requestAnimationFrame) return window.requestAnimationFrame(callback);
  115. else if (window.webkitRequestAnimationFrame) return window.webkitRequestAnimationFrame(callback);
  116. else if (window.mozRequestAnimationFrame) return window.mozRequestAnimationFrame(callback);
  117. else {
  118. return window.setTimeout(callback, 1000 / 60);
  119. }
  120. };
  121. $.cancelAnimationFrame = function (id) {
  122. if (window.cancelAnimationFrame) return window.cancelAnimationFrame(id);
  123. else if (window.webkitCancelAnimationFrame) return window.webkitCancelAnimationFrame(id);
  124. else if (window.mozCancelAnimationFrame) return window.mozCancelAnimationFrame(id);
  125. else {
  126. return window.clearTimeout(id);
  127. }
  128. };
  129. $.fn.join = function(arg) {
  130. return this.toArray().join(arg);
  131. }
  132. })($);
  133. /*===========================
  134. Template7 Template engine
  135. ===========================*/
  136. /* global $:true */
  137. /* jshint unused:false */
  138. /* jshint forin:false */
  139. +function ($) {
  140. "use strict";
  141. $.Template7 = $.t7 = (function () {
  142. function isArray(arr) {
  143. return Object.prototype.toString.apply(arr) === '[object Array]';
  144. }
  145. function isObject(obj) {
  146. return obj instanceof Object;
  147. }
  148. function isFunction(func) {
  149. return typeof func === 'function';
  150. }
  151. var cache = {};
  152. function helperToSlices(string) {
  153. var helperParts = string.replace(/[{}#}]/g, '').split(' ');
  154. var slices = [];
  155. var shiftIndex, i, j;
  156. for (i = 0; i < helperParts.length; i++) {
  157. var part = helperParts[i];
  158. if (i === 0) slices.push(part);
  159. else {
  160. if (part.indexOf('"') === 0) {
  161. // Plain String
  162. if (part.match(/"/g).length === 2) {
  163. // One word string
  164. slices.push(part);
  165. }
  166. else {
  167. // Find closed Index
  168. shiftIndex = 0;
  169. for (j = i + 1; j < helperParts.length; j++) {
  170. part += ' ' + helperParts[j];
  171. if (helperParts[j].indexOf('"') >= 0) {
  172. shiftIndex = j;
  173. slices.push(part);
  174. break;
  175. }
  176. }
  177. if (shiftIndex) i = shiftIndex;
  178. }
  179. }
  180. else {
  181. if (part.indexOf('=') > 0) {
  182. // Hash
  183. var hashParts = part.split('=');
  184. var hashName = hashParts[0];
  185. var hashContent = hashParts[1];
  186. if (hashContent.match(/"/g).length !== 2) {
  187. shiftIndex = 0;
  188. for (j = i + 1; j < helperParts.length; j++) {
  189. hashContent += ' ' + helperParts[j];
  190. if (helperParts[j].indexOf('"') >= 0) {
  191. shiftIndex = j;
  192. break;
  193. }
  194. }
  195. if (shiftIndex) i = shiftIndex;
  196. }
  197. var hash = [hashName, hashContent.replace(/"/g,'')];
  198. slices.push(hash);
  199. }
  200. else {
  201. // Plain variable
  202. slices.push(part);
  203. }
  204. }
  205. }
  206. }
  207. return slices;
  208. }
  209. function stringToBlocks(string) {
  210. var blocks = [], i, j, k;
  211. if (!string) return [];
  212. var _blocks = string.split(/({{[^{^}]*}})/);
  213. for (i = 0; i < _blocks.length; i++) {
  214. var block = _blocks[i];
  215. if (block === '') continue;
  216. if (block.indexOf('{{') < 0) {
  217. blocks.push({
  218. type: 'plain',
  219. content: block
  220. });
  221. }
  222. else {
  223. if (block.indexOf('{/') >= 0) {
  224. continue;
  225. }
  226. if (block.indexOf('{#') < 0 && block.indexOf(' ') < 0 && block.indexOf('else') < 0) {
  227. // Simple variable
  228. blocks.push({
  229. type: 'variable',
  230. contextName: block.replace(/[{}]/g, '')
  231. });
  232. continue;
  233. }
  234. // Helpers
  235. var helperSlices = helperToSlices(block);
  236. var helperName = helperSlices[0];
  237. var helperContext = [];
  238. var helperHash = {};
  239. for (j = 1; j < helperSlices.length; j++) {
  240. var slice = helperSlices[j];
  241. if (isArray(slice)) {
  242. // Hash
  243. helperHash[slice[0]] = slice[1] === 'false' ? false : slice[1];
  244. }
  245. else {
  246. helperContext.push(slice);
  247. }
  248. }
  249. if (block.indexOf('{#') >= 0) {
  250. // Condition/Helper
  251. var helperStartIndex = i;
  252. var helperContent = '';
  253. var elseContent = '';
  254. var toSkip = 0;
  255. var shiftIndex;
  256. var foundClosed = false, foundElse = false, foundClosedElse = false, depth = 0;
  257. for (j = i + 1; j < _blocks.length; j++) {
  258. if (_blocks[j].indexOf('{{#') >= 0) {
  259. depth ++;
  260. }
  261. if (_blocks[j].indexOf('{{/') >= 0) {
  262. depth --;
  263. }
  264. if (_blocks[j].indexOf('{{#' + helperName) >= 0) {
  265. helperContent += _blocks[j];
  266. if (foundElse) elseContent += _blocks[j];
  267. toSkip ++;
  268. }
  269. else if (_blocks[j].indexOf('{{/' + helperName) >= 0) {
  270. if (toSkip > 0) {
  271. toSkip--;
  272. helperContent += _blocks[j];
  273. if (foundElse) elseContent += _blocks[j];
  274. }
  275. else {
  276. shiftIndex = j;
  277. foundClosed = true;
  278. break;
  279. }
  280. }
  281. else if (_blocks[j].indexOf('else') >= 0 && depth === 0) {
  282. foundElse = true;
  283. }
  284. else {
  285. if (!foundElse) helperContent += _blocks[j];
  286. if (foundElse) elseContent += _blocks[j];
  287. }
  288. }
  289. if (foundClosed) {
  290. if (shiftIndex) i = shiftIndex;
  291. blocks.push({
  292. type: 'helper',
  293. helperName: helperName,
  294. contextName: helperContext,
  295. content: helperContent,
  296. inverseContent: elseContent,
  297. hash: helperHash
  298. });
  299. }
  300. }
  301. else if (block.indexOf(' ') > 0) {
  302. blocks.push({
  303. type: 'helper',
  304. helperName: helperName,
  305. contextName: helperContext,
  306. hash: helperHash
  307. });
  308. }
  309. }
  310. }
  311. return blocks;
  312. }
  313. var Template7 = function (template) {
  314. var t = this;
  315. t.template = template;
  316. function getCompileFn(block, depth) {
  317. if (block.content) return compile(block.content, depth);
  318. else return function () {return ''; };
  319. }
  320. function getCompileInverse(block, depth) {
  321. if (block.inverseContent) return compile(block.inverseContent, depth);
  322. else return function () {return ''; };
  323. }
  324. function getCompileVar(name, ctx) {
  325. var variable, parts, levelsUp = 0, initialCtx = ctx;
  326. if (name.indexOf('../') === 0) {
  327. levelsUp = name.split('../').length - 1;
  328. var newDepth = ctx.split('_')[1] - levelsUp;
  329. ctx = 'ctx_' + (newDepth >= 1 ? newDepth : 1);
  330. parts = name.split('../')[levelsUp].split('.');
  331. }
  332. else if (name.indexOf('@global') === 0) {
  333. ctx = '$.Template7.global';
  334. parts = name.split('@global.')[1].split('.');
  335. }
  336. else if (name.indexOf('@root') === 0) {
  337. ctx = 'ctx_1';
  338. parts = name.split('@root.')[1].split('.');
  339. }
  340. else {
  341. parts = name.split('.');
  342. }
  343. variable = ctx;
  344. for (var i = 0; i < parts.length; i++) {
  345. var part = parts[i];
  346. if (part.indexOf('@') === 0) {
  347. if (i > 0) {
  348. variable += '[(data && data.' + part.replace('@', '') + ')]';
  349. }
  350. else {
  351. variable = '(data && data.' + name.replace('@', '') + ')';
  352. }
  353. }
  354. else {
  355. if (isFinite(part)) {
  356. variable += '[' + part + ']';
  357. }
  358. else {
  359. if (part.indexOf('this') === 0) {
  360. variable = part.replace('this', ctx);
  361. }
  362. else {
  363. variable += '.' + part;
  364. }
  365. }
  366. }
  367. }
  368. return variable;
  369. }
  370. function getCompiledArguments(contextArray, ctx) {
  371. var arr = [];
  372. for (var i = 0; i < contextArray.length; i++) {
  373. if (contextArray[i].indexOf('"') === 0) arr.push(contextArray[i]);
  374. else {
  375. arr.push(getCompileVar(contextArray[i], ctx));
  376. }
  377. }
  378. return arr.join(', ');
  379. }
  380. function compile(template, depth) {
  381. depth = depth || 1;
  382. template = template || t.template;
  383. if (typeof template !== 'string') {
  384. throw new Error('Template7: Template must be a string');
  385. }
  386. var blocks = stringToBlocks(template);
  387. if (blocks.length === 0) {
  388. return function () { return ''; };
  389. }
  390. var ctx = 'ctx_' + depth;
  391. var resultString = '(function (' + ctx + ', data) {\n';
  392. if (depth === 1) {
  393. resultString += 'function isArray(arr){return Object.prototype.toString.apply(arr) === \'[object Array]\';}\n';
  394. resultString += 'function isFunction(func){return (typeof func === \'function\');}\n';
  395. resultString += 'function c(val, ctx) {if (typeof val !== "undefined") {if (isFunction(val)) {return val.call(ctx);} else return val;} else return "";}\n';
  396. }
  397. resultString += 'var r = \'\';\n';
  398. var i, j, context;
  399. for (i = 0; i < blocks.length; i++) {
  400. var block = blocks[i];
  401. // Plain block
  402. if (block.type === 'plain') {
  403. resultString += 'r +=\'' + (block.content).replace(/\r/g, '\\r').replace(/\n/g, '\\n').replace(/'/g, '\\' + '\'') + '\';';
  404. continue;
  405. }
  406. var variable, compiledArguments;
  407. // Variable block
  408. if (block.type === 'variable') {
  409. variable = getCompileVar(block.contextName, ctx);
  410. resultString += 'r += c(' + variable + ', ' + ctx + ');';
  411. }
  412. // Helpers block
  413. if (block.type === 'helper') {
  414. if (block.helperName in t.helpers) {
  415. compiledArguments = getCompiledArguments(block.contextName, ctx);
  416. resultString += 'r += ($.Template7.helpers.' + block.helperName + ').call(' + ctx + ', ' + (compiledArguments && (compiledArguments + ', ')) +'{hash:' + JSON.stringify(block.hash) + ', data: data || {}, fn: ' + getCompileFn(block, depth+1) + ', inverse: ' + getCompileInverse(block, depth+1) + ', root: ctx_1});';
  417. }
  418. else {
  419. if (block.contextName.length > 0) {
  420. throw new Error('Template7: Missing helper: "' + block.helperName + '"');
  421. }
  422. else {
  423. variable = getCompileVar(block.helperName, ctx);
  424. resultString += 'if (' + variable + ') {';
  425. resultString += 'if (isArray(' + variable + ')) {';
  426. resultString += 'r += ($.Template7.helpers.each).call(' + ctx + ', ' + variable + ', {hash:' + JSON.stringify(block.hash) + ', data: data || {}, fn: ' + getCompileFn(block, depth+1) + ', inverse: ' + getCompileInverse(block, depth+1) + ', root: ctx_1});';
  427. resultString += '}else {';
  428. resultString += 'r += ($.Template7.helpers.with).call(' + ctx + ', ' + variable + ', {hash:' + JSON.stringify(block.hash) + ', data: data || {}, fn: ' + getCompileFn(block, depth+1) + ', inverse: ' + getCompileInverse(block, depth+1) + ', root: ctx_1});';
  429. resultString += '}}';
  430. }
  431. }
  432. }
  433. }
  434. resultString += '\nreturn r;})';
  435. return eval.call(window, resultString);
  436. }
  437. t.compile = function (template) {
  438. if (!t.compiled) {
  439. t.compiled = compile(template);
  440. }
  441. return t.compiled;
  442. };
  443. };
  444. Template7.prototype = {
  445. options: {},
  446. helpers: {
  447. 'if': function (context, options) {
  448. if (isFunction(context)) { context = context.call(this); }
  449. if (context) {
  450. return options.fn(this, options.data);
  451. }
  452. else {
  453. return options.inverse(this, options.data);
  454. }
  455. },
  456. 'unless': function (context, options) {
  457. if (isFunction(context)) { context = context.call(this); }
  458. if (!context) {
  459. return options.fn(this, options.data);
  460. }
  461. else {
  462. return options.inverse(this, options.data);
  463. }
  464. },
  465. 'each': function (context, options) {
  466. var ret = '', i = 0;
  467. if (isFunction(context)) { context = context.call(this); }
  468. if (isArray(context)) {
  469. if (options.hash.reverse) {
  470. context = context.reverse();
  471. }
  472. for (i = 0; i < context.length; i++) {
  473. ret += options.fn(context[i], {first: i === 0, last: i === context.length - 1, index: i});
  474. }
  475. if (options.hash.reverse) {
  476. context = context.reverse();
  477. }
  478. }
  479. else {
  480. for (var key in context) {
  481. i++;
  482. ret += options.fn(context[key], {key: key});
  483. }
  484. }
  485. if (i > 0) return ret;
  486. else return options.inverse(this);
  487. },
  488. 'with': function (context, options) {
  489. if (isFunction(context)) { context = context.call(this); }
  490. return options.fn(context);
  491. },
  492. 'join': function (context, options) {
  493. if (isFunction(context)) { context = context.call(this); }
  494. return context.join(options.hash.delimiter || options.hash.delimeter);
  495. },
  496. 'js': function (expression, options) {
  497. var func;
  498. if (expression.indexOf('return')>=0) {
  499. func = '(function(){'+expression+'})';
  500. }
  501. else {
  502. func = '(function(){return ('+expression+')})';
  503. }
  504. return eval.call(this, func).call(this);
  505. },
  506. 'js_compare': function (expression, options) {
  507. var func;
  508. if (expression.indexOf('return')>=0) {
  509. func = '(function(){'+expression+'})';
  510. }
  511. else {
  512. func = '(function(){return ('+expression+')})';
  513. }
  514. var condition = eval.call(this, func).call(this);
  515. if (condition) {
  516. return options.fn(this, options.data);
  517. }
  518. else {
  519. return options.inverse(this, options.data);
  520. }
  521. }
  522. }
  523. };
  524. var t7 = function (template, data) {
  525. if (arguments.length === 2) {
  526. var instance = new Template7(template);
  527. var rendered = instance.compile()(data);
  528. instance = null;
  529. return (rendered);
  530. }
  531. else return new Template7(template);
  532. };
  533. t7.registerHelper = function (name, fn) {
  534. Template7.prototype.helpers[name] = fn;
  535. };
  536. t7.unregisterHelper = function (name) {
  537. Template7.prototype.helpers[name] = undefined;
  538. delete Template7.prototype.helpers[name];
  539. };
  540. t7.compile = function (template, options) {
  541. var instance = new Template7(template, options);
  542. return instance.compile();
  543. };
  544. t7.options = Template7.prototype.options;
  545. t7.helpers = Template7.prototype.helpers;
  546. return t7;
  547. })();
  548. }($);
  549. + function($) {
  550. "use strict";
  551. var defaults;
  552. $.modal = function(params) {
  553. params = $.extend({}, defaults, params);
  554. var buttons = params.buttons;
  555. var buttonsHtml = buttons.map(function(d, i) {
  556. return '<a href="javascript:;" class="weui_btn_dialog ' + (d.className || "") + '">' + d.text + '</a>';
  557. }).join("");
  558. var tpl = '<div class="weui_dialog">' +
  559. '<div class="weui_dialog_hd"><strong class="weui_dialog_title">' + params.title + '</strong></div>' +
  560. ( params.text ? '<div class="weui_dialog_bd">'+params.text+'</div>' : '')+
  561. '<div class="weui_dialog_ft">' + buttonsHtml + '</div>' +
  562. '</div>';
  563. var dialog = $.openModal(tpl);
  564. dialog.find(".weui_btn_dialog").each(function(i, e) {
  565. var el = $(e);
  566. el.click(function() {
  567. //先关闭对话框,再调用回调函数
  568. if(params.autoClose) $.closeModal();
  569. if(buttons[i].onClick) {
  570. buttons[i].onClick();
  571. }
  572. });
  573. });
  574. };
  575. $.openModal = function(tpl) {
  576. var mask = $("<div class='weui_mask'></div>").appendTo(document.body);
  577. mask.show();
  578. var dialog = $(tpl).appendTo(document.body);
  579. dialog.show();
  580. mask.addClass("weui_mask_visible");
  581. dialog.addClass("weui_dialog_visible");
  582. return dialog;
  583. }
  584. $.closeModal = function() {
  585. $(".weui_mask_visible").removeClass("weui_mask_visible").transitionEnd(function() {
  586. $(this).remove();
  587. });
  588. $(".weui_dialog_visible").removeClass("weui_dialog_visible").transitionEnd(function() {
  589. $(this).remove();
  590. });
  591. };
  592. $.alert = function(text, title, callback) {
  593. if (typeof title === 'function') {
  594. callback = arguments[1];
  595. title = undefined;
  596. }
  597. return $.modal({
  598. text: text,
  599. title: title,
  600. buttons: [{
  601. text: defaults.buttonOK,
  602. className: "primary",
  603. onClick: callback
  604. }]
  605. });
  606. }
  607. $.confirm = function(text, title, callbackOK, callbackCancel) {
  608. if (typeof title === 'function') {
  609. callbackCancel = arguments[2];
  610. callbackOK = arguments[1];
  611. title = undefined;
  612. }
  613. return $.modal({
  614. text: text,
  615. title: title,
  616. buttons: [
  617. {
  618. text: defaults.buttonCancel,
  619. className: "default",
  620. onClick: callbackCancel
  621. },
  622. {
  623. text: defaults.buttonOK,
  624. className: "primary",
  625. onClick: callbackOK
  626. }]
  627. });
  628. };
  629. $.prompt = function(text, title, callbackOK, callbackCancel) {
  630. if (typeof title === 'function') {
  631. callbackCancel = arguments[2];
  632. callbackOK = arguments[1];
  633. title = undefined;
  634. }
  635. return $.modal({
  636. text: "<p class='weui-prompt-text'>"+(text || "")+"</p><input type='text' class='weui_input weui-prompt-input' id='weui-prompt-input'/>",
  637. title: title,
  638. buttons: [
  639. {
  640. text: defaults.buttonCancel,
  641. className: "default",
  642. onClick: callbackCancel
  643. },
  644. {
  645. text: defaults.buttonOK,
  646. className: "primary",
  647. onClick: function() {
  648. callbackOK && callbackOK($("#weui-prompt-input").val());
  649. }
  650. }]
  651. });
  652. };
  653. defaults = $.modal.prototype.defaults = {
  654. title: "提示",
  655. text: undefined,
  656. buttonOK: "确定",
  657. buttonCancel: "取消",
  658. buttons: [{
  659. text: "确定",
  660. className: "primary"
  661. }],
  662. autoClose: true //点击按钮自动关闭对话框,如果你不希望点击按钮就关闭对话框,可以把这个设置为false
  663. };
  664. }($);
  665. + function($) {
  666. "use strict";
  667. var defaults;
  668. var show = function(html, className) {
  669. className = className || "";
  670. var mask = $("<div class='weui_mask_transparent'></div>").appendTo(document.body);
  671. var tpl = '<div class="weui_toast ' + className + '">' + html + '</div>';
  672. var dialog = $(tpl).appendTo(document.body);
  673. dialog.show();
  674. dialog.addClass("weui_toast_visible");
  675. };
  676. var hide = function() {
  677. $(".weui_mask_transparent").hide();
  678. $(".weui_toast_visible").removeClass("weui_toast_visible").transitionEnd(function() {
  679. $(this).remove();
  680. });
  681. }
  682. $.toast = function(text, style) {
  683. var className;
  684. if(style == "cancel") {
  685. className = "weui_toast_cancel";
  686. } else if(style == "forbidden") {
  687. className = "weui_toast_forbidden";
  688. }
  689. show('<i class="weui_icon_toast"></i><p class="weui_toast_content">' + (text || "已经完成") + '</p>', className);
  690. setTimeout(function() {
  691. hide();
  692. }, toastDefaults.duration);
  693. }
  694. $.showLoading = function(text) {
  695. var html = '<div class="weui_loading">';
  696. for(var i=0;i<12;i++) {
  697. html += '<div class="weui_loading_leaf weui_loading_leaf_' + i + '"></div>';
  698. }
  699. html += '</div>';
  700. html += '<p class="weui_toast_content">' + (text || "数据加载中") + '</p>';
  701. show(html, 'weui_loading_toast');
  702. }
  703. $.hideLoading = function() {
  704. hide();
  705. }
  706. var toastDefaults = $.toast.prototype.defaults = {
  707. duration: 2000
  708. }
  709. }($);
  710. + function($) {
  711. "use strict";
  712. var defaults;
  713. var show = function(params) {
  714. var mask = $("<div class='weui_mask weui_actions_mask'></div>").appendTo(document.body);
  715. var actions = params.actions || [];
  716. var actionsHtml = actions.map(function(d, i) {
  717. return '<div class="weui_actionsheet_cell ' + (d.className || "") + '">' + d.text + '</div>';
  718. }).join("");
  719. var tpl = '<div class="weui_actionsheet " id="weui_actionsheet">'+
  720. '<div class="weui_actionsheet_menu">'+
  721. actionsHtml +
  722. '</div>'+
  723. '<div class="weui_actionsheet_action">'+
  724. '<div class="weui_actionsheet_cell weui_actionsheet_cancel">取消</div>'+
  725. '</div>'+
  726. '</div>';
  727. var dialog = $(tpl).appendTo(document.body);
  728. dialog.find(".weui_actionsheet_menu .weui_actionsheet_cell, .weui_actionsheet_action .weui_actionsheet_cell").each(function(i, e) {
  729. $(e).click(function() {
  730. $.closeActions();
  731. if(actions[i] && actions[i].onClick) {
  732. actions[i].onClick();
  733. }
  734. })
  735. });
  736. mask.show();
  737. dialog.show();
  738. mask.addClass("weui_mask_visible");
  739. dialog.addClass("weui_actionsheet_toggle");
  740. };
  741. var hide = function() {
  742. $(".weui_mask").removeClass("weui_mask_visible").transitionEnd(function() {
  743. $(this).remove();
  744. });
  745. $(".weui_actionsheet").removeClass("weui_actionsheet_toggle").transitionEnd(function() {
  746. $(this).remove();
  747. });
  748. }
  749. $.actions = function(params) {
  750. params = $.extend({}, defaults, params);
  751. show(params);
  752. }
  753. $.closeActions = function() {
  754. hide();
  755. }
  756. $(document).on("click", ".weui_actions_mask", function() {
  757. $.closeActions();
  758. });
  759. var defaults = $.actions.prototype.defaults = {
  760. /*actions: [{
  761. text: "菜单",
  762. className: "danger",
  763. onClick: function() {
  764. console.log(1);
  765. }
  766. },{
  767. text: "菜单2",
  768. className: "danger",
  769. onClick: function() {
  770. console.log(2);
  771. }
  772. }]*/
  773. }
  774. }($);
  775. /* ===============================================================================
  776. ************ Pull to refreh ************
  777. =============================================================================== */
  778. /* global $:true */
  779. +function ($) {
  780. "use strict";
  781. var PTR = function(el) {
  782. this.container = $(el);
  783. this.distance = 50;
  784. this.attachEvents();
  785. }
  786. PTR.prototype.touchStart = function(e) {
  787. if(this.container.hasClass("refreshing")) return;
  788. var p = $.getTouchPosition(e);
  789. this.start = p;
  790. this.diffX = this.diffY = 0;
  791. };
  792. PTR.prototype.touchMove= function(e) {
  793. if(this.container.hasClass("refreshing")) return;
  794. if(!this.start) return false;
  795. if(this.container.scrollTop() > 0) return;
  796. var p = $.getTouchPosition(e);
  797. this.diffX = p.x - this.start.x;
  798. this.diffY = p.y - this.start.y;
  799. if(this.diffY < 0) return;
  800. this.container.addClass("touching");
  801. e.preventDefault();
  802. e.stopPropagation();
  803. this.diffY = Math.pow(this.diffY, 0.8);
  804. this.container.css("transform", "translate3d(0, "+this.diffY+"px, 0)");
  805. if(this.diffY < this.distance) {
  806. this.container.removeClass("pull-up").addClass("pull-down");
  807. } else {
  808. this.container.removeClass("pull-down").addClass("pull-up");
  809. }
  810. };
  811. PTR.prototype.touchEnd = function() {
  812. this.start = false;
  813. if(this.diffY <= 0 || this.container.hasClass("refreshing")) return;
  814. this.container.removeClass("touching");
  815. this.container.removeClass("pull-down pull-up");
  816. this.container.css("transform", "");
  817. if(Math.abs(this.diffY) <= this.distance) {
  818. } else {
  819. this.container.addClass("refreshing");
  820. this.container.trigger("pull-to-refresh");
  821. }
  822. };
  823. PTR.prototype.attachEvents = function() {
  824. var el = this.container;
  825. el.addClass("weui-pull-to-refresh");
  826. el.on($.touchEvents.start, $.proxy(this.touchStart, this));
  827. el.on($.touchEvents.move, $.proxy(this.touchMove, this));
  828. el.on($.touchEvents.end, $.proxy(this.touchEnd, this));
  829. };
  830. var pullToRefresh = function(el) {
  831. new PTR(el);
  832. };
  833. var pullToRefreshDone = function(el) {
  834. $(el).removeClass("refreshing");
  835. }
  836. $.fn.pullToRefresh = function() {
  837. return this.each(function() {
  838. pullToRefresh(this);
  839. });
  840. }
  841. $.fn.pullToRefreshDone = function() {
  842. return this.each(function() {
  843. pullToRefreshDone(this);
  844. });
  845. }
  846. }($);
  847. /* ===============================================================================
  848. ************ Notification ************
  849. =============================================================================== */
  850. /* global $:true */
  851. +function ($) {
  852. "use strict";
  853. var Infinite = function(el, distance) {
  854. this.container = $(el);
  855. this.container.data("infinite", this);
  856. this.distance = distance || 50;
  857. this.attachEvents();
  858. }
  859. Infinite.prototype.scroll = function() {
  860. var container = this.container;
  861. var offset = container.scrollHeight() - ($(window).height() + container.scrollTop());
  862. if(offset <= this.distance) {
  863. container.trigger("infinite");
  864. }
  865. }
  866. Infinite.prototype.attachEvents = function(off) {
  867. var el = this.container;
  868. var scrollContainer = (el[0].tagName.toUpperCase() === "BODY" ? $(document) : el);
  869. scrollContainer[off ? "off" : "on"]("scroll", $.proxy(this.scroll, this));
  870. };
  871. Infinite.prototype.detachEvents = function(off) {
  872. this.attachEvents(true);
  873. }
  874. var infinite = function(el) {
  875. attachEvents(el);
  876. }
  877. $.fn.infinite = function(distance) {
  878. return this.each(function() {
  879. new Infinite(this, distance);
  880. });
  881. }
  882. $.fn.destroyInfinite = function() {
  883. return this.each(function() {
  884. var infinite = $(this).data("infinite");
  885. if(infinite && infinite.detachEvents) infinite.detachEvents();
  886. });
  887. }
  888. }($);
  889. /* global $:true */
  890. +function ($) {
  891. "use strict";
  892. var ITEM_ON = "weui_bar_item_on";
  893. var showTab = function(a) {
  894. var $a = $(a);
  895. if($a.hasClass(ITEM_ON)) return;
  896. var href = $a.attr("href");
  897. if(!/^#/.test(href)) return ;
  898. $a.parent().find("."+ITEM_ON).removeClass(ITEM_ON);
  899. $a.addClass(ITEM_ON);
  900. var bd = $a.parents(".weui_tab").find(".weui_tab_bd");
  901. bd.find(".weui_tab_bd_item_active").removeClass("weui_tab_bd_item_active");
  902. $(href).addClass("weui_tab_bd_item_active");
  903. }
  904. $.showTab = showTab;
  905. $(document).on("click", ".weui_tabbar_item, .weui_navbar_item", function(e) {
  906. var $a = $(e.currentTarget);
  907. var href = $a.attr("href");
  908. if($a.hasClass(ITEM_ON)) return;
  909. if(!/^#/.test(href)) return;
  910. e.preventDefault();
  911. showTab($a);
  912. });
  913. }($);
  914. /* global $:true */
  915. + function($) {
  916. "use strict";
  917. $(document).on("click", ".weui_search_bar label", function(e) {
  918. $(e.target).parents(".weui_search_bar").addClass("weui_search_focusing");
  919. })
  920. .on("blur", ".weui_search_input", function(e) {
  921. var $input = $(e.target);
  922. if(!$input.val()) $input.parents(".weui_search_bar").removeClass("weui_search_focusing");
  923. })
  924. .on("click", ".weui_search_cancel", function(e) {
  925. var $input = $(e.target).parents(".weui_search_bar").find(".weui_search_input").val("").blur();
  926. })
  927. .on("click", ".weui_icon_clear", function(e) {
  928. var $input = $(e.target).parents(".weui_search_bar").find(".weui_search_input").val("").focus();
  929. });
  930. }($);
  931. /*===========================
  932. Device/OS Detection
  933. ===========================*/
  934. /* global $:true */
  935. ;(function ($) {
  936. "use strict";
  937. var device = {};
  938. var ua = navigator.userAgent;
  939. var android = ua.match(/(Android);?[\s\/]+([\d.]+)?/);
  940. var ipad = ua.match(/(iPad).*OS\s([\d_]+)/);
  941. var ipod = ua.match(/(iPod)(.*OS\s([\d_]+))?/);
  942. var iphone = !ipad && ua.match(/(iPhone\sOS)\s([\d_]+)/);
  943. device.ios = device.android = device.iphone = device.ipad = device.androidChrome = false;
  944. // Android
  945. if (android) {
  946. device.os = 'android';
  947. device.osVersion = android[2];
  948. device.android = true;
  949. device.androidChrome = ua.toLowerCase().indexOf('chrome') >= 0;
  950. }
  951. if (ipad || iphone || ipod) {
  952. device.os = 'ios';
  953. device.ios = true;
  954. }
  955. // iOS
  956. if (iphone && !ipod) {
  957. device.osVersion = iphone[2].replace(/_/g, '.');
  958. device.iphone = true;
  959. }
  960. if (ipad) {
  961. device.osVersion = ipad[2].replace(/_/g, '.');
  962. device.ipad = true;
  963. }
  964. if (ipod) {
  965. device.osVersion = ipod[3] ? ipod[3].replace(/_/g, '.') : null;
  966. device.iphone = true;
  967. }
  968. // iOS 8+ changed UA
  969. if (device.ios && device.osVersion && ua.indexOf('Version/') >= 0) {
  970. if (device.osVersion.split('.')[0] === '10') {
  971. device.osVersion = ua.toLowerCase().split('version/')[1].split(' ')[0];
  972. }
  973. }
  974. // Webview
  975. device.webView = (iphone || ipad || ipod) && ua.match(/.*AppleWebKit(?!.*Safari)/i);
  976. // Minimal UI
  977. if (device.os && device.os === 'ios') {
  978. var osVersionArr = device.osVersion.split('.');
  979. device.minimalUi = !device.webView &&
  980. (ipod || iphone) &&
  981. (osVersionArr[0] * 1 === 7 ? osVersionArr[1] * 1 >= 1 : osVersionArr[0] * 1 > 7) &&
  982. $('meta[name="viewport"]').length > 0 && $('meta[name="viewport"]').attr('content').indexOf('minimal-ui') >= 0;
  983. }
  984. // Check for status bar and fullscreen app mode
  985. var windowWidth = $(window).width();
  986. var windowHeight = $(window).height();
  987. device.statusBar = false;
  988. if (device.webView && (windowWidth * windowHeight === screen.width * screen.height)) {
  989. device.statusBar = true;
  990. }
  991. else {
  992. device.statusBar = false;
  993. }
  994. // Classes
  995. var classNames = [];
  996. // Pixel Ratio
  997. device.pixelRatio = window.devicePixelRatio || 1;
  998. classNames.push('pixel-ratio-' + Math.floor(device.pixelRatio));
  999. if (device.pixelRatio >= 2) {
  1000. classNames.push('retina');
  1001. }
  1002. // OS classes
  1003. if (device.os) {
  1004. classNames.push(device.os, device.os + '-' + device.osVersion.split('.')[0], device.os + '-' + device.osVersion.replace(/\./g, '-'));
  1005. if (device.os === 'ios') {
  1006. var major = parseInt(device.osVersion.split('.')[0], 10);
  1007. for (var i = major - 1; i >= 6; i--) {
  1008. classNames.push('ios-gt-' + i);
  1009. }
  1010. }
  1011. }
  1012. // Status bar classes
  1013. if (device.statusBar) {
  1014. classNames.push('with-statusbar-overlay');
  1015. }
  1016. else {
  1017. $('html').removeClass('with-statusbar-overlay');
  1018. }
  1019. // Add html classes
  1020. if (classNames.length > 0) $('html').addClass(classNames.join(' '));
  1021. $.device = device;
  1022. })($);
  1023. /*======================================================
  1024. ************ Picker ************
  1025. ======================================================*/
  1026. /* global $:true */
  1027. /* jshint unused:false */
  1028. /* jshint multistr:true */
  1029. + function($) {
  1030. "use strict";
  1031. var Picker = function (params) {
  1032. var p = this;
  1033. var defaults = {
  1034. updateValuesOnMomentum: false,
  1035. updateValuesOnTouchmove: true,
  1036. rotateEffect: false,
  1037. momentumRatio: 7,
  1038. freeMode: false,
  1039. // Common settings
  1040. scrollToInput: true,
  1041. inputReadOnly: true,
  1042. toolbar: true,
  1043. toolbarCloseText: '完成',
  1044. title: '请选择',
  1045. toolbarTemplate: '<div class="toolbar">\
  1046. <div class="toolbar-inner">\
  1047. <a href="javascript:;" class="picker-button close-picker">{{closeText}}</a>\
  1048. <h1 class="title">{{title}}</h1>\
  1049. </div>\
  1050. </div>',
  1051. };
  1052. params = params || {};
  1053. for (var def in defaults) {
  1054. if (typeof params[def] === 'undefined') {
  1055. params[def] = defaults[def];
  1056. }
  1057. }
  1058. p.params = params;
  1059. p.cols = [];
  1060. p.initialized = false;
  1061. // Inline flag
  1062. p.inline = p.params.container ? true : false;
  1063. // 3D Transforms origin bug, only on safari
  1064. var originBug = $.device.ios || (navigator.userAgent.toLowerCase().indexOf('safari') >= 0 && navigator.userAgent.toLowerCase().indexOf('chrome') < 0) && !$.device.android;
  1065. // Should be converted to popover
  1066. function isPopover() {
  1067. var toPopover = false;
  1068. if (!p.params.convertToPopover && !p.params.onlyInPopover) return toPopover;
  1069. if (!p.inline && p.params.input) {
  1070. if (p.params.onlyInPopover) toPopover = true;
  1071. else {
  1072. if ($.device.ios) {
  1073. toPopover = $.device.ipad ? true : false;
  1074. }
  1075. else {
  1076. if ($(window).width() >= 768) toPopover = true;
  1077. }
  1078. }
  1079. }
  1080. return toPopover;
  1081. }
  1082. function inPopover() {
  1083. if (p.opened && p.container && p.container.length > 0 && p.container.parents('.popover').length > 0) return true;
  1084. else return false;
  1085. }
  1086. // Value
  1087. p.setValue = function (arrValues, transition) {
  1088. var valueIndex = 0;
  1089. for (var i = 0; i < p.cols.length; i++) {
  1090. if (p.cols[i] && !p.cols[i].divider) {
  1091. p.cols[i].setValue(arrValues[valueIndex], transition);
  1092. valueIndex++;
  1093. }
  1094. }
  1095. };
  1096. p.updateValue = function () {
  1097. var newValue = [];
  1098. var newDisplayValue = [];
  1099. for (var i = 0; i < p.cols.length; i++) {
  1100. if (!p.cols[i].divider) {
  1101. newValue.push(p.cols[i].value);
  1102. newDisplayValue.push(p.cols[i].displayValue);
  1103. }
  1104. }
  1105. if (newValue.indexOf(undefined) >= 0) {
  1106. return;
  1107. }
  1108. p.value = newValue;
  1109. p.displayValue = newDisplayValue;
  1110. if (p.params.onChange) {
  1111. p.params.onChange(p, p.value, p.displayValue);
  1112. }
  1113. if (p.input && p.input.length > 0) {
  1114. $(p.input).val(p.params.formatValue ? p.params.formatValue(p, p.value, p.displayValue) : p.value.join(' '));
  1115. $(p.input).trigger('change');
  1116. }
  1117. };
  1118. // Columns Handlers
  1119. p.initPickerCol = function (colElement, updateItems) {
  1120. var colContainer = $(colElement);
  1121. var colIndex = colContainer.index();
  1122. var col = p.cols[colIndex];
  1123. if (col.divider) return;
  1124. col.container = colContainer;
  1125. col.wrapper = col.container.find('.picker-items-col-wrapper');
  1126. col.items = col.wrapper.find('.picker-item');
  1127. var i, j;
  1128. var wrapperHeight, itemHeight, itemsHeight, minTranslate, maxTranslate;
  1129. col.replaceValues = function (values, displayValues) {
  1130. col.destroyEvents();
  1131. col.values = values;
  1132. col.displayValues = displayValues;
  1133. var newItemsHTML = p.columnHTML(col, true);
  1134. col.wrapper.html(newItemsHTML);
  1135. col.items = col.wrapper.find('.picker-item');
  1136. col.calcSize();
  1137. col.setValue(col.values[0], 0, true);
  1138. col.initEvents();
  1139. };
  1140. col.calcSize = function () {
  1141. if (p.params.rotateEffect) {
  1142. col.container.removeClass('picker-items-col-absolute');
  1143. if (!col.width) col.container.css({width:''});
  1144. }
  1145. var colWidth, colHeight;
  1146. colWidth = 0;
  1147. colHeight = col.container[0].offsetHeight;
  1148. wrapperHeight = col.wrapper[0].offsetHeight;
  1149. itemHeight = col.items[0].offsetHeight;
  1150. itemsHeight = itemHeight * col.items.length;
  1151. minTranslate = colHeight / 2 - itemsHeight + itemHeight / 2;
  1152. maxTranslate = colHeight / 2 - itemHeight / 2;
  1153. if (col.width) {
  1154. colWidth = col.width;
  1155. if (parseInt(colWidth, 10) === colWidth) colWidth = colWidth + 'px';
  1156. col.container.css({width: colWidth});
  1157. }
  1158. if (p.params.rotateEffect) {
  1159. if (!col.width) {
  1160. col.items.each(function () {
  1161. var item = $(this);
  1162. item.css({width:'auto'});
  1163. colWidth = Math.max(colWidth, item[0].offsetWidth);
  1164. item.css({width:''});
  1165. });
  1166. col.container.css({width: (colWidth + 2) + 'px'});
  1167. }
  1168. col.container.addClass('picker-items-col-absolute');
  1169. }
  1170. };
  1171. col.calcSize();
  1172. col.wrapper.transform('translate3d(0,' + maxTranslate + 'px,0)').transition(0);
  1173. var activeIndex = 0;
  1174. var animationFrameId;
  1175. // Set Value Function
  1176. col.setValue = function (newValue, transition, valueCallbacks) {
  1177. if (typeof transition === 'undefined') transition = '';
  1178. var newActiveIndex = col.wrapper.find('.picker-item[data-picker-value="' + newValue + '"]').index();
  1179. if(typeof newActiveIndex === 'undefined' || newActiveIndex === -1) {
  1180. return;
  1181. }
  1182. var newTranslate = -newActiveIndex * itemHeight + maxTranslate;
  1183. // Update wrapper
  1184. col.wrapper.transition(transition);
  1185. col.wrapper.transform('translate3d(0,' + (newTranslate) + 'px,0)');
  1186. // Watch items
  1187. if (p.params.updateValuesOnMomentum && col.activeIndex && col.activeIndex !== newActiveIndex ) {
  1188. $.cancelAnimationFrame(animationFrameId);
  1189. col.wrapper.transitionEnd(function(){
  1190. $.cancelAnimationFrame(animationFrameId);
  1191. });
  1192. updateDuringScroll();
  1193. }
  1194. // Update items
  1195. col.updateItems(newActiveIndex, newTranslate, transition, valueCallbacks);
  1196. };
  1197. col.updateItems = function (activeIndex, translate, transition, valueCallbacks) {
  1198. if (typeof translate === 'undefined') {
  1199. translate = $.getTranslate(col.wrapper[0], 'y');
  1200. }
  1201. if(typeof activeIndex === 'undefined') activeIndex = -Math.round((translate - maxTranslate)/itemHeight);
  1202. if (activeIndex < 0) activeIndex = 0;
  1203. if (activeIndex >= col.items.length) activeIndex = col.items.length - 1;
  1204. var previousActiveIndex = col.activeIndex;
  1205. col.activeIndex = activeIndex;
  1206. /*
  1207. col.wrapper.find('.picker-selected, .picker-after-selected, .picker-before-selected').removeClass('picker-selected picker-after-selected picker-before-selected');
  1208. col.items.transition(transition);
  1209. var selectedItem = col.items.eq(activeIndex).addClass('picker-selected').transform('');
  1210. var prevItems = selectedItem.prevAll().addClass('picker-before-selected');
  1211. var nextItems = selectedItem.nextAll().addClass('picker-after-selected');
  1212. */
  1213. //去掉 .picker-after-selected, .picker-before-selected 以提高性能
  1214. col.wrapper.find('.picker-selected').removeClass('picker-selected');
  1215. if (p.params.rotateEffect) {
  1216. col.items.transition(transition);
  1217. }
  1218. var selectedItem = col.items.eq(activeIndex).addClass('picker-selected').transform('');
  1219. if (valueCallbacks || typeof valueCallbacks === 'undefined') {
  1220. // Update values
  1221. col.value = selectedItem.attr('data-picker-value');
  1222. col.displayValue = col.displayValues ? col.displayValues[activeIndex] : col.value;
  1223. // On change callback
  1224. if (previousActiveIndex !== activeIndex) {
  1225. if (col.onChange) {
  1226. col.onChange(p, col.value, col.displayValue);
  1227. }
  1228. p.updateValue();
  1229. }
  1230. }
  1231. // Set 3D rotate effect
  1232. if (!p.params.rotateEffect) {
  1233. return;
  1234. }
  1235. var percentage = (translate - (Math.floor((translate - maxTranslate)/itemHeight) * itemHeight + maxTranslate)) / itemHeight;
  1236. col.items.each(function () {
  1237. var item = $(this);
  1238. var itemOffsetTop = item.index() * itemHeight;
  1239. var translateOffset = maxTranslate - translate;
  1240. var itemOffset = itemOffsetTop - translateOffset;
  1241. var percentage = itemOffset / itemHeight;
  1242. var itemsFit = Math.ceil(col.height / itemHeight / 2) + 1;
  1243. var angle = (-18*percentage);
  1244. if (angle > 180) angle = 180;
  1245. if (angle < -180) angle = -180;
  1246. // Far class
  1247. if (Math.abs(percentage) > itemsFit) item.addClass('picker-item-far');
  1248. else item.removeClass('picker-item-far');
  1249. // Set transform
  1250. item.transform('translate3d(0, ' + (-translate + maxTranslate) + 'px, ' + (originBug ? -110 : 0) + 'px) rotateX(' + angle + 'deg)');
  1251. });
  1252. };
  1253. function updateDuringScroll() {
  1254. animationFrameId = $.requestAnimationFrame(function () {
  1255. col.updateItems(undefined, undefined, 0);
  1256. updateDuringScroll();
  1257. });
  1258. }
  1259. // Update items on init
  1260. if (updateItems) col.updateItems(0, maxTranslate, 0);
  1261. var allowItemClick = true;
  1262. var isTouched, isMoved, touchStartY, touchCurrentY, touchStartTime, touchEndTime, startTranslate, returnTo, currentTranslate, prevTranslate, velocityTranslate, velocityTime;
  1263. function handleTouchStart (e) {
  1264. if (isMoved || isTouched) return;
  1265. e.preventDefault();
  1266. isTouched = true;
  1267. var position = $.getTouchPosition(e);
  1268. touchStartY = touchCurrentY = position.y;
  1269. touchStartTime = (new Date()).getTime();
  1270. allowItemClick = true;
  1271. startTranslate = currentTranslate = $.getTranslate(col.wrapper[0], 'y');
  1272. }
  1273. function handleTouchMove (e) {
  1274. if (!isTouched) return;
  1275. e.preventDefault();
  1276. allowItemClick = false;
  1277. var position = $.getTouchPosition(e);
  1278. touchCurrentY = position.y;
  1279. if (!isMoved) {
  1280. // First move
  1281. $.cancelAnimationFrame(animationFrameId);
  1282. isMoved = true;
  1283. startTranslate = currentTranslate = $.getTranslate(col.wrapper[0], 'y');
  1284. col.wrapper.transition(0);
  1285. }
  1286. e.preventDefault();
  1287. var diff = touchCurrentY - touchStartY;
  1288. currentTranslate = startTranslate + diff;
  1289. returnTo = undefined;
  1290. // Normalize translate
  1291. if (currentTranslate < minTranslate) {
  1292. currentTranslate = minTranslate - Math.pow(minTranslate - currentTranslate, 0.8);
  1293. returnTo = 'min';
  1294. }
  1295. if (currentTranslate > maxTranslate) {
  1296. currentTranslate = maxTranslate + Math.pow(currentTranslate - maxTranslate, 0.8);
  1297. returnTo = 'max';
  1298. }
  1299. // Transform wrapper
  1300. col.wrapper.transform('translate3d(0,' + currentTranslate + 'px,0)');
  1301. // Update items
  1302. col.updateItems(undefined, currentTranslate, 0, p.params.updateValuesOnTouchmove);
  1303. // Calc velocity
  1304. velocityTranslate = currentTranslate - prevTranslate || currentTranslate;
  1305. velocityTime = (new Date()).getTime();
  1306. prevTranslate = currentTranslate;
  1307. }
  1308. function handleTouchEnd (e) {
  1309. if (!isTouched || !isMoved) {
  1310. isTouched = isMoved = false;
  1311. return;
  1312. }
  1313. isTouched = isMoved = false;
  1314. col.wrapper.transition('');
  1315. if (returnTo) {
  1316. if (returnTo === 'min') {
  1317. col.wrapper.transform('translate3d(0,' + minTranslate + 'px,0)');
  1318. }
  1319. else col.wrapper.transform('translate3d(0,' + maxTranslate + 'px,0)');
  1320. }
  1321. touchEndTime = new Date().getTime();
  1322. var velocity, newTranslate;
  1323. if (touchEndTime - touchStartTime > 300) {
  1324. newTranslate = currentTranslate;
  1325. }
  1326. else {
  1327. velocity = Math.abs(velocityTranslate / (touchEndTime - velocityTime));
  1328. newTranslate = currentTranslate + velocityTranslate * p.params.momentumRatio;
  1329. }
  1330. newTranslate = Math.max(Math.min(newTranslate, maxTranslate), minTranslate);
  1331. // Active Index
  1332. var activeIndex = -Math.floor((newTranslate - maxTranslate)/itemHeight);
  1333. // Normalize translate
  1334. if (!p.params.freeMode) newTranslate = -activeIndex * itemHeight + maxTranslate;
  1335. // Transform wrapper
  1336. col.wrapper.transform('translate3d(0,' + (parseInt(newTranslate,10)) + 'px,0)');
  1337. // Update items
  1338. col.updateItems(activeIndex, newTranslate, '', true);
  1339. // Watch items
  1340. if (p.params.updateValuesOnMomentum) {
  1341. updateDuringScroll();
  1342. col.wrapper.transitionEnd(function(){
  1343. $.cancelAnimationFrame(animationFrameId);
  1344. });
  1345. }
  1346. // Allow click
  1347. setTimeout(function () {
  1348. allowItemClick = true;
  1349. }, 100);
  1350. }
  1351. function handleClick(e) {
  1352. if (!allowItemClick) return;
  1353. $.cancelAnimationFrame(animationFrameId);
  1354. /*jshint validthis:true */
  1355. var value = $(this).attr('data-picker-value');
  1356. col.setValue(value);
  1357. }
  1358. col.initEvents = function (detach) {
  1359. var method = detach ? 'off' : 'on';
  1360. col.container[method]($.touchEvents.start, handleTouchStart);
  1361. col.container[method]($.touchEvents.move, handleTouchMove);
  1362. col.container[method]($.touchEvents.end, handleTouchEnd);
  1363. col.items[method]('click', handleClick);
  1364. };
  1365. col.destroyEvents = function () {
  1366. col.initEvents(true);
  1367. };
  1368. col.container[0].f7DestroyPickerCol = function () {
  1369. col.destroyEvents();
  1370. };
  1371. col.initEvents();
  1372. };
  1373. p.destroyPickerCol = function (colContainer) {
  1374. colContainer = $(colContainer);
  1375. if ('f7DestroyPickerCol' in colContainer[0]) colContainer[0].f7DestroyPickerCol();
  1376. };
  1377. // Resize cols
  1378. function resizeCols() {
  1379. if (!p.opened) return;
  1380. for (var i = 0; i < p.cols.length; i++) {
  1381. if (!p.cols[i].divider) {
  1382. p.cols[i].calcSize();
  1383. p.cols[i].setValue(p.cols[i].value, 0, false);
  1384. }
  1385. }
  1386. }
  1387. $(window).on('resize', resizeCols);
  1388. // HTML Layout
  1389. p.columnHTML = function (col, onlyItems) {
  1390. var columnItemsHTML = '';
  1391. var columnHTML = '';
  1392. if (col.divider) {
  1393. columnHTML += '<div class="picker-items-col picker-items-col-divider ' + (col.textAlign ? 'picker-items-col-' + col.textAlign : '') + ' ' + (col.cssClass || '') + '">' + col.content + '</div>';
  1394. }
  1395. else {
  1396. for (var j = 0; j < col.values.length; j++) {
  1397. columnItemsHTML += '<div class="picker-item" data-picker-value="' + col.values[j] + '">' + (col.displayValues ? col.displayValues[j] : col.values[j]) + '</div>';
  1398. }
  1399. columnHTML += '<div class="picker-items-col ' + (col.textAlign ? 'picker-items-col-' + col.textAlign : '') + ' ' + (col.cssClass || '') + '"><div class="picker-items-col-wrapper">' + columnItemsHTML + '</div></div>';
  1400. }
  1401. return onlyItems ? columnItemsHTML : columnHTML;
  1402. };
  1403. p.layout = function () {
  1404. var pickerHTML = '';
  1405. var pickerClass = '';
  1406. var i;
  1407. p.cols = [];
  1408. var colsHTML = '';
  1409. for (i = 0; i < p.params.cols.length; i++) {
  1410. var col = p.params.cols[i];
  1411. colsHTML += p.columnHTML(p.params.cols[i]);
  1412. p.cols.push(col);
  1413. }
  1414. pickerClass = 'weui-picker-modal picker-columns ' + (p.params.cssClass || '') + (p.params.rotateEffect ? ' picker-3d' : '');
  1415. pickerHTML =
  1416. '<div class="' + (pickerClass) + '">' +
  1417. (p.params.toolbar ? p.params.toolbarTemplate.replace(/{{closeText}}/g, p.params.toolbarCloseText).replace(/{{title}}/g, p.params.title) : '') +
  1418. '<div class="picker-modal-inner picker-items">' +
  1419. colsHTML +
  1420. '<div class="picker-center-highlight"></div>' +
  1421. '</div>' +
  1422. '</div>';
  1423. p.pickerHTML = pickerHTML;
  1424. };
  1425. // Input Events
  1426. function openOnInput(e) {
  1427. e.preventDefault();
  1428. if (p.opened) return;
  1429. p.open();
  1430. if (p.params.scrollToInput && !isPopover()) {
  1431. var pageContent = p.input.parents('.content');
  1432. if (pageContent.length === 0) return;
  1433. var paddingTop = parseInt(pageContent.css('padding-top'), 10),
  1434. paddingBottom = parseInt(pageContent.css('padding-bottom'), 10),
  1435. pageHeight = pageContent[0].offsetHeight - paddingTop - p.container.height(),
  1436. pageScrollHeight = pageContent[0].scrollHeight - paddingTop - p.container.height(),
  1437. newPaddingBottom;
  1438. var inputTop = p.input.offset().top - paddingTop + p.input[0].offsetHeight;
  1439. if (inputTop > pageHeight) {
  1440. var scrollTop = pageContent.scrollTop() + inputTop - pageHeight;
  1441. if (scrollTop + pageHeight > pageScrollHeight) {
  1442. newPaddingBottom = scrollTop + pageHeight - pageScrollHeight + paddingBottom;
  1443. if (pageHeight === pageScrollHeight) {
  1444. newPaddingBottom = p.container.height();
  1445. }
  1446. pageContent.css({'padding-bottom': (newPaddingBottom) + 'px'});
  1447. }
  1448. pageContent.scrollTop(scrollTop, 300);
  1449. }
  1450. }
  1451. }
  1452. function closeOnHTMLClick(e) {
  1453. if (inPopover()) return;
  1454. if (p.input && p.input.length > 0) {
  1455. if (e.target !== p.input[0] && $(e.target).parents('.weui-picker-modal').length === 0) p.close();
  1456. }
  1457. else {
  1458. if ($(e.target).parents('.weui-picker-modal').length === 0) p.close();
  1459. }
  1460. }
  1461. if (p.params.input) {
  1462. p.input = $(p.params.input);
  1463. if (p.input.length > 0) {
  1464. if (p.params.inputReadOnly) p.input.prop('readOnly', true);
  1465. if (!p.inline) {
  1466. p.input.on('click', openOnInput);
  1467. }
  1468. if (p.params.inputReadOnly) {
  1469. p.input.on('focus mousedown', function (e) {
  1470. e.preventDefault();
  1471. });
  1472. }
  1473. }
  1474. }
  1475. if (!p.inline) $('html').on('click', closeOnHTMLClick);
  1476. // Open
  1477. function onPickerClose() {
  1478. p.opened = false;
  1479. if (p.input && p.input.length > 0) p.input.parents('.page-content').css({'padding-bottom': ''});
  1480. if (p.params.onClose) p.params.onClose(p);
  1481. // Destroy events
  1482. p.container.find('.picker-items-col').each(function () {
  1483. p.destroyPickerCol(this);
  1484. });
  1485. }
  1486. p.opened = false;
  1487. p.open = function () {
  1488. var toPopover = isPopover();
  1489. if (!p.opened) {
  1490. // Layout
  1491. p.layout();
  1492. // Append
  1493. if (toPopover) {
  1494. p.pickerHTML = '<div class="popover popover-picker-columns"><div class="popover-inner">' + p.pickerHTML + '</div></div>';
  1495. p.popover = $.popover(p.pickerHTML, p.params.input, true);
  1496. p.container = $(p.popover).find('.weui-picker-modal');
  1497. $(p.popover).on('close', function () {
  1498. onPickerClose();
  1499. });
  1500. }
  1501. else if (p.inline) {
  1502. p.container = $(p.pickerHTML);
  1503. p.container.addClass('picker-modal-inline');
  1504. $(p.params.container).append(p.container);
  1505. }
  1506. else {
  1507. p.container = $($.openPicker(p.pickerHTML));
  1508. $(p.container)
  1509. .on('close', function () {
  1510. onPickerClose();
  1511. });
  1512. }
  1513. // Store picker instance
  1514. p.container[0].f7Picker = p;
  1515. // Init Events
  1516. p.container.find('.picker-items-col').each(function () {
  1517. var updateItems = true;
  1518. if ((!p.initialized && p.params.value) || (p.initialized && p.value)) updateItems = false;
  1519. p.initPickerCol(this, updateItems);
  1520. });
  1521. // Set value
  1522. if (!p.initialized) {
  1523. if (p.params.value) {
  1524. p.setValue(p.params.value, 0);
  1525. }
  1526. }
  1527. else {
  1528. if (p.value) p.setValue(p.value, 0);
  1529. }
  1530. }
  1531. // Set flag
  1532. p.opened = true;
  1533. p.initialized = true;
  1534. if (p.params.onOpen) p.params.onOpen(p);
  1535. };
  1536. // Close
  1537. p.close = function () {
  1538. if (!p.opened || p.inline) return;
  1539. if (inPopover()) {
  1540. $.closePicker(p.popover);
  1541. return;
  1542. }
  1543. else {
  1544. $.closePicker(p.container);
  1545. return;
  1546. }
  1547. };
  1548. // Destroy
  1549. p.destroy = function () {
  1550. p.close();
  1551. if (p.params.input && p.input.length > 0) {
  1552. p.input.off('click focus', openOnInput);
  1553. }
  1554. $('html').off('click', closeOnHTMLClick);
  1555. $(window).off('resize', resizeCols);
  1556. };
  1557. if (p.inline) {
  1558. p.open();
  1559. }
  1560. return p;
  1561. };
  1562. $(document).on("click", ".close-picker", function() {
  1563. var pickerToClose = $('.weui-picker-modal.weui-picker-modal-visible');
  1564. if (pickerToClose.length > 0) {
  1565. $.closePicker(pickerToClose);
  1566. }
  1567. });
  1568. //修复picker会滚动页面的bug
  1569. $(document).on($.touchEvents.move, ".picker-modal-inner", function(e) {
  1570. e.preventDefault();
  1571. });
  1572. $.openPicker = function(tpl, className) {
  1573. $.closePicker();
  1574. var container = $("<div class='weui-picker-container "+ (className || "") + "'></div>").appendTo(document.body);
  1575. container.show();
  1576. container.addClass("weui-picker-container-visible");
  1577. //关于布局的问题,如果直接放在body上,则做动画的时候会撑开body高度而导致滚动条变化。
  1578. var dialog = $(tpl).appendTo(container);
  1579. dialog.width(); //通过取一次CSS值,强制浏览器不能把上下两行代码合并执行,因为合并之后会导致无法出现动画。
  1580. dialog.addClass("weui-picker-modal-visible");
  1581. return dialog;
  1582. }
  1583. $.closePicker = function(container) {
  1584. $(".weui-picker-modal-visible").removeClass("weui-picker-modal-visible").transitionEnd(function() {
  1585. $(this).parent().remove();
  1586. }).trigger("close");
  1587. };
  1588. $.fn.picker = function(params) {
  1589. var args = arguments;
  1590. return this.each(function() {
  1591. if(!this) return;
  1592. var $this = $(this);
  1593. var picker = $this.data("picker");
  1594. if(!picker) {
  1595. params = params || {};
  1596. var inputValue = $this.val();
  1597. if(params.value === undefined && inputValue !== "") {
  1598. params.value = params.cols.length > 1 ? inputValue.split(" ") : [inputValue];
  1599. }
  1600. var p = $.extend({input: this}, params);
  1601. picker = new Picker(p);
  1602. $this.data("picker", picker);
  1603. }
  1604. if(typeof params === typeof "a") {
  1605. picker[params].apply(picker, Array.prototype.slice.call(args, 1));
  1606. }
  1607. });
  1608. };
  1609. }($);
  1610. /* global $:true */
  1611. + function($) {
  1612. "use strict";
  1613. var defaults;
  1614. var Select = function(input, config) {
  1615. var self = this;
  1616. this.config = config;
  1617. this.$input = $(input);
  1618. var tpl = $.t7.compile("<div class='weui-picker-modal weui-select-modal'>" + config.toolbarTemplate + (config.multi ? config.checkboxTemplate : config.radioTemplate) + "</div>");
  1619. this.$input.prop("readOnly", true);
  1620. this.$input.click(function() {
  1621. self.parseInitValue();
  1622. var dialog = self.dialog = $.openPicker(tpl({
  1623. items: config.items,
  1624. title: config.title,
  1625. closeText: config.closeText
  1626. }));
  1627. dialog.on("change", function(e) {
  1628. var checked = dialog.find("input:checked");
  1629. var values = checked.map(function() {
  1630. return $(this).val();
  1631. });
  1632. var titles = checked.map(function() {
  1633. return $(this).data("title");
  1634. });
  1635. self.updateInputValue(values, titles);
  1636. if(config.autoClose && !config.multi) $.closePicker();
  1637. });
  1638. });
  1639. $(document).on("click", function() {
  1640. });
  1641. }
  1642. Select.prototype.updateInputValue = function(values, titles) {
  1643. var v, t;
  1644. if(this.config.multi) {
  1645. v = values.join(this.config.split);
  1646. t = titles.join(this.config.split);
  1647. } else {
  1648. v = values[0];
  1649. t = titles[0];
  1650. }
  1651. this.$input.val(t).data("values", v);
  1652. this.$input.attr("value", t).attr("data-values", v);
  1653. }
  1654. Select.prototype.parseInitValue = function() {
  1655. var value = this.$input.val();
  1656. var items = this.config.items;
  1657. if(value === undefined || value == null || value === "") return;
  1658. var titles = this.config.multi ? value.split(this.config.split) : [value];
  1659. for(var i=0;i<items.length;i++) {
  1660. items[i].checked = false;
  1661. for(var j=0;j<titles.length;j++) {
  1662. if(items[i].title === titles[j]) {
  1663. items[i].checked = true;
  1664. }
  1665. }
  1666. }
  1667. }
  1668. $.fn.select = function(params) {
  1669. var config = $.extend({}, defaults, params);
  1670. if(!config.items || !config.items.length) return;
  1671. config.items = config.items.map(function(d, i) {
  1672. if(typeof d == typeof "a") {
  1673. return {
  1674. title: d,
  1675. value: d
  1676. };
  1677. }
  1678. return d;
  1679. });
  1680. return this.each(function() {
  1681. var $this = $(this);
  1682. if(!$this.data("weui-select")) $this.data("weui-select", new Select(this, config));
  1683. var select = $this.data("weui-select");
  1684. return select;
  1685. });
  1686. }
  1687. defaults = $.fn.select.prototype.defaults = {
  1688. items: [],
  1689. title: "请选择",
  1690. multi: false,
  1691. closeText: "关闭",
  1692. autoClose: true, //是否选择完成后自动关闭,只有单选模式下才有效
  1693. split: ",", //多选模式下的分隔符
  1694. toolbarTemplate: '<div class="toolbar">\
  1695. <div class="toolbar-inner">\
  1696. <a href="javascript:;" class="picker-button close-picker">{{closeText}}</a>\
  1697. <h1 class="title">{{title}}</h1>\
  1698. </div>\
  1699. </div>',
  1700. radioTemplate:
  1701. '<div class="weui_cells weui_cells_radio">\
  1702. {{#items}}\
  1703. <label class="weui_cell weui_check_label" for="weui-select-id-{{this.title}}">\
  1704. <div class="weui_cell_bd weui_cell_primary">\
  1705. <p>{{this.title}}</p>\
  1706. </div>\
  1707. <div class="weui_cell_ft">\
  1708. <input type="radio" class="weui_check" name="weui-select" id="weui-select-id-{{this.title}}" value="{{this.value}}" {{#if this.checked}}checked="checked"{{/if}} data-title="{{this.title}}">\
  1709. <span class="weui_icon_checked"></span>\
  1710. </div>\
  1711. </label>\
  1712. {{/items}}\
  1713. </div>',
  1714. checkboxTemplate:
  1715. '<div class="weui_cells weui_cells_checkbox">\
  1716. {{#items}}\
  1717. <label class="weui_cell weui_check_label" for="weui-select-id-{{this.title}}">\
  1718. <div class="weui_cell_bd weui_cell_primary">\
  1719. <p>{{this.title}}</p>\
  1720. </div>\
  1721. <div class="weui_cell_ft">\
  1722. <input type="checkbox" class="weui_check" name="weui-select" id="weui-select-id-{{this.title}}" value="{{this.value}}" {{#if this.checked}}checked="checked"{{/if}} data-title="{{this.title}}" >\
  1723. <span class="weui_icon_checked"></span>\
  1724. </div>\
  1725. </label>\
  1726. {{/items}}\
  1727. </div>',
  1728. }
  1729. }($);
  1730. /*======================================================
  1731. ************ Calendar ************
  1732. ======================================================*/
  1733. /* global $:true */
  1734. /*jshint unused: false*/
  1735. +function ($) {
  1736. "use strict";
  1737. var rtl = false;
  1738. var defaults;
  1739. var Calendar = function (params) {
  1740. var p = this;
  1741. params = params || {};
  1742. for (var def in defaults) {
  1743. if (typeof params[def] === 'undefined') {
  1744. params[def] = defaults[def];
  1745. }
  1746. }
  1747. p.params = params;
  1748. p.initialized = false;
  1749. // Inline flag
  1750. p.inline = p.params.container ? true : false;
  1751. // Is horizontal
  1752. p.isH = p.params.direction === 'horizontal';
  1753. // RTL inverter
  1754. var inverter = p.isH ? (rtl ? -1 : 1) : 1;
  1755. // Animating flag
  1756. p.animating = false;
  1757. // Should be converted to popover
  1758. function isPopover() {
  1759. var toPopover = false;
  1760. if (!p.params.convertToPopover && !p.params.onlyInPopover) return toPopover;
  1761. if (!p.inline && p.params.input) {
  1762. if (p.params.onlyInPopover) toPopover = true;
  1763. else {
  1764. if ($.device.ios) {
  1765. toPopover = $.device.ipad ? true : false;
  1766. }
  1767. else {
  1768. if ($(window).width() >= 768) toPopover = true;
  1769. }
  1770. }
  1771. }
  1772. return toPopover;
  1773. }
  1774. function inPopover() {
  1775. if (p.opened && p.container && p.container.length > 0 && p.container.parents('.popover').length > 0) return true;
  1776. else return false;
  1777. }
  1778. // Format date
  1779. function formatDate(date) {
  1780. date = new Date(date);
  1781. var year = date.getFullYear();
  1782. var month = date.getMonth();
  1783. var month1 = month + 1;
  1784. var day = date.getDate();
  1785. var weekDay = date.getDay();
  1786. return p.params.dateFormat
  1787. .replace(/yyyy/g, year)
  1788. .replace(/yy/g, (year + '').substring(2))
  1789. .replace(/mm/g, month1 < 10 ? '0' + month1 : month1)
  1790. .replace(/m/g, month1)
  1791. .replace(/MM/g, p.params.monthNames[month])
  1792. .replace(/M/g, p.params.monthNamesShort[month])
  1793. .replace(/dd/g, day < 10 ? '0' + day : day)
  1794. .replace(/d/g, day)
  1795. .replace(/DD/g, p.params.dayNames[weekDay])
  1796. .replace(/D/g, p.params.dayNamesShort[weekDay]);
  1797. }
  1798. // Value
  1799. p.addValue = function (value) {
  1800. if (p.params.multiple) {
  1801. if (!p.value) p.value = [];
  1802. var inValuesIndex;
  1803. for (var i = 0; i < p.value.length; i++) {
  1804. if (new Date(value).getTime() === new Date(p.value[i]).getTime()) {
  1805. inValuesIndex = i;
  1806. }
  1807. }
  1808. if (typeof inValuesIndex === 'undefined') {
  1809. p.value.push(value);
  1810. }
  1811. else {
  1812. p.value.splice(inValuesIndex, 1);
  1813. }
  1814. p.updateValue();
  1815. }
  1816. else {
  1817. p.value = [value];
  1818. p.updateValue();
  1819. }
  1820. };
  1821. p.setValue = function (arrValues) {
  1822. p.value = arrValues;
  1823. p.updateValue();
  1824. };
  1825. p.updateValue = function () {
  1826. p.wrapper.find('.picker-calendar-day-selected').removeClass('picker-calendar-day-selected');
  1827. var i, inputValue;
  1828. for (i = 0; i < p.value.length; i++) {
  1829. var valueDate = new Date(p.value[i]);
  1830. p.wrapper.find('.picker-calendar-day[data-date="' + valueDate.getFullYear() + '-' + valueDate.getMonth() + '-' + valueDate.getDate() + '"]').addClass('picker-calendar-day-selected');
  1831. }
  1832. if (p.params.onChange) {
  1833. p.params.onChange(p, p.value, p.value.map(formatDate));
  1834. }
  1835. if (p.input && p.input.length > 0) {
  1836. if (p.params.formatValue) inputValue = p.params.formatValue(p, p.value);
  1837. else {
  1838. inputValue = [];
  1839. for (i = 0; i < p.value.length; i++) {
  1840. inputValue.push(formatDate(p.value[i]));
  1841. }
  1842. inputValue = inputValue.join(', ');
  1843. }
  1844. $(p.input).val(inputValue);
  1845. $(p.input).trigger('change');
  1846. }
  1847. };
  1848. // Columns Handlers
  1849. p.initCalendarEvents = function () {
  1850. var col;
  1851. var allowItemClick = true;
  1852. var isTouched, isMoved, touchStartX, touchStartY, touchCurrentX, touchCurrentY, touchStartTime, touchEndTime, startTranslate, currentTranslate, wrapperWidth, wrapperHeight, percentage, touchesDiff, isScrolling;
  1853. function handleTouchStart (e) {
  1854. if (isMoved || isTouched) return;
  1855. // e.preventDefault();
  1856. isTouched = true;
  1857. var position = $.getTouchPosition(e);
  1858. touchStartX = touchCurrentY = position.x;
  1859. touchStartY = touchCurrentY = position.y;
  1860. touchStartTime = (new Date()).getTime();
  1861. percentage = 0;
  1862. allowItemClick = true;
  1863. isScrolling = undefined;
  1864. startTranslate = currentTranslate = p.monthsTranslate;
  1865. }
  1866. function handleTouchMove (e) {
  1867. if (!isTouched) return;
  1868. var position = $.getTouchPosition(e);
  1869. touchCurrentX = position.x;
  1870. touchCurrentY = position.y;
  1871. if (typeof isScrolling === 'undefined') {
  1872. isScrolling = !!(isScrolling || Math.abs(touchCurrentY - touchStartY) > Math.abs(touchCurrentX - touchStartX));
  1873. }
  1874. if (p.isH && isScrolling) {
  1875. isTouched = false;
  1876. return;
  1877. }
  1878. e.preventDefault();
  1879. if (p.animating) {
  1880. isTouched = false;
  1881. return;
  1882. }
  1883. allowItemClick = false;
  1884. if (!isMoved) {
  1885. // First move
  1886. isMoved = true;
  1887. wrapperWidth = p.wrapper[0].offsetWidth;
  1888. wrapperHeight = p.wrapper[0].offsetHeight;
  1889. p.wrapper.transition(0);
  1890. }
  1891. e.preventDefault();
  1892. touchesDiff = p.isH ? touchCurrentX - touchStartX : touchCurrentY - touchStartY;
  1893. percentage = touchesDiff/(p.isH ? wrapperWidth : wrapperHeight);
  1894. currentTranslate = (p.monthsTranslate * inverter + percentage) * 100;
  1895. // Transform wrapper
  1896. p.wrapper.transform('translate3d(' + (p.isH ? currentTranslate : 0) + '%, ' + (p.isH ? 0 : currentTranslate) + '%, 0)');
  1897. }
  1898. function handleTouchEnd (e) {
  1899. if (!isTouched || !isMoved) {
  1900. isTouched = isMoved = false;
  1901. return;
  1902. }
  1903. isTouched = isMoved = false;
  1904. touchEndTime = new Date().getTime();
  1905. if (touchEndTime - touchStartTime < 300) {
  1906. if (Math.abs(touchesDiff) < 10) {
  1907. p.resetMonth();
  1908. }
  1909. else if (touchesDiff >= 10) {
  1910. if (rtl) p.nextMonth();
  1911. else p.prevMonth();
  1912. }
  1913. else {
  1914. if (rtl) p.prevMonth();
  1915. else p.nextMonth();
  1916. }
  1917. }
  1918. else {
  1919. if (percentage <= -0.5) {
  1920. if (rtl) p.prevMonth();
  1921. else p.nextMonth();
  1922. }
  1923. else if (percentage >= 0.5) {
  1924. if (rtl) p.nextMonth();
  1925. else p.prevMonth();
  1926. }
  1927. else {
  1928. p.resetMonth();
  1929. }
  1930. }
  1931. // Allow click
  1932. setTimeout(function () {
  1933. allowItemClick = true;
  1934. }, 100);
  1935. }
  1936. function handleDayClick(e) {
  1937. if (!allowItemClick) return;
  1938. var day = $(e.target).parents('.picker-calendar-day');
  1939. if (day.length === 0 && $(e.target).hasClass('picker-calendar-day')) {
  1940. day = $(e.target);
  1941. }
  1942. if (day.length === 0) return;
  1943. if (day.hasClass('picker-calendar-day-selected') && !p.params.multiple) return;
  1944. if (day.hasClass('picker-calendar-day-disabled')) return;
  1945. if (day.hasClass('picker-calendar-day-next')) p.nextMonth();
  1946. if (day.hasClass('picker-calendar-day-prev')) p.prevMonth();
  1947. var dateYear = day.attr('data-year');
  1948. var dateMonth = day.attr('data-month');
  1949. var dateDay = day.attr('data-day');
  1950. if (p.params.onDayClick) {
  1951. p.params.onDayClick(p, day[0], dateYear, dateMonth, dateDay);
  1952. }
  1953. p.addValue(new Date(dateYear, dateMonth, dateDay).getTime());
  1954. if (p.params.closeOnSelect) p.close();
  1955. }
  1956. p.container.find('.picker-calendar-prev-month').on('click', p.prevMonth);
  1957. p.container.find('.picker-calendar-next-month').on('click', p.nextMonth);
  1958. p.container.find('.picker-calendar-prev-year').on('click', p.prevYear);
  1959. p.container.find('.picker-calendar-next-year').on('click', p.nextYear);
  1960. p.wrapper.on('click', handleDayClick);
  1961. if (p.params.touchMove) {
  1962. p.wrapper.on($.touchEvents.start, handleTouchStart);
  1963. p.wrapper.on($.touchEvents.move, handleTouchMove);
  1964. p.wrapper.on($.touchEvents.end, handleTouchEnd);
  1965. }
  1966. p.container[0].f7DestroyCalendarEvents = function () {
  1967. p.container.find('.picker-calendar-prev-month').off('click', p.prevMonth);
  1968. p.container.find('.picker-calendar-next-month').off('click', p.nextMonth);
  1969. p.container.find('.picker-calendar-prev-year').off('click', p.prevYear);
  1970. p.container.find('.picker-calendar-next-year').off('click', p.nextYear);
  1971. p.wrapper.off('click', handleDayClick);
  1972. if (p.params.touchMove) {
  1973. p.wrapper.off($.touchEvents.start, handleTouchStart);
  1974. p.wrapper.off($.touchEvents.move, handleTouchMove);
  1975. p.wrapper.off($.touchEvents.end, handleTouchEnd);
  1976. }
  1977. };
  1978. };
  1979. p.destroyCalendarEvents = function (colContainer) {
  1980. if ('f7DestroyCalendarEvents' in p.container[0]) p.container[0].f7DestroyCalendarEvents();
  1981. };
  1982. // Calendar Methods
  1983. p.daysInMonth = function (date) {
  1984. var d = new Date(date);
  1985. return new Date(d.getFullYear(), d.getMonth() + 1, 0).getDate();
  1986. };
  1987. p.monthHTML = function (date, offset) {
  1988. date = new Date(date);
  1989. var year = date.getFullYear(),
  1990. month = date.getMonth(),
  1991. day = date.getDate();
  1992. if (offset === 'next') {
  1993. if (month === 11) date = new Date(year + 1, 0);
  1994. else date = new Date(year, month + 1, 1);
  1995. }
  1996. if (offset === 'prev') {
  1997. if (month === 0) date = new Date(year - 1, 11);
  1998. else date = new Date(year, month - 1, 1);
  1999. }
  2000. if (offset === 'next' || offset === 'prev') {
  2001. month = date.getMonth();
  2002. year = date.getFullYear();
  2003. }
  2004. var daysInPrevMonth = p.daysInMonth(new Date(date.getFullYear(), date.getMonth()).getTime() - 10 * 24 * 60 * 60 * 1000),
  2005. daysInMonth = p.daysInMonth(date),
  2006. firstDayOfMonthIndex = new Date(date.getFullYear(), date.getMonth()).getDay();
  2007. if (firstDayOfMonthIndex === 0) firstDayOfMonthIndex = 7;
  2008. var dayDate, currentValues = [], i, j,
  2009. rows = 6, cols = 7,
  2010. monthHTML = '',
  2011. dayIndex = 0 + (p.params.firstDay - 1),
  2012. today = new Date().setHours(0,0,0,0),
  2013. minDate = p.params.minDate ? new Date(p.params.minDate).getTime() : null,
  2014. maxDate = p.params.maxDate ? new Date(p.params.maxDate).getTime() : null;
  2015. if (p.value && p.value.length) {
  2016. for (i = 0; i < p.value.length; i++) {
  2017. currentValues.push(new Date(p.value[i]).setHours(0,0,0,0));
  2018. }
  2019. }
  2020. for (i = 1; i <= rows; i++) {
  2021. var rowHTML = '';
  2022. var row = i;
  2023. for (j = 1; j <= cols; j++) {
  2024. var col = j;
  2025. dayIndex ++;
  2026. var dayNumber = dayIndex - firstDayOfMonthIndex;
  2027. var addClass = '';
  2028. if (dayNumber < 0) {
  2029. dayNumber = daysInPrevMonth + dayNumber + 1;
  2030. addClass += ' picker-calendar-day-prev';
  2031. dayDate = new Date(month - 1 < 0 ? year - 1 : year, month - 1 < 0 ? 11 : month - 1, dayNumber).getTime();
  2032. }
  2033. else {
  2034. dayNumber = dayNumber + 1;
  2035. if (dayNumber > daysInMonth) {
  2036. dayNumber = dayNumber - daysInMonth;
  2037. addClass += ' picker-calendar-day-next';
  2038. dayDate = new Date(month + 1 > 11 ? year + 1 : year, month + 1 > 11 ? 0 : month + 1, dayNumber).getTime();
  2039. }
  2040. else {
  2041. dayDate = new Date(year, month, dayNumber).getTime();
  2042. }
  2043. }
  2044. // Today
  2045. if (dayDate === today) addClass += ' picker-calendar-day-today';
  2046. // Selected
  2047. if (currentValues.indexOf(dayDate) >= 0) addClass += ' picker-calendar-day-selected';
  2048. // Weekend
  2049. if (p.params.weekendDays.indexOf(col - 1) >= 0) {
  2050. addClass += ' picker-calendar-day-weekend';
  2051. }
  2052. // Disabled
  2053. if ((minDate && dayDate < minDate) || (maxDate && dayDate > maxDate)) {
  2054. addClass += ' picker-calendar-day-disabled';
  2055. }
  2056. dayDate = new Date(dayDate);
  2057. var dayYear = dayDate.getFullYear();
  2058. var dayMonth = dayDate.getMonth();
  2059. rowHTML += '<div data-year="' + dayYear + '" data-month="' + dayMonth + '" data-day="' + dayNumber + '" class="picker-calendar-day' + (addClass) + '" data-date="' + (dayYear + '-' + dayMonth + '-' + dayNumber) + '"><span>'+dayNumber+'</span></div>';
  2060. }
  2061. monthHTML += '<div class="picker-calendar-row">' + rowHTML + '</div>';
  2062. }
  2063. monthHTML = '<div class="picker-calendar-month" data-year="' + year + '" data-month="' + month + '">' + monthHTML + '</div>';
  2064. return monthHTML;
  2065. };
  2066. p.animating = false;
  2067. p.updateCurrentMonthYear = function (dir) {
  2068. if (typeof dir === 'undefined') {
  2069. p.currentMonth = parseInt(p.months.eq(1).attr('data-month'), 10);
  2070. p.currentYear = parseInt(p.months.eq(1).attr('data-year'), 10);
  2071. }
  2072. else {
  2073. p.currentMonth = parseInt(p.months.eq(dir === 'next' ? (p.months.length - 1) : 0).attr('data-month'), 10);
  2074. p.currentYear = parseInt(p.months.eq(dir === 'next' ? (p.months.length - 1) : 0).attr('data-year'), 10);
  2075. }
  2076. p.container.find('.current-month-value').text(p.params.monthNames[p.currentMonth]);
  2077. p.container.find('.current-year-value').text(p.currentYear);
  2078. };
  2079. p.onMonthChangeStart = function (dir) {
  2080. p.updateCurrentMonthYear(dir);
  2081. p.months.removeClass('picker-calendar-month-current picker-calendar-month-prev picker-calendar-month-next');
  2082. var currentIndex = dir === 'next' ? p.months.length - 1 : 0;
  2083. p.months.eq(currentIndex).addClass('picker-calendar-month-current');
  2084. p.months.eq(dir === 'next' ? currentIndex - 1 : currentIndex + 1).addClass(dir === 'next' ? 'picker-calendar-month-prev' : 'picker-calendar-month-next');
  2085. if (p.params.onMonthYearChangeStart) {
  2086. p.params.onMonthYearChangeStart(p, p.currentYear, p.currentMonth);
  2087. }
  2088. };
  2089. p.onMonthChangeEnd = function (dir, rebuildBoth) {
  2090. p.animating = false;
  2091. var nextMonthHTML, prevMonthHTML, newMonthHTML;
  2092. p.wrapper.find('.picker-calendar-month:not(.picker-calendar-month-prev):not(.picker-calendar-month-current):not(.picker-calendar-month-next)').remove();
  2093. if (typeof dir === 'undefined') {
  2094. dir = 'next';
  2095. rebuildBoth = true;
  2096. }
  2097. if (!rebuildBoth) {
  2098. newMonthHTML = p.monthHTML(new Date(p.currentYear, p.currentMonth), dir);
  2099. }
  2100. else {
  2101. p.wrapper.find('.picker-calendar-month-next, .picker-calendar-month-prev').remove();
  2102. prevMonthHTML = p.monthHTML(new Date(p.currentYear, p.currentMonth), 'prev');
  2103. nextMonthHTML = p.monthHTML(new Date(p.currentYear, p.currentMonth), 'next');
  2104. }
  2105. if (dir === 'next' || rebuildBoth) {
  2106. p.wrapper.append(newMonthHTML || nextMonthHTML);
  2107. }
  2108. if (dir === 'prev' || rebuildBoth) {
  2109. p.wrapper.prepend(newMonthHTML || prevMonthHTML);
  2110. }
  2111. p.months = p.wrapper.find('.picker-calendar-month');
  2112. p.setMonthsTranslate(p.monthsTranslate);
  2113. if (p.params.onMonthAdd) {
  2114. p.params.onMonthAdd(p, dir === 'next' ? p.months.eq(p.months.length - 1)[0] : p.months.eq(0)[0]);
  2115. }
  2116. if (p.params.onMonthYearChangeEnd) {
  2117. p.params.onMonthYearChangeEnd(p, p.currentYear, p.currentMonth);
  2118. }
  2119. };
  2120. p.setMonthsTranslate = function (translate) {
  2121. translate = translate || p.monthsTranslate || 0;
  2122. if (typeof p.monthsTranslate === 'undefined') p.monthsTranslate = translate;
  2123. p.months.removeClass('picker-calendar-month-current picker-calendar-month-prev picker-calendar-month-next');
  2124. var prevMonthTranslate = -(translate + 1) * 100 * inverter;
  2125. var currentMonthTranslate = -translate * 100 * inverter;
  2126. var nextMonthTranslate = -(translate - 1) * 100 * inverter;
  2127. p.months.eq(0).transform('translate3d(' + (p.isH ? prevMonthTranslate : 0) + '%, ' + (p.isH ? 0 : prevMonthTranslate) + '%, 0)').addClass('picker-calendar-month-prev');
  2128. p.months.eq(1).transform('translate3d(' + (p.isH ? currentMonthTranslate : 0) + '%, ' + (p.isH ? 0 : currentMonthTranslate) + '%, 0)').addClass('picker-calendar-month-current');
  2129. p.months.eq(2).transform('translate3d(' + (p.isH ? nextMonthTranslate : 0) + '%, ' + (p.isH ? 0 : nextMonthTranslate) + '%, 0)').addClass('picker-calendar-month-next');
  2130. };
  2131. p.nextMonth = function (transition) {
  2132. if (typeof transition === 'undefined' || typeof transition === 'object') {
  2133. transition = '';
  2134. if (!p.params.animate) transition = 0;
  2135. }
  2136. var nextMonth = parseInt(p.months.eq(p.months.length - 1).attr('data-month'), 10);
  2137. var nextYear = parseInt(p.months.eq(p.months.length - 1).attr('data-year'), 10);
  2138. var nextDate = new Date(nextYear, nextMonth);
  2139. var nextDateTime = nextDate.getTime();
  2140. var transitionEndCallback = p.animating ? false : true;
  2141. if (p.params.maxDate) {
  2142. if (nextDateTime > new Date(p.params.maxDate).getTime()) {
  2143. return p.resetMonth();
  2144. }
  2145. }
  2146. p.monthsTranslate --;
  2147. if (nextMonth === p.currentMonth) {
  2148. var nextMonthTranslate = -(p.monthsTranslate) * 100 * inverter;
  2149. var nextMonthHTML = $(p.monthHTML(nextDateTime, 'next')).transform('translate3d(' + (p.isH ? nextMonthTranslate : 0) + '%, ' + (p.isH ? 0 : nextMonthTranslate) + '%, 0)').addClass('picker-calendar-month-next');
  2150. p.wrapper.append(nextMonthHTML[0]);
  2151. p.months = p.wrapper.find('.picker-calendar-month');
  2152. if (p.params.onMonthAdd) {
  2153. p.params.onMonthAdd(p, p.months.eq(p.months.length - 1)[0]);
  2154. }
  2155. }
  2156. p.animating = true;
  2157. p.onMonthChangeStart('next');
  2158. var translate = (p.monthsTranslate * 100) * inverter;
  2159. p.wrapper.transition(transition).transform('translate3d(' + (p.isH ? translate : 0) + '%, ' + (p.isH ? 0 : translate) + '%, 0)');
  2160. if (transitionEndCallback) {
  2161. p.wrapper.transitionEnd(function () {
  2162. p.onMonthChangeEnd('next');
  2163. });
  2164. }
  2165. if (!p.params.animate) {
  2166. p.onMonthChangeEnd('next');
  2167. }
  2168. };
  2169. p.prevMonth = function (transition) {
  2170. if (typeof transition === 'undefined' || typeof transition === 'object') {
  2171. transition = '';
  2172. if (!p.params.animate) transition = 0;
  2173. }
  2174. var prevMonth = parseInt(p.months.eq(0).attr('data-month'), 10);
  2175. var prevYear = parseInt(p.months.eq(0).attr('data-year'), 10);
  2176. var prevDate = new Date(prevYear, prevMonth + 1, -1);
  2177. var prevDateTime = prevDate.getTime();
  2178. var transitionEndCallback = p.animating ? false : true;
  2179. if (p.params.minDate) {
  2180. if (prevDateTime < new Date(p.params.minDate).getTime()) {
  2181. return p.resetMonth();
  2182. }
  2183. }
  2184. p.monthsTranslate ++;
  2185. if (prevMonth === p.currentMonth) {
  2186. var prevMonthTranslate = -(p.monthsTranslate) * 100 * inverter;
  2187. var prevMonthHTML = $(p.monthHTML(prevDateTime, 'prev')).transform('translate3d(' + (p.isH ? prevMonthTranslate : 0) + '%, ' + (p.isH ? 0 : prevMonthTranslate) + '%, 0)').addClass('picker-calendar-month-prev');
  2188. p.wrapper.prepend(prevMonthHTML[0]);
  2189. p.months = p.wrapper.find('.picker-calendar-month');
  2190. if (p.params.onMonthAdd) {
  2191. p.params.onMonthAdd(p, p.months.eq(0)[0]);
  2192. }
  2193. }
  2194. p.animating = true;
  2195. p.onMonthChangeStart('prev');
  2196. var translate = (p.monthsTranslate * 100) * inverter;
  2197. p.wrapper.transition(transition).transform('translate3d(' + (p.isH ? translate : 0) + '%, ' + (p.isH ? 0 : translate) + '%, 0)');
  2198. if (transitionEndCallback) {
  2199. p.wrapper.transitionEnd(function () {
  2200. p.onMonthChangeEnd('prev');
  2201. });
  2202. }
  2203. if (!p.params.animate) {
  2204. p.onMonthChangeEnd('prev');
  2205. }
  2206. };
  2207. p.resetMonth = function (transition) {
  2208. if (typeof transition === 'undefined') transition = '';
  2209. var translate = (p.monthsTranslate * 100) * inverter;
  2210. p.wrapper.transition(transition).transform('translate3d(' + (p.isH ? translate : 0) + '%, ' + (p.isH ? 0 : translate) + '%, 0)');
  2211. };
  2212. p.setYearMonth = function (year, month, transition) {
  2213. if (typeof year === 'undefined') year = p.currentYear;
  2214. if (typeof month === 'undefined') month = p.currentMonth;
  2215. if (typeof transition === 'undefined' || typeof transition === 'object') {
  2216. transition = '';
  2217. if (!p.params.animate) transition = 0;
  2218. }
  2219. var targetDate;
  2220. if (year < p.currentYear) {
  2221. targetDate = new Date(year, month + 1, -1).getTime();
  2222. }
  2223. else {
  2224. targetDate = new Date(year, month).getTime();
  2225. }
  2226. if (p.params.maxDate && targetDate > new Date(p.params.maxDate).getTime()) {
  2227. return false;
  2228. }
  2229. if (p.params.minDate && targetDate < new Date(p.params.minDate).getTime()) {
  2230. return false;
  2231. }
  2232. var currentDate = new Date(p.currentYear, p.currentMonth).getTime();
  2233. var dir = targetDate > currentDate ? 'next' : 'prev';
  2234. var newMonthHTML = p.monthHTML(new Date(year, month));
  2235. p.monthsTranslate = p.monthsTranslate || 0;
  2236. var prevTranslate = p.monthsTranslate;
  2237. var monthTranslate, wrapperTranslate;
  2238. var transitionEndCallback = p.animating ? false : true;
  2239. if (targetDate > currentDate) {
  2240. // To next
  2241. p.monthsTranslate --;
  2242. if (!p.animating) p.months.eq(p.months.length - 1).remove();
  2243. p.wrapper.append(newMonthHTML);
  2244. p.months = p.wrapper.find('.picker-calendar-month');
  2245. monthTranslate = -(prevTranslate - 1) * 100 * inverter;
  2246. p.months.eq(p.months.length - 1).transform('translate3d(' + (p.isH ? monthTranslate : 0) + '%, ' + (p.isH ? 0 : monthTranslate) + '%, 0)').addClass('picker-calendar-month-next');
  2247. }
  2248. else {
  2249. // To prev
  2250. p.monthsTranslate ++;
  2251. if (!p.animating) p.months.eq(0).remove();
  2252. p.wrapper.prepend(newMonthHTML);
  2253. p.months = p.wrapper.find('.picker-calendar-month');
  2254. monthTranslate = -(prevTranslate + 1) * 100 * inverter;
  2255. p.months.eq(0).transform('translate3d(' + (p.isH ? monthTranslate : 0) + '%, ' + (p.isH ? 0 : monthTranslate) + '%, 0)').addClass('picker-calendar-month-prev');
  2256. }
  2257. if (p.params.onMonthAdd) {
  2258. p.params.onMonthAdd(p, dir === 'next' ? p.months.eq(p.months.length - 1)[0] : p.months.eq(0)[0]);
  2259. }
  2260. p.animating = true;
  2261. p.onMonthChangeStart(dir);
  2262. wrapperTranslate = (p.monthsTranslate * 100) * inverter;
  2263. p.wrapper.transition(transition).transform('translate3d(' + (p.isH ? wrapperTranslate : 0) + '%, ' + (p.isH ? 0 : wrapperTranslate) + '%, 0)');
  2264. if (transitionEndCallback) {
  2265. p.wrapper.transitionEnd(function () {
  2266. p.onMonthChangeEnd(dir, true);
  2267. });
  2268. }
  2269. if (!p.params.animate) {
  2270. p.onMonthChangeEnd(dir);
  2271. }
  2272. };
  2273. p.nextYear = function () {
  2274. p.setYearMonth(p.currentYear + 1);
  2275. };
  2276. p.prevYear = function () {
  2277. p.setYearMonth(p.currentYear - 1);
  2278. };
  2279. // HTML Layout
  2280. p.layout = function () {
  2281. var pickerHTML = '';
  2282. var pickerClass = '';
  2283. var i;
  2284. var layoutDate = p.value && p.value.length ? p.value[0] : new Date().setHours(0,0,0,0);
  2285. var prevMonthHTML = p.monthHTML(layoutDate, 'prev');
  2286. var currentMonthHTML = p.monthHTML(layoutDate);
  2287. var nextMonthHTML = p.monthHTML(layoutDate, 'next');
  2288. var monthsHTML = '<div class="picker-calendar-months"><div class="picker-calendar-months-wrapper">' + (prevMonthHTML + currentMonthHTML + nextMonthHTML) + '</div></div>';
  2289. // Week days header
  2290. var weekHeaderHTML = '';
  2291. if (p.params.weekHeader) {
  2292. for (i = 0; i < 7; i++) {
  2293. var weekDayIndex = (i + p.params.firstDay > 6) ? (i - 7 + p.params.firstDay) : (i + p.params.firstDay);
  2294. var dayName = p.params.dayNamesShort[weekDayIndex];
  2295. weekHeaderHTML += '<div class="picker-calendar-week-day ' + ((p.params.weekendDays.indexOf(weekDayIndex) >= 0) ? 'picker-calendar-week-day-weekend' : '') + '"> ' + dayName + '</div>';
  2296. }
  2297. weekHeaderHTML = '<div class="picker-calendar-week-days">' + weekHeaderHTML + '</div>';
  2298. }
  2299. pickerClass = 'weui-picker-modal weui-picker-calendar ' + (p.params.cssClass || '');
  2300. var toolbarHTML = p.params.toolbar ? p.params.toolbarTemplate.replace(/{{closeText}}/g, p.params.toolbarCloseText) : '';
  2301. if (p.params.toolbar) {
  2302. toolbarHTML = p.params.toolbarTemplate
  2303. .replace(/{{closeText}}/g, p.params.toolbarCloseText)
  2304. .replace(/{{monthPicker}}/g, (p.params.monthPicker ? p.params.monthPickerTemplate : ''))
  2305. .replace(/{{yearPicker}}/g, (p.params.yearPicker ? p.params.yearPickerTemplate : ''));
  2306. }
  2307. pickerHTML =
  2308. '<div class="' + (pickerClass) + '">' +
  2309. toolbarHTML +
  2310. '<div class="picker-modal-inner">' +
  2311. weekHeaderHTML +
  2312. monthsHTML +
  2313. '</div>' +
  2314. '</div>';
  2315. p.pickerHTML = pickerHTML;
  2316. };
  2317. // Input Events
  2318. function openOnInput(e) {
  2319. e.preventDefault();
  2320. if (p.opened) return;
  2321. p.open();
  2322. if (p.params.scrollToInput && !isPopover()) {
  2323. var pageContent = p.input.parents('.page-content');
  2324. if (pageContent.length === 0) return;
  2325. var paddingTop = parseInt(pageContent.css('padding-top'), 10),
  2326. paddingBottom = parseInt(pageContent.css('padding-bottom'), 10),
  2327. pageHeight = pageContent[0].offsetHeight - paddingTop - p.container.height(),
  2328. pageScrollHeight = pageContent[0].scrollHeight - paddingTop - p.container.height(),
  2329. newPaddingBottom;
  2330. var inputTop = p.input.offset().top - paddingTop + p.input[0].offsetHeight;
  2331. if (inputTop > pageHeight) {
  2332. var scrollTop = pageContent.scrollTop() + inputTop - pageHeight;
  2333. if (scrollTop + pageHeight > pageScrollHeight) {
  2334. newPaddingBottom = scrollTop + pageHeight - pageScrollHeight + paddingBottom;
  2335. if (pageHeight === pageScrollHeight) {
  2336. newPaddingBottom = p.container.height();
  2337. }
  2338. pageContent.css({'padding-bottom': (newPaddingBottom) + 'px'});
  2339. }
  2340. pageContent.scrollTop(scrollTop, 300);
  2341. }
  2342. }
  2343. }
  2344. function closeOnHTMLClick(e) {
  2345. if (inPopover()) return;
  2346. if (p.input && p.input.length > 0) {
  2347. if (e.target !== p.input[0] && $(e.target).parents('.weui-picker-modal').length === 0) p.close();
  2348. }
  2349. else {
  2350. if ($(e.target).parents('.weui-picker-modal').length === 0) p.close();
  2351. }
  2352. }
  2353. if (p.params.input) {
  2354. p.input = $(p.params.input);
  2355. if (p.input.length > 0) {
  2356. if (p.params.inputReadOnly) p.input.prop('readOnly', true);
  2357. if (!p.inline) {
  2358. p.input.on('click', openOnInput);
  2359. }
  2360. if (p.params.inputReadOnly) {
  2361. p.input.on('focus mousedown', function (e) {
  2362. e.preventDefault();
  2363. });
  2364. }
  2365. }
  2366. }
  2367. //iphone 上无法正确触发 click,会导致点击外面无法关闭
  2368. if (!p.inline) $(document).on('click touchend', closeOnHTMLClick);
  2369. // Open
  2370. function onPickerClose() {
  2371. p.opened = false;
  2372. if (p.input && p.input.length > 0) p.input.parents('.page-content').css({'padding-bottom': ''});
  2373. if (p.params.onClose) p.params.onClose(p);
  2374. // Destroy events
  2375. p.destroyCalendarEvents();
  2376. }
  2377. p.opened = false;
  2378. p.open = function () {
  2379. var toPopover = isPopover();
  2380. var updateValue = false;
  2381. if (!p.opened) {
  2382. // Set date value
  2383. if (!p.value) {
  2384. if (p.params.value) {
  2385. p.value = p.params.value;
  2386. updateValue = true;
  2387. }
  2388. }
  2389. // Layout
  2390. p.layout();
  2391. // Append
  2392. if (toPopover) {
  2393. p.pickerHTML = '<div class="popover popover-picker-calendar"><div class="popover-inner">' + p.pickerHTML + '</div></div>';
  2394. p.popover = $.popover(p.pickerHTML, p.params.input, true);
  2395. p.container = $(p.popover).find('.weui-picker-modal');
  2396. $(p.popover).on('close', function () {
  2397. onPickerClose();
  2398. });
  2399. }
  2400. else if (p.inline) {
  2401. p.container = $(p.pickerHTML);
  2402. p.container.addClass('picker-modal-inline');
  2403. $(p.params.container).append(p.container);
  2404. }
  2405. else {
  2406. p.container = $($.openPicker(p.pickerHTML));
  2407. $(p.container)
  2408. .on('close', function () {
  2409. onPickerClose();
  2410. });
  2411. }
  2412. // Store calendar instance
  2413. p.container[0].f7Calendar = p;
  2414. p.wrapper = p.container.find('.picker-calendar-months-wrapper');
  2415. // Months
  2416. p.months = p.wrapper.find('.picker-calendar-month');
  2417. // Update current month and year
  2418. p.updateCurrentMonthYear();
  2419. // Set initial translate
  2420. p.monthsTranslate = 0;
  2421. p.setMonthsTranslate();
  2422. // Init events
  2423. p.initCalendarEvents();
  2424. // Update input value
  2425. if (updateValue) p.updateValue();
  2426. }
  2427. // Set flag
  2428. p.opened = true;
  2429. p.initialized = true;
  2430. if (p.params.onMonthAdd) {
  2431. p.months.each(function () {
  2432. p.params.onMonthAdd(p, this);
  2433. });
  2434. }
  2435. if (p.params.onOpen) p.params.onOpen(p);
  2436. };
  2437. // Close
  2438. p.close = function () {
  2439. if (!p.opened || p.inline) return;
  2440. if (inPopover()) {
  2441. $.closePicker(p.popover);
  2442. return;
  2443. }
  2444. else {
  2445. $.closePicker(p.container);
  2446. return;
  2447. }
  2448. };
  2449. // Destroy
  2450. p.destroy = function () {
  2451. p.close();
  2452. if (p.params.input && p.input.length > 0) {
  2453. p.input.off('click focus', openOnInput);
  2454. }
  2455. $('html').off('click', closeOnHTMLClick);
  2456. };
  2457. if (p.inline) {
  2458. p.open();
  2459. }
  2460. return p;
  2461. };
  2462. $.fn.calendar = function (params) {
  2463. params = params || {};
  2464. return this.each(function() {
  2465. var $this = $(this);
  2466. if(!$this[0]) return;
  2467. var p = {};
  2468. if($this[0].tagName.toUpperCase() === "INPUT") {
  2469. p.input = $this;
  2470. } else {
  2471. p.container = $this;
  2472. }
  2473. //默认显示今天
  2474. if(!params.value) {
  2475. var today = new Date();
  2476. params.value = [today.getFullYear() + "-" + (today.getMonth() + 1) + "-" + today.getDate()];
  2477. }
  2478. new Calendar($.extend(p, params));
  2479. });
  2480. };
  2481. defaults = $.fn.calendar.prototype.defaults = {
  2482. monthNames: ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月'],
  2483. monthNamesShort: ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月'],
  2484. dayNames: ['周日', '周一', '周二', '周三', '周四', '周五', '周六'],
  2485. dayNamesShort: ['周日', '周一', '周二', '周三', '周四', '周五', '周六'],
  2486. firstDay: 1, // First day of the week, Monday
  2487. weekendDays: [0, 6], // Sunday and Saturday
  2488. multiple: false,
  2489. dateFormat: 'yyyy-mm-dd',
  2490. direction: 'horizontal', // or 'vertical'
  2491. minDate: null,
  2492. maxDate: null,
  2493. touchMove: true,
  2494. animate: true,
  2495. closeOnSelect: true,
  2496. monthPicker: true,
  2497. monthPickerTemplate:
  2498. '<div class="picker-calendar-month-picker">' +
  2499. '<a href="#" class="link icon-only picker-calendar-prev-month"><i class="icon icon-prev"></i></a>' +
  2500. '<div class="current-month-value"></div>' +
  2501. '<a href="#" class="link icon-only picker-calendar-next-month"><i class="icon icon-next"></i></a>' +
  2502. '</div>',
  2503. yearPicker: true,
  2504. yearPickerTemplate:
  2505. '<div class="picker-calendar-year-picker">' +
  2506. '<a href="#" class="link icon-only picker-calendar-prev-year"><i class="icon icon-prev"></i></a>' +
  2507. '<span class="current-year-value"></span>' +
  2508. '<a href="#" class="link icon-only picker-calendar-next-year"><i class="icon icon-next"></i></a>' +
  2509. '</div>',
  2510. weekHeader: true,
  2511. // Common settings
  2512. scrollToInput: true,
  2513. inputReadOnly: true,
  2514. convertToPopover: true,
  2515. onlyInPopover: false,
  2516. toolbar: true,
  2517. toolbarCloseText: 'Done',
  2518. toolbarTemplate:
  2519. '<div class="toolbar">' +
  2520. '<div class="toolbar-inner">' +
  2521. '{{yearPicker}}' +
  2522. '{{monthPicker}}' +
  2523. // '<a href="#" class="link close-picker">{{closeText}}</a>' +
  2524. '</div>' +
  2525. '</div>',
  2526. /* Callbacks
  2527. onMonthAdd
  2528. onChange
  2529. onOpen
  2530. onClose
  2531. onDayClick
  2532. onMonthYearChangeStart
  2533. onMonthYearChangeEnd
  2534. */
  2535. };
  2536. }($);
  2537. /* global $:true */
  2538. /* jshint unused:false*/
  2539. + function($) {
  2540. "use strict";
  2541. var defaults;
  2542. $.fn.datetimePicker = function(params) {
  2543. params = $.extend({}, defaults, params);
  2544. return this.each(function() {
  2545. if(!this) return;
  2546. var today = new Date();
  2547. var getDays = function(max) {
  2548. var days = [];
  2549. for(var i=1; i<= (max||31);i++) {
  2550. days.push(i < 10 ? "0"+i : i);
  2551. }
  2552. return days;
  2553. };
  2554. var getDaysByMonthAndYear = function(month, year) {
  2555. var int_d = new Date(year, parseInt(month)+1-1, 1);
  2556. var d = new Date(int_d - 1);
  2557. return getDays(d.getDate());
  2558. };
  2559. var formatNumber = function (n) {
  2560. return n < 10 ? "0" + n : n;
  2561. };
  2562. var formatValue = function(values, displayValues) {
  2563. return values[0] + params.dateSplit + values[1] + params.dateSplit + values[2] + ' ' + values[3] + params.timeSplit + values[4];
  2564. }
  2565. var initMonthes = ('01 02 03 04 05 06 07 08 09 10 11 12').split(' ');
  2566. var initYears = (function () {
  2567. var arr = [];
  2568. for (var i = 1950; i <= 2030; i++) { arr.push(i); }
  2569. return arr;
  2570. })();
  2571. var lastValidValues;
  2572. var config = {
  2573. rotateEffect: false, //为了性能
  2574. value: [today.getFullYear(), formatNumber(today.getMonth()+1), formatNumber(today.getDate()), formatNumber(today.getHours()), formatNumber(today.getMinutes())],
  2575. onChange: function (picker, values, displayValues) {
  2576. var cols = picker.cols;
  2577. var days = getDaysByMonthAndYear(cols[1].value, cols[0].value);
  2578. var currentValue = picker.cols[2].value;
  2579. if(currentValue > days.length) currentValue = days.length;
  2580. picker.cols[2].setValue(currentValue);
  2581. //check min and max
  2582. var current = + new Date(formatValue(values, displayValues));
  2583. var valid = true;
  2584. if(params.min) {
  2585. var min = + new Date(params.min ? params.min : params.min());
  2586. if(current < min) {
  2587. picker.setValue(lastValidValues);
  2588. valid = false;
  2589. }
  2590. }
  2591. if(params.max) {
  2592. var max = + new Date(params.max ? params.max: params.max());
  2593. if(current > max) {
  2594. picker.setValue(lastValidValues);
  2595. valid = false;
  2596. }
  2597. }
  2598. valid && (lastValidValues = values);
  2599. },
  2600. formatValue: function (p, values, displayValues) {
  2601. return formatValue(values, displayValues);
  2602. },
  2603. cols: [
  2604. // Years
  2605. {
  2606. values: initYears
  2607. },
  2608. // Months
  2609. {
  2610. values: initMonthes
  2611. },
  2612. // Days
  2613. {
  2614. values: getDays()
  2615. },
  2616. // Space divider
  2617. {
  2618. divider: true,
  2619. content: ' '
  2620. },
  2621. // Hours
  2622. {
  2623. values: (function () {
  2624. var arr = [];
  2625. for (var i = 0; i <= 23; i++) { arr.push(formatNumber(i)); }
  2626. return arr;
  2627. })(),
  2628. },
  2629. // Divider
  2630. {
  2631. divider: true,
  2632. content: ':'
  2633. },
  2634. // Minutes
  2635. {
  2636. values: (function () {
  2637. var arr = [];
  2638. for (var i = 0; i <= 59; i++) { arr.push(formatNumber(i)); }
  2639. return arr;
  2640. })(),
  2641. }
  2642. ]
  2643. };
  2644. var inputValue = $(this).val();
  2645. if(params.value === undefined && inputValue !== "") {
  2646. params.value = [].concat(inputValue.split(" ")[0].split(params.dateSplit), inputValue.split(" ")[1].split(params.timeSplit));
  2647. }
  2648. var p = $.extend(config, params);
  2649. $(this).picker(p);
  2650. });
  2651. };
  2652. defaults = $.fn.datetimePicker.prototype.defaults = {
  2653. dateSplit: "-",
  2654. timeSplit: ":",
  2655. min: undefined,
  2656. max: undefined
  2657. }
  2658. }($);
  2659. /*======================================================
  2660. ************ Picker ************
  2661. ======================================================*/
  2662. /* global $:true */
  2663. + function($) {
  2664. "use strict";
  2665. //Popup 和 picker 之类的不要共用一个弹出方法,因为这样会导致 在 popup 中再弹出 picker 的时候会有问题。
  2666. $.openPopup = function(popup, className) {
  2667. $.closePopup();
  2668. popup = $(popup);
  2669. popup.addClass("weui-popup-container-visible");
  2670. var modal = popup.find(".weui-popup-modal");
  2671. modal.width();
  2672. modal.addClass("weui-popup-modal-visible");
  2673. }
  2674. $.closePopup = function(container, remove) {
  2675. $(".weui-popup-modal-visible").removeClass("weui-popup-modal-visible").transitionEnd(function() {
  2676. $(this).parent().removeClass("weui-popup-container-visible");
  2677. remove && $(this).parent().remove();
  2678. }).trigger("close");
  2679. };
  2680. $(document).on("click", ".close-popup", function() {
  2681. $.closePopup();
  2682. });
  2683. $(document).on("click", ".open-popup", function() {
  2684. $($(this).data("target")).popup();
  2685. });
  2686. $.fn.popup = function() {
  2687. return this.each(function() {
  2688. $.openPopup(this);
  2689. });
  2690. };
  2691. }($);
  2692. /* ===============================================================================
  2693. ************ Notification ************
  2694. =============================================================================== */
  2695. /* global $:true */
  2696. +function ($) {
  2697. "use strict";
  2698. var noti, defaults, timeout, start, diffX, diffY;
  2699. var touchStart = function(e) {
  2700. var p = $.getTouchPosition(e);
  2701. start = p;
  2702. diffX = diffY = 0;
  2703. noti.addClass("touching");
  2704. };
  2705. var touchMove = function(e) {
  2706. if(!start) return false;
  2707. e.preventDefault();
  2708. e.stopPropagation();
  2709. var p = $.getTouchPosition(e);
  2710. diffX = p.x - start.x;
  2711. diffY = p.y - start.y;
  2712. if(diffY > 0) {
  2713. diffY = Math.sqrt(diffY);
  2714. }
  2715. noti.css("transform", "translate3d(0, "+diffY+"px, 0)");
  2716. };
  2717. var touchEnd = function() {
  2718. noti.removeClass("touching");
  2719. noti.attr("style", "");
  2720. if(diffY < 0 && (Math.abs(diffY) > noti.height()*0.38)) {
  2721. $.closeNotification();
  2722. }
  2723. if(Math.abs(diffX) <= 1 && Math.abs(diffY) <= 1) {
  2724. noti.trigger("noti-click");
  2725. }
  2726. start = false;
  2727. };
  2728. var attachEvents = function(el) {
  2729. el.on($.touchEvents.start, touchStart);
  2730. el.on($.touchEvents.move, touchMove);
  2731. el.on($.touchEvents.end, touchEnd);
  2732. };
  2733. $.notification = $.noti = function(params) {
  2734. params = $.extend({}, defaults, params);
  2735. noti = $(".notification");
  2736. if(!noti[0]) { // create a new notification
  2737. noti = $('<div class="notification"></div>').appendTo(document.body);
  2738. attachEvents(noti);
  2739. }
  2740. noti.off("noti-click"); //the click event is not correct sometime: it will trigger when user is draging.
  2741. if(params.onClick) noti.on("noti-click", function() {
  2742. params.onClick(params.data);
  2743. });
  2744. noti.html($.t7.compile(params.tpl)(params));
  2745. noti.show();
  2746. noti.addClass("notification-in");
  2747. noti.data("params", params);
  2748. var startTimeout = function() {
  2749. if(timeout) {
  2750. clearTimeout(timeout);
  2751. timeout = null;
  2752. }
  2753. timeout = setTimeout(function() {
  2754. if(noti.hasClass("touching")) {
  2755. startTimeout();
  2756. } else {
  2757. $.closeNotification();
  2758. }
  2759. }, params.time);
  2760. };
  2761. startTimeout();
  2762. };
  2763. $.closeNotification = function() {
  2764. timeout && clearTimeout(timeout);
  2765. timeout = null;
  2766. var noti = $(".notification").removeClass("notification-in").transitionEnd(function() {
  2767. $(this).remove();
  2768. });
  2769. if(noti[0]) {
  2770. var params = $(".notification").data("params");
  2771. if(params && params.onClose) {
  2772. params.onClose(params.data);
  2773. }
  2774. }
  2775. };
  2776. defaults = $.noti.prototype.defaults = {
  2777. title: undefined,
  2778. text: undefined,
  2779. media: undefined,
  2780. time: 4000,
  2781. onClick: undefined,
  2782. onClose: undefined,
  2783. data: undefined,
  2784. tpl: '<div class="notification-inner">' +
  2785. '{{#if media}}<div class="notification-media">{{media}}</div>{{/if}}' +
  2786. '<div class="notification-content">' +
  2787. '{{#if title}}<div class="notification-title">{{title}}</div>{{/if}}' +
  2788. '{{#if text}}<div class="notification-text">{{text}}</div>{{/if}}' +
  2789. '</div>' +
  2790. '<div class="notification-handle-bar"></div>' +
  2791. '</div>'
  2792. };
  2793. }($);