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.jsx77
1 files changed, 77 insertions, 0 deletions
diff --git a/client/components/Browser/Folder/Folder.jsx b/client/components/Browser/Folder/Folder.jsx
new file mode 100644
index 0000000..3ed3ddb
--- /dev/null
+++ b/client/components/Browser/Folder/Folder.jsx
@@ -0,0 +1,77 @@
+import { h, Component } from 'preact'
+
+import client from '../../../client.js'
+
+import FileUploadButton from './FileUploadButton.jsx'
+
+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'>
+ <span onClick={() => this.props.setContent(file)}>content &gt;</span>
+ <span onClick={() => this.props.setStyle(file)}>style &gt;</span>
+ </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