13.0.2 • Published 11 months ago

@procore/labs-form-components v13.0.2

Weekly downloads
6
License
SEE LICENSE IN LI...
Repository
github
Last release
11 months ago

Form Components Introduction

A package to co-locate forms built using CORE Form..

Installation

yarn add @procore/labs-form-components

Dependencies

@procore/core-react and react are listed as external peer dependencies. The package will not bundle the code, and requires the app client to provide it as a dependency. The external peer dep is to assure React Context is consistent in a client's React tree, the child consumers can reference the correct parent provider. If the package uses latest features or bug fixes and a new minimum version of core-react is required, it should be considered a breaking change as the peer dependency version must be met.

Usage

Use the base component of FormRendered to build your own views. It is rendered using a two dimentional array. Top level represents a row, second level is a cell in that row. You can call the generateType function and pass it to the array like below to generate a type (or cell if you prefer in the two dimentional array).

import * as FormRenderer from '@procore/labs-form-components';

const Component = () => {
  const [view, setView] = React.useState('read');

  const whereAreYouLocated = generateType({
    required: true,
    name: 'whereAreYouLocated',
    label: 'Where are you located?',
    type: CoreForm.Text,
    colStart: 1,
    colWidth: 6,
  });

  const whatIsYourName = generateType({
    required: true,
    name: 'whatIsYourName',
    label: 'What is your name?',
    type: CoreForm.Text,
    colStart: 1,
    colWidth: 3,
  });

  const CUSTOM_FIELD_SETS = [[whereAreYouLocated], [whatIsYourName]];
  return (
    <>
      <FormRenderer.Form
        view="read"
        initialValues={{ whereAreYouLocated: '', whatIsYourName: '' }}
      >
        <FormRenderer.Read
          title="Canvas 23 Studios"
          secondaryTitle="Overview"
          avatar={IMAGE_FILE}
          sections={[
            {
              label: 'view.global.general_information',
              value: CUSTOM_FIELD_SETS,
            },
          ]}
          onEdit={() => setView('update')}
        />
      </FormRenderer.Form>
      <FormRenderer.Form
        view="update"
        initialValues={{ whereAreYouLocated: '', whatIsYourName: '' }}
        validationSchema={generateValidationSchema(CUSTOM_FIELD_SETS)}
        onSubmit={(values) => {
          console.log(values);
        }}
      >
        <FormRenderer.Update
          open={view === 'update'}
          title='view.global.general_information',
          sections={[
            {
              value: CUSTOM_FIELD_SETS_FOR_FORM,
            },
          ]}
          onCancel={() => setView('read')}
        />
      </FormRenderer.Form>
    </>
  );
};

Helper Functions

There are a few helper functions that can help to create objects so you don't have to manually create them.

generateType()

Used to generate a field type to be fed to the FormRenderer

generateInitialValues()

Used to generate initial values initially to allow for validation on empty fields. (Core Form and by extension Formik requires a value empty string, empty array to validate upon). This function can create an empty values set for your form to validate against.

generateValidationSchema()

Used to generate a validation schema using yup package. Feed it a fieldSet two dimentional array.

example usage:

  const whereAreYouLocated = generateType({
  required: true,
  name: 'whereAreYouLocated',
  label: 'Where are you located?',
  type: CoreForm.Text,
  colStart: 1,
  colWidth: 6,
});

  const whatIsYourName = generateType({
  required: true,
  name: 'whatIsYourName',
  label: 'What is your name?',
  type: CoreForm.Text,
  colStart: 1,
  colWidth: 3,
});

const CUSTOM_FIELD_SETS = [[whereAreYouLocated], [whatIsYourName]];
generateValidationSchema(CUSTOM_FIELD_SETS)
13.0.1-alpha.6

11 months ago

13.0.2

11 months ago

13.0.0

12 months ago

12.3.20-alpha.2

1 year ago

13.0.1

11 months ago

12.3.20-alpha.1

1 year ago

12.3.20-alpha.4

1 year ago

