You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

repo-diff-commit.js 1.8KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. import {hideElem, showElem, toggleElem} from '../utils/dom.js';
  2. import {GET} from '../modules/fetch.js';
  3. async function loadBranchesAndTags(area, loadingButton) {
  4. loadingButton.classList.add('disabled');
  5. try {
  6. const res = await GET(loadingButton.getAttribute('data-fetch-url'));
  7. const data = await res.json();
  8. hideElem(loadingButton);
  9. addTags(area, data.tags);
  10. addBranches(area, data.branches, data.default_branch);
  11. showElem(area.querySelectorAll('.branch-and-tag-detail'));
  12. } finally {
  13. loadingButton.classList.remove('disabled');
  14. }
  15. }
  16. function addTags(area, tags) {
  17. const tagArea = area.querySelector('.tag-area');
  18. toggleElem(tagArea.parentElement, tags.length > 0);
  19. for (const tag of tags) {
  20. addLink(tagArea, tag.web_link, tag.name);
  21. }
  22. }
  23. function addBranches(area, branches, defaultBranch) {
  24. const defaultBranchTooltip = area.getAttribute('data-text-default-branch-tooltip');
  25. const branchArea = area.querySelector('.branch-area');
  26. toggleElem(branchArea.parentElement, branches.length > 0);
  27. for (const branch of branches) {
  28. const tooltip = defaultBranch === branch.name ? defaultBranchTooltip : null;
  29. addLink(branchArea, branch.web_link, branch.name, tooltip);
  30. }
  31. }
  32. function addLink(parent, href, text, tooltip) {
  33. const link = document.createElement('a');
  34. link.classList.add('muted', 'tw-px-1');
  35. link.href = href;
  36. link.textContent = text;
  37. if (tooltip) {
  38. link.classList.add('tw-border', 'tw-border-secondary', 'tw-rounded');
  39. link.setAttribute('data-tooltip-content', tooltip);
  40. }
  41. parent.append(link);
  42. }
  43. export function initRepoDiffCommitBranchesAndTags() {
  44. for (const area of document.querySelectorAll('.branch-and-tag-area')) {
  45. const btn = area.querySelector('.load-branches-and-tags');
  46. btn.addEventListener('click', () => loadBranchesAndTags(area, btn));
  47. }
  48. }