Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tiaguinho/material-community-components
:panda_face: Angular Material Components created from the community
https://github.com/tiaguinho/material-community-components
angular angular-components angular-material2 colorpicker community material scrollspy speed-dial timerpicker typescript
Last synced: 4 days ago
JSON representation
:panda_face: Angular Material Components created from the community
- Host: GitHub
- URL: https://github.com/tiaguinho/material-community-components
- Owner: tiaguinho
- License: mit
- Created: 2018-01-09T14:30:54.000Z (about 7 years ago)
- Default Branch: main
- Last Pushed: 2023-03-09T03:21:00.000Z (almost 2 years ago)
- Last Synced: 2024-04-14T10:09:12.098Z (10 months ago)
- Topics: angular, angular-components, angular-material2, colorpicker, community, material, scrollspy, speed-dial, timerpicker, typescript
- Language: TypeScript
- Homepage: https://tiaguinho.github.io/material-community-components
- Size: 7.25 MB
- Stars: 322
- Watchers: 20
- Forks: 50
- Open Issues: 32
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-material-design - Material Community Components - An awesome idea for a library of components built by the angular community for components not found in the offical Angular Material rep. (Angular / Frameworks)
README
# Material Community Components
Angular Material components that are not implemented in official package.[![npm version](https://badge.fury.io/js/material-community-components.svg)](https://badge.fury.io/js/material-community-components)
[![Travis CI](https://travis-ci.org/tiaguinho/material-community-components.svg?branch=master)](https://travis-ci.org/tiaguinho/material-community-components)
[![Coverage Status](https://coveralls.io/repos/github/tiaguinho/material-community-components/badge.svg?branch=master)](https://coveralls.io/github/tiaguinho/material-community-components?branch=master)
[![patreon](https://img.shields.io/badge/patreon-donate-yellow.svg)](https://www.patreon.com/temporin)The idea of the [Material Community Components]() is to provide components that aren't available in the [Angular Material2](https://material.angular.io) yet.
All the components are created using [Angular](https://angular.io), [Material 2](https://material.angular.io) and [CDK](https://material.angular.io/cdk). Since version 7.1.0 only Angular 9+ is supported.
The color-picker component has an additional peer-dependency to [@thebespokepixel/es-tinycolor](https://github.com/thebespokepixel/es-tinycolor) to help with color calculations.
Check out our [documentation & live demo](https://tiaguinho.github.io/material-community-components/)
## Components
All the components have the prefix `mcc` followed by the package name.
| Component | Package | Screenshot |
| ------------ | ---------------- | ------------- |
| Color Picker | mcc-color-picker | ![alt text](https://github.com/tiaguinho/material-community-components/raw/master/images/color-picker.png 'Color Picker') |
| Scrollspy | mcc-scrollspy | ![alt text](https://github.com/tiaguinho/material-community-components/raw/master/images/scrollspy.png 'Scrollspy') |
| Speed Dial | mcc-speed-dial | ![alt text](https://github.com/tiaguinho/material-community-components/raw/master/images/speed-dial.png 'Speed Dial') |
| Timer Picker | mcc-timer-picker | ![alt text](https://github.com/tiaguinho/material-community-components/raw/master/images/timer-picker.png 'Timer Picker') |If you miss any component, please follow the [CONTRIBUTION GUIDELINE](https://github.com/tiaguinho/material-community-components/blob/master/CONTRIBUTING.md) to open an issue or file your idea [here](https://github.com/tiaguinho/material-community-components/discussions/191).
## Install
### step: 1
We use some components from [Angular Material](https://material.angular.io/). To be able to use this components, you have to install the `@angular/animations`. If you follow all the steps in [Material Guide](https://material.angular.io/guide/getting-started), you already have this step done.
```bash
npm install --save @angular/animations
```Note: [@angular/animations](https://angular.io/guide/animations) uses the WebAnimation API that isn't supported by all browsers yet. If you want to support Material component animations in these browsers, you'll have to include a [polyfill](https://github.com/web-animations/web-animations-js).
```typescript
import {BrowserAnimationsModule} from '@angular/platform-browser/animations';@NgModule({
...
imports: [BrowserAnimationsModule],
...
})
export class PizzaPartyAppModule { }
```If you don't want to add another dependency to your project, you can use the [NoopAnimationsModule](https://angular.io/api/platform-browser/animations/NoopAnimationsModule).
```typescript
import {NoopAnimationsModule} from '@angular/platform-browser/animations';@NgModule({
...
imports: [NoopAnimationsModule],
...
})
export class PizzaPartyAppModule { }
```### step: 2
Install material community components package:
```bash
npm install material-community-components
```or
```bash
yarn add material-community-components
```## Theming
To use the same theme of Angular Material add the following code to your ```style.scss```.
```scss
@use '~@angular/material' as mat;
@use '~material-community-components/theming' as mcc;@include mat.core();
// Define the palettes for your theme using the Material Design palettes available in palette.scss
// (imported above). For each palette, you can optionally specify a default, lighter, and darker
// hue. Available color palettes: https://material.io/design/color/
$demo-primary: mat.define-palette(mat.$green-palette);
$demo-accent: mat.define-palette(mat.$pink-palette, A200, A100, A400);// The warn palette is optional (defaults to red).
$demo-warn: mat.define-palette(mat.$red-palette);// Create the theme object (a Sass map containing all of the palettes).
$demo-theme: mat.define-light-theme($demo-primary, $demo-accent, $demo-warn);// build angular material theme
@include mat.all-component-themes($demo-theme);// pass angular material theme to material community components
@include mcc.mcc-theme($demo-theme);
```
***Right now only ```timer-picker``` and ```speed-dial```*** do support the theme (see [ISSUE-172](https://github.com/tiaguinho/material-community-components/issues/172)).## Upgrading from 7.x.x
Since version 9.0.0 the lib only provides secondary entry-points for import. To migrate change your imports like that:
Before:
```typescript
import { MccColorPickerModule} from 'material-community-components';
import { MccTimerPickerModule} from 'material-community-components';
import { MccSpeedDialModule} from 'material-community-components';
import { MccScrollspyModule} from 'material-community-components';
```After:
```typescript
import { MccColorPickerModule} from 'material-community-components/color-picker';
import { MccTimerPickerModule} from 'material-community-components/timer-picker';
import { MccSpeedDialModule} from 'material-community-components/speed-dial';
import { MccScrollspyModule} from 'material-community-components/scrollspy';
```
## How to useFor more examples, you can see our [demo](https://github.com/tiaguinho/material-community-components/tree/master/projects/demo) folder or read the [documentation](https://tiaguinho.github.io/material-community-components/)
## License
[The MIT License (MIT) Copyright (c) 2018](http://opensource.org/licenses/MIT)
## Sponsors
[![alt text](https://github.com/tiaguinho/material-community-components/raw/master/images/sponsor-egoi.png 'E-goi')](https://www.e-goi.com)