summaryrefslogtreecommitdiffstatshomepage
path: root/test/attributes/hx-params.js
blob: b2b19ca25563f1681e4893a168486a02d3c104fd (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
describe("hx-params attribute", function() {
    beforeEach(function () {
        this.server = makeServer();
        clearWorkArea();
    });
    afterEach(function () {
        this.server.restore();
        clearWorkArea();
    });

    it('none excludes all params', function () {
        this.server.respondWith("POST", "/params", function (xhr) {
            var params = getParameters(xhr);
            should.equal(params['i1'], undefined);
            should.equal(params['i2'], undefined);
            should.equal(params['i3'], undefined);
            xhr.respond(200, {}, "Clicked!")
        });
        var form = make('<form hx-trigger="click" hx-post="/params" hx-params="none">' +
            '<input name="i1" value="test"/>' +
            '<input  name="i2" value="test"/>' +
            '<input  name="i3" value="test"/>' +
            '</form> ');
        form.click();
        this.server.respond();
        form.innerHTML.should.equal("Clicked!");
    });

    it('"*" includes all params', function () {
        this.server.respondWith("POST", "/params", function (xhr) {
            var params = getParameters(xhr);
            should.equal(params['i1'], "test");
            should.equal(params['i2'], "test");
            should.equal(params['i3'], "test");
            xhr.respond(200, {}, "Clicked!")
        });
        var form = make('<form hx-trigger="click" hx-post="/params" hx-params="*">' +
            '<input name="i1" value="test"/>' +
            '<input  name="i2" value="test"/>' +
            '<input  name="i3" value="test"/>' +
            '</form> ');
        form.click();
        this.server.respond();
        form.innerHTML.should.equal("Clicked!");
    });

    it('named includes works', function () {
        this.server.respondWith("POST", "/params", function (xhr) {
            var params = getParameters(xhr);
            should.equal(params['i1'], "test");
            should.equal(params['i2'], undefined);
            should.equal(params['i3'], "test");
            xhr.respond(200, {}, "Clicked!")
        });
        var form = make('<form hx-trigger="click" hx-post="/params" hx-params="i1, i3">' +
            '<input name="i1" value="test"/>' +
            '<input  name="i2" value="test"/>' +
            '<input  name="i3" value="test"/>' +
            '</form> ');
        form.click();
        this.server.respond();
        form.innerHTML.should.equal("Clicked!");
    });

    it('named exclude works', function () {
        this.server.respondWith("POST", "/params", function (xhr) {
            var params = getParameters(xhr);
            should.equal(params['i1'], undefined);
            should.equal(params['i2'], "test");
            should.equal(params['i3'], undefined);
            xhr.respond(200, {}, "Clicked!")
        });
        var form = make('<form hx-trigger="click" hx-post="/params" hx-params="not i1, i3">' +
            '<input name="i1" value="test"/>' +
            '<input  name="i2" value="test"/>' +
            '<input  name="i3" value="test"/>' +
            '</form> ');
        form.click();
        this.server.respond();
        form.innerHTML.should.equal("Clicked!");
    });

    it('named exclude works  w/ data-* prefix', function () {
        this.server.respondWith("POST", "/params", function (xhr) {
            var params = getParameters(xhr);
            should.equal(params['i1'], undefined);
            should.equal(params['i2'], "test");
            should.equal(params['i3'], undefined);
            xhr.respond(200, {}, "Clicked!")
        });
        var form = make('<form data-hx-trigger="click" data-hx-post="/params" data-hx-params="not i1, i3">' +
            '<input name="i1" value="test"/>' +
            '<input  name="i2" value="test"/>' +
            '<input  name="i3" value="test"/>' +
            '</form> ');
        form.click();
        this.server.respond();
        form.innerHTML.should.equal("Clicked!");
    });

});