12.3.20-alpha.3

1 year ago

12.3.22-alpha.3

1 year ago

12.4.0

1 year ago

12.4.1

1 year ago

12.3.22-alpha.1

1 year ago

12.3.22-alpha.2

1 year ago

12.3.22

1 year ago

12.3.20

1 year ago

12.3.21

1 year ago

12.3.19

1 year ago

12.3.17

1 year ago

12.3.18

1 year ago

13.0.1-alpha.1

11 months ago

13.0.1-alpha.0

11 months ago

13.0.1-alpha.3

11 months ago

13.0.1-alpha.2

11 months ago

13.0.1-alpha.5

11 months ago

12.4.1-alpha.1

1 year ago

12.3.21-alpha.2

1 year ago

12.3.21-alpha.3

1 year ago

12.3.21-alpha.1

1 year ago

12.3.15-alpha.1

1 year ago

12.3.15

1 year ago

12.3.16

1 year ago

12.3.11

1 year ago

12.3.12

1 year ago

12.3.13

1 year ago

12.3.14

1 year ago

12.3.7

1 year ago

12.3.8

1 year ago

12.3.9

1 year ago

12.3.10

1 year ago

12.3.9-alpha

1 year ago

12.2.11-alpha

2 years ago

12.3.1-alpha

1 year ago

12.2.10-alpha.5

2 years ago

12.2.21-alpha.1

1 year ago

12.2.16-k1

1 year ago

12.2.7

2 years ago

12.2.8

2 years ago

12.2.9

2 years ago

13.0.0-alpha.1

1 year ago

12.3.4

1 year ago

12.3.5

1 year ago

12.3.6

1 year ago

12.3.0

1 year ago

12.3.1

1 year ago

12.3.2

1 year ago

12.3.3

1 year ago

12.2.21

1 year ago

12.2.20

1 year ago

12.2.8-alpha

2 years ago

12.2.18

1 year ago

12.2.19

1 year ago

12.2.13-alpha.1

2 years ago

12.2.14

2 years ago

12.2.15

1 year ago

12.2.16

1 year ago

12.2.17

1 year ago

12.2.10

2 years ago

12.2.11

2 years ago

12.2.12

2 years ago

12.2.13

2 years ago

12.2.15-alpha.1

2 years ago

12.2.12-alpha.4

2 years ago

12.2.12-alpha.3

2 years ago

12.2.12-alpha.6

2 years ago

12.2.12-alpha.5

2 years ago

12.2.12-alpha.2

2 years ago

12.2.12-alpha.1

2 years ago

12.2.3-alpha

2 years ago

12.2.5-alpha

2 years ago

12.1.3-alpha

2 years ago

12.2.5

2 years ago

12.2.6

2 years ago

12.2.1

2 years ago

12.2.2

2 years ago

12.2.3

2 years ago

12.2.4

2 years ago

12.2.0

2 years ago

12.1.3-alpha.2

2 years ago

12.1.2

2 years ago

12.1.3

2 years ago

12.2.3-alpha.2

2 years ago

11.0.5-alpha.1

2 years ago

11.0.5-alpha.2

2 years ago

12.1.1-alpha.2

2 years ago

12.1.1-alpha.1

2 years ago

11.0.2-alpha.1

2 years ago

11.0.2-alpha

2 years ago

11.0.4

2 years ago

10.1.1-alpha.5

2 years ago

10.1.1-alpha.4

2 years ago

11.0.2

2 years ago

10.1.1-alpha.1

2 years ago

11.0.3

2 years ago

11.0.0

2 years ago

10.1.1-alpha.3

2 years ago

11.0.1

2 years ago

10.1.1-alpha.2

2 years ago

10.1.0

2 years ago

10.1.1

2 years ago

11.0.4-alpha.1

2 years ago

12.1.0-alpha

2 years ago

12.0.0

2 years ago

12.0.1

2 years ago

12.1.1-alpha

2 years ago

10.0.2-alpha.3

2 years ago

10.1.2-alpha.1

