Hiding values from React Developer Tools
By default, useStateValue
and useStateValueWithReactiveSelector
only exposes the state value to the React Developer Tools in non-production environments and hides it in production environment.
The state value is obscured by storing it inside a WeakMap
and conditionally exposed as "InspectableValue
" instead.
This behavior can be changed via the visibility
option, which has three modes:
ENVIRONMENT
— State values will be exposed in non-production environments, but hidden in production environment. This is the default behavior.EXPOSED
— State values will be always exposed regardless of the environment.HIDDEN
— State values will be always hidden regardless of the environment.
The screenshots below show how State Managers with different visibility
values appear in the React Developer Tools.
With data:image/s3,"s3://crabby-images/87b45/87b45cd9aa2b6834978f8271dde9888a0ef9ac74" alt="Inspecting an exposed state in React Dev Tools"
data:image/s3,"s3://crabby-images/a7d90/a7d9053f3e8a3a8121bd57ad7808778e710e6932" alt="Inspecting an exposed state in React Dev Tools"
StateManagerVisibility.HIDDEN
:data:image/s3,"s3://crabby-images/87b45/87b45cd9aa2b6834978f8271dde9888a0ef9ac74" alt="Inspecting an exposed state in React Dev Tools"
data:image/s3,"s3://crabby-images/a7d90/a7d9053f3e8a3a8121bd57ad7808778e710e6932" alt="Inspecting an exposed state in React Dev Tools"
With data:image/s3,"s3://crabby-images/24b42/24b4219572d1a0c21f6664dc2096f92bf93a5f02" alt="Inspecting a hidden state in React Dev Tools"
data:image/s3,"s3://crabby-images/622d9/622d9a24161253ecb9eb335d2b37bb3669c80090" alt="Inspecting a hidden state in React Dev Tools"
StateManagerVisibility.EXPOSED
:data:image/s3,"s3://crabby-images/24b42/24b4219572d1a0c21f6664dc2096f92bf93a5f02" alt="Inspecting a hidden state in React Dev Tools"
data:image/s3,"s3://crabby-images/622d9/622d9a24161253ecb9eb335d2b37bb3669c80090" alt="Inspecting a hidden state in React Dev Tools"
Related items: