message/amd/src/default_notification_preferences.js

// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.

/**
 * Controls the default settings for the list of notification types on the
 * notifications admin page
 *
 * @module     core_message/default_notification_preferences
 * @class      default_notification_preferences
 * @copyright  2021 Moodle
 * @author     Pau Ferrer OcaƱa <pau@moodle.com>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

const selectors = {
    provider: '.defaultmessageoutputs .provider_enabled',
    lockSetting: '.locked_message_setting',
    enabledSetting: '.enabled_message_setting',
    allSettings: '.locked_message_setting, .enabled_message_setting'
};

/**
 * Register event listeners for the default_notification_preferences page.
 */
const registerEventListeners = () => {

    /**
     * Update the dimmed status of the "enabled" toggle on the notification setting.
     *
     * @param {HTMLElement} lockedElement Element that receives the event.
     */
    const toggleLockSetting = (lockedElement) => {
        const isEnabled = lockedElement.checked || false;
        const enabledId = lockedElement.id.replace('_locked[', '_enabled[');

        const enabledElement = document.getElementById(enabledId).closest('div.custom-control');
        enabledElement.classList.toggle('dimmed_text', isEnabled);
    };

    /**
     * Enable/Disable all settings of the provider.
     *
     * @param {HTMLElement} providerEnabledElement Element that receives the event.
     */
    const toggleEnableProviderSettings = (providerEnabledElement) => {
        const isEnabled = providerEnabledElement.checked || false;
        const parentRow = providerEnabledElement.closest('tr');

        const elements = parentRow.querySelectorAll(selectors.allSettings);
        elements.forEach((element) => {
            element.toggleAttribute('disabled', !isEnabled);
        });
    };

    const container = document.querySelector('.preferences-container');

    container.querySelectorAll(selectors.provider).forEach((providerEnabledElement) => {
        // Set the initial statuses.
        if (!providerEnabledElement.checked) {
            toggleEnableProviderSettings(providerEnabledElement);
        }

        providerEnabledElement.addEventListener('change', (e) => {
            toggleEnableProviderSettings(e.target);
        });
    });

    container.querySelectorAll(selectors.lockSetting).forEach((lockedElement) => {
        // Set the initial statuses.
        if (lockedElement.checked) {
            toggleLockSetting(lockedElement);
        }

        lockedElement.addEventListener('change', (e) => {
            toggleLockSetting(e.target);
        });
    });
};

/**
 * Initialize the page.
 */
const init = () => {
    registerEventListeners();
};

export default {
    init: init,
};