ui.js 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387
  1. // date picker timezone conversion for display
  2. QUnit.test("date picker", assert => {
  3. Date.prototype.getTimezoneOffset2 = Date.prototype.getTimezoneOffset
  4. Date.prototype.getTimezoneOffset = function() { return -360 }
  5. obj_date_time = {
  6. name: 'test',
  7. value: '2018-04-06T20:45:00.000Z'
  8. }
  9. el_date_time = App.UiElement.datetime.render(obj_date_time)
  10. date_time_parsed = new Date(Date.parse(obj_date_time.value))
  11. date_time_input = el_date_time.find('.js-datepicker').datepicker('getDate')
  12. assert.equal(date_time_parsed.getDate(), date_time_input.getDate(), 'datetime matching day')
  13. obj_date = {
  14. name: 'test',
  15. value: '2018-06-06'
  16. }
  17. el_date = App.UiElement.date.render(obj_date)
  18. date_parsed = new Date(Date.parse(obj_date.value))
  19. date_input = el_date.find('.js-datepicker').datepicker('getUTCDate')
  20. assert.equal(date_parsed.getDate(), date_input.getDate(), 'date matching day')
  21. Date.prototype.getTimezoneOffset = Date.prototype.getTimezoneOffset2
  22. Date.prototype.getTimezoneOffset2 = undefined
  23. })
  24. // pretty date
  25. QUnit.test("check pretty date", assert => {
  26. var current = new Date()
  27. // use date formatting as functions to make it more flexible
  28. prettyDateRelative(current, '', true, 'relative');
  29. prettyDateAbsolute(current, '', true, 'absolute');
  30. prettyDateTimestamp(current, '', true, 'timestamp');
  31. // past
  32. function prettyDateRelative(current, escalation, long, type) {
  33. var result = App.PrettyDate.humanTime(current, escalation, long, type);
  34. assert.equal(result, 'just now', 'just now')
  35. result = App.PrettyDate.humanTime(current - 15000, escalation, long, type);
  36. assert.equal(result, 'just now', 'just now')
  37. result = App.PrettyDate.humanTime(current - 60000, escalation, long, type);
  38. assert.equal(result, '1 minute ago', '1 min ago')
  39. result = App.PrettyDate.humanTime(current - (2 * 60000), escalation, long, type);
  40. assert.equal(result, '2 minutes ago', '2 min ago')
  41. result = App.PrettyDate.humanTime(current - (60000 * 60), escalation, long, type);
  42. assert.equal(result, '1 hour ago', '1 hour')
  43. result = App.PrettyDate.humanTime(current - (60000 * 60 * 2), escalation, long, type);
  44. assert.equal(result, '2 hours ago', '2 hours')
  45. result = App.PrettyDate.humanTime(current - (60000 * 60 * 2.5), escalation, long, type);
  46. assert.equal(result, '2 hours 30 minutes ago', '2.5 hours')
  47. result = App.PrettyDate.humanTime(current - (60000 * 60 * 12.5), escalation, long, type);
  48. assert.equal(result, '12 hours ago', '12.5 hours')
  49. result = App.PrettyDate.humanTime(current - (60000 * 60 * 24), escalation, long, type);
  50. assert.equal(result, '1 day ago', '1 day')
  51. result = App.PrettyDate.humanTime(current - (60000 * 60 * 24 * 2), escalation, long, type);
  52. assert.equal(result, '2 days ago', '2 days')
  53. result = App.PrettyDate.humanTime(current - (60000 * 60 * 24 * 2) - (60000 * 5), escalation, long, type);
  54. assert.equal(result, '2 days ago', '2 days')
  55. result = App.PrettyDate.humanTime(current - (60000 * 60 * 24 * 2.5), escalation, long, type);
  56. assert.equal(result, '2 days 12 hours ago', '2.5 days')
  57. result = App.PrettyDate.humanTime(current - (60000 * 60 * 24 * 2.5) - (60000 * 5), escalation, long, type);
  58. assert.equal(result, '2 days 12 hours ago', '2.5 days')
  59. result = App.PrettyDate.humanTime(current - (60000 * 60 * 24 * 10.5), escalation, long, type);
  60. var pastDate = new Date(current - (60000 * 60 * 24 * 10.5))
  61. var dd = pastDate.getDate();
  62. if(dd<10) {
  63. dd = '0' + dd
  64. }
  65. var mm = pastDate.getMonth() + 1;
  66. if(mm<10) {
  67. mm = '0' + mm
  68. }
  69. var yyyy = pastDate.getFullYear();
  70. // mm/dd/yyyy
  71. assert.equal(result, mm+'/'+dd+'/'+yyyy, '10.5 days')
  72. result = App.PrettyDate.humanTime(current - (60000 * 60 * 24 * 30), escalation, long, type);
  73. var pastDate = new Date(current - (60000 * 60 * 24 * 30))
  74. var dd = pastDate.getDate();
  75. if(dd<10) {
  76. dd = '0' + dd
  77. }
  78. var mm = pastDate.getMonth() + 1;
  79. if(mm<10) {
  80. mm = '0' + mm
  81. }
  82. var yyyy = pastDate.getFullYear();
  83. // mm/dd/yyyy
  84. assert.equal(result, mm+'/'+dd+'/'+yyyy, '30 days')
  85. // future
  86. current = new Date()
  87. result = App.PrettyDate.humanTime(current, escalation, long, type);
  88. assert.equal(result, 'just now', 'just now')
  89. result = App.PrettyDate.humanTime(current.getTime() + 55000, escalation, long, type);
  90. assert.equal(result, 'just now', 'just now')
  91. result = App.PrettyDate.humanTime(current.getTime() + 65000, escalation, long, type);
  92. assert.equal(result, 'in 1 minute', 'in 1 min')
  93. result = App.PrettyDate.humanTime(current.getTime() + (2 * 65000), escalation, long, type);
  94. assert.equal(result, 'in 2 minutes', 'in 2 min')
  95. result = App.PrettyDate.humanTime(current.getTime() + (60500 * 60), escalation, long, type);
  96. assert.equal(result, 'in 1 hour', 'in 1 hour')
  97. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 2), escalation, long, type);
  98. assert.equal(result, 'in 2 hours', 'in 2 hours')
  99. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 2.5), escalation, long, type);
  100. assert.equal(result, 'in 2 hours 30 minutes', 'in 2.5 hours')
  101. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 24), escalation, long, type) ;
  102. assert.equal(result, 'in 1 day', 'in 1 day')
  103. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 24 * 2), escalation, long, type);
  104. assert.equal(result, 'in 2 days', 'in 2 days')
  105. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 24 * 2.5), escalation, long, type);
  106. assert.equal(result, 'in 2 days 12 hours', 'in 2.5 days')
  107. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 24 * 5.5), escalation, long, type);
  108. assert.equal(result, 'in 5 days 12 hours', 'in 30.5 days')
  109. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 24 * 30.5), escalation, long, type);
  110. assert.equal(result, 'in 30 days', 'in 30.5 days')
  111. };
  112. function prettyDateAbsolute(current, escalation, long, type) {
  113. var result = App.PrettyDate.humanTime(current, escalation, long, type);
  114. assert.equal(result, 'just now', 'just now') // by defaul < 1 min is just now
  115. result = App.PrettyDate.humanTime(current - 15000, escalation, long, type);
  116. assert.equal(result, 'just now', 'just now') // by default < 1 min is just now
  117. result = App.PrettyDate.humanTime(current - 60000, escalation, long, type);
  118. diff = 60
  119. assert.equal(result, getAbsolute(new Date(current - 60000), diff), '1 min ago')
  120. result = App.PrettyDate.humanTime(current - (2 * 60000), escalation, long, type);
  121. diff = 2 * 60
  122. assert.equal(result, getAbsolute(new Date(current - (2 * 60000)), diff), '2 min ago')
  123. result = App.PrettyDate.humanTime(current - (60000 * 60), escalation, long, type);
  124. diff = 60 * 60
  125. assert.equal(result, getAbsolute(new Date(current - (60000 * 60)), diff), '1 hour')
  126. result = App.PrettyDate.humanTime(current - (60000 * 60 * 2), escalation, long, type);
  127. diff = 60 * 60 * 2
  128. assert.equal(result, getAbsolute(new Date(current - (60000 * 60 * 2)), diff), '2 hours')
  129. result = App.PrettyDate.humanTime(current - (60000 * 60 * 2.5), escalation, long, type);
  130. diff = 60 * 60 * 2.5
  131. assert.equal(result, getAbsolute(new Date(current - (60000 * 60 * 2.5)), diff), '2.5 hours')
  132. result = App.PrettyDate.humanTime(current - (60000 * 60 * 12.5), escalation, long, type);
  133. diff = 60 * 60 * 12.5
  134. assert.equal(result, getAbsolute(new Date(current - (60000 * 60 * 12.5)), diff), '12.5 hours')
  135. result = App.PrettyDate.humanTime(current - (60000 * 60 * 24), escalation, long, type);
  136. diff = 60 * 60 * 25
  137. assert.equal(result, getAbsolute(new Date(current - (60000 * 60 * 24)), diff), '1 day')
  138. result = App.PrettyDate.humanTime(current - (60000 * 60 * 24 * 2), escalation, long, type);
  139. diff = 60 * 60 * 25 * 2
  140. assert.equal(result, getAbsolute(new Date(current - (60000 * 60 * 24 * 2)), diff), '2 days')
  141. result = App.PrettyDate.humanTime(current - (60000 * 60 * 24 * 2) - (60000 * 5), escalation, long, type);
  142. diff = (60 * 60 * 24 * 2) - (60 * 5)
  143. assert.equal(result, getAbsolute(new Date(current - (60000 * 60 * 24 * 2) - (60000 * 5)), diff), '2 days')
  144. result = App.PrettyDate.humanTime(current - (60000 * 60 * 24 * 2.5), escalation, long, type);
  145. diff = (60 * 60 * 24 * 2.5)
  146. assert.equal(result, getAbsolute(new Date(current - (60000 * 60 * 24 * 2.5)), diff), '2.5 days')
  147. result = App.PrettyDate.humanTime(current - (60000 * 60 * 24 * 2.5) - (60000 * 5), escalation, long, type);
  148. diff = (60 * 60 * 24 * 2.5) - (60 * 5)
  149. assert.equal(result, getAbsolute(new Date(current - (60000 * 60 * 24 * 2.5) - (60000 * 5)), diff), '2.5 days')
  150. // future
  151. current = new Date()
  152. result = App.PrettyDate.humanTime(current, escalation, long, type);
  153. assert.equal(result, 'just now', 'just now') // no change, because < 1 min = just now
  154. result = App.PrettyDate.humanTime(current.getTime() + 55000, escalation, long, type);
  155. assert.equal(result, 'just now', 'just now') // no change, because < 1 min = just now
  156. result = App.PrettyDate.humanTime(current.getTime() + 65000, escalation, long, type);
  157. diff = 60
  158. assert.equal(result, getAbsolute(new Date(current.getTime() + 65000), diff), 'in 1 min')
  159. result = App.PrettyDate.humanTime(current.getTime() + (2 * 65000), escalation, long, type);
  160. diff = 2 * 60
  161. assert.equal(result, getAbsolute(new Date(current.getTime() + (2 * 65000)), diff), 'in 2 min')
  162. result = App.PrettyDate.humanTime(current.getTime() + (60500 * 60), escalation, long, type) ;
  163. diff = 60 * 60
  164. assert.equal(result, getAbsolute(new Date(current.getTime() + (60500 * 60)), diff), 'in 1 hour')
  165. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 2), escalation, long, type);
  166. diff = 60 * 60 * 2
  167. assert.equal(result, getAbsolute(new Date(current.getTime() + (60050 * 60 * 2)), diff), 'in 2 hours')
  168. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 2.5), escalation, long, type);
  169. diff = 60 * 60 * 2.5
  170. assert.equal(result, getAbsolute(new Date(current.getTime() + (60050 * 60 * 2.5)), diff), 'in 2.5 hours')
  171. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 24), escalation, long, type);
  172. diff = 60 * 60 * 24
  173. assert.equal(result, getAbsolute(new Date(current.getTime() + (60050 * 60 * 24)), diff), 'in 1 day')
  174. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 24 * 2), escalation, long, type);
  175. diff = 60 * 60 * 24 * 2
  176. assert.equal(result, getAbsolute(new Date(current.getTime() + (60050 * 60 * 24 * 2)), diff), 'in 2 days')
  177. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 24 * 2.5), escalation, long, type);
  178. diff = 60 * 60 * 24 * 2.5
  179. assert.equal(result, getAbsolute(new Date(current.getTime() + (60050 * 60 * 24 * 2.5)), diff), 'in 2.5 days')
  180. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 24 * 5.5), escalation, long, type);
  181. diff = 60 * 60 * 24 * 5.5
  182. assert.equal(result, getAbsolute(new Date(current.getTime() + (60050 * 60 * 24 * 5.5)), diff), 'in 5.5 days')
  183. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 24 * 30.5), escalation, long, type);
  184. diff = (60 * 60 * 24 * 30.5);
  185. assert.equal(result, getAbsolute(new Date(current.getTime() + 60050 * 60 * 24 * 30.5), diff), 'in 30.5 days')
  186. };
  187. function prettyDateTimestamp(current, escalation, long, type) {
  188. var result = App.PrettyDate.humanTime(current, escalation, long, type);
  189. assert.equal(result, 'just now', 'just now') // by defaul < 1 min is just now
  190. result = App.PrettyDate.humanTime(current - 15000, escalation, long, type);
  191. assert.equal(result, 'just now', 'just now') // by default < 1 min is just now
  192. result = App.PrettyDate.humanTime(current - 60000, escalation, long, type);
  193. assert.equal(result, getTimestamp(new Date(current - 60000)), '1 min ago')
  194. result = App.PrettyDate.humanTime(current - (2 * 60000), escalation, long, type);
  195. assert.equal(result, getTimestamp(new Date(current - (2 * 60000))), '2 min ago')
  196. result = App.PrettyDate.humanTime(current - (60000 * 60), escalation, long, type);
  197. assert.equal(result, getTimestamp(new Date(current - (60000 * 60))), '1 hour')
  198. result = App.PrettyDate.humanTime(current - (60000 * 60 * 2), escalation, long, type);
  199. assert.equal(result, getTimestamp(new Date(current - (60000 * 60 * 2))), '2 hours')
  200. result = App.PrettyDate.humanTime(current - (60000 * 60 * 2.5), escalation, long, type);
  201. assert.equal(result, getTimestamp(new Date(current - (60000 * 60 * 2.5))), '2.5 hours')
  202. result = App.PrettyDate.humanTime(current - (60000 * 60 * 12.5), escalation, long, type);
  203. assert.equal(result, getTimestamp(new Date(current - (60000 * 60 * 12.5))), '12.5 hours')
  204. result = App.PrettyDate.humanTime(current - (60000 * 60 * 24), escalation, long, type);
  205. assert.equal(result, getTimestamp(new Date(current - (60000 * 60 * 24))), '1 day')
  206. result = App.PrettyDate.humanTime(current - (60000 * 60 * 24 * 2), escalation, long, type);
  207. assert.equal(result, getTimestamp(new Date(current - (60000 * 60 * 24 * 2))), '2 days')
  208. result = App.PrettyDate.humanTime(current - (60000 * 60 * 24 * 2) - (60000 * 5), escalation, long, type);
  209. assert.equal(result, getTimestamp(new Date(current - (60000 * 60 * 24 * 2) - (60000 * 5))), '2 days')
  210. result = App.PrettyDate.humanTime(current - (60000 * 60 * 24 * 2.5), escalation, long, type);
  211. assert.equal(result, getTimestamp(new Date(current - (60000 * 60 * 24 * 2.5))), '2.5 days')
  212. result = App.PrettyDate.humanTime(current - (60000 * 60 * 24 * 2.5) - (60000 * 5), escalation, long, type);
  213. assert.equal(result, getTimestamp(new Date(current - (60000 * 60 * 24 * 2.5) - (60000 * 5))), '2.5 days')
  214. // future
  215. current = new Date()
  216. result = App.PrettyDate.humanTime(current, escalation, long, type);
  217. assert.equal(result, 'just now', 'just now') // no change, because < 1 min = just now
  218. result = App.PrettyDate.humanTime(current.getTime() + 55000, escalation, long, type);
  219. assert.equal(result, 'just now', 'just now') // no change, because < 1 min = just now
  220. result = App.PrettyDate.humanTime(current.getTime() + 65000, escalation, long, type);
  221. assert.equal(result, getTimestamp(new Date(current.getTime() + 65000)), 'in 1 min')
  222. result = App.PrettyDate.humanTime(current.getTime() + (2 * 65000), escalation, long, type);
  223. assert.equal(result, getTimestamp(new Date(current.getTime() + (2 * 65000))), 'in 2 min')
  224. result = App.PrettyDate.humanTime(current.getTime() + (60500 * 60), escalation, long, type) ;
  225. assert.equal(result, getTimestamp(new Date(current.getTime() + (60500 * 60))), 'in 1 hour')
  226. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 2), escalation, long, type);
  227. assert.equal(result, getTimestamp(new Date(current.getTime() + (60050 * 60 * 2))), 'in 2 hours')
  228. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 2.5), escalation, long, type);
  229. assert.equal(result, getTimestamp(new Date(current.getTime() + (60050 * 60 * 2.5))), 'in 2.5 hours')
  230. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 24), escalation, long, type);
  231. assert.equal(result, getTimestamp(new Date(current.getTime() + (60050 * 60 * 24))), 'in 1 day')
  232. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 24 * 2), escalation, long, type);
  233. assert.equal(result, getTimestamp(new Date(current.getTime() + (60050 * 60 * 24 * 2))), 'in 2 days')
  234. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 24 * 2.5), escalation, long, type);
  235. assert.equal(result, getTimestamp(new Date(current.getTime() + (60050 * 60 * 24 * 2.5))), 'in 2.5 days')
  236. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 24 * 5.5), escalation, long, type);
  237. assert.equal(result, getTimestamp(new Date(current.getTime() + (60050 * 60 * 24 * 5.5))), 'in 5.5 days')
  238. result = App.PrettyDate.humanTime(current.getTime() + (60050 * 60 * 24 * 30.5), escalation, long, type);
  239. assert.equal(result, getTimestamp(new Date(current.getTime() + 60050 * 60 * 24 * 30.5)), 'in 30.5 days')
  240. };
  241. function getAbsolute(date, diff) {
  242. weekdays = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];
  243. weekday = weekdays[date.getDay()];
  244. months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];
  245. month = months[date.getMonth()];
  246. d = date.getDate()
  247. m = date.getMonth() + 1
  248. yfull = date.getFullYear()
  249. M = date.getMinutes()
  250. H = date.getHours()
  251. l = (H + 11) % 12 + 1
  252. if (l < 10) {
  253. l = ' ' + l
  254. }
  255. P = H >= 12 ? 'pm' : 'am'
  256. // for less than 6 days
  257. // weekday HH::MM
  258. if (diff < (60 * 60 * 24 * 6))
  259. string = weekday + ' ' + H + ':' + (M < 10 ? '0':'') + M
  260. else if (current.getYear() == date.getYear())
  261. string = weekday + ' ' + date.getDate() + '. ' + month + ' ' + H + ':' + (M < 10 ? '0':'') + M
  262. else
  263. string = weekday + ' ' + (m < 10 ? '0':'') + m + '/' + (d < 10 ? '0':'') + d + '/' + (yfull) + ' ' + l + ':' + (M < 10 ? '0':'') + M + ' ' + P
  264. return string;
  265. }
  266. function getTimestamp(date) {
  267. d = date.getDate()
  268. m = date.getMonth() + 1
  269. yfull = date.getFullYear()
  270. yshort = date.getYear()-100
  271. M = date.getMinutes()
  272. H = date.getHours()
  273. l = (H + 11) % 12 + 1
  274. if (l < 10) {
  275. l = ' ' + l
  276. }
  277. P = H >= 12 ? 'pm' : 'am'
  278. // YYYY-MM-DD HH::MM
  279. return (m < 10 ? '0':'') + m + '/' + (d < 10 ? '0':'') + d + '/' + (yfull) + ' ' + l + ':' + (M < 10 ? '0':'') + M + ' ' + P
  280. }
  281. });
  282. QUnit.test("PrettyDate getISOWeeks", assert => {
  283. assert.equal(App.PrettyDate.getISOWeeks(2026), 53, '53 weeks')
  284. assert.equal(App.PrettyDate.getISOWeeks(2020), 53, 'leap year and 53 weeks')
  285. assert.equal(App.PrettyDate.getISOWeeks(2019), 52, '52 weeks')
  286. assert.equal(App.PrettyDate.getISOWeeks(2024), 52, 'leap year and 52 weeks')
  287. })