tooltip.js 13.1 KB
Newer Older
Jacob Thornton's avatar
Jacob Thornton committed
1
2
$(function () {

fat's avatar
fat committed
3
    module("tooltip")
Jacob Thornton's avatar
Jacob Thornton committed
4

5
6
7
8
9
10
      test("should provide no conflict", function () {
        var tooltip = $.fn.tooltip.noConflict()
        ok(!$.fn.tooltip, 'tooltip was set back to undefined (org value)')
        $.fn.tooltip = tooltip
      })

Jacob Thornton's avatar
Jacob Thornton committed
11
12
      test("should be defined on jquery object", function () {
        var div = $("<div></div>")
13
        ok(div.tooltip, 'popover method is defined')
Jacob Thornton's avatar
Jacob Thornton committed
14
15
16
17
      })

      test("should return element", function () {
        var div = $("<div></div>")
18
        ok(div.tooltip() == div, 'document.body returned')
Jacob Thornton's avatar
Jacob Thornton committed
19
20
21
      })

      test("should expose default settings", function () {
fat's avatar
fat committed
22
        ok(!!$.fn.tooltip.Constructor.DEFAULTS, 'defaults is defined')
Jacob Thornton's avatar
Jacob Thornton committed
23
24
      })

Yohn's avatar
Yohn committed
25
      test("should empty title attribute", function () {
26
        var tooltip = $('<a href="#" rel="tooltip" title="Another tooltip"></a>').tooltip()
Yohn's avatar
Yohn committed
27
        ok(tooltip.attr('title') === '', 'title attribute was emptied')
Jacob Thornton's avatar
Jacob Thornton committed
28
29
30
      })

      test("should add data attribute for referencing original title", function () {
31
32
        var tooltip = $('<a href="#" rel="tooltip" title="Another tooltip"></a>').tooltip()
        equals(tooltip.attr('data-original-title'), 'Another tooltip', 'original title preserved in data attribute')
Jacob Thornton's avatar
Jacob Thornton committed
33
34
35
36
      })

      test("should place tooltips relative to placement option", function () {
        $.support.transition = false
37
        var tooltip = $('<a href="#" rel="tooltip" title="Another tooltip"></a>')
38
          .appendTo('#qunit-fixture')
39
40
          .tooltip({placement: 'bottom'})
          .tooltip('show')
Jacob Thornton's avatar
Jacob Thornton committed
41

42
        ok($(".tooltip").is('.fade.bottom.in'), 'has correct classes applied')
43
        tooltip.tooltip('hide')
Jacob Thornton's avatar
Jacob Thornton committed
44
45
      })

46
      test("should allow html entities", function () {
Jacob Thornton's avatar
Jacob Thornton committed
47
        $.support.transition = false
48
        var tooltip = $('<a href="#" rel="tooltip" title="<b>@fat</b>"></a>')
49
          .appendTo('#qunit-fixture')
50
          .tooltip({html: true})
51
          .tooltip('show')
Jacob Thornton's avatar
Jacob Thornton committed
52

53
54
55
        ok($('.tooltip b').length, 'b tag was inserted')
        tooltip.tooltip('hide')
        ok(!$(".tooltip").length, 'tooltip removed')
Jacob Thornton's avatar
Jacob Thornton committed
56
57
      })

58
      test("should respect custom classes", function () {
59
        var tooltip = $('<a href="#" rel="tooltip" title="Another tooltip"></a>')
60
          .appendTo('#qunit-fixture')
61
62
          .tooltip({ template: '<div class="tooltip some-class"><div class="tooltip-arrow"/><div class="tooltip-inner"/></div>'})
          .tooltip('show')
63

64
65
66
        ok($('.tooltip').hasClass('some-class'), 'custom class is present')
        tooltip.tooltip('hide')
        ok(!$(".tooltip").length, 'tooltip removed')
67
68
      })

69
70
71
      test("should fire show event", function () {
        stop()
        var tooltip = $('<div title="tooltip title"></div>')
72
          .on("show.bs.tooltip", function() {
73
74
75
76
77
78
79
80
81
            ok(true, "show was called")
            start()
          })
          .tooltip('show')
      })

      test("should fire shown event", function () {
        stop()
        var tooltip = $('<div title="tooltip title"></div>')
82
          .on("shown.bs.tooltip", function() {
83
84
85
86
87
88
89
90
91
            ok(true, "shown was called")
            start()
          })
          .tooltip('show')
      })

      test("should not fire shown event when default prevented", function () {
        stop()
        var tooltip = $('<div title="tooltip title"></div>')
92
          .on("show.bs.tooltip", function(e) {
93
94
95
96
            e.preventDefault()
            ok(true, "show was called")
            start()
          })
97
          .on("shown.bs.tooltip", function() {
98
99
100
101
102
103
104
105
            ok(false, "shown was called")
          })
          .tooltip('show')
      })

      test("should fire hide event", function () {
        stop()
        var tooltip = $('<div title="tooltip title"></div>')
106
          .on("shown.bs.tooltip", function() {
107
108
            $(this).tooltip('hide')
          })
109
          .on("hide.bs.tooltip", function() {
110
111
112
113
114
115
116
117
118
            ok(true, "hide was called")
            start()
          })
          .tooltip('show')
      })

      test("should fire hidden event", function () {
        stop()
        var tooltip = $('<div title="tooltip title"></div>')
119
          .on("shown.bs.tooltip", function() {
120
121
            $(this).tooltip('hide')
          })
122
          .on("hidden.bs.tooltip", function() {
123
124
125
126
127
128
129
130
131
            ok(true, "hidden was called")
            start()
          })
          .tooltip('show')
      })

      test("should not fire hidden event when default prevented", function () {
        stop()
        var tooltip = $('<div title="tooltip title"></div>')
132
          .on("shown.bs.tooltip", function() {
133
134
            $(this).tooltip('hide')
          })
135
          .on("hide.bs.tooltip", function(e) {
136
137
138
139
            e.preventDefault()
            ok(true, "hide was called")
            start()
          })
140
          .on("hidden.bs.tooltip", function() {
141
142
143
144
145
            ok(false, "hidden was called")
          })
          .tooltip('show')
      })

146
147
148
149
150
151
152
153
154
155
      test("should not show tooltip if leave event occurs before delay expires", function () {
        var tooltip = $('<a href="#" rel="tooltip" title="Another tooltip"></a>')
          .appendTo('#qunit-fixture')
          .tooltip({ delay: 200 })

        stop()

        tooltip.trigger('mouseenter')

        setTimeout(function () {
156
          ok(!$(".tooltip").is('.fade.in'), 'tooltip is not faded in')
157
158
          tooltip.trigger('mouseout')
          setTimeout(function () {
159
            ok(!$(".tooltip").is('.fade.in'), 'tooltip is not faded in')
160
161
162
163
164
            start()
          }, 200)
        }, 100)
      })

165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
      test("should not show tooltip if leave event occurs before delay expires, even if hide delay is 0", function () {
        var tooltip = $('<a href="#" rel="tooltip" title="Another tooltip"></a>')
          .appendTo('#qunit-fixture')
          .tooltip({ delay: { show: 200, hide: 0} })

        stop()

        tooltip.trigger('mouseenter')

        setTimeout(function () {
          ok(!$(".tooltip").is('.fade.in'), 'tooltip is not faded in')
          tooltip.trigger('mouseout')
          setTimeout(function () {
            ok(!$(".tooltip").is('.fade.in'), 'tooltip is not faded in')
            start()
          }, 200)
        }, 100)
      })

184
185
186
187
188
189
190
      test("should not show tooltip if leave event occurs before delay expires", function () {
        var tooltip = $('<a href="#" rel="tooltip" title="Another tooltip"></a>')
          .appendTo('#qunit-fixture')
          .tooltip({ delay: 100 })
        stop()
        tooltip.trigger('mouseenter')
        setTimeout(function () {
191
          ok(!$(".tooltip").is('.fade.in'), 'tooltip is not faded in')
192
193
          tooltip.trigger('mouseout')
          setTimeout(function () {
194
            ok(!$(".tooltip").is('.fade.in'), 'tooltip is not faded in')
195
196
197
198
199
            start()
          }, 100)
        }, 50)
      })

200
      test("should show tooltip if leave event hasn't occured before delay expires", function () {
201
202
        var tooltip = $('<a href="#" rel="tooltip" title="Another tooltip"></a>')
          .appendTo('#qunit-fixture')
Jacob Thornton's avatar
Jacob Thornton committed
203
          .tooltip({ delay: 150 })
204
205
206
        stop()
        tooltip.trigger('mouseenter')
        setTimeout(function () {
207
          ok(!$(".tooltip").is('.fade.in'), 'tooltip is not faded in')
208
        }, 100)
Jacob Thornton's avatar
Jacob Thornton committed
209
210
211
212
        setTimeout(function () {
          ok($(".tooltip").is('.fade.in'), 'tooltip has faded in')
          start()
        }, 200)
213
214
      })

215
      test("should destroy tooltip", function () {
216
        var tooltip = $('<div/>').tooltip().on('click.foo', function(){})
217
        ok(tooltip.data('bs.tooltip'), 'tooltip has data')
218
219
        ok($._data(tooltip[0], 'events').mouseover && $._data(tooltip[0], 'events').mouseout, 'tooltip has hover event')
        ok($._data(tooltip[0], 'events').click[0].namespace == 'foo', 'tooltip has extra click.foo event')
220
        tooltip.tooltip('show')
221
        tooltip.tooltip('destroy')
222
        ok(!tooltip.hasClass('in'), 'tooltip is hidden')
223
        ok(!$._data(tooltip[0], 'bs.tooltip'), 'tooltip does not have data')
224
225
        ok($._data(tooltip[0], 'events').click[0].namespace == 'foo', 'tooltip still has click.foo')
        ok(!$._data(tooltip[0], 'events').mouseover && !$._data(tooltip[0], 'events').mouseout, 'tooltip does not have any events')
226
227
      })

228
229
230
231
232
233
234
235
      test("should show tooltip with delegate selector on click", function () {
        var div = $('<div><a href="#" rel="tooltip" title="Another tooltip"></a></div>')
        var tooltip = div.appendTo('#qunit-fixture')
                         .tooltip({ selector: 'a[rel=tooltip]',
                                    trigger: 'click' })
        div.find('a').trigger('click')
        ok($(".tooltip").is('.fade.in'), 'tooltip is faded in')
      })
236
237
238
239
240
241
242
243

      test("should show tooltip when toggle is called", function () {
        var tooltip = $('<a href="#" rel="tooltip" title="tooltip on toggle"></a>')
          .appendTo('#qunit-fixture')
          .tooltip({trigger: 'manual'})
          .tooltip('toggle')
        ok($(".tooltip").is('.fade.in'), 'tooltip should be toggled in')
      })
244
245
246
247
248
249
250
251
252
253

      test("should place tooltips inside the body", function () {
        var tooltip = $('<a href="#" rel="tooltip" title="Another tooltip"></a>')
          .appendTo('#qunit-fixture')
          .tooltip({container:'body'})
          .tooltip('show')
        ok($("body > .tooltip").length, 'inside the body')
        ok(!$("#qunit-fixture > .tooltip").length, 'not found in parent')
        tooltip.tooltip('hide')
      })
254
255

      test("should place tooltip inside window", function(){
256
257
258
        var container = $("<div />").appendTo("body")
            .css({position: "absolute", width: 200, height: 200, bottom: 0, left: 0})
          , tooltip = $("<a href='#' title='Very very very very very very very very long tooltip'>Hover me</a>")
259
          .css({position: "absolute", top:0, left: 0})
260
261
          .appendTo(container)
          .tooltip({placement: "top", animate: false})
Guillaume Gautreau's avatar
Guillaume Gautreau committed
262
          .tooltip("show")
263

Guillaume Gautreau's avatar
Guillaume Gautreau committed
264
        stop()
265
266

        setTimeout(function(){
Guillaume Gautreau's avatar
Guillaume Gautreau committed
267
          ok($(".tooltip").offset().left >= 0)
268

Guillaume Gautreau's avatar
Guillaume Gautreau committed
269
270
          start()
          container.remove()
271
        }, 100)
Guillaume Gautreau's avatar
Guillaume Gautreau committed
272
      })
273
274
275
276
277
278
279
280
281

      test("should place tooltip on top of element", function(){
        var container = $("<div />").appendTo("body")
              .css({position: "absolute", bottom: 0, left: 0, textAlign: "right", width: 300, height: 300})
            , p = $("<p style='margin-top:200px' />").appendTo(container)
            , tooltiped = $("<a href='#' title='very very very very very very very long tooltip'>Hover me</a>")
              .css({marginTop: 200})
              .appendTo(p)
              .tooltip({placement: "top", animate: false})
Guillaume Gautreau's avatar
Guillaume Gautreau committed
282
              .tooltip("show")
283

Guillaume Gautreau's avatar
Guillaume Gautreau committed
284
        stop()
285
286

        setTimeout(function(){
Guillaume Gautreau's avatar
Guillaume Gautreau committed
287
          var tooltip = container.find(".tooltip")
288

Guillaume Gautreau's avatar
Guillaume Gautreau committed
289
290
291
          start()
          ok(tooltip.offset().top + tooltip.outerHeight() <= tooltiped.offset().top)
          container.remove()
292
        }, 100)
Guillaume Gautreau's avatar
Guillaume Gautreau committed
293
      })
294
295
296

      test("should add position class before positioning so that position-specific styles are taken into account", function(){
        $("head").append('<style> .tooltip.right { white-space: nowrap; } .tooltip.right .tooltip-inner { max-width: none; } </style>')
fat's avatar
fat committed
297

298
        var container = $("<div />").appendTo("body")
fat's avatar
fat committed
299
          , target = $('<a href="#" rel="tooltip" title="very very very very very very very very long tooltip in one line"></a>')
fat's avatar
fat committed
300
301
302
              .appendTo(container)
              .tooltip({placement: 'right'})
              .tooltip('show')
303
          , tooltip = container.find(".tooltip")
fat's avatar
fat committed
304
305

        ok( Math.round(target.offset().top + target[0].offsetHeight/2 - tooltip[0].offsetHeight/2) === Math.round(tooltip.offset().top) )
306
307
        target.tooltip('hide')
      })
fat's avatar
fat committed
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343

      test("tooltip title test #1", function () {
        var tooltip = $('<a href="#" rel="tooltip" title="Simple tooltip" style="display: inline-block; position: absolute; top: 0; left: 0;"></a>')
          .appendTo('#qunit-fixture')
          .tooltip({
          })
          .tooltip('show')
        equal($('.tooltip').children('.tooltip-inner').text(), 'Simple tooltip', 'title from title attribute is set')
        tooltip.tooltip('hide')
        ok(!$(".tooltip").length, 'tooltip removed')
      })

      test("tooltip title test #2", function () {
        var tooltip = $('<a href="#" rel="tooltip" title="Simple tooltip" style="display: inline-block; position: absolute; top: 0; left: 0;"></a>')
          .appendTo('#qunit-fixture')
          .tooltip({
            title: 'This is a tooltip with some content'
          })
          .tooltip('show')
        equal($('.tooltip').children('.tooltip-inner').text(), 'Simple tooltip', 'title is set from title attribute while prefered over title option')
        tooltip.tooltip('hide')
        ok(!$(".tooltip").length, 'tooltip removed')
      })

      test("tooltip title test #3", function () {
        var tooltip = $('<a href="#" rel="tooltip" style="display: inline-block; position: absolute; top: 0; left: 0;"></a>')
          .appendTo('#qunit-fixture')
          .tooltip({
            title: 'This is a tooltip with some content'
          })
          .tooltip('show')
        equal($('.tooltip').children('.tooltip-inner').text(), 'This is a tooltip with some content', 'title from title option is set')
        tooltip.tooltip('hide')
        ok(!$(".tooltip").length, 'tooltip removed')
      })

344
})