GitLab Total Time

Add total time to header of lists on GitLab boards

Verze ze dne 16. 08. 2021. Zobrazit nejnovější verzi.

K instalaci tototo skriptu si budete muset nainstalovat rozšíření jako Tampermonkey, Greasemonkey nebo Violentmonkey.

K instalaci tohoto skriptu si budete muset nainstalovat rozšíření jako Tampermonkey nebo Violentmonkey.

K instalaci tohoto skriptu si budete muset nainstalovat rozšíření jako Tampermonkey nebo Violentmonkey.

K instalaci tohoto skriptu si budete muset nainstalovat rozšíření jako Tampermonkey nebo Userscripts.

You will need to install an extension such as Tampermonkey to install this script.

K instalaci tohoto skriptu si budete muset nainstalovat manažer uživatelských skriptů.

(Už mám manažer uživatelských skriptů, nechte mě ho nainstalovat!)

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

(Už mám manažer uživatelských stylů, nechte mě ho nainstalovat!)

  1. // ==UserScript==
  2. // @name GitLab Total Time
  3. // @namespace https://github.com/LibreCodeCoop/gitlab-time-userscript/
  4. // @version 0.1
  5. // @description Add total time to header of lists on GitLab boards
  6. // @author Vitor Mattos
  7. // @supportURL https://github.com/LibreCodeCoop/gitlab-time-userscript/issues
  8. // @contributionURL https://patreon.com/librecode
  9. // @license AGPL-3.0-or-later
  10. // @match https://gitlab.com/*/*/boards/*
  11. // @match http*://*/*/boards
  12. // @match http*://*/*/boards?*
  13. // @match http*://*/*/boards/*
  14. // @icon 
  15. // @require https://code.jquery.com/jquery-3.6.0.min.js
  16. // ==/UserScript==
  17.  
  18. function listTotalTime() {
  19. $('header.board-header div.issue-count-badge').each(function() {
  20. var container = $(this).children();
  21. var timeElement = container.find('span.list-total-time');
  22. if(timeElement.length === 0) {
  23. container.append('<span class="gl-display-inline-flex gl-ml-3 list-total-time"></span>')
  24. }
  25. timeElement = container.find('span.list-total-time')
  26.  
  27. timeElement.attr('time_m', 0)
  28. timeElement.attr('time_h', 0)
  29. });
  30.  
  31. $('time:not([datetime]').each(function() {
  32. var countElement = $(this).closest('div.board-inner').find('span.list-total-time');
  33. var time = $(this).text()
  34. var type = time.slice(-1)
  35. time = time.slice(0, -1)
  36. countElement.attr('time_' + type, parseInt(countElement.attr('time_' + type)) + parseInt(time))
  37. })
  38.  
  39. $('span.list-total-time').each(function() {
  40. var min = parseInt($(this).attr('time_m'))
  41. if (min >= 60) {
  42. $(this).attr('time_h', parseInt($(this).attr('time_h')) + min / 60)
  43. $(this).attr('time_m', parseInt($(this).attr('time_m')) + min % 60)
  44. }
  45. var minPad = $(this).attr('time_m')
  46. minPad = ('00' + minPad).slice(-2)
  47. $(this).html(
  48. '<svg role="img" aria-hidden="true" class="gl-mr-2 gl-icon s16" data-testid="hourglass-icon"><use href="/assets/icons-05c4d4d8f3cc1fe0f22064d47d6a57d254ff9686a08abb74993ade21581e46f8.svg#hourglass"></use></svg>'
  49. + $(this).attr('time_h')
  50. + ':'
  51. + minPad
  52. )
  53. });
  54. }
  55.  
  56. $(document).ready(function() {
  57. setTimeout(function () {
  58. $('<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>').insertAfter($('[data-testid="boards-create-list"]'));
  59.  
  60. $('#refresh-list-time').on("click", function(){
  61. listTotalTime()
  62. })
  63. }, 1000)
  64. });