"use strict"; class File_Upload extends Component { on_ready() { const $input = this.$sid('file_input'); const $drop_zone = this.$sid('drop_zone'); if (this.args.accept) { $input.attr('accept', this.args.accept); } if (this.args.multiple) { $input.attr('multiple', true); } // Click to upload $drop_zone.on('click', () => { $input.click(); }); // File selected $input.on('change', e => { const files = e.target.files; if (files.length > 0) { this.handle_files(files); } }); // Drag and drop $drop_zone.on('dragover', e => { e.preventDefault(); e.stopPropagation(); $drop_zone.addClass('border-primary bg-light'); }); $drop_zone.on('dragleave', e => { e.preventDefault(); e.stopPropagation(); $drop_zone.removeClass('border-primary bg-light'); }); $drop_zone.on('drop', e => { e.preventDefault(); e.stopPropagation(); $drop_zone.removeClass('border-primary bg-light'); const files = e.originalEvent.dataTransfer.files; if (files.length > 0) { this.handle_files(files); } }); // Remove button this.$sid('remove_btn').on('click', e => { e.stopPropagation(); this.clear(); }); } handle_files(files) { const file = files[0]; // Single file for now // Validate file size if (this.args.max_size_bytes && file.size > this.args.max_size_bytes) { alert(`File is too large. Max size is ${this.format_size(this.args.max_size_bytes)}`); return; } this.selected_file = file; // Show file info this.$sid('placeholder').hide(); this.$sid('file_info').show(); this.$sid('file_name').text(file.name); this.$sid('file_size').text(this.format_size(file.size)); // Auto-upload if endpoint provided if (this.args.upload_url) { this.upload(); } // Trigger callback if (this.args.on_select) { this.args.on_select(file); } } async upload() { if (!this.selected_file || !this.args.upload_url) return; // Show progress this.$sid('file_info').hide(); this.$sid('progress').show(); const form_data = new FormData(); form_data.append('file', this.selected_file); try { const response = await fetch(this.args.upload_url, { method: 'POST', body: form_data }); const result = await response.json(); // Hide progress this.$sid('progress').hide(); this.$sid('file_info').show(); if (this.args.on_upload) { this.args.on_upload(result); } } catch (error) { alert('Upload failed: ' + error.message); this.$sid('progress').hide(); this.$sid('placeholder').show(); } } clear() { this.selected_file = null; this.$sid('file_input').val(''); this.$sid('file_info').hide(); this.$sid('progress').hide(); this.$sid('placeholder').show(); if (this.args.on_clear) { this.args.on_clear(); } } get_file() { return this.selected_file; } format_size(bytes) { if (bytes < 1024) return bytes + ' B'; if (bytes < 1024 * 1024) return (bytes / 1024).toFixed(1) + ' KB'; return (bytes / (1024 * 1024)).toFixed(1) + ' MB'; } } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["File_Upload","Jqhtml_Component","on_ready","$input","$id","$drop_zone","args","accept","attr","multiple","on","click","e","files","target","length","handle_files","preventDefault","stopPropagation","addClass","removeClass","originalEvent","dataTransfer","clear","file","max_size_bytes","size","alert","format_size","selected_file","hide","show","text","name","upload_url","upload","on_select","form_data","FormData","append","response","fetch","method","body","result","json","on_upload","error","message","val","on_clear","get_file","bytes","toFixed"],"sources":["rsx/theme/components/_archived/unfinished/File_Upload.js"],"sourcesContent":["class File_Upload extends Jqhtml_Component {\n    on_ready() {\n        const $input = this.$id('file_input');\n        const $drop_zone = this.$id('drop_zone');\n\n        if (this.args.accept) {\n            $input.attr('accept', this.args.accept);\n        }\n\n        if (this.args.multiple) {\n            $input.attr('multiple', true);\n        }\n\n        // Click to upload\n        $drop_zone.on('click', () => {\n            $input.click();\n        });\n\n        // File selected\n        $input.on('change', (e) => {\n            const files = e.target.files;\n            if (files.length > 0) {\n                this.handle_files(files);\n            }\n        });\n\n        // Drag and drop\n        $drop_zone.on('dragover', (e) => {\n            e.preventDefault();\n            e.stopPropagation();\n            $drop_zone.addClass('border-primary bg-light');\n        });\n\n        $drop_zone.on('dragleave', (e) => {\n            e.preventDefault();\n            e.stopPropagation();\n            $drop_zone.removeClass('border-primary bg-light');\n        });\n\n        $drop_zone.on('drop', (e) => {\n            e.preventDefault();\n            e.stopPropagation();\n            $drop_zone.removeClass('border-primary bg-light');\n\n            const files = e.originalEvent.dataTransfer.files;\n            if (files.length > 0) {\n                this.handle_files(files);\n            }\n        });\n\n        // Remove button\n        this.$id('remove_btn').on('click', (e) => {\n            e.stopPropagation();\n            this.clear();\n        });\n    }\n\n    handle_files(files) {\n        const file = files[0]; // Single file for now\n\n        // Validate file size\n        if (this.args.max_size_bytes && file.size > this.args.max_size_bytes) {\n            alert(`File is too large. Max size is ${this.format_size(this.args.max_size_bytes)}`);\n            return;\n        }\n\n        this.selected_file = file;\n\n        // Show file info\n        this.$id('placeholder').hide();\n        this.$id('file_info').show();\n        this.$id('file_name').text(file.name);\n        this.$id('file_size').text(this.format_size(file.size));\n\n        // Auto-upload if endpoint provided\n        if (this.args.upload_url) {\n            this.upload();\n        }\n\n        // Trigger callback\n        if (this.args.on_select) {\n            this.args.on_select(file);\n        }\n    }\n\n    async upload() {\n        if (!this.selected_file || !this.args.upload_url) return;\n\n        // Show progress\n        this.$id('file_info').hide();\n        this.$id('progress').show();\n\n        const form_data = new FormData();\n        form_data.append('file', this.selected_file);\n\n        try {\n            const response = await fetch(this.args.upload_url, {\n                method: 'POST',\n                body: form_data\n            });\n\n            const result = await response.json();\n\n            // Hide progress\n            this.$id('progress').hide();\n            this.$id('file_info').show();\n\n            if (this.args.on_upload) {\n                this.args.on_upload(result);\n            }\n        } catch (error) {\n            alert('Upload failed: ' + error.message);\n            this.$id('progress').hide();\n            this.$id('placeholder').show();\n        }\n    }\n\n    clear() {\n        this.selected_file = null;\n        this.$id('file_input').val('');\n        this.$id('file_info').hide();\n        this.$id('progress').hide();\n        this.$id('placeholder').show();\n\n        if (this.args.on_clear) {\n            this.args.on_clear();\n        }\n    }\n\n    get_file() {\n        return this.selected_file;\n    }\n\n    format_size(bytes) {\n        if (bytes < 1024) return bytes + ' B';\n        if (bytes < 1024 * 1024) return (bytes / 1024).toFixed(1) + ' KB';\n        return (bytes / (1024 * 1024)).toFixed(1) + ' MB';\n    }\n}\n"],"mappings":"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","ignoreList":[]}