Sharkey/src/client/app/desktop/views/components/drive.folder.vue

264 lines
5.8 KiB
Vue
Raw Normal View History

2018-02-14 02:03:48 -08:00
<template>
2018-07-24 12:36:02 -07:00
<div class="ynntpczxvnusfwdyxsfuhvcmuypqopdd"
2018-02-14 02:03:48 -08:00
:data-is-contextmenu-showing="isContextmenuShowing"
:data-draghover="draghover"
@click="onClick"
@mouseover="onMouseover"
@mouseout="onMouseout"
@dragover.prevent.stop="onDragover"
@dragenter.prevent="onDragenter"
@dragleave="onDragleave"
@drop.prevent.stop="onDrop"
draggable="true"
@dragstart="onDragstart"
@dragend="onDragend"
2018-02-17 19:35:18 -08:00
@contextmenu.prevent.stop="onContextmenu"
2018-02-14 02:03:48 -08:00
:title="title"
>
<p class="name">
<template v-if="hover"><fa :icon="['far', 'folder-open']" fixed-width/></template>
<template v-if="!hover"><fa :icon="['far', 'folder']" fixed-width/></template>
2018-02-14 02:03:48 -08:00
{{ folder.name }}
</p>
</div>
</template>
<script lang="ts">
import Vue from 'vue';
2018-02-17 19:35:18 -08:00
import contextmenu from '../../api/contextmenu';
2018-02-14 02:03:48 -08:00
export default Vue.extend({
2018-02-17 19:35:18 -08:00
props: ['folder'],
2018-02-14 02:03:48 -08:00
data() {
return {
hover: false,
draghover: false,
isDragging: false,
isContextmenuShowing: false
};
},
computed: {
2018-02-17 19:35:18 -08:00
browser(): any {
return this.$parent;
},
2018-02-14 02:03:48 -08:00
title(): string {
return this.folder.name;
}
},
methods: {
onClick() {
this.browser.move(this.folder);
},
2018-02-17 19:35:18 -08:00
onContextmenu(e) {
this.isContextmenuShowing = true;
2018-05-29 08:15:32 -07:00
contextmenu((this as any).os)(e, [{
2018-02-17 19:35:18 -08:00
type: 'item',
2018-05-20 04:26:38 -07:00
text: '%i18n:@contextmenu.move-to-this-folder%',
icon: 'arrow-right',
2018-06-07 19:46:45 -07:00
action: this.go
2018-02-17 19:35:18 -08:00
}, {
type: 'item',
2018-05-20 04:26:38 -07:00
text: '%i18n:@contextmenu.show-in-new-window%',
icon: ['far', 'window-restore'],
2018-06-07 19:46:45 -07:00
action: this.newWindow
}, null, {
2018-02-17 19:35:18 -08:00
type: 'item',
2018-05-20 04:26:38 -07:00
text: '%i18n:@contextmenu.rename%',
icon: 'i-cursor',
2018-06-07 19:46:45 -07:00
action: this.rename
2018-10-25 23:06:55 -07:00
}, null, {
2018-02-17 19:35:18 -08:00
type: 'item',
2018-05-20 04:26:38 -07:00
text: '%i18n:common.delete%',
icon: ['far', 'trash-alt'],
2018-06-07 19:46:45 -07:00
action: this.deleteFolder
2018-10-25 23:06:55 -07:00
}], {
2018-08-13 06:08:59 -07:00
closed: () => {
this.isContextmenuShowing = false;
}
});
2018-02-17 19:35:18 -08:00
},
2018-02-14 02:03:48 -08:00
onMouseover() {
this.hover = true;
},
onMouseout() {
this.hover = false
},
onDragover(e) {
2018-02-26 13:25:17 -08:00
// 自分自身がドラッグされている場合
if (this.isDragging) {
2018-02-14 02:03:48 -08:00
// 自分自身にはドロップさせない
e.dataTransfer.dropEffect = 'none';
2018-02-26 13:25:17 -08:00
return;
}
const isFile = e.dataTransfer.items[0].kind == 'file';
const isDriveFile = e.dataTransfer.types[0] == 'mk_drive_file';
const isDriveFolder = e.dataTransfer.types[0] == 'mk_drive_folder';
if (isFile || isDriveFile || isDriveFolder) {
e.dataTransfer.dropEffect = e.dataTransfer.effectAllowed == 'all' ? 'copy' : 'move';
} else {
e.dataTransfer.dropEffect = 'none';
2018-02-14 02:03:48 -08:00
}
},
onDragenter() {
if (!this.isDragging) this.draghover = true;
},
onDragleave() {
this.draghover = false;
},
onDrop(e) {
this.draghover = false;
// ファイルだったら
if (e.dataTransfer.files.length > 0) {
Array.from(e.dataTransfer.files).forEach(file => {
this.browser.upload(file, this.folder);
});
2018-02-26 13:25:17 -08:00
return;
2018-02-22 14:56:35 -08:00
}
2018-02-14 02:03:48 -08:00
2018-02-26 13:25:17 -08:00
//#region ドライブのファイル
const driveFile = e.dataTransfer.getData('mk_drive_file');
if (driveFile != null && driveFile != '') {
const file = JSON.parse(driveFile);
this.browser.removeFile(file.id);
2018-02-17 19:35:18 -08:00
(this as any).api('drive/files/update', {
2018-03-28 22:48:47 -07:00
fileId: file.id,
folderId: this.folder.id
2018-02-14 02:03:48 -08:00
});
2018-02-26 13:25:17 -08:00
}
//#endregion
//#region ドライブのフォルダ
const driveFolder = e.dataTransfer.getData('mk_drive_folder');
if (driveFolder != null && driveFolder != '') {
const folder = JSON.parse(driveFolder);
2018-02-14 02:03:48 -08:00
// 移動先が自分自身ならreject
2018-02-26 13:25:17 -08:00
if (folder.id == this.folder.id) return;
this.browser.removeFolder(folder.id);
2018-02-17 19:35:18 -08:00
(this as any).api('drive/folders/update', {
2018-03-28 22:48:47 -07:00
folderId: folder.id,
parentId: this.folder.id
2018-02-14 02:03:48 -08:00
}).then(() => {
2018-02-26 13:25:17 -08:00
// noop
2018-02-14 02:03:48 -08:00
}).catch(err => {
switch (err) {
case 'detected-circular-definition':
2018-02-17 19:35:18 -08:00
(this as any).apis.dialog({
title: '<fa icon="exclamation-triangle"/>%i18n:@unable-to-process%',
2018-05-20 04:26:38 -07:00
text: '%i18n:@circular-reference-detected%',
2018-02-17 19:35:18 -08:00
actions: [{
2018-05-20 04:26:38 -07:00
text: '%i18n:common.ok%'
2018-02-17 19:35:18 -08:00
}]
});
2018-02-14 02:03:48 -08:00
break;
default:
2018-09-01 07:12:51 -07:00
alert(`%i18n:@unhandled-error% ${err}`);
2018-02-14 02:03:48 -08:00
}
});
}
2018-02-26 13:25:17 -08:00
//#endregion
2018-02-14 02:03:48 -08:00
},
onDragstart(e) {
e.dataTransfer.effectAllowed = 'move';
2018-02-26 13:25:17 -08:00
e.dataTransfer.setData('mk_drive_folder', JSON.stringify(this.folder));
2018-02-14 02:03:48 -08:00
this.isDragging = true;
// 親ブラウザに対して、ドラッグが開始されたフラグを立てる
// (=あなたの子供が、ドラッグを開始しましたよ)
this.browser.isDragSource = true;
},
onDragend() {
this.isDragging = false;
this.browser.isDragSource = false;
},
2018-02-17 19:35:18 -08:00
go() {
this.browser.move(this.folder.id);
},
newWindow() {
2018-02-21 07:18:19 -08:00
this.browser.newWindow(this.folder);
2018-02-17 19:35:18 -08:00
},
rename() {
(this as any).apis.input({
2018-05-20 04:26:38 -07:00
title: '%i18n:@contextmenu.rename-folder%',
placeholder: '%i18n:@contextmenu.input-new-folder-name%',
2018-02-17 19:35:18 -08:00
default: this.folder.name
}).then(name => {
(this as any).api('drive/folders/update', {
2018-03-28 22:48:47 -07:00
folderId: this.folder.id,
2018-02-17 19:35:18 -08:00
name: name
});
2018-02-14 02:03:48 -08:00
});
2018-02-17 19:35:18 -08:00
},
deleteFolder() {
2018-10-25 23:06:55 -07:00
(this as any).api('drive/folders/delete', {
folderId: this.folder.id
});
2018-02-14 02:03:48 -08:00
}
}
});
</script>
<style lang="stylus" scoped>
2018-09-28 01:49:37 -07:00
.ynntpczxvnusfwdyxsfuhvcmuypqopdd
2018-02-14 02:03:48 -08:00
padding 8px
height 64px
2018-09-28 01:49:37 -07:00
background var(--desktopDriveFolderBg)
2018-02-14 02:03:48 -08:00
border-radius 4px
&, *
cursor pointer
*
pointer-events none
&:hover
2018-09-28 01:49:37 -07:00
background var(--desktopDriveFolderHoverBg)
2018-02-14 02:03:48 -08:00
&:active
2018-09-28 01:49:37 -07:00
background var(--desktopDriveFolderActiveBg)
2018-02-14 02:03:48 -08:00
&[data-is-contextmenu-showing]
&[data-draghover]
&:after
content ""
pointer-events none
position absolute
top -4px
right -4px
bottom -4px
left -4px
2018-09-26 04:19:35 -07:00
border 2px dashed var(--primaryAlpha03)
2018-02-14 02:03:48 -08:00
border-radius 4px
&[data-draghover]
2018-09-28 01:49:37 -07:00
background var(--desktopDriveFolderActiveBg)
2018-02-14 02:03:48 -08:00
> .name
margin 0
font-size 0.9em
2018-09-28 01:49:37 -07:00
color var(--desktopDriveFolderFg)
2018-02-14 02:03:48 -08:00
> [data-icon]
2018-02-14 02:03:48 -08:00
margin-right 4px
margin-left 2px
text-align left
</style>