The page
response¶
Superglue expects your JSON responses to contain the following attributes. If you
used Superglue's generators, this would be all set for you in
application.json.props
.
{
data: {
...
},
componentIdentifier,
defers,
assets,
csrfToken,
action,
path,
renderedAt,
fragments,
restoreStrategy,
slices
}
data
¶
Your page's content. This can be accessed using the
componentIdentifier
¶
A string
to instruct Superglue which component to render. The generated
application.json.props
will set this to the active_template_virtual_path
(added by props_template), but you can customize this to fit your needs.
You can control which componentIdentifier
will render which component in the
page_to_page_mapping.js
.
- See reference for page_to_page_mapping.js
assets
¶
An array
of asset fingerprint string
s. Used by Superglue to detect the need to
refresh the browser due to new assets. You can control the refresh behavior in
application_visit.js
.
csrfToken
¶
The authenticity token that Superglue will use for non-GET request made by using
visit
or remote
thunks. This includes forms that have the data-sg-visit
or data-sg-remote
attribute.
action
and path
¶
Only included when props_at
is part of the request parameters. action
is always
set to graft
and path
is the camelCase keypath to the requested node.
Superglue uses these attributes to immutably graft a node from the server-side to
the client-side.
renderedAt
¶
An UNIX timestamp representing the time the response was rendered.
fragments
¶
An array
of fragments. In
application.json.props
this is set to json.fragments!
.
restoreStrategy
¶
By specifying the restore strategy used (fromCacheOnly
, revisitOnly
, or
fromCacheAndRevisitInBackground
), you can control what superglue does when
encountering the page again when pressing the back or forward browser navigation
buttons.
fromCacheAndRevisitInBackground
will transition to the cached page, then issue a visit in the background, redirecting and replacing history if needed. This is the option set inapplication.json.props
when using the generators.revisitOnly
will always issue a visit request in the background beforefromCacheOnly
will only restore the page from cache transitioning
slices
¶
An object merged with the initialState
when implementing buildStore
inside
of application.js
. You can use this as the initial state for redux slices.
Take advantage of the SAVE_RESPONSE
to continually update your slice everytime
superglue recieves a new page request.