You can clear Reactotron by calling clear()
.
For example, let's say in React Native you want to clear the logs everytime you start up? Add this to your app's ReactotronConfig.js
:
Reactotron.clear()
Don't... said the stranger on the Internet pretending he knows what's best for you.
Please install reactotron-react-native
, reactotron-react-js
, and others with --save-dev
instead of --save
.
For React Native apps, there's several good reasons.
- Battery life. WebSockets will drain the battery as the connection stays open.
- Privacy. Your app might store stuff in state that the user realize... like social tokens.
- Security. You can literally remote control parts of the app. Yikes!
Surround your Reactotron activities with:
if (__DEV__) {
// ZAP!
}
This means you'll need to be careful to use require()
instead of import
as import
in ES6 are hoisted!
Flip Flop Alert! Technically it's possible just to NPM --save
. Maybe you want to do some debugging on a production build on a local device? That's cool. Just please, don't ship without conditionally shutting off Reactotron.connect()
. <3
For web sites, well... CORS browser security will pretty much shut you down anyway.
If you're running ReactJS and webpack, anything inside false
expressions will get nuked in production builds.
if (process.env.NODE_ENV !== 'production') {
// ZAP!
}
In ES6, you must import Reactotron at the top of your file before using it like this:
import Reactotron from 'reactotron-react-native'
// or import Reactotron from 'reactotron-react-native'
And later on in your file, you type:
Reactotron.log('something really interesting happened')
You can cut out the top step by attaching to the console
object in your ReactotronConfig.js
file (or wherever you setup).
// horrible, but useful hack.... oh come on, don't look at me like that... it's JavaScript :|
console.tron = Reactotron
Now, anywhere in your app if you want to log something?
console.tron.log('Sweet Freedom!')
You can add an important indicator light on any log by adding true
as a second parameter. E.g.
// or Reactotron.log
console.tron.log('I am important', true)
Additionally, you can access a more advanced message and indicator with display
.
// or Reactotron.display
console.tron.display({
name: 'Tacos',
value: {a: 1, b: [1,2,3]},
preview: 'when you click here, it might surprise you!',
important: true,
image: 'http://placekitten.com/g/400/400'
})
If you're using reactotron-redux and an immutable library such as seamless-immutable you need to make sure you transform your state back into an immutable object when using State Snapshots.
To do so you can use the onRestore
callback like this:
.use(reactotronRedux({
// Fires when Reactotron uploads a new copy of the state tree.
onRestore: state => Immutable(state)
}))
However if only some of your reducers are immutable and the rest are mutable you can selectively transform the state like this:
.use(reactotronRedux({
// Fires when Reactotron uploads a new copy of the state tree.
onRestore: state => {
return { ...Immutable(state), nav: state.nav }
}
}))
This will nav
mutable. Note this is what you want to do when using
react-navigation's default reducer.
You have control over Socket.IO and can pass through settings to control that in your Reactotron.configure({})
call.
Reactotron.configure({
socketIoProperties: {
reconnection: true,
reconnectionDelay: 2000,
reconnectionDelayMax: 5000,
reconnectionAttempts: 5
}
})