Package Exports
- ra-data-firebase
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (ra-data-firebase) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
ra-data-firebase
Firebase data provider for React Admin
Table of Contents
About
A Firebase data provider for react-admin. Based on aor-firebase-client, modified and maintained to own preferences.
Install
This project uses node and npm. Ensure that firebase and react-admin is installed.
$ npm install ra-data-firebase
$ # OR
$ yarn add ra-data-firebaseUsage
import React, { Component } from 'react'
import { Admin, Resource } from 'react-admin'
import firebase from 'firebase'
import Login from './login'
import Dashboard from './dashboard'
import Store from '@material-ui/icons/Store'
import { AssetsCreate, AssetsEdit, AssetsList } from './assets'
import { FirebaseDataProvider } from 'ra-data-firebase'
const firebaseConfig =
{
// Firebase config used to create additional app to create users (HACK)
apiKey: '########################################',
authDomain: '########################################',
databaseURL: '########################################',
projectId: '########################################',
storageBucket: '########################################'
}
const providerConfig = {
admin: {
path: 'people', // path in db to store user information (default 'users')
config: firebaseConfig,
validate: (data) => data.isEmployee // Function to validate that a user should be created in firebase (default () => true)
},
metaFieldNames: {
createdAt: 'createdAt',
updatedAt: 'updatedAt',
createdBy: 'createdBy'
},
trackedResources: [
{
name: 'sites',
path: `sites`,
isPublic: false
},
{
name: 'assets',
path: `assets`,
isPublic: false,
uploadFields: ['pictures', 'files']
},
{
name: 'parts',
path: 'parts',
isPublic: false,
uploadFields: ['pictures', 'files']
},
{
name: 'maintenance',
path: `maintenance`,
isPublic: false,
uploadFields: ['pictures', 'files']
}
]
}
// Firebase must be initialized first
firebase.initializeApp(firebaseConfig)
class App extends Component {
render () {
return <Admin
title='Demo'
loginPage={Login}
dashboard={Dashboard}
dataProvider={FirebaseDataProvider(providerConfig)}
>
<Resource
icon={Store}
options={{ label: 'Assets' }}
name='assets'
list={AssetsList}
edit={AssetsEdit}
create={AssetsCreate}
/>
</Admin>
}
}
export default App
See
Contribute
- Fork it and create your feature branch: git checkout -b my-new-feature
- Commit your changes: git commit -am 'Add some feature'
- Push to the branch: git push origin my-new-feature
- Submit a pull request
License
MIT