case insensitive test for presence of headers because chrome uses lower case in the string

This commit is contained in:
carson 2020-09-18 12:13:16 -06:00
parent 7d49d5ab58
commit f39fccf28c
2 changed files with 38 additions and 27 deletions

View File

@ -1654,15 +1654,13 @@ return (function () {
try {
if (!triggerEvent(elt, 'htmx:beforeOnLoad', eventDetail)) return;
//AK - FIXED CHROME issue - "refuse to get unsafe header" warning.
if (xhr.getAllResponseHeaders().indexOf("HX-Trigger") >= 0) {
if (xhr.getAllResponseHeaders().search(/HX-Trigger/i) >= 0) {
handleTrigger(elt, this.getResponseHeader("HX-Trigger"));
}
}
if (xhr.getAllResponseHeaders().indexOf("HX-Push") >= 0) {
if (xhr.getAllResponseHeaders().search(/HX-Push/i) >= 0) {
var pushedUrl = this.getResponseHeader("HX-Push");
}
//AK - FIXED CHROME issue - "refuse to get unsafe header" warning. \\
}
var shouldSaveHistory = shouldPush(elt) || pushedUrl;

View File

@ -1,4 +1,4 @@
describe("Core htmx AJAX headers", function() {
describe("Core htmx AJAX headers", function () {
beforeEach(function () {
this.server = makeServer();
clearWorkArea();
@ -8,8 +8,8 @@ describe("Core htmx AJAX headers", function() {
clearWorkArea();
});
it("should include the HX-Request header", function(){
this.server.respondWith("GET", "/test", function(xhr){
it("should include the HX-Request header", function () {
this.server.respondWith("GET", "/test", function (xhr) {
xhr.requestHeaders['HX-Request'].should.be.equal('true');
xhr.respond(200, {}, "");
});
@ -18,8 +18,8 @@ describe("Core htmx AJAX headers", function() {
this.server.respond();
})
it("should include the HX-Trigger header", function(){
this.server.respondWith("GET", "/test", function(xhr){
it("should include the HX-Trigger header", function () {
this.server.respondWith("GET", "/test", function (xhr) {
xhr.requestHeaders['HX-Trigger'].should.equal('d1');
xhr.respond(200, {}, "");
});
@ -28,8 +28,8 @@ describe("Core htmx AJAX headers", function() {
this.server.respond();
})
it("should include the HX-Trigger-Name header", function(){
this.server.respondWith("GET", "/test", function(xhr){
it("should include the HX-Trigger-Name header", function () {
this.server.respondWith("GET", "/test", function (xhr) {
xhr.requestHeaders['HX-Trigger-Name'].should.equal('n1');
xhr.respond(200, {}, "");
});
@ -38,8 +38,8 @@ describe("Core htmx AJAX headers", function() {
this.server.respond();
})
it("should include the HX-Target header", function(){
this.server.respondWith("GET", "/test", function(xhr){
it("should include the HX-Target header", function () {
this.server.respondWith("GET", "/test", function (xhr) {
xhr.requestHeaders['HX-Target'].should.equal('d1');
xhr.respond(200, {}, "");
});
@ -48,8 +48,8 @@ describe("Core htmx AJAX headers", function() {
this.server.respond();
})
it("should handle simple string HX-Trigger response header properly", function(){
this.server.respondWith("GET", "/test", [200, {"HX-Trigger" : "foo"}, ""]);
it("should handle simple string HX-Trigger response header properly", function () {
this.server.respondWith("GET", "/test", [200, {"HX-Trigger": "foo"}, ""]);
var div = make('<div hx-get="/test"></div>');
var invokedEvent = false;
@ -61,8 +61,21 @@ describe("Core htmx AJAX headers", function() {
invokedEvent.should.equal(true);
})
it("should handle a namespaced HX-Trigger response header properly", function(){
this.server.respondWith("GET", "/test", [200, {"HX-Trigger" : "namespace:foo"}, ""]);
it("should handle simple string HX-Trigger response header in different case properly", function () {
this.server.respondWith("GET", "/test", [200, {"hx-trigger": "foo"}, ""]);
var div = make('<div hx-get="/test"></div>');
var invokedEvent = false;
div.addEventListener("foo", function (evt) {
invokedEvent = true;
});
div.click();
this.server.respond();
invokedEvent.should.equal(true);
})
it("should handle a namespaced HX-Trigger response header properly", function () {
this.server.respondWith("GET", "/test", [200, {"HX-Trigger": "namespace:foo"}, ""]);
var div = make('<div hx-get="/test"></div>');
var invokedEvent = false;
@ -74,8 +87,8 @@ describe("Core htmx AJAX headers", function() {
invokedEvent.should.equal(true);
})
it("should handle basic JSON HX-Trigger response header properly", function(){
this.server.respondWith("GET", "/test", [200, {"HX-Trigger" : "{\"foo\":null}"}, ""]);
it("should handle basic JSON HX-Trigger response header properly", function () {
this.server.respondWith("GET", "/test", [200, {"HX-Trigger": "{\"foo\":null}"}, ""]);
var div = make('<div hx-get="/test"></div>');
var invokedEvent = false;
@ -89,8 +102,8 @@ describe("Core htmx AJAX headers", function() {
invokedEvent.should.equal(true);
})
it("should handle JSON with array arg HX-Trigger response header properly", function(){
this.server.respondWith("GET", "/test", [200, {"HX-Trigger" : "{\"foo\":[1, 2, 3]}"}, ""]);
it("should handle JSON with array arg HX-Trigger response header properly", function () {
this.server.respondWith("GET", "/test", [200, {"HX-Trigger": "{\"foo\":[1, 2, 3]}"}, ""]);
var div = make('<div hx-get="/test"></div>');
var invokedEvent = false;
@ -104,8 +117,8 @@ describe("Core htmx AJAX headers", function() {
invokedEvent.should.equal(true);
})
it("should handle JSON with array arg HX-Trigger response header properly", function(){
this.server.respondWith("GET", "/test", [200, {"HX-Trigger" : "{\"foo\":{\"a\":1, \"b\":2}}"}, ""]);
it("should handle JSON with array arg HX-Trigger response header properly", function () {
this.server.respondWith("GET", "/test", [200, {"HX-Trigger": "{\"foo\":{\"a\":1, \"b\":2}}"}, ""]);
var div = make('<div hx-get="/test"></div>');
var invokedEvent = false;
@ -120,8 +133,8 @@ describe("Core htmx AJAX headers", function() {
invokedEvent.should.equal(true);
})
it("should survive malformed JSON in HX-Trigger response header", function(){
this.server.respondWith("GET", "/test", [200, {"HX-Trigger" : "{not: valid}"}, ""]);
it("should survive malformed JSON in HX-Trigger response header", function () {
this.server.respondWith("GET", "/test", [200, {"HX-Trigger": "{not: valid}"}, ""]);
var div = make('<div hx-get="/test"></div>');
div.click();