diff --git a/src/html/history.zig b/src/html/history.zig
index b507c3ab..f3e96dc0 100644
--- a/src/html/history.zig
+++ b/src/html/history.zig
@@ -28,62 +28,70 @@ const checkCases = jsruntime.test_utils.checkCases;
pub const History = struct {
pub const mem_guarantied = true;
- const ScrollRestaurationMode = enum {
+ const ScrollRestorationMode = enum {
auto,
manual,
};
- scrollRestauration: ScrollRestaurationMode = .audio,
+ scrollRestoration: ScrollRestorationMode = .auto,
+ state: std.json.Value = .null,
- pub fn get_length(_: *History) u64 {
- return 0;
+ // count tracks the history length until we implement correctly pushstate.
+ count: u32 = 0,
+
+ pub fn get_length(self: *History) u32 {
+ // TODO return the real history length value.
+ return self.count;
}
- pub fn get_appCodeName(_: *Navigator) []const u8 {
- return "Mozilla";
+ pub fn get_scrollRestoration(self: *History) []const u8 {
+ return switch (self.scrollRestoration) {
+ .auto => "auto",
+ .manual => "manual",
+ };
}
- pub fn get_appName(_: *Navigator) []const u8 {
- return "Netscape";
+
+ pub fn set_scrollRestoration(self: *History, mode: []const u8) void {
+ if (std.mem.eql(u8, "manual", mode)) self.scrollRestoration = .manual;
+ if (std.mem.eql(u8, "auto", mode)) self.scrollRestoration = .auto;
}
- pub fn get_appVersion(self: *Navigator) []const u8 {
- return self.version;
+
+ pub fn get_state(self: *History) std.json.Value {
+ return self.state;
}
- pub fn get_platform(self: *Navigator) []const u8 {
- return self.platform;
- }
- pub fn get_product(_: *Navigator) []const u8 {
- return "Gecko";
- }
- pub fn get_productSub(_: *Navigator) []const u8 {
- return "20030107";
- }
- pub fn get_vendor(self: *Navigator) []const u8 {
- return self.vendor;
- }
- pub fn get_vendorSub(_: *Navigator) []const u8 {
- return "";
- }
- pub fn get_language(self: *Navigator) []const u8 {
- return self.language;
- }
- // TODO wait for arrays.
- //pub fn get_languages(self: *Navigator) [][]const u8 {
- // return .{self.language};
- //}
- pub fn get_online(_: *Navigator) bool {
- return true;
- }
- pub fn _registerProtocolHandler(_: *Navigator, scheme: []const u8, url: []const u8) void {
- _ = scheme;
- _ = url;
- }
- pub fn _unregisterProtocolHandler(_: *Navigator, scheme: []const u8, url: []const u8) void {
- _ = scheme;
+
+ // TODO implement the function
+ // data must handle any argument. We could expect a std.json.Value but
+ // https://github.com/lightpanda-io/zig-js-runtime/issues/267 is missing.
+ pub fn _pushState(self: *History, data: []const u8, _: ?[]const u8, url: ?[]const u8) void {
+ self.count += 1;
_ = url;
+ _ = data;
}
- pub fn get_cookieEnabled(_: *Navigator) bool {
- return true;
+ // TODO implement the function
+ // data must handle any argument. We could expect a std.json.Value but
+ // https://github.com/lightpanda-io/zig-js-runtime/issues/267 is missing.
+ pub fn _replaceState(self: *History, data: []const u8, _: ?[]const u8, url: ?[]const u8) void {
+ _ = self;
+ _ = url;
+ _ = data;
+ }
+
+ // TODO implement the function
+ pub fn _go(self: *History, delta: ?i32) void {
+ _ = self;
+ _ = delta;
+ }
+
+ // TODO implement the function
+ pub fn _back(self: *History) void {
+ _ = self;
+ }
+
+ // TODO implement the function
+ pub fn _forward(self: *History) void {
+ _ = self;
}
};
@@ -94,11 +102,27 @@ pub fn testExecFn(
_: std.mem.Allocator,
js_env: *jsruntime.Env,
) anyerror!void {
- var navigator = [_]Case{
- .{ .src = "navigator.userAgent", .ex = "Lightpanda/1.0" },
- .{ .src = "navigator.appVersion", .ex = "1.0" },
- .{ .src = "navigator.language", .ex = "en-US" },
- };
- try checkCases(js_env, &navigator);
-}
+ var history = [_]Case{
+ .{ .src = "history.scrollRestoration", .ex = "auto" },
+ .{ .src = "history.scrollRestoration = 'manual'", .ex = "manual" },
+ .{ .src = "history.scrollRestoration = 'foo'", .ex = "foo" },
+ .{ .src = "history.scrollRestoration", .ex = "manual" },
+ .{ .src = "history.scrollRestoration = 'auto'", .ex = "auto" },
+ .{ .src = "history.scrollRestoration", .ex = "auto" },
+ .{ .src = "history.state", .ex = "null" },
+
+ .{ .src = "history.pushState({}, null, '')", .ex = "undefined" },
+
+ .{ .src = "history.replaceState({}, null, '')", .ex = "undefined" },
+
+ .{ .src = "history.go()", .ex = "undefined" },
+ .{ .src = "history.go(1)", .ex = "undefined" },
+ .{ .src = "history.go(-1)", .ex = "undefined" },
+
+ .{ .src = "history.forward()", .ex = "undefined" },
+
+ .{ .src = "history.back()", .ex = "undefined" },
+ };
+ try checkCases(js_env, &history);
+}
diff --git a/src/html/html.zig b/src/html/html.zig
index 2bb439d1..29b467cb 100644
--- a/src/html/html.zig
+++ b/src/html/html.zig
@@ -22,6 +22,7 @@ const HTMLDocument = @import("document.zig").HTMLDocument;
const HTMLElem = @import("elements.zig");
const Window = @import("window.zig").Window;
const Navigator = @import("navigator.zig").Navigator;
+const History = @import("history.zig").History;
pub const Interfaces = generate.Tuple(.{
HTMLDocument,
@@ -30,4 +31,5 @@ pub const Interfaces = generate.Tuple(.{
HTMLElem.Interfaces,
Window,
Navigator,
+ History,
});
diff --git a/src/html/window.zig b/src/html/window.zig
index 414b660d..65a8af67 100644
--- a/src/html/window.zig
+++ b/src/html/window.zig
@@ -26,6 +26,7 @@ const Loop = jsruntime.Loop;
const EventTarget = @import("../dom/event_target.zig").EventTarget;
const Navigator = @import("navigator.zig").Navigator;
+const History = @import("history.zig").History;
const storage = @import("../storage/storage.zig");
@@ -41,6 +42,7 @@ pub const Window = struct {
document: ?*parser.DocumentHTML = null,
target: []const u8,
+ history: History = .{},
storageShelf: ?*storage.Shelf = null,
@@ -86,6 +88,10 @@ pub const Window = struct {
return self.document;
}
+ pub fn get_history(self: *Window) *History {
+ return &self.history;
+ }
+
pub fn get_name(self: *Window) []const u8 {
return self.target;
}
diff --git a/src/run_tests.zig b/src/run_tests.zig
index 077e56e2..838a6047 100644
--- a/src/run_tests.zig
+++ b/src/run_tests.zig
@@ -138,6 +138,7 @@ fn testsAllExecFn(
MutationObserverTestExecFn,
@import("polyfill/fetch.zig").testExecFn,
@import("html/navigator.zig").testExecFn,
+ @import("html/history.zig").testExecFn,
};
inline for (testFns) |testFn| {
diff --git a/src/storage/storage.zig b/src/storage/storage.zig
index 52b467d2..6937594d 100644
--- a/src/storage/storage.zig
+++ b/src/storage/storage.zig
@@ -173,7 +173,7 @@ pub const Bottle = struct {
// > context of another document.
// https://developer.mozilla.org/en-US/docs/Web/API/Window/storage_event
//
- // So for now, we won't impement the feature.
+ // So for now, we won't implement the feature.
}
pub fn _removeItem(self: *Bottle, k: []const u8) !void {