%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /www/varak.net/nextcloud.varak.net/apps_old/apps/bookmarks/src/components/
Upload File :
Create Path :
Current File : //www/varak.net/nextcloud.varak.net/apps_old/apps/bookmarks/src/components/BulkEditing.vue

<!--
  - Copyright (c) 2021. The Nextcloud Bookmarks contributors.
  -
  - This file is licensed under the Affero General Public License version 3 or later. See the COPYING file.
  -->

<template>
	<div class="bulkediting">
		<NcActions :primary="true" :menu-title="selectionDescription">
			<NcActionButton close-after-click @click="onBulkOpen">
				<template #icon>
					<OpenInNewIcon />
				</template>
				{{ t('bookmarks', 'Open all selected') }}
			</NcActionButton>
			<NcActionButton close-after-click @click="onBulkMove">
				<template #icon>
					<FolderMoveIcon />
				</template>
				{{ t('bookmarks', 'Move selection') }}
			</NcActionButton>
			<NcActionButton v-if="!selectedFolders.length" close-after-click @click="onBulkCopy">
				<template #icon>
					<FolderPlusIcon />
				</template>
				{{ t('bookmarks', 'Add to folders') }}
			</NcActionButton>
			<NcActionInput v-if="!selectedFolders.length"
				:value="selectionTags"
				type="multiselect"
				:options="allTags"
				:multiple="true"
				:taggable="true"
				@tag="onBulkTag([...selectionTags, $event])"
				@input="onBulkTag">
				<template #icon>
					<TagIcon />
				</template>
				{{ t('bookmarks', 'Edit tags of selection') }}
			</NcActionInput>
			<NcActionButton close-after-click @click="onBulkDelete">
				<template #icon>
					<DeleteIcon />
				</template>
				{{ t('bookmarks', 'Delete selection') }}
			</NcActionButton>
			<NcActionSeparator />
			<NcActionButton @click="onSelectAll">
				<template #icon>
					<SelectAllIcon />
				</template>
				{{ t('bookmarks', 'Select all') }}
			</NcActionButton>
			<NcActionButton @click="onCancelSelection">
				<template #icon>
					<SelectOffIcon />
				</template>
				{{ t('bookmarks', 'Cancel selection') }}
			</NcActionButton>
		</NcActions>
	</div>
</template>

<script>

import { NcActions, NcActionSeparator, NcActionButton, NcActionInput } from '@nextcloud/vue'
import FolderPlusIcon from 'vue-material-design-icons/FolderPlus.vue'
import FolderMoveIcon from 'vue-material-design-icons/FolderMove.vue'
import OpenInNewIcon from 'vue-material-design-icons/OpenInNew.vue'
import TagIcon from 'vue-material-design-icons/Tag.vue'
import SelectAllIcon from 'vue-material-design-icons/SelectAll.vue'
import SelectOffIcon from 'vue-material-design-icons/SelectOff.vue'
import DeleteIcon from 'vue-material-design-icons/Delete.vue'
import { actions, mutations } from '../store/index.js'
import intersection from 'lodash/intersection.js'

export default {
	name: 'BulkEditing',
	components: { NcActionInput, NcActionSeparator, FolderPlusIcon, FolderMoveIcon, NcActionButton, NcActions, OpenInNewIcon, TagIcon, SelectAllIcon, SelectOffIcon, DeleteIcon },
	data() {
		return {
			selectionTags: [],
		}
	},
	computed: {
		allTags() {
			return this.$store.state.tags.map(tag => tag.name)
		},
		selectedFolders() {
			return this.$store.state.selection.folders
		},
		selectedBookmarks() {
			return this.$store.state.selection.bookmarks
		},
		selectionDescription() {
			if (this.$store.state.selection.bookmarks.length !== 0 && this.$store.state.selection.folders.length !== 0) {
				return this.t('bookmarks',
					'Selected {folders} folders and {bookmarks} bookmarks',
					{ folders: this.$store.state.selection.folders.length, bookmarks: this.$store.state.selection.bookmarks.length }
				)
			}
			if (this.$store.state.selection.bookmarks.length !== 0) {
				return this.n('bookmarks',
					'Selected %n bookmark',
					'Selected %n bookmarks',
					this.$store.state.selection.bookmarks.length
				)
			}
			if (this.$store.state.selection.folders.length !== 0) {
				return this.n('bookmarks',
					'Selected %n folder',
					'Selected %n folders',
					this.$store.state.selection.folders.length
				)
			}
			return ''
		},
	},
	watch: {
		selectedBookmarks(bookmarks) {
			this.updateSelectionTags()
		},
	},
	methods: {
		async onBulkOpen() {
			for (const { url } of this.$store.state.selection.bookmarks) {
				window.open(url)
				await new Promise(resolve => setTimeout(resolve, 200))
			}
		},
		async onBulkDelete() {
			if (!confirm(t('bookmarks', 'Do you really want to delete these items?'))) {
				return
			}
			await this.$store.dispatch(actions.DELETE_SELECTION, { folder: this.$route.params.folder })
			this.$store.commit(mutations.RESET_SELECTION)
		},
		onBulkMove() {
			this.$store.commit(mutations.DISPLAY_MOVE_DIALOG, true)
		},
		onBulkCopy() {
			this.$store.commit(mutations.DISPLAY_COPY_DIALOG, true)
		},
		async onBulkTag(tags) {
			const originalTags = this.selectionTags
			this.selectionTags = tags
			await this.$store.dispatch(actions.TAG_SELECTION, { tags, originalTags })
		},
		onCancelSelection() {
			this.$store.commit(mutations.RESET_SELECTION)
		},
		async onSelectAll() {
			await this.$store.dispatch(actions.FETCH_ALL)
			this.$store.state.bookmarks.forEach(bookmark => {
				this.$store.commit(mutations.ADD_SELECTION_BOOKMARK, bookmark)
			})
		},
		updateSelectionTags() {
			this.selectionTags = intersection(...this.selectedBookmarks.map((bm) => bm.tags))
		},
	},
}
</script>
<style>
.bulkediting {
	opacity: 1 !important;
	padding: 0 !important;
	margin-top: 1px;
	min-width: 500px;
}
</style>

Zerion Mini Shell 1.0