summaryrefslogtreecommitdiffstats
path: root/core/src/jquery/tipsy.js
blob: 0ae6ec83af07b3b1e8fb26b60338279c28c1396b (plain)
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
/**
 * @copyright 2019 Christoph Wurst <christoph@winzerhof-wurst.at>
 *
 * @author 2019 Christoph Wurst <christoph@winzerhof-wurst.at>
 *
 * @license GNU AGPL version 3 or any later version
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as
 * published by the Free Software Foundation, either version 3 of the
 * License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */

import $ from 'jquery'

/**
 * $ tipsy shim for the bootstrap tooltip
 * @param {Object} argument options
 * @returns {Object} this
 * @deprecated
 */
$.fn.tipsy = function(argument) {
	console.warn('Deprecation warning: tipsy is deprecated. Use tooltip instead.')
	if (typeof argument === 'object' && argument !== null) {

		// tipsy defaults
		const options = {
			placement: 'bottom',
			delay: { 'show': 0, 'hide': 0 },
			trigger: 'hover',
			html: false,
			container: 'body',
		}
		if (argument.gravity) {
			switch (argument.gravity) {
			case 'n':
			case 'nw':
			case 'ne':
				options.placement = 'bottom'
				break
			case 's':
			case 'sw':
			case 'se':
				options.placement = 'top'
				break
			case 'w':
				options.placement = 'right'
				break
			case 'e':
				options.placement = 'left'
				break
			}
		}
		if (argument.trigger) {
			options.trigger = argument.trigger
		}
		if (argument.delayIn) {
			options.delay.show = argument.delayIn
		}
		if (argument.delayOut) {
			options.delay.hide = argument.delayOut
		}
		if (argument.html) {
			options.html = true
		}
		if (argument.fallback) {
			options.title = argument.fallback
		}
		// destroy old tooltip in case the title has changed
		$.fn.tooltip.call(this, 'destroy')
		$.fn.tooltip.call(this, options)
	} else {
		this.tooltip(argument)
		$.fn.tooltip.call(this, argument)
	}
	return this
}