Start adding basic login infrastructure (still needs styling)
[gitphp.git] / js / modules / tooltip.tag.js
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
/*
 * GitPHP Javascript tag tooltip
 * 
 * Displays tag messages in a tooltip
 * 
 * @author Christopher Han <xiphux@gmail.com>
 * @copyright Copyright (c) 2011 Christopher Han
 * @package GitPHP
 * @subpackage Javascript
 */
 
define(["jquery", "modules/geturl", "modules/getproject", 'modules/resources'],
        function($, url, project, resources) {
 
                function getTagName(element) {
                        var tag = element.attr('href').match(/t=([^&]+)/);
                        if (!tag) {
                                tag = element.attr('href').match(/\/tags\/([^\/\?]+)/);
                        }
                        return tag ? tag[1] : null;
                }
 
                function buildTipConfig(tag) {
                        return {
                                content: {
                                        text: '<img src="' + url + 'images/tooltip-loader.gif" alt="' + resources.Loading + '" />',
                                        ajax: {
                                                url: url,
                                                data: {
                                                        p: project,
                                                        a: 'tag',
                                                        o: 'jstip',
                                                        t: tag
                                                },
                                                type: 'GET'
                                        }
                                },
                                style: {
                                        classes: 'ui-tooltip-gitphp ui-tooltip-light ui-tooltip-shadow'
                                },
                                position: {
                                        viewport: $(window)
                                }
                        }
                }
 
                return function(elements) {
 
                        if (elements && (elements.size() > 0)) {
                                require(['qtip'], function() {
                                        elements.each(function(){
                                                var jThis = $(this);
                                                var tag = getTagName(jThis);
                                                if (!tag) {
                                                        return;
                                                }
                                                var config = buildTipConfig(tag);
                                                jThis.qtip(config);
                                        });
                                });
                        }
                }
        }
);
 
comments