Strip length of dropdown items, unique items, add specific params to request

This commit is contained in:
Urban Rotnik 2019-10-30 08:37:20 +01:00
parent 6fbb99c8d2
commit db2943a1b7
3 changed files with 30 additions and 3 deletions

View file

@ -1,7 +1,12 @@
/* global GLOBAL_CONSTANTS */
/* eslint-disable no-unused-vars */ /* eslint-disable no-unused-vars */
var RepositoryListColumnType = (function() { var RepositoryListColumnType = (function() {
var manageModal = '#manageRepositoryColumn'; var manageModal = '#manageRepositoryColumn';
function onlyUnique(value, index, self) {
return self.indexOf(value) === index;
}
function textToItems(text, delimiter) { function textToItems(text, delimiter) {
var res = []; var res = [];
var definedDelimiters = { var definedDelimiters = {
@ -26,7 +31,12 @@ var RepositoryListColumnType = (function() {
} }
}); });
return res.filter(Boolean); res = res.filter(Boolean).filter(onlyUnique);
$.each(res, (index, option) => {
res[index] = option.slice(0, GLOBAL_CONSTANTS.NAME_MAX_LENGTH);
});
return res;
} }
function drawDropdownPreview(items) { function drawDropdownPreview(items) {
@ -47,11 +57,15 @@ var RepositoryListColumnType = (function() {
var dropdownDelimiter = 'select#delimiter'; var dropdownDelimiter = 'select#delimiter';
$manageModal.off('change keyup paste', listItemsTextarea).on('change keyup paste', listItemsTextarea, function() { $manageModal.off('change keyup paste', listItemsTextarea).on('change keyup paste', listItemsTextarea, function() {
drawDropdownPreview(textToItems($(listItemsTextarea).val(), $(dropdownDelimiter).val())); var items = textToItems($(listItemsTextarea).val(), $(dropdownDelimiter).val());
drawDropdownPreview(items);
$('#dropdown_options').val(items);
}); });
$manageModal.off('change', dropdownDelimiter).on('change', dropdownDelimiter, function() { $manageModal.off('change', dropdownDelimiter).on('change', dropdownDelimiter, function() {
drawDropdownPreview(textToItems($(listItemsTextarea).val(), $(dropdownDelimiter).val())); var items = textToItems($(listItemsTextarea).val(), $(dropdownDelimiter).val());
drawDropdownPreview(items);
$('#dropdown_options').val(items);
}); });
} }

View file

@ -80,11 +80,21 @@ var RepositoryColumns = (function() {
$('li[data-id=' + column.id + ']').find('span').first().text(name); $('li[data-id=' + column.id + ']').find('span').first().text(name);
} }
function loadSpecificParams(type, params) {
var newParams = params;
if (type === 'RepositoryListValue') {
newParams.repository_column.list_items = $('#dropdown_options').val();
}
return newParams;
}
function initCreateSubmitAction() { function initCreateSubmitAction() {
var $manageModal = $(manageModal); var $manageModal = $(manageModal);
$manageModal.off('click', '#new-repo-column-submit').on('click', '#new-repo-column-submit', function() { $manageModal.off('click', '#new-repo-column-submit').on('click', '#new-repo-column-submit', function() {
var url = $('#repository-column-data-type').find(':selected').data('create-url'); var url = $('#repository-column-data-type').find(':selected').data('create-url');
var params = { repository_column: { name: $('#repository-column-name').val() } }; var params = { repository_column: { name: $('#repository-column-name').val() } };
var selectedType = $('#repository-column-data-type').find(':selected').val();
params = loadSpecificParams(selectedType, params);
$.post(url, params, (result) => { $.post(url, params, (result) => {
var data = result.data; var data = result.data;
insertNewListItem(data); insertNewListItem(data);
@ -101,6 +111,8 @@ var RepositoryColumns = (function() {
$manageModal.off('click', '#update-repo-column-submit').on('click', '#update-repo-column-submit', function() { $manageModal.off('click', '#update-repo-column-submit').on('click', '#update-repo-column-submit', function() {
var url = $('#repository-column-data-type').find(':selected').data('edit-url'); var url = $('#repository-column-data-type').find(':selected').data('edit-url');
var params = { repository_column: { name: $('#repository-column-name').val() } }; var params = { repository_column: { name: $('#repository-column-name').val() } };
var selectedType = $('#repository-column-data-type').find(':selected').val();
params = loadSpecificParams(selectedType, params);
$.ajax({ $.ajax({
url: url, url: url,
type: 'PUT', type: 'PUT',

View file

@ -1,3 +1,4 @@
<%= hidden_field_tag 'dropdown_options' %>
<div class="form-group"> <div class="form-group">
<label class="control-label col-sm-3" for="repository-column-data-type"> <label class="control-label col-sm-3" for="repository-column-data-type">
<%= t('libraries.manange_modal_column.list_type.delimiter_label') %> <%= t('libraries.manange_modal_column.list_type.delimiter_label') %>