aboutsummaryrefslogtreecommitdiffstats
path: root/public/js
diff options
context:
space:
mode:
authorAlexey Terentyev <axifnx@gmail.com>2018-07-15 03:43:32 +0300
committertechknowlogick <techknowlogick@users.noreply.github.com>2018-07-14 20:43:32 -0400
commitca474af3c655eaaaa01ae9cf26cb583a974da61f (patch)
tree3bb9ebafc9347efee88a573936b0fc5c42097252 /public/js
parent8e103d3e76dbd5af562687b64508be62355422d2 (diff)
downloadgitea-ca474af3c655eaaaa01ae9cf26cb583a974da61f.tar.gz
gitea-ca474af3c655eaaaa01ae9cf26cb583a974da61f.zip
Added front-end topics validation (#4316)
Diffstat (limited to 'public/js')
-rw-r--r--public/js/index.js110
1 files changed, 90 insertions, 20 deletions
diff --git a/public/js/index.js b/public/js/index.js
index 823dd87669..667f27ce46 100644
--- a/public/js/index.js
+++ b/public/js/index.js
@@ -2302,46 +2302,75 @@ function initNavbarContentToggle() {
}
function initTopicbar() {
- var mgrBtn = $("#manage_topic")
- var editDiv = $("#topic_edit")
- var viewDiv = $("#repo-topic")
- var saveBtn = $("#save_topic")
+ var mgrBtn = $("#manage_topic"),
+ editDiv = $("#topic_edit"),
+ viewDiv = $("#repo-topic"),
+ saveBtn = $("#save_topic"),
+ topicDropdown = $('#topic_edit .dropdown'),
+ topicForm = $('#topic_edit.ui.form'),
+ topicPrompts;
mgrBtn.click(function() {
viewDiv.hide();
editDiv.show();
- })
+ });
+
+ function getPrompts() {
+ var hidePrompt = $("div.hide#validate_prompt"),
+ prompts = {
+ countPrompt: hidePrompt.children('#count_prompt').text(),
+ formatPrompt: hidePrompt.children('#format_prompt').text()
+ };
+ hidePrompt.remove();
+ return prompts;
+ }
saveBtn.click(function() {
var topics = $("input[name=topics]").val();
- $.post($(this).data('link'), {
+ $.post(saveBtn.data('link'), {
"_csrf": csrf,
"topics": topics
- }).success(function(res){
- if (res["status"] != "ok") {
- alert(res.message);
- } else {
+ }, function(data, textStatus, xhr){
+ if (xhr.responseJSON.status === 'ok') {
viewDiv.children(".topic").remove();
- if (topics.length == 0) {
+ if (topics.length === 0) {
return
}
var topicArray = topics.split(",");
var last = viewDiv.children("a").last();
- for (var i=0;i < topicArray.length; i++) {
+ for (var i=0; i < topicArray.length; i++) {
$('<div class="ui green basic label topic" style="cursor:pointer;">'+topicArray[i]+'</div>').insertBefore(last)
}
+ editDiv.hide();
+ viewDiv.show();
}
- }).done(function() {
- editDiv.hide();
- viewDiv.show();
- }).fail(function(xhr) {
- alert(xhr.responseJSON.message)
- })
+ }).fail(function(xhr){
+ if (xhr.status === 422) {
+ if (xhr.responseJSON.invalidTopics.length > 0) {
+ topicPrompts.formatPrompt = xhr.responseJSON.message;
+
+ var invalidTopics = xhr.responseJSON.invalidTopics,
+ topicLables = topicDropdown.children('a.ui.label');
+
+ topics.split(',').forEach(function(value, index) {
+ for (var i=0; i < invalidTopics.length; i++) {
+ if (invalidTopics[i] === value) {
+ topicLables.eq(index).removeClass("green").addClass("red");
+ }
+ }
+ });
+ } else {
+ topicPrompts.countPrompt = xhr.responseJSON.message;
+ }
+ }
+ }).always(function() {
+ topicForm.form('validate form');
+ });
});
- $('#topic_edit .dropdown').dropdown({
+ topicDropdown.dropdown({
allowAdditions: true,
fields: { name: "description", value: "data-value" },
saveRemoteData: false,
@@ -2362,7 +2391,7 @@ function initTopicbar() {
onResponse: function(res) {
var formattedResponse = {
success: false,
- results: new Array(),
+ results: [],
};
if (res.topics) {
@@ -2375,7 +2404,48 @@ function initTopicbar() {
return formattedResponse;
},
},
+ onLabelCreate: function(value) {
+ value = value.toLowerCase().trim();
+ this.attr("data-value", value).contents().first().replaceWith(value);
+ return $(this);
+ },
+ onAdd: function(addedValue, addedText, $addedChoice) {
+ addedValue = addedValue.toLowerCase().trim();
+ $($addedChoice).attr('data-value', addedValue);
+ $($addedChoice).attr('data-text', addedValue);
+ }
});
+
+ $.fn.form.settings.rules.validateTopic = function(values, regExp) {
+ var topics = topicDropdown.children('a.ui.label'),
+ status = topics.length === 0 || topics.last().attr("data-value").match(regExp);
+ if (!status) {
+ topics.last().removeClass("green").addClass("red");
+ }
+ return status && topicDropdown.children('a.ui.label.red').length === 0;
+ };
+
+ topicPrompts = getPrompts();
+ topicForm.form({
+ on: 'change',
+ inline : true,
+ fields: {
+ topics: {
+ identifier: 'topics',
+ rules: [
+ {
+ type: 'validateTopic',
+ value: /^[a-z0-9][a-z0-9-]{1,35}$/,
+ prompt: topicPrompts.formatPrompt
+ },
+ {
+ type: 'maxCount[25]',
+ prompt: topicPrompts.countPrompt
+ }
+ ]
+ },
+ }
+ });
}
function toggleDuedateForm() {
$('#add_deadline_form').fadeToggle(150);