2 years ago

11.0.4-alpha

2 years ago

12.1.0

2 years ago

12.1.1

2 years ago

9.1.1-alpha.2

2 years ago

10.0.0

2 years ago

10.0.1

2 years ago

9.1.1-alpha.1

2 years ago

9.1.2

2 years ago

9.1.1

2 years ago

9.1.0

2 years ago

9.2.0-alpha

2 years ago

9.1.2-alpha.1

2 years ago

10.0.2-alpha.2

2 years ago

10.0.2-alpha.1

2 years ago

9.0.6-alpha.6

2 years ago

9.0.6-alpha.7

2 years ago

9.0.6-alpha.8

2 years ago

9.0.6-alpha.9

2 years ago

9.0.6-alpha.2

2 years ago

9.0.6-alpha.3

2 years ago

9.0.6-alpha.4

2 years ago

9.0.6-alpha.5

2 years ago

9.0.6-alpha.1

2 years ago

9.1.3-alpha.1

2 years ago

9.1.3-alpha.3

2 years ago

9.1.3-alpha.2

2 years ago

9.1.3-alpha.5

2 years ago

9.1.3-alpha.4

2 years ago

9.1.3-alpha.7

2 years ago

9.1.3-alpha.6

2 years ago

9.1.0-alpha

2 years ago

9.2.0-alpha.1

2 years ago

9.0.6-alpha.10

2 years ago

9.0.5

2 years ago

9.0.4

2 years ago

9.0.3

2 years ago

8.3.1

2 years ago

9.0.2-alpha.6

2 years ago

9.0.2-alpha.4

2 years ago

9.0.2-alpha.5

2 years ago

9.0.2-alpha.2

2 years ago

9.0.2-alpha.3

2 years ago

9.0.2-alpha.1

2 years ago

9.0.2

2 years ago

9.0.1

2 years ago

9.0.0

2 years ago

8.3.2-alpha.3

2 years ago

8.3.2-alpha.2

2 years ago

8.3.2-alpha.1

2 years ago

9.0.4-alpha.1

2 years ago

8.3.1-alpha

2 years ago

9.0.1-alpha

2 years ago

8.2.1-alpha

2 years ago

8.2.1

2 years ago

8.2.0

2 years ago

8.3.0

2 years ago

8.3.0-alpha.6

2 years ago

8.3.0-alpha.7

2 years ago

8.3.0-alpha.2

2 years ago

8.3.0-alpha.3

2 years ago

8.3.0-alpha.4

2 years ago

8.3.0-alpha.1

2 years ago

8.3.0-alpha

2 years ago

8.1.3

2 years ago

8.0.0-alpha.1

2 years ago

8.1.0

2 years ago

8.1.2

2 years ago

8.1.1

2 years ago

6.5.0-alpha.1

2 years ago

6.3.1-alpha.1

2 years ago

7.2.1-alpha.1

2 years ago

8.0.0-alpha

2 years ago

6.0.1

2 years ago

6.0.3

2 years ago

6.0.2

2 years ago

6.0.4

2 years ago

8.0.1-alpha.1

2 years ago

6.0.3-alpha

2 years ago

6.1.0

2 years ago

6.0.5-alpha

2 years ago

6.0.4-alpha

2 years ago

6.3.0-alpha.2

2 years ago

8.1.1-alpha.1

2 years ago

6.3.0-alpha.1

2 years ago

6.2.1

2 years ago

6.2.0

2 years ago

7.0.0

2 years ago

6.3.0

2 years ago

8.0.2-alpha.1

2 years ago

6.0.2-alpha.1

2 years ago

7.1.1

2 years ago

7.1.0

2 years ago

6.4.1

2 years ago

6.4.0

2 years ago

7.2.0-alpha.1

2 years ago

7.2.1

2 years ago

7.2.0

2 years ago

6.1.0-alpha.1

2 years ago

8.0.1

2 years ago

8.0.0

2 years ago

8.0.2

2 years ago

7.1.0-alpha.1

