Get started with Covalent using the Angular CLI.
See the material getting started for instructions.
npm install -g @angular/cli@latest
ng new my-project
The new command creates a project with a build system for your Angular app.
npm install --save @covalent/core
## (optional) Additional Covalent Modules installs
npm install --save @covalent/http @covalent/highlight @covalent/markdown @covalent/dynamic-forms
To test (only for testing!) the latest changes from develop, install the nightly build: (only the core module has a nightly build)
npm install --save https://github.com/Teradata/covalent-nightly.git
src/app/app.module.ts
import { CovalentLayoutModule } from '@covalent/core/layout';
import { CovalentStepsModule } from '@covalent/core/steps';
/* any other core modules */
// (optional) Additional Covalent Modules imports
import { CovalentHttpModule } from '@covalent/http';
import { CovalentHighlightModule } from '@covalent/highlight';
import { CovalentMarkdownModule } from '@covalent/markdown';
import { CovalentDynamicFormsModule } from '@covalent/dynamic-forms';
// other imports
@NgModule({
imports: [
CovalentLayoutModule,
CovalentStepsModule,
// (optional) Additional Covalent Modules imports
CovalentHttpModule.forRoot(),
CovalentHighlightModule,
CovalentMarkdownModule,
CovalentDynamicFormsModule,
],
...
})
export class AppModule { }
This is required to apply all of the core, theme and typography styles to your application.
See the material theming guide and the material typography guide for instructions.
A theme file is a simple Sass file that defines your palettes and passes them to mixins that output the corresponding styles. A typical theme file will look something like this:
@import '~@angular/material/theming';
@import '~@covalent/core/theming/all-theme';
// (optional) Additional themes
@import '~@covalent/markdown/markdown-theme';
@import '~@covalent/highlight/highlight-theme';
// Define a custom typography config that overrides the font-family
// or any typography level.
$typography: mat-typography-config(
$font-family: 'Roboto, monospace',
$headline: mat-typography-level(32px, 48px, 700)
);
@include mat-core($typography); // $typography is an **optional** argument for the mat-core
$primary: mat-palette($mat-orange, 800, 100, 900);
$accent: mat-palette($mat-light-blue, 600, 100, 900);
$warn: mat-palette($mat-red, 600, 100, 900);
$theme: mat-light-theme($primary, $accent, $warn);
@include angular-material-theme($theme);
@include covalent-theme($theme, $typography); // $typography is an **optional** argument for the covalent-theme
// (optional) Additional themes
@include covalent-markdown-theme($theme);
@include covalent-highlight-theme();
You only need this single Sass file; you do not need to use Sass to style the rest of your app.
If you are using the Angular CLI, support for compiling Sass to css is built-in but you have to add a new entry to the "styles" list in .angular-cli.json pointing to the theme file and the platform.css as follows:
This is an optional set of CSS classes that will help to speed up development and standardize your application.
The covalent utility CSS classes can be included via platform.css
file either in your index.html
or as a new entry to the "styles" list in .angular-cli.json
src/index.html
<link href="../node_modules/@covalent/core/common/platform.css" rel="stylesheet">
or
.angular-cli.json
"styles": [
"../node_modules/@covalent/core/common/platform.scss"
],
This also includes the material icons
by default.
Click here if you want to cherry pick the utility classes instead of loading the platform.css
If you're not using the Angular CLI, you can use any existing Sass tooling to build the file (such as gulp-sass or grunt-sass). The simplest approach is to use the node-sass CLI; you simply run:
node-sass src/themes.scss dist/themes.css
and then include the output file in your application.
The theme file can be concatenated and minified with the rest of the application's css.
If your project is using SystemJS for module loading, you will need to add @covalent/core
to the SystemJS configuration:
System.config({
// existing configuration options
map: {
...,
'@covalent/core/loading': 'npm:@covalent/core/bundles/covalent-core-loading.umd.min.js',
'@covalent/core/chips': 'npm:@covalent/core/bundles/covalent-core-chips.umd.min.js',
// and any other module you need from @covalent/core/*
// (optional) Additional configuration options
'@covalent/http': 'npm:@covalent/http/bundles/covalent-http.umd.min.js',
'@covalent/highlight': 'npm:@covalent/highlight/bundles/covalent-highlight.umd.min.js',
'@covalent/markdown': 'npm:@covalent/markdown/bundles/covalent-markdown.min.umd.js',
'@covalent/dynamic-forms': 'npm:@covalent/dynamic-forms/bundles/covalent-dynamic-forms.umd.min.js'
}
});