logologo
Get Started
Guide
Development
Plugins
API
Home
English
简体中文
日本語
한국어
Español
Português
Deutsch
Français
Русский
Italiano
Türkçe
Українська
Tiếng Việt
Bahasa Indonesia
ไทย
Polski
Nederlands
Čeština
العربية
עברית
हिन्दी
Svenska
Get Started
Guide
Development
Plugins
API
Home
logologo
RunJS Overview
Import Modules
Render in Container

Globals

window
document
navigator

ctx

ctx.blockModel
ctx.collection
ctx.collectionField
ctx.dataSource
ctx.dataSourceManager
ctx.element
ctx.exit()
ctx.exitAll()
ctx.filterManager
ctx.form
ctx.getModel()
ctx.getValue()
ctx.getVar()
ctx.i18n
ctx.importAsync()
ctx.initResource()
ctx.libs
ctx.location
ctx.logger
ctx.makeResource()
ctx.message
ctx.modal
ctx.model
ctx.notification
ctx.off()
ctx.on()
ctx.openView()
ctx.render()
ctx.request()
ctx.requireAsync()
ctx.resource
ctx.route
ctx.router
ctx.setValue()
ctx.sql
ctx.t()
ctx.view
Next PageRunJS Overview

#SingleRecordResource

A resource for single records. Data is a single object and supports fetching by primary key, create/update (save), and delete. Suitable for details and forms.

Inheritance: FlowResource -> APIResource -> BaseRecordResource -> SingleRecordResource. It provides the request capability of APIResource and extends resource name, primary key, and save/destroy.

Creation: ctx.makeResource('SingleRecordResource') or ctx.initResource('SingleRecordResource'). Call setResourceName('collection'); use setFilterByTk(id) for PK-based operations.


#Resource name and primary key

MethodDescription
setResourceName(name) / getResourceName()Resource name, e.g. 'users', 'users.profile'
setSourceId(id) / getSourceId()Parent record ID for related resources
setDataSourceKey(key) / getDataSourceKey()Data source key
setFilterByTk(tk) / getFilterByTk()Current record PK; sets isNewRecord to false

#State

Property/MethodDescription
isNewRecordWhether this is a new record (true when no filterByTk is set or newly created)

#Request parameters (filter / fields)

MethodDescription
setFilter(filter) / getFilter()Filter (usable when not new)
setFields(fields) / getFields()Requested fields
setAppends(appends) / getAppends() / addAppends / removeAppendsAssociation expansion

#CRUD

MethodDescription
refresh()Request get by current filterByTk, update getData(); no request if new
save(data, options?)Create when new, otherwise update; optional { refresh: false }
destroy(options?)Delete by current filterByTk, and clear local data
runAction(actionName, options)Call any resource action

#Configuration and events

MethodDescription
setSaveActionOptions(options)Request config for save
on('refresh', fn) / on('saved', fn)Triggered on refresh complete, after save

#Example

ctx.initResource('SingleRecordResource');
ctx.resource.setResourceName('users');
ctx.resource.setFilterByTk(1);
await ctx.resource.refresh();
const user = ctx.resource.getData();

// Update
await ctx.resource.save({ name: 'Bob' });

// Create: no filterByTk
const newRes = ctx.makeResource('SingleRecordResource');
newRes.setResourceName('users');
await newRes.save({ name: 'Charlie' });