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),