-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathgitlab-time.user.js
88 lines (82 loc) · 8.23 KB
/
gitlab-time.user.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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
// ==UserScript==
// @name GitLab Total Time
// @namespace https://github.com/LibreCodeCoop/gitlab-time-userscript/
// @version 0.3
// @description Add total time to header of lists on GitLab boards
// @author Vitor Mattos
// @supportURL https://github.com/LibreCodeCoop/gitlab-time-userscript/issues
// @contributionURL https://patreon.com/librecode
// @license AGPL-3.0-or-later
// @match https://gitlab.com/*/*/boards/*
// @match http*://*/*/boards
// @match http*://*/*/boards?*
// @match http*://*/*/boards/*
// @icon 
// @require https://code.jquery.com/jquery-3.6.0.min.js
// ==/UserScript==
function listTotalTime() {
$('header.board-header div.issue-count-badge').each(function() {
var container = $(this).children();
var timeElement = container.find('span.list-total-time');
if(timeElement.length === 0) {
container.append('<span class="gl-display-inline-flex gl-ml-3 list-total-time"></span>')
}
timeElement = container.find('span.list-total-time')
timeElement.attr('time_m', 0)
timeElement.attr('time_h', 0)
timeElement.attr('time_d', 0)
});
$('time:not([datetime]').each(function() {
var countElement = $(this).closest('div.board').find('span.list-total-time');
var time = $(this).text()
var timeArray = time.split(" ")
for (var i = 0; i < timeArray.length; i++) {
var type = timeArray[i].slice(-1);
time = timeArray[i].slice(0, -1);
if (type === "d") {
countElement.attr(
"time_d",
parseInt(countElement.attr("time_d")) + parseInt(time)
);
} else if (type === "h") {
countElement.attr(
"time_h",
parseInt(countElement.attr("time_h")) + parseInt(time)
);
} else if (type === "m") {
countElement.attr(
"time_m",
parseInt(countElement.attr("time_m")) + parseInt(time)
);
}
}
});
$('span.list-total-time').each(function() {
var min = parseInt($(this).attr('time_m'))
var hour = parseInt($(this).attr('time_h'));
var day = parseInt($(this).attr('time_d')) * 8;
hour += day;
if (min >= 60) {
hour += min / 60;
min = min % 60;
}
$(this).attr('time_h', hour)
$(this).attr('time_m', min)
var minPad = $(this).attr('time_m')
minPad = ('00' + minPad).slice(-2)
$(this).html(
'<svg role="img" aria-hidden="true" class="gl-mr-2 gl-icon s14" data-testid="hourglass-icon"><use href="/assets/icons-ffa14d1d14478de17bd5c7220bf466194ad3bc99589858dae76a86bc89017324.svg#hourglass"></use></svg>'
+ $(this).attr('time_h')
+ ':'
+ minPad
)
});
}
$(document).ready(function() {
setTimeout(function () {
$('<div class="gl-ml-3 gl-display-flex gl-align-items-center"><button title="" data-qa-selector="boards_config_button" type="button" class="btn btn-default btn-md gl-button" id="refresh-list-time"><!----> <!----> <span class="gl-button-text">Refresh times</span></button></div>').insertBefore($('[data-testid="board-options-dropdown"]'));
$(document).on("click", "#refresh-list-time", function() {
listTotalTime();
});
}, 1000);
});