2 years ago

7.1.0-alpha.2

2 years ago

5.1.0-alpha

2 years ago

4.4.1-alpha.2

2 years ago

4.0.1

2 years ago

4.0.0

2 years ago

3.0.1-alpha-1

2 years ago

5.0.0

2 years ago

3.0.3-alpha

2 years ago

4.5.0-alpha.1

2 years ago

4.4.1-alpha

2 years ago

4.1.2-alpha.1

2 years ago

4.1.2-alpha.2

2 years ago

5.1.1

2 years ago

5.1.0

2 years ago

4.2.1-alpha.1

2 years ago

5.2.1-alpha.1

2 years ago

3.0.2

2 years ago

3.0.1

2 years ago

4.1.1-alpha

2 years ago

5.2.0

2 years ago

6.0.0

2 years ago

3.0.1-alpha.1

2 years ago

4.0.1-alpha.1

2 years ago

4.4.2-alpha.1

2 years ago

3.0.2-alpha

2 years ago

4.5.0

2 years ago

4.4.0-alpha

2 years ago

4.0.0-alpha

2 years ago

4.4.5-alpha

2 years ago

4.4.1

2 years ago

4.4.0

2 years ago

4.4.3

2 years ago

4.4.2

2 years ago

4.1.1-alpha-1

2 years ago

4.4.5

2 years ago

4.4.4

2 years ago

4.4.6

2 years ago

3.0.2-alpha-3

2 years ago

3.0.2-alpha-4

2 years ago

5.2.0-alpha

2 years ago

4.1.2-alpha

2 years ago

4.3.0

2 years ago

5.2.0-alpha.11

2 years ago

5.2.0-alpha.12

2 years ago

5.2.0-alpha.10

2 years ago

3.0.2-alpha-1

2 years ago

3.0.2-alpha-2

2 years ago

4.2.0-alpha

2 years ago

4.4.0-alpha.3

2 years ago

4.4.0-alpha.2

2 years ago

4.4.0-alpha.1

2 years ago

4.4.3-alpha.4

2 years ago

4.4.3-alpha.2

2 years ago

4.4.3-alpha.3

2 years ago

4.4.3-alpha.1

2 years ago

4.2.1

2 years ago

4.5.0-alpha

2 years ago

4.2.0

2 years ago

3.0.3-alpha-2

2 years ago

4.2.0-alpha.1

2 years ago

5.2.0-alpha.1

2 years ago

5.2.0-alpha.4

2 years ago

5.2.0-alpha.5

2 years ago

5.2.0-alpha.2

2 years ago

5.2.0-alpha.3

2 years ago

5.2.0-alpha.8

2 years ago

5.2.0-alpha.9

2 years ago

5.2.0-alpha.6

2 years ago

5.2.0-alpha.7

2 years ago

5.1.0-alpha.1

2 years ago

5.0.0-alpha

2 years ago

4.2.1-alpha

2 years ago

4.1.0

2 years ago

4.1.2

2 years ago

4.1.1

2 years ago

4.0.0-alpha-1

2 years ago

4.4.6-alpha.1

2 years ago

3.0.0

2 years ago

2.1.1

3 years ago

2.1.0-beta.1

3 years ago

1.0.22

3 years ago

2.0.0

3 years ago

1.4.0-alpha.1

3 years ago

1.4.0-alpha.2

3 years ago

1.4.0-alpha.3

3 years ago

1.0.21

3 years ago

1.0.20

3 years ago

1.4.0-alpha.4

3 years ago

1.0.20-alpha.1

3 years ago

2.1.0

3 years ago

2.1.0-alpha.2

3 years ago

2.1.0-alpha.1

3 years ago

1.3.1-beta.1

3 years ago

1.3.1-beta.0

3 years ago

1.3.1-alpha.6

3 years ago

1.3.2-alpha.2

3 years ago

1.3.3

3 years ago

1.3.2

3 years ago

1.3.1

3 years ago

1.3.0

3 years ago

1.2.0

3 years ago

