2020-11-25 10:50:51 +01:00
|
|
|
import { enrichDataBindings } from "./enrichDataBinding"
|
|
|
|
import { enrichButtonActions } from "./buttonActions"
|
|
|
|
|
2021-01-21 11:41:30 +01:00
|
|
|
/**
|
|
|
|
* Deeply compares 2 props using JSON.stringify.
|
|
|
|
* Does not consider functions, as currently only button actions have a function
|
|
|
|
* prop and it's cheaper to just always re-render buttons than it is to deeply
|
|
|
|
* compare them.
|
|
|
|
*/
|
|
|
|
export const propsAreSame = (a, b) => {
|
|
|
|
if (a === b) {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
if (typeof a === "function" || typeof b === "function") {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return JSON.stringify(a) === JSON.stringify(b)
|
|
|
|
}
|
|
|
|
|
2020-11-25 10:50:51 +01:00
|
|
|
/**
|
|
|
|
* Enriches component props.
|
|
|
|
* Data bindings are enriched, and button actions are enriched.
|
|
|
|
*/
|
2021-06-01 15:59:42 +02:00
|
|
|
export const enrichProps = (props, context) => {
|
2020-11-25 10:50:51 +01:00
|
|
|
// Create context of all bindings and data contexts
|
|
|
|
// Duplicate the closest context as "data" which the builder requires
|
2021-02-01 19:51:22 +01:00
|
|
|
const totalContext = {
|
|
|
|
...context,
|
2021-02-02 15:32:58 +01:00
|
|
|
|
|
|
|
// This is only required for legacy bindings that used "data" rather than a
|
|
|
|
// component ID.
|
2021-02-01 19:51:22 +01:00
|
|
|
data: context[context.closestComponentId],
|
2020-11-25 10:50:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Enrich all data bindings in top level props
|
2021-06-25 16:04:27 +02:00
|
|
|
let enrichedProps = enrichDataBindings(props, totalContext)
|
2020-11-25 10:50:51 +01:00
|
|
|
|
2021-03-25 17:18:19 +01:00
|
|
|
// Enrich click actions if they exist
|
|
|
|
if (enrichedProps.onClick) {
|
2021-02-03 16:53:25 +01:00
|
|
|
enrichedProps.onClick = enrichButtonActions(
|
|
|
|
enrichedProps.onClick,
|
|
|
|
totalContext
|
|
|
|
)
|
2020-11-25 10:50:51 +01:00
|
|
|
}
|
|
|
|
|
2021-07-23 16:44:16 +02:00
|
|
|
// Enrich any click actions in conditions
|
|
|
|
if (enrichedProps._conditions) {
|
|
|
|
enrichedProps._conditions.forEach(condition => {
|
|
|
|
if (condition.setting === "onClick") {
|
|
|
|
condition.settingValue = enrichButtonActions(
|
|
|
|
condition.settingValue,
|
|
|
|
totalContext
|
|
|
|
)
|
2021-08-23 17:39:09 +02:00
|
|
|
|
|
|
|
// If there is an onclick function in here then it won't be serialised
|
|
|
|
// properly, and therefore will not be updated properly.
|
|
|
|
// The solution to this is add a rand which will ensure diffs happen
|
|
|
|
// every time.
|
|
|
|
condition.rand = Math.random()
|
2021-07-23 16:44:16 +02:00
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2020-11-25 10:50:51 +01:00
|
|
|
return enrichedProps
|
|
|
|
}
|