Skip to content

Commit

Permalink
Removed favorite button from file list and added it instead in action…
Browse files Browse the repository at this point in the history
… dropdown
  • Loading branch information
Julian1998 committed Apr 14, 2020
1 parent 87d4f48 commit 8562092
Show file tree
Hide file tree
Showing 10 changed files with 144 additions and 111 deletions.
19 changes: 0 additions & 19 deletions apps/files/src/components/AllFilesList.vue
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,6 @@
<file-list :fileData="fileData" id="files-list" :loading="loadingFolder" :actions="actions" :compactMode="_sidebarOpen"
:isActionEnabled="isActionEnabled">
<template #headerColumns>
<div v-if="!publicPage()">
<span class="oc-visually-hidden" v-text="favoritesHeaderText" />
<oc-star id="files-table-header-star" aria-hidden="true" class="uk-display-block uk-disabled" />
</div>
<div class="uk-text-truncate uk-text-meta uk-width-expand" ref="headerNameColumn" >
<sortable-column-header
@click="toggleSort('name')"
Expand Down Expand Up @@ -44,9 +40,6 @@
</div>
</template>
<template #rowColumns="{ item, index }">
<div v-if="!publicPage()">
<oc-star class="uk-display-block" @click.native.stop="toggleFileFavorite(item)" :shining="item.starred" />
</div>
<div class="uk-text-truncate uk-width-expand" :ref="index === 0 ? 'firstRowNameColumn' : null">
<file-item
@click.native.stop="item.type === 'folder' ? navigateTo(item.path.substr(1)) : openFileActionBar(item)"
Expand Down Expand Up @@ -141,11 +134,6 @@ export default {
FileActions
],
props: ['fileData', 'starsEnabled', 'checkboxEnabled', 'dateEnabled', 'parentFolder'],
data () {
return {
favoritesHeaderText: this.$gettext('Favorites')
}
},
computed: {
...mapState(['route']),
...mapGetters('Files', [
Expand Down Expand Up @@ -237,7 +225,6 @@ export default {
methods: {
...mapActions('Files', [
'loadFolder',
'markFavorite',
'setHighlightedFile'
]),
Expand Down Expand Up @@ -289,12 +276,6 @@ export default {
})
})
},
toggleFileFavorite (item) {
this.markFavorite({
client: this.$client,
file: item
})
},
isActionEnabled (item, action) {
return action.isEnabled(item, this.parentFolder)
Expand Down
10 changes: 8 additions & 2 deletions apps/files/src/components/FileDetails.vue
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
<span id="files-sidebar-item-name" class="uk-margin-small-right uk-text-bold" v-text="highlightedFile.name" />
</div>
<div v-if="$route.name !== 'files-shared-with-others'">
<oc-star v-if="!publicPage()" class="uk-inline" :shining="highlightedFile.starred"/>
<oc-star v-if="!publicPage()" @click.native.stop="toggleFileFavorite(highlightedFile)" class="uk-inline" :shining="highlightedFile.starred"/>
<template v-if="highlightedFile.size > -1">
{{ highlightedFile.size | fileSize }},
</template>
Expand Down Expand Up @@ -73,13 +73,19 @@ export default {
this.activeTab = this.defaultTab
},
methods: {
...mapActions('Files', ['deleteFiles']),
...mapActions('Files', ['deleteFiles', 'markFavorite']),
...mapActions(['showMessage']),
close () {
this.$emit('reset')
},
showSidebar (app) {
this.activeTab = app
},
toggleFileFavorite (file) {
this.markFavorite({
client: this.$client,
file: file
})
}
}
}
Expand Down
8 changes: 1 addition & 7 deletions apps/files/src/components/FileList.vue
Original file line number Diff line number Diff line change
Expand Up @@ -160,20 +160,14 @@ export default {
}
},
methods: {
...mapActions('Files', ['loadFolder', 'markFavorite',
...mapActions('Files', ['loadFolder',
'setHighlightedFile', 'setPublicLinkPassword',
'resetFileSelection', 'addFileSelection', 'removeFileSelection', 'toggleFileSelection'
]),
labelSelectSingleItem (item) {
return this.$gettextInterpolate(this.labelSelectSingleItemText, { name: item.name, type: item.type }, true)
},
toggleFileFavorite (item) {
this.markFavorite({
client: this.$client,
file: item
})
},
$_ocFileName (item) {
if (this.$route.name === 'files-favorites') {
const pathSplit = item.path.substr(1).split('/')
Expand Down
6 changes: 3 additions & 3 deletions apps/files/src/components/FilesLists/RowActionsDropdown.vue
Original file line number Diff line number Diff line change
Expand Up @@ -9,14 +9,14 @@
class="uk-open uk-drop-stack"
>
<ul class="uk-list">
<li v-for="action in actions" :key="action.ariaLabel">
<li v-for="action in actions" :key="action.ariaLabel(item)">
<oc-button
class="uk-width-1-1"
@click.native.stop="action.handler(item, action.handlerData); actionClicked()"
:icon="action.icon"
:ariaLabel="action.ariaLabel"
:ariaLabel="action.ariaLabel(item)"
>
{{ action.ariaLabel }}
{{ action.ariaLabel(item) }}
</oc-button>
</li>
</ul>
Expand Down
49 changes: 42 additions & 7 deletions apps/files/src/fileactions.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,11 +10,14 @@ export default {
...mapGetters(['capabilities', 'fileSideBars']),
// Files lists
actions () {
const ctrl = this
const actions = [
{
icon: 'edit',
ariaLabel: this.$gettext('Rename'),
handler: this.promptFileRename,
ariaLabel: function (item) {
return ctrl.$gettext('Rename')
},
isEnabled: function (item, parent) {
if (parent && !parent.canRename()) {
return false
Expand All @@ -25,21 +28,38 @@ export default {
{
icon: 'file_download',
handler: this.downloadFile,
ariaLabel: this.$gettext('Download'),
ariaLabel: function (item) {
return ctrl.$gettext('Download')
},
isEnabled: function (item) {
return item.canDownload()
}
},
{
icon: 'delete',
ariaLabel: this.$gettext('Delete'),
handler: this.deleteFile,
ariaLabel: function (item) {
return ctrl.$gettext('Delete')
},
isEnabled: function (item, parent) {
if (parent && !parent.canBeDeleted()) {
return false
}
return item.canBeDeleted()
}
},
{
icon: 'star',
handler: this.toggleFileFavorite,
ariaLabel: function (item) {
if (item.starred) {
return ctrl.$gettext('Unmark as favorite')
}
return ctrl.$gettext('Mark as favorite')
},
isEnabled: function () {
return true
}
}
]
// FIXME: we are assuming this.fileSideBars and others are available on object
Expand All @@ -50,7 +70,9 @@ export default {
if (sideBar.quickAccess) {
actions.push({
icon: sideBar.quickAccess.icon,
ariaLabel: sideBar.quickAccess.ariaLabel,
ariaLabel: function (item) {
return sideBar.quickAccess.ariaLabel
},
handler: this.openSideBar,
handlerData: sideBar.app,
isEnabled: function (item) {
Expand All @@ -66,7 +88,8 @@ export default {
methods: {
...mapActions('Files', [
'renameFile', 'promptFileRename', 'closePromptFileRename',
'deleteFiles', 'promptFileDelete', 'closePromptFileDelete'
'deleteFiles', 'promptFileDelete', 'closePromptFileDelete',
'markFavorite'
]),
...mapActions(['showMessage']),

Expand Down Expand Up @@ -112,7 +135,19 @@ export default {
this.closePromptFileRename()
})
},

toggleFileFavorite (file) {
this.markFavorite({
client: this.$client,
file: file
}).catch(() => {
const translated = this.$gettext('Error while starring "%{file}"')
const title = this.$gettextInterpolate(translated, { file: file.name }, true)
this.showMessage({
title: title,
status: 'danger'
})
})
},
cancelDeleteFile () {
this.closePromptFileDelete()
},
Expand All @@ -125,7 +160,7 @@ export default {
})
},
reallyDeleteFiles () {
let files = this.deleteDialogSelectedFiles ? this.deleteDialogSelectedFiles : this.selectedFiles
let files = this.dfavoriteFileeleteDialogSelectedFiles ? this.deleteDialogSelectedFiles : this.selectedFiles
if (!Array.isArray(files)) {
files = [files]
}
Expand Down
8 changes: 8 additions & 0 deletions changelog/unreleased/3336
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
Change: Removed favorite button from file list and added it in the sidebar

We've removed the favorite star button in the file list and added instead a functionality
to the before non-working star button in the file's sidebar. We also added a new action in
the file action dropdown menu which allows you to toggle the favorite status of your file.

https://github.com/owncloud/phoenix/issues/1987
https://github.com/owncloud/phoenix/pull/3336
45 changes: 45 additions & 0 deletions tests/acceptance/pageObjects/FilesPageElement/fileActionsMenu.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,8 @@ module.exports = {
FileAction: Object.freeze({
download: 'download',
delete: 'delete',
favorite: 'favorite',
unmarkFavorite: 'unmarkFavorite',
restore: 'restore',
share: 'share',
rename: 'rename',
Expand Down Expand Up @@ -90,6 +92,41 @@ module.exports = {

return this
},
/**
* mark as favorite resource using fileActions 'favorite' button
* @returns {Promise<*>}
*/
favorite: async function () {
this.performFileAction(this.FileAction.favorite)
return this
},
/**
* unmark as favorite resource using fileActions 'favorite' button
* @returns {Promise<*>}
*/
unmarkFavorite: async function () {
this.performFileAction(this.FileAction.unmarkFavorite)
return this
},
/**
* checks whether unmark as favorite button of given file-row is present
*
* @returns {Promise<boolean>}
*/
isUnmarkFavoriteBtnPresent: async function () {
const unmarkFavoriteButtonXpath = this.elements.unmarkFavoriteButtonInFileRow.selector
let isPresent = true
await this
.api.page.FilesPageElement.appSideBar().closeSidebar(100)
await this
.api.elements(
this.elements.unmarkFavoriteButtonXpath.locateStrategy,
unmarkFavoriteButtonXpath,
(result) => {
isPresent = result.value.length > 0
})
return isPresent
},
/**
* opens sharing dialog for given resource
* assumes filesAction menu for the resource to be opened
Expand Down Expand Up @@ -172,6 +209,14 @@ module.exports = {
selector: '//button[@aria-label="Download"]',
locateStrategy: 'xpath'
},
favoriteButtonInFileRow: {
selector: '//button[@aria-label="Mark as favorite"]',
locateStrategy: 'xpath'
},
unmarkFavoriteButtonInFileRow: {
selector: '//button[@aria-label="Unmark as favorite"]',
locateStrategy: 'xpath'
},
restoreButtonInFileRow: {
selector: '//button[@aria-label="Restore"]',
locateStrategy: 'xpath'
Expand Down
41 changes: 33 additions & 8 deletions tests/acceptance/pageObjects/FilesPageElement/filesList.js
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,39 @@ module.exports = {
.rename(toName, expectToSucceed)
return this
},
/**
* @param {string} path
* @return {Promise<module.exports.commands>}
*/
markFavorite: async function (path) {
await this.waitForFileVisible(path)
await filesRow
.openFileActionsMenu(path)
.favorite()
return this
},
/**
* @param {string} path
* @return {Promise<module.exports.commands>}
*/
unmarkFavorite: async function (path) {
await this.waitForFileVisible(path)
await filesRow
.openFileActionsMenu(path)
.unmarkFavorite()
return this
},
/**
* @param {string} path
* @return {Promise<module.exports.commands>}
*/
isMarkedFavorite: async function (path) {
await this.waitForFileVisible(path)
await filesRow
.openFileActionsMenu(path)
.isUnmarkFavoriteBtnPresent()
return this
},
/**
* @param {string} element
* @param {string} elementType
Expand Down Expand Up @@ -713,14 +746,6 @@ module.exports = {
selector: '//span[contains(@class, "file-row-name") and (@data-preview-loaded="true" or not(@data-preview-loaded))]',
locateStrategy: 'xpath'
},
notMarkedFavoriteInFileRow: {
selector: '//span[contains(@class, "oc-star-dimm")]',
locateStrategy: 'xpath'
},
markedFavoriteInFileRow: {
selector: '//span[contains(@class, "oc-star-shining")]',
locateStrategy: 'xpath'
},
collaboratorsInFileRow: {
selector: '//*[contains(@class, "file-row-collaborator-name")]',
locateStrategy: 'xpath'
Expand Down
Loading

0 comments on commit 8562092

Please sign in to comment.