Merge pull request #2976 from jbivins/legacy-browser-support
Legacy browser support
This commit is contained in:
commit
0d5c518630
6 changed files with 73 additions and 4 deletions
|
|
@ -12,7 +12,7 @@
|
||||||
.content_creation
|
.content_creation
|
||||||
= form_for(StatusMessage.new) do |status|
|
= form_for(StatusMessage.new) do |status|
|
||||||
= status.error_messages
|
= status.error_messages
|
||||||
%p
|
%div
|
||||||
%params
|
%params
|
||||||
#publisher_textarea_wrapper
|
#publisher_textarea_wrapper
|
||||||
= link_to( image_tag('deletelabel.png'), "#", :id => "hide_publisher", :title => t('.discard_post'))
|
= link_to( image_tag('deletelabel.png'), "#", :id => "hide_publisher", :title => t('.discard_post'))
|
||||||
|
|
|
||||||
35
public/javascripts/app/helpers/date_formatter.js
Normal file
35
public/javascripts/app/helpers/date_formatter.js
Normal file
|
|
@ -0,0 +1,35 @@
|
||||||
|
(function(){
|
||||||
|
var dateFormatter = function dateFormatter() {
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
dateFormatter.parse = function(date_string) {
|
||||||
|
var timestamp = new Date(date_string).getTime();
|
||||||
|
|
||||||
|
if (isNaN(timestamp)) {
|
||||||
|
timestamp = dateFormatter.parseISO8601UTC(date_string);
|
||||||
|
}
|
||||||
|
|
||||||
|
return timestamp;
|
||||||
|
},
|
||||||
|
|
||||||
|
dateFormatter.parseISO8601UTC = function(date_string) {
|
||||||
|
var iso8601_utc_pattern = /^(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2})(.(\d{3}))?Z$/;
|
||||||
|
var time_components = date_string.match(iso8601_utc_pattern);
|
||||||
|
var timestamp = 0;
|
||||||
|
|
||||||
|
if (time_components != null) {
|
||||||
|
if (time_components[8] == undefined) {
|
||||||
|
time_components[8] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
timestamp = Date.UTC(time_components[1], time_components[2] - 1, time_components[3],
|
||||||
|
time_components[4], time_components[5], time_components[6],
|
||||||
|
time_components[8]);
|
||||||
|
}
|
||||||
|
|
||||||
|
return timestamp;
|
||||||
|
},
|
||||||
|
|
||||||
|
app.helpers.dateFormatter = dateFormatter;
|
||||||
|
})();
|
||||||
|
|
@ -8,7 +8,7 @@ app.models.Photo = Backbone.Model.extend({
|
||||||
},
|
},
|
||||||
|
|
||||||
timeOf: function(field) {
|
timeOf: function(field) {
|
||||||
return new Date(this.get(field)) /1000;
|
return app.helpers.dateFormatter.parse(this.get(field)) / 1000;
|
||||||
},
|
},
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
|
||||||
|
|
@ -21,7 +21,7 @@ app.models.Post = Backbone.Model.extend({
|
||||||
},
|
},
|
||||||
|
|
||||||
timeOf: function(field) {
|
timeOf: function(field) {
|
||||||
return new Date(this.get(field)) /1000;
|
return app.helpers.dateFormatter.parse(this.get(field)) / 1000;
|
||||||
},
|
},
|
||||||
|
|
||||||
createReshareUrl : "/reshares",
|
createReshareUrl : "/reshares",
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@ describe("app", function() {
|
||||||
describe("user", function() {
|
describe("user", function() {
|
||||||
it("sets the user if given one and returns the current user", function() {
|
it("sets the user if given one and returns the current user", function() {
|
||||||
expect(app.user()).toBeFalsy()
|
expect(app.user()).toBeFalsy()
|
||||||
|
});
|
||||||
|
|
||||||
it("sets the user if given one and returns the current user", function() {
|
it("sets the user if given one and returns the current user", function() {
|
||||||
expect(app.user().authenticated()).toBeFalsy()
|
expect(app.user().authenticated()).toBeFalsy()
|
||||||
|
|
|
||||||
33
spec/javascripts/app/helpers/date_formatter_spec.js
Normal file
33
spec/javascripts/app/helpers/date_formatter_spec.js
Normal file
|
|
@ -0,0 +1,33 @@
|
||||||
|
describe("app.helpers.dateFormatter", function(){
|
||||||
|
|
||||||
|
beforeEach(function(){
|
||||||
|
this.statusMessage = factory.post();
|
||||||
|
this.formatter = app.helpers.dateFormatter;
|
||||||
|
})
|
||||||
|
|
||||||
|
describe("parse", function(){
|
||||||
|
context("modern web browsers", function(){
|
||||||
|
it ("supports ISO 8601 UTC dates", function(){
|
||||||
|
var timestamp = new Date(this.statusMessage.get("created_at")).getTime();
|
||||||
|
expect(this.formatter.parse(this.statusMessage.get("created_at"))).toEqual(timestamp);
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
context("legacy web browsers", function(){
|
||||||
|
it("supports ISO 8601 UTC dates", function(){
|
||||||
|
var timestamp = new Date(this.statusMessage.get("created_at")).getTime();
|
||||||
|
|
||||||
|
expect(this.formatter.parseISO8601UTC(this.statusMessage.get("created_at"))).toEqual(timestamp);
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
context("status messages", function(){
|
||||||
|
it("uses ISO 8601 UTC dates", function(){
|
||||||
|
var iso8601_utc_pattern = /^(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2})(.(\d{3}))?Z$/;
|
||||||
|
|
||||||
|
expect(iso8601_utc_pattern.test(this.statusMessage.get("created_at"))).toBe(true);
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
})
|
||||||
Loading…
Reference in a new issue