From 8719c507dbe1360cab45325e05a35d140cb2678d Mon Sep 17 00:00:00 2001
From: Vladimir Potekhin <46284632+vladimirpotekhin@users.noreply.github.com>
Date: Tue, 19 Jul 2022 12:21:38 +0300
Subject: [PATCH] refactor!: move fonts to separate file (#2132)
* refactor!: move fonts to separate file
* chore: remove global styles from schematic
---
.../cdk/schematics/constants/taiga-styles.ts | 4 ++
.../ng-add/steps/add-taiga-icons.ts | 4 +-
.../ng-add/steps/add-taiga-styles.ts | 26 ++--------
.../ng-add/tests/schematic-ng-add.spec.ts | 42 ++---------------
projects/cdk/schematics/ng-update/index.ts | 47 +++++++++++++------
.../tests/schematic-date-time.spec.ts | 3 ++
.../tests/schematic-migrate-progress.spec.ts | 2 +
.../tests/schematic-migrate-sliders.spec.ts | 2 +
.../tests/schematic-miscellaneous.spec.ts | 3 ++
.../tests/schematic-rename-types.spec.ts | 3 ++
.../tests/schematic-replace-consts.spec.ts | 3 ++
.../schematic-replace-deep-imports.spec.ts | 3 ++
...matic-replace-deprecated-functions.spec.ts | 3 ++
.../tests/schematic-replace-enums.spec.ts | 3 ++
.../tests/schematic-replace-functions.spec.ts | 3 ++
.../tests/schematic-replace-html.spec.ts | 29 ++++++++++++
.../tests/schematic-replace-services.spec.ts | 3 ++
.../tests/schematic-textfield-icon.spec.ts | 3 ++
.../tests/schematic-warnings.spec.ts | 3 ++
projects/cdk/schematics/utils/add-styles.ts | 18 +++++++
.../schematics/utils/create-angular-json.ts | 34 ++++++++++++++
projects/core/styles/taiga-ui-fonts.less | 1 +
projects/core/styles/taiga-ui-theme.less | 1 -
projects/demo/src/modules/app/app.style.less | 1 +
.../app/home/examples/angular-json-styles.md | 1 +
25 files changed, 170 insertions(+), 75 deletions(-)
create mode 100644 projects/cdk/schematics/constants/taiga-styles.ts
create mode 100644 projects/cdk/schematics/utils/add-styles.ts
create mode 100644 projects/cdk/schematics/utils/create-angular-json.ts
create mode 100644 projects/core/styles/taiga-ui-fonts.less
diff --git a/projects/cdk/schematics/constants/taiga-styles.ts b/projects/cdk/schematics/constants/taiga-styles.ts
new file mode 100644
index 0000000000000..2faf93086f4c5
--- /dev/null
+++ b/projects/cdk/schematics/constants/taiga-styles.ts
@@ -0,0 +1,4 @@
+export const TAIGA_GLOBAL_STYLE =
+ 'node_modules/@taiga-ui/core/styles/taiga-ui-global.less';
+export const TAIGA_THEME_STYLE = 'node_modules/@taiga-ui/core/styles/taiga-ui-theme.less';
+export const TAIGA_THEME_FONTS = 'node_modules/@taiga-ui/core/styles/taiga-ui-fonts.less';
diff --git a/projects/cdk/schematics/ng-add/steps/add-taiga-icons.ts b/projects/cdk/schematics/ng-add/steps/add-taiga-icons.ts
index 84f52b20f57ba..019e7ebf49c74 100644
--- a/projects/cdk/schematics/ng-add/steps/add-taiga-icons.ts
+++ b/projects/cdk/schematics/ng-add/steps/add-taiga-icons.ts
@@ -13,11 +13,11 @@ const ICON_ASSETS = {
export function addTaigaIcons(options: Schema): Rule {
return async (_: Tree) => {
- return addTaigaStylesToAngularJson(options);
+ return addTaigaAssetsToAngularJson(options);
};
}
-export function addTaigaStylesToAngularJson(options: Schema): Rule {
+export function addTaigaAssetsToAngularJson(options: Schema): Rule {
return updateWorkspace(workspace => {
const project = getProject(options, workspace);
diff --git a/projects/cdk/schematics/ng-add/steps/add-taiga-styles.ts b/projects/cdk/schematics/ng-add/steps/add-taiga-styles.ts
index 2c88b7fdf6224..317ad14d0ccab 100644
--- a/projects/cdk/schematics/ng-add/steps/add-taiga-styles.ts
+++ b/projects/cdk/schematics/ng-add/steps/add-taiga-styles.ts
@@ -1,28 +1,12 @@
-import {JsonArray} from '@angular-devkit/core';
import {Rule, Tree} from '@angular-devkit/schematics';
-import {updateWorkspace} from '@schematics/angular/utility/workspace';
-import {getProject} from '../../utils/get-project';
-import {getProjectTargetOptions} from '../../utils/get-project-target-options';
import {Schema} from '../schema';
-
-const TAIGA_GLOBAL_STYLE = 'node_modules/@taiga-ui/core/styles/taiga-ui-global.less';
-const TAIGA_THEME_STYLE = 'node_modules/@taiga-ui/core/styles/taiga-ui-theme.less';
+import {addStylesToAngularJson} from '../../utils/add-styles';
+import {TAIGA_THEME_FONTS, TAIGA_THEME_STYLE} from '../../constants/taiga-styles';
export function addTaigaStyles(options: Schema): Rule {
return async (_: Tree) => {
- return addTaigaStylesToAngularJson(options);
- };
-}
+ const taigaStyles = [TAIGA_THEME_STYLE, TAIGA_THEME_FONTS];
-export function addTaigaStylesToAngularJson(options: Schema): Rule {
- return updateWorkspace(workspace => {
- const project = getProject(options, workspace);
- const targetOptions = getProjectTargetOptions(project, 'build');
- const styles = targetOptions.styles as JsonArray | undefined;
- const taigaStyles = [TAIGA_GLOBAL_STYLE, TAIGA_THEME_STYLE];
-
- targetOptions.styles = styles
- ? Array.from(new Set([...taigaStyles, ...styles]))
- : taigaStyles;
- });
+ return addStylesToAngularJson(options, taigaStyles);
+ };
}
diff --git a/projects/cdk/schematics/ng-add/tests/schematic-ng-add.spec.ts b/projects/cdk/schematics/ng-add/tests/schematic-ng-add.spec.ts
index 072df9901caea..71cbd83dd31ef 100644
--- a/projects/cdk/schematics/ng-add/tests/schematic-ng-add.spec.ts
+++ b/projects/cdk/schematics/ng-add/tests/schematic-ng-add.spec.ts
@@ -16,6 +16,7 @@ import {
TAIGA_VERSION,
} from '../constants/versions';
import {Schema} from '../schema';
+import {createAngularJson} from '../../utils/create-angular-json';
const collectionPath = join(__dirname, '../../collection.json');
@@ -110,8 +111,8 @@ describe('ng-add', () => {
"options": {
"main": "test/main.ts",
"styles": [
- "node_modules/@taiga-ui/core/styles/taiga-ui-global.less",
- "node_modules/@taiga-ui/core/styles/taiga-ui-theme.less"
+ "node_modules/@taiga-ui/core/styles/taiga-ui-theme.less",
+ "node_modules/@taiga-ui/core/styles/taiga-ui-fonts.less"
],
"assets": [
{
@@ -128,7 +129,7 @@ describe('ng-add', () => {
}`);
});
- it('should add styles without dublicates, taiga styles first', async () => {
+ it('should add styles without duplicates, taiga styles first', async () => {
createAngularJson({stylesExist: true});
saveActiveProject();
@@ -147,8 +148,8 @@ describe('ng-add', () => {
"options": {
"main": "test/main.ts",
"styles": [
- "node_modules/@taiga-ui/core/styles/taiga-ui-global.less",
"node_modules/@taiga-ui/core/styles/taiga-ui-theme.less",
+ "node_modules/@taiga-ui/core/styles/taiga-ui-fonts.less",
"some.style"
],
"assets": [
@@ -209,39 +210,6 @@ export class AppModule {}
});
});
-function createAngularJson(
- {stylesExist}: {stylesExist: boolean} = {stylesExist: false},
-): void {
- createSourceFile(
- 'angular.json',
- `
-{
- "version": 1,
- "defaultProject": "demo",
- "projects": {
- "demo": {
- "architect": {
- "build": {
- "options": {
- "main": "test/main.ts",
- ${
- stylesExist
- ? `"styles": [
- "node_modules/@taiga-ui/core/styles/taiga-ui-theme.less",
- "some.style"
- ]
- `
- : ``
- }}
- }
- }
- }
- }
-}`,
- {overwrite: true},
- );
-}
-
function createMainFiles(): void {
createSourceFile(
'test/main.ts',
diff --git a/projects/cdk/schematics/ng-update/index.ts b/projects/cdk/schematics/ng-update/index.ts
index 5d4ebb3568b11..56888e42ecf06 100644
--- a/projects/cdk/schematics/ng-update/index.ts
+++ b/projects/cdk/schematics/ng-update/index.ts
@@ -1,4 +1,4 @@
-import {Rule, SchematicContext, Tree} from '@angular-devkit/schematics';
+import {chain, Rule, SchematicContext, Tree} from '@angular-devkit/schematics';
import {createProject, saveActiveProject, setActiveProject} from 'ng-morph';
import {TAIGA_VERSION} from '../ng-add/constants/versions';
import {Schema} from '../ng-add/schema';
@@ -17,15 +17,35 @@ import {migrateProgress} from './steps/migrate-progress';
import {DevkitFileSystem} from 'ng-morph/project/classes/devkit-file-system';
import {FINISH_SYMBOL, START_SYMBOL, titleLog} from '../utils/colored-log';
import {dateTimeMigrations} from './steps/migrate-date-time';
+import {addStylesToAngularJson} from '../utils/add-styles';
+import {TAIGA_THEME_FONTS} from '../constants/taiga-styles';
+const {performance} = require('perf_hooks');
-export function updateToV3(_: Schema): Rule {
- return async (tree: Tree, context: SchematicContext) => {
- const t0 = performance.now();
+export function updateToV3(options: Schema): Rule {
+ const t0 = performance.now();
+
+ titleLog(
+ `\n\n${START_SYMBOL} Your packages will be updated to @taiga-ui/*@${TAIGA_VERSION}\n`,
+ );
- titleLog(
- `\n\n${START_SYMBOL} Your packages will be updated to @taiga-ui/*@${TAIGA_VERSION}\n`,
- );
+ return chain([
+ main(options),
+ addTaigaStyles(options),
+ () => {
+ const t1 = performance.now();
+ const sum = t1 - t0;
+ const result =
+ sum > 1000 ? `${(sum / 1000).toFixed(2)} sec.` : `${sum.toFixed(2)} ms.`;
+
+ titleLog(
+ `${FINISH_SYMBOL} We migrated packages to @taiga-ui/*@${TAIGA_VERSION} in ${result} \n`,
+ );
+ },
+ ]);
+}
+function main(_: Schema): Rule {
+ return async (tree: Tree, context: SchematicContext) => {
const fileSystem = getFileSystem(tree);
replaceDeepImports();
@@ -47,15 +67,14 @@ export function updateToV3(_: Schema): Rule {
replaceFunctions();
miscellaneousMigrations();
saveActiveProject();
+ };
+}
- const t1 = performance.now();
- const sum = t1 - t0;
- const result =
- sum > 1000 ? `${(sum / 1000).toFixed(2)} sec.` : `${sum.toFixed(2)} ms.`;
+function addTaigaStyles(options: Schema): Rule {
+ return async (_: Tree) => {
+ const taigaStyles = [TAIGA_THEME_FONTS];
- titleLog(
- `${FINISH_SYMBOL} We migrated packages to @taiga-ui/*@${TAIGA_VERSION} in ${result} \n`,
- );
+ return addStylesToAngularJson(options, taigaStyles);
};
}
diff --git a/projects/cdk/schematics/ng-update/tests/schematic-date-time.spec.ts b/projects/cdk/schematics/ng-update/tests/schematic-date-time.spec.ts
index 14d977987f385..7234042804f69 100644
--- a/projects/cdk/schematics/ng-update/tests/schematic-date-time.spec.ts
+++ b/projects/cdk/schematics/ng-update/tests/schematic-date-time.spec.ts
@@ -9,6 +9,7 @@ import {
setActiveProject,
} from 'ng-morph';
import {join} from 'path';
+import {createAngularJson} from '../../utils/create-angular-json';
const collectionPath = join(__dirname, '../../migration.json');
@@ -103,4 +104,6 @@ function createMainFiles(): void {
createSourceFile('test/app/mock.ts', 'export class TuiDay {}');
createSourceFile('test/app/app.template.html', ``);
+
+ createAngularJson();
}
diff --git a/projects/cdk/schematics/ng-update/tests/schematic-migrate-progress.spec.ts b/projects/cdk/schematics/ng-update/tests/schematic-migrate-progress.spec.ts
index 6c8ebc8a3787f..ccc9a613328f7 100644
--- a/projects/cdk/schematics/ng-update/tests/schematic-migrate-progress.spec.ts
+++ b/projects/cdk/schematics/ng-update/tests/schematic-migrate-progress.spec.ts
@@ -9,6 +9,7 @@ import {
} from 'ng-morph';
import {join} from 'path';
import {DEPRECATED_PROGRESS_PIPES_REG} from '../steps/migrate-progress';
+import {createAngularJson} from '../../utils/create-angular-json';
const collectionPath = join(__dirname, '../../migration.json');
@@ -160,4 +161,5 @@ describe('migrate progress', () => {
function createMainFiles(): void {
createSourceFile('test/app-with-progress/app.component.ts', APP_COMPONENT);
createSourceFile('test/app-with-progress/app.template.html', TEMPLATE_BEFORE);
+ createAngularJson();
}
diff --git a/projects/cdk/schematics/ng-update/tests/schematic-migrate-sliders.spec.ts b/projects/cdk/schematics/ng-update/tests/schematic-migrate-sliders.spec.ts
index 008b21723087f..c0d7adbb1a201 100644
--- a/projects/cdk/schematics/ng-update/tests/schematic-migrate-sliders.spec.ts
+++ b/projects/cdk/schematics/ng-update/tests/schematic-migrate-sliders.spec.ts
@@ -9,6 +9,7 @@ import {
setActiveProject,
} from 'ng-morph';
import {join} from 'path';
+import {createAngularJson} from '../../utils/create-angular-json';
const collectionPath = join(__dirname, '../../migration.json');
@@ -450,4 +451,5 @@ function createMainFiles(): void {
'test/inline-html-child/inline-html-child.component.ts',
INLINE_HTML_CHILD_COMPONENT_BEFORE,
);
+ createAngularJson();
}
diff --git a/projects/cdk/schematics/ng-update/tests/schematic-miscellaneous.spec.ts b/projects/cdk/schematics/ng-update/tests/schematic-miscellaneous.spec.ts
index 54d958d7e5407..22eab24aee6be 100644
--- a/projects/cdk/schematics/ng-update/tests/schematic-miscellaneous.spec.ts
+++ b/projects/cdk/schematics/ng-update/tests/schematic-miscellaneous.spec.ts
@@ -9,6 +9,7 @@ import {
setActiveProject,
} from 'ng-morph';
import {join} from 'path';
+import {createAngularJson} from '../../utils/create-angular-json';
const collectionPath = join(__dirname, '../../migration.json');
@@ -89,4 +90,6 @@ function createMainFiles(): void {
createSourceFile('test/app/app.component.ts', BEFORE);
createSourceFile('test/app/app.template.html', ``);
+
+ createAngularJson();
}
diff --git a/projects/cdk/schematics/ng-update/tests/schematic-rename-types.spec.ts b/projects/cdk/schematics/ng-update/tests/schematic-rename-types.spec.ts
index ee811bbf7c778..6b6008c1dc44d 100644
--- a/projects/cdk/schematics/ng-update/tests/schematic-rename-types.spec.ts
+++ b/projects/cdk/schematics/ng-update/tests/schematic-rename-types.spec.ts
@@ -9,6 +9,7 @@ import {
setActiveProject,
} from 'ng-morph';
import {join} from 'path';
+import {createAngularJson} from '../../utils/create-angular-json';
const collectionPath = join(__dirname, '../../migration.json');
@@ -163,4 +164,6 @@ function createMainFiles(): void {
createSourceFile('test/app/app.component.ts', BEFORE);
createSourceFile('test/app/app.template.html', ``);
+
+ createAngularJson();
}
diff --git a/projects/cdk/schematics/ng-update/tests/schematic-replace-consts.spec.ts b/projects/cdk/schematics/ng-update/tests/schematic-replace-consts.spec.ts
index bcf1ac1d5541d..1ad2fe954f5d2 100644
--- a/projects/cdk/schematics/ng-update/tests/schematic-replace-consts.spec.ts
+++ b/projects/cdk/schematics/ng-update/tests/schematic-replace-consts.spec.ts
@@ -9,6 +9,7 @@ import {
setActiveProject,
} from 'ng-morph';
import {join} from 'path';
+import {createAngularJson} from '../../utils/create-angular-json';
const collectionPath = join(__dirname, '../../migration.json');
@@ -143,4 +144,6 @@ function createMainFiles(): void {
createSourceFile('test/app/app.component.ts', BEFORE);
createSourceFile('test/app/app.template.html', ``);
+
+ createAngularJson();
}
diff --git a/projects/cdk/schematics/ng-update/tests/schematic-replace-deep-imports.spec.ts b/projects/cdk/schematics/ng-update/tests/schematic-replace-deep-imports.spec.ts
index b6a84be85abad..15a16e3f9fecc 100644
--- a/projects/cdk/schematics/ng-update/tests/schematic-replace-deep-imports.spec.ts
+++ b/projects/cdk/schematics/ng-update/tests/schematic-replace-deep-imports.spec.ts
@@ -9,6 +9,7 @@ import {
setActiveProject,
} from 'ng-morph';
import {join} from 'path';
+import {createAngularJson} from '../../utils/create-angular-json';
const collectionPath = join(__dirname, '../../migration.json');
@@ -59,4 +60,6 @@ export class AppComponent {}`,
);
createSourceFile('test/app/app.template.html', ``);
+
+ createAngularJson();
}
diff --git a/projects/cdk/schematics/ng-update/tests/schematic-replace-deprecated-functions.spec.ts b/projects/cdk/schematics/ng-update/tests/schematic-replace-deprecated-functions.spec.ts
index 0d52a238ff752..58f500925d88a 100644
--- a/projects/cdk/schematics/ng-update/tests/schematic-replace-deprecated-functions.spec.ts
+++ b/projects/cdk/schematics/ng-update/tests/schematic-replace-deprecated-functions.spec.ts
@@ -9,6 +9,7 @@ import {
setActiveProject,
} from 'ng-morph';
import {join} from 'path';
+import {createAngularJson} from '../../utils/create-angular-json';
const collectionPath = join(__dirname, '../../migration.json');
@@ -849,4 +850,6 @@ function createMainFiles(): void {
createSourceFile('test/app/app.component.ts', BEFORE);
createSourceFile('test/app/app.template.html', ``);
+
+ createAngularJson();
}
diff --git a/projects/cdk/schematics/ng-update/tests/schematic-replace-enums.spec.ts b/projects/cdk/schematics/ng-update/tests/schematic-replace-enums.spec.ts
index 59acfa76d27de..709a4ba9b48a3 100644
--- a/projects/cdk/schematics/ng-update/tests/schematic-replace-enums.spec.ts
+++ b/projects/cdk/schematics/ng-update/tests/schematic-replace-enums.spec.ts
@@ -9,6 +9,7 @@ import {
setActiveProject,
} from 'ng-morph';
import {join} from 'path';
+import {createAngularJson} from '../../utils/create-angular-json';
const collectionPath = join(__dirname, '../../migration.json');
@@ -79,4 +80,6 @@ export class AppComponent {
);
createSourceFile('test/app/app.template.html', ``);
+
+ createAngularJson();
}
diff --git a/projects/cdk/schematics/ng-update/tests/schematic-replace-functions.spec.ts b/projects/cdk/schematics/ng-update/tests/schematic-replace-functions.spec.ts
index d759b11f3d719..10f91fa77ef69 100644
--- a/projects/cdk/schematics/ng-update/tests/schematic-replace-functions.spec.ts
+++ b/projects/cdk/schematics/ng-update/tests/schematic-replace-functions.spec.ts
@@ -9,6 +9,7 @@ import {
setActiveProject,
} from 'ng-morph';
import {join} from 'path';
+import {createAngularJson} from '../../utils/create-angular-json';
const collectionPath = join(__dirname, '../../migration.json');
@@ -97,4 +98,6 @@ function createMainFiles(): void {
createSourceFile('test/app/app.component.ts', BEFORE);
createSourceFile('test/app/app.template.html', ``);
+
+ createAngularJson();
}
diff --git a/projects/cdk/schematics/ng-update/tests/schematic-replace-html.spec.ts b/projects/cdk/schematics/ng-update/tests/schematic-replace-html.spec.ts
index 7cfb1f56facbc..fea6802c9ad33 100644
--- a/projects/cdk/schematics/ng-update/tests/schematic-replace-html.spec.ts
+++ b/projects/cdk/schematics/ng-update/tests/schematic-replace-html.spec.ts
@@ -9,6 +9,7 @@ import {
setActiveProject,
} from 'ng-morph';
import {join} from 'path';
+import {createAngularJson} from '../../utils/create-angular-json';
const collectionPath = join(__dirname, '../../migration.json');
@@ -420,6 +421,32 @@ describe('ng-update', () => {
);
});
+ it('should add font style in angular.json', async () => {
+ const tree = await runner.runSchematicAsync('updateToV3', {}, host).toPromise();
+
+ expect(tree.readContent('angular.json')).toEqual(
+ `
+{
+ "version": 1,
+ "defaultProject": "demo",
+ "projects": {
+ "demo": {
+ "architect": {
+ "build": {
+ "options": {
+ "main": "test/main.ts",
+ "styles": [
+ "node_modules/@taiga-ui/core/styles/taiga-ui-fonts.less"
+ ]
+ }
+ }
+ }
+ }
+ }
+}`,
+ );
+ });
+
afterEach(() => {
resetActiveProject();
});
@@ -433,4 +460,6 @@ function createMainFiles(): void {
createSourceFile('test/app/test-inline.component.ts', COMPONENT_BEFORE);
createSourceFile('test/app/test.module.ts', MODULE_BEFORE);
+
+ createAngularJson();
}
diff --git a/projects/cdk/schematics/ng-update/tests/schematic-replace-services.spec.ts b/projects/cdk/schematics/ng-update/tests/schematic-replace-services.spec.ts
index 8e8e253abec34..8c27c89e73a51 100644
--- a/projects/cdk/schematics/ng-update/tests/schematic-replace-services.spec.ts
+++ b/projects/cdk/schematics/ng-update/tests/schematic-replace-services.spec.ts
@@ -9,6 +9,7 @@ import {
setActiveProject,
} from 'ng-morph';
import {join} from 'path';
+import {createAngularJson} from '../../utils/create-angular-json';
const collectionPath = join(__dirname, '../../migration.json');
@@ -109,4 +110,6 @@ function createMainFiles(): void {
createSourceFile('test/app/app.component.ts', BEFORE);
createSourceFile('test/app/app.template.html', ``);
+
+ createAngularJson();
}
diff --git a/projects/cdk/schematics/ng-update/tests/schematic-textfield-icon.spec.ts b/projects/cdk/schematics/ng-update/tests/schematic-textfield-icon.spec.ts
index 91dc8b36c3f2f..2704f1b48ffaa 100644
--- a/projects/cdk/schematics/ng-update/tests/schematic-textfield-icon.spec.ts
+++ b/projects/cdk/schematics/ng-update/tests/schematic-textfield-icon.spec.ts
@@ -9,6 +9,7 @@ import {
setActiveProject,
} from 'ng-morph';
import {join} from 'path';
+import {createAngularJson} from '../../utils/create-angular-json';
const collectionPath = join(__dirname, '../../migration.json');
@@ -155,4 +156,6 @@ function createMainFiles(): void {
createSourceFile('test/app/test.template.html', TEMPLATE_BEFORE);
createSourceFile('test/app/test.module.ts', MODULE_BEFORE);
+
+ createAngularJson();
}
diff --git a/projects/cdk/schematics/ng-update/tests/schematic-warnings.spec.ts b/projects/cdk/schematics/ng-update/tests/schematic-warnings.spec.ts
index 1f9182a85fb3e..d94d13bc44c5b 100644
--- a/projects/cdk/schematics/ng-update/tests/schematic-warnings.spec.ts
+++ b/projects/cdk/schematics/ng-update/tests/schematic-warnings.spec.ts
@@ -12,6 +12,7 @@ import {join} from 'path';
import {Subscription} from 'rxjs';
import {LogEntry} from '@angular-devkit/core/src/logger/logger';
import {MIGRATION_WARNINGS} from '../constants/warnings';
+import {createAngularJson} from '../../utils/create-angular-json';
const collectionPath = join(__dirname, '../../migration.json');
@@ -116,4 +117,6 @@ function createMainFiles(): void {
createSourceFile('test/app/app.component.ts', BEFORE);
createSourceFile('test/app/app.template.html', ``);
+
+ createAngularJson();
}
diff --git a/projects/cdk/schematics/utils/add-styles.ts b/projects/cdk/schematics/utils/add-styles.ts
new file mode 100644
index 0000000000000..6968860733139
--- /dev/null
+++ b/projects/cdk/schematics/utils/add-styles.ts
@@ -0,0 +1,18 @@
+import {Schema} from '../ng-add/schema';
+import {Rule} from '@angular-devkit/schematics';
+import {getProject} from './get-project';
+import {getProjectTargetOptions} from './get-project-target-options';
+import {JsonArray} from '@angular-devkit/core';
+import {updateWorkspace} from '@schematics/angular/utility/workspace';
+
+export function addStylesToAngularJson(options: Schema, taigaStyles: string[]): Rule {
+ return updateWorkspace(workspace => {
+ const project = getProject(options, workspace);
+ const targetOptions = getProjectTargetOptions(project, 'build');
+ const styles = targetOptions.styles as JsonArray | undefined;
+
+ targetOptions.styles = styles
+ ? Array.from(new Set([...taigaStyles, ...styles]))
+ : taigaStyles;
+ });
+}
diff --git a/projects/cdk/schematics/utils/create-angular-json.ts b/projects/cdk/schematics/utils/create-angular-json.ts
new file mode 100644
index 0000000000000..c804a034a5883
--- /dev/null
+++ b/projects/cdk/schematics/utils/create-angular-json.ts
@@ -0,0 +1,34 @@
+import {createSourceFile} from 'ng-morph';
+
+export function createAngularJson(
+ {stylesExist}: {stylesExist: boolean} = {stylesExist: false},
+): void {
+ createSourceFile(
+ 'angular.json',
+ `
+{
+ "version": 1,
+ "defaultProject": "demo",
+ "projects": {
+ "demo": {
+ "architect": {
+ "build": {
+ "options": {
+ "main": "test/main.ts",
+ ${
+ stylesExist
+ ? `"styles": [
+ "node_modules/@taiga-ui/core/styles/taiga-ui-theme.less",
+ "some.style"
+ ]
+ `
+ : ``
+ }}
+ }
+ }
+ }
+ }
+}`,
+ {overwrite: true},
+ );
+}
diff --git a/projects/core/styles/taiga-ui-fonts.less b/projects/core/styles/taiga-ui-fonts.less
new file mode 100644
index 0000000000000..304dafcf7b5ca
--- /dev/null
+++ b/projects/core/styles/taiga-ui-fonts.less
@@ -0,0 +1 @@
+@import 'theme/fonts.css';
diff --git a/projects/core/styles/taiga-ui-theme.less b/projects/core/styles/taiga-ui-theme.less
index f039be19a1d27..bc4dd29203cc7 100644
--- a/projects/core/styles/taiga-ui-theme.less
+++ b/projects/core/styles/taiga-ui-theme.less
@@ -1,4 +1,3 @@
-@import 'theme/fonts.css';
@import 'theme/dialog.less';
@import 'theme/variables.less';
@import 'theme/wrapper.less';
diff --git a/projects/demo/src/modules/app/app.style.less b/projects/demo/src/modules/app/app.style.less
index a1721d16381e1..ff216958ddc8c 100644
--- a/projects/demo/src/modules/app/app.style.less
+++ b/projects/demo/src/modules/app/app.style.less
@@ -1,5 +1,6 @@
@import 'taiga-ui-global';
@import 'taiga-ui-theme';
+@import 'taiga-ui-fonts';
@import 'taiga-ui-local';
app {
diff --git a/projects/demo/src/modules/app/home/examples/angular-json-styles.md b/projects/demo/src/modules/app/home/examples/angular-json-styles.md
index f542ea3e0f718..43e025bc44f2e 100644
--- a/projects/demo/src/modules/app/home/examples/angular-json-styles.md
+++ b/projects/demo/src/modules/app/home/examples/angular-json-styles.md
@@ -8,6 +8,7 @@
"styles": [
"node_modules/@taiga-ui/core/styles/taiga-ui-global.less",
"node_modules/@taiga-ui/core/styles/taiga-ui-theme.less",
+ "node_modules/@taiga-ui/core/styles/taiga-ui-fonts.less",
"src/styles.css"
]
}