Skip to content

Commit

Permalink
NGSTACK-922 rewrite to vanilla
Browse files Browse the repository at this point in the history
  • Loading branch information
amalija-ramljak committed Oct 28, 2024
1 parent 4b27ac2 commit ab3cb1f
Show file tree
Hide file tree
Showing 2 changed files with 236 additions and 157 deletions.
79 changes: 46 additions & 33 deletions bundle/Resources/public/admin/js/init.js
Original file line number Diff line number Diff line change
@@ -1,41 +1,54 @@
(function($) {
'use strict';
$('.multientry').multientry();
const init = () => {
window.initaliseMultientries();

const saveButton = document.getElementById('content_type_edit__sidebar_right__save-tab');
const observer = new MutationObserver(() => {
window.initaliseMultientries();
});

const observer = new MutationObserver(e => {
$('.multientry').multientry();
// enables observer when element is dropped
document.addEventListener('drop', () => {
document.querySelectorAll('.ibexa-collapse').forEach((element) => {
observer.observe(element, { childList: true, subtree: true });
});
});

// enables observer when elements is dropped
document.addEventListener("drop", e => {
document.querySelectorAll('.ibexa-collapse').forEach(el => {
observer.observe(el, { childList: true, subtree: true });
});
// disable observer while dragging to reduce function firing
document.addEventListener('drag', () => {
document.querySelectorAll('.ibexa-collapse').forEach(() => {
observer.disconnect();
});
});

// disable observer while dragging to reduce function firing
document.addEventListener("drag", e => {
document.querySelectorAll('.ibexa-collapse').forEach(el => {
observer.disconnect();
});
});
// checks if any multientry inputs are empty and expands the field type
const saveButton = document.getElementById('content_type_edit__sidebar_right__save-tab');

saveButton && saveButton.addEventListener('click', (event) => {
document.querySelectorAll('.multientry input').forEach((input) => {
if (input.value.length > 0) {
return;
}

event.preventDefault();

const collapseWrapper = input.closest('.ibexa-collapse');
const collapseBody = collapseWrapper.querySelector('.ibexa-collapse__body');
const collapseToggle = collapseWrapper.querySelector('.ibexa-collapse__toggle-btn');

// checks if any multientry inputs are empty and expands the field type
saveButton && saveButton.addEventListener("click", e => {
document.querySelectorAll('.multientry input').forEach(el => {
if (el.value.length === 0) {
e.preventDefault();
const fullElement = el.closest('.ibexa-collapse');
const elementBody = fullElement.querySelector('.ibexa-collapse__body');
const collapseToggle = fullElement.querySelector('.ibexa-collapse__toggle-btn');
fullElement.classList.contains('multientry-error') ? null : fullElement.classList.add('multientry-error');
fullElement.classList.contains('ibexa-collapse--collapsed') ? fullElement.classList.remove('ibexa-collapse--collapsed') : null;
elementBody.classList.contains('show') ? null : elementBody.classList.add('show');
collapseToggle.classList.contains('collapsed') ? elementBody.classList.remove('collapsed') : null;
fullElement.dataset.collapsed ? fullElement.dataset.collapsed = false : null;
}
})
collapseWrapper.classList.add('multientry-error');
collapseWrapper.classList.remove('ibexa-collapse--collapsed');
collapseWrapper.dataset.collapsed = false;

collapseBody.classList.add('show');

if (collapseToggle.classList.contains('collapsed')) {
collapseBody.classList.remove('collapsed');
}
});
})(jQuery);
});
};

if (document.readyState === 'loading') {
document.addEventListener('DOMContentLoaded', init);
} else {
init();
}
Loading

0 comments on commit ab3cb1f

Please sign in to comment.