diff --git a/README.md b/README.md
index 9893b6c..4cdd545 100644
--- a/README.md
+++ b/README.md
@@ -58,162 +58,66 @@ Save and close, then run ``crafter-build build executable && caddy file-server -
This sample can also be viewed in the [HelloElement example](https://forgejo.catcrafts.net/Catcrafts/Crafter.CppDOM/src/branch/master/examples)
-## Enhanced Event Handling Capabilities
+## New Event Handling Capabilities
-The library now supports comprehensive event handling with rich event data for modern web applications:
+The library now supports comprehensive event handling for modern web applications:
### Mouse Events
- `AddClickListener()` - Handles click events
- `AddMouseOverListener()` - Handles mouse over events
- `AddMouseOutListener()` - Handles mouse out events
- `AddMouseMoveListener()` - Handles mouse move events
-- `AddMouseDownListener()` - Handles mouse down events
-- `AddMouseUpListener()` - Handles mouse up events
### Focus Events
- `AddFocusListener()` - Handles focus events
- `AddBlurListener()` - Handles blur events
### Keyboard Events
-- `AddKeyDownListener()` - Handles key down events with event data
-- `AddKeyUpListener()` - Handles key up events with event data
-- `AddKeyPressListener()` - Handles key press events with event data
+- `AddKeyDownListener()` - Handles key down events
+- `AddKeyUpListener()` - Handles key up events
+- `AddKeyPressListener()` - Handles key press events
### Form Events
-- `AddChangeListener()` - Handles change events with event data
+- `AddChangeListener()` - Handles change events
- `AddSubmitListener()` - Handles form submit events
-- `AddInputListener()` - Handles input events with event data
+- `AddInputListener()` - Handles input events
### Window Events
- `AddLoadListener()` - Handles page load events
-- `AddErrorListener()` - Handles error events with event data
-- `AddResizeListener()` - Handles window resize events with event data
-- `AddScrollListener()` - Handles scroll events with event data
+- `AddErrorListener()` - Handles error events
+- `AddResizeListener()` - Handles window resize events
+- `AddScrollListener()` - Handles scroll events
### Context Menu Events
-- `AddContextMenuListener()` - Handles context menu events with event data
+- `AddContextMenuListener()` - Handles context menu events
### Drag and Drop Events
-- `AddDragStartListener()` - Handles drag start events with event data
-- `AddDragEndListener()` - Handles drag end events with event data
-- `AddDropListener()` - Handles drop events with event data
-- `AddDragOverListener()` - Handles drag over events with event data
-- `AddDragEnterListener()` - Handles drag enter events with event data
-- `AddDragLeaveListener()` - Handles drag leave events with event data
-
-### Wheel Events
-- `AddWheelListener()` - Handles wheel events with event data
-
-### Example Usage with Event Data
+- `AddDragStartListener()` - Handles drag start events
+- `AddDragEndListener()` - Handles drag end events
+- `AddDropListener()` - Handles drop events
+Example usage:
```cpp
import Crafter.CppDOM;
-using namespace Crafter;
+using namespace Crafter::CppDOM;
int main(){
HtmlElement button("myButton");
HtmlElement input("textInput");
- // Handle click event with position data
+ // Handle click event
button.AddClickListener([]() {
- // Simple click handler without event data
+ // Handle button click
});
- // Handle keyboard events with rich event data
- input.AddKeyDownListener([](Crafter::CppDOM::EventTypes::KeyboardEvent event) {
- // Access key information
- if (event.key == "Enter") {
- // Handle Enter key specifically
- }
- // Check modifier keys
- if (event.ctrlKey) {
- // Handle Ctrl+key combinations
- }
+ // Handle keyboard events
+ input.AddKeyDownListener([]() {
+ // Handle key press
});
- // Handle input changes with event data
- input.AddInputListener([](Crafter::CppDOM::EventTypes::InputEvent event) {
- // Access input data
- std::string data = event.data;
- bool isComposing = event.isComposing;
- });
-
- // Handle mouse movements with coordinates
- button.AddMouseMoveListener([](Crafter::CppDOM::EventTypes::MouseEvent event) {
- // Access mouse position
- double x = event.clientX;
- double y = event.clientY;
- });
-
- // Handle form changes with value
- input.AddChangeListener([](Crafter::CppDOM::EventTypes::ChangeEvent event) {
- // Access the new value
- std::string value = event.value;
- });
-
- // Handle window resize with dimensions
- button.AddResizeListener([](Crafter::CppDOM::EventTypes::ResizeEvent event) {
- // Access window dimensions
- unsigned int width = event.width;
- unsigned int height = event.height;
+ // Handle input changes
+ input.AddInputListener([]() {
+ // Handle input changes
});
}
-```
-
-### Event Data Structures
-
-The library provides specific event data structures for different event types:
-
-#### KeyboardEvent
-- `std::string key` - The key value
-- `std::string code` - The physical key code
-- `int keyCode` - Legacy key code
-- `bool altKey` - Whether Alt key was pressed
-- `bool ctrlKey` - Whether Ctrl key was pressed
-- `bool shiftKey` - Whether Shift key was pressed
-- `bool metaKey` - Whether Meta key was pressed
-
-#### MouseEvent
-- `double clientX` - X coordinate relative to viewport
-- `double clientY` - Y coordinate relative to viewport
-- `double screenX` - X coordinate relative to screen
-- `double screenY` - Y coordinate relative to screen
-- `int button` - Which mouse button was pressed
-- `int buttons` - Which mouse buttons were pressed
-- `bool altKey` - Whether Alt key was pressed
-- `bool ctrlKey` - Whether Ctrl key was pressed
-- `bool shiftKey` - Whether Shift key was pressed
-- `bool metaKey` - Whether Meta key was pressed
-
-#### InputEvent
-- `std::string data` - The input data
-- `bool isComposing` - Whether input is in composition mode
-
-#### ChangeEvent
-- `std::string value` - The new value
-
-#### ResizeEvent
-- `unsigned int width` - Window width
-- `unsigned int height` - Window height
-
-#### ScrollEvent
-- `double scrollX` - Horizontal scroll position
-- `double scrollY` - Vertical scroll position
-
-#### ErrorEvent
-- `std::string message` - Error message
-- `std::string filename` - File where error occurred
-- `unsigned int lineno` - Line number
-- `unsigned int colno` - Column number
-
-#### DragEvent
-- All MouseEvent properties plus:
-- `double offsetX` - X offset from drag start
-- `double offsetY` - Y offset from drag start
-
-#### WheelEvent
-- All MouseEvent properties plus:
-- `double deltaX` - Horizontal scroll amount
-- `double deltaY` - Vertical scroll amount
-- `double deltaZ` - Depth scroll amount
-- `int deltaMode` - Scroll mode
\ No newline at end of file
+```
\ No newline at end of file
diff --git a/additional/env.js b/additional/env.js
index dbf94e6..3ae3309 100644
--- a/additional/env.js
+++ b/additional/env.js
@@ -29,19 +29,6 @@ function freeJs(ptr) {
jsmemory.delete(ptr);
}
-function writeStringToWasm(str) {
- const encoder = new TextEncoder();
- const encoded = encoder.encode(str + '\0');
- const len = encoded.length;
-
- const { WasmAlloc } = window.crafter_webbuild_wasi.instance.exports;
- const ptr = WasmAlloc(len);
- const memView = new Uint8Array(window.crafter_webbuild_wasi.instance.exports.memory.buffer, ptr, len);
- memView.set(encoded);
-
- return ptr;
-}
-
function getElementById(id, idLenght) {
const obj = document.getElementById(decoder.decode(new Int8Array(window.crafter_webbuild_wasi.instance.exports.memory.buffer, id, idLenght)));
jsmemory.set(++memorycounter, obj);
@@ -55,523 +42,427 @@ function setInnerHTML(ptr, html, htmlLenght) {
// Event handler registration functions
function addClickListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
// Create a handler that will trigger a notification to C++
- const handler = function (event) {
+ const handler = function(event) {
const { ExecuteClickHandler } = window.crafter_webbuild_wasi.instance.exports;
ExecuteClickHandler(handlerID);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}`, handler);
-
+
element.addEventListener("click", handler);
}
function removeClickListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}`);
-
+
element.removeEventListener("click", handler);
eventHandlers.delete(`${ptr}-${handlerID}`);
}
-// Mouse Events
+// Add more event handlers for modern websites
function addMouseOverListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
- const handler = function (event) {
+
+ const handler = function(event) {
const { ExecuteMouseOverHandler } = window.crafter_webbuild_wasi.instance.exports;
ExecuteMouseOverHandler(handlerID);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}-mouseover`, handler);
element.addEventListener("mouseover", handler);
}
function removeMouseOverListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}-mouseover`);
-
+
element.removeEventListener("mouseover", handler);
eventHandlers.delete(`${ptr}-${handlerID}-mouseover`);
}
function addMouseOutListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
- const handler = function (event) {
+
+ const handler = function(event) {
const { ExecuteMouseOutHandler } = window.crafter_webbuild_wasi.instance.exports;
ExecuteMouseOutHandler(handlerID);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}-mouseout`, handler);
element.addEventListener("mouseout", handler);
}
function removeMouseOutListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}-mouseout`);
-
+
element.removeEventListener("mouseout", handler);
eventHandlers.delete(`${ptr}-${handlerID}-mouseout`);
}
function addMouseMoveListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
- const handler = function (event) {
+
+ const handler = function(event) {
const { ExecuteMouseMoveHandler } = window.crafter_webbuild_wasi.instance.exports;
ExecuteMouseMoveHandler(handlerID);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}-mousemove`, handler);
element.addEventListener("mousemove", handler);
}
function removeMouseMoveListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}-mousemove`);
-
+
element.removeEventListener("mousemove", handler);
eventHandlers.delete(`${ptr}-${handlerID}-mousemove`);
}
-function addMouseDownListener(ptr, handlerID) {
- const element = jsmemory.get(ptr);
-
- const handler = function (event) {
- const { ExecuteMouseDownHandler } = window.crafter_webbuild_wasi.instance.exports;
- ExecuteMouseDownHandler(handlerID);
- };
-
- eventHandlers.set(`${ptr}-${handlerID}-mousedown`, handler);
- element.addEventListener("mousedown", handler);
-}
-
-function removeMouseDownListener(ptr, handlerID) {
- const element = jsmemory.get(ptr);
-
- const handler = eventHandlers.get(`${ptr}-${handlerID}-mousedown`);
-
- element.removeEventListener("mousedown", handler);
- eventHandlers.delete(`${ptr}-${handlerID}-mousedown`);
-}
-
-function addMouseUpListener(ptr, handlerID) {
- const element = jsmemory.get(ptr);
-
- const handler = function (event) {
- const { ExecuteMouseUpHandler } = window.crafter_webbuild_wasi.instance.exports;
- ExecuteMouseUpHandler(handlerID);
- };
-
- eventHandlers.set(`${ptr}-${handlerID}-mouseup`, handler);
- element.addEventListener("mouseup", handler);
-}
-
-function removeMouseUpListener(ptr, handlerID) {
- const element = jsmemory.get(ptr);
-
- const handler = eventHandlers.get(`${ptr}-${handlerID}-mouseup`);
-
- element.removeEventListener("mouseup", handler);
- eventHandlers.delete(`${ptr}-${handlerID}-mouseup`);
-}
-
-// Focus Events
function addFocusListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
- const handler = function (event) {
+
+ const handler = function(event) {
const { ExecuteFocusHandler } = window.crafter_webbuild_wasi.instance.exports;
ExecuteFocusHandler(handlerID);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}-focus`, handler);
element.addEventListener("focus", handler);
}
function removeFocusListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}-focus`);
-
+
element.removeEventListener("focus", handler);
eventHandlers.delete(`${ptr}-${handlerID}-focus`);
}
function addBlurListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
- const handler = function (event) {
+
+ const handler = function(event) {
const { ExecuteBlurHandler } = window.crafter_webbuild_wasi.instance.exports;
ExecuteBlurHandler(handlerID);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}-blur`, handler);
element.addEventListener("blur", handler);
}
function removeBlurListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}-blur`);
-
+
element.removeEventListener("blur", handler);
eventHandlers.delete(`${ptr}-${handlerID}-blur`);
}
-// Keyboard Events
function addKeyDownListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
- const handler = function (event) {
- const { ExecuteKeyDownHandler, WasmFree } = window.crafter_webbuild_wasi.instance.exports;
- const ptr = writeStringToWasm(event.key);
- ExecuteKeyDownHandler(handlerID, ptr, event.keyCode, event.altKey, event.ctrlKey, event.shiftKey, event.metaKey);
- WasmFree(ptr);
+
+ const handler = function(event) {
+ const { ExecuteKeyDownHandler } = window.crafter_webbuild_wasi.instance.exports;
+ ExecuteKeyDownHandler(handlerID, event.key, event.code, event.keyCode);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}-keydown`, handler);
element.addEventListener("keydown", handler);
}
function removeKeyDownListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}-keydown`);
-
+
element.removeEventListener("keydown", handler);
eventHandlers.delete(`${ptr}-${handlerID}-keydown`);
}
function addKeyUpListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
- const handler = function (event) {
- const { ExecuteKeyUpHandler, WasmFree } = window.crafter_webbuild_wasi.instance.exports;
- const ptr = writeStringToWasm(event.key);
- ExecuteKeyUpHandler(handlerID, ptr, event.keyCode, event.altKey, event.ctrlKey, event.shiftKey, event.metaKey);
- WasmFree(ptr);
+
+ const handler = function(event) {
+ const { ExecuteKeyUpHandler } = window.crafter_webbuild_wasi.instance.exports;
+ ExecuteKeyUpHandler(handlerID, event.key, event.code, event.keyCode);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}-keyup`, handler);
element.addEventListener("keyup", handler);
}
function removeKeyUpListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}-keyup`);
-
+
element.removeEventListener("keyup", handler);
eventHandlers.delete(`${ptr}-${handlerID}-keyup`);
}
function addKeyPressListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
- const handler = function (event) {
- const { ExecuteKeyPressHandler, WasmFree } = window.crafter_webbuild_wasi.instance.exports;
- const ptr = writeStringToWasm(event.key);
- ExecuteKeyPressHandler(handlerID, ptr, event.keyCode, event.altKey, event.ctrlKey, event.shiftKey, event.metaKey);
- WasmFree(ptr);
+
+ const handler = function(event) {
+ const { ExecuteKeyPressHandler } = window.crafter_webbuild_wasi.instance.exports;
+ ExecuteKeyPressHandler(handlerID, event.key, event.code, event.keyCode);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}-keypress`, handler);
element.addEventListener("keypress", handler);
}
function removeKeyPressListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}-keypress`);
-
+
element.removeEventListener("keypress", handler);
eventHandlers.delete(`${ptr}-${handlerID}-keypress`);
}
function addChangeListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
- const handler = function (event) {
+
+ const handler = function(event) {
const { ExecuteChangeHandler } = window.crafter_webbuild_wasi.instance.exports;
- ExecuteChangeHandler(handlerID, event.target.value);
+ ExecuteChangeHandler(handlerID);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}-change`, handler);
element.addEventListener("change", handler);
}
function removeChangeListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}-change`);
-
+
element.removeEventListener("change", handler);
eventHandlers.delete(`${ptr}-${handlerID}-change`);
}
function addSubmitListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
- const handler = function (event) {
+
+ const handler = function(event) {
const { ExecuteSubmitHandler } = window.crafter_webbuild_wasi.instance.exports;
ExecuteSubmitHandler(handlerID);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}-submit`, handler);
element.addEventListener("submit", handler);
}
function removeSubmitListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}-submit`);
-
+
element.removeEventListener("submit", handler);
eventHandlers.delete(`${ptr}-${handlerID}-submit`);
}
function addInputListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
- const handler = function (event) {
+
+ const handler = function(event) {
const { ExecuteInputHandler } = window.crafter_webbuild_wasi.instance.exports;
- ExecuteInputHandler(handlerID, event.data || event.target.value, event.inputType === 'insertCompositionText');
+ ExecuteInputHandler(handlerID);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}-input`, handler);
element.addEventListener("input", handler);
}
function removeInputListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}-input`);
-
+
element.removeEventListener("input", handler);
eventHandlers.delete(`${ptr}-${handlerID}-input`);
}
+function addLoadListener(ptr, handlerID) {
+ const element = jsmemory.get(ptr);
+
+ const handler = function(event) {
+ const { ExecuteLoadHandler } = window.crafter_webbuild_wasi.instance.exports;
+ ExecuteLoadHandler(handlerID);
+ };
+
+ eventHandlers.set(`${ptr}-${handlerID}-load`, handler);
+ element.addEventListener("load", handler);
+}
+
+function removeLoadListener(ptr, handlerID) {
+ const element = jsmemory.get(ptr);
+
+ const handler = eventHandlers.get(`${ptr}-${handlerID}-load`);
+
+ element.removeEventListener("load", handler);
+ eventHandlers.delete(`${ptr}-${handlerID}-load`);
+}
+
+function addErrorListener(ptr, handlerID) {
+ const element = jsmemory.get(ptr);
+
+ const handler = function(event) {
+ const { ExecuteErrorHandler } = window.crafter_webbuild_wasi.instance.exports;
+ ExecuteErrorHandler(handlerID);
+ };
+
+ eventHandlers.set(`${ptr}-${handlerID}-error`, handler);
+ element.addEventListener("error", handler);
+}
+
+function removeErrorListener(ptr, handlerID) {
+ const element = jsmemory.get(ptr);
+
+ const handler = eventHandlers.get(`${ptr}-${handlerID}-error`);
+
+ element.removeEventListener("error", handler);
+ eventHandlers.delete(`${ptr}-${handlerID}-error`);
+}
+
function addResizeListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
- const handler = function (event) {
+
+ const handler = function(event) {
const { ExecuteResizeHandler } = window.crafter_webbuild_wasi.instance.exports;
- ExecuteResizeHandler(handlerID, window.innerWidth, window.innerHeight);
+ ExecuteResizeHandler(handlerID);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}-resize`, handler);
element.addEventListener("resize", handler);
}
function removeResizeListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}-resize`);
-
+
element.removeEventListener("resize", handler);
eventHandlers.delete(`${ptr}-${handlerID}-resize`);
}
function addScrollListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
- const handler = function (event) {
+
+ const handler = function(event) {
const { ExecuteScrollHandler } = window.crafter_webbuild_wasi.instance.exports;
- ExecuteScrollHandler(handlerID, window.scrollX, window.scrollY);
+ ExecuteScrollHandler(handlerID);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}-scroll`, handler);
element.addEventListener("scroll", handler);
}
function removeScrollListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}-scroll`);
-
+
element.removeEventListener("scroll", handler);
eventHandlers.delete(`${ptr}-${handlerID}-scroll`);
}
-// Context Menu Events
function addContextMenuListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
- const handler = function (event) {
+
+ const handler = function(event) {
const { ExecuteContextMenuHandler } = window.crafter_webbuild_wasi.instance.exports;
- ExecuteContextMenuHandler(handlerID, event.clientX, event.clientY, event.screenX, event.screenY, event.button, event.altKey, event.ctrlKey, event.shiftKey, event.metaKey);
+ ExecuteContextMenuHandler(handlerID);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}-contextmenu`, handler);
element.addEventListener("contextmenu", handler);
}
function removeContextMenuListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}-contextmenu`);
-
+
element.removeEventListener("contextmenu", handler);
eventHandlers.delete(`${ptr}-${handlerID}-contextmenu`);
}
-// Drag and Drop Events
function addDragStartListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
- const handler = function (event) {
+
+ const handler = function(event) {
const { ExecuteDragStartHandler } = window.crafter_webbuild_wasi.instance.exports;
- ExecuteDragStartHandler(handlerID, event.clientX, event.clientY, event.screenX, event.screenY, event.button, event.altKey, event.ctrlKey, event.shiftKey, event.metaKey);
+ ExecuteDragStartHandler(handlerID);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}-dragstart`, handler);
element.addEventListener("dragstart", handler);
}
function removeDragStartListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}-dragstart`);
-
+
element.removeEventListener("dragstart", handler);
eventHandlers.delete(`${ptr}-${handlerID}-dragstart`);
}
function addDragEndListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
- const handler = function (event) {
+
+ const handler = function(event) {
const { ExecuteDragEndHandler } = window.crafter_webbuild_wasi.instance.exports;
- ExecuteDragEndHandler(handlerID, event.clientX, event.clientY, event.screenX, event.screenY, event.button, event.altKey, event.ctrlKey, event.shiftKey, event.metaKey);
+ ExecuteDragEndHandler(handlerID);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}-dragend`, handler);
element.addEventListener("dragend", handler);
}
function removeDragEndListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}-dragend`);
-
+
element.removeEventListener("dragend", handler);
eventHandlers.delete(`${ptr}-${handlerID}-dragend`);
}
function addDropListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
- const handler = function (event) {
+
+ const handler = function(event) {
const { ExecuteDropHandler } = window.crafter_webbuild_wasi.instance.exports;
- ExecuteDropHandler(handlerID, event.clientX, event.clientY, event.screenX, event.screenY, event.button, event.altKey, event.ctrlKey, event.shiftKey, event.metaKey);
+ ExecuteDropHandler(handlerID);
};
-
+
eventHandlers.set(`${ptr}-${handlerID}-drop`, handler);
element.addEventListener("drop", handler);
}
function removeDropListener(ptr, handlerID) {
const element = jsmemory.get(ptr);
-
+
const handler = eventHandlers.get(`${ptr}-${handlerID}-drop`);
-
+
element.removeEventListener("drop", handler);
eventHandlers.delete(`${ptr}-${handlerID}-drop`);
}
-// Additional Drag Events
-function addDragOverListener(ptr, handlerID) {
- const element = jsmemory.get(ptr);
-
- const handler = function (event) {
- const { ExecuteDragOverHandler } = window.crafter_webbuild_wasi.instance.exports;
- ExecuteDragOverHandler(handlerID, event.clientX, event.clientY, event.screenX, event.screenY, event.button, event.altKey, event.ctrlKey, event.shiftKey, event.metaKey);
- };
-
- eventHandlers.set(`${ptr}-${handlerID}-dragover`, handler);
- element.addEventListener("dragover", handler);
-}
-
-function removeDragOverListener(ptr, handlerID) {
- const element = jsmemory.get(ptr);
-
- const handler = eventHandlers.get(`${ptr}-${handlerID}-dragover`);
-
- element.removeEventListener("dragover", handler);
- eventHandlers.delete(`${ptr}-${handlerID}-dragover`);
-}
-
-function addDragEnterListener(ptr, handlerID) {
- const element = jsmemory.get(ptr);
-
- const handler = function (event) {
- const { ExecuteDragEnterHandler } = window.crafter_webbuild_wasi.instance.exports;
- ExecuteDragEnterHandler(handlerID, event.clientX, event.clientY, event.screenX, event.screenY, event.button, event.altKey, event.ctrlKey, event.shiftKey, event.metaKey);
- };
-
- eventHandlers.set(`${ptr}-${handlerID}-dragenter`, handler);
- element.addEventListener("dragenter", handler);
-}
-
-function removeDragEnterListener(ptr, handlerID) {
- const element = jsmemory.get(ptr);
-
- const handler = eventHandlers.get(`${ptr}-${handlerID}-dragenter`);
-
- element.removeEventListener("dragenter", handler);
- eventHandlers.delete(`${ptr}-${handlerID}-dragenter`);
-}
-
-function addDragLeaveListener(ptr, handlerID) {
- const element = jsmemory.get(ptr);
-
- const handler = function (event) {
- const { ExecuteDragLeaveHandler } = window.crafter_webbuild_wasi.instance.exports;
- ExecuteDragLeaveHandler(handlerID, event.clientX, event.clientY, event.screenX, event.screenY, event.button, event.altKey, event.ctrlKey, event.shiftKey, event.metaKey);
- };
-
- eventHandlers.set(`${ptr}-${handlerID}-dragleave`, handler);
- element.addEventListener("dragleave", handler);
-}
-
-function removeDragLeaveListener(ptr, handlerID) {
- const element = jsmemory.get(ptr);
-
- const handler = eventHandlers.get(`${ptr}-${handlerID}-dragleave`);
-
- element.removeEventListener("dragleave", handler);
- eventHandlers.delete(`${ptr}-${handlerID}-dragleave`);
-}
-
-// Wheel Event
-function addWheelListener(ptr, handlerID) {
- const element = jsmemory.get(ptr);
-
- const handler = function (event) {
- const { ExecuteWheelHandler } = window.crafter_webbuild_wasi.instance.exports;
- ExecuteWheelHandler(handlerID, event.deltaX, event.deltaY, event.deltaZ, event.deltaMode, event.clientX, event.clientY, event.screenX, event.screenY, event.button, event.altKey, event.ctrlKey, event.shiftKey, event.metaKey);
- };
-
- eventHandlers.set(`${ptr}-${handlerID}-wheel`, handler);
- element.addEventListener("wheel", handler);
-}
-
-function removeWheelListener(ptr, handlerID) {
- const element = jsmemory.get(ptr);
-
- const handler = eventHandlers.get(`${ptr}-${handlerID}-wheel`);
-
- element.removeEventListener("wheel", handler);
- eventHandlers.delete(`${ptr}-${handlerID}-wheel`);
-}
-
let env = {
freeJs: freeJs,
getElementById: getElementById,
@@ -584,10 +475,6 @@ let env = {
removeMouseOutListener: removeMouseOutListener,
addMouseMoveListener: addMouseMoveListener,
removeMouseMoveListener: removeMouseMoveListener,
- addMouseDownListener: addMouseDownListener,
- removeMouseDownListener: removeMouseDownListener,
- addMouseUpListener: addMouseUpListener,
- removeMouseUpListener: removeMouseUpListener,
addFocusListener: addFocusListener,
removeFocusListener: removeFocusListener,
addBlurListener: addBlurListener,
@@ -604,6 +491,10 @@ let env = {
removeSubmitListener: removeSubmitListener,
addInputListener: addInputListener,
removeInputListener: removeInputListener,
+ addLoadListener: addLoadListener,
+ removeLoadListener: removeLoadListener,
+ addErrorListener: addErrorListener,
+ removeErrorListener: removeErrorListener,
addResizeListener: addResizeListener,
removeResizeListener: removeResizeListener,
addScrollListener: addScrollListener,
@@ -616,14 +507,6 @@ let env = {
removeDragEndListener: removeDragEndListener,
addDropListener: addDropListener,
removeDropListener: removeDropListener,
- addWheelListener: addWheelListener,
- removeWheelListener: removeWheelListener,
- addDragOverListener: addDragOverListener,
- removeDragOverListener: removeDragOverListener,
- addDragEnterListener: addDragEnterListener,
- removeDragEnterListener: removeDragEnterListener,
- addDragLeaveListener: addDragLeaveListener,
- removeDragLeaveListener: removeDragLeaveListener,
}
window.crafter_webbuild_env = env;
\ No newline at end of file
diff --git a/examples/CompleteEventHandling/README.md b/examples/CompleteEventHandling/README.md
new file mode 100644
index 0000000..175741a
--- /dev/null
+++ b/examples/CompleteEventHandling/README.md
@@ -0,0 +1,84 @@
+# Complete Event Handling Example
+
+This example demonstrates comprehensive event handling capabilities in Crafter.CppDOM.
+
+## Features
+
+- Shows how to handle various types of DOM events using C++
+- Demonstrates mouse, keyboard, form, and window events
+- Illustrates proper event listener attachment and callback handling
+- Shows real-time interaction with UI elements
+
+## Event Types Demonstrated
+
+### Mouse Events
+- Click events
+- Mouse over/out events
+- Mouse move events
+
+### Focus Events
+- Focus and blur events
+
+### Keyboard Events
+- Key down, up, and press events
+
+### Form Events
+- Change, submit, and input events
+
+### Window Events
+- Load, error, resize, and scroll events
+
+### Context Menu Events
+- Context menu events
+
+### Drag and Drop Events
+- Drag start, end, and drop events
+
+## Usage
+
+```cpp
+import Crafter.CppDOM;
+using namespace Crafter::CppDOM;
+
+int main(){
+ // Create UI elements
+ HtmlElement body("body");
+ body.SetInnerHTML("
Complete Event Handling Demo
"
+ ""
+ ""
+ "Events will appear here
");
+
+ // Handle click event
+ HtmlElement button("myButton");
+ button.AddClickListener([]() {
+ HtmlElement output("output");
+ output.SetInnerHTML("Button was clicked!");
+ });
+
+ // Handle keyboard events
+ HtmlElement input("textInput");
+ input.AddInputListener([]() {
+ HtmlElement output("output");
+ output.SetInnerHTML("Input changed!");
+ });
+
+ // Handle form events
+ input.AddChangeListener([]() {
+ HtmlElement output("output");
+ output.SetInnerHTML("Form value changed!");
+ });
+
+ return 0;
+}
+```
+
+## Building and Running
+
+```bash
+crafter-build build executable
+run.sh
+```
+
+Then navigate to `http://localhost:8080/` in your browser.
+
+If caddy is not installed, you can use your favorite static file server instead.
\ No newline at end of file
diff --git a/examples/CompleteEventHandling/main.cpp b/examples/CompleteEventHandling/main.cpp
new file mode 100644
index 0000000..e5ad748
--- /dev/null
+++ b/examples/CompleteEventHandling/main.cpp
@@ -0,0 +1,77 @@
+import Crafter.CppDOM;
+using namespace Crafter;
+
+HtmlElement* body = new HtmlElement("body", "");
+HtmlElement* button = new HtmlElement("myButton");
+HtmlElement* input = new HtmlElement("textInput");
+HtmlElement* output = new HtmlElement("output");
+
+int main(){
+
+
+ // Click event
+ button->AddClickListener([&]() {
+ output->SetInnerHTML("Button was clicked!");
+ });
+
+ // Mouse events
+ button->AddMouseOverListener([&]() {
+ output->SetInnerHTML("Mouse over button!");
+ });
+
+ button->AddMouseOutListener([&]() {
+ output->SetInnerHTML("Mouse left button!");
+ });
+
+ // Focus/Blur events
+ input->AddFocusListener([&]() {
+ output->SetInnerHTML("Input focused!");
+ });
+
+ input->AddBlurListener([&]() {
+ output->SetInnerHTML("Input blurred!");
+ });
+
+ // Keyboard events
+ input->AddKeyDownListener([&]() {
+ output->SetInnerHTML("Key pressed in input!");
+ });
+
+ input->AddKeyUpListener([&]() {
+ output->SetInnerHTML("Key released in input!");
+ });
+
+ // Input/change events
+ input->AddInputListener([&]() {
+ output->SetInnerHTML("Input value changed!");
+ });
+
+ input->AddChangeListener([&]() {
+ output->SetInnerHTML("Input value changed and lost focus!");
+ });
+
+ // Context menu
+ button->AddContextMenuListener([&]() {
+ output->SetInnerHTML("Context menu opened!");
+ });
+
+ // Scroll event on body
+ body->AddScrollListener([&]() {
+ output->SetInnerHTML("Page scrolled!");
+ });
+
+ // Resize event
+ body->AddResizeListener([&]() {
+ output->SetInnerHTML("Window resized!");
+ });
+
+ // Load event
+ body->AddLoadListener([&]() {
+ output->SetInnerHTML("Page loaded!");
+ });
+
+ // Error event
+ body->AddErrorListener([&]() {
+ output->SetInnerHTML("An error occurred!");
+ });
+}
\ No newline at end of file
diff --git a/examples/EnhancedEventHandling/project.json b/examples/CompleteEventHandling/project.json
similarity index 100%
rename from examples/EnhancedEventHandling/project.json
rename to examples/CompleteEventHandling/project.json
diff --git a/examples/EnhancedEventHandling/run.sh b/examples/CompleteEventHandling/run.sh
similarity index 100%
rename from examples/EnhancedEventHandling/run.sh
rename to examples/CompleteEventHandling/run.sh
diff --git a/examples/EnhancedEventHandling/main.cpp b/examples/EnhancedEventHandling/main.cpp
deleted file mode 100644
index fb89730..0000000
--- a/examples/EnhancedEventHandling/main.cpp
+++ /dev/null
@@ -1,21 +0,0 @@
-import Crafter.CppDOM;
-using namespace Crafter;
-import std;
-
-HtmlElement* body = new HtmlElement("body", ""
- "
Enhanced Event Handling Demo
"
- "
"
- "
"
- "
");
-HtmlElement* keyInput = new HtmlElement("keyInput");
-HtmlElement* output = new HtmlElement("output");
-
-int main(){
- keyInput->AddKeyDownListener([&](KeyboardEvent event) {
- std::string keyInfo = std::format("Key pressed: {}
", event.key);
- if (event.ctrlKey) keyInfo += "Ctrl key pressed
";
- if (event.shiftKey) keyInfo += "Shift key pressed
";
- if (event.altKey) keyInfo += "Alt key pressed
";
- output->SetInnerHTML(keyInfo);
- });
-}
\ No newline at end of file
diff --git a/examples/HelloWorld/main.cpp b/examples/HelloWorld/main.cpp
index b485511..1fe57d6 100644
--- a/examples/HelloWorld/main.cpp
+++ b/examples/HelloWorld/main.cpp
@@ -1,5 +1,5 @@
import Crafter.CppDOM;
-using namespace Crafter::CppDOMBindings;
+using namespace Crafter::CppDOM::Bindings;
int main(){
void* body = GetElementById("body");
diff --git a/interfaces/Crafter.CppDOM-Bindings.cppm b/interfaces/Crafter.CppDOM-Bindings.cppm
new file mode 100644
index 0000000..6177fd7
--- /dev/null
+++ b/interfaces/Crafter.CppDOM-Bindings.cppm
@@ -0,0 +1,237 @@
+/*
+Crafter.CppDOM
+Copyright (C) 2025 Catcrafts
+Catcrafts.net
+
+This library is free software; you can redistribute it and/or
+modify it under the terms of the GNU Lesser General Public
+License as published by the Free Software Foundation; either
+version 3.0 of the License, or (at your option) any later version.
+
+This library is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+Lesser General Public License for more details.
+
+You should have received a copy of the GNU Lesser General Public
+License along with this library; if not, write to the Free Software
+Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+*/
+
+export module Crafter.CppDOM:Bindings;
+import std;
+
+export namespace Crafter::CppDOM::Bindings {
+ int clickHandlerMaxId = 0;
+ std::unordered_map>* clickHandlers = new std::unordered_map>();
+
+ int mouseOverHandlerMaxId = 0;
+ std::unordered_map>* mouseOverHandlers = new std::unordered_map>();
+
+ int mouseOutHandlerMaxId = 0;
+ std::unordered_map>* mouseOutHandlers = new std::unordered_map>();
+
+ int mouseMoveHandlerMaxId = 0;
+ std::unordered_map>* mouseMoveHandlers = new std::unordered_map>();
+
+ int focusHandlerMaxId = 0;
+ std::unordered_map>* focusHandlers = new std::unordered_map>();
+
+ int blurHandlerMaxId = 0;
+ std::unordered_map>* blurHandlers = new std::unordered_map>();
+
+ int keyDownHandlerMaxId = 0;
+ std::unordered_map>* keyDownHandlers = new std::unordered_map>();
+
+ int keyUpHandlerMaxId = 0;
+ std::unordered_map>* keyUpHandlers = new std::unordered_map>();
+
+ int keyPressHandlerMaxId = 0;
+ std::unordered_map>* keyPressHandlers = new std::unordered_map>();
+
+ int changeHandlerMaxId = 0;
+ std::unordered_map>* changeHandlers = new std::unordered_map>();
+
+ int submitHandlerMaxId = 0;
+ std::unordered_map>* submitHandlers = new std::unordered_map>();
+
+ int inputHandlerMaxId = 0;
+ std::unordered_map>* inputHandlers = new std::unordered_map>();
+
+ int loadHandlerMaxId = 0;
+ std::unordered_map>* loadHandlers = new std::unordered_map>();
+
+ int errorHandlerMaxId = 0;
+ std::unordered_map>* errorHandlers = new std::unordered_map>();
+
+ int resizeHandlerMaxId = 0;
+ std::unordered_map>* resizeHandlers = new std::unordered_map>();
+
+ int scrollHandlerMaxId = 0;
+ std::unordered_map>* scrollHandlers = new std::unordered_map>();
+
+ int contextMenuHandlerMaxId = 0;
+ std::unordered_map>* contextMenuHandlers = new std::unordered_map>();
+
+ int dragStartHandlerMaxId = 0;
+ std::unordered_map>* dragStartHandlers = new std::unordered_map>();
+
+ int dragEndHandlerMaxId = 0;
+ std::unordered_map>* dragEndHandlers = new std::unordered_map>();
+
+ int dropHandlerMaxId = 0;
+ std::unordered_map>* dropHandlers = new std::unordered_map>();
+
+ __attribute__((import_module("env"), import_name("freeJs"))) void FreeJs(void* ptr);
+ __attribute__((import_module("env"), import_name("getElementById"))) void* GetElementById(const char* id, std::size_t idLenght);
+ void* GetElementById(const std::string_view id) {
+ return GetElementById(id.data(), id.size());
+ }
+ __attribute__((import_module("env"), import_name("setInnerHTML"))) void SetInnerHTML(void* ptr, const char* html, std::size_t htmlLenght);
+ void SetInnerHTML(void* ptr, const std::string_view html) {
+ SetInnerHTML(ptr, html.data(), html.size());
+ }
+
+ // Event handling functions
+ __attribute__((import_module("env"), import_name("addClickListener"))) void AddClickListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeClickListener"))) void RemoveClickListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addMouseOverListener"))) void AddMouseOverListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeMouseOverListener"))) void RemoveMouseOverListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addMouseOutListener"))) void AddMouseOutListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeMouseOutListener"))) void RemoveMouseOutListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addMouseMoveListener"))) void AddMouseMoveListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeMouseMoveListener"))) void RemoveMouseMoveListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addFocusListener"))) void AddFocusListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeFocusListener"))) void RemoveFocusListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addBlurListener"))) void AddBlurListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeBlurListener"))) void RemoveBlurListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addKeyDownListener"))) void AddKeyDownListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeKeyDownListener"))) void RemoveKeyDownListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addKeyUpListener"))) void AddKeyUpListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeKeyUpListener"))) void RemoveKeyUpListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addKeyPressListener"))) void AddKeyPressListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeKeyPressListener"))) void RemoveKeyPressListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addChangeListener"))) void AddChangeListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeChangeListener"))) void RemoveChangeListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addSubmitListener"))) void AddSubmitListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeSubmitListener"))) void RemoveSubmitListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addInputListener"))) void AddInputListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeInputListener"))) void RemoveInputListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addLoadListener"))) void AddLoadListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeLoadListener"))) void RemoveLoadListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addErrorListener"))) void AddErrorListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeErrorListener"))) void RemoveErrorListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addResizeListener"))) void AddResizeListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeResizeListener"))) void RemoveResizeListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addScrollListener"))) void AddScrollListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeScrollListener"))) void RemoveScrollListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addContextMenuListener"))) void AddContextMenuListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeContextMenuListener"))) void RemoveContextMenuListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addDragStartListener"))) void AddDragStartListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeDragStartListener"))) void RemoveDragStartListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addDragEndListener"))) void AddDragEndListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeDragEndListener"))) void RemoveDragEndListener(void* ptr, int id);
+
+ __attribute__((import_module("env"), import_name("addDropListener"))) void AddDropListener(void* ptr, int id);
+ __attribute__((import_module("env"), import_name("removeDropListener"))) void RemoveDropListener(void* ptr, int id);
+}
+
+extern "C" {
+ __attribute__((export_name("ExecuteClickHandler"))) void ExecuteClickHandler(int a) {
+ Crafter::CppDOM::Bindings::clickHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteMouseOverHandler"))) void ExecuteMouseOverHandler(int a) {
+ Crafter::CppDOM::Bindings::mouseOverHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteMouseOutHandler"))) void ExecuteMouseOutHandler(int a) {
+ Crafter::CppDOM::Bindings::mouseOutHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteMouseMoveHandler"))) void ExecuteMouseMoveHandler(int a) {
+ Crafter::CppDOM::Bindings::mouseMoveHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteFocusHandler"))) void ExecuteFocusHandler(int a) {
+ Crafter::CppDOM::Bindings::focusHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteBlurHandler"))) void ExecuteBlurHandler(int a) {
+ Crafter::CppDOM::Bindings::blurHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteKeyDownHandler"))) void ExecuteKeyDownHandler(int a, const char* key, const char* code, int keyCode) {
+ Crafter::CppDOM::Bindings::keyDownHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteKeyUpHandler"))) void ExecuteKeyUpHandler(int a, const char* key, const char* code, int keyCode) {
+ Crafter::CppDOM::Bindings::keyUpHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteKeyPressHandler"))) void ExecuteKeyPressHandler(int a, const char* key, const char* code, int keyCode) {
+ Crafter::CppDOM::Bindings::keyPressHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteChangeHandler"))) void ExecuteChangeHandler(int a) {
+ Crafter::CppDOM::Bindings::changeHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteSubmitHandler"))) void ExecuteSubmitHandler(int a) {
+ Crafter::CppDOM::Bindings::submitHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteInputHandler"))) void ExecuteInputHandler(int a) {
+ Crafter::CppDOM::Bindings::inputHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteLoadHandler"))) void ExecuteLoadHandler(int a) {
+ Crafter::CppDOM::Bindings::loadHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteErrorHandler"))) void ExecuteErrorHandler(int a) {
+ Crafter::CppDOM::Bindings::errorHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteResizeHandler"))) void ExecuteResizeHandler(int a) {
+ Crafter::CppDOM::Bindings::resizeHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteScrollHandler"))) void ExecuteScrollHandler(int a) {
+ Crafter::CppDOM::Bindings::scrollHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteContextMenuHandler"))) void ExecuteContextMenuHandler(int a) {
+ Crafter::CppDOM::Bindings::contextMenuHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteDragStartHandler"))) void ExecuteDragStartHandler(int a) {
+ Crafter::CppDOM::Bindings::dragStartHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteDragEndHandler"))) void ExecuteDragEndHandler(int a) {
+ Crafter::CppDOM::Bindings::dragEndHandlers->find(static_cast(a))->second();
+ }
+
+ __attribute__((export_name("ExecuteDropHandler"))) void ExecuteDropHandler(int a) {
+ Crafter::CppDOM::Bindings::dropHandlers->find(static_cast(a))->second();
+ }
+}
\ No newline at end of file
diff --git a/interfaces/Crafter.CppDOM-BindingsExport.cppm b/interfaces/Crafter.CppDOM-BindingsExport.cppm
deleted file mode 100644
index 7ebe266..0000000
--- a/interfaces/Crafter.CppDOM-BindingsExport.cppm
+++ /dev/null
@@ -1,204 +0,0 @@
-/*
-Crafter.CppDOM
-Copyright (C) 2025 Catcrafts
-Catcrafts.net
-
-This library is free software; you can redistribute it and/or
-modify it under the terms of the GNU Lesser General Public
-License as published by the Free Software Foundation; either
-version 3.0 of the License, or (at your option) any later version.
-
-This library is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
-Lesser General Public License for more details.
-
-You should have received a copy of the GNU Lesser General Public
-License along with this library; if not, write to the Free Software
-Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
-*/
-
-export module Crafter.CppDOM:BindingsExport;
-import std;
-import :EventTypes;
-
-export namespace Crafter::CppDOMBindings {
- int clickHandlerMaxId = 0;
- std::unordered_map>* clickHandlers = new std::unordered_map>();
-
- int mouseOverHandlerMaxId = 0;
- std::unordered_map>* mouseOverHandlers = new std::unordered_map>();
-
- int mouseOutHandlerMaxId = 0;
- std::unordered_map>* mouseOutHandlers = new std::unordered_map>();
-
- int mouseMoveHandlerMaxId = 0;
- std::unordered_map>* mouseMoveHandlers = new std::unordered_map>();
-
- int mouseDownHandlerMaxId = 0;
- std::unordered_map>* mouseDownHandlers = new std::unordered_map>();
-
- int mouseUpHandlerMaxId = 0;
- std::unordered_map>* mouseUpHandlers = new std::unordered_map>();
-
- int focusHandlerMaxId = 0;
- std::unordered_map>* focusHandlers = new std::unordered_map>();
-
- int blurHandlerMaxId = 0;
- std::unordered_map>* blurHandlers = new std::unordered_map>();
-
- int keyDownHandlerMaxId = 0;
- std::unordered_map>* keyDownHandlers = new std::unordered_map>();
-
- int keyUpHandlerMaxId = 0;
- std::unordered_map>* keyUpHandlers = new std::unordered_map>();
-
- int keyPressHandlerMaxId = 0;
- std::unordered_map>* keyPressHandlers = new std::unordered_map>();
-
- int changeHandlerMaxId = 0;
- std::unordered_map>* changeHandlers = new std::unordered_map>();
-
- int submitHandlerMaxId = 0;
- std::unordered_map>* submitHandlers = new std::unordered_map>();
-
- int inputHandlerMaxId = 0;
- std::unordered_map>* inputHandlers = new std::unordered_map>();
-
- int resizeHandlerMaxId = 0;
- std::unordered_map>* resizeHandlers = new std::unordered_map>();
-
- int scrollHandlerMaxId = 0;
- std::unordered_map>* scrollHandlers = new std::unordered_map>();
-
- int contextMenuHandlerMaxId = 0;
- std::unordered_map>* contextMenuHandlers = new std::unordered_map>();
-
- int dragStartHandlerMaxId = 0;
- std::unordered_map>* dragStartHandlers = new std::unordered_map>();
-
- int dragEndHandlerMaxId = 0;
- std::unordered_map>* dragEndHandlers = new std::unordered_map>();
-
- int dropHandlerMaxId = 0;
- std::unordered_map>* dropHandlers = new std::unordered_map>();
-
- int wheelHandlerMaxId = 0;
- std::unordered_map>* wheelHandlers = new std::unordered_map>();
-
- int dragOverHandlerMaxId = 0;
- std::unordered_map>* dragOverHandlers = new std::unordered_map>();
-
- int dragEnterHandlerMaxId = 0;
- std::unordered_map>* dragEnterHandlers = new std::unordered_map>();
-
- int dragLeaveHandlerMaxId = 0;
- std::unordered_map>* dragLeaveHandlers = new std::unordered_map>();
-}
-
-extern "C" {
- __attribute__((export_name("WasmAlloc"))) void* WasmAlloc(std::int32_t size) {
- std::cout << std::format("Alloc: {}", size) << std::endl;
- return std::malloc(size);
- }
-
- __attribute__((export_name("WasmFree"))) void WasmFree(void* ptr) {
- std::free(ptr);
- }
-
- __attribute__((export_name("ExecuteClickHandler"))) void ExecuteClickHandler(std::int32_t handlerID) {
- Crafter::CppDOMBindings::clickHandlers->find(handlerID)->second();
- }
-
- __attribute__((export_name("ExecuteMouseOverHandler"))) void ExecuteMouseOverHandler(std::int32_t handlerID) {
- Crafter::CppDOMBindings::mouseOverHandlers->find(handlerID)->second();
- }
-
- __attribute__((export_name("ExecuteMouseOutHandler"))) void ExecuteMouseOutHandler(std::int32_t handlerID) {
- Crafter::CppDOMBindings::mouseOutHandlers->find(handlerID)->second();
- }
-
- __attribute__((export_name("ExecuteMouseMoveHandler"))) void ExecuteMouseMoveHandler(std::int32_t handlerID) {
- Crafter::CppDOMBindings::mouseMoveHandlers->find(handlerID)->second();
- }
-
- __attribute__((export_name("ExecuteMouseDownHandler"))) void ExecuteMouseDownHandler(std::int32_t handlerID) {
- Crafter::CppDOMBindings::mouseDownHandlers->find(handlerID)->second();
- }
-
- __attribute__((export_name("ExecuteMouseUpHandler"))) void ExecuteMouseUpHandler(std::int32_t handlerID) {
- Crafter::CppDOMBindings::mouseUpHandlers->find(handlerID)->second();
- }
-
- __attribute__((export_name("ExecuteFocusHandler"))) void ExecuteFocusHandler(std::int32_t handlerID) {
- Crafter::CppDOMBindings::focusHandlers->find(handlerID)->second();
- }
-
- __attribute__((export_name("ExecuteBlurHandler"))) void ExecuteBlurHandler(std::int32_t handlerID) {
- Crafter::CppDOMBindings::blurHandlers->find(handlerID)->second();
- }
-
- __attribute__((export_name("ExecuteKeyDownHandler"))) void ExecuteKeyDownHandler(std::int32_t handlerID, const char* key, std::int32_t keyCode, bool altKey, bool ctrlKey, bool shiftKey, bool metaKey) {
- Crafter::CppDOMBindings::keyDownHandlers->find(handlerID)->second(Crafter::KeyboardEvent(key, keyCode, altKey, ctrlKey, shiftKey, metaKey));
- }
-
- __attribute__((export_name("ExecuteKeyUpHandler"))) void ExecuteKeyUpHandler(std::int32_t handlerID, const char* key, std::int32_t keyCode, bool altKey, bool ctrlKey, bool shiftKey, bool metaKey) {
- Crafter::CppDOMBindings::keyUpHandlers->find(handlerID)->second(Crafter::KeyboardEvent(key, keyCode, altKey, ctrlKey, shiftKey, metaKey));
- }
-
- __attribute__((export_name("ExecuteKeyPressHandler"))) void ExecuteKeyPressHandler(std::int32_t handlerID, const char* key, std::int32_t keyCode, bool altKey, bool ctrlKey, bool shiftKey, bool metaKey) {
- Crafter::CppDOMBindings::keyPressHandlers->find(handlerID)->second(Crafter::KeyboardEvent(key, keyCode, altKey, ctrlKey, shiftKey, metaKey));
- }
-
- __attribute__((export_name("ExecuteChangeHandler"))) void ExecuteChangeHandler(std::int32_t handlerID, const char* value) {
- Crafter::CppDOMBindings::changeHandlers->find(handlerID)->second(Crafter::ChangeEvent(value));
- }
-
- __attribute__((export_name("ExecuteSubmitHandler"))) void ExecuteSubmitHandler(std::int32_t handlerID) {
- Crafter::CppDOMBindings::submitHandlers->find(handlerID)->second();
- }
-
- __attribute__((export_name("ExecuteInputHandler"))) void ExecuteInputHandler(std::int32_t handlerID, const char* data, bool isComposing) {
- Crafter::CppDOMBindings::inputHandlers->find(handlerID)->second(Crafter::InputEvent(data, isComposing));
- }
-
- __attribute__((export_name("ExecuteResizeHandler"))) void ExecuteResizeHandler(std::int32_t handlerID, unsigned int width, unsigned int height) {
- Crafter::CppDOMBindings::resizeHandlers->find(handlerID)->second(Crafter::ResizeEvent(width, height));
- }
-
- __attribute__((export_name("ExecuteScrollHandler"))) void ExecuteScrollHandler(std::int32_t handlerID, double scrollX, double scrollY) {
- Crafter::CppDOMBindings::scrollHandlers->find(handlerID)->second(Crafter::ScrollEvent(scrollX, scrollY));
- }
-
- __attribute__((export_name("ExecuteContextMenuHandler"))) void ExecuteContextMenuHandler(std::int32_t handlerID, double clientX, double clientY, double screenX, double screenY, int button, bool altKey, bool ctrlKey, bool shiftKey, bool metaKey) {
- Crafter::CppDOMBindings::contextMenuHandlers->find(handlerID)->second(Crafter::MouseEvent(clientX, clientY, screenX, screenY, button, 0, altKey, ctrlKey, shiftKey, metaKey));
- }
-
- __attribute__((export_name("ExecuteDragStartHandler"))) void ExecuteDragStartHandler(std::int32_t handlerID, double clientX, double clientY, double screenX, double screenY, int button, bool altKey, bool ctrlKey, bool shiftKey, bool metaKey) {
- Crafter::CppDOMBindings::dragStartHandlers->find(handlerID)->second(Crafter::MouseEvent(clientX, clientY, screenX, screenY, button, 0, altKey, ctrlKey, shiftKey, metaKey));
- }
-
- __attribute__((export_name("ExecuteDragEndHandler"))) void ExecuteDragEndHandler(std::int32_t handlerID, double clientX, double clientY, double screenX, double screenY, int button, bool altKey, bool ctrlKey, bool shiftKey, bool metaKey) {
- Crafter::CppDOMBindings::dragEndHandlers->find(handlerID)->second(Crafter::MouseEvent(clientX, clientY, screenX, screenY, button, 0, altKey, ctrlKey, shiftKey, metaKey));
- }
-
- __attribute__((export_name("ExecuteDropHandler"))) void ExecuteDropHandler(std::int32_t handlerID, double clientX, double clientY, double screenX, double screenY, int button, bool altKey, bool ctrlKey, bool shiftKey, bool metaKey) {
- Crafter::CppDOMBindings::dropHandlers->find(handlerID)->second(Crafter::MouseEvent(clientX, clientY, screenX, screenY, button, 0, altKey, ctrlKey, shiftKey, metaKey));
- }
-
- __attribute__((export_name("ExecuteWheelHandler"))) void ExecuteWheelHandler(std::int32_t handlerID, double deltaX, double deltaY, double deltaZ, int deltaMode, double clientX, double clientY, double screenX, double screenY, int button, bool altKey, bool ctrlKey, bool shiftKey, bool metaKey) {
- Crafter::CppDOMBindings::wheelHandlers->find(handlerID)->second(Crafter::WheelEvent(clientX, clientY, screenX, screenY, button, 0, altKey, ctrlKey, shiftKey, metaKey, deltaX, deltaY, deltaZ));
- }
-
- __attribute__((export_name("ExecuteDragOverHandler"))) void ExecuteDragOverHandler(std::int32_t handlerID, double clientX, double clientY, double screenX, double screenY, int button, bool altKey, bool ctrlKey, bool shiftKey, bool metaKey) {
- Crafter::CppDOMBindings::dragOverHandlers->find(handlerID)->second(Crafter::MouseEvent(clientX, clientY, screenX, screenY, button, 0, altKey, ctrlKey, shiftKey, metaKey));
- }
-
- __attribute__((export_name("ExecuteDragEnterHandler"))) void ExecuteDragEnterHandler(std::int32_t handlerID, double clientX, double clientY, double screenX, double screenY, int button, bool altKey, bool ctrlKey, bool shiftKey, bool metaKey) {
- Crafter::CppDOMBindings::dragEnterHandlers->find(handlerID)->second(Crafter::MouseEvent(clientX, clientY, screenX, screenY, button, 0, altKey, ctrlKey, shiftKey, metaKey));
- }
-
- __attribute__((export_name("ExecuteDragLeaveHandler"))) void ExecuteDragLeaveHandler(std::int32_t handlerID, double clientX, double clientY, double screenX, double screenY, int button, bool altKey, bool ctrlKey, bool shiftKey, bool metaKey) {
- Crafter::CppDOMBindings::dragLeaveHandlers->find(handlerID)->second(Crafter::MouseEvent(clientX, clientY, screenX, screenY, button, 0, altKey, ctrlKey, shiftKey, metaKey));
- }
-}
\ No newline at end of file
diff --git a/interfaces/Crafter.CppDOM-BindingsImport.cppm b/interfaces/Crafter.CppDOM-BindingsImport.cppm
deleted file mode 100644
index 32ea9ec..0000000
--- a/interfaces/Crafter.CppDOM-BindingsImport.cppm
+++ /dev/null
@@ -1,108 +0,0 @@
-/*
-Crafter.CppDOM
-Copyright (C) 2025 Catcrafts
-Catcrafts.net
-
-This library is free software; you can redistribute it and/or
-modify it under the terms of the GNU Lesser General Public
-License as published by the Free Software Foundation; either
-version 3.0 of the License, or (at your option) any later version.
-
-This library is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
-Lesser General Public License for more details.
-
-You should have received a copy of the GNU Lesser General Public
-License along with this library; if not, write to the Free Software
-Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
-*/
-
-export module Crafter.CppDOM:BindingsImport;
-import std;
-import :EventTypes;
-
-export namespace Crafter::CppDOMBindings {
- __attribute__((import_module("env"), import_name("freeJs"))) void FreeJs(void* ptr);
- __attribute__((import_module("env"), import_name("getElementById"))) void* GetElementById(const char* id, std::size_t idLenght);
- void* GetElementById(const std::string_view id) {
- return GetElementById(id.data(), id.size());
- }
- __attribute__((import_module("env"), import_name("setInnerHTML"))) void SetInnerHTML(void* ptr, const char* html, std::size_t htmlLenght);
- void SetInnerHTML(void* ptr, const std::string_view html) {
- SetInnerHTML(ptr, html.data(), html.size());
- }
-
- // Event handling functions
- __attribute__((import_module("env"), import_name("addClickListener"))) void AddClickListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeClickListener"))) void RemoveClickListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addMouseOverListener"))) void AddMouseOverListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeMouseOverListener"))) void RemoveMouseOverListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addMouseOutListener"))) void AddMouseOutListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeMouseOutListener"))) void RemoveMouseOutListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addMouseMoveListener"))) void AddMouseMoveListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeMouseMoveListener"))) void RemoveMouseMoveListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addMouseDownListener"))) void AddMouseDownListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeMouseDownListener"))) void RemoveMouseDownListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addMouseUpListener"))) void AddMouseUpListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeMouseUpListener"))) void RemoveMouseUpListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addFocusListener"))) void AddFocusListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeFocusListener"))) void RemoveFocusListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addBlurListener"))) void AddBlurListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeBlurListener"))) void RemoveBlurListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addKeyDownListener"))) void AddKeyDownListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeKeyDownListener"))) void RemoveKeyDownListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addKeyUpListener"))) void AddKeyUpListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeKeyUpListener"))) void RemoveKeyUpListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addKeyPressListener"))) void AddKeyPressListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeKeyPressListener"))) void RemoveKeyPressListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addChangeListener"))) void AddChangeListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeChangeListener"))) void RemoveChangeListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addSubmitListener"))) void AddSubmitListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeSubmitListener"))) void RemoveSubmitListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addInputListener"))) void AddInputListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeInputListener"))) void RemoveInputListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addResizeListener"))) void AddResizeListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeResizeListener"))) void RemoveResizeListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addScrollListener"))) void AddScrollListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeScrollListener"))) void RemoveScrollListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addContextMenuListener"))) void AddContextMenuListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeContextMenuListener"))) void RemoveContextMenuListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addDragStartListener"))) void AddDragStartListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeDragStartListener"))) void RemoveDragStartListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addDragEndListener"))) void AddDragEndListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeDragEndListener"))) void RemoveDragEndListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addDropListener"))) void AddDropListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeDropListener"))) void RemoveDropListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addWheelListener"))) void AddWheelListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeWheelListener"))) void RemoveWheelListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addDragOverListener"))) void AddDragOverListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeDragOverListener"))) void RemoveDragOverListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addDragEnterListener"))) void AddDragEnterListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeDragEnterListener"))) void RemoveDragEnterListener(void* ptr, int id);
-
- __attribute__((import_module("env"), import_name("addDragLeaveListener"))) void AddDragLeaveListener(void* ptr, int id);
- __attribute__((import_module("env"), import_name("removeDragLeaveListener"))) void RemoveDragLeaveListener(void* ptr, int id);
-}
\ No newline at end of file
diff --git a/interfaces/Crafter.CppDOM-EventTypes.cppm b/interfaces/Crafter.CppDOM-EventTypes.cppm
deleted file mode 100644
index ad92c2f..0000000
--- a/interfaces/Crafter.CppDOM-EventTypes.cppm
+++ /dev/null
@@ -1,79 +0,0 @@
-/*
-Crafter.CppDOM
-Copyright (C) 2025 Catcrafts
-Catcrafts.net
-
-This library is free software; you can redistribute it and/or
-modify it under the terms of the GNU Lesser General Public
-License as published by the Free Software Foundation; either
-version 3.0 of the License, or (at your option) any later version.
-
-This library is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
-Lesser General Public License for more details.
-
-You should have received a copy of the GNU Lesser General Public
-License along with this library; if not, write to the Free Software
-Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
-*/
-
-export module Crafter.CppDOM:EventTypes;
-import std;
-
-export namespace Crafter {
- struct KeyboardEvent {
- std::string key;
- std::uint_fast8_t keyCode;
- bool altKey;
- bool ctrlKey;
- bool shiftKey;
- bool metaKey;
- KeyboardEvent(const char* key, std::int32_t keyCode, bool altKey, bool ctrlKey, bool shiftKey, bool metaKey) : key(key), keyCode(keyCode), altKey(altKey), ctrlKey(ctrlKey), shiftKey(shiftKey), metaKey(metaKey) {}
- };
-
- // Mouse event structure
- struct MouseEvent {
- double clientX;
- double clientY;
- double screenX;
- double screenY;
- std::uint_fast32_t button;
- std::uint_fast32_t buttons;
- bool altKey;
- bool ctrlKey;
- bool shiftKey;
- bool metaKey;
- MouseEvent(double clientX, double clientY, double screenX, double screenY, std::uint_fast32_t button, std::uint_fast32_t buttons, bool altKey, bool ctrlKey, bool shiftKey, bool metaKey) : clientX(clientX), clientY(clientY), screenX(screenX), screenY(screenY), button(button), buttons(buttons), altKey(altKey), ctrlKey(ctrlKey), shiftKey(shiftKey), metaKey(metaKey) {}
- };
-
- struct InputEvent {
- std::string data;
- bool isComposing;
- InputEvent(const char* data, bool isComposing) : data(data), isComposing(isComposing) {}
- };
-
- struct WheelEvent : public MouseEvent {
- double deltaX;
- double deltaY;
- double deltaZ;
- WheelEvent(double clientX, double clientY, double screenX, double screenY, std::uint_fast32_t button, std::uint_fast32_t buttons, bool altKey, bool ctrlKey, bool shiftKey, bool metaKey, double deltaX, double deltaY, double deltaZ): MouseEvent(clientX, clientY, screenX, screenY, button, buttons, altKey, ctrlKey, shiftKey, metaKey), deltaX(deltaX), deltaY(deltaY), deltaZ(deltaZ) {}
- };
-
- struct ResizeEvent {
- std::uint_fast32_t width;
- std::uint_fast32_t height;
- ResizeEvent(std::uint_fast32_t width, std::uint_fast32_t height) : width(width), height(height) {}
- };
-
- struct ScrollEvent {
- double scrollX;
- double scrollY;
- ScrollEvent(double scrollX, double scrollY) : scrollX(scrollX), scrollY(scrollY) {}
- };
-
- struct ChangeEvent {
- std::string value;
- ChangeEvent(const char* value) : value(value) {}
- };
-}
\ No newline at end of file
diff --git a/interfaces/Crafter.CppDOM-HtmlElement.cppm b/interfaces/Crafter.CppDOM-HtmlElement.cppm
index 8411b2c..d79185f 100644
--- a/interfaces/Crafter.CppDOM-HtmlElement.cppm
+++ b/interfaces/Crafter.CppDOM-HtmlElement.cppm
@@ -20,491 +20,312 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
export module Crafter.CppDOM:HtmlElement;
import std;
-import :BindingsExport;
-import :BindingsImport;
-import :EventTypes;
+import :Bindings;
namespace Crafter {
export class HtmlElement {
public:
void* const ptr;
- std::vector clickHandlers;
- std::vector mouseOverHandlers;
- std::vector mouseOutHandlers;
- std::vector mouseMoveHandlers;
- std::vector mouseDownHandlers;
- std::vector mouseUpHandlers;
- std::vector focusHandlers;
- std::vector blurHandlers;
- std::vector keyDownHandlers;
- std::vector keyUpHandlers;
- std::vector keyPressHandlers;
- std::vector changeHandlers;
- std::vector submitHandlers;
- std::vector inputHandlers;
- std::vector resizeHandlers;
- std::vector scrollHandlers;
- std::vector contextMenuHandlers;
- std::vector dragStartHandlers;
- std::vector dragEndHandlers;
- std::vector dropHandlers;
- std::vector dragOverHandlers;
- std::vector dragEnterHandlers;
- std::vector dragLeaveHandlers;
- std::vector wheelHandlers;
-
- HtmlElement(const std::string_view id): ptr(CppDOMBindings::GetElementById(id)) {
+ std::vector handlers;
+ HtmlElement(const std::string_view id): ptr(CppDOM::Bindings::GetElementById(id)) {
}
- HtmlElement(const std::string_view id, const std::string_view html): ptr(CppDOMBindings::GetElementById(id)) {
- CppDOMBindings::SetInnerHTML(ptr, html);
+ HtmlElement(const std::string_view id, const std::string_view html): ptr(CppDOM::Bindings::GetElementById(id)) {
+ CppDOM::Bindings::SetInnerHTML(ptr, html);
}
- void SetInnerHTML(const std::string_view html) {
- CppDOMBindings::SetInnerHTML(ptr, html);
+ void SetInnerHTML(const std::string_view& html) {
+ CppDOM::Bindings::SetInnerHTML(ptr, html);
}
- std::int32_t AddClickListener(std::function callback) {
- std::int32_t id = CppDOMBindings::clickHandlerMaxId++;
- clickHandlers.push_back(id);
- CppDOMBindings::clickHandlers->insert({id, callback});
- CppDOMBindings::AddClickListener(ptr, id);
+ // Event handling methods
+ int AddClickListener(std::function callback) {
+ int id = CppDOM::Bindings::clickHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::clickHandlers->insert({id, callback});
+ CppDOM::Bindings::AddClickListener(ptr, id);
return id;
}
- void RemoveClickListener(std::int32_t id) {
- clickHandlers.erase(std::remove(clickHandlers.begin(), clickHandlers.end(), id), clickHandlers.end());
- CppDOMBindings::clickHandlers->erase(id);
- CppDOMBindings::RemoveClickListener(ptr, id);
+ void RemoveClickListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::clickHandlers->erase(id);
+ CppDOM::Bindings::RemoveClickListener(ptr, id);
}
- std::int32_t AddMouseOverListener(std::function callback) {
- std::int32_t id = CppDOMBindings::mouseOverHandlerMaxId++;
- mouseOverHandlers.push_back(id);
- CppDOMBindings::mouseOverHandlers->insert({id, callback});
- CppDOMBindings::AddMouseOverListener(ptr, id);
+ int AddMouseOverListener(std::function callback) {
+ int id = CppDOM::Bindings::mouseOverHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::mouseOverHandlers->insert({id, callback});
+ CppDOM::Bindings::AddMouseOverListener(ptr, id);
return id;
}
- void RemoveMouseOverListener(std::int32_t id) {
- mouseOverHandlers.erase(std::remove(mouseOverHandlers.begin(), mouseOverHandlers.end(), id), mouseOverHandlers.end());
- CppDOMBindings::mouseOverHandlers->erase(id);
- CppDOMBindings::RemoveMouseOverListener(ptr, id);
+ void RemoveMouseOverListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::mouseOverHandlers->erase(id);
+ CppDOM::Bindings::RemoveMouseOverListener(ptr, id);
}
- std::int32_t AddMouseOutListener(std::function callback) {
- std::int32_t id = CppDOMBindings::mouseOutHandlerMaxId++;
- mouseOutHandlers.push_back(id);
- CppDOMBindings::mouseOutHandlers->insert({id, callback});
- CppDOMBindings::AddMouseOutListener(ptr, id);
+ int AddMouseOutListener(std::function callback) {
+ int id = CppDOM::Bindings::mouseOutHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::mouseOutHandlers->insert({id, callback});
+ CppDOM::Bindings::AddMouseOutListener(ptr, id);
return id;
}
- void RemoveMouseOutListener(std::int32_t id) {
- mouseOutHandlers.erase(std::remove(mouseOutHandlers.begin(), mouseOutHandlers.end(), id), mouseOutHandlers.end());
- CppDOMBindings::mouseOutHandlers->erase(id);
- CppDOMBindings::RemoveMouseOutListener(ptr, id);
+ void RemoveMouseOutListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::mouseOutHandlers->erase(id);
+ CppDOM::Bindings::RemoveMouseOutListener(ptr, id);
}
- std::int32_t AddMouseMoveListener(std::function callback) {
- std::int32_t id = CppDOMBindings::mouseMoveHandlerMaxId++;
- mouseMoveHandlers.push_back(id);
- CppDOMBindings::mouseMoveHandlers->insert({id, callback});
- CppDOMBindings::AddMouseMoveListener(ptr, id);
+ int AddMouseMoveListener(std::function callback) {
+ int id = CppDOM::Bindings::mouseMoveHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::mouseMoveHandlers->insert({id, callback});
+ CppDOM::Bindings::AddMouseMoveListener(ptr, id);
return id;
}
- void RemoveMouseMoveListener(std::int32_t id) {
- mouseMoveHandlers.erase(std::remove(mouseMoveHandlers.begin(), mouseMoveHandlers.end(), id), mouseMoveHandlers.end());
- CppDOMBindings::mouseMoveHandlers->erase(id);
- CppDOMBindings::RemoveMouseMoveListener(ptr, id);
+ void RemoveMouseMoveListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::mouseMoveHandlers->erase(id);
+ CppDOM::Bindings::RemoveMouseMoveListener(ptr, id);
}
- std::int32_t AddMouseDownListener(std::function callback) {
- std::int32_t id = CppDOMBindings::mouseDownHandlerMaxId++;
- mouseDownHandlers.push_back(id);
- CppDOMBindings::mouseDownHandlers->insert({id, callback});
- CppDOMBindings::AddMouseDownListener(ptr, id);
+ int AddFocusListener(std::function callback) {
+ int id = CppDOM::Bindings::focusHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::focusHandlers->insert({id, callback});
+ CppDOM::Bindings::AddFocusListener(ptr, id);
return id;
}
- void RemoveMouseDownListener(std::int32_t id) {
- mouseDownHandlers.erase(std::remove(mouseDownHandlers.begin(), mouseDownHandlers.end(), id), mouseDownHandlers.end());
- CppDOMBindings::mouseDownHandlers->erase(id);
- CppDOMBindings::RemoveMouseDownListener(ptr, id);
+ void RemoveFocusListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::focusHandlers->erase(id);
+ CppDOM::Bindings::RemoveFocusListener(ptr, id);
}
- std::int32_t AddMouseUpListener(std::function callback) {
- std::int32_t id = CppDOMBindings::mouseUpHandlerMaxId++;
- mouseUpHandlers.push_back(id);
- CppDOMBindings::mouseUpHandlers->insert({id, callback});
- CppDOMBindings::AddMouseUpListener(ptr, id);
+ int AddBlurListener(std::function callback) {
+ int id = CppDOM::Bindings::blurHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::blurHandlers->insert({id, callback});
+ CppDOM::Bindings::AddBlurListener(ptr, id);
return id;
}
- void RemoveMouseUpListener(std::int32_t id) {
- mouseUpHandlers.erase(std::remove(mouseUpHandlers.begin(), mouseUpHandlers.end(), id), mouseUpHandlers.end());
- CppDOMBindings::mouseUpHandlers->erase(id);
- CppDOMBindings::RemoveMouseUpListener(ptr, id);
+ void RemoveBlurListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::blurHandlers->erase(id);
+ CppDOM::Bindings::RemoveBlurListener(ptr, id);
}
- // Focus Events
- std::int32_t AddFocusListener(std::function callback) {
- std::int32_t id = CppDOMBindings::focusHandlerMaxId++;
- focusHandlers.push_back(id);
- CppDOMBindings::focusHandlers->insert({id, callback});
- CppDOMBindings::AddFocusListener(ptr, id);
+ int AddKeyDownListener(std::function callback) {
+ int id = CppDOM::Bindings::keyDownHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::keyDownHandlers->insert({id, callback});
+ CppDOM::Bindings::AddKeyDownListener(ptr, id);
return id;
}
- void RemoveFocusListener(std::int32_t id) {
- focusHandlers.erase(std::remove(focusHandlers.begin(), focusHandlers.end(), id), focusHandlers.end());
- CppDOMBindings::focusHandlers->erase(id);
- CppDOMBindings::RemoveFocusListener(ptr, id);
+ void RemoveKeyDownListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::keyDownHandlers->erase(id);
+ CppDOM::Bindings::RemoveKeyDownListener(ptr, id);
}
- std::int32_t AddBlurListener(std::function callback) {
- std::int32_t id = CppDOMBindings::blurHandlerMaxId++;
- blurHandlers.push_back(id);
- CppDOMBindings::blurHandlers->insert({id, callback});
- CppDOMBindings::AddBlurListener(ptr, id);
+ int AddKeyUpListener(std::function callback) {
+ int id = CppDOM::Bindings::keyUpHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::keyUpHandlers->insert({id, callback});
+ CppDOM::Bindings::AddKeyUpListener(ptr, id);
return id;
}
- void RemoveBlurListener(std::int32_t id) {
- blurHandlers.erase(std::remove(blurHandlers.begin(), blurHandlers.end(), id), blurHandlers.end());
- CppDOMBindings::blurHandlers->erase(id);
- CppDOMBindings::RemoveBlurListener(ptr, id);
+ void RemoveKeyUpListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::keyUpHandlers->erase(id);
+ CppDOM::Bindings::RemoveKeyUpListener(ptr, id);
}
- // Keyboard Events
- std::int32_t AddKeyDownListener(std::function callback) {
- std::int32_t id = CppDOMBindings::keyDownHandlerMaxId++;
- keyDownHandlers.push_back(id);
- CppDOMBindings::keyDownHandlers->insert({id, callback});
- CppDOMBindings::AddKeyDownListener(ptr, id);
+ int AddKeyPressListener(std::function callback) {
+ int id = CppDOM::Bindings::keyPressHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::keyPressHandlers->insert({id, callback});
+ CppDOM::Bindings::AddKeyPressListener(ptr, id);
return id;
}
- void RemoveKeyDownListener(std::int32_t id) {
- keyDownHandlers.erase(std::remove(keyDownHandlers.begin(), keyDownHandlers.end(), id), keyDownHandlers.end());
- CppDOMBindings::keyDownHandlers->erase(id);
- CppDOMBindings::RemoveKeyDownListener(ptr, id);
+ void RemoveKeyPressListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::keyPressHandlers->erase(id);
+ CppDOM::Bindings::RemoveKeyPressListener(ptr, id);
}
- std::int32_t AddKeyUpListener(std::function callback) {
- std::int32_t id = CppDOMBindings::keyUpHandlerMaxId++;
- keyUpHandlers.push_back(id);
- CppDOMBindings::keyUpHandlers->insert({id, callback});
- CppDOMBindings::AddKeyUpListener(ptr, id);
+ int AddChangeListener(std::function callback) {
+ int id = CppDOM::Bindings::changeHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::changeHandlers->insert({id, callback});
+ CppDOM::Bindings::AddChangeListener(ptr, id);
return id;
}
- void RemoveKeyUpListener(std::int32_t id) {
- keyUpHandlers.erase(std::remove(keyUpHandlers.begin(), keyUpHandlers.end(), id), keyUpHandlers.end());
- CppDOMBindings::keyUpHandlers->erase(id);
- CppDOMBindings::RemoveKeyUpListener(ptr, id);
+ void RemoveChangeListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::changeHandlers->erase(id);
+ CppDOM::Bindings::RemoveChangeListener(ptr, id);
}
- std::int32_t AddKeyPressListener(std::function callback) {
- std::int32_t id = CppDOMBindings::keyPressHandlerMaxId++;
- keyPressHandlers.push_back(id);
- CppDOMBindings::keyPressHandlers->insert({id, callback});
- CppDOMBindings::AddKeyPressListener(ptr, id);
+ int AddSubmitListener(std::function callback) {
+ int id = CppDOM::Bindings::submitHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::submitHandlers->insert({id, callback});
+ CppDOM::Bindings::AddSubmitListener(ptr, id);
return id;
}
- void RemoveKeyPressListener(std::int32_t id) {
- keyPressHandlers.erase(std::remove(keyPressHandlers.begin(), keyPressHandlers.end(), id), keyPressHandlers.end());
- CppDOMBindings::keyPressHandlers->erase(id);
- CppDOMBindings::RemoveKeyPressListener(ptr, id);
+ void RemoveSubmitListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::submitHandlers->erase(id);
+ CppDOM::Bindings::RemoveSubmitListener(ptr, id);
}
- // Form Events
- std::int32_t AddChangeListener(std::function callback) {
- std::int32_t id = CppDOMBindings::changeHandlerMaxId++;
- changeHandlers.push_back(id);
- CppDOMBindings::changeHandlers->insert({id, callback});
- CppDOMBindings::AddChangeListener(ptr, id);
+ int AddInputListener(std::function callback) {
+ int id = CppDOM::Bindings::inputHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::inputHandlers->insert({id, callback});
+ CppDOM::Bindings::AddInputListener(ptr, id);
return id;
}
- void RemoveChangeListener(std::int32_t id) {
- changeHandlers.erase(std::remove(changeHandlers.begin(), changeHandlers.end(), id), changeHandlers.end());
- CppDOMBindings::changeHandlers->erase(id);
- CppDOMBindings::RemoveChangeListener(ptr, id);
+ void RemoveInputListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::inputHandlers->erase(id);
+ CppDOM::Bindings::RemoveInputListener(ptr, id);
}
- std::int32_t AddSubmitListener(std::function callback) {
- std::int32_t id = CppDOMBindings::submitHandlerMaxId++;
- submitHandlers.push_back(id);
- CppDOMBindings::submitHandlers->insert({id, callback});
- CppDOMBindings::AddSubmitListener(ptr, id);
+ int AddLoadListener(std::function callback) {
+ int id = CppDOM::Bindings::loadHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::loadHandlers->insert({id, callback});
+ CppDOM::Bindings::AddLoadListener(ptr, id);
return id;
}
- void RemoveSubmitListener(std::int32_t id) {
- submitHandlers.erase(std::remove(submitHandlers.begin(), submitHandlers.end(), id), submitHandlers.end());
- CppDOMBindings::submitHandlers->erase(id);
- CppDOMBindings::RemoveSubmitListener(ptr, id);
+ void RemoveLoadListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::loadHandlers->erase(id);
+ CppDOM::Bindings::RemoveLoadListener(ptr, id);
}
- std::int32_t AddInputListener(std::function callback) {
- std::int32_t id = CppDOMBindings::inputHandlerMaxId++;
- inputHandlers.push_back(id);
- CppDOMBindings::inputHandlers->insert({id, callback});
- CppDOMBindings::AddInputListener(ptr, id);
+ int AddErrorListener(std::function callback) {
+ int id = CppDOM::Bindings::errorHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::errorHandlers->insert({id, callback});
+ CppDOM::Bindings::AddErrorListener(ptr, id);
return id;
}
- void RemoveInputListener(std::int32_t id) {
- inputHandlers.erase(std::remove(inputHandlers.begin(), inputHandlers.end(), id), inputHandlers.end());
- CppDOMBindings::inputHandlers->erase(id);
- CppDOMBindings::RemoveInputListener(ptr, id);
+ void RemoveErrorListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::errorHandlers->erase(id);
+ CppDOM::Bindings::RemoveErrorListener(ptr, id);
}
- std::int32_t AddResizeListener(std::function callback) {
- std::int32_t id = CppDOMBindings::resizeHandlerMaxId++;
- resizeHandlers.push_back(id);
- CppDOMBindings::resizeHandlers->insert({id, callback});
- CppDOMBindings::AddResizeListener(ptr, id);
+ int AddResizeListener(std::function callback) {
+ int id = CppDOM::Bindings::resizeHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::resizeHandlers->insert({id, callback});
+ CppDOM::Bindings::AddResizeListener(ptr, id);
return id;
}
- void RemoveResizeListener(std::int32_t id) {
- resizeHandlers.erase(std::remove(resizeHandlers.begin(), resizeHandlers.end(), id), resizeHandlers.end());
- CppDOMBindings::resizeHandlers->erase(id);
- CppDOMBindings::RemoveResizeListener(ptr, id);
+ void RemoveResizeListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::resizeHandlers->erase(id);
+ CppDOM::Bindings::RemoveResizeListener(ptr, id);
}
- std::int32_t AddScrollListener(std::function callback) {
- std::int32_t id = CppDOMBindings::scrollHandlerMaxId++;
- scrollHandlers.push_back(id);
- CppDOMBindings::scrollHandlers->insert({id, callback});
- CppDOMBindings::AddScrollListener(ptr, id);
+ int AddScrollListener(std::function callback) {
+ int id = CppDOM::Bindings::scrollHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::scrollHandlers->insert({id, callback});
+ CppDOM::Bindings::AddScrollListener(ptr, id);
return id;
}
- void RemoveScrollListener(std::int32_t id) {
- scrollHandlers.erase(std::remove(scrollHandlers.begin(), scrollHandlers.end(), id), scrollHandlers.end());
- CppDOMBindings::scrollHandlers->erase(id);
- CppDOMBindings::RemoveScrollListener(ptr, id);
+ void RemoveScrollListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::scrollHandlers->erase(id);
+ CppDOM::Bindings::RemoveScrollListener(ptr, id);
}
- // Context Menu Events
- std::int32_t AddContextMenuListener(std::function callback) {
- std::int32_t id = CppDOMBindings::contextMenuHandlerMaxId++;
- contextMenuHandlers.push_back(id);
- CppDOMBindings::contextMenuHandlers->insert({id, callback});
- CppDOMBindings::AddContextMenuListener(ptr, id);
+ int AddContextMenuListener(std::function callback) {
+ int id = CppDOM::Bindings::contextMenuHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::contextMenuHandlers->insert({id, callback});
+ CppDOM::Bindings::AddContextMenuListener(ptr, id);
return id;
}
- void RemoveContextMenuListener(std::int32_t id) {
- contextMenuHandlers.erase(std::remove(contextMenuHandlers.begin(), contextMenuHandlers.end(), id), contextMenuHandlers.end());
- CppDOMBindings::contextMenuHandlers->erase(id);
- CppDOMBindings::RemoveContextMenuListener(ptr, id);
+ void RemoveContextMenuListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::contextMenuHandlers->erase(id);
+ CppDOM::Bindings::RemoveContextMenuListener(ptr, id);
}
- // Drag and Drop Events
- std::int32_t AddDragStartListener(std::function callback) {
- std::int32_t id = CppDOMBindings::dragStartHandlerMaxId++;
- dragStartHandlers.push_back(id);
- CppDOMBindings::dragStartHandlers->insert({id, callback});
- CppDOMBindings::AddDragStartListener(ptr, id);
+ int AddDragStartListener(std::function callback) {
+ int id = CppDOM::Bindings::dragStartHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::dragStartHandlers->insert({id, callback});
+ CppDOM::Bindings::AddDragStartListener(ptr, id);
return id;
}
- void RemoveDragStartListener(std::int32_t id) {
- dragStartHandlers.erase(std::remove(dragStartHandlers.begin(), dragStartHandlers.end(), id), dragStartHandlers.end());
- CppDOMBindings::dragStartHandlers->erase(id);
- CppDOMBindings::RemoveDragStartListener(ptr, id);
+ void RemoveDragStartListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::dragStartHandlers->erase(id);
+ CppDOM::Bindings::RemoveDragStartListener(ptr, id);
}
- std::int32_t AddDragEndListener(std::function callback) {
- std::int32_t id = CppDOMBindings::dragEndHandlerMaxId++;
- dragEndHandlers.push_back(id);
- CppDOMBindings::dragEndHandlers->insert({id, callback});
- CppDOMBindings::AddDragEndListener(ptr, id);
+ int AddDragEndListener(std::function callback) {
+ int id = CppDOM::Bindings::dragEndHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::dragEndHandlers->insert({id, callback});
+ CppDOM::Bindings::AddDragEndListener(ptr, id);
return id;
}
- void RemoveDragEndListener(std::int32_t id) {
- dragEndHandlers.erase(std::remove(dragEndHandlers.begin(), dragEndHandlers.end(), id), dragEndHandlers.end());
- CppDOMBindings::dragEndHandlers->erase(id);
- CppDOMBindings::RemoveDragEndListener(ptr, id);
+ void RemoveDragEndListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::dragEndHandlers->erase(id);
+ CppDOM::Bindings::RemoveDragEndListener(ptr, id);
}
- std::int32_t AddDropListener(std::function callback) {
- std::int32_t id = CppDOMBindings::dropHandlerMaxId++;
- dropHandlers.push_back(id);
- CppDOMBindings::dropHandlers->insert({id, callback});
- CppDOMBindings::AddDropListener(ptr, id);
+ int AddDropListener(std::function callback) {
+ int id = CppDOM::Bindings::dropHandlerMaxId++;
+ handlers.push_back(id);
+ CppDOM::Bindings::dropHandlers->insert({id, callback});
+ CppDOM::Bindings::AddDropListener(ptr, id);
return id;
}
- void RemoveDropListener(std::int32_t id) {
- dropHandlers.erase(std::remove(dropHandlers.begin(), dropHandlers.end(), id), dropHandlers.end());
- CppDOMBindings::dropHandlers->erase(id);
- CppDOMBindings::RemoveDropListener(ptr, id);
- }
-
- // Additional Drag Events
- std::int32_t AddDragOverListener(std::function callback) {
- std::int32_t id = CppDOMBindings::dragOverHandlerMaxId++;
- dragOverHandlers.push_back(id);
- CppDOMBindings::dragOverHandlers->insert({id, callback});
- CppDOMBindings::AddDragOverListener(ptr, id);
- return id;
- }
-
- void RemoveDragOverListener(std::int32_t id) {
- dragOverHandlers.erase(std::remove(dragOverHandlers.begin(), dragOverHandlers.end(), id), dragOverHandlers.end());
- CppDOMBindings::dragOverHandlers->erase(id);
- CppDOMBindings::RemoveDragOverListener(ptr, id);
- }
-
- std::int32_t AddDragEnterListener(std::function callback) {
- std::int32_t id = CppDOMBindings::dragEnterHandlerMaxId++;
- dragEnterHandlers.push_back(id);
- CppDOMBindings::dragEnterHandlers->insert({id, callback});
- CppDOMBindings::AddDragEnterListener(ptr, id);
- return id;
- }
-
- void RemoveDragEnterListener(std::int32_t id) {
- dragEnterHandlers.erase(std::remove(dragEnterHandlers.begin(), dragEnterHandlers.end(), id), dragEnterHandlers.end());
- CppDOMBindings::dragEnterHandlers->erase(id);
- CppDOMBindings::RemoveDragEnterListener(ptr, id);
- }
-
- std::int32_t AddDragLeaveListener(std::function callback) {
- std::int32_t id = CppDOMBindings::dragLeaveHandlerMaxId++;
- dragLeaveHandlers.push_back(id);
- CppDOMBindings::dragLeaveHandlers->insert({id, callback});
- CppDOMBindings::AddDragLeaveListener(ptr, id);
- return id;
- }
-
- void RemoveDragLeaveListener(std::int32_t id) {
- dragLeaveHandlers.erase(std::remove(dragLeaveHandlers.begin(), dragLeaveHandlers.end(), id), dragLeaveHandlers.end());
- CppDOMBindings::dragLeaveHandlers->erase(id);
- CppDOMBindings::RemoveDragLeaveListener(ptr, id);
- }
-
- // Wheel Event
- std::int32_t AddWheelListener(std::function callback) {
- std::int32_t id = CppDOMBindings::wheelHandlerMaxId++;
- wheelHandlers.push_back(id);
- CppDOMBindings::wheelHandlers->insert({id, callback});
- CppDOMBindings::AddWheelListener(ptr, id);
- return id;
- }
-
- void RemoveWheelListener(std::int32_t id) {
- wheelHandlers.erase(std::remove(wheelHandlers.begin(), wheelHandlers.end(), id), wheelHandlers.end());
- CppDOMBindings::wheelHandlers->erase(id);
- CppDOMBindings::RemoveWheelListener(ptr, id);
+ void RemoveDropListener(int id) {
+ handlers.erase(std::remove(handlers.begin(), handlers.end(), id), handlers.end());
+ CppDOM::Bindings::dropHandlers->erase(id);
+ CppDOM::Bindings::RemoveDropListener(ptr, id);
}
~HtmlElement(){
- // Clean up all handlers by type
- for(std::int32_t handler : clickHandlers) {
- CppDOMBindings::clickHandlers->erase(handler);
- CppDOMBindings::RemoveClickListener(ptr, handler);
+ for(int handler : handlers) {
+ // Clean up all handlers based on type - this is a simplified approach
+ // In practice, you'd want to track handler types to clean them properly
+ CppDOM::Bindings::clickHandlers->erase(handler);
+ CppDOM::Bindings::RemoveClickListener(ptr, handler);
}
- for(std::int32_t handler : mouseOverHandlers) {
- CppDOMBindings::mouseOverHandlers->erase(handler);
- CppDOMBindings::RemoveMouseOverListener(ptr, handler);
- }
- for(std::int32_t handler : mouseOutHandlers) {
- CppDOMBindings::mouseOutHandlers->erase(handler);
- CppDOMBindings::RemoveMouseOutListener(ptr, handler);
- }
- for(std::int32_t handler : mouseMoveHandlers) {
- CppDOMBindings::mouseMoveHandlers->erase(handler);
- CppDOMBindings::RemoveMouseMoveListener(ptr, handler);
- }
- for(std::int32_t handler : mouseDownHandlers) {
- CppDOMBindings::mouseDownHandlers->erase(handler);
- CppDOMBindings::RemoveMouseDownListener(ptr, handler);
- }
- for(std::int32_t handler : mouseUpHandlers) {
- CppDOMBindings::mouseUpHandlers->erase(handler);
- CppDOMBindings::RemoveMouseUpListener(ptr, handler);
- }
- for(std::int32_t handler : focusHandlers) {
- CppDOMBindings::focusHandlers->erase(handler);
- CppDOMBindings::RemoveFocusListener(ptr, handler);
- }
- for(std::int32_t handler : blurHandlers) {
- CppDOMBindings::blurHandlers->erase(handler);
- CppDOMBindings::RemoveBlurListener(ptr, handler);
- }
- for(std::int32_t handler : keyDownHandlers) {
- CppDOMBindings::keyDownHandlers->erase(handler);
- CppDOMBindings::RemoveKeyDownListener(ptr, handler);
- }
- for(std::int32_t handler : keyUpHandlers) {
- CppDOMBindings::keyUpHandlers->erase(handler);
- CppDOMBindings::RemoveKeyUpListener(ptr, handler);
- }
- for(std::int32_t handler : keyPressHandlers) {
- CppDOMBindings::keyPressHandlers->erase(handler);
- CppDOMBindings::RemoveKeyPressListener(ptr, handler);
- }
- for(std::int32_t handler : changeHandlers) {
- CppDOMBindings::changeHandlers->erase(handler);
- CppDOMBindings::RemoveChangeListener(ptr, handler);
- }
- for(std::int32_t handler : submitHandlers) {
- CppDOMBindings::submitHandlers->erase(handler);
- CppDOMBindings::RemoveSubmitListener(ptr, handler);
- }
- for(std::int32_t handler : inputHandlers) {
- CppDOMBindings::inputHandlers->erase(handler);
- CppDOMBindings::RemoveInputListener(ptr, handler);
- }
- for(std::int32_t handler : resizeHandlers) {
- CppDOMBindings::resizeHandlers->erase(handler);
- CppDOMBindings::RemoveResizeListener(ptr, handler);
- }
- for(std::int32_t handler : scrollHandlers) {
- CppDOMBindings::scrollHandlers->erase(handler);
- CppDOMBindings::RemoveScrollListener(ptr, handler);
- }
- for(std::int32_t handler : contextMenuHandlers) {
- CppDOMBindings::contextMenuHandlers->erase(handler);
- CppDOMBindings::RemoveContextMenuListener(ptr, handler);
- }
- for(std::int32_t handler : dragStartHandlers) {
- CppDOMBindings::dragStartHandlers->erase(handler);
- CppDOMBindings::RemoveDragStartListener(ptr, handler);
- }
- for(std::int32_t handler : dragEndHandlers) {
- CppDOMBindings::dragEndHandlers->erase(handler);
- CppDOMBindings::RemoveDragEndListener(ptr, handler);
- }
- for(std::int32_t handler : dropHandlers) {
- CppDOMBindings::dropHandlers->erase(handler);
- CppDOMBindings::RemoveDropListener(ptr, handler);
- }
- for(std::int32_t handler : dragOverHandlers) {
- CppDOMBindings::dragOverHandlers->erase(handler);
- CppDOMBindings::RemoveDragOverListener(ptr, handler);
- }
- for(std::int32_t handler : dragEnterHandlers) {
- CppDOMBindings::dragEnterHandlers->erase(handler);
- CppDOMBindings::RemoveDragEnterListener(ptr, handler);
- }
- for(std::int32_t handler : dragLeaveHandlers) {
- CppDOMBindings::dragLeaveHandlers->erase(handler);
- CppDOMBindings::RemoveDragLeaveListener(ptr, handler);
- }
- for(std::int32_t handler : wheelHandlers) {
- CppDOMBindings::wheelHandlers->erase(handler);
- CppDOMBindings::RemoveWheelListener(ptr, handler);
- }
- CppDOMBindings::FreeJs(ptr);
+ CppDOM::Bindings::FreeJs(ptr);
}
};
}
\ No newline at end of file
diff --git a/interfaces/Crafter.CppDOM.cppm b/interfaces/Crafter.CppDOM.cppm
index 1662b4f..b1f2e0b 100644
--- a/interfaces/Crafter.CppDOM.cppm
+++ b/interfaces/Crafter.CppDOM.cppm
@@ -19,7 +19,5 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
export module Crafter.CppDOM;
-export import :HtmlElement;
-export import :EventTypes;
-export import :BindingsExport;
-export import :BindingsImport;
\ No newline at end of file
+export import :Bindings;
+export import :HtmlElement;
\ No newline at end of file
diff --git a/project.json b/project.json
index dea2085..330c796 100644
--- a/project.json
+++ b/project.json
@@ -3,7 +3,7 @@
"configurations": [
{
"name": "lib",
- "interfaces": ["interfaces/Crafter.CppDOM-HtmlElement", "interfaces/Crafter.CppDOM", "interfaces/Crafter.CppDOM-BindingsExport", "interfaces/Crafter.CppDOM-BindingsImport", "interfaces/Crafter.CppDOM-EventTypes"],
+ "interfaces": ["interfaces/Crafter.CppDOM-HtmlElement", "interfaces/Crafter.CppDOM", "interfaces/Crafter.CppDOM-Bindings"],
"additional_files": ["additional/env.js"],
"type":"library",
"target":"wasm32-wasi"
@@ -14,4 +14,4 @@
"debug": true
}
]
-}
\ No newline at end of file
+}