Skip to content

Instantly share code, notes, and snippets.

@mmazzarolo
Created May 30, 2016 13:10
Show Gist options
  • Star 14 You must be signed in to star a gist
  • Fork 4 You must be signed in to fork a gist
  • Save mmazzarolo/8d321f01f749d3470f0314e773114a95 to your computer and use it in GitHub Desktop.
Save mmazzarolo/8d321f01f749d3470f0314e773114a95 to your computer and use it in GitHub Desktop.
While waiting for React-Native MobX devtools...
import mobx from 'mobx'
const DEFAULT_STYLE = 'color: #006d92; font-weight:bold;'
// Just call this function after MobX initialization
// As argument you can pass an object with:
// - collapsed: true -> shows the log collapsed
// - style -> the style applied to the action description
export const startLogging = ({ collapsed, style } = {}) => {
mobx.spy(event => {
if (event.type === 'action') {
if (collapsed) {
console.groupCollapsed(`Action @ ${formatTime(new Date())} ${event.name}`)
} else {
console.group(`Action @ ${formatTime(new Date())} ${event.name}`)
}
console.log('%cType: ', style || DEFAULT_STYLE, event.type)
console.log('%cName: ', style || DEFAULT_STYLE, event.name)
console.log('%cTarget: ', style || DEFAULT_STYLE, event.target)
console.log('%cArguments: ', style || DEFAULT_STYLE, event.arguments)
console.groupEnd()
}
})
}
// Utilities
const repeat = (str, times) => (new Array(times + 1)).join(str)
const pad = (num, maxLength) => repeat('0', maxLength - num.toString().length) + num
const formatTime = (time) => `${pad(time.getHours(), 2)}:${pad(time.getMinutes(), 2)}:${pad(time.getSeconds(), 2)}.${pad(time.getMilliseconds(), 3)}`
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment