2019-11-28 11:01:09 +00:00
|
|
|
document.addEventListener('DOMContentLoaded', () => {
|
2022-04-29 11:14:12 -07:00
|
|
|
var metatags = ['order:id', 'order:width', 'order:height', 'order:filesize', 'order:filename', 'order:favorites'];
|
2016-06-19 10:07:56 +01:00
|
|
|
|
2023-05-25 14:04:13 +01:00
|
|
|
$('.autocomplete_tags').tagit({
|
2016-06-18 11:58:41 +01:00
|
|
|
singleFieldDelimiter: ' ',
|
|
|
|
beforeTagAdded: function(event, ui) {
|
2016-06-19 10:07:56 +01:00
|
|
|
if(metatags.indexOf(ui.tagLabel) !== -1) {
|
|
|
|
ui.tag.addClass('tag-metatag');
|
|
|
|
} else {
|
|
|
|
console.log(ui.tagLabel);
|
|
|
|
// give special class to negative tags
|
|
|
|
if(ui.tagLabel[0] === '-') {
|
|
|
|
ui.tag.addClass('tag-negative');
|
|
|
|
}else{
|
|
|
|
ui.tag.addClass('tag-positive');
|
|
|
|
}
|
2016-06-18 11:58:41 +01:00
|
|
|
}
|
|
|
|
},
|
|
|
|
autocomplete : ({
|
|
|
|
source: function (request, response) {
|
2016-06-19 10:07:56 +01:00
|
|
|
var ac_metatags = $.map(
|
|
|
|
$.grep(metatags, function(s) {
|
|
|
|
// Only show metatags for strings longer than one character
|
|
|
|
return (request.term.length > 1 && s.indexOf(request.term) === 0);
|
|
|
|
}),
|
|
|
|
function(item) {
|
|
|
|
return {
|
|
|
|
label : item + ' [metatag]',
|
|
|
|
value : item
|
|
|
|
};
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
2016-06-18 11:58:41 +01:00
|
|
|
var isNegative = (request.term[0] === '-');
|
|
|
|
$.ajax({
|
|
|
|
url: base_href + '/api/internal/autocomplete',
|
|
|
|
data: {'s': (isNegative ? request.term.substring(1) : request.term)},
|
|
|
|
dataType : 'json',
|
|
|
|
type : 'GET',
|
|
|
|
success : function (data) {
|
2016-06-19 10:07:56 +01:00
|
|
|
response(
|
|
|
|
$.merge(ac_metatags,
|
|
|
|
$.map(data, function (count, item) {
|
|
|
|
item = (isNegative ? '-'+item : item);
|
|
|
|
return {
|
|
|
|
label : item + ' ('+count+')',
|
|
|
|
value : item
|
|
|
|
};
|
|
|
|
})
|
|
|
|
)
|
|
|
|
);
|
2016-06-18 11:58:41 +01:00
|
|
|
},
|
|
|
|
error : function (request, status, error) {
|
2018-07-20 00:48:03 +01:00
|
|
|
console.log(error);
|
2016-06-18 11:58:41 +01:00
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
minLength: 1
|
|
|
|
})
|
|
|
|
});
|
|
|
|
|
2022-04-03 21:01:25 -07:00
|
|
|
$('#tag_editor,[name="bulk_tags"]').tagit({
|
2022-04-03 14:58:36 -07:00
|
|
|
singleFieldDelimiter: ' ',
|
|
|
|
autocomplete : ({
|
|
|
|
source: function (request, response) {
|
|
|
|
$.ajax({
|
|
|
|
url: base_href + '/api/internal/autocomplete',
|
|
|
|
data: {'s': request.term},
|
|
|
|
dataType : 'json',
|
|
|
|
type : 'GET',
|
|
|
|
success : function (data) {
|
|
|
|
response(
|
|
|
|
$.map(data, function (count, item) {
|
|
|
|
return {
|
|
|
|
label : item + ' ('+count+')',
|
|
|
|
value : item
|
|
|
|
};
|
|
|
|
})
|
|
|
|
);
|
|
|
|
},
|
|
|
|
error : function (request, status, error) {
|
|
|
|
console.log(error);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
minLength: 1
|
|
|
|
})
|
|
|
|
});
|
|
|
|
|
2016-06-18 11:58:41 +01:00
|
|
|
$('.ui-autocomplete-input').keydown(function(e) {
|
|
|
|
var keyCode = e.keyCode || e.which;
|
|
|
|
|
|
|
|
//Stop tags containing space.
|
2021-03-14 23:43:50 +00:00
|
|
|
if(keyCode === 32) {
|
2016-06-18 11:58:41 +01:00
|
|
|
e.preventDefault();
|
2023-03-26 02:42:25 -04:00
|
|
|
var el = $('.ui-widget-content:focus');
|
2016-06-18 11:58:41 +01:00
|
|
|
|
2023-03-26 02:42:25 -04:00
|
|
|
//Find the correct element in a page with multiple tagit input boxes.
|
|
|
|
$('.autocomplete_tags').each(function(_,n){
|
|
|
|
if (n.parentNode.contains(el[0])){
|
|
|
|
$(n.parentNode).find('.autocomplete_tags').tagit('createTag', el.val());
|
|
|
|
}
|
|
|
|
});
|
2016-06-18 11:58:41 +01:00
|
|
|
$(this).autocomplete('close');
|
2021-03-14 23:43:50 +00:00
|
|
|
} else if (keyCode === 9) {
|
2016-06-18 11:58:41 +01:00
|
|
|
e.preventDefault();
|
|
|
|
|
2016-06-19 09:49:55 +01:00
|
|
|
var tag = $('.tagit-autocomplete[style*=\"display: block\"] > li:focus, .tagit-autocomplete[style*=\"display: block\"] > li:first').first();
|
|
|
|
if(tag.length){
|
|
|
|
$(tag).click();
|
2016-06-18 11:58:41 +01:00
|
|
|
$('.ui-autocomplete-input').val(''); //If tag already exists, make sure to remove duplicate.
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
2016-06-18 19:00:26 +01:00
|
|
|
});
|