(
state: any,
strPath: string
)
| 43 | }; |
| 44 | |
| 45 | function determineChangedProps( |
| 46 | state: any, |
| 47 | strPath: string |
| 48 | ): ChangedPropsRecord { |
| 49 | let combinedHash = 0; |
| 50 | let renderType: any; // Default render type, adjust as needed |
| 51 | const changedProps: Record<string, any> = {}; |
| 52 | Object.entries(state.layoutHashes).forEach(([updatedPath, pathHash]) => { |
| 53 | const [descendant, remainingSegments] = isFirstLevelPropsChild( |
| 54 | updatedPath, |
| 55 | strPath |
| 56 | ); |
| 57 | if (descendant) { |
| 58 | const previousHash: any = pathOr({}, [updatedPath], previousHashes); |
| 59 | combinedHash += pathOr(0, ['hash'], pathHash); |
| 60 | if (previousHash !== pathHash) { |
| 61 | if (updatedPath !== strPath) { |
| 62 | Object.assign(changedProps, {[remainingSegments[1]]: true}); |
| 63 | renderType = 'components'; |
| 64 | } else { |
| 65 | Object.assign( |
| 66 | changedProps, |
| 67 | pathOr({}, ['changedProps'], pathHash) |
| 68 | ); |
| 69 | renderType = pathOr({}, ['renderType'], pathHash); |
| 70 | } |
| 71 | previousHashes[updatedPath] = pathHash; |
| 72 | } |
| 73 | } |
| 74 | }); |
| 75 | |
| 76 | return { |
| 77 | hash: combinedHash, |
| 78 | changedProps, |
| 79 | renderType |
| 80 | }; |
| 81 | } |
| 82 | |
| 83 | export const selectDashProps = |
| 84 | (componentPath: DashLayoutPath) => |
no test coverage detected
searching dependent graphs…