Ir al contenido

Referencia de Hooks

Rebase proporciona hooks de React para acceder a la funcionalidad del framework desde cualquier componente dentro del árbol de proveedores <Rebase>.

El hook maestro — accede a todo:

import { useRebaseContext } from "@rebasepro/core";
function MyComponent() {
const context = useRebaseContext();
context.dataSource // Operaciones de datos
context.storageSource // Operaciones de archivo
context.authController // Estado de autenticación
context.navigation // Estado de navegación
context.sideEntityController // Control de panel lateral
context.snackbarController // Notificaciones Toast
}

Acceder al estado de autenticación:

import { useAuthController } from "@rebasepro/core";
function UserMenu() {
const auth = useAuthController();
auth.user // Usuario actual (o nulo)
auth.initialLoading // Cargando sesión inicial
auth.signOut() // Cerrar sesión
auth.getAuthToken() // Obtener JWT para llamadas a la API
auth.extra // Datos de usuario adicionales (roles, etc.)
}

Abrir entidades programáticamente en un panel lateral:

import { useSideEntityController } from "@rebasepro/core";
function OpenProductButton({ productId }) {
const sideEntityController = useSideEntityController();
return (
<button onClick={() => {
sideEntityController.open({
path: "products",
entityId: productId,
collection: productsCollection
});
}}>
Abrir Producto
</button>
);
}

Métodos:

MétodoDescripción
open({ path, entityId, collection })Abrir una entidad en un panel lateral
close()Cerrar el panel lateral actual
replace({ path, entityId, collection })Reemplazar el contenido del panel lateral actual

Mostrar notificaciones Toast:

import { useSnackbarController } from "@rebasepro/core";
function SaveButton() {
const snackbar = useSnackbarController();
const handleSave = async () => {
try {
await saveData();
snackbar.open({ type: "success", message: "¡Guardado con éxito!" });
} catch (error) {
snackbar.open({ type: "error", message: "Error al guardar" });
}
};
}

Acceder a las operaciones de almacenamiento de archivos:

import { useStorageSource } from "@rebasepro/core";
function FileUploader() {
const storage = useStorageSource();
const upload = async (file: File) => {
const result = await storage.uploadFile({
file,
fileName: file.name,
path: "documents"
});
const url = await storage.getDownloadURL(result.path);
return url;
};
}

Controlar tema claro/oscuro:

import { useModeController } from "@rebasepro/core";
function ThemeToggle() {
const mode = useModeController();
return (
<button onClick={mode.toggleMode}>
Actual: {mode.mode} {/* "light" | "dark" */}
</button>
);
}

Abrir un diálogo lateral para seleccionar entidades de una colección. Este es el mismo hook usado internamente cuando se renderiza una propiedad de relación:

import { useEntitySelectionDialog } from "@rebasepro/core";
function SelectProduct() {
const selectionDialog = useEntitySelectionDialog({
path: "products",
collection: productsCollection,
onSingleEntitySelected: (entity) => {
console.log("Seleccionado:", entity);
}
});
return <button onClick={selectionDialog.open}>Seleccionar Producto</button>;
}

Acceder al estado de navegación y colecciones resueltas:

import { useNavigationController } from "@rebasepro/core";
function MyComponent() {
const navigation = useNavigationController();
navigation.collections // Todas las colecciones registradas
navigation.views // Vistas personalizadas
navigation.adminViews // Vistas en modo administrador
navigation.getCollection(path) // Obtener colección para una ruta
}