mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-09-21 10:19:03 +03:00
LibWeb: Basic support for location.replace(url)
This is not entirely to spec, but gets the basic job done.
This commit is contained in:
parent
37784a85c0
commit
573955be7f
Notes:
sideshowbarker
2024-07-18 03:06:41 +09:00
Author: https://github.com/awesomekling Commit: https://github.com/SerenityOS/serenity/commit/573955be7f4
@ -33,6 +33,7 @@ void LocationObject::initialize(JS::GlobalObject& global_object)
|
||||
define_native_accessor("port", port_getter, {}, attr);
|
||||
|
||||
define_native_function("reload", reload, 0, JS::Attribute::Enumerable);
|
||||
define_native_function("replace", replace, 1, JS::Attribute::Enumerable);
|
||||
}
|
||||
|
||||
LocationObject::~LocationObject()
|
||||
@ -125,6 +126,17 @@ JS_DEFINE_NATIVE_FUNCTION(LocationObject::reload)
|
||||
return JS::js_undefined();
|
||||
}
|
||||
|
||||
JS_DEFINE_NATIVE_FUNCTION(LocationObject::replace)
|
||||
{
|
||||
auto& window = static_cast<WindowObject&>(global_object);
|
||||
auto url = vm.argument(0).to_string(global_object);
|
||||
if (vm.exception())
|
||||
return {};
|
||||
// FIXME: This needs spec compliance work.
|
||||
window.impl().did_call_location_replace({}, move(url));
|
||||
return JS::js_undefined();
|
||||
}
|
||||
|
||||
// https://html.spec.whatwg.org/multipage/history.html#location-setprototypeof
|
||||
JS::ThrowCompletionOr<bool> LocationObject::internal_set_prototype_of(Object* prototype)
|
||||
{
|
||||
|
@ -30,6 +30,7 @@ public:
|
||||
|
||||
private:
|
||||
JS_DECLARE_NATIVE_FUNCTION(reload);
|
||||
JS_DECLARE_NATIVE_FUNCTION(replace);
|
||||
|
||||
JS_DECLARE_NATIVE_FUNCTION(href_getter);
|
||||
JS_DECLARE_NATIVE_FUNCTION(href_setter);
|
||||
|
@ -234,6 +234,15 @@ void Window::did_call_location_reload(Badge<Bindings::LocationObject>)
|
||||
frame->loader().load(associated_document().url(), FrameLoader::Type::Reload);
|
||||
}
|
||||
|
||||
void Window::did_call_location_replace(Badge<Bindings::LocationObject>, String url)
|
||||
{
|
||||
auto* frame = associated_document().browsing_context();
|
||||
if (!frame)
|
||||
return;
|
||||
auto new_url = associated_document().parse_url(url);
|
||||
frame->loader().load(move(new_url), FrameLoader::Type::Navigation);
|
||||
}
|
||||
|
||||
bool Window::dispatch_event(NonnullRefPtr<Event> event)
|
||||
{
|
||||
return EventDispatcher::dispatch(*this, event, true);
|
||||
|
@ -62,6 +62,7 @@ public:
|
||||
|
||||
void did_set_location_href(Badge<Bindings::LocationObject>, AK::URL const& new_href);
|
||||
void did_call_location_reload(Badge<Bindings::LocationObject>);
|
||||
void did_call_location_replace(Badge<Bindings::LocationObject>, String url);
|
||||
|
||||
Bindings::WindowObject* wrapper() { return m_wrapper; }
|
||||
Bindings::WindowObject const* wrapper() const { return m_wrapper; }
|
||||
|
Loading…
Reference in New Issue
Block a user