Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alexlafroscia/ember-react-components
Render React components in Ember
https://github.com/alexlafroscia/ember-react-components
ember ember-addon react
Last synced: 20 days ago
JSON representation
Render React components in Ember
- Host: GitHub
- URL: https://github.com/alexlafroscia/ember-react-components
- Owner: alexlafroscia
- License: mit
- Created: 2018-03-23T22:15:18.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2022-12-09T14:49:45.000Z (about 2 years ago)
- Last Synced: 2025-01-03T07:45:52.963Z (24 days ago)
- Topics: ember, ember-addon, react
- Language: JavaScript
- Homepage: https://alexlafroscia.github.io/ember-react-components
- Size: 3.65 MB
- Stars: 52
- Watchers: 5
- Forks: 16
- Open Issues: 37
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-ember - @alexlafroscia/ember-cli-react - Render React components in Ember.js. (Packages / External Components Integration)
README
ember-react-components
==============================================================================[![Build Status](https://travis-ci.org/alexlafroscia/ember-react-components.svg?branch=master)](https://travis-ci.org/alexlafroscia/ember-react-components)
> Consume React components in Ember
This addon is a proof-of-concept for an approach to rendering React components in Ember. It is almost entirely inspired by [a blog post][blog-post] by [Sivakumar Kailasam][sivakumar], from which the general idea was borrowed.
Installation
------------------------------------------------------------------------------```bash
ember install ember-react-components @ember-decorators/babel-transforms
```Compatibility
------------------------------------------------------------------------------This addon requires Ember CLI 2.15 or higher.
Usage
------------------------------------------------------------------------------This addon provides an ES6 class decorator that allows a React element to be rendered in Ember.
As an example, you can create a component like this:
```javascript
// app/components/my-react-component.js
import React from 'react';
import WithEmberSupport from 'ember-react-components';@WithEmberSupport
export default class extends React.Component {
render() {
const { name } = this.props;return (
Hello, {name}
);
}
}
```And render it like this:
```handlebars
{{my-react-component name='Alex'}}
```That would create a component that renders `Hello, Alex`.
Options
------------------------------------------------------------------------------* `outputFile` option imports `react` and `react-dom` into a separate file than `/assets/vendor.js`. This is useful if your entire Ember application doesn't require `react`. The separate file containing `react` and `react-dom` can be imported via a template or initializer.
```javascript
// ember-cli-build.js
let app = new EmberApp(defaults, {
'ember-react-components': {
outputFile: '/assets/react.js'
}
});
```What all is this addon doing?
------------------------------------------------------------------------------* Provides imports for `react` and `react-dom`
* Hooks up a bunch of necessary `babel` transforms
* Provides a decorator for creating a thin wrapper around your React components that bridge the gap between the two librariesIs this production ready?
------------------------------------------------------------------------------It _does_ work, but you should be really careful about including both the Ember _and_ React libraries in your application since that's quite a lot of JavaScript to ship to your users.
License
------------------------------------------------------------------------------This project is licensed under the [MIT License](LICENSE.md).
[blog-post]: https://medium.com/@sivakumar_k/using-react-components-in-your-ember-app-8f7805d409b0
[sivakumar]: https://github.com/sivakumar-kailasam