Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/marmelab/ng-admin
Add an AngularJS admin GUI to any RESTful API
https://github.com/marmelab/ng-admin
admin admin-dashboard angular ng-admin rest
Last synced: 4 days ago
JSON representation
Add an AngularJS admin GUI to any RESTful API
- Host: GitHub
- URL: https://github.com/marmelab/ng-admin
- Owner: marmelab
- License: mit
- Created: 2014-05-22T12:00:10.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2020-06-01T07:58:30.000Z (over 4 years ago)
- Last Synced: 2025-01-04T20:30:12.081Z (8 days ago)
- Topics: admin, admin-dashboard, angular, ng-admin, rest
- Language: JavaScript
- Homepage: http://ng-admin-book.marmelab.com/
- Size: 69.3 MB
- Stars: 3,942
- Watchers: 196
- Forks: 725
- Open Issues: 111
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- annals-of-awesome - Resource - Create an admin interface for a RESTful API. (Web Development / Angular)
- awesome-github-repos - marmelab/ng-admin - Add an AngularJS admin GUI to any RESTful API (JavaScript)
- awesome-rest - ng-admin - Add an AngularJS admin GUI to any RESTful API. (Miscellaneous / Public REST APIs To Use In Tests)
- awesome-starred - marmelab/ng-admin - Add an AngularJS admin GUI to any RESTful API (angular)
- starred-awesome - ng-admin - Add an AngularJS admin GUI to any RESTful API (JavaScript)
README
ng-admin [![Build Status](https://travis-ci.org/marmelab/ng-admin.svg?branch=master)](https://travis-ci.org/marmelab/ng-admin)
========[![Join the chat at https://gitter.im/marmelab/ng-admin](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/marmelab/ng-admin?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
Plug me to your RESTFul API to get a complete administration interface (datagrid, filters, complex form widgets, multi-model relationships, dashboard) in no time! Beyond simple CRUD, ng-admin lets you build sophisticated GUIs without getting in your way.
[![Screencast](https://static.marmelab.com/ng-admin-09-video-thumbnail.png)](https://vimeo.com/143909685)
* [Online demo](http://marmelab.com/ng-admin-demo/) ([source](https://github.com/marmelab/ng-admin-demo))
* [Documentation](http://ng-admin-book.marmelab.com/)**This project is now in maintenance mode. We've rebuilt it from scratch with React.js (the new project is called [react-admin](https://github.com/marmelab/react-admin)), and we're putting all our efforts on the React version.**
## Installation
The current ng-admin version (master) depends on Angular.js 1.6. If you need compatibility with Angular 1.3, use [ng-admin 0.9](https://github.com/marmelab/ng-admin/releases/tag/v0.9.1).
Grab ng-admin from your favorite package manager:
```sh
npm install ng-admin --save
# or
yarn add ng-admin
```### With a Module Bundler
`ng-admin` is fully compatible with Webpack, and should also be compatible with all
available major module bundlers. If you use one of them, you just have to add this line:``` js
const myApp = angular.module('myApp', [
require('ng-admin'),
// ...
]);
```**Important note:** as we include HTML templates using `require` to prevent the AJAX
request implied by `templateUrl`, you will need to configure your module bundler
to deal with HTML. It can be accomplished with Webpack using the HTML loader:``` js
module.exports = {
// ...
module: {
loaders: [
// ...
{ test: /\.html$/, loader: 'html' },
]
},
};
```If your module bundler also supports SASS or CSS, you can also include stylesheets using:
``` js
// SASS version
require('ng-admin/lib/sass/ng-admin.scss');// CSS version
require('ng-admin/build/ng-admin.min.css');
```Using a module bundler, you would also be able to generate the source map for all your JavaScript
and stylesheets, helping you to hunt even the most obscure bugs.### Without a Module Bundler
If you don't have a module bundler, don't worry: you can still include `ng-admin` with a `` tag:
``` html
<link rel="stylesheet" href="node_modules/ng-admin/build/ng-admin.min.css">
<script src="node_modules/ng-admin/build/ng-admin.min.js">
```## Bootstrapping your Admin
Add the `ng-admin.min.css` and `ng-admin.min.js` to the HTML, add a `
`, and configure the admin:``` html
My First Admin
var myApp = angular.module('myApp', ['ng-admin']);
myApp.config(['NgAdminConfigurationProvider', function(NgAdminConfigurationProvider) {
var nga = NgAdminConfigurationProvider;
// create an admin application
var admin = nga.application('My First Admin');
// more configuration here later
// ...
// attach the admin application to the DOM and run it
nga.configure(admin);
}]);
```
## Getting Started
See the [Getting Started](doc/Getting-started.md) dedicated chapter for a step-by-step tutorial aimed at beginners.
## Usage Examples
* You can find a simple configuration in the [blog admin demo](examples/blog/config.js), where the entities are posts, comments, and tags. The remote REST API is simulated in the browser, using [FakeRest](https://github.com/marmelab/FakeRest).
* The [Posters Galore demo](http://marmelab.com/ng-admin-demo/) ([source](https://github.com/marmelab/ng-admin-demo)) is a more complete example of an e-commerce administration, with custom authentication, pages, directives and modules, all well organized via WebPack. The remote REST API is also simulated in the browser, using [FakeRest](https://github.com/marmelab/FakeRest).## Configuration Reference
An administration in ng-admin is made of one *application* containing several *entities*. Each entity has up to 5 *views*, and each view has many *fields*.
```
application
|-header
|-menu
|-dashboard
|-entity[]
|-creationView
|-editionView
|-deletionView
|-showView
|-listView
|-field[]
|-name
|-type
```See [Configuration API Reference](doc/Configuration-reference.md) dedicated chapter for more details.
**Tip**: You won't find the related classes in the ng-admin project. In fact, the admin configuration API exists as a standalone, framework-agnostic library, called [admin-config](https://github.com/marmelab/admin-config). Don't hesitate to browse the source of that library to learn more.
## Relationships
Ng-admin supports relationships between entities in read and write views, and provides specialized field types for that: `reference`, `referenced_list`, `reference_many`, and `embedded_list`. The [Relationships Reference chapter](doc/Relationships.md) describes in more details which field type to use for which case.
Also, the Fields section of the [Configuration API Reference chapter](doc/Configuration-reference.md) has a list of all settings for each of these field types.
## Menu Configuration
By default, ng-admin creates a sidebar menu with one entry per entity. If you want to customize this sidebar (labels, icons, order, adding submenus, etc), you have to define menus manually.
See [Menus Configuration](doc/Menus.md) dedicated chapter.
## Dashboard Configuration
The home page of a ng-admin application is called the Dashboard. Use it to show important pieces of information to the end user, such as latest entries, or charts.
See [Dashboard Configuration](doc/Dashboard.md) dedicated chapter.
## Customizing the API Mapping
All HTTP requests made by ng-admin to your REST API are carried out by [Restangular](https://github.com/mgonto/restangular), which is like `$resource` on steroids.
The REST specification doesn't provide enough detail to cover all requirements of an administration GUI. ng-admin makes some assumptions about how your API is designed. All of these assumptions can be overridden by way of [Restangular's request and response interceptors](https://github.com/mgonto/restangular#addresponseinterceptor).
That means you don't need to adapt your API to ng-admin; ng-admin can adapt to any REST API, thanks to the flexibility of Restangular.
See the [Customizing the API Mapping](doc/API-mapping.md) dedicated chapter.
## Theming
You can override pretty much all the HTML generated by ng-admin, at different levels.
See the [Theming](doc/Theming.md) dedicated chapter.
## Translation
The ng-admin interface uses English as the default language, but supports switching to another language, thanks to [angular-translate](https://angular-translate.github.io/).
See the [Translation](doc/Translation.md) dedicated chapter.
## Adding Custom Pages
For each entity, ng-admin creates the necessary pages for Creating, Retrieving, Updating, and Deleting (CRUD) this entity. When you need to achieve more specific actions on an entity, you have to add a custom page - for instance a page asking for an email address to send a message to. How can you route to a specific page and display it in the ng-admin layout?
See the [Adding Custom Pages](doc/Custom-pages.md) dedicated chapter.
## Adding Custom Types
When you map a field between a REST API response and ng-admin, you give it a type. This type determines how the data is displayed and edited. It is very easy to customize existing ng-admin types and add new ones.
See the [Adding Custom Types](doc/Custom-types.md) dedicated chapter.
## Getting Ready For Production
To build the ng-admin source with the dependencies you need, and to get hints about performance boosters, head to the [Getting Ready For Production](doc/Production.md) dedicated chapter.
## News
Follow the [marmelab blog](http://marmelab.com/blog/) for news about ng-admin (tutorials, plugins, new releases, etc).
You should also watch the [ng-admin release page on GitHub](https://github.com/marmelab/ng-admin/releases) for announcements on new releases, and complete changelog.
## Support
Ng-admin is an open-source project, with a community getting larger every day. You will get help by asking politely in any the following channels:
* [StackOverflow](http://stackoverflow.com/questions/tagged/ng-admin)
* [Gitter (live chat)](https://gitter.im/marmelab/ng-admin) [![Join the chat at https://gitter.im/marmelab/ng-admin](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/marmelab/ng-admin?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)Please give as much context as possible, including and admin configuration snippet, and the response from the API you're mapping.
## Looking For a Material UI / React.js version?
[marmelab/admin-on-rest](https://github.com/marmelab/admin-on-rest), by the same team, uses a different architecture but provides a similar service: an admin GUI for REST APIs, this time with React.js, Redux, react-router, and material UI.
## Contributing
Your feedback about the usage of ng-admin in your specific context is valuable, don't hesitate to [open GitHub Issues](https://github.com/marmelab/ng-admin/issues) for any problem or question you may have.
All contributions are welcome: please send us a Pull Request for any new feature / bug fix in your fork that you consider worth giving back.
Also, if you have some experience with ng-admin, please answer questions from newcomers in any of the support channels (see above).
### Installing Dependencies
Install npm dependencies (for tests) by calling the `install` target:
```sh
make install
```### Running the example app
To test your changes, run the example app, which is bundled with a sample REST api, by calling:
```sh
make run
```Then, connect to `http://localhost:8000/` to browse the admin app. This task uses webpack-dev-server, which means that the browser will reload the page as soon as one file in the source is updated. This makes the blog app our preferred live testing environment.
### Testing
ng-admin has unit tests (powered by karma) and end to end tests (powered by protractor). Launch the entire tests suite by calling:
```sh
make test
```**Tip:** If you are working on Karma tests, you can prevent from relaunching the whole process by disabling single-run:
```
./node_modules/.bin/karma start src/javascripts/test/karma.conf.js
```### Releasing
Before releasing a new version, concatenate and minify the JS and CSS sources into minified scripts with:
```sh
make build
git add build
git commit -m 'update built files'
git push origin master
git tag vx.x.x
# create a new tag
git push origin --tags
# publish to npm
npm publish
```**Tip**: Don't commit built files in Pull Requests, it forces rebases on other PRs. The core team will take care of regularly updating these built files.
## License
ng-admin is licensed under the [MIT Licence](LICENSE), and sponsored by [marmelab](http://marmelab.com).