mirror of
https://github.com/whscullin/apple1js.git
synced 2024-11-22 04:33:34 +00:00
Add drag and drop support.
This commit is contained in:
parent
ebe3821b0f
commit
7a3cff10ec
@ -58,7 +58,9 @@ var tapes = {};
|
||||
|
||||
<!-- Web FE -->
|
||||
</head>
|
||||
<body>
|
||||
<body ondragover="Apple1.handleDragOver(event)"
|
||||
ondrop="Apple1.handleDrop(event)"
|
||||
ondragend="Apple1.handleDragEnd(event)">
|
||||
<div style="margin: auto; width: 604px">
|
||||
<h1 style="font-size: 24px" class="motter">Apple 1js</h1>
|
||||
<h2 id="subtitle">An Apple 1 Emulator in JavaScript</h2>
|
||||
|
34
js/apple1.js
34
js/apple1.js
@ -80,9 +80,9 @@ if (typeof window.webkitAudioContext !== 'undefined') {
|
||||
context = new window.AudioContext();
|
||||
}
|
||||
|
||||
export function doLoadLocal() {
|
||||
export function doLoadLocal(files) {
|
||||
context.resume();
|
||||
var files = document.querySelector('#local_file').files;
|
||||
files = files || document.querySelector('#local_file').files;
|
||||
if (files.length == 1) {
|
||||
var file = files[0];
|
||||
var fileReader = new FileReader();
|
||||
@ -106,8 +106,8 @@ export function doLoadLocal() {
|
||||
aci.buffer = buf;
|
||||
MicroModal.close('local-modal');
|
||||
},
|
||||
function(error) {
|
||||
window.alert(error.message);
|
||||
function() {
|
||||
window.alert('Unable to read tape file: ' + file.name);
|
||||
}
|
||||
);
|
||||
};
|
||||
@ -352,6 +352,32 @@ export function doLoadText() {
|
||||
MicroModal.close('input-modal');
|
||||
}
|
||||
|
||||
export function handleDragOver(event) {
|
||||
event.preventDefault();
|
||||
event.dataTransfer.dropEffect = 'copy';
|
||||
}
|
||||
|
||||
export function handleDrop(event) {
|
||||
event.preventDefault();
|
||||
event.stopPropagation();
|
||||
|
||||
var dt = event.dataTransfer;
|
||||
if (dt.files.length > 0) {
|
||||
doLoadLocal(dt.files);
|
||||
}
|
||||
}
|
||||
|
||||
export function handleDragEnd(event) {
|
||||
var dt = event.dataTransfer;
|
||||
if (dt.items) {
|
||||
for (var i = 0; i < dt.items.length; i++) {
|
||||
dt.items.remove(i);
|
||||
}
|
||||
} else {
|
||||
event.dataTransfer.clearData();
|
||||
}
|
||||
}
|
||||
|
||||
MicroModal.init();
|
||||
|
||||
document.addEventListener('DOMContentLoaded', function() {
|
||||
|
Loading…
Reference in New Issue
Block a user