Current File : /home/pacjaorg/.trash/media.1/com_associations/js/sidebyside.js
/**
 * @copyright   (C) 2017 Open Source Matters, Inc. <https://www.joomla.org>
 * @license     GNU General Public License version 2 or later; see LICENSE.txt
 */

if (!Joomla) {
  throw new Error('Joomla API is not properly initialised');
}
const hideElements = ids => {
  ids.forEach(id => {
    const element = document.getElementById(id);
    if (element) {
      element.classList.add('hidden');
    }
  });
};
const createOption = (value, text) => {
  const option = document.createElement('option');
  option.value = value;
  option.innerText = text;
  return option;
};

// Attach behaviour to toggle button.
document.body.addEventListener('click', ({
  target
}) => {
  if (target.id === 'toggle-left-panel') {
    const referenceHide = target.getAttribute('data-hide-reference');
    const referenceShow = target.getAttribute('data-show-reference');
    if (target.innerText === referenceHide) {
      target.innerText = referenceShow;
    } else {
      target.innerText = referenceHide;
    }
    document.getElementById('left-panel').classList.toggle('hidden');
    document.getElementById('right-panel').classList.toggle('full-width');
  }
});

// Attach behaviour to language selector change event.
document.body.addEventListener('change', ({
  target
}) => {
  if (target.id === 'jform_itemlanguage') {
    const targetIframe = document.getElementById('target-association');
    const selected = target.value;

    // Populate the data attributes and load the the edit page in target frame.
    if (selected !== '' && typeof selected !== 'undefined') {
      targetIframe.setAttribute('data-action', selected.split(':')[2]);
      targetIframe.setAttribute('data-id', selected.split(':')[1]);
      targetIframe.setAttribute('data-language', selected.split(':')[0]);

      // Iframe load start, show Joomla loading layer.
      document.body.appendChild(document.createElement('joomla-core-loader'));

      // Load the target frame.
      targetIframe.src = `${targetIframe.getAttribute('data-editurl')}&task=${targetIframe.getAttribute('data-item')}.${targetIframe.getAttribute('data-action')}&id=${targetIframe.getAttribute('data-id')}`;
    } else {
      // Reset the data attributes and no item to load.
      hideElements(['toolbar-target', 'toolbar-copy', 'select-change', 'remove-assoc']);
      targetIframe.setAttribute('data-action', '');
      targetIframe.setAttribute('data-id', '0');
      targetIframe.setAttribute('data-language', '');
      targetIframe.src = '';
    }
  }
});

// Attach behaviour to reference frame load event.
document.getElementById('reference-association').addEventListener('load', ({
  target
}) => {
  // Waiting until the reference has loaded before loading the target to avoid race conditions
  let targetURL = Joomla.getOptions('targetSrc', false);
  if (targetURL) {
    targetURL = targetURL.split('&amp;').join('&');
    document.getElementById('target-association').setAttribute('src', targetURL);
    Joomla.loadOptions({
      targetSrc: false
    });
    return;
  }

  // Load Target Pane AFTER reference pane has loaded to prevent session conflict with checkout
  document.getElementById('target-association').setAttribute('src', document.getElementById('target-association').getAttribute('src'));
  const content = target.contentDocument.body || target.contentWindow.document.body;

  // If copy button used
  if (content.querySelector('#jform_id') && content.querySelector('#jform_id').value !== target.getAttribute('data-id')) {
    const targetAssociation = document.getElementById('target-association');
    targetAssociation.src = `${targetAssociation.getAttribute('data-editurl')}&task=${targetAssociation.getAttribute('data-item')}.edit&id=${content.querySelector('#jform_id').value}`;
    target.src = `${target.getAttribute('data-editurl')}&task=${target.getAttribute('data-item')}.edit&id=${target.getAttribute('data-id')}`;
  }

  // Disable language field.
  if (content.querySelector('#jform_language')) {
    content.querySelector('#jform_language').setAttribute('disabled', 'disabled');
  }

  // Remove modal buttons on the reference
  const associationBtn = content.querySelector('#associations .btn');
  if (associationBtn) {
    associationBtn.remove();
  }
  const itemLanguageOptions = document.querySelectorAll('#jform_itemlanguage option');
  if (itemLanguageOptions) {
    itemLanguageOptions.forEach(option => {
      const parse = option.value.split(':');
      if (typeof parse[0] !== 'undefined') {
        // - For modal association selectors.
        const langAssociation = parse[0].replace(/-/, '_');
        const langAssociationId = content.querySelector(`#jform_associations_${langAssociation}_id`);
        if (langAssociationId && langAssociationId.value === '') {
          const referenceAssociation = document.getElementById('reference-association');
          if (referenceAssociation.hasAttribute('data-no-assoc')) {
            content.querySelector(`#jform_associations_${langAssociation}_name`).value = referenceAssociation.getAttribute('data-no-assoc');
          }
        }
      }
    });
  }

  // Iframe load finished, hide Joomla loading layer.
  const spinner = document.querySelector('joomla-core-loader');
  if (spinner) {
    spinner.parentNode.removeChild(spinner);
  }
});

