Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/coatue-oss/angular2react

One line of code to turn any Angular 1 Component into a React Component
https://github.com/coatue-oss/angular2react

angular angularjs react reactjs

Last synced: 19 days ago
JSON representation

One line of code to turn any Angular 1 Component into a React Component

Awesome Lists containing this project

README

        

Angular to React: The easiest way to embed Angular components in a React app

# angular2react [![Build Status](https://img.shields.io/circleci/project/coatue-oss/angular2react.svg?branch=master&style=flat-square)](https://circleci.com/gh/coatue-oss/angular2react) [![NPM](https://img.shields.io/npm/v/angular2react.svg?style=flat-square)](https://www.npmjs.com/package/angular2react) [![Apache2](https://img.shields.io/npm/l/angular2react.svg?style=flat-square)](https://opensource.org/licenses/Apache2)

> One line of code to turn any Angular 1 Component into a React Component (opposite of [react2angular](https://github.com/coatue-oss/react2angular))

## Installation

```sh
# Using Yarn:
yarn add angular2react angular angular-resource react react-dom @types/angular @types/react @types/react-dom

# Or, using NPM:
npm install angular2react angular angular-resource react react-dom @types/angular @types/react @types/react-dom --save
```

## Usage

### 1. Save a reference to the `$injector`

```js
let $injector
angular
.module('myModule')
.run(['$injector', function(_$injector) { $injector = _$injector }])
```

### 2. Create an Angular component

```js
const MyComponent = {
bindings: {
fooBar: '<',
baz: '<'
},
template: `

FooBar: {this.$ctrl.fooBar}


Baz: {this.$ctrl.baz}


`
}
```

### 3. Expose it to Angular

```js
angular
.module('myModule', [])
.component('myComponent', MyComponent)
```

### 4. Convert it to a React Component

```js
import { angular2react } from 'angular2react'

const MyComponent = angular2react('myComponent', MyComponent, $injector)
```

### 5. Use it in your React code

```js

```

## Why step 1?

We need a reference to the `$injector` created by the Angular module that registered the Angular component you're exposing. That way we can manually compile your component.

If you use [ngimport](https://github.com/bcherny/ngimport), you can skip step 1 and omit the last argument in step 4:

```js
import { angular2react } from 'angular2react'

const MyComponent = angular2react('myComponent', MyComponent)
```

## Full Examples

https://github.com/bcherny/angular2react-demos

## Caveats

- Only one way bindings (`<`) are supported, because this is the only type of binding that React supports
- Be sure to bootstrap your Angular app before rendering its React counterpart

## Tests

```sh
npm test
```

## License

Apache-2.0