summaryrefslogtreecommitdiff
path: root/client/components/Browser/Folder/Folder.jsx
diff options
context:
space:
mode:
Diffstat (limited to 'client/components/Browser/Folder/Folder.jsx')
-rw-r--r--client/components/Browser/Folder/Folder.jsx79
1 files changed, 0 insertions, 79 deletions
diff --git a/client/components/Browser/Folder/Folder.jsx b/client/components/Browser/Folder/Folder.jsx
deleted file mode 100644
index a3588f1..0000000
--- a/client/components/Browser/Folder/Folder.jsx
+++ /dev/null
@@ -1,79 +0,0 @@
-import { h, Component } from 'preact'
-
-import client from '../../../client.js'
-
-import FileUploadButton from './FileUploadButton.jsx'
-import TaskContentLink from '../../../containers/taskContentLink.js'
-import TaskStyleLink from '../../../containers/taskStyleLink.js'
-
-export default class Folder extends Component {
- constructor(props) {
- super()
- this.state = {
- files: props.folder.files || [],
- }
- this.addFiles = this.addFiles.bind(this)
- if (! props.folder.files) {
- client.file.index({ folder_id: props.folder.id }).then( files => this.setState({ files }) )
- }
- this.audio = document.createElement('audio')
- }
- addFiles(newFiles) {
- if (! newFiles) return
- const files = this.state.files.concat(newFiles).sort( (a,b) => { return b.id - a.id } )
- this.setState({ files })
- }
- handleClick(file) {
- if (file.type === 'audio') {
- this.audio.setAttribute('src', mp3path(file))
- this.audio.play()
- document.body.style.backgroundImage = 'url(' + pngpath(file) + ')'
- }
- }
- render() {
- const files = (this.state.files).map(toFilenamePair).sort(sortByFilename).map(fromPair).map( (file, i) => {
- if (! file) return
- return (
- <div key={i}>
- <span class='name' onClick={() => this.handleClick(file)}>{file.name}</span>
- <span class='mime'>{file.mime}</span>
- <span class='actions'>
- <TaskContentLink file={file}> content </TaskContentLink>
- <TaskStyleLink file={file}> style </TaskStyleLink>
- </span>
- </div>
- )
- })
- return (
- <div class='window'>
- <div class='heading'>
- <b>{this.props.folder.name}</b>
- <div class='buttons'>
- <FileUploadButton folder={this.props.folder} addFiles={this.addFiles} />
- <button onClick={this.props.onClose}>&times;</button>
- </div>
- </div>
- <div class='list'>
- {files}
- </div>
- </div>
- )
- }
-}
-
-function toFilenamePair (file) { return [file.name.toLowerCase(), file] }
-function sortByFilename (a,b) { return a[0] < b[0] ? -1 : a[0] == b[0] ? 0 : 1 }
-function fromPair (pair) { return pair[1] }
-
-function filepath (file) {
- return '/data/' + file.folder_id + '/' + encodeURIComponent(file.name)
-}
-function mp3path (file) {
- if (file.mime !== 'audio/mp3') {
- return filepath(file) + '.mp3'
- }
- return filepath(file)
-}
-function pngpath (file) {
- return filepath(file) + '.png'
-} \ No newline at end of file