diff --git a/TODO b/TODO index a659cd9e..69a6dd36 100644 --- a/TODO +++ b/TODO @@ -28,7 +28,6 @@ everything related to tags: - tag editing - category (from config.ini) - description - - related tags - aliases - take care of recursion - listing diff --git a/public_html/css/forms.css b/public_html/css/forms.css index d9e1213c..89bfddcc 100644 --- a/public_html/css/forms.css +++ b/public_html/css/forms.css @@ -197,9 +197,31 @@ input[type=checkbox]:checked + label::before { } .tag-input li a { color: black; +} +.tag-input li a.close { font-size: 14px; - margin-left: 0.5em; - cursor: pointer; + margin-left: 0.75em; +} + +.related-tags { + line-height: 200%; + font-size: 15px; + display: none; + margin: 0.5em 0.5em 1em 0.5em; +} +.related-tags span { + float: left; +} +.related-tags ul { + list-style-type: none; + margin: 0; + padding: 0; + overflow: hidden; +} +.related-tags li { + display: inline-block; + margin: 0 0.5em; + padding: 0; } .autocomplete { diff --git a/public_html/js/Controls/TagInput.js b/public_html/js/Controls/TagInput.js index 1c1fa5db..ea17aec9 100644 --- a/public_html/js/Controls/TagInput.js +++ b/public_html/js/Controls/TagInput.js @@ -4,6 +4,8 @@ App.Controls = App.Controls || {}; App.Controls.TagInput = function($underlyingInput) { var _ = App.DI.get('_'); var jQuery = App.DI.get('jQuery'); + var promise = App.DI.get('promise'); + var api = App.DI.get('api'); var KEY_RETURN = 13; var KEY_SPACE = 32; @@ -18,38 +20,46 @@ App.Controls.TagInput = function($underlyingInput) { inputConfirmed: null, }; - if ($underlyingInput.length === 0) { - throw new Error('Tag input element was not found'); - } - if ($underlyingInput.length > 1) { - throw new Error('Cannot set tag input to more than one element at once'); - } - if ($underlyingInput.attr('data-tagged')) { - throw new Error('Tag input was already initialized for this element'); - } - $underlyingInput.attr('data-tagged', true); - $underlyingInput.hide(); - var $wrapper = jQuery('