mirror of
https://github.com/lospec/pixel-editor.git
synced 2023-08-10 21:12:51 +03:00
Removed a few dependencies, refactored pixel-editor.js
This commit is contained in:
parent
21dd47c2b0
commit
05beab6929
@ -50,7 +50,6 @@ const ColorPicker = (() => {
|
|||||||
init();
|
init();
|
||||||
|
|
||||||
function init() {
|
function init() {
|
||||||
// TODO: BIND EVENTS
|
|
||||||
// Appending the palette styles
|
// Appending the palette styles
|
||||||
document.getElementsByTagName("head")[0].appendChild(styleElement);
|
document.getElementsByTagName("head")[0].appendChild(styleElement);
|
||||||
|
|
||||||
@ -302,7 +301,6 @@ const ColorPicker = (() => {
|
|||||||
sliders[2].getElementsByTagName("label")[0].innerHTML = 'L';
|
sliders[2].getElementsByTagName("label")[0].innerHTML = 'L';
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
console.log("wtf select a decent picker mode");
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -447,9 +445,7 @@ const ColorPicker = (() => {
|
|||||||
currPickerIconPos[0][1] = miniPickerCanvas.height - yPos;
|
currPickerIconPos[0][1] = miniPickerCanvas.height - yPos;
|
||||||
|
|
||||||
if (currPickerIconPos[0][1] >= 92)
|
if (currPickerIconPos[0][1] >= 92)
|
||||||
{
|
|
||||||
currPickerIconPos[0][1] = 91.999;
|
currPickerIconPos[0][1] = 91.999;
|
||||||
}
|
|
||||||
|
|
||||||
activePickerIcon.style.left = '' + xPos + 'px';
|
activePickerIcon.style.left = '' + xPos + 'px';
|
||||||
activePickerIcon.style.top = '' + (miniPickerCanvas.height - yPos) + 'px';
|
activePickerIcon.style.top = '' + (miniPickerCanvas.height - yPos) + 'px';
|
||||||
@ -467,8 +463,6 @@ const ColorPicker = (() => {
|
|||||||
let newHsv = currColor.hsv;
|
let newHsv = currColor.hsv;
|
||||||
let newHex;
|
let newHex;
|
||||||
|
|
||||||
console.log("Hex: " + currColor.hex);
|
|
||||||
|
|
||||||
// Adding slider value to value
|
// Adding slider value to value
|
||||||
newHsv = new Color("hsv", newHsv.h, newHsv.s, parseInt(event.target.value));
|
newHsv = new Color("hsv", newHsv.h, newHsv.s, parseInt(event.target.value));
|
||||||
// Updating hex
|
// Updating hex
|
||||||
@ -575,7 +569,6 @@ const ColorPicker = (() => {
|
|||||||
case 'analog':
|
case 'analog':
|
||||||
createIcon();
|
createIcon();
|
||||||
createIcon();
|
createIcon();
|
||||||
|
|
||||||
nHexContainers = 2;
|
nHexContainers = 2;
|
||||||
break;
|
break;
|
||||||
case 'cmpt':
|
case 'cmpt':
|
||||||
@ -594,13 +587,11 @@ const ColorPicker = (() => {
|
|||||||
nHexContainers = 2;
|
nHexContainers = 2;
|
||||||
break;
|
break;
|
||||||
case 'tetra':
|
case 'tetra':
|
||||||
for (let i=0; i<3; i++) {
|
for (let i=0; i<3; i++)
|
||||||
createIcon();
|
createIcon();
|
||||||
}
|
|
||||||
nHexContainers = 3;
|
nHexContainers = 3;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
console.log("How did you select the " + currentPickingMode + ", hackerman?");
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -632,7 +623,6 @@ const ColorPicker = (() => {
|
|||||||
let currentColourHsv = new Color("hex", currentColorHex).hsv;
|
let currentColourHsv = new Color("hex", currentColorHex).hsv;
|
||||||
let newColourHsv;
|
let newColourHsv;
|
||||||
let newColourHexes = ['', '', ''];
|
let newColourHexes = ['', '', ''];
|
||||||
let tmpRgb;
|
|
||||||
|
|
||||||
switch (currentPickingMode)
|
switch (currentPickingMode)
|
||||||
{
|
{
|
||||||
|
@ -42,7 +42,7 @@ const Dialogue = (() => {
|
|||||||
document.getElementById(dialogueName).style.display = 'block';
|
document.getElementById(dialogueName).style.display = 'block';
|
||||||
|
|
||||||
// If I'm opening the palette window, I initialize the colour picker
|
// If I'm opening the palette window, I initialize the colour picker
|
||||||
if (dialogueName == 'palette-block' && Startup.documentCreated()) {
|
if (dialogueName == 'palette-block' && EditorState.documentCreated()) {
|
||||||
ColorPicker.init();
|
ColorPicker.init();
|
||||||
PaletteBlock.init();
|
PaletteBlock.init();
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
const EditorState = (() => {
|
const EditorState = (() => {
|
||||||
let pixelEditorMode = "Basic";
|
let pixelEditorMode = "Basic";
|
||||||
|
let firstFile = true;
|
||||||
|
|
||||||
Events.on('click', 'switch-editor-mode-splash', chooseMode);
|
Events.on('click', 'switch-editor-mode-splash', chooseMode);
|
||||||
Events.on('click', 'switch-mode-button', toggleMode);
|
Events.on('click', 'switch-mode-button', toggleMode);
|
||||||
@ -11,35 +12,16 @@ const EditorState = (() => {
|
|||||||
function switchMode(newMode) {
|
function switchMode(newMode) {
|
||||||
//switch to advanced mode
|
//switch to advanced mode
|
||||||
if (newMode == 'Advanced') {
|
if (newMode == 'Advanced') {
|
||||||
// Show the layer menus
|
Events.emit("switchedToAdvanced");
|
||||||
LayerList.getLayerListEntries().style.display = "inline-block";
|
|
||||||
document.getElementById('layer-button').style.display = 'inline-block';
|
|
||||||
// Hide the palette menu
|
// Hide the palette menu
|
||||||
document.getElementById('colors-menu').style.right = '200px'
|
document.getElementById('colors-menu').style.right = '200px'
|
||||||
|
|
||||||
pixelEditorMode = 'Advanced';
|
pixelEditorMode = 'Advanced';
|
||||||
document.getElementById("switch-mode-button").innerHTML = 'Switch to basic mode';
|
document.getElementById("switch-mode-button").innerHTML = 'Switch to basic mode';
|
||||||
|
|
||||||
//turn pixel grid off
|
|
||||||
currFile.pixelGrid.togglePixelGrid('off');
|
|
||||||
}
|
}
|
||||||
//switch to basic mode
|
//switch to basic mode
|
||||||
else {
|
else {
|
||||||
//if there is a current layer (a document is active)
|
Events.emit("switchedToBasic");
|
||||||
if (Startup.documentCreated()) {
|
|
||||||
if (!confirm('Switching to basic mode will flatten all the visible layers. Are you sure you want to continue?')) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Selecting the current layer
|
|
||||||
currFile.currentLayer.selectLayer();
|
|
||||||
// Flatten the layers
|
|
||||||
LayerList.flatten(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Hide the layer menus
|
|
||||||
LayerList.getLayerListEntries().style.display = 'none';
|
|
||||||
document.getElementById('layer-button').style.display = 'none';
|
|
||||||
// Show the palette menu
|
// Show the palette menu
|
||||||
document.getElementById('colors-menu').style.display = 'flex';
|
document.getElementById('colors-menu').style.display = 'flex';
|
||||||
// Move the palette menu
|
// Move the palette menu
|
||||||
@ -47,7 +29,6 @@ const EditorState = (() => {
|
|||||||
|
|
||||||
pixelEditorMode = 'Basic';
|
pixelEditorMode = 'Basic';
|
||||||
document.getElementById("switch-mode-button").innerHTML = 'Switch to advanced mode';
|
document.getElementById("switch-mode-button").innerHTML = 'Switch to advanced mode';
|
||||||
currFile.pixelGrid.togglePixelGrid('on');
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -73,8 +54,23 @@ const EditorState = (() => {
|
|||||||
switchMode('Advanced');
|
switchMode('Advanced');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function documentCreated() {
|
||||||
|
return !firstFile;
|
||||||
|
}
|
||||||
|
|
||||||
|
function firstPixel() {
|
||||||
|
return firstFile;
|
||||||
|
}
|
||||||
|
|
||||||
|
function created() {
|
||||||
|
firstFile = false;
|
||||||
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
getCurrentMode,
|
getCurrentMode,
|
||||||
switchMode
|
switchMode,
|
||||||
|
documentCreated,
|
||||||
|
created,
|
||||||
|
firstPixel
|
||||||
}
|
}
|
||||||
})();
|
})();
|
@ -58,7 +58,7 @@ const FileManager = (() => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function exportProject() {
|
function exportProject() {
|
||||||
if (Startup.documentCreated()) {
|
if (EditorState.documentCreated()) {
|
||||||
//create name
|
//create name
|
||||||
let fileName = Util.getValue("export-file-name");
|
let fileName = Util.getValue("export-file-name");
|
||||||
//set download link
|
//set download link
|
||||||
@ -107,7 +107,7 @@ const FileManager = (() => {
|
|||||||
|
|
||||||
function open() {
|
function open() {
|
||||||
//if a document exists
|
//if a document exists
|
||||||
if (Startup.documentCreated()) {
|
if (EditorState.documentCreated()) {
|
||||||
//check if the user wants to overwrite
|
//check if the user wants to overwrite
|
||||||
if (confirm('Opening a pixel will discard your current one. Are you sure you want to do that?'))
|
if (confirm('Opening a pixel will discard your current one. Are you sure you want to do that?'))
|
||||||
//open file selection dialog
|
//open file selection dialog
|
||||||
|
@ -73,7 +73,7 @@ const Input = (() => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//if no document has been created yet or there is a dialog box open ignore hotkeys
|
//if no document has been created yet or there is a dialog box open ignore hotkeys
|
||||||
if (!Startup.documentCreated() || Dialogue.isOpen()) return;
|
if (!EditorState.documentCreated() || Dialogue.isOpen()) return;
|
||||||
|
|
||||||
if (e.key === "Escape") {
|
if (e.key === "Escape") {
|
||||||
console.log("esc");
|
console.log("esc");
|
||||||
|
@ -9,6 +9,9 @@ const LayerList = (() => {
|
|||||||
Events.on("mousedown", layerList, openOptionsMenu);
|
Events.on("mousedown", layerList, openOptionsMenu);
|
||||||
// Binding the add layer button to the right function
|
// Binding the add layer button to the right function
|
||||||
Events.on('click',"add-layer-button", addLayer, false);
|
Events.on('click',"add-layer-button", addLayer, false);
|
||||||
|
// Listening to the switch mode event so I can change the layout
|
||||||
|
Events.onCustom("switchedToAdvanced", showMenu);
|
||||||
|
Events.onCustom("switchedToBasic", hideMenu);
|
||||||
|
|
||||||
// Making the layers list sortable
|
// Making the layers list sortable
|
||||||
new Sortable(layerList, {
|
new Sortable(layerList, {
|
||||||
@ -19,6 +22,25 @@ const LayerList = (() => {
|
|||||||
onEnd: layerDragDrop
|
onEnd: layerDragDrop
|
||||||
});
|
});
|
||||||
|
|
||||||
|
function showMenu() {
|
||||||
|
layerList.style.display = "inline-block";
|
||||||
|
document.getElementById('layer-button').style.display = 'inline-block';
|
||||||
|
}
|
||||||
|
function hideMenu() {
|
||||||
|
if (EditorState.documentCreated()) {
|
||||||
|
if (!confirm('Switching to basic mode will flatten all the visible layers. Are you sure you want to continue?')) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// Selecting the current layer
|
||||||
|
currFile.currentLayer.selectLayer();
|
||||||
|
// Flatten the layers
|
||||||
|
flatten(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
layerList.style.display = "none";
|
||||||
|
document.getElementById('layer-button').style.display = 'none';
|
||||||
|
}
|
||||||
|
|
||||||
function addLayer(id, saveHistory = true) {
|
function addLayer(id, saveHistory = true) {
|
||||||
// layers.length - 3
|
// layers.length - 3
|
||||||
let index = currFile.layers.length - 3;
|
let index = currFile.layers.length - 3;
|
||||||
|
@ -1,14 +1,10 @@
|
|||||||
const PaletteBlock = (() => {
|
const PaletteBlock = (() => {
|
||||||
// HTML elements
|
// HTML elements
|
||||||
let coloursList = document.getElementById("palette-list");
|
let coloursList = document.getElementById("palette-list");
|
||||||
let rampMenu = document.getElementById("pb-ramp-options");
|
|
||||||
let pbRampDialogue = document.getElementById("pb-ramp-dialogue");
|
|
||||||
|
|
||||||
// PaletteBlock-specific data
|
// PaletteBlock-specific data
|
||||||
let currentSquareSize = coloursList.children[0].clientWidth;
|
let currentSquareSize = coloursList.children[0].clientWidth;
|
||||||
let blockData = {blockWidth: 300, blockHeight: 320, squareSize: 40};
|
let blockData = {blockWidth: 300, blockHeight: 320, squareSize: 40};
|
||||||
let isRampSelecting = false;
|
|
||||||
let ramps = [];
|
|
||||||
let currentSelection = {startIndex:0, endIndex:0, startCoords:[], endCoords: [], name: "", colour: "", label: null};
|
let currentSelection = {startIndex:0, endIndex:0, startCoords:[], endCoords: [], name: "", colour: "", label: null};
|
||||||
|
|
||||||
|
|
||||||
|
@ -45,10 +45,10 @@ const Settings = (() => {
|
|||||||
settings.numberOfHistoryStates = Util.getValue('setting-numberOfHistoryStates');
|
settings.numberOfHistoryStates = Util.getValue('setting-numberOfHistoryStates');
|
||||||
settings.pixelGridColour = Util.getValue('setting-pixelGridColour');
|
settings.pixelGridColour = Util.getValue('setting-pixelGridColour');
|
||||||
// Filling pixel grid again if colour changed
|
// Filling pixel grid again if colour changed
|
||||||
currFile.pixelGrid.fillPixelGrid();
|
Events.emit("refreshPixelGrid");
|
||||||
|
|
||||||
//save settings object to cookie
|
//save settings object to cookie
|
||||||
var cookieValue = JSON.stringify(settings);
|
let cookieValue = JSON.stringify(settings);
|
||||||
Cookies.set('pixelEditorSettings', cookieValue, { expires: Infinity });
|
Cookies.set('pixelEditorSettings', cookieValue, { expires: Infinity });
|
||||||
|
|
||||||
//close window
|
//close window
|
||||||
|
@ -1,6 +1,4 @@
|
|||||||
const Startup = (() => {
|
const Startup = (() => {
|
||||||
|
|
||||||
let firstPixel = true;
|
|
||||||
let splashPostfix = '';
|
let splashPostfix = '';
|
||||||
|
|
||||||
Events.on('click', 'create-button', create, false);
|
Events.on('click', 'create-button', create, false);
|
||||||
@ -55,10 +53,9 @@ const Startup = (() => {
|
|||||||
currFile.layers[1].selectLayer();
|
currFile.layers[1].selectLayer();
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log("Starting with mode " + EditorState.getCurrentMode());
|
|
||||||
EditorState.switchMode(EditorState.getCurrentMode());
|
EditorState.switchMode(EditorState.getCurrentMode());
|
||||||
// This is not the first Pixel anymore
|
// This is not the first Pixel anymore
|
||||||
firstPixel = false;
|
EditorState.created();
|
||||||
}
|
}
|
||||||
|
|
||||||
function initLayers(width, height) {
|
function initLayers(width, height) {
|
||||||
@ -66,7 +63,7 @@ const Startup = (() => {
|
|||||||
currFile.canvasSize = [width, height];
|
currFile.canvasSize = [width, height];
|
||||||
|
|
||||||
// If this is the first pixel I'm creating since the app has started
|
// If this is the first pixel I'm creating since the app has started
|
||||||
if (firstPixel) {
|
if (EditorState.firstPixel()) {
|
||||||
// Creating the first layer
|
// Creating the first layer
|
||||||
currFile.currentLayer = new Layer(width, height, 'pixel-canvas', "");
|
currFile.currentLayer = new Layer(width, height, 'pixel-canvas', "");
|
||||||
currFile.currentLayer.canvas.style.zIndex = 2;
|
currFile.currentLayer.canvas.style.zIndex = 2;
|
||||||
@ -113,7 +110,7 @@ const Startup = (() => {
|
|||||||
// Tmp layer to draw previews on
|
// Tmp layer to draw previews on
|
||||||
currFile.TMPLayer = new Layer(width, height, 'tmp-canvas');
|
currFile.TMPLayer = new Layer(width, height, 'tmp-canvas');
|
||||||
|
|
||||||
if (firstPixel) {
|
if (EditorState.firstPixel()) {
|
||||||
// Adding the first layer and the checkerboard to the list of layers
|
// Adding the first layer and the checkerboard to the list of layers
|
||||||
currFile.layers.push(currFile.checkerBoard);
|
currFile.layers.push(currFile.checkerBoard);
|
||||||
currFile.layers.push(currFile.currentLayer);
|
currFile.layers.push(currFile.currentLayer);
|
||||||
@ -227,10 +224,6 @@ const Startup = (() => {
|
|||||||
newPixel(x, y);
|
newPixel(x, y);
|
||||||
}
|
}
|
||||||
|
|
||||||
function documentCreated() {
|
|
||||||
return !firstPixel;
|
|
||||||
}
|
|
||||||
|
|
||||||
function splashEditorMode(mode) {
|
function splashEditorMode(mode) {
|
||||||
editorMode = mode;
|
editorMode = mode;
|
||||||
}
|
}
|
||||||
@ -239,7 +232,6 @@ const Startup = (() => {
|
|||||||
create,
|
create,
|
||||||
newPixel,
|
newPixel,
|
||||||
newFromTemplate,
|
newFromTemplate,
|
||||||
documentCreated,
|
|
||||||
splashEditorMode
|
splashEditorMode
|
||||||
}
|
}
|
||||||
})();
|
})();
|
21
js/Tool.js
21
js/Tool.js
@ -123,23 +123,4 @@ class Tool {
|
|||||||
get size() {
|
get size() {
|
||||||
return this.currSize;
|
return this.currSize;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*global dragging currentTool, currentToolTemp, selectionCanceled, endSelection*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Class selectionTool extends Tool {
|
|
||||||
* imageDataToMove
|
|
||||||
* startDataPos
|
|
||||||
* currDataPos
|
|
||||||
* finalDataPos
|
|
||||||
* canMove
|
|
||||||
*
|
|
||||||
* movePreview()
|
|
||||||
*
|
|
||||||
* // start and end selection just overwrite the onStart and onEnd methods
|
|
||||||
*
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
*/
|
|
@ -30,13 +30,13 @@ const ToolManager = (() => {
|
|||||||
Events.onCustom("tool-shortcut", onShortcut);
|
Events.onCustom("tool-shortcut", onShortcut);
|
||||||
|
|
||||||
function onShortcut(tool) {
|
function onShortcut(tool) {
|
||||||
if (!Startup.documentCreated || Dialogue.isOpen())
|
if (!EditorState.documentCreated || Dialogue.isOpen())
|
||||||
return;
|
return;
|
||||||
switchTool(tools[tool]);
|
switchTool(tools[tool]);
|
||||||
}
|
}
|
||||||
|
|
||||||
function onMouseWheel(mouseEvent) {
|
function onMouseWheel(mouseEvent) {
|
||||||
if (!Startup.documentCreated || Dialogue.isOpen())
|
if (!EditorState.documentCreated || Dialogue.isOpen())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
let mousePos = Input.getCursorPosition(mouseEvent);
|
let mousePos = Input.getCursorPosition(mouseEvent);
|
||||||
@ -44,7 +44,7 @@ const ToolManager = (() => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function onMouseDown(mouseEvent) {
|
function onMouseDown(mouseEvent) {
|
||||||
if (!Startup.documentCreated() || Dialogue.isOpen())
|
if (!EditorState.documentCreated() || Dialogue.isOpen())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
let mousePos = Input.getCursorPosition(mouseEvent);
|
let mousePos = Input.getCursorPosition(mouseEvent);
|
||||||
@ -75,7 +75,7 @@ const ToolManager = (() => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function onMouseMove(mouseEvent) {
|
function onMouseMove(mouseEvent) {
|
||||||
if (!Startup.documentCreated() || Dialogue.isOpen())
|
if (!EditorState.documentCreated() || Dialogue.isOpen())
|
||||||
return;
|
return;
|
||||||
let mousePos = Input.getCursorPosition(mouseEvent);
|
let mousePos = Input.getCursorPosition(mouseEvent);
|
||||||
// Call the hover event
|
// Call the hover event
|
||||||
@ -108,7 +108,7 @@ const ToolManager = (() => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function onMouseUp(mouseEvent) {
|
function onMouseUp(mouseEvent) {
|
||||||
if (!Startup.documentCreated())
|
if (!EditorState.documentCreated())
|
||||||
return;
|
return;
|
||||||
let mousePos = Input.getCursorPosition(mouseEvent);
|
let mousePos = Input.getCursorPosition(mouseEvent);
|
||||||
|
|
||||||
|
@ -44,7 +44,7 @@ const TopMenuModule = (() => {
|
|||||||
break;
|
break;
|
||||||
case 'Exit':
|
case 'Exit':
|
||||||
//if a document exists, make sure they want to delete it
|
//if a document exists, make sure they want to delete it
|
||||||
if (Startup.documentCreated()) {
|
if (EditorState.documentCreated()) {
|
||||||
//ask user if they want to leave
|
//ask user if they want to leave
|
||||||
if (confirm('Exiting will discard your current pixel. Are you sure you want to do that?'))
|
if (confirm('Exiting will discard your current pixel. Are you sure you want to do that?'))
|
||||||
//skip onbeforeunload prompt
|
//skip onbeforeunload prompt
|
||||||
@ -64,12 +64,10 @@ const TopMenuModule = (() => {
|
|||||||
Events.on('click', currSubmenuButton, function(){Events.emit("ctrl+x");});
|
Events.on('click', currSubmenuButton, function(){Events.emit("ctrl+x");});
|
||||||
break;
|
break;
|
||||||
case 'Cancel':
|
case 'Cancel':
|
||||||
//Events.on('click', currSubmenuButton, tool.pencil.switchTo);
|
Events.on('click', currSubmenuButton, function(){Events.emit("esc-pressed")});
|
||||||
break;
|
break;
|
||||||
//Help Menu
|
//Help Menu
|
||||||
case 'Settings':
|
case 'Settings':
|
||||||
//fill form with current settings values
|
|
||||||
//Util.setValue('setting-numberOfHistoryStates', settings.numberOfHistoryStates);
|
|
||||||
Events.on('click', currSubmenuButton, Dialogue.showDialogue, 'settings');
|
Events.on('click', currSubmenuButton, Dialogue.showDialogue, 'settings');
|
||||||
break;
|
break;
|
||||||
case 'Help':
|
case 'Help':
|
||||||
|
@ -17,6 +17,9 @@ class PixelGrid extends Layer {
|
|||||||
initialize() {
|
initialize() {
|
||||||
super.initialize();
|
super.initialize();
|
||||||
this.fillPixelGrid();
|
this.fillPixelGrid();
|
||||||
|
Events.onCustom("refreshPixelGrid", this.fillPixelGrid.bind(this));
|
||||||
|
Events.onCustom("switchedToAdvanced", this.disablePixelGrid.bind(this));
|
||||||
|
Events.onCustom("switchedToBasic", this.enablePixelGrid.bind(this));
|
||||||
}
|
}
|
||||||
|
|
||||||
disablePixelGrid() {
|
disablePixelGrid() {
|
||||||
|
@ -1,22 +1,34 @@
|
|||||||
/**EXTERNALS AND LIBRARIES**/
|
/** EXTERNALS AND LIBRARIES **/
|
||||||
//=include lib/cookies.js
|
//=include lib/cookies.js
|
||||||
//=include lib/jscolor.js
|
//=include lib/jscolor.js
|
||||||
//=include lib/sortable.js
|
//=include lib/sortable.js
|
||||||
|
|
||||||
/**UTILITY AND INPUT*/
|
//=include data/consts.js
|
||||||
|
//=include data/palettes.js
|
||||||
|
|
||||||
|
/** UTILITY AND INPUT **/
|
||||||
//=include Util.js
|
//=include Util.js
|
||||||
//=include Events.js
|
//=include Events.js
|
||||||
//=include Dialogue.js
|
//=include Dialogue.js
|
||||||
//=include History.js
|
//=include History.js
|
||||||
|
//=include Settings.js
|
||||||
|
//=include EditorState.js
|
||||||
|
|
||||||
|
/** COLOR-RELATED **/
|
||||||
//=include Color.js
|
//=include Color.js
|
||||||
|
//=include ColorPicker.js
|
||||||
|
//=include PaletteBlock.js
|
||||||
|
|
||||||
|
/** BASE CLASSES **/
|
||||||
//=include File.js
|
//=include File.js
|
||||||
//=include ColorModule.js
|
|
||||||
|
|
||||||
//=include Tool.js
|
//=include Tool.js
|
||||||
|
//=include layers/Layer.js
|
||||||
|
|
||||||
|
/** SPECIAL LAYERS **/
|
||||||
|
//=include layers/Checkerboard.js
|
||||||
|
//=include layers/PixelGrid.js
|
||||||
|
|
||||||
|
/** TOOLS **/
|
||||||
//=include tools/ResizableTool.js
|
//=include tools/ResizableTool.js
|
||||||
//=include tools/SelectionTool.js
|
//=include tools/SelectionTool.js
|
||||||
|
|
||||||
@ -31,35 +43,22 @@
|
|||||||
//=include tools/RectangularSelectionTool.js
|
//=include tools/RectangularSelectionTool.js
|
||||||
//=include tools/MoveSelectionTool.js
|
//=include tools/MoveSelectionTool.js
|
||||||
|
|
||||||
/**init**/
|
/** MODULES AND MENUS **/
|
||||||
//=include data/consts.js
|
|
||||||
//=include Settings.js
|
|
||||||
//=include LayerList.js
|
|
||||||
//=include layers/Layer.js
|
|
||||||
//=include layers/Checkerboard.js
|
|
||||||
//=include layers/PixelGrid.js
|
|
||||||
|
|
||||||
//=include Startup.js
|
|
||||||
//=include EditorState.js
|
|
||||||
//=include ToolManager.js
|
|
||||||
|
|
||||||
/**dropdown formatting**/
|
|
||||||
//=include PresetModule.js
|
|
||||||
//=include data/palettes.js
|
|
||||||
|
|
||||||
/**functions**/
|
|
||||||
//=include ColorPicker.js
|
|
||||||
//=include PaletteBlock.js
|
|
||||||
//=include SplashPage.js
|
//=include SplashPage.js
|
||||||
|
//=include PresetModule.js
|
||||||
|
//=include ColorModule.js
|
||||||
|
//=include ToolManager.js
|
||||||
|
//=include LayerList.js
|
||||||
|
|
||||||
/**menus**/
|
/** STARTUP AND FILE MANAGEMENT **/
|
||||||
|
//=include Startup.js
|
||||||
//=include FileManager.js
|
//=include FileManager.js
|
||||||
//=include TopMenuModule.js
|
//=include TopMenuModule.js
|
||||||
|
|
||||||
/**event listeners**/
|
/** HTML INPUT EVENTS **/
|
||||||
//=include Input.js
|
//=include Input.js
|
||||||
|
|
||||||
/**feature toggles**/
|
/** IHER **/
|
||||||
//=include FeatureToggles.js
|
//=include FeatureToggles.js
|
||||||
|
|
||||||
// Controls execution of this preset module
|
// Controls execution of this preset module
|
||||||
@ -118,7 +117,7 @@ window.onload = function () {
|
|||||||
|
|
||||||
//prevent user from leaving page with unsaved data
|
//prevent user from leaving page with unsaved data
|
||||||
window.onbeforeunload = function() {
|
window.onbeforeunload = function() {
|
||||||
if (documentCreated)
|
if (EditorState.documentCreated)
|
||||||
return 'You will lose your pixel if it\'s not saved!';
|
return 'You will lose your pixel if it\'s not saved!';
|
||||||
|
|
||||||
else return;
|
else return;
|
||||||
|
@ -1,12 +1,8 @@
|
|||||||
Input <- Startup, LayerList, TopMenuModule: Could be resolved by using custom events
|
Input <- Startup, LayerList, TopMenuModule: Could be resolved by using custom events
|
||||||
|
|
||||||
|
FileManager <- LayerList, File, Startup, EditorState, ColorModule
|
||||||
|
|
||||||
Startup <- ColorModule, ToolManager, LayerList, EditorState, Layer(++)
|
Startup <- ColorModule, ToolManager, LayerList, EditorState, Layer(++)
|
||||||
|
|
||||||
EditorState <- LayerList, File, Startup(documentCreated): maybe documentCreated should stay in EditorState (that would fix the
|
TopMenuModule -> Startup
|
||||||
circular dependency with Startup), for the other dependencies it'd probably be nice for them to listen to a custom events
|
|
||||||
|
|
||||||
Color <- NONE
|
|
||||||
|
|
||||||
ColorModule <- File
|
|
||||||
|
|
||||||
File <- Startup, but only because Startup sets certain variables in File (pixelGrid, checkerboard and the other global layers)
|
|
||||||
|
Loading…
Reference in New Issue
Block a user