At this point, when your editors go to /your-page-url
in edit-mode, they will be able to edit content and see those changes reflected on the page, in real-time. Next, let's ensure users will be navigated to that same live-editing experience (instead of the basic editor experience) every time they click on a document in the CMS Document List.
To accomplish this, we will make use of the ui.router
property on a collection.
router
PropertyThe router
property is used by the CMS's Document List to navigate to a document's contextual editor rather than the basic editor.
router: ({ collection: Collection, document: Document }) => string | undefined
The router
property is a function, that is run when a document is clicked within a Document List:
router
returns a string
, the string
is used as the document's route rather than the default.router
returns undefined
, the user is navigated to the document's basic editor.This is an example using router
.
const default defineConfig({schema: {collections: [{name: 'page',label: 'Page',path: 'content/page',format: 'md',ui: {router: ({ document }) => {// navigate to the home pageif (document._sys.filename === 'home') {return '/'}// navigate to the about pageif (document._sys.filename === 'about') {return `/about`}return undefined},},fields: [// An array of fields],},{label: 'Blog Posts',name: 'post',path: 'content/posts',format: 'mdx',ui: {router: ({ document }) => {// navigate to the post that was clickedreturn `/post/${document._sys.filename}`},},fields: [// An array of fields],}]}})
Now when a document is clicked in the CMS we will be re-directed to the page in the site with visual editing.
useTina
hook. In production, it returns the original data unchanged. In edit-mode, it returns the live data, which is updated as the user types in the sidebar.router
property to automatically navigate to the contextual-editing experience from the CMS.© TinaCMS 2019–2025