summaryrefslogtreecommitdiffstats
path: root/core/js
diff options
context:
space:
mode:
authorVincent Petry <pvince81@owncloud.com>2016-01-27 15:49:11 +0100
committerVincent Petry <pvince81@owncloud.com>2016-01-28 11:24:13 +0100
commit1473e156f4c1f6c634cc7933343de0fbcc91cbe8 (patch)
tree71f41e282b261e7e1e571b8686dd9af762941ae6 /core/js
parent308396b770f3b1b41ba31ff0ee889d485b14d14a (diff)
downloadnextcloud-server-1473e156f4c1f6c634cc7933343de0fbcc91cbe8.tar.gz
nextcloud-server-1473e156f4c1f6c634cc7933343de0fbcc91cbe8.zip
Use boxes for system tags, shorten permission text
Permission text now doesn't appear when all permissions are there, or shows as "invisible" or "not assignable", which should better cover all use cases. Changed select2 style to use boxes in the input field.
Diffstat (limited to 'core/js')
-rw-r--r--core/js/systemtags/systemtags.js24
-rw-r--r--core/js/systemtags/systemtagsinputfield.js3
-rw-r--r--core/js/tests/specs/systemtags/systemtagsSpec.js26
-rw-r--r--core/js/tests/specs/systemtags/systemtagsinputfieldSpec.js6
4 files changed, 43 insertions, 16 deletions
diff --git a/core/js/systemtags/systemtags.js b/core/js/systemtags/systemtags.js
index 05d3ba2c7b8..042f49bb8ed 100644
--- a/core/js/systemtags/systemtags.js
+++ b/core/js/systemtags/systemtags.js
@@ -31,15 +31,25 @@
);
}
- var $span = $('<span>'),
- $tag = $('<em>').text(
- t('core', '({uservisible}, {userassignable})', {
- uservisible: tag.userVisible ? t('core', 'visible') : t('core', 'invisible'),
- userassignable: tag.userAssignable ? t('core', 'assignable') : t('core', 'not assignable')
+ var $span = $('<span>');
+ $span.append(escapeHTML(tag.name));
+
+ var scope;
+ if (!tag.userAssignable) {
+ scope = t('core', 'not assignable');
+ }
+ if (!tag.userVisible) {
+ // invisible also implicitly means not assignable
+ scope = t('core', 'invisible');
+ }
+ if (scope) {
+ var $tag = $('<em>').text(' ' +
+ t('core', '({scope})', {
+ scope: scope
})
);
- $span.append(escapeHTML(tag.name) + ' ');
- $span.append($tag);
+ $span.append($tag);
+ }
return $span;
}
};
diff --git a/core/js/systemtags/systemtagsinputfield.js b/core/js/systemtags/systemtagsinputfield.js
index b90ecbe4265..3e0bfbbc55c 100644
--- a/core/js/systemtags/systemtagsinputfield.js
+++ b/core/js/systemtags/systemtagsinputfield.js
@@ -34,8 +34,7 @@
' <span class="label">{{{tagMarkup}}}</span>' +
'{{else}}' +
' <span class="label">{{name}}</span>' +
- '{{/if}}' +
- '<span class="comma">,&nbsp;</span>';
+ '{{/if}}';
var RENAME_FORM_TEMPLATE =
'<form class="systemtags-rename-form">' +
diff --git a/core/js/tests/specs/systemtags/systemtagsSpec.js b/core/js/tests/specs/systemtags/systemtagsSpec.js
index 2e8390ad9f0..515b75258a0 100644
--- a/core/js/tests/specs/systemtags/systemtagsSpec.js
+++ b/core/js/tests/specs/systemtags/systemtagsSpec.js
@@ -34,7 +34,7 @@ describe('OC.SystemTags tests', function() {
userVisible: true
});
var $return = OC.SystemTags.getDescriptiveTag(tag);
- expect($return.text()).toEqual('Twenty Three (visible, assignable)');
+ expect($return.text()).toEqual('Twenty Three');
expect($return.hasClass('non-existing-tag')).toEqual(false);
});
@@ -42,10 +42,28 @@ describe('OC.SystemTags tests', function() {
var $return = OC.SystemTags.getDescriptiveTag({
id: 42,
name: 'Fourty Two',
- userAssignable: false,
- userVisible: false
+ userAssignable: true,
+ userVisible: true
});
- expect($return.text()).toEqual('Fourty Two (invisible, not assignable)');
+ expect($return.text()).toEqual('Fourty Two');
expect($return.hasClass('non-existing-tag')).toEqual(false);
});
+
+ it('scope', function() {
+ function testScope(userVisible, userAssignable, expectedText) {
+ var $return = OC.SystemTags.getDescriptiveTag({
+ id: 42,
+ name: 'Fourty Two',
+ userAssignable: userAssignable,
+ userVisible: userVisible
+ });
+ expect($return.text()).toEqual(expectedText);
+ expect($return.hasClass('non-existing-tag')).toEqual(false);
+ }
+
+ testScope(true, true, 'Fourty Two');
+ testScope(false, true, 'Fourty Two (invisible)');
+ testScope(false, false, 'Fourty Two (invisible)');
+ testScope(true, false, 'Fourty Two (not assignable)');
+ });
});
diff --git a/core/js/tests/specs/systemtags/systemtagsinputfieldSpec.js b/core/js/tests/specs/systemtags/systemtagsinputfieldSpec.js
index 07e926cd2a9..a2347eb6893 100644
--- a/core/js/tests/specs/systemtags/systemtagsinputfieldSpec.js
+++ b/core/js/tests/specs/systemtags/systemtagsinputfieldSpec.js
@@ -234,12 +234,12 @@ describe('OC.SystemTags.SystemTagsInputField tests', function() {
it('formatResult renders tag name with visibility', function() {
var opts = select2Stub.getCall(0).args[0];
var $el = $(opts.formatResult({id: '1', name: 'test', userVisible: false, userAssignable: false}));
- expect($el.find('.label').text()).toEqual('test (invisible, not assignable)');
+ expect($el.find('.label').text()).toEqual('test (invisible)');
});
it('formatSelection renders tag name with visibility', function() {
var opts = select2Stub.getCall(0).args[0];
var $el = $(opts.formatSelection({id: '1', name: 'test', userVisible: false, userAssignable: false}));
- expect($el.text().trim()).toEqual('test (invisible, not assignable),');
+ expect($el.text().trim()).toEqual('test (invisible)');
});
describe('initSelection', function() {
var fetchStub;
@@ -337,7 +337,7 @@ describe('OC.SystemTags.SystemTagsInputField tests', function() {
it('formatSelection renders tag name only', function() {
var opts = select2Stub.getCall(0).args[0];
var $el = $(opts.formatSelection({id: '1', name: 'test'}));
- expect($el.text().trim()).toEqual('test,');
+ expect($el.text().trim()).toEqual('test');
});
describe('initSelection', function() {
var fetchStub;