Skip to content

Description

DataContext.Provider is the context provider that has to wrap the features if components of Field and Value is to be used with a common source instead of distributing values and events individually.

For a more complete feature set tailored to building forms, please use Form.Handler. It uses DataContext internally.

Demos

Data and callback events (and session store)











Code Editor
<DataContext.Provider
  defaultData={testdata}
  onChange={(data) => console.log('onChange', data)}
  onPathChange={(path, value) => console.log('onPathChange', path, value)}
  onSubmit={(data) => console.log('onSubmit', data)}
  onSubmitRequest={() => console.log('onSubmitRequest')}
  sessionStorageId="provider-example-1"
>
  <Flex.Stack>
    <Card>
      <Flex.Vertical divider="line" spacing="small">
        <Field.String
          path="/requiredString"
          label="Required string"
          required
        />
        <Field.String path="/hmm" label="Invalid path" />
        <Field.String path="/string" label="String value" />
        <Field.String path="/string" label="String value (copy)" />
        <Field.Number path="/number" label="Number value" />
        <Field.String path="/number" label="Number with Field.String" />
        <Field.Boolean
          path="/boolean"
          label="Boolean - Checkbox"
          variant="checkbox"
        />
        <Field.Boolean
          path="/boolean"
          label="Boolean - Toggle"
          variant="button"
        />
        <div>
          <Field.String path="/nested/nestedText" label="Nested text" />
          <Field.Number
            path="/nested/nestedNumber"
            label="Nested number (minimum 50)"
            minimum={50}
          />
        </div>
        <div className="hmm">
          <Flex.Horizontal>
            <Field.String path="/list/0/itemText" label="Item text" />
            <Field.Number path="/list/0/itemNumber" label="Item number" />
          </Flex.Horizontal>
          <Flex.Horizontal>
            <Field.String path="/list/1/itemText" label="Item text" />
            <Field.Number path="/list/1/itemNumber" label="Item number" />
          </Flex.Horizontal>
        </div>
        <Form.ButtonRow>
          <Form.SubmitButton />
        </Form.ButtonRow>
      </Flex.Vertical>
    </Card>
  </Flex.Stack>
</DataContext.Provider>

Validation with Json Schema











Code Editor
<DataContext.Provider
  data={testdata}
  schema={TestdataSchema}
  onChange={(data) => console.log('onChange', data)}
  onPathChange={(path, value) => console.log('onPathChange', path, value)}
  onSubmit={(data) => console.log('onSubmit', data)}
  onSubmitRequest={() => console.log('onSubmitRequest')}
>
  <Flex.Stack>
    <Card>
      <Flex.Vertical divider="line" spacing="small">
        <Field.String path="/requiredString" label="Required string" />
        <Field.String path="/hmm" label="Invalid path" />
        <Field.String path="/string" label="String value" />
        <Field.String path="/string" label="String value (copy)" />
        <Field.Number path="/number" label="Number value" />
        <Field.String path="/number" label="Number with Field.String" />
        <Field.Boolean
          path="/boolean"
          label="Boolean - Checkbox"
          variant="checkbox"
        />
        <Field.Boolean
          path="/boolean"
          label="Boolean - Toggle"
          variant="button"
        />
        <div>
          <Field.String path="/nested/nestedText" label="Nested text" />
          <Field.Number
            path="/nested/nestedNumber"
            label="Nested number"
          />
        </div>
        <div className="hmm">
          <Flex.Horizontal>
            <Field.String path="/list/0/itemText" label="Item text" />
            <Field.Number path="/list/0/itemNumber" label="Item number" />
          </Flex.Horizontal>
          <Flex.Horizontal>
            <Field.String path="/list/1/itemText" label="Item text" />
            <Field.Number path="/list/1/itemNumber" label="Item number" />
          </Flex.Horizontal>
        </div>
        <Form.ButtonRow>
          <Form.SubmitButton />
        </Form.ButtonRow>
      </Flex.Vertical>
    </Card>
  </Flex.Stack>
</DataContext.Provider>