From 75a6bbd80a04eb2222cf22e155e272e7f10f64b1 Mon Sep 17 00:00:00 2001 From: Rufus Pollock Date: Sun, 10 Jun 2012 12:35:39 +0100 Subject: [PATCH 1/4] [#152,view/timeline][s]: more robust data parsing with tests - fixes #152. * Also discover and fix "bug" re momentjs timezone calculation and toDate. --- src/view.timeline.js | 24 ++++++++++++++++++++---- test/view.timeline.test.js | 20 ++++++++++++++++++++ 2 files changed, 40 insertions(+), 4 deletions(-) diff --git a/src/view.timeline.js b/src/view.timeline.js index c556a1e4..5c0da584 100644 --- a/src/view.timeline.js +++ b/src/view.timeline.js @@ -79,12 +79,11 @@ my.Timeline = Backbone.View.extend({ } }; this.model.currentRecords.each(function(doc) { - var start = doc.get(self.state.get('startField')); + var start = self._parseDate(doc.get(self.state.get('startField'))); + var end = self._parseDate(doc.get(self.state.get('endField'))); if (start) { - var end = doc.get(self.state.get('endField')); - end = end ? moment(end).toDate() : null; var tlEntry = { - "startDate": moment(start).toDate(), + "startDate": start, "endDate": end, "headline": String(doc.get('title') || ''), "text": doc.summary() @@ -103,6 +102,23 @@ my.Timeline = Backbone.View.extend({ return out; }, + _parseDate: function(date) { + var out = date.trim(); + out = out.replace(/(\d)th/g, '$1'); + out = out.replace(/(\d)st/g, '$1'); + out = out.trim() ? moment(out) : null; + if (out.toDate() == 'Invalid Date') { + return null; + } else { + // fix for moment weirdness around date parsing and time zones + // moment('1914-08-01').toDate() => 1914-08-01 00:00 +01:00 + // which in iso format (with 0 time offset) is 31 July 1914 23:00 + // meanwhile native new Date('1914-08-01') => 1914-08-01 01:00 +01:00 + out = out.subtract('minutes', out.zone()); + return out.toDate(); + } + }, + _setupTemporalField: function() { this.state.set({ startField: this._checkField(this.startFieldNames), diff --git a/test/view.timeline.test.js b/test/view.timeline.test.js index 583afc79..8746b0bb 100644 --- a/test/view.timeline.test.js +++ b/test/view.timeline.test.js @@ -48,3 +48,23 @@ test('render etc', function () { view.remove(); }); +test('_parseDate', function () { + var dataset = Fixture.getDataset(); + var view = new recline.View.Timeline({ + model: dataset + }); + var testData = [ + [ '1st August 1914', '1914-08-01T00:00:00.000Z' ], + [ '1 August 1914', '1914-08-01T00:00:00.000Z' ], + [ 'August 1st 1914', '1914-08-01T00:00:00.000Z' ], + [ '1914-08-01', '1914-08-01T00:00:00.000Z' ], + [ '1914-08-01T08:00', '1914-08-01T08:00:00.000Z' ], + [ 'afdaf afdaf', null ] + ]; + _.each(testData, function(item) { + var out = view._parseDate(item[0]); + if (out) out = out.toISOString(); + equal(out, item[1]); + }); +}); + From 3fbad6bace12e1c14b57cd53836d848e166a1135 Mon Sep 17 00:00:00 2001 From: Rufus Pollock Date: Sun, 10 Jun 2012 12:45:50 +0100 Subject: [PATCH 2/4] [make,bugfix][xs]: concat js files as well as css (problem introduced in 882d31eca577fcb35be2c23995af29f1d6e441ac). --- make | 2 ++ 1 file changed, 2 insertions(+) diff --git a/make b/make index 0c51ff41..7b02912b 100755 --- a/make +++ b/make @@ -6,6 +6,8 @@ import os def cat(): print("** Combining js files") cmd = 'cat src/*.js src/backend/*.js > dist/recline.js' + os.system(cmd) + print("** Combining css files") cmd = 'cat css/*.css > dist/recline.css' os.system(cmd) From 1c9024d051052959fc7b83b16c1b5e66daf498b1 Mon Sep 17 00:00:00 2001 From: Rufus Pollock Date: Sun, 10 Jun 2012 12:49:59 +0100 Subject: [PATCH 3/4] [css,refactor][xs]: inline images (spinner + edit-map) into css to avoid dependencies on external image files. * Why? Cleaner, simpler and avoids problems now we build a single consolidated css file. --- css/grid.css | 2 +- css/images/edit-map.png | Bin 1569 -> 0 bytes css/images/small-spinner.gif | Bin 1849 -> 0 bytes css/multiview.css | 2 +- 4 files changed, 2 insertions(+), 2 deletions(-) delete mode 100755 css/images/edit-map.png delete mode 100755 css/images/small-spinner.gif diff --git a/css/grid.css b/css/grid.css index 452bfe4a..efe1dd37 100644 --- a/css/grid.css +++ b/css/grid.css @@ -130,7 +130,7 @@ a.data-table-cell-edit { width: 25px; height: 16px; text-decoration: none; - background-image: url(images/edit-map.png); + background-image: url(); background-repeat: no-repeat; visibility: hidden; } diff --git a/css/images/edit-map.png b/css/images/edit-map.png deleted file mode 100755 index dea0ed1ef4e1a8d301f58c9a24ce7ed3ea297bb6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1569 zcmeAS@N?(olHy`uVBq!ia0vp^MnEjU!3HElqIG(Jlw^r(L`iUdT1k0gQ7VIDN`6wR zf@f}GdTLN=VoGJ<$y6H#24v4 zq}24xJX@vryZ0+8WTx0Eg`4^s_!c;)W@LI)6{QAO`Gq7`WhYyvDB0U7*i={n4aiL` zNmQuF&B-gas<2f8n`;GRgM{^!6u?SKvTcwn`Gtf;oFf&jvGt@IQ zHZeCh*HJJsFf`CNFw!?P(ls=ndS0-B(gnVDi`Y3yQQ>}q7{VqjotXz1c*X=!fZ;%w&ZVrt;# zXl&>R)9aF-T$-DjR|3v4~Pj*wm=R%;iu*SQ+p9GSx?XmOJ`tUn(FD|7*cU7 z>CgZF_J<1?bQF?q9W(#tu!_6m?23$UnhJWSKZ#p%JhBkKzi_5(b#*A;CI{9qhK(#! znNRX$ty8gmlhDL9A%)RkiX=~{rQwY?YkGL1xMWUvsTOSDWJ=HgMh9oohDyts5;ZzM z4BjLxH1RN#{e9xY%iHz_w+}Y3zmQaG%jT~OFumcOZkJr~@0lKpccGqNlVi|~sSoe0&FAs$jx(tF_mAJT=IFlf8dXZNtP*^2 ze-0gB=&4jT)!PuUYP-SVH*50~y<%ogF#Qqv(Rk0lAM7%x7Njt7CC)f}h~K z$Bs$o@BK~u!DJ%cl4!`n`qbwI->;wCLd*+h1WZe6KRtK%-`1hW%Y2!BWZ4a&gi$?sGPuetgw8Sf*;h z?XxWX;v}t|4V;!PjvE~l9gaM%CaJb>8OCt&WB73QrJ#wOUN}&b*PE)d9Y`Z&QUg>?-MS)IMAw}aDM0P zPls%~w8b1x21#$_aAQn0p4VhtQoc*%#>EX=_`LkK%l~IcubAOpcvMLva*^mko}LA2 zTpQAsM_RK+oHuaFE}M0eaaDSP;io3IvONb5F54#CW6*zu@uRF(bOC#o9y2f<$>^<( gS8GdTVqoH7aNjQEEY|+vJ*d$3boFyt=akR{0GM<+9{>OV diff --git a/css/images/small-spinner.gif b/css/images/small-spinner.gif deleted file mode 100755 index 5b33f7e54f4e55b6b8774d86d96895db9af044b4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1849 zcma*odr(tX9tZI2z31lM+(&YVk%mZ}5P~KlG2s=WSbGzm0!x7^P##Mnh7t-jP!X0Q zk_SQ}Po-L1tlDK;6l?(>v)e5ZBQx4|Y-Q?nr@Px3?9h(3ZWr3^tj=`TP57gKr87N$ zp2wWee1GRRCwo_xahnw)5cxNPJbCg2L6DV|6`#+yw6v6!mDS$f9-JvFD^n;GQ&UrZ zzh5jCkByB101O60U0q#p_1BM>Cv-vP?&s4@g_((4_1L=L$(a91)0=J91Gas#R{McE znYG^9*0A5YZ>#;~+Wkn(W5B0^yELIYLP!K}mB~<)AM@1&nqekynuaEGqPrzoH|KodRXJy)%+w_fu3nE5>@Bd_b zqC$EQ;{c`T&?EsNO|igL9gC7Ygxv?aQUEXMq?~>wg{EyW;VcJ37CUF#HjrT=KQO_* zS>M9yydXk18D(+QDJ1>r);Lav_uYKp$T?4vr{Q$lTo&pKv^?(>L-)G2*lwH!Ah7k? z7oH<8h-(KTKt5V6$8gF)C7Io&P5=SjTh)=zV=E2EUhQZP##L8S{d%UK>>+y82>+FV+#^BzW7u3F)Bb>=lYQ%%j`F>ASe zo*cw@V#u6T`A2He;70mR(V&iV&-7{qP~=SRf&jm9-T{*ZeZ}$rd0#6c&fLG^xJcf5 z+p<`wJYgW+_s*V{uI$nMB;%8`S_3>PfGOj3Rq}@Cx^+j?rk92fANSFDBYnOqQ>Vdj z)(|$AhP4t&Lb=Gvo2#3Gl%9<=Gv`Mz?Po@P4iLF!x}GUWJICDlFk-hS^Whyh7x~VH z@0vD1>HYD4&e+~yzS*-sFR{9`{QEEZO1zg7>R&7cHts-6j!xHVdA8eI+ZlVzd%`es zJT@$#GX(gvCJ1oJN%yLBK}{V=V;seo;!w|Yte!W1%5qLNFWqvZW>h&IiH+oPT=b@E zPhGzv5=(Un*X>v`>%8h_nj^NdYcE6NHS_ifkCV$*D)Tqrbu`s;<=t<4 zAHNqNV?6(g<1PY-w@#I-WYFViz?9TrkMr)u0g`O`u|>T;k|2sV*YF^punvT;$SuTy{j3Gv)yqD!R_CF>yR)MzmmYS5v+~R zXAdD%ng9?df;wd8GxR#%3O+gz};Vo;)sK%Bj-q>Oq%R7JU-KD?vYu>#2UjaDo z&8$>5xW~?KPD_#XFToU1hIb*VOMidUr6iYiO0N|i-7s`T8!cFT`rN!^1Pt78J93i6 z5HI1wIM$94m{3SLDvISDe6$ZG1;eq_D9RTaaC>=cO{@Bs>$IlPCPJJ$h$)-3vzNUQ6OsN#_zWxey!_9%hxwH2_dEJi=yY|1c7nDm2_Lm!Cof8-R_+9UkS zcBE(o47yE)oMR(Q=dp1a2wTX5KvvGyLqlWTa7V&!A*|w|)ax~1_~aJ0=_Lilg*0iQk7#ZD EAHN$8j{pDw diff --git a/css/multiview.css b/css/multiview.css index 4d0795f4..4e7fbf20 100644 --- a/css/multiview.css +++ b/css/multiview.css @@ -161,7 +161,7 @@ .recline-data-explorer .notification-loader { width: 18px; margin-left: 5px; - background: url(images/small-spinner.gif) no-repeat; + background-image: url(%3D%3D); display: inline-block; } From 6a746420c650a7512a7eb4f82616ae019b1dfa4b Mon Sep 17 00:00:00 2001 From: Rufus Pollock Date: Sun, 10 Jun 2012 13:14:48 +0100 Subject: [PATCH 4/4] [build][xs]: usual build. --- dist/recline.css | 4 ++-- dist/recline.js | 24 ++++++++++++++++++++---- 2 files changed, 22 insertions(+), 6 deletions(-) diff --git a/dist/recline.css b/dist/recline.css index bde27901..fcc74387 100644 --- a/dist/recline.css +++ b/dist/recline.css @@ -149,7 +149,7 @@ a.data-table-cell-edit { width: 25px; height: 16px; text-decoration: none; - background-image: url(images/edit-map.png); + background-image: url(); background-repeat: no-repeat; visibility: hidden; } @@ -503,7 +503,7 @@ td.expression-preview-value { .recline-data-explorer .notification-loader { width: 18px; margin-left: 5px; - background: url(images/small-spinner.gif) no-repeat; + background-image: url(%3D%3D); display: inline-block; } diff --git a/dist/recline.js b/dist/recline.js index 1cedf311..aad9bb33 100644 --- a/dist/recline.js +++ b/dist/recline.js @@ -2830,12 +2830,11 @@ my.Timeline = Backbone.View.extend({ } }; this.model.currentRecords.each(function(doc) { - var start = doc.get(self.state.get('startField')); + var start = self._parseDate(doc.get(self.state.get('startField'))); + var end = self._parseDate(doc.get(self.state.get('endField'))); if (start) { - var end = doc.get(self.state.get('endField')); - end = end ? moment(end).toDate() : null; var tlEntry = { - "startDate": moment(start).toDate(), + "startDate": start, "endDate": end, "headline": String(doc.get('title') || ''), "text": doc.summary() @@ -2854,6 +2853,23 @@ my.Timeline = Backbone.View.extend({ return out; }, + _parseDate: function(date) { + var out = date.trim(); + out = out.replace(/(\d)th/g, '$1'); + out = out.replace(/(\d)st/g, '$1'); + out = out.trim() ? moment(out) : null; + if (out.toDate() == 'Invalid Date') { + return null; + } else { + // fix for moment weirdness around date parsing and time zones + // moment('1914-08-01').toDate() => 1914-08-01 00:00 +01:00 + // which in iso format (with 0 time offset) is 31 July 1914 23:00 + // meanwhile native new Date('1914-08-01') => 1914-08-01 01:00 +01:00 + out = out.subtract('minutes', out.zone()); + return out.toDate(); + } + }, + _setupTemporalField: function() { this.state.set({ startField: this._checkField(this.startFieldNames),