// Attach behaviour to target frame load event.
document.getElementById('target-association').addEventListener('load', ({
  target
}) => {
  // We need to check if we are not loading a blank iframe.
  if (target.getAttribute('src') !== '') {
    document.getElementById('toolbar-target').classList.remove('hidden');
    document.getElementById('toolbar-copy').classList.remove('hidden');
    document.getElementById('select-change').classList.remove('hidden');
    const targetLanguage = target.getAttribute('data-language');
    const targetId = target.getAttribute('data-id');
    const content = target.contentDocument.body || target.contentWindow.document.body;
    const targetLoadedId = content.querySelector('#jform_id').value || '0';
    const reference = document.getElementById('reference-association');

    // Remove modal buttons on the target
    // content.querySelector('a[href="#associations"]').parentNode.querySelector('.btn').forEach(btn => btn.remove());
    // content.querySelector('#associations .btn').forEach(btn => btn.remove());

    // Always show General tab first if associations tab is selected on the reference
    const associations = content.querySelector('#associations');
    if (associations && associations.classList.contains('active')) {
      content.querySelector('a[href="#associations"]').parentNode.classList.remove('active');
      associations.classList.remove('active');
      content.querySelector('.nav-tabs li').classList.add('active');
      content.querySelector('.tab-content .tab-pane').classList.add('active');
    }

    // Update language field with the selected language and them disable it.
    if (content.querySelector('#jform_language')) {
      content.querySelector('#jform_language').value = targetLanguage;
      content.querySelector('#jform_language').setAttribute('disabled', 'disabled');
    }

    // If we are creating a new association (before save) we need to add the new association.
    if (targetLoadedId === '0') {
      document.getElementById('select-change-text').innerHTML = Joomla.sanitizeHtml(document.getElementById('select-change').getAttribute('data-select'));
    } else {
      // If we are editing an association.

      // Show change language button
      document.getElementById('select-change-text').innerHTML = Joomla.sanitizeHtml(document.getElementById('select-change').getAttribute('data-change'));
      document.getElementById('remove-assoc').classList.remove('hidden');
      document.getElementById('remove-assoc').classList.add('toolbar-copy');

      // Add the id to list of items to check in on close.
      const currentIdList = document.getElementById('target-id').value;
      const updatedList = currentIdList === '' ? targetLoadedId : `${currentIdList},${targetLoadedId}`;
      document.getElementById('target-id').value = updatedList;

      // If we created a new association (after save).
      if (targetLoadedId !== targetId) {
        // Refresh the language selector with the new id (used after save).
        const languageSelector = document.querySelector(`#jform_itemlanguage option[value^="${targetLanguage}:${targetId}:add"]`);
        if (languageSelector) {
          languageSelector.value = `${targetLanguage}:${targetLoadedId}:edit`;
        }

        // Update main frame data-id attribute (used after save).
        target.setAttribute('data-id', targetLoadedId);
        target.setAttribute('data-action', 'edit');
      }

      // Update the reference item associations tab.
      const referenceContent = reference.contentDocument.body || reference.contentWindow.document.body;
      const languageCode = targetLanguage.replace(/-/, '_');
      const title = content.querySelector(`#jform_${reference.getAttribute('data-title')}`).value;

      // - For modal association selectors.
      const referenceContentId = referenceContent.querySelector(`#jform_associations_${languageCode}_id`);
      if (referenceContentId) {
        referenceContentId.value = targetLoadedId;
      }
      const referenceContentName = referenceContent.querySelector(`#jform_associations_${languageCode}_name`);
      if (referenceContentName) {
        referenceContentName.value = title;
      }

      // - For chosen association selectors (menus).
      const referenceContentDropdown = referenceContent.querySelector(`#jform_associations_${languageCode}`);
      if (referenceContentDropdown) {
        referenceContentDropdown.appendChild(createOption(targetLoadedId, title));
        referenceContentDropdown.value = targetLoadedId;
      }
    }

    // Update the target item associations tab.
    const referenceId = reference.getAttribute('data-id');
    const referenceLanguageCode = reference.getAttribute('data-language').replace(/-/, '_');
    const referenceTitle = reference.getAttribute('data-title-value');

    // - For modal association selectors.
    const targetContentId = content.querySelector(`#jform_associations_${referenceLanguageCode}_id`);
    if (targetContentId) {
      targetContentId.value = referenceId;
    }
    const targetContentName = content.querySelector(`#jform_associations_${referenceLanguageCode}_name`);
    if (targetContentName) {
      targetContentName.value = referenceTitle;
    }

    // - For chosen association selectors (menus).
    let chosenField = content.querySelector(`#jform_associations_${referenceLanguageCode}`);
    if (chosenField) {
      chosenField.appendChild(createOption(referenceId, referenceTitle));
      chosenField.value = referenceId;
    }
    document.querySelectorAll('#jform_itemlanguage option').forEach(option => {
      const parse = option.value.split(':');
      if (typeof parse[1] !== 'undefined' && parse[1] !== '0') {
        // - For modal association selectors.
        const langAssociation = parse[0].replace(/-/, '_');
        const formAssociationId = content.querySelector(`#jform_associations_${langAssociation}_id`);
        if (formAssociationId) {
          // eslint-disable-next-line prefer-destructuring
          content.querySelector(`#jform_associations_${langAssociation}_id`).value = parse[1];
        }

        // - For chosen association selectors (menus).
        chosenField = content.querySelector(`#jform_associations_${langAssociation}`);
        if (chosenField) {
          chosenField.appendChild(createOption(parse[1], ''));
          // eslint-disable-next-line prefer-destructuring
          chosenField.value = parse[1];
        }
      }
    });

    // Iframe load finished, hide Joomla loading layer.
    const spinner = document.querySelector('joomla-core-loader');
    if (spinner) {
      spinner.parentNode.removeChild(spinner);
    }
  }
});

