definePageLayout() para declarar un layout para un objeto que posees, o definePageLayoutTab() para agregar una sola pestaña a un layout que ya existe (tuyo o uno estándar de Twenty).
| Caso de uso | Entidad |
|---|---|
| Define todo el layout para una página de registro en un objeto que posees | definePageLayout |
| Agrega una pestaña a un layout existente (tu propio objeto o uno estándar) | definePageLayoutTab |
definePageLayout
Usa esto cuando eres propietario de toda la página de detalle; normalmente para un objeto personalizado que definiste tú mismo.src/page-layouts/example-record-page-layout.ts
Puntos clave
typesuele ser'RECORD_PAGE'para personalizar la vista de detalles de un objeto específico.objectUniversalIdentifierespecifica a qué objeto se aplica este diseño.- Cada
tabdefine una sección de la página con untitle,positionylayoutMode(CANVASpara un diseño libre). - Cada
widgetdentro de una pestaña puede renderizar un componente de frontend, una lista de relaciones u otros tipos de widget integrados. positionen las pestañas controla su orden. Usa valores más altos (p. ej., 50) para colocar pestañas personalizadas después de las integradas.
definePageLayoutTab
Usa esto cuando solo quieras agregar una pestaña a un layout existente; por ejemplo, una pestaña de analíticas en la página estándar de Company o una pestaña de resumen de IA añadida al layout de tu propio objeto.src/page-layouts/example-extra-tab.ts
Puntos clave
-
pageLayoutUniversalIdentifieres obligatorio y debe apuntar a un page layout que ya exista en el momento de la instalación, ya sea un layout estándar de Twenty o uno definido por tu propia app. Las referencias entre apps a layouts que pertenecen a otra app instalada no son compatibles hoy en día. Cuando falta el layout padre, la instalación falla con un error de validación claro. -
Para los diseños estándar de Twenty, importa los identificadores desde
twenty-sdk/define:Cada entrada de diseño también expone sustabsy suswidgets, para que puedas hacer referencia a cualquier nivel:También hay disponible un alias cortoSTANDARD_PAGE_LAYOUT: -
widgetsestán limitados solo a esta pestaña: hacen referencia a componentes de frontend, vistas, etc., exactamente igual que los widgets definidos en línea endefinePageLayout. -
positioncontrola el orden con respecto a las pestañas existentes en el diseño de página de destino. Elige un valor que sitúe tu pestaña donde la quieras, en relación con las pestañas integradas. -
Usa esto en lugar de
definePageLayoutcuando solo quieras agregar a un layout existente. UsadefinePageLayoutcuando eres propietario de todo el layout.