Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/angular/material-start
Starter Repository for AngularJS Material
https://github.com/angular/material-start
angularjs angularjs-material javascript material-design material-start
Last synced: 3 months ago
JSON representation
Starter Repository for AngularJS Material
- Host: GitHub
- URL: https://github.com/angular/material-start
- Owner: angular
- License: mit
- Archived: true
- Created: 2015-01-12T19:26:04.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2022-03-08T19:25:14.000Z (almost 3 years ago)
- Last Synced: 2024-09-19T12:06:04.691Z (3 months ago)
- Topics: angularjs, angularjs-material, javascript, material-design, material-start
- Language: JavaScript
- Homepage: https://angularjs-material-start.web.app
- Size: 493 KB
- Stars: 2,205
- Watchers: 145
- Forks: 1,214
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# AngularJS Material-Start (ES6)
[![Gitter](https://badges.gitter.im/angular/material2.svg)](https://gitter.im/angular/material?utm_source=badge&utm_medium=badge)This branch contains the final/complete version (i.e. `step-10-finished`) of the
[Material Start ES6 Tutorial](https://github.com/angular/material-start/tree/es6-tutorial) branch
in this repository.You can see the [Live Demo here](https://angularjs-material-start.firebaseapp.com/).
There are many additional branches in this repository that you may find useful:
- [`master`](https://github.com/angular/material-start/tree/master) (this branch) - A copy of the
`es6` branch outlined below with additional notes about the available branches.
- [`es5-tutorial`](https://github.com/angular/material-start/tree/es5-tutorial) - Step-by-step
instructions that clearly demonstrate how the Starter application can be created in minutes using
ES5.
- [`es5`](https://github.com/angular/material-start/tree/es5) - The final ES5 version which you
complete in the last step of the tutorials above.
- [`es6-tutorial`](https://github.com/angular/material-start/tree/es6-tutorial) - Step-by-step
instructions that clearly demonstrate how the Starter application can be created in minutes using
ES6.
- [`es6`](https://github.com/angular/material-start/tree/es6) - The final ES6 version which you
complete in the last step of the tutorials above.
- [`typescript`](https://github.com/angular/material-start/tree/typescript) - The final Starter
Application built using Typescript.
> **Note:** We do not currently offer a `typescript-tutorial` branch as the steps are fairly similar
to the existing `es6-tutorial` branch.#### Purpose
This project uses the latest master branch of AngularJS Material to build the application outlined
below.![material-starter-ux2](https://cloud.githubusercontent.com/assets/6004537/14996543/b588eb46-1137-11e6-803c-ce23996c9742.png)
Above is a snapshot of the Starter-App with a **Master-Detail** layout: showing a list of users
(left) and a user detail view (right).Also shown is the user experience that will be displayed for smaller device sizes. The responsive
layout reveals the **menu** button that can be used to hide the user list. And the **share** button
can be used to show the Share bottom sheet view.This Starter app demonstrates how:
* AngularJS Material `layout` and `flex` options can easily configure HTML containers
* AngularJS Material components ``, ``, and `` can quickly provide
a base application structure
* Custom controllers can be used and show `` with HTML templates
* Custom controller can easily, and programmatically open/close the SideNav component
* Responsive breakpoints and `$mdMedia` are used
* Theming can be altered/configured using `$mdThemingProvider`This sample application is purposed as both a learning tool and a skeleton application for a typical
[AngularJS Material](http://angularjs.org/) web app, comprised of a side navigation area and a
content area. You can use it to quickly bootstrap your angular webapp projects and dev environment
for these projects.- - -
#### "How to build an App"
Here are some generalized steps that may be used to conceptualize the application implementation
process:1. Plan your layout and the components you want to use
2. Use hard-coded HTML and mock content to make sure the components appear as desired
3. Wire components to your application logic
> Use the seamless integration possible with AngularJS directives and controllers.
> This integration assumes that you have unit tested your application logic.4. Add Responsive breakpoints
5. Add Theming support
6. Confirm ARIA compliance
7. Write End-to-end (e2e) Tests
> It is important to validate your application logic with AngularJS Material UI components.
###### Wireframe
The illustration below shows how we planned the layout and identified the primary components that
will be used in the Starter app:
> **Note:** The container #2 (above) is a simple `
` container and not an AngularJS Material
component.- - -
##### Getting Started
This project uses [jspm.io](http://jspm.io), a package manager for SystemJS which is built on top
of the dynamic ES6 module loader. This allows developers to load any module format (ES6, CommonJS,
AMD, and globals).###### Prerequisites
This project assumes that you have NodeJS and any relevant development tools (like XCode) already
installed.
###### Getting StartedClone this repository and execute the following commands in a terminal:
* `git checkout master`
* `npm install`
* `npm run serve`> **Note:** Open the dev console to see any warnings and browse the elements.
###### Layout
You will notice a few files/directories within this project:
1. `app/src` - This is where all of your application files are stored.
2. `app/assets` - This folder contains some tutorial-provided images and icons which are used by
the application.
3. `index.html` - The entry point to your application. This uses System.js to load the
`app/src/boot/boot.js` bootstrap file which in turn loads the `app/src/app.js` file that imports
all of your dependencies and declares them as AngularJS modules, and configures the icons and
theming for the application.#### Troubleshooting
If you have issues getting the application to run or work as expected:
1. Make sure you have installed JSPM and run the `jspm update` command.
2. Reach out on our [Forum](https://groups.google.com/forum/#!forum/ngmaterial) to see if any other
developers have had the same issue.
3. This project is based against the `master` branch of AngularJS Material, so it is always showing
the latest and greatest. You may want to update the `package.json` to use Version 1.1.0 or
another stable release to make sure it isn't because of something we changed recently.
4. Search for the issue here on [GitHub](https://github.com/angular/material-start/issues?q=is%3Aissue+is%3Aopen).
5. If you don't see an existing issue, please open a new one with the relevant information and the
details of the problem you are facing.