Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

field-change-effects-calculator

Package Overview
Dependencies
Maintainers
1
Versions
5
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

field-change-effects-calculator

**field-change-effects-calculator** is a utility that will calculate all field changes for changes to a certain field.

  • 1.0.3
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
5
Maintainers
1
Weekly downloads
 
Created
Source

field-change-effects-calculator

field-change-effects-calculator is a utility that will calculate all field changes for changes to a certain field.

It does multi level changes at one shot. For instance if there is a rule saying if A changes B has to change and if B changes C has to change, all the calculations are done and returned by the utility function.

It also has infinite loop mitigation logic built into it so even if there were some misleading rules set, the algorithm will avoid such loops.

Usage

The npm module exposes a utility function that should be used to calculate the change effects.

import fieldChangesCalculator from 'field-change-effects-calculator'

Signature:

(rules: { fieldName: Array<FieldChangeEffectRuleType> }) => (state: Object) => (name: string, fieldPathInState: Array<string>, value: any): Array<FieldChangeObjectType>

The function when provided with rules, state object, field's name, path and new value, returns the state of fields that have changed as an Array of objects of type FieldChangeObjectType.

type  FieldChangeObjectType = {
    name: string,
    path: Array<string>,
    value: any,
    editable: boolean,
    readable: boolean,
    required: boolean,
    otherProps: { prop: any }
}

More about rules in the future sections.

Why?

This is very useful when we are maintaining large forms where ther are many inter field dependencies.

All your actions do is call the calculator function, pass rules and information it needs, get back the changed fields data and do what ever you want (in case of redux, dispatch it).

Also since the module does not relate itself to a certain state management tool like redux, etc, you can use it with any state management choice of yours.

Rules

Rules are the most important part of the calculator. They decide the change effects.

Rules object will have keys as field names and values are array field change configurations.

For instance if we have a rule saying B's editability has to change if A's value is changed to World from Hello. Here is how the rules object will look like:

var RULES = {
  A: [
    {
      name: 'B',
      path: ['fields', 'B'],
      value: (ANewValue, state) => state.fields.B.value,
      editable: (ANewValue, state) => ANewValue === 'Hello' ? 'true' : 'false',
      readable: (ANewValue, state) => state.fields.B.readable,
      required: (ANewValue, state) => false,
      otherProps: (ANewValue, state) => ({
        placeholder: ANewValue.toLowerCase(),
        label: ANewValue.toUpperCase()
      })
    }
  ]
}

If you want to write more complex rules like changing A changes B and C and changing B changes D, you can write it like this:

var RULES = {
  A: [
    {
      name: 'B',
      path: ['fields', 'B'],
      value: (ANewValue, state) => state.fields.B.value,
      editable: (ANewValue, state) => ANewValue === 'Hello' ? 'true' : 'false',
      readable: (ANewValue, state) => state.fields.B.readable,
      required: (ANewValue, state) => false,
      otherProps: (ANewValue, state) => ({
        placeholder: ANewValue.toLowerCase(),
        label: ANewValue.toUpperCase()
      })
    },
    {
      name: 'C',
      path: ['fields', 'C'],
      value: (ANewValue, state) => ANewValue.toLowerCase(),
      editable: (ANewValue, state) => true,
      readable: (ANewValue, state) => state.fields.C.readable,
      required: (ANewValue, state) => false
    }
  ],
  B: [
    {
      name: 'D',
      path: ['fields', 'D'],
      value: (BNewValue, state) => BNewValue.toLowerCase() + '*',
      editable: (BNewValue, state) => true,
      readable: (BNewValue, state) => state.fields.D.readable,
      required: (ANewValue, state) => false
    }
  ]
}

Each rule has the following properties:

Property NameisRequiredTypeDescription
nametruestringName of the field that will be used to uniquely identify the field.
pathtrueArray<string>Path of the field where it resides in the state.
valuetrue(newValue, state) => anyFunction that will be used to calculate new value for the field.
editabletrue(newValue, state) => booleanFunction that will be used to calculate new editable value for the field.
readabletrue(newValue, state) => booleanFunction that will be used to calculate new readable value for the field.
requiredtrue(newValue, state) => booleanFunction that will be used to calculate new required value for the field.
otherPropsfalse(newValue, state) => {}Function that will be used to calculate other props that do not change often like value, editable, readable etc, like label, placeholder, styles etc.

Wanna Contribute?

Any help is appreciated.

Clone the project and create your own branch to work on. Once done create a Pull Request.

Make sure to run tests and add more tests if you add a new feature or to replicate the bug that you are trying to fix.

npm run test

FAQs

Package last updated on 01 Aug 2018

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc