169 lines
6.5 KiB
JavaScript
169 lines
6.5 KiB
JavaScript
|
/**
|
||
|
* This program 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; under version 2
|
||
|
* of the License (non-upgradable).
|
||
|
*
|
||
|
* This program 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 this program; if not, write to the Free Software
|
||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||
|
*
|
||
|
* Copyright (c) 2021 (original work) Open Assessment Technologies SA ;
|
||
|
*/
|
||
|
|
||
|
define([
|
||
|
'jquery',
|
||
|
'context',
|
||
|
], function ($, context) {
|
||
|
'use strict';
|
||
|
|
||
|
function getSecondaryPropsList($primaryProp) {
|
||
|
let $secondaryPropsList = $primaryProp.find('.secondary-props-list');
|
||
|
|
||
|
if (!$secondaryPropsList.length) {
|
||
|
$secondaryPropsList = $('<ul class="secondary-props-list"></ul>');
|
||
|
$primaryProp.append($secondaryPropsList);
|
||
|
}
|
||
|
|
||
|
return $secondaryPropsList;
|
||
|
}
|
||
|
|
||
|
function filterSecondaryValues($container, selectedPrimaryProperty, fromMultiple) {
|
||
|
const $secondaryList = $container.find('.secondary-props-list > li > *');
|
||
|
|
||
|
$secondaryList.each((i, secondaryProp) => {
|
||
|
let $secondarySelect = $(secondaryProp).children('select');
|
||
|
|
||
|
if ($secondarySelect.length) {
|
||
|
$.ajax({
|
||
|
url: context.root_url + 'tao/PropertyValues/get',
|
||
|
type: "GET",
|
||
|
data: {
|
||
|
propertyUri: $secondarySelect.attr('id'),
|
||
|
parentListValues: selectedPrimaryProperty
|
||
|
},
|
||
|
dataType: 'json',
|
||
|
success: function(response) {
|
||
|
if (fromMultiple) {
|
||
|
response.data.forEach((selectOption) => {
|
||
|
if (!$secondarySelect.find(`option[value="${selectOption.uri}"]`).length) {
|
||
|
$secondarySelect.append(new Option(selectOption.label, selectOption.uri));
|
||
|
}
|
||
|
});
|
||
|
} else {
|
||
|
$secondarySelect.empty().append(new Option('', ' '));
|
||
|
|
||
|
response.data.forEach((selectOption) => {
|
||
|
$secondarySelect.append(new Option(selectOption.label, selectOption.uri));
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
|
||
|
function toggleDisableSecondary($container, disable = true) {
|
||
|
const $secondaryList = $container.find('.secondary-props-list > li > *');
|
||
|
|
||
|
$secondaryList.each((i, secondaryProp) => {
|
||
|
if (disable) {
|
||
|
$(secondaryProp).find('[data-depends-on-property]').attr('disabled', 'disabled');
|
||
|
$(secondaryProp).addClass('disabled');
|
||
|
clearSecondary($(secondaryProp));
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
$(secondaryProp).find('[data-depends-on-property]').removeAttr('disabled');
|
||
|
$(secondaryProp).removeClass('disabled');
|
||
|
});
|
||
|
}
|
||
|
|
||
|
function clearSecondary($secondaryProp) {
|
||
|
const $select2Chosen = $secondaryProp.find('.select2-chosen');
|
||
|
if ($select2Chosen.length) {
|
||
|
$(this).find('> div > input').val('').trigger('change');
|
||
|
$select2Chosen.empty();
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
const $selectElt = $secondaryProp.find('select[data-depends-on-property]');
|
||
|
if ($selectElt.length) {
|
||
|
$selectElt.each(function() {
|
||
|
$(this).find('option[selected]').removeAttr('selected');
|
||
|
$(this).find('option[value=" "]').attr('selected', 'selected');
|
||
|
$(this).trigger('change');
|
||
|
});
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
const $inputElt = $secondaryProp.find('input');
|
||
|
if ($inputElt.length) {
|
||
|
$inputElt.each(function() {
|
||
|
$(this).val(null).trigger('change');
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function initializeSecondaryProperties($container) {
|
||
|
const $props = $container.children();
|
||
|
let primaryPropsMap = new Map();
|
||
|
let $secondaryProps = $props.filter(function() {
|
||
|
return !!$(this).find('[data-depends-on-property]').length;
|
||
|
});
|
||
|
|
||
|
$secondaryProps.each((i, secondaryProp) => {
|
||
|
const primaryPropUri = $(secondaryProp).find('[data-depends-on-property]').data('depends-on-property');
|
||
|
let $primaryProp = $($props.filter(function() {
|
||
|
return !!$(this).find(`#${primaryPropUri}`).length;
|
||
|
})[0]);
|
||
|
|
||
|
if (!$primaryProp.length) {
|
||
|
return;
|
||
|
} else {
|
||
|
primaryPropsMap.has(primaryPropUri) ? null : primaryPropsMap.set(primaryPropUri, $primaryProp);
|
||
|
moveSecondaryProperty($(secondaryProp), $primaryProp);
|
||
|
const $primaryElt = $primaryProp.find(`[name="${primaryPropUri}"]`);
|
||
|
toggleDisableSecondary($primaryProp, !$primaryElt.val().trim());
|
||
|
}
|
||
|
});
|
||
|
|
||
|
primaryPropsMap.forEach(($primaryProp, primaryPropUri) => {
|
||
|
addPrimaryPropertyListener($primaryProp, primaryPropUri);
|
||
|
})
|
||
|
}
|
||
|
|
||
|
function addPrimaryPropertyListener($primaryProp, primaryPropUri) {
|
||
|
$primaryProp.on('change', `[name="${primaryPropUri}"]`, (e) => {
|
||
|
if (e.removed || e.added) {
|
||
|
// This is from a multiple input (i.e: multiple search input)
|
||
|
// TODO: ADF-521 - Add cascade deletion logic here when e.removed
|
||
|
filterSecondaryValues($primaryProp, e.target.value.split(','), true);
|
||
|
} else {
|
||
|
// This is from a single input (i.e: single dropdown)
|
||
|
filterSecondaryValues($primaryProp, e.target.value.split(','));
|
||
|
}
|
||
|
|
||
|
toggleDisableSecondary($primaryProp, !e.target.value.trim());
|
||
|
});
|
||
|
}
|
||
|
|
||
|
function moveSecondaryProperty($secondaryProp, $primaryProp) {
|
||
|
const $secondaryPropsList = getSecondaryPropsList($primaryProp);
|
||
|
const $wrapper = $('<li></li>');
|
||
|
$secondaryPropsList.append($wrapper);
|
||
|
$wrapper.append($secondaryProp.detach());
|
||
|
}
|
||
|
|
||
|
return {
|
||
|
init: initializeSecondaryProperties,
|
||
|
}
|
||
|
});
|
||
|
|
||
|
|