blockbench/js/web.js

113 lines
2.7 KiB
JavaScript
Raw Normal View History

2017-10-26 19:00:52 +02:00
(function() {
2018-10-17 19:50:25 +02:00
$.getScript("lib/file_saver.js");
2020-07-16 09:32:59 +02:00
$.getScript('https://rawgit.com/nodeca/pako/master/dist/pako.min.js', function() {
2019-01-09 15:54:35 +01:00
window.zlib = pako
})
2017-10-26 19:00:52 +02:00
})()
2019-12-15 20:04:31 +01:00
function initializeWebApp() {
2019-07-17 18:02:07 +02:00
$(document.body).on('click', 'a[href]', (event) => {
event.preventDefault();
window.open(event.target.href, '_blank');
2018-10-17 19:50:25 +02:00
});
2019-07-17 18:02:07 +02:00
if (!Blockbench.isMobile) {
$('#web_download_button').show()
2017-10-26 19:00:52 +02:00
}
if (Blockbench.browser == 'firefox') {
document.body.style.imageRendering = 'crisp-edges'
}
}
function loadInfoFromURL() {
2019-07-17 18:02:07 +02:00
if (location.hash.substr(1, 8) == 'session=') {
EditSession.dialog()
$('#edit_session_token').val(location.hash.substr(9))
2018-12-27 14:03:04 +01:00
}
2020-03-04 20:56:17 +01:00
if (location.hash.substr(1, 5) == 'load=') {
$.getJSON('https://blockbench.net/api/rawtext.php?url='+location.hash.substr(6), (model) => {
if (showSaveDialog()) {
resetProject();
Codecs.project.load(model, {path: ''});
}
})
} else if (location.hash.substr(1, 5) == 'pbin=') {
$.getJSON('https://blockbench.net/api/rawtext.php?url='+'https://pastebin.com/raw/'+location.hash.substr(6), (model) => {
if (showSaveDialog()) {
resetProject();
Codecs.project.load(model, {path: ''});
}
})
}
2019-12-15 20:04:31 +01:00
}
2017-10-26 19:00:52 +02:00
//Misc
window.onbeforeunload = function() {
2018-03-28 20:48:11 +02:00
if (Prop.project_saved === false && elements.length > 0) {
2019-07-17 18:02:07 +02:00
return 'Unsaved Changes';
2019-04-12 22:39:53 +02:00
} else {
2020-07-16 09:32:59 +02:00
Blockbench.dispatchEvent('before_closing')
2019-04-12 22:39:53 +02:00
EditSession.quit()
2017-10-26 19:00:52 +02:00
}
}
function showSaveDialog(close) {
2018-10-17 19:50:25 +02:00
var unsaved_textures = 0;
textures.forEach(function(t) {
if (!t.saved) {
unsaved_textures++;
}
})
if ((Prop.project_saved === false && elements.length > 0) || unsaved_textures) {
var answer = confirm(tl('message.close_warning.web'))
2019-12-15 20:04:31 +01:00
return answer;
2018-10-17 19:50:25 +02:00
} else {
return true;
}
2019-07-17 18:02:07 +02:00
}
function setupMobilePanelSelector() {
2019-07-17 18:02:07 +02:00
if (Blockbench.isMobile) {
Interface.PanelSelectorVue = new Vue({
el: '#panel_selector_bar',
data: {
all_panels: Interface.Panels,
selected: null,
},
computed: {
panels() {
let arr = [];
arr.push({
icon: '3d_rotation',
name: tl('data.preview'),
id: 'preview'
})
for (var id in this.all_panels) {
let panel = this.all_panels[id];
if (Condition(panel.condition)) {
arr.push(panel)
}
2019-12-15 20:04:31 +01:00
}
return arr;
}
},
methods: {
select(panel) {
this.selected = panel && panel.id;
let overlay = $('#mobile_panel_overlay');
$('#left_bar').append(overlay.children());
if (panel instanceof Panel) {
overlay.append(panel.node);
overlay.show();
2020-10-26 15:27:07 +01:00
$(panel.node).show();
if (panel.onResize) panel.onResize();
2019-12-15 20:04:31 +01:00
} else {
overlay.hide();
2019-12-15 20:04:31 +01:00
}
}
}
})
2019-07-17 18:02:07 +02:00
}
}