spee.ch/views/index.handlebars

132 lines
5.5 KiB
Handlebars
Raw Normal View History

<script src="/assets/js/generalFunctions.js"></script>
2017-09-29 11:59:53 -07:00
{{> topBar}}
2017-10-02 11:47:12 -07:00
<div class="row row--full-height">
<div id="publish-dropzone-wrapper">
<div id="publish-dropzone" class="align-content-center" ondrop="drop_handler(event);" ondragover="dragover_handler(event);" ondragend="dragend_handler(event)">
<div id="publish-dropzone-instructions">
2017-10-03 10:05:09 -07:00
<div class="row">
<p>Drag & drop image or video here</p>
<p>OR</p>
<form>
<label class="input-file-label" for="siofu_input">CHOOSE FILE</label>
<input class=" input-file" type="file" id="siofu_input" name="siofu_input" accept="video/*,image/*" onchange="previewAndStageFile(event.target.files[0])" enctype="multipart/form-data"/>
</form>
</div>
<div class="info-message info-message--failure" id="input-error-file-selection" hidden="true"></div>
2017-10-02 11:47:12 -07:00
</div>
</div>
2017-09-29 14:24:53 -07:00
</div>
2017-10-02 11:47:12 -07:00
<div id="publish-form-wrapper" hidden="true">
2017-10-02 17:36:25 -07:00
<div class="column column--10">
<!-- title input -->
<input type="text" id="publish-title" class="input-text input-text--large input-text--full-width" placeholder="Title (optional)">
2017-10-02 17:36:25 -07:00
</div>
<div class="column column--5 align-content-top" >
<!-- preview -->
<div class="row">
<div id="asset-preview-holder" class="asset-show"></div>
</div>
<!-- description input -->
<textarea rows="3" id="publish-description" class="textarea textarea--large textarea--full-width" placeholder="Description (optional)"></textarea>
2017-10-02 17:36:25 -07:00
</div><div class="column column--5 align-content-top">
<div id="publish-status" class="row" hidden="true"></div>
<div id="publish-progress-bar" class="row" hidden="true"></div>
2017-09-29 15:56:13 -07:00
<div id="publish-active-area">
{{> publishForm-Channel}}
{{> publishForm-Url}}
{{> publishForm-Details}}
{{> publishForm-Submit}}
</div>
2017-09-29 14:24:53 -07:00
</div>
</div>
2017-06-09 16:46:57 -07:00
2017-10-02 11:47:12 -07:00
2017-06-09 16:46:57 -07:00
<script src="/socket.io/socket.io.js"></script>
<script src="/siofu/client.js"></script>
<script src="/assets/js/validationFunctions.js"></script>
2017-09-20 09:49:05 -07:00
<script src="/assets/js/publishFileFunctions.js"></script>
<script typ="text/javascript">
2017-09-29 15:56:13 -07:00
var socket = io();
var uploader = new SocketIOFileUpload(socket);
var stagedFiles = null;
2017-10-03 10:05:09 -07:00
2017-09-29 15:56:13 -07:00
/* drop zone functions */
function drop_handler(ev) {
ev.preventDefault();
// if dropped items aren't files, reject them
var dt = ev.dataTransfer;
if (dt.items) {
if (dt.items[0].kind == 'file') {
var droppedFile = dt.items[0].getAsFile();
previewAndStageFile(droppedFile);
}
}
}
function dragover_handler(ev) {
ev.preventDefault();
}
function dragend_handler(ev) {
var dt = ev.dataTransfer;
if (dt.items) {
for (var i = 0; i < dt.items.length; i++) {
dt.items.remove(i);
}
} else {
ev.dataTransfer.clearData();
}
}
2017-10-03 10:05:09 -07:00
/* socketio-file-upload listeners */
2017-09-29 15:56:13 -07:00
function updatePublishStatus(msg){
document.getElementById('publish-status').innerHTML = msg;
}
uploader.addEventListener('start', function(event){
2017-07-22 18:01:17 -07:00
var name = document.getElementById('claim-name-input').value;
2017-08-20 16:56:37 -07:00
var title = document.getElementById('publish-title').value;
var description = document.getElementById('publish-description').value;
var license = document.getElementById('publish-license').value;
var nsfw = document.getElementById('publish-nsfw').checked;
2017-09-19 15:39:54 -07:00
var channel = document.getElementById('channel-name-select').value;
event.file.meta.name = name;
2017-08-20 16:56:37 -07:00
event.file.meta.title = title;
event.file.meta.description = description;
event.file.meta.license = license;
event.file.meta.nsfw = nsfw;
event.file.meta.type = stagedFiles[0].type;
2017-09-19 15:39:54 -07:00
event.file.meta.channel = channel;
2017-09-29 15:56:13 -07:00
// hide the submit area
document.getElementById('publish-active-area').hidden = true;
// show the progress status and animation
document.getElementById('publish-status').hidden = false;
document.getElementById('publish-progress-bar').hidden = false;
createProgressBar(document.getElementById('publish-progress-bar'), 12);
// google analytics
ga('send', {
hitType: 'event',
eventCategory: 'publish',
eventAction: name
});
});
uploader.addEventListener('progress', function(event){
var percent = event.bytesLoaded / event.file.size * 100;
updatePublishStatus('File is ' + percent.toFixed(2) + '% loaded to the server');
});
/* socket.io message listeners */
socket.on('publish-status', function(msg){
updatePublishStatus(msg);
});
socket.on('publish-failure', function(msg){
2017-09-29 15:56:13 -07:00
updatePublishStatus('<p> --(✖╭╮✖)→ </p><p>' + JSON.stringify(msg) + '</p><strong>For help, post the above error text in the #speech channel on the <a href="https://lbry.slack.com/" target="_blank">lbry slack</a></strong>');
document.getElementById('publish-progress-bar').hidden = true;
});
socket.on('publish-complete', function(msg){
2017-09-19 15:39:54 -07:00
var showUrl = msg.result.claim_id + "/" + msg.name;
2017-09-29 15:56:13 -07:00
// update status
updatePublishStatus('<p>Your publish is complete! You are being redirected to it now.</p><p><a target="_blank" href="' + showUrl + '">If you do not get redirected, click here.</a></p>');
document.getElementById('publish-progress-bar').hidden = true;
// redirect the user
window.location.href = showUrl;
});
</script>