// Save button actions, replacing the default Joomla.submitbutton() with custom function.
Joomla.submitbutton = task => {
  // Using close button, normal joomla submit.
  if (task === 'association.cancel') {
    Joomla.submitform(task);
  } else if (task === 'copy') {
    document.body.appendChild(document.createElement('joomla-core-loader'));
    const targetLang = document.getElementById('target-association').getAttribute('data-language');
    const referlangInput = window.frames['reference-association'].document.getElementById('jform_language');

    // Set target language, to get correct content language in the copy
    referlangInput.removeAttribute('disabled');
    referlangInput.value = targetLang;
    window.frames['reference-association'].Joomla.submitbutton(`${document.getElementById('adminForm').getAttribute('data-associatedview')}.save2copy`);
  } else if (task === 'undo-association') {
    // Undo association
    const referenceEl = document.getElementById('reference-association');
    const targetEl = document.getElementById('target-association');
    const referenceLang = referenceEl.getAttribute('data-language').replace(/-/, '_');
    const targetLang = targetEl.getAttribute('data-language').replace(/-/, '_');
    const reference = referenceEl.contentDocument.body || referenceEl.contentWindow.document.body;
    const target = targetEl.contentDocument.body || targetEl.contentWindow.document.body;

    // Remove it on the reference
    // - For modal association selectors.
    const referenceAssocId = reference.querySelector(`#jform_associations_${targetLang}_id`);
    if (referenceAssocId) {
      referenceAssocId.value = '';
    }
    const referenceAssocName = reference.querySelector(`#jform_associations_${targetLang}_name`);
    if (referenceAssocName) {
      referenceAssocName.value = '';
    }

    // - For chosen association selectors (menus).
    const referenceAssoc = reference.querySelector(`#jform_associations_${targetLang}`);
    if (referenceAssoc) {
      referenceAssoc.value = '';
    }

    // Remove it on the target
    document.querySelectorAll('#jform_itemlanguage option').forEach(option => {
      let lang = option.value.split(':')[0];
      if (lang) {
        lang = lang.replace(/-/, '_');
        const formAssociationId = target.querySelector(`#jform_associations_${lang}_id`);
        if (formAssociationId) {
          // - For modal association selectors.
          formAssociationId.value = '';
        }
        const formAssociation = target.querySelector(`#jform_associations_${lang}`);
        if (formAssociation) {
          // - For chosen association selectors (menus).
          formAssociation.value = '';
        }
      }
    });

    // Same as above but reference language is not in the selector
    // - For modal association selectors.
    const targetAssocId = target.querySelector(`#jform_associations_${referenceLang}_id`);
    if (targetAssocId) {
      targetAssocId.value = '';
    }
    const targetAssocName = target.querySelector(`#jform_associations_${referenceLang}_name`);
    if (targetAssocName) {
      targetAssocName.value = '';
    }

    // - For chosen association selectors (menus).
    const targetAssoc = target.querySelector(`#jform_associations_${referenceLang}`);
    if (targetAssoc) {
      targetAssoc.value = '';
    }

    // Reset switcher after removing association
    const currentLangSelect = document.getElementById('jform_itemlanguage');
    const currentSwitcher = currentLangSelect.value;
    const currentLang = targetLang.replace(/_/, '-');
    const itemLanguageItem = document.querySelector(`#jform_itemlanguage option[value="${currentSwitcher}"]`);
    if (itemLanguageItem) {
      itemLanguageItem.value = `${currentLang}:0:add`;
    }
    currentLangSelect.value = '';
    currentLangSelect.dispatchEvent(new CustomEvent('change', {
      bubbles: true,
      cancelable: true
    }));

    // Save one of the items to confirm action
    Joomla.submitbutton('reference');
  } else {
    // Saving target or reference, send the save action to the target/reference iframe.
    // We need to re-enable the language field to save.
    const el = document.getElementById(`${task}-association`);
    const content = el.contentDocument.body || el.contentWindow.document.body;
    const languageButton = content.querySelector('#jform_language');
    if (languageButton) {
      languageButton.removeAttribute('disabled');
    }
    window.frames[`${task}-association`].Joomla.submitbutton(`${document.getElementById('adminForm').getAttribute('data-associatedview')}.apply`);
  }
  return false;
};
hideElements(['toolbar-target', 'toolbar-copy']);
Site is undergoing maintenance

PACJA Events

Maintenance mode is on

Site will be available soon. Thank you for your patience!