1.2.0-alpha-5

3 years ago

1.2.0-alpha-3

3 years ago

1.2.0-alpha-4

3 years ago

1.2.0-alpha-1

3 years ago

1.2.0-alpha-2

3 years ago

1.1.0-alpha-18

3 years ago

1.1.0-alpha-17

3 years ago

1.1.0-alpha-12

3 years ago

1.1.0-alpha-11

3 years ago

1.1.0-alpha-10

3 years ago

1.1.0-alpha-16

3 years ago

1.1.0-alpha-15

3 years ago

1.1.0-alpha-14

3 years ago

1.1.0-alpha-13

3 years ago

1.1.0-alpha4

3 years ago

1.1.0-alpha3

3 years ago

1.1.0-alpha2

3 years ago

1.1.0-alpha1

3 years ago

1.0.19

3 years ago

1.0.18

3 years ago

1.0.18-alpha.4

3 years ago

1.0.17

3 years ago

1.0.18-alpha.3

3 years ago

1.0.16

3 years ago

1.0.18-alpha.2

3 years ago

1.0.18-alpha.1

3 years ago

1.0.18-alpha

3 years ago

1.0.17-alpha

3 years ago

1.0.14-alpha

3 years ago

1.0.16-alpha.1

3 years ago

1.0.16-alpha.2

3 years ago

1.0.16-alpha.3

3 years ago

1.0.14-alpha.2

3 years ago

1.0.17-alpha.3

3 years ago

1.0.17-alpha.2

3 years ago

1.0.15-alpha

3 years ago

1.0.15-alpha.1

3 years ago

1.0.15

3 years ago

1.0.14

3 years ago

1.0.14-alpha.1

3 years ago

1.0.12

3 years ago

1.0.12-alpha.7

3 years ago

1.0.12-alpha.8

3 years ago

1.0.12-alpha.19

3 years ago

1.0.12-alpha.5

3 years ago

1.0.12-alpha.18

3 years ago

1.0.12-alpha.6

3 years ago

1.0.12-alpha.3

3 years ago

1.0.12-alpha.2

3 years ago

1.0.12-alpha.13

3 years ago

1.0.12-alpha.12

3 years ago

1.0.12-alpha.11

3 years ago

1.0.12-alpha.10

3 years ago

1.0.12-alpha.17

3 years ago

1.0.12-alpha.16

3 years ago

1.0.12-alpha.15

3 years ago

1.0.12-alpha.9

3 years ago

1.0.12-alpha.14

3 years ago

1.0.9

3 years ago

1.0.12-alpha.1

3 years ago

1.0.11-alpha.4

3 years ago

1.0.11-alpha.2

3 years ago

1.0.11-alpha.3

3 years ago

1.0.11

3 years ago

1.0.10

3 years ago

1.0.8

3 years ago

1.0.9-alpha.1

3 years ago

1.0.8-alpha.2

3 years ago

1.0.5-alpha.0

3 years ago

1.0.5-alpha.2

3 years ago

1.0.5-alpha.1

3 years ago

1.0.6-alpha.1

3 years ago

1.0.7

3 years ago

1.0.6

3 years ago

1.0.5

3 years ago

1.0.4-alpha.5.1

3 years ago

1.0.6-alpha.2

3 years ago

1.0.5-alpha.3

3 years ago

1.0.5-alpha.6

3 years ago

1.0.4-alpha.5

3 years ago

1.0.4-alpha.6

3 years ago

1.0.4-alpha.3

3 years ago

1.0.4-alpha.2

3 years ago

1.0.4-alpha.4

3 years ago

1.0.4-alpha.1

3 years ago

1.0.4-alpha.0

3 years ago

1.0.4

3 years ago

1.0.2

3 years ago

1.0.1

3 years ago

1.0.3

3 years ago

1.0.1-bid-sheet

3 years ago

1.0.0

3 years ago

0.1.1

3 years ago

0.1.1-alpha.2

3 years ago

0.1.1-alpha.1

4 years ago