--- layout: docs title: Interface Components ---

N1 uses React to create a fast, responsive UI. Packages that want to extend the N1 interface should use React. Using React's JSX syntax is optional, but both JSX and CJSX (CoffeeScript) are available.

For a quick introduction to React, take a look at Facebook's Getting Started with React.

React Components

N1 provides a set of core React components you can use in your packages. Many of the standard components listen for key events, include considerations for different platforms, and have extensive CSS. Wrapping standard components makes it easy to build rich interfaces that are consistent with the rest of the N1 platform.

To use a standard component, require it from nylas-component-kit and use it in your component's render method.

Keep in mind that React's Component model is based on composition rather than inheritance. On other platforms, you might subclass Popover to create your own custom Popover. In React, you should wrap the standard Popover component in your own component, which provides the Popover with props and children to customize its behavior.

Here's a quick look at standard components you can require from nylas-component-kit:

React Component Injection

The N1 interface is composed at runtime from components added by different packages. The app's left sidebar contains components from the composer package, the source list package, the activity package, and more. You can leverage the flexiblity of this system to extend almost any part of N1's interface.

Registering Components

After you've created React components in your package, you should register them with the ComponentRegistry. The Component Registry manages the dynamic injection of components that makes N1 so extensible. You can request that your components appear in a specific Location defined by the WorkspaceStore, or register your component for a Role that another package has declared.

The Component Registry allows you to insert your custom component without hacking up the DOM. Register for a Location or Role and your Component will be rendered into that part of the interface.

It's easy to see where registered components are displayed in N1. Enable the Developer bar at the bottom of the app by opening the Inspector panel, and then click "Component Regions":

Each region outlined in red is filled dynamically by looking up a React component or set of components from the Component Registry. You can see the role or location you'd need to register for, and the props that your component will receive in those locations.

Here are a few examples of how to use it to extend N1. Typically, packages register components in their main activate method, and unregister them in deactivate:

  1. Add a component to the Thread List column:

         ComponentRegistry.register ThreadList,
           location: WorkspaceStore.Location.ThreadList
    
  2. Add a component to the action bar at the bottom of the Composer:

         ComponentRegistry.register TemplatePicker,
           role: 'Composer:ActionButton'
    
  3. Replace the Participants component that ships with N1 to display thread participants on your own:

         ComponentRegistry.register ParticipantsWithStatusDots,
             role: 'Participants'
    

Tip: Remember to unregister components in the deactivate method of your package.

Using Registered Components

It's easy to build packages that use the Component Registry to display components vended by other parts of the application. You can query the Component Registry and display the components it returns. The Component Registry is a Reflux-compatible Store, so you can listen to it and update your state as the registry changes.

There are also several convenience components that make it easy to dynamically inject components into your Virtual DOM. These are the preferred way of using injected components.

<InjectedComponent
    matching={role:"Attachment"}
    exposedProps={file: file, messageLocalId: @props.localId}/>
<InjectedComponentSet
    className="message-actions"
    matching={role:"MessageAction"}
    exposedProps={thread:@props.thread, message: @props.message}>

Unsafe Components

N1 considers all injected components "unsafe". When you render them using InjectedComponent or InjectedComponentSet, they will be wrapped in a component that prevents exceptions in their React render and lifecycle methods from impacting your component. Instead of your component triggering a React Invariant exception in the application, an exception notice will be rendered in place of the unsafe component.

In the future, N1 may automatically disable packages when their React components throw exceptions.