tools/save.js
function saveTool(toolbar) {
"use strict";
function toDataURL(bytes) {
return "data:application/octet-stream;base64," + btoa(String.fromCharCode.apply(null, bytes));
}
function getHighestRow(input) {
var inputIndex, highest;
highest = 26;
for (inputIndex = 0; inputIndex < input.length; inputIndex += 3) {
if (input[inputIndex]) {
highest = Math.max(Math.ceil(inputIndex / 240), highest);
}
}
return highest;
}
function toBinFormat(input) {
var output, inputIndex, outputIndex, highest, end, flags;
highest = getHighestRow(input);
output = new Uint8Array((input.length / 3 * 2) + 11);
flags = toolbar.editor.noblink ? 8 : 0;
output.set(new Uint8Array([88, 66, 73, 78, 26, 80, 0, highest, 0, 16, flags]), 0);
for (inputIndex = 0, outputIndex = 11, end = highest * 80 * 3; inputIndex < end; inputIndex += 3, outputIndex += 2) {
output[outputIndex] = input[inputIndex];
output[outputIndex + 1] = input[inputIndex + 1] + (input[inputIndex + 2] << 4);
}
return output;
}
// function toANSFormat(input) {
// var highest, inputIndex, end, charCode, fg, bg, bold, blink, currentFg, currentBg, currentBold, currentBlink, attribs, attribIndex, output;
//
// function ansiColor(binColor) {
// switch (binColor) {
// case 1:
// return 4;
// case 3:
// return 6;
// case 4:
// return 1;
// case 6:
// return 3;
// default:
// return binColor;
// }
// }
//
// highest = getHighestRow(input);
// output = [27, 91, 48, 109];
// for (inputIndex = 0, end = highest * 80 * 3, currentFg = 7, currentBg = 0, currentBold = false, currentBlink = false; inputIndex < end; inputIndex += 3) {
// attribs = [];
// charCode = input[inputIndex];
// fg = input[inputIndex + 1];
// bg = input[inputIndex + 2];
// if (fg > 7) {
// bold = true;
// fg = fg - 8;
// } else {
// bold = false;
// }
// if (bg > 7) {
// blink = true;
// bg = bg - 8;
// } else {
// blink = false;
// }
// if ((currentBold && !bold) || (currentBlink && !blink)) {
// attribs.push([48]);
// currentFg = 7;
// currentBg = 0;
// currentBold = false;
// currentBlink = false;
// }
// if (bold && !currentBold) {
// attribs.push([49]);
// currentBold = true;
// }
// if (blink && !currentBlink) {
// attribs.push([53]);
// currentBlink = true;
// }
// if (fg !== currentFg) {
// attribs.push([51, 48 + ansiColor(fg)]);
// currentFg = fg;
// }
// if (bg !== currentBg) {
// attribs.push([52, 48 + ansiColor(bg)]);
// currentBg = bg;
// }
// if (attribs.length) {
// output.push(27, 91);
// for (attribIndex = 0; attribIndex < attribs.length; ++attribIndex) {
// output = output.concat(attribs[attribIndex]);
// if (attribIndex !== attribs.length - 1) {
// output.push(59);
// } else {
// output.push(109);
// }
// }
// }
// output.push(charCode);
// }
// return new Uint8Array(output);
// }
function init() {
var modal;
function dismiss() {
modal.remove();
toolbar.editor.startListening();
toolbar.startListening();
}
modal = modalBox();
// modal.addButton("download", {"textContent": "Download ansiedit.ans", "href": toDataURL(toANSFormat(toolbar.editor.image)), "onclick": dismiss, "download": "ansiedit.ans"});
modal.addButton("download", {"textContent": "Download ansiedit.xb", "href": toDataURL(toBinFormat(toolbar.editor.image)), "onclick": dismiss, "download": "ansiedit.xb"});
modal.addButton("cancel", {"textContent": "Cancel", "href": "#", "onclick": function (evt) {
evt.preventDefault();
dismiss();
}});
toolbar.editor.stopListening();
toolbar.stopListening();
modal.init();
return false;
}
function toString() {
return "Save";
}
return {
"init": init,
"toString": toString,
"uid": "save"
};
}
AnsiEditController.addTool(saveTool);