sagess-devtools

1.0.5 • Public • Published

Focus dev tools

Install it with npm install sagess-devtools -D

By default to display it press ctrl+m on your keyboard.

The purpose of these dev tools is to provide help for your focus projects:

  • Store data and store state

image You can explore all your stores data.

  • Routes information

image You can list all your routes and click on them.

Its purpose is also to allow us to collect some satisfaction indicators. image

Please provide some feedback

Here is a short video demo of this tool

A video of the component in action

<iframe width="560" height="315" src="https://www.youtube.com/embed/XuaWkIbWR-A" frameborder="0" allowfullscreen></iframe>

How to use it

You have two components at your disposal:

  • A dispatcher logger which can help you trace all the incoming actions to your app
import dispatchLogger from 'focus-dev-tools/logger/dispatch-logger';
import dispatcher from 'sagess-core/dispatcher';
import CoreStore from 'sagess-core/stores/CoreStore'

dispatchLogger(dispatcher, () => CoreStore._instances);
  • A FocusDevTools console to visualize information, create a container component in your project.
import FocusDevTools from 'sagess-devtools';
import React from 'react';
import history from 'sagess-core/history';
import CoreStore from 'sagess-core/store/CoreStore'


const devTools = () => <FocusDevTools
                        isPanel /* If you want to embed the component in a DOck */
                        toggleVisibilityKey={'ctrl-m'}  /*How do you want to display the dev tool*/
                        routes={history.handlers}  /* A list of all your routes (`sagess-core/router/history`)*/
                        getStores={() => CoreStore.prototype._instances} /* A list of all your stores (`sagess-core/CoreStore._instances`)*/
                        isDebugDevTools={false} /* If you want to display the dev tools props (not usefull for the projects)*//* If you want to display the dev tools props (not usefull for the projects)*/
                         />

export default devTools;

It has to be included in the Layout of the application, as an example in the starter kit and the demo app there is a layout-initializer

import React from 'react';
import Layout from 'sagess-components/components/layout';
import MenuLeft from '../../views/menu/menu-left';
import DevTools from '../dev-tools';


const CustomLayout = (props) => (
        <div>
          <Layout
              MenuLeft={MenuLeft}
          >
          {props.children}
          </Layout>
          <DevTools/>
        </div>
);

export default CustomLayout;

where DevTools is the container component you just create.

We hope this will help you and improve your experience with focus.

Warning

You have to add an explicit name property to your stores.

import {CoreStore} from 'sagess-core/store';

/**
* Store dealing with subjects about persons.
* @type {focus}
*/
const personStore = new CoreStore({
    definition: {
        personIdentity: 'personIdentity',
        personBiography: 'personBiography',
        personMovieLinks: 'personMovieLinks'
    }
});

personStore.name = 'PersonStore';

export default personStore;

Readme

Keywords

Package Sidebar

Install

npm i sagess-devtools

Weekly Downloads

0

Version

1.0.5

License

MIT

Unpacked Size

70.3 kB

Total Files

43

Last publish

Collaborators

  • anasamo92