Updates :D
Former-commit-id: 4aab1964b9462d1fdee92999dd5a7d03f17b4457 [formerly 22352202547980b191886cf29f68ce8e9cc4c39b] [formerly 1a66bae34022092936c2912ea3a323a6984fe7e4 [formerly 1e7c4e6468
]]
Former-commit-id: 94170b15369b05e8f4985e88242ba453b5545116 [formerly 2a0b57bebcd48c0189974f4f9e72679b5c67f37b]
Former-commit-id: 635be5ad2826c1659670997900122d024a46de24
pull/726/head
parent
60ffb88d8e
commit
dd87a70157
|
@ -80,36 +80,6 @@ listing.addDoubleTapEvent = function () {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
listing.selectMoveFolder = function (event) {
|
|
||||||
if (event.target.getAttribute('aria-selected') === 'true') {
|
|
||||||
event.target.setAttribute('aria-selected', false)
|
|
||||||
return
|
|
||||||
} else {
|
|
||||||
if (document.querySelector('.file-list li[aria-selected=true]')) {
|
|
||||||
document.querySelector('.file-list li[aria-selected=true]').setAttribute('aria-selected', false)
|
|
||||||
}
|
|
||||||
event.target.setAttribute('aria-selected', true)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
listing.getJSON = function (link) {
|
|
||||||
return new Promise((resolve, reject) => {
|
|
||||||
let request = new XMLHttpRequest()
|
|
||||||
request.open('GET', link)
|
|
||||||
request.setRequestHeader('Accept', 'application/json')
|
|
||||||
request.onload = () => {
|
|
||||||
if (request.status == 200) {
|
|
||||||
resolve(request.responseText)
|
|
||||||
} else {
|
|
||||||
reject(request.statusText)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
request.onerror = () => reject(request.statusText)
|
|
||||||
request.send()
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
listing.moveMakeItem = function (url, name) {
|
listing.moveMakeItem = function (url, name) {
|
||||||
let node = document.createElement('li'),
|
let node = document.createElement('li'),
|
||||||
count = 0
|
count = 0
|
||||||
|
@ -135,43 +105,6 @@ listing.moveMakeItem = function (url, name) {
|
||||||
return node
|
return node
|
||||||
}
|
}
|
||||||
|
|
||||||
listing.moveDialogNext = function (event) {
|
|
||||||
let request = new XMLHttpRequest(),
|
|
||||||
prompt = document.querySelector('form.prompt.active'),
|
|
||||||
list = prompt.querySelector('div.file-list ul')
|
|
||||||
|
|
||||||
prompt.addEventListener('submit', listing.moveSelected)
|
|
||||||
|
|
||||||
listing.getJSON(event.target.dataset.url)
|
|
||||||
.then((data) => {
|
|
||||||
let dirs = 0
|
|
||||||
|
|
||||||
prompt.querySelector('ul').innerHTML = ''
|
|
||||||
prompt.querySelector('code').innerHTML = event.target.dataset.url
|
|
||||||
|
|
||||||
if (event.target.dataset.url != baseURL + '/') {
|
|
||||||
let node = listing.moveMakeItem(removeLastDirectoryPartOf(event.target.dataset.url) + '/', '..')
|
|
||||||
list.appendChild(node)
|
|
||||||
}
|
|
||||||
|
|
||||||
if (JSON.parse(data) == null) {
|
|
||||||
prompt.querySelector('p').innerHTML = `There aren't any folders in this directory.`
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
for (let f of JSON.parse(data)) {
|
|
||||||
if (f.IsDir === true) {
|
|
||||||
dirs++
|
|
||||||
list.appendChild(listing.moveMakeItem(f.URL, f.Name))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (dirs === 0)
|
|
||||||
prompt.querySelector('p').innerHTML = `There aren't any folders in this directory.`
|
|
||||||
})
|
|
||||||
.catch(e => console.log(e))
|
|
||||||
}
|
|
||||||
|
|
||||||
listing.moveSelected = function (event) {
|
listing.moveSelected = function (event) {
|
||||||
event.preventDefault()
|
event.preventDefault()
|
||||||
|
|
||||||
|
@ -203,40 +136,6 @@ listing.moveSelected = function (event) {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
listing.moveEvent = function (event) {
|
|
||||||
if (event.currentTarget.classList.contains('disabled'))
|
|
||||||
return
|
|
||||||
|
|
||||||
listing.getJSON(window.location.pathname)
|
|
||||||
.then((data) => {
|
|
||||||
let prompt = document.importNode(templates.move.content, true),
|
|
||||||
list = prompt.querySelector('div.file-list ul'),
|
|
||||||
dirs = 0
|
|
||||||
|
|
||||||
prompt.querySelector('form').addEventListener('submit', listing.moveSelected)
|
|
||||||
prompt.querySelector('code').innerHTML = window.location.pathname
|
|
||||||
|
|
||||||
if (window.location.pathname !== baseURL + '/') {
|
|
||||||
list.appendChild(listing.moveMakeItem(removeLastDirectoryPartOf(window.location.pathname) + '/', '..'))
|
|
||||||
}
|
|
||||||
|
|
||||||
for (let f of JSON.parse(data)) {
|
|
||||||
if (f.IsDir === true) {
|
|
||||||
dirs++
|
|
||||||
list.appendChild(listing.moveMakeItem(f.URL, f.Name))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (dirs === 0) {
|
|
||||||
prompt.querySelector('p').innerHTML = `There aren't any folders in this directory.`
|
|
||||||
}
|
|
||||||
|
|
||||||
document.body.appendChild(prompt)
|
|
||||||
document.querySelector('.overlay').classList.add('active')
|
|
||||||
document.querySelector('.prompt').classList.add('active')
|
|
||||||
})
|
|
||||||
.catch(e => console.log(e))
|
|
||||||
}
|
|
||||||
|
|
||||||
document.addEventListener('DOMContentLoaded', event => {
|
document.addEventListener('DOMContentLoaded', event => {
|
||||||
listing.updateColumns()
|
listing.updateColumns()
|
||||||
|
|
|
@ -20,25 +20,4 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<template id="move-template">
|
|
||||||
<form class="prompt">
|
|
||||||
<h3>Move</h3>
|
|
||||||
<p>Choose new house for your file(s)/folder(s):</p>
|
|
||||||
|
|
||||||
<div class="file-list">
|
|
||||||
<ul>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<p>Currently navigating on: <code></code>.</p>
|
|
||||||
|
|
||||||
<div>
|
|
||||||
<button type="submit" autofocus class="ok">Move</button>
|
|
||||||
<button class="cancel" onclick="closePrompt(event);">Cancel</button>
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
|
|
||||||
{{ end }}
|
{{ end }}
|
|
@ -43,11 +43,9 @@
|
||||||
showDelete: false,
|
showDelete: false,
|
||||||
showRename: false,
|
showRename: false,
|
||||||
showMove: false,
|
showMove: false,
|
||||||
listing: {
|
|
||||||
selected: [],
|
selected: [],
|
||||||
multiple: false
|
multiple: false
|
||||||
}
|
}
|
||||||
}
|
|
||||||
</script>
|
</script>
|
||||||
<div id="app">
|
<div id="app">
|
||||||
<!-- TODO: loading -->
|
<!-- TODO: loading -->
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
<rename-button v-show="showRenameButton()"></rename-button>
|
<rename-button v-show="showRenameButton()"></rename-button>
|
||||||
<move-button v-show="showDeleteButton()"></move-button>
|
<move-button v-show="showMoveButton()"></move-button>
|
||||||
<delete-button v-show="showDeleteButton()"></delete-button>
|
<delete-button v-show="showDeleteButton()"></delete-button>
|
||||||
<switch-button v-show="req.kind !== 'editor'"></switch-button>
|
<switch-button v-show="req.kind !== 'editor'"></switch-button>
|
||||||
<download-button></download-button>
|
<download-button></download-button>
|
||||||
|
@ -50,6 +50,7 @@
|
||||||
<rename-prompt v-show="showRename" :class="{ active: showRename }"></rename-prompt>
|
<rename-prompt v-show="showRename" :class="{ active: showRename }"></rename-prompt>
|
||||||
<delete-prompt v-show="showDelete" :class="{ active: showDelete }"></delete-prompt>
|
<delete-prompt v-show="showDelete" :class="{ active: showDelete }"></delete-prompt>
|
||||||
<info-prompt v-show="showInfo" :class="{ active: showInfo }"></info-prompt>
|
<info-prompt v-show="showInfo" :class="{ active: showInfo }"></info-prompt>
|
||||||
|
<move-prompt v-if="showMove" :class="{ active: showMove }"></move-prompt>
|
||||||
<help v-show="showHelp" :class="{ active: showHelp }"></help>
|
<help v-show="showHelp" :class="{ active: showHelp }"></help>
|
||||||
|
|
||||||
<div v-show="showOverlay()" @click="resetPrompts" class="overlay" :class="{ active: showOverlay() }"></div>
|
<div v-show="showOverlay()" @click="resetPrompts" class="overlay" :class="{ active: showOverlay() }"></div>
|
||||||
|
@ -73,8 +74,11 @@ import UploadButton from './components/UploadButton'
|
||||||
import DownloadButton from './components/DownloadButton'
|
import DownloadButton from './components/DownloadButton'
|
||||||
import SwitchButton from './components/SwitchViewButton'
|
import SwitchButton from './components/SwitchViewButton'
|
||||||
import MoveButton from './components/MoveButton'
|
import MoveButton from './components/MoveButton'
|
||||||
|
import MovePrompt from './components/MovePrompt'
|
||||||
import css from './css.js'
|
import css from './css.js'
|
||||||
|
|
||||||
|
var $ = window.info
|
||||||
|
|
||||||
function updateColumnSizes () {
|
function updateColumnSizes () {
|
||||||
let columns = Math.floor(document.querySelector('main').offsetWidth / 300)
|
let columns = Math.floor(document.querySelector('main').offsetWidth / 300)
|
||||||
let items = css(['#listing.mosaic .item', '.mosaic#listing .item'])
|
let items = css(['#listing.mosaic .item', '.mosaic#listing .item'])
|
||||||
|
@ -83,11 +87,11 @@ function updateColumnSizes () {
|
||||||
}
|
}
|
||||||
|
|
||||||
function resetPrompts () {
|
function resetPrompts () {
|
||||||
window.info.showHelp = false
|
$.showHelp = false
|
||||||
window.info.showInfo = false
|
$.showInfo = false
|
||||||
window.info.showDelete = false
|
$.showDelete = false
|
||||||
window.info.showRename = false
|
$.showRename = false
|
||||||
window.info.showMove = false
|
$.showMove = false
|
||||||
}
|
}
|
||||||
|
|
||||||
window.addEventListener('keydown', (event) => {
|
window.addEventListener('keydown', (event) => {
|
||||||
|
@ -96,13 +100,13 @@ window.addEventListener('keydown', (event) => {
|
||||||
resetPrompts()
|
resetPrompts()
|
||||||
|
|
||||||
// Unselect all files and folders.
|
// Unselect all files and folders.
|
||||||
if (window.info.req.kind === 'listing') {
|
if ($.req.kind === 'listing') {
|
||||||
let items = document.getElementsByClassName('item')
|
let items = document.getElementsByClassName('item')
|
||||||
Array.from(items).forEach(link => {
|
Array.from(items).forEach(link => {
|
||||||
link.setAttribute('aria-selected', false)
|
link.setAttribute('aria-selected', false)
|
||||||
})
|
})
|
||||||
|
|
||||||
window.info.listing.selected.length = 0
|
$.selected = []
|
||||||
}
|
}
|
||||||
|
|
||||||
return
|
return
|
||||||
|
@ -110,18 +114,18 @@ window.addEventListener('keydown', (event) => {
|
||||||
|
|
||||||
// Del!
|
// Del!
|
||||||
if (event.keyCode === 46) {
|
if (event.keyCode === 46) {
|
||||||
window.info.showDelete = true
|
$.showDelete = true
|
||||||
}
|
}
|
||||||
|
|
||||||
// F1!
|
// F1!
|
||||||
if (event.keyCode === 112) {
|
if (event.keyCode === 112) {
|
||||||
event.preventDefault()
|
event.preventDefault()
|
||||||
window.info.showHelp = true
|
$.showHelp = true
|
||||||
}
|
}
|
||||||
|
|
||||||
// F2!
|
// F2!
|
||||||
if (event.keyCode === 113) {
|
if (event.keyCode === 113) {
|
||||||
window.info.showRename = true
|
$.showRename = true
|
||||||
}
|
}
|
||||||
|
|
||||||
// CTRL + S
|
// CTRL + S
|
||||||
|
@ -130,7 +134,7 @@ window.addEventListener('keydown', (event) => {
|
||||||
case 's':
|
case 's':
|
||||||
event.preventDefault()
|
event.preventDefault()
|
||||||
|
|
||||||
if (window.info.req.kind !== 'editor') {
|
if ($.req.kind !== 'editor') {
|
||||||
window.location = '?download=true'
|
window.location = '?download=true'
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -156,7 +160,8 @@ export default {
|
||||||
DownloadButton,
|
DownloadButton,
|
||||||
UploadButton,
|
UploadButton,
|
||||||
SwitchButton,
|
SwitchButton,
|
||||||
MoveButton
|
MoveButton,
|
||||||
|
MovePrompt
|
||||||
},
|
},
|
||||||
mounted: function () {
|
mounted: function () {
|
||||||
updateColumnSizes()
|
updateColumnSizes()
|
||||||
|
@ -175,29 +180,40 @@ export default {
|
||||||
},
|
},
|
||||||
showUpload: function () {
|
showUpload: function () {
|
||||||
if (this.req.kind === 'editor') return false
|
if (this.req.kind === 'editor') return false
|
||||||
return this.user.allowNew
|
return $.user.allowNew
|
||||||
},
|
},
|
||||||
showDeleteButton: function () {
|
showDeleteButton: function () {
|
||||||
if (this.req.kind === 'listing') {
|
if (this.req.kind === 'listing') {
|
||||||
if (this.listing.selected.length === 0) {
|
if (this.selected.length === 0) {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
return this.user.allowEdit
|
return $.user.allowEdit
|
||||||
}
|
}
|
||||||
|
|
||||||
return this.user.allowEdit
|
return $.user.allowEdit
|
||||||
},
|
},
|
||||||
showRenameButton: function () {
|
showRenameButton: function () {
|
||||||
if (this.req.kind === 'listing') {
|
if (this.req.kind === 'listing') {
|
||||||
if (this.listing.selected.length === 1) {
|
if (this.selected.length === 1) {
|
||||||
return this.user.allowEdit
|
return $.user.allowEdit
|
||||||
}
|
}
|
||||||
|
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
return this.user.allowEdit
|
return $.user.allowEdit
|
||||||
|
},
|
||||||
|
showMoveButton: function () {
|
||||||
|
if (this.req.kind !== 'listing') {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.selected.length > 0) {
|
||||||
|
return $.user.allowEdit
|
||||||
|
}
|
||||||
|
|
||||||
|
return false
|
||||||
},
|
},
|
||||||
resetPrompts: resetPrompts
|
resetPrompts: resetPrompts
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
<div class="prompt">
|
<div class="prompt">
|
||||||
<h3>Delete files</h3>
|
<h3>Delete files</h3>
|
||||||
<p v-show="req.kind !== 'listing'">Are you sure you want to delete this file/folder?</p>
|
<p v-show="req.kind !== 'listing'">Are you sure you want to delete this file/folder?</p>
|
||||||
<p v-show="req.kind === 'listing'">Are you sure you want to delete {{ listing.selected.length }} file(s)?</p>
|
<p v-show="req.kind === 'listing'">Are you sure you want to delete {{ selected.length }} file(s)?</p>
|
||||||
<div>
|
<div>
|
||||||
<button @click="submit" autofocus>Delete</button>
|
<button @click="submit" autofocus>Delete</button>
|
||||||
<button @click="cancel" class="cancel">Cancel</button>
|
<button @click="cancel" class="cancel">Cancel</button>
|
||||||
|
@ -14,6 +14,8 @@
|
||||||
import webdav from '../webdav'
|
import webdav from '../webdav'
|
||||||
import page from '../page'
|
import page from '../page'
|
||||||
|
|
||||||
|
var $ = window.info
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'delete-prompt',
|
name: 'delete-prompt',
|
||||||
data: function () {
|
data: function () {
|
||||||
|
@ -21,13 +23,13 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
cancel: function (event) {
|
cancel: function (event) {
|
||||||
this.showDelete = false
|
$.showDelete = false
|
||||||
},
|
},
|
||||||
submit: function (event) {
|
submit: function (event) {
|
||||||
this.showDelete = false
|
$.showDelete = false
|
||||||
// buttons.setLoading('delete')
|
// buttons.setLoading('delete')
|
||||||
|
|
||||||
if (this.req.kind !== 'listing') {
|
if ($.req.kind !== 'listing') {
|
||||||
webdav.trash(window.location.pathname)
|
webdav.trash(window.location.pathname)
|
||||||
.then(() => {
|
.then(() => {
|
||||||
// buttons.setDone('delete')
|
// buttons.setDone('delete')
|
||||||
|
@ -41,13 +43,13 @@ export default {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.listing.selected.length === 0) {
|
if ($.selected.length === 0) {
|
||||||
// This shouldn't happen...
|
// This shouldn't happen...
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.listing.selected.length === 1) {
|
if ($.selected.length === 1) {
|
||||||
webdav.trash(this.req.data.items[this.listing.selected[0]].url)
|
webdav.trash($.req.data.items[$.selected[0]].url)
|
||||||
.then(() => {
|
.then(() => {
|
||||||
// buttons.setDone('delete')
|
// buttons.setDone('delete')
|
||||||
page.reload()
|
page.reload()
|
||||||
|
@ -63,8 +65,8 @@ export default {
|
||||||
// More than one item!
|
// More than one item!
|
||||||
let promises = []
|
let promises = []
|
||||||
|
|
||||||
for (let index of this.listing.selected) {
|
for (let index of $.selected) {
|
||||||
promises.push(webdav.trash(this.req.data.items[index].url))
|
promises.push(webdav.trash($.req.data.items[index].url))
|
||||||
}
|
}
|
||||||
|
|
||||||
Promise.all(promises)
|
Promise.all(promises)
|
||||||
|
|
|
@ -2,13 +2,13 @@
|
||||||
<div class="prompt">
|
<div class="prompt">
|
||||||
<h3>File Information</h3>
|
<h3>File Information</h3>
|
||||||
|
|
||||||
<p v-show="listing.selected.length > 1">{{ listing.selected.length }} files selected.</p>
|
<p v-show="selected.length > 1">{{ selected.length }} files selected.</p>
|
||||||
|
|
||||||
<p v-show="listing.selected.length < 2"><strong>Display Name:</strong> {{ name() }}</p>
|
<p v-show="selected.length < 2"><strong>Display Name:</strong> {{ name() }}</p>
|
||||||
<p><strong>Size:</strong> <span id="content_length"></span>{{ humanSize() }}</p>
|
<p><strong>Size:</strong> <span id="content_length"></span>{{ humanSize() }}</p>
|
||||||
<p v-show="listing.selected.length < 2"><strong>Last Modified:</strong> {{ humanTime() }}</p>
|
<p v-show="selected.length < 2"><strong>Last Modified:</strong> {{ humanTime() }}</p>
|
||||||
|
|
||||||
<section v-show="dir() && listing.selected.length === 0">
|
<section v-show="dir() && selected.length === 0">
|
||||||
<p><strong>Number of files:</strong> {{ req.data.numFiles }}</p>
|
<p><strong>Number of files:</strong> {{ req.data.numFiles }}</p>
|
||||||
<p><strong>Number of directories:</strong> {{ req.data.numDirs }}</p>
|
<p><strong>Number of directories:</strong> {{ req.data.numDirs }}</p>
|
||||||
</section>
|
</section>
|
||||||
|
@ -37,43 +37,43 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
humanSize: function () {
|
humanSize: function () {
|
||||||
if (this.listing.selected.length === 0 || this.req.kind !== 'listing') {
|
if (this.selected.length === 0 || this.req.kind !== 'listing') {
|
||||||
return filesize(this.req.data.size)
|
return filesize(this.req.data.size)
|
||||||
}
|
}
|
||||||
|
|
||||||
var sum = 0
|
var sum = 0
|
||||||
|
|
||||||
for (let i = 0; i < this.listing.selected.length; i++) {
|
for (let i = 0; i < this.selected.length; i++) {
|
||||||
sum += this.req.data.items[this.listing.selected[i]].size
|
sum += this.req.data.items[this.selected[i]].size
|
||||||
}
|
}
|
||||||
|
|
||||||
return filesize(sum)
|
return filesize(sum)
|
||||||
},
|
},
|
||||||
humanTime: function () {
|
humanTime: function () {
|
||||||
if (this.listing.selected.length === 0) {
|
if (this.selected.length === 0) {
|
||||||
return moment(this.req.data.modified).fromNow()
|
return moment(this.req.data.modified).fromNow()
|
||||||
}
|
}
|
||||||
|
|
||||||
return moment(this.req.data.items[this.listing.selected[0]]).fromNow()
|
return moment(this.req.data.items[this.selected[0]]).fromNow()
|
||||||
},
|
},
|
||||||
name: function () {
|
name: function () {
|
||||||
if (this.listing.selected.length === 0) {
|
if (this.selected.length === 0) {
|
||||||
return this.req.data.name
|
return this.req.data.name
|
||||||
}
|
}
|
||||||
|
|
||||||
return this.req.data.items[this.listing.selected[0]].name
|
return this.req.data.items[this.selected[0]].name
|
||||||
},
|
},
|
||||||
dir: function () {
|
dir: function () {
|
||||||
if (this.listing.selected.length > 1) {
|
if (this.selected.length > 1) {
|
||||||
// Don't show when multiple selected.
|
// Don't show when multiple selected.
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.listing.selected.length === 0) {
|
if (this.selected.length === 0) {
|
||||||
return this.req.data.isDir
|
return this.req.data.isDir
|
||||||
}
|
}
|
||||||
|
|
||||||
return this.req.data.items[this.listing.selected[0]].isDir
|
return this.req.data.items[this.selected[0]].isDir
|
||||||
},
|
},
|
||||||
checksum: function (event, hash) {
|
checksum: function (event, hash) {
|
||||||
event.preventDefault()
|
event.preventDefault()
|
||||||
|
@ -81,8 +81,8 @@ export default {
|
||||||
let request = new window.XMLHttpRequest()
|
let request = new window.XMLHttpRequest()
|
||||||
let link
|
let link
|
||||||
|
|
||||||
if (this.listing.selected.length) {
|
if (this.selected.length) {
|
||||||
link = this.req.data.items[this.listing.selected[0]].url
|
link = this.req.data.items[this.selected[0]].url
|
||||||
} else {
|
} else {
|
||||||
link = window.location.pathname
|
link = window.location.pathname
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,12 +31,11 @@ import webdav from '../webdav.js'
|
||||||
import page from '../page.js'
|
import page from '../page.js'
|
||||||
import array from '../array.js'
|
import array from '../array.js'
|
||||||
|
|
||||||
|
var $ = window.info
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'item',
|
name: 'item',
|
||||||
props: ['name', 'isDir', 'url', 'type', 'size', 'modified', 'index'],
|
props: ['name', 'isDir', 'url', 'type', 'size', 'modified', 'index'],
|
||||||
data: function () {
|
|
||||||
return window.info.listing
|
|
||||||
},
|
|
||||||
methods: {
|
methods: {
|
||||||
icon: function () {
|
icon: function () {
|
||||||
if (this.isDir) return 'folder'
|
if (this.isDir) return 'folder'
|
||||||
|
@ -99,19 +98,19 @@ export default {
|
||||||
link.setAttribute('aria-selected', false)
|
link.setAttribute('aria-selected', false)
|
||||||
})
|
})
|
||||||
|
|
||||||
this.selected.length = 0
|
$.selected = []
|
||||||
return false
|
return false
|
||||||
},
|
},
|
||||||
click: function (event) {
|
click: function (event) {
|
||||||
if (this.selected.length !== 0) event.preventDefault()
|
if ($.selected.length !== 0) event.preventDefault()
|
||||||
if (this.selected.indexOf(this.index) === -1) {
|
if ($.selected.indexOf(this.index) === -1) {
|
||||||
if (!event.ctrlKey && !this.multiple) this.unselectAll()
|
if (!event.ctrlKey && !$.multiple) this.unselectAll()
|
||||||
|
|
||||||
this.$el.setAttribute('aria-selected', true)
|
this.$el.setAttribute('aria-selected', true)
|
||||||
this.selected.push(this.index)
|
$.selected.push(this.index)
|
||||||
} else {
|
} else {
|
||||||
this.$el.setAttribute('aria-selected', false)
|
this.$el.setAttribute('aria-selected', false)
|
||||||
this.selected = array.remove(this.selected, this.index)
|
$.selected = array.remove($.selected, this.index)
|
||||||
}
|
}
|
||||||
|
|
||||||
// this.handleSelectionChange()
|
// this.handleSelectionChange()
|
||||||
|
|
|
@ -0,0 +1,122 @@
|
||||||
|
<template>
|
||||||
|
<div class="prompt">
|
||||||
|
<h3>Move</h3>
|
||||||
|
<p>Choose new house for your file(s)/folder(s):</p>
|
||||||
|
|
||||||
|
<ul class="file-list">
|
||||||
|
<li @click="select" @dblclick="next" v-for="item in items" :data-url="item.url">{{ item.name }}</li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
<p>Currently navigating on: <code>{{ current }}</code>.</p>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<button class="ok" @click="move">Move</button>
|
||||||
|
<button class="cancel" @click="cancel">Cancel</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import page from '../page'
|
||||||
|
|
||||||
|
var $ = window.info
|
||||||
|
|
||||||
|
export default {
|
||||||
|
name: 'move-prompt',
|
||||||
|
data: function () {
|
||||||
|
return {
|
||||||
|
items: [],
|
||||||
|
current: window.location.pathname
|
||||||
|
}
|
||||||
|
},
|
||||||
|
mounted: function () {
|
||||||
|
if (window.location.pathname !== $.baseURL + '/') {
|
||||||
|
this.items.push({
|
||||||
|
name: '..',
|
||||||
|
url: page.removeLastDir(window.location.pathname) + '/'
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($.req.kind === 'listing') {
|
||||||
|
for (let item of $.req.data.items) {
|
||||||
|
if (!item.isDir) continue
|
||||||
|
|
||||||
|
this.items.push({
|
||||||
|
name: item.name,
|
||||||
|
url: item.url
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
cancel: function (event) {
|
||||||
|
$.showMove = false
|
||||||
|
},
|
||||||
|
move: function (event) {
|
||||||
|
console.log('Move')
|
||||||
|
},
|
||||||
|
next: function (event) {
|
||||||
|
console.log('Next')
|
||||||
|
|
||||||
|
let url = event.currentTarget.dataset.url
|
||||||
|
this.json(url)
|
||||||
|
.then((data) => {
|
||||||
|
this.current = url
|
||||||
|
this.items = []
|
||||||
|
|
||||||
|
if (url !== $.baseURL + '/') {
|
||||||
|
this.items.push({
|
||||||
|
name: '..',
|
||||||
|
url: page.removeLastDir(url) + '/'
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
let req = JSON.parse(data)
|
||||||
|
for (let item of req.data.items) {
|
||||||
|
if (!item.isDir) continue
|
||||||
|
|
||||||
|
this.items.push({
|
||||||
|
name: item.name,
|
||||||
|
url: item.url
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.catch(e => console.log(e))
|
||||||
|
},
|
||||||
|
json: function (url) {
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
let request = new XMLHttpRequest()
|
||||||
|
request.open('GET', url)
|
||||||
|
request.setRequestHeader('Accept', 'application/json')
|
||||||
|
request.onload = () => {
|
||||||
|
if (request.status === 200) {
|
||||||
|
resolve(request.responseText)
|
||||||
|
} else {
|
||||||
|
reject(request.statusText)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
request.onerror = () => reject(request.statusText)
|
||||||
|
request.send()
|
||||||
|
})
|
||||||
|
},
|
||||||
|
select: function (event) {
|
||||||
|
let el = event.currentTarget
|
||||||
|
|
||||||
|
if (el.getAttribute('aria-selected') === 'true') {
|
||||||
|
el.setAttribute('aria-selected', false)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
let el2 = this.$el.querySelector('li[aria-selected=true]')
|
||||||
|
if (el2) {
|
||||||
|
el2.setAttribute('aria-selected', false)
|
||||||
|
}
|
||||||
|
|
||||||
|
el.setAttribute('aria-selected', true)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
|
@ -4,7 +4,7 @@
|
||||||
<p>Insert a new name for <code>{{ oldName() }}</code>:</p>
|
<p>Insert a new name for <code>{{ oldName() }}</code>:</p>
|
||||||
<input autofocus type="text" @keyup.enter="submit" v-model.trim="name">
|
<input autofocus type="text" @keyup.enter="submit" v-model.trim="name">
|
||||||
<div>
|
<div>
|
||||||
<button @click="submit" type="submit" autofocus>Rename</button>
|
<button @click="submit" type="submit">Rename</button>
|
||||||
<button @click="cancel" class="cancel">Cancel</button>
|
<button @click="cancel" class="cancel">Cancel</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -33,12 +33,12 @@ export default {
|
||||||
return $.req.data.name
|
return $.req.data.name
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($.listing.selected.length === 0 || $.listing.selected.length > 1) {
|
if ($.selected.length === 0 || $.selected.length > 1) {
|
||||||
// This shouldn't happen.
|
// This shouldn't happen.
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
return $.req.data.items[$.listing.selected[0]].name
|
return $.req.data.items[$.selected[0]].name
|
||||||
},
|
},
|
||||||
submit: function (event) {
|
submit: function (event) {
|
||||||
let oldLink = ''
|
let oldLink = ''
|
||||||
|
@ -47,7 +47,7 @@ export default {
|
||||||
if ($.req.kind !== 'listing') {
|
if ($.req.kind !== 'listing') {
|
||||||
oldLink = $.req.data.url
|
oldLink = $.req.data.url
|
||||||
} else {
|
} else {
|
||||||
oldLink = $.req.data.items[$.listing.selected[0]].url
|
oldLink = $.req.data.items[$.selected[0]].url
|
||||||
}
|
}
|
||||||
|
|
||||||
newLink = page.removeLastDir(oldLink) + '/' + this.name
|
newLink = page.removeLastDir(oldLink) + '/' + this.name
|
||||||
|
@ -56,6 +56,10 @@ export default {
|
||||||
|
|
||||||
webdav.move(oldLink, newLink)
|
webdav.move(oldLink, newLink)
|
||||||
.then(() => {
|
.then(() => {
|
||||||
|
if ($.req.kind !== 'listing') {
|
||||||
|
page.open(newLink)
|
||||||
|
return
|
||||||
|
}
|
||||||
// TODO: keep selected after reload?
|
// TODO: keep selected after reload?
|
||||||
page.reload()
|
page.reload()
|
||||||
// buttons.setDone('rename')
|
// buttons.setDone('rename')
|
||||||
|
|
|
@ -72,44 +72,44 @@
|
||||||
* PROMPT - MOVE *
|
* PROMPT - MOVE *
|
||||||
* * * * * * * * * * * * * * * */
|
* * * * * * * * * * * * * * * */
|
||||||
|
|
||||||
.prompt .file-list {
|
.file-list {
|
||||||
flex-direction: initial;
|
|
||||||
max-height: 50vh;
|
max-height: 50vh;
|
||||||
overflow: auto;
|
overflow: auto;
|
||||||
}
|
|
||||||
|
|
||||||
.prompt .file-list ul {
|
|
||||||
list-style: none;
|
list-style: none;
|
||||||
margin: 0;
|
margin: 0;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.prompt .file-list ul li {
|
.file-list li {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
user-select: none;
|
user-select: none;
|
||||||
|
border-radius: .2em;
|
||||||
|
padding: .3em;
|
||||||
}
|
}
|
||||||
|
|
||||||
.prompt .file-list ul li[aria-selected=true] {
|
.file-list li[aria-selected=true] {
|
||||||
background: #2196f3 !important;
|
background: #2196f3 !important;
|
||||||
color: #fff !important;
|
color: #fff !important;
|
||||||
transition: .1s ease all;
|
transition: .1s ease all;
|
||||||
}
|
}
|
||||||
|
|
||||||
.prompt .file-list ul li:hover {
|
.file-list li:hover {
|
||||||
background-color: #e9eaeb;
|
background-color: #e9eaeb;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
|
|
||||||
.prompt .file-list ul li:before {
|
.file-list li:before {
|
||||||
content: "folder";
|
content: "folder";
|
||||||
color: #6f6f6f;
|
color: #6f6f6f;
|
||||||
vertical-align: middle;
|
vertical-align: middle;
|
||||||
padding: 0 .25em;
|
line-height: 1.4;
|
||||||
line-height: 2em;
|
font-family: 'Material Icons';
|
||||||
|
font-size: 1.75em;
|
||||||
|
margin-right: .25em;
|
||||||
}
|
}
|
||||||
|
|
||||||
.prompt .file-list ul li[aria-selected=true]:before {
|
.file-list li[aria-selected=true]:before {
|
||||||
color: white;
|
color: white;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,8 +17,8 @@ window.addEventListener('popstate', (event) => {
|
||||||
event.stopPropagation()
|
event.stopPropagation()
|
||||||
|
|
||||||
$.req.kind = ''
|
$.req.kind = ''
|
||||||
$.listing.selected.length = 0
|
$.selected = []
|
||||||
$.listing.selected.multiple = false
|
$.multiple = false
|
||||||
// TODO: find a better way to do this. Maybe on app.vue?
|
// TODO: find a better way to do this. Maybe on app.vue?
|
||||||
window.info.showHelp = false
|
window.info.showHelp = false
|
||||||
window.info.showInfo = false
|
window.info.showInfo = false
|
||||||
|
|
|
@ -2,8 +2,8 @@ var $ = window.info
|
||||||
|
|
||||||
function open (url, history) {
|
function open (url, history) {
|
||||||
// Reset info
|
// Reset info
|
||||||
$.listing.selected.length = 0
|
$.selected = []
|
||||||
$.listing.selected.multiple = false
|
$.multiple = false
|
||||||
$.req.kind = ''
|
$.req.kind = ''
|
||||||
|
|
||||||
let request = new window.XMLHttpRequest()
|
let request = new window.XMLHttpRequest()
|
||||||
|
|
2
page.go
2
page.go
|
@ -147,7 +147,7 @@ func htmlError(w http.ResponseWriter, code int, err error) (int, error) {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return http.StatusInternalServerError, err
|
return http.StatusInternalServerError, err
|
||||||
}
|
}
|
||||||
return http.StatusOK, nil
|
return 0, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
const errTemplate = `<!DOCTYPE html>
|
const errTemplate = `<!DOCTYPE html>
|
||||||
|
|
Loading…
Reference in New Issue