GitLab Merge Confirmation

Adds a confirmation prompt before merging in GitLab

You will need to install an extension such as Tampermonkey, Greasemonkey or Violentmonkey to install this script.

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

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

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

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

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

(I already have a user script manager, let me install it!)

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.

(I already have a user style manager, let me install it!)

// ==UserScript==
// @name         GitLab Merge Confirmation
// @namespace    https://github.com/rvoortman/gitlab-merge-confirmation
// @version      1.0
// @description  Adds a confirmation prompt before merging in GitLab
// @author       Robbin Voortman
// @match        https://gitlab.com/*/-/merge_requests/*
// @license      MIT
// @homepage     https://github.com/rvoortman/gitlab-merge-confirmation
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    // Observe the DOM for dynamic loading of the merge button
    const observer = new MutationObserver(() => {
        const mergeButton = document.querySelector('button[data-testid="merge-button"]');

        if (mergeButton && !mergeButton.dataset.confirmAdded) {
            mergeButton.addEventListener('click', function(e) {
                const confirmed = confirm("Are you sure you want to merge this request?");
                if (!confirmed) {
                    e.stopImmediatePropagation();
                    e.preventDefault();
                }
            }, true);

            // Prevent multiple bindings
            mergeButton.dataset.confirmAdded = "true";
        }
    });

    observer.observe(document.body, { childList: true, subtree: true });
})();