UNPKG

jqwidgets-ng

Version:

[![Price](https://img.shields.io/badge/price-COMMERCIAL-0098f7.svg)](https://jqwidgets.com/license/)

111 lines (97 loc) 4.87 kB
import {Rule, SchematicContext, Tree} from '@angular-devkit/schematics'; import {NodePackageInstallTask, RunSchematicTask} from '@angular-devkit/schematics/tasks'; import {addPackageToPackageJson, getPackageVersionFromPackageJson} from './package-config'; import {Schema} from './schema'; import {chain, Rule, SchematicContext, Tree} from '@angular-devkit/schematics'; import { addModuleImportToRootModule, getAppModulePath, getProjectFromWorkspace, getProjectMainFile, getProjectStyleFile, hasNgModuleImport, } from '@angular/cdk/schematics'; import {getWorkspace} from '@schematics/angular/utility/workspace'; import {addFontsToIndex} from '../fonts/material-fonts'; import {addThemeToAppStyles, addTypographyClass} from '../theming/theming'; /** Name of the Angular module that enables Angular browser animations. */ const browserAnimationsModuleName = 'BrowserAnimationsModule'; /** Name of the module that switches Angular animations to a noop implementation. */ const noopAnimationsModuleName = 'NoopAnimationsModule'; /** * Version range that will be used for the Angular CDK and Angular Material if this * schematic has been run outside of the CLI `ng add` command. In those cases, there * can be no dependency on `@angular/material` in the `package.json` file, and we need * to manually insert the dependency based on the build version placeholder. * * Note that the fallback version range does not use caret, but tilde because that is * the default for Angular framework dependencies in CLI projects. */ const fallbackSmartVersionRange = `~0.0.0-PLACEHOLDER`; /** * Adds custom Material styles to the project style file. The custom CSS sets up the Roboto font * and reset the default browser body margin. */ function addMaterialAppStyles(options: Schema) { return (host: Tree, context: SchematicContext) => { const workspace = getWorkspace(host); const project = getProjectFromWorkspace(workspace, options.project); const styleFilePath = getProjectStyleFile(project); const logger = context.logger; if (!styleFilePath) { logger.error(`Could not find the default style file for this project.`); logger.info(`Please consider manually setting up the Roboto font in your CSS.`); return; } const buffer = host.read(styleFilePath); if (!buffer) { logger.error(`Could not read the default style file within the project ` + `(${styleFilePath})`); logger.info(`Please consider manually setting up the Robot font.`); return; } const htmlContent = buffer.toString(); const insertion = '\n' + `html, body { height: 100%; }\n` + `body { margin: 0; font-family: Roboto, "Helvetica Neue", sans-serif; }\n`; if (htmlContent.includes(insertion)) { return; } const recorder = host.beginUpdate(styleFilePath); recorder.insertLeft(htmlContent.length, insertion); host.commitUpdate(recorder); }; } /** * Schematic factory entry-point for the `ng-add` schematic. The ng-add schematic will be * automatically executed if developers run `ng add @angular/material`. * * Since the Angular Material schematics depend on the schematic utility functions from the CDK, * we need to install the CDK before loading the schematic files that import from the CDK. */ export default function(options: Schema): Rule { return (host: Tree, context: SchematicContext) => { // Version tag of the `@angular/core` dependency that has been loaded from the `package.json` // of the CLI project. This tag should be preferred because all Angular dependencies should // have the same version tag if possible. const ngCoreVersionTag = getPackageVersionFromPackageJson(host, '@angular/core'); const smartVersionRange = getPackageVersionFromPackageJson(host, 'jqwidgets-ng'); const angularDependencyVersion = ngCoreVersionTag || `0.0.0-NG`; // The CLI inserts `jqwidgets-ng` into the `package.json` before this schematic runs. // This means that we do not need to insert Angular Material into `package.json` files again. // In some cases though, it could happen that this schematic runs outside of the CLI `ng add` // command, or Material is only listed a dev dependency. If that is the case, we insert a // version based on the current build version (substituted version placeholder). if (smartVersionRange === null) { addPackageToPackageJson(host, 'jqwidgets-ng', fallbackSmartVersionRange); } addPackageToPackageJson( host, '@angular/cdk', smartVersionRange || fallbackSmartVersionRange); return chain([ addThemeToAppStyles(options), addFontsToIndex(options), addMaterialAppStyles(options), addTypographyClass(options), ]); }; }