This page demo how to use multiple instances of SingleFieldForm.
Each instance can be distinguished by the "key" attribute.
Usually the attribute value is index of array, or primary key of database record.
In below example, Nickname is created from newSingleFieldForm(). Then 3 instances of <Nickname.Form /> are mapped over an array of users.
user-list.tsximport { title } from '../../config.js'
import { mapArray } from '../components/fragment.js'
import { newSingleFieldForm } from '../components/single-field-form.js'
import SourceCode from '../components/source-code.js'
import Style from '../components/style.js'
import { o } from '../jsx/jsx.js'
import { Routes } from '../routes.js'let style = Style(/* css */ `
#user-list fieldset {
  max-width: 20rem;
}
#user-list legend {
  margin-bottom: 0.75rem;
}
#user-list .inline-code {
  background-color: #dddb;
}
`)
let users = [
  { id: 1, nickname: 'alice' },
  { id: 2, nickname: 'bob' },
  { id: 3, nickname: 'charlie' },
]
let Nickname = newSingleFieldForm({
  action: '/user-list/update',
  label: 'Nickname',
  name: 'nickname',
  updateKeyName: 'id',
  updateValue(attrs, context) {
    const { id, nickname } = attrs.input
    const index = +id - 1
    users[index].nickname = nickname
  },
  renderUpdate(attrs, context) {
    return content
  },
})
let content = (
  <div id="user-list">
    {style}
    <h1>List Editing Demo</h1>
    <p>This page demo how to use multiple instances of SingleFieldForm.</p>
    <p>Each instance can be distinguished by the "key" attribute.</p>
    <p>
      Usually the attribute value is index of array, or primary key of database
      record.
    </p>
    <p>
      In below example, <code class="inline-code">{'Nickname'}</code> is created
      from <code class="inline-code">{'newSingleFieldForm()'}</code>. Then 3
      instances of <code class="inline-code">{'<Nickname.Form />'}</code> are
      mapped over an array of users.
    </p>
    <View />
    <SourceCode page="user-list.tsx" />
  </div>
)
function View() {
  return mapArray(users, user => (
    <fieldset>
      <legend>user {user.id}</legend>
      <Nickname.Form key={user.id} value={user.nickname} />
    </fieldset>
  ))
}
let routes = {
  '/user-list': {
    title: title('Demo List Editing'),
    description:
      'Demo list editing with newSingleFieldForm powered by ts-liveview',
    menuText: 'List Editing',
    node: content,
  },
  ...Nickname.routes,
} as Routes
export default { routes }