diff options
author | John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> | 2018-08-08 19:17:55 +0200 |
---|---|---|
committer | John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> | 2018-08-13 11:33:48 +0200 |
commit | b9a24bfef8aad3e8ccdb8a72d654e14a03d2bf30 (patch) | |
tree | 3520bd6444a50656fd58a1e85fc168da38a7f09d /settings/src/views | |
parent | b0c18b81177ace2432316efc702929949e05698b (diff) | |
download | nextcloud-server-b9a24bfef8aad3e8ccdb8a72d654e14a03d2bf30.tar.gz nextcloud-server-b9a24bfef8aad3e8ccdb8a72d654e14a03d2bf30.zip |
Allow external actions to users list
+ Created fix
Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com>
Diffstat (limited to 'settings/src/views')
-rw-r--r-- | settings/src/views/Users.vue | 30 |
1 files changed, 29 insertions, 1 deletions
diff --git a/settings/src/views/Users.vue b/settings/src/views/Users.vue index 70b4db66412..c3fda5b8a01 100644 --- a/settings/src/views/Users.vue +++ b/settings/src/views/Users.vue @@ -52,7 +52,7 @@ </div> </template> </app-navigation> - <user-list :users="users" :showConfig="showConfig" :selectedGroup="selectedGroup" /> + <user-list :users="users" :showConfig="showConfig" :selectedGroup="selectedGroup" :externalActions="externalActions" /> </div> </template> @@ -83,12 +83,24 @@ export default { }); this.$store.dispatch('getPasswordPolicyMinLength'); }, + created() { + // init the OCA.Settings.UserList object + // and add the registerAction method + Object.assign(OCA, { + Settings: { + UserList: { + registerAction: this.registerAction + } + } + }); + }, data() { return { // default quota is set to unlimited unlimitedQuota: {id: 'none', label: t('settings', 'Unlimited')}, // temporary value used for multiselect change selectedQuota: false, + externalActions: [], showConfig: { showStoragePath: false, showUserBackend: false, @@ -171,6 +183,22 @@ export default { // if no valid do not change return false; }, + + /** + * Register a new action for the user menu + * + * @param {string} icon the icon class + * @param {string} text the text to display + * @param {function} action the function to run + */ + registerAction(icon, text, action) { + this.externalActions.push({ + icon: icon, + text: text, + action: action + }); + return this.externalActions; + } }, computed: { users() { |