Blame view

vendor/yiisoft/yii2-debug/assets/timeline.js 2.07 KB
2e86c939   xu   “首次提交”
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
(function () {
    'use strict';

    var Timeline = function (options) {

        this.options = options;
        var self = this;
        this.init = function () {
            if (this.options.$focus) {
                this.options.$focus.focus();
                delete this.options.$focus;
            }
            self.options.$timeline.find('.debug-timeline-panel__item a')
                .on('show.bs.tooltip', function () {
                    var data = $(this).data('memory');
                    if (data) {
                        self.options.$memory.text(data[0]).css({'bottom': data[1]+'%'});
                    }
                })
                .tooltip();
            return self;
        };
        this.setFocus = function ($elem) {
            this.options.$focus = $elem;
            return $elem;
        };
        this.affixTop = function (refresh) {
            if (!this.options.affixTop || refresh) {
                this.options.affixTop = self.options.$header.offset().top;
            }
            return this.options.affixTop;
        };

        $(document).on('pjax:success', function () {
            self.init()
        });
        $(window).on('resize', function () {
            self.affixTop(true);
        });
        self.options.$header
            .on('dblclick', function () {
                self.options.$timeline.toggleClass('inline');
            })
            .on('click', 'button', function () {
                self.options.$timeline.toggleClass('inline');
            });
        self.options.$search.on('change', function () {
            self.setFocus($(this)).submit();
        });
        self.options.$timeline.affix({
            offset: {
                top: function () {
                    return self.affixTop()
                }
            }
        });
        this.init();
    };

    (new Timeline({
        '$timeline': $('.debug-timeline-panel'),
        '$header': $('.debug-timeline-panel__header'),
        '$search': $('.debug-timeline-panel__search input'),
        '$memory': $('.debug-timeline-panel__memory .scale')
    }));
})();