Skip to content

Commit

Permalink
Changed overrideHook to support useReducer overrides; added isEditabl…
Browse files Browse the repository at this point in the history
…e bool to hooks metadata
  • Loading branch information
Brian Vaughn committed Feb 21, 2019
1 parent fe5271d commit 15b3e6e
Show file tree
Hide file tree
Showing 4 changed files with 180 additions and 38 deletions.
8 changes: 6 additions & 2 deletions packages/react-debug-tools/src/ReactDebugHooks.js
Original file line number Diff line number Diff line change
Expand Up @@ -233,6 +233,7 @@ const Dispatcher: DispatcherType = {

type HooksNode = {
index: number,
isEditable: boolean,
name: string,
value: mixed,
subHooks: Array<HooksNode>,
Expand Down Expand Up @@ -406,6 +407,7 @@ function buildTree(rootStack, readHookLog): HooksTree {
let children = [];
levelChildren.push({
index: -1,
isEditable: false,
name: parseCustomHookName(stack[j - 1].functionName),
value: undefined,
subHooks: children,
Expand All @@ -415,9 +417,11 @@ function buildTree(rootStack, readHookLog): HooksTree {
}
prevStack = stack;
}
const {primitive} = hook;
levelChildren.push({
index: hook.primitive === 'DebugValue' ? -1 : index++,
name: hook.primitive,
index: primitive === 'DebugValue' ? -1 : index++,
isEditable: primitive === 'Reducer' || primitive === 'State',
name: primitive,
value: hook.value,
subHooks: [],
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ describe('ReactHooksInspection', () => {
let tree = ReactDebugTools.inspectHooks(Foo, {});
expect(tree).toEqual([
{
isEditable: true,
index: 0,
name: 'State',
value: 'hello world',
Expand All @@ -49,11 +50,13 @@ describe('ReactHooksInspection', () => {
let tree = ReactDebugTools.inspectHooks(Foo, {});
expect(tree).toEqual([
{
isEditable: false,
index: -1,
name: 'Custom',
value: __DEV__ ? 'custom hook label' : undefined,
subHooks: [
{
isEditable: true,
index: 0,
name: 'State',
value: 'hello world',
Expand Down Expand Up @@ -83,17 +86,20 @@ describe('ReactHooksInspection', () => {
let tree = ReactDebugTools.inspectHooks(Foo, {});
expect(tree).toEqual([
{
isEditable: false,
index: -1,
name: 'Custom',
value: undefined,
subHooks: [
{
isEditable: true,
index: 0,
name: 'State',
subHooks: [],
value: 'hello',
},
{
isEditable: false,
index: 1,
name: 'Effect',
subHooks: [],
Expand All @@ -102,17 +108,20 @@ describe('ReactHooksInspection', () => {
],
},
{
isEditable: false,
index: -1,
name: 'Custom',
value: undefined,
subHooks: [
{
isEditable: true,
index: 2,
name: 'State',
value: 'world',
subHooks: [],
},
{
isEditable: false,
index: 3,
name: 'Effect',
value: effect,
Expand Down Expand Up @@ -152,22 +161,26 @@ describe('ReactHooksInspection', () => {
let tree = ReactDebugTools.inspectHooks(Foo, {});
expect(tree).toEqual([
{
isEditable: false,
index: -1,
name: 'Bar',
value: undefined,
subHooks: [
{
isEditable: false,
index: -1,
name: 'Custom',
value: undefined,
subHooks: [
{
isEditable: true,
index: 0,
name: 'Reducer',
value: 'hello',
subHooks: [],
},
{
isEditable: false,
index: 1,
name: 'Effect',
value: effect,
Expand All @@ -176,6 +189,7 @@ describe('ReactHooksInspection', () => {
],
},
{
isEditable: false,
index: 2,
name: 'LayoutEffect',
value: effect,
Expand All @@ -184,27 +198,32 @@ describe('ReactHooksInspection', () => {
],
},
{
isEditable: false,
index: -1,
name: 'Baz',
value: undefined,
subHooks: [
{
isEditable: false,
index: 3,
name: 'LayoutEffect',
value: effect,
subHooks: [],
},
{
isEditable: false,
index: -1,
name: 'Custom',
subHooks: [
{
isEditable: true,
index: 4,
name: 'Reducer',
subHooks: [],
value: 'world',
},
{
isEditable: false,
index: 5,
name: 'Effect',
subHooks: [],
Expand All @@ -227,6 +246,7 @@ describe('ReactHooksInspection', () => {
let tree = ReactDebugTools.inspectHooks(Foo, {});
expect(tree).toEqual([
{
isEditable: false,
index: 0,
name: 'Context',
value: 'default',
Expand Down Expand Up @@ -290,10 +310,13 @@ describe('ReactHooksInspection', () => {
let tree = ReactDebugTools.inspectHooks(Foo, {});
expect(tree).toEqual([
{
isEditable: false,
index: -1,
name: 'Custom',
value: __DEV__ ? 'bar:123' : undefined,
subHooks: [{index: 0, name: 'State', subHooks: [], value: 0}],
subHooks: [
{isEditable: true, index: 0, name: 'State', subHooks: [], value: 0},
],
},
]);
});
Expand Down
Loading

0 comments on commit 15b3e6e

Please sign in to comment.