Rename Merge Request Title Automatically

Compatible gitlab

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

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

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name Rename Merge Request Title Automatically
// @name:es Rename Merge Request Title Automatically
// @description Compatible gitlab
// @description:es Compatible gitlab
// @date 2022-03-21
// @compatible chrome
// @compatible firefox
// @compatible opera
// @compatible safari
// @license CC BY-NC-ND 4.0 International. https://creativecommons.org/licenses/by-nc-nd/4.0/
// @match *://*.gitlab.com/*
// @match *://gitlab.*.com.*/*
// @version 0.1
// @namespace https://greatest.deepsurf.us/en/users/314553-stefango
// ==/UserScript==
(() => {
  if (window.location.href.includes('cherry-pick')) {
    const branchSelector = document.getElementsByClassName("branch-selector");
    const texto = branchSelector[0].innerText;
    const textoToInput = texto.split(' ');
    const source = textoToInput[1];
    const target = textoToInput[3];
    const url = window.location.href;
    const originalTitle = document.getElementById("merge_request_title").value;

    if (originalTitle.startsWith('Merge branch')) {
      let titleArr = document.getElementById("merge_request_title").value.split(' ');
      titleArr.splice(-1, 1, `'${target}'`);
      document.getElementById("merge_request_title").value = titleArr.join(' ');
    } else {
      // rename manually when code conflicted
    }
  }
})();