Skip to main content

Navigator

Struct Navigator 

Source
pub struct Navigator;
Expand description

Navigation API for convenient route navigation

Provides static methods for navigation operations:

  • Navigator::push(cx, "/path") - Navigate to a new page
  • Navigator::pop(cx) - Go back to previous page
  • Navigator::replace(cx, "/path") - Replace current page

Works with any context that has access to App (Context<V>, App, etc.)

§Example

use gpui_navigator::Navigator;

// Navigate to a new route
Navigator::push(cx, "/users/123");

// Go back
Navigator::pop(cx);

// Replace current route
Navigator::replace(cx, "/login");

Implementations§

Source§

impl Navigator

Source

pub fn of<C: BorrowAppContext>(cx: &mut C) -> NavigatorHandle<'_, C>

Get a NavigatorHandle for the given context

This allows chained navigation calls:

use gpui_navigator::Navigator;

// Chained style
Navigator::of(cx).push("/users");
Navigator::of(cx).pop();

// Or direct style (also works)
Navigator::push(cx, "/users");
Navigator::pop(cx);
Source

pub fn push(cx: &mut impl BorrowAppContext, route: impl IntoRoute)

Navigate to a new path

§Example
use gpui_navigator::{Navigator, PageRoute};

// Simple string path
Navigator::push(cx, "/users/123");

// With PageRoute and params
Navigator::push(cx, PageRoute::builder("/profile", |_, _cx, _params| gpui::div())
    .with_param("userId".into(), "456".into()));
Source

pub fn replace(cx: &mut impl BorrowAppContext, route: impl IntoRoute)

Replace current path without adding to history

§Example
use gpui_navigator::{Navigator, PageRoute};

// Simple string path
Navigator::replace(cx, "/login");

// With PageRoute
Navigator::replace(cx, PageRoute::builder("/login", |_, _cx, _params| gpui::div())
    .with_param("redirect".into(), "/dashboard".into()));
Source

pub fn pop(cx: &mut impl BorrowAppContext)

Go back to the previous route

§Example
use gpui_navigator::Navigator;

if Navigator::can_pop(cx) {
    Navigator::pop(cx);
}
Source

pub fn back(cx: &mut impl BorrowAppContext)

Alias for pop() - go back (kept for compatibility)

Source

pub fn forward(cx: &mut impl BorrowAppContext)

Go forward in history

Source

pub fn current_path(cx: &App) -> String

Get current path

Works with Context<V> since it derefs to App

§Example
use gpui_navigator::Navigator;

let path = Navigator::current_path(cx);
Source

pub fn can_pop(cx: &App) -> bool

Check if can go back

Source

pub fn can_go_back(cx: &App) -> bool

Alias for can_pop() - check if can go back (kept for compatibility)

Source

pub fn push_named( cx: &mut impl BorrowAppContext, name: &str, params: &RouteParams, )

Navigate to a named route with parameters

§Example
use gpui_navigator::{Navigator, RouteParams};

let mut params = RouteParams::new();
params.set("id".into(), "123".into());

Navigator::push_named(cx, "user.detail", &params);
Source

pub fn url_for(cx: &App, name: &str, params: &RouteParams) -> Option<String>

Generate URL for a named route

§Example
use gpui_navigator::{Navigator, RouteParams};

let mut params = RouteParams::new();
params.set("id".into(), "123".into());

let url = Navigator::url_for(cx, "user.detail", &params);
assert_eq!(url, Some("/users/123".to_string()));
Source

pub fn can_go_forward(cx: &App) -> bool

Check if can go forward

Source

pub fn set_next_transition( cx: &mut impl BorrowAppContext, transition: Transition, )

Available on crate feature transition only.

Set transition for the next navigation

The transition will be used for the next push/replace call, then automatically cleared.

§Example
use gpui_navigator::{Navigator, Transition};

Navigator::set_next_transition(cx, Transition::fade(300));
Navigator::push(cx, "/page");
Source

pub fn push_with_transition( cx: &mut impl BorrowAppContext, route: impl IntoRoute, transition: Transition, )

Available on crate feature transition only.

Navigate with a specific transition

§Example
use gpui_navigator::{Navigator, Transition};

Navigator::push_with_transition(cx, "/page", Transition::slide_left(300));
Source

pub fn replace_with_transition( cx: &mut impl BorrowAppContext, route: impl IntoRoute, transition: Transition, )

Available on crate feature transition only.

Replace with a specific transition

§Example
use gpui_navigator::{Navigator, Transition};

Navigator::replace_with_transition(cx, "/page", Transition::fade(200));
Source

pub fn push_named_with_transition( cx: &mut impl BorrowAppContext, name: &str, params: &RouteParams, transition: Transition, )

Available on crate feature transition only.

Push named route with a specific transition

§Example
use gpui_navigator::{Navigator, RouteParams, Transition};

let mut params = RouteParams::new();
params.set("id".to_string(), "123".to_string());
Navigator::push_named_with_transition(
    cx,
    "user.detail",
    &params,
    Transition::slide_right(300)
);

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
Source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more