diff options
author | John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> | 2018-09-12 17:20:39 +0200 |
---|---|---|
committer | John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com> | 2018-09-28 15:37:37 +0200 |
commit | 2b41b01bf2c2c1346d5368a6686a175a4e694f15 (patch) | |
tree | d7a74acb632953e35524629036adfee31c22cd48 /settings/src/components/appNavigation/navigationItem.vue | |
parent | a23d5240987392f4eb140eefbb81882ef6ae6a5a (diff) | |
download | nextcloud-server-2b41b01bf2c2c1346d5368a6686a175a4e694f15.tar.gz nextcloud-server-2b41b01bf2c2c1346d5368a6686a175a4e694f15.zip |
Add new group entry on users list + fixes
Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com>
Diffstat (limited to 'settings/src/components/appNavigation/navigationItem.vue')
-rw-r--r-- | settings/src/components/appNavigation/navigationItem.vue | 155 |
1 files changed, 0 insertions, 155 deletions
diff --git a/settings/src/components/appNavigation/navigationItem.vue b/settings/src/components/appNavigation/navigationItem.vue deleted file mode 100644 index 4464c0abd0a..00000000000 --- a/settings/src/components/appNavigation/navigationItem.vue +++ /dev/null @@ -1,155 +0,0 @@ -<!-- - - @copyright Copyright (c) 2018 John Molakvoæ <skjnldsv@protonmail.com> - - - - @author John Molakvoæ <skjnldsv@protonmail.com> - - - - @license GNU AGPL version 3 or any later version - - - - This program is free software: you can redistribute it and/or modify - - it under the terms of the GNU Affero General Public License as - - published by the Free Software Foundation, either version 3 of the - - License, or (at your option) any later version. - - - - This program is distributed in the hope that it will be useful, - - but WITHOUT ANY WARRANTY; without even the implied warranty of - - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - - GNU Affero General Public License for more details. - - - - You should have received a copy of the GNU Affero General Public License - - along with this program. If not, see <http://www.gnu.org/licenses/>. - - - --> -<template> - - <!-- Is this a caption ? --> - <li class="app-navigation-caption" v-if="item.caption">{{item.text}}</li> - - <!-- Navigation item --> - <nav-element v-else :id="item.id" v-bind="navElement(item)" - :class="[{'icon-loading-small': item.loading, 'open': item.opened, 'collapsible': item.collapsible&&item.children&&item.children.length>0 }, item.classes]"> - - <!-- Bullet --> - <div v-if="item.bullet" class="app-navigation-entry-bullet" :style="{ backgroundColor: item.bullet }"></div> - - <!-- Main link --> - <a :href="(item.href) ? item.href : '#' " @click="toggleCollapse" :class="item.icon"> - <img v-if="item.iconUrl" :alt="item.text" :src="item.iconUrl"> - {{item.text}} - </a> - - <!-- Popover, counter and button(s) --> - <div v-if="item.utils" class="app-navigation-entry-utils"> - <ul> - <!-- counter --> - <li v-if="Number.isInteger(item.utils.counter)" - class="app-navigation-entry-utils-counter">{{item.utils.counter}}</li> - - <!-- first action if only one action --> - <li v-if="item.utils.actions && item.utils.actions.length === 1" - class="app-navigation-entry-utils-menu-button"> - <button @click="item.utils.actions[0].action" :class="item.utils.actions[0].icon" :title="item.utils.actions[0].text"></button> - </li> - - <!-- second action only two actions and no counter --> - <li v-else-if="item.utils.actions && item.utils.actions.length === 2 && !Number.isInteger(item.utils.counter)" - v-for="action in item.utils.actions" :key="action.action" - class="app-navigation-entry-utils-menu-button"> - <button @click="action.action" :class="action.icon" :title="action.text"></button> - </li> - - <!-- menu if only at least one action and counter OR two actions and no counter--> - <li v-else-if="item.utils.actions && item.utils.actions.length > 1 && (Number.isInteger(item.utils.counter) || item.utils.actions.length > 2)" - class="app-navigation-entry-utils-menu-button"> - <button v-click-outside="hideMenu" @click="showMenu" ></button> - </li> - </ul> - </div> - - <!-- if more than 2 actions or more than 1 actions with counter --> - <div v-if="item.utils && item.utils.actions && item.utils.actions.length > 1 && (Number.isInteger(item.utils.counter) || item.utils.actions.length > 2)" - class="app-navigation-entry-menu" :class="{ 'open': openedMenu }"> - <popover-menu :menu="item.utils.actions"/> - </div> - - <!-- undo entry --> - <div class="app-navigation-entry-deleted" v-if="item.undo"> - <div class="app-navigation-entry-deleted-description">{{item.undo.text}}</div> - <button class="app-navigation-entry-deleted-button icon-history" :title="t('settings', 'Undo')"></button> - </div> - - <!-- edit entry --> - <div class="app-navigation-entry-edit" v-if="item.edit"> - <form> - <input type="text" v-model="item.text"> - <input type="submit" value="" class="icon-confirm"> - <input type="submit" value="" class="icon-close" @click.stop.prevent="cancelEdit"> - </form> - </div> - - <!-- if the item has children, inject the component with proper data --> - <ul v-if="item.children"> - <navigation-item v-for="(item, key) in item.children" :item="item" :key="key" /> - </ul> - </nav-element> -</template> - -<script> -import popoverMenu from '../popoverMenu'; -import ClickOutside from 'vue-click-outside'; -import Vue from 'vue'; - -export default { - name: 'navigationItem', - props: ['item'], - components: { - popoverMenu - }, - directives: { - ClickOutside - }, - data() { - return { - openedMenu: false - }; - }, - methods: { - showMenu() { - this.openedMenu = true; - }, - hideMenu() { - this.openedMenu = false; - }, - toggleCollapse() { - // if item.opened isn't set, Vue won't trigger view updates https://vuejs.org/v2/api/#Vue-set - // ternary is here to detect the undefined state of item.opened - Vue.set(this.item, 'opened', this.item.opened ? !this.item.opened : true); - }, - cancelEdit() { - // remove the editing class - if (Array.isArray(this.item.classes)) - this.item.classes = this.item.classes.filter( - item => item !== 'editing' - ); - }, - // This is used to decide which outter element type to use - // li or router-link - navElement(item) { - if (item.href) { - return { - is: 'li' - }; - } - return { - is: 'router-link', - tag: 'li', - to: item.router, - exact: true - }; - } - }, - mounted() { - // prevent click outside event with popupItem. - this.popupItem = this.$el; - } -}; -</script> |