diff --git a/src/main/java/org/gcube/portlets/widgets/ckandatapublisherwidget/client/ui/dataset/resources/TagsPanel.java b/src/main/java/org/gcube/portlets/widgets/ckandatapublisherwidget/client/ui/dataset/resources/TagsPanel.java index fef64ac..468cf89 100644 --- a/src/main/java/org/gcube/portlets/widgets/ckandatapublisherwidget/client/ui/dataset/resources/TagsPanel.java +++ b/src/main/java/org/gcube/portlets/widgets/ckandatapublisherwidget/client/ui/dataset/resources/TagsPanel.java @@ -37,6 +37,9 @@ public class TagsPanel extends Composite{ @UiField FocusPanel focusPanelTags; @UiField Popover popoverTags; + // regular expression for tags + private static final String REGEX_TAG = "^[a-zA-Z0-9]*$"; + // tags list private List tagsList = new ArrayList(); @@ -60,6 +63,18 @@ public class TagsPanel extends Composite{ ); } + @UiHandler("tagsEnterTextBox") + void onAddTag(KeyDownEvent event){ + + if (event.getNativeKeyCode() == KeyCodes.KEY_ENTER) { + if (!tagsEnterTextBox.getValue().trim().isEmpty()) { + + addTagElement(tagsEnterTextBox); + + } + } + } + /** * Add the tag as an element (inserted by the user) */ @@ -75,14 +90,14 @@ public class TagsPanel extends Composite{ // ckan accepts only alphanumeric values String[] subTags = itemBox.getValue().split(" "); if(subTags.length == 1){ - if(!subTags[0].matches("^[a-zA-Z0-9]*$")) + if(!subTags[0].matches(REGEX_TAG)) return; if(subTags[0].length() <= 1) return; }else{ for (int i = 0; i < subTags.length; i++) { String subTag = subTags[i]; - if(!subTag.matches("^[a-zA-Z0-9]*$")) + if(!subTag.matches(REGEX_TAG)) return; } } @@ -121,14 +136,14 @@ public class TagsPanel extends Composite{ // ckan accepts only alphanumeric values String[] subTags = tag.split(" "); if(subTags.length == 1){ - if(!subTags[0].matches("^[a-zA-Z0-9]*$")) + if(!subTags[0].matches(REGEX_TAG)) return; if(subTags[0].length() <= 1) return; }else{ for (int i = 0; i < subTags.length; i++) { String subTag = subTags[i]; - if(!subTag.matches("^[a-zA-Z0-9]*$")) + if(!subTag.matches(REGEX_TAG)) return; } } @@ -173,18 +188,10 @@ public class TagsPanel extends Composite{ } - @UiHandler("tagsEnterTextBox") - void onAddTag(KeyDownEvent event){ - - if (event.getNativeKeyCode() == KeyCodes.KEY_ENTER) { - if (!tagsEnterTextBox.getValue().trim().isEmpty()) { - - addTagElement(tagsEnterTextBox); - - } - } - } - + /** + * Return the tag list + * @return + */ public List getTags() { return tagsList; }