Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ui-router/react-hybrid
Hybrid adapter for routing to AngularJS and React components
https://github.com/ui-router/react-hybrid
Last synced: 4 days ago
JSON representation
Hybrid adapter for routing to AngularJS and React components
- Host: GitHub
- URL: https://github.com/ui-router/react-hybrid
- Owner: ui-router
- License: mit
- Created: 2017-07-07T17:41:09.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2023-07-11T13:32:26.000Z (over 1 year ago)
- Last Synced: 2025-01-14T12:12:19.486Z (11 days ago)
- Language: TypeScript
- Size: 1.32 MB
- Stars: 88
- Watchers: 6
- Forks: 38
- Open Issues: 18
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome - react-hybrid - Hybrid adapter for routing to AngularJS and React components (TypeScript)
README
# UI-Router react-hybrid
### UI-Router support for Hybrid Angular/React apps
This package enables UI-Router to route to both AngularJS components (and/or templates) and React components.
Your app will be hosted by AngularJS while you incrementally migrate to React.```js
import { ReactAboutComponent } from "./about.component";/// ...
$stateProvider.state({
name: 'home',
url: '/home',
component: 'ng1HomeComponent' // AngularJS component or directive name
}).state({
name: 'about',
url: '/about',
component: ReactAboutComponent // React component class reference
});.state({
name: 'other',
url: '/other',
template: 'Other
', // AngularJS template/controller
controller: function($scope) { /* do stuff */ }
})```
When routing to a React component, that component can use the standard
[React directives (UIView, UISref, UISrefActive) from `@uirouter/react`](https://ui-router.github.io/react/docs/latest/modules/components.html).When routing to an AngularJS component or template, that component uses the standard
[AngularJS directives (ui-view, ui-sref, ui-sref-active) from `@uirouter/angularjs`](https://ui-router.github.io/ng1/docs/latest/modules/directives.html).### Getting started
Remove `angular-ui-router` (or `@uirouter/angularjs`) from your package.json and replace it with `@uirouter/react-hybrid`.
Add the `react` and `react-dom` dependencies.```
dependencies: {
...
"angular": "^1.6.0",
"react": "^15.4.0",
"react-dom": "^15.4.0",
...
"@uirouter/react-hybrid": "^0.0.8",
...
}
```#### Add AngularJS module for hybrid support
```js
import { UI_ROUTER_REACT_HYBRID } from '@uirouter/react-hybrid';
let ng1module = angular.module("myApp", ['ui.router', UI_ROUTER_REACT_HYBRID]);
```#### Route to AngularJS components/templates
Your existing AngularJS routes work the same as before.
```
var foo = {
name: 'foo',
url: '/foo',
component: 'fooComponent'
};
$stateProvider.state(foo);var bar = {
name: 'foo.bar',
url: '/bar',
templateUrl: '/bar.html',
controller: 'BarController'
};
$stateProvider.state(bar);
```#### Route to React components
Use `component:` in your state declaration.
```
var leaf = {
name: 'foo.bar.leaf',
url: '/leaf',
component: MyReactComponentClass
};
$stateProvider.state(leaf);
```## How it works
### React and AngularJS ui-views
An AngularJS `` can have default content.
This default content is rendered when no state is filling the `ui-view` with a component.
For example, a parent state may render a `ui-view` portal, but want `Default Content` to display
when no child state is active: `Default Content`.The `@uirouter/react-hybrid` project **sets the default content to an adapter component**, ``.
The `react-ui-view-adapter` then renders a React ``.When a state loads an AngularJS view into the AngularJS ``, it replaces the `react-ui-view-adapter` default content.
When a state loads a React Component into the React `` component, it is nested inside the AngularJS components like so:
```html
// angularjs
// angularjs
// react
//react
```
### Providing "context" to children
In AngularJS, each `` provides the state context to its children elements, such as `ui-sref` or `ui-view`.
The state context allows a `ui-sref` to use relative links, for example.
AngularJS provides this context by setting hidden data on its DOM element, using `angular.element(el).data('$uiView')`.
Any nested `ui-view` or `ui-sref` fetches the context by asking for `angular.element(childel).inheritedData('$uiView')`.In React, each `UIView` provides the state context to its children elements using [React context](https://facebook.github.io/react/docs/context.html).
The nested `UIView` or `UISref` fetches the state context using the React context API.There is some glue provided by `@uirouter/react-hybrid` which bridges these two context mechanisms.
When a React `UIView` component is rendered, it is wrapped in a `UIRouterReactContext` component.
The component finds the state context by looking first via React props, and second via AngularJS DOM data.
It then provides the state context to its children using React props.The `` wraps a React `UIView` component.
When the react `UIView` is filled by a state's react component, the `react-ui-view-adapter` gets the state context for the newly filled `UIView`.
It then provides that context to AngularJS components using AngularJS DOM data.