Skip to content

Commit

Permalink
refactor!: move fonts to separate file (#2132)
Browse files Browse the repository at this point in the history
* refactor!: move fonts to separate file

* chore: remove global styles from schematic
  • Loading branch information
vladimirpotekhin authored and splincode committed Aug 8, 2022
1 parent 0c49009 commit 8719c50
Show file tree
Hide file tree
Showing 25 changed files with 170 additions and 75 deletions.
4 changes: 4 additions & 0 deletions projects/cdk/schematics/constants/taiga-styles.ts
Original file line number Diff line number Diff line change
@@ -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';
4 changes: 2 additions & 2 deletions projects/cdk/schematics/ng-add/steps/add-taiga-icons.ts
Original file line number Diff line number Diff line change
Expand Up @@ -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);

Expand Down
26 changes: 5 additions & 21 deletions projects/cdk/schematics/ng-add/steps/add-taiga-styles.ts
Original file line number Diff line number Diff line change
@@ -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);
};
}
42 changes: 5 additions & 37 deletions projects/cdk/schematics/ng-add/tests/schematic-ng-add.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -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');

Expand Down Expand Up @@ -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": [
{
Expand All @@ -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();

Expand All @@ -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": [
Expand Down Expand Up @@ -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',
Expand Down
47 changes: 33 additions & 14 deletions projects/cdk/schematics/ng-update/index.ts
Original file line number Diff line number Diff line change
@@ -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';
Expand All @@ -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();
Expand All @@ -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);
};
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -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');

Expand Down Expand Up @@ -103,4 +104,6 @@ function createMainFiles(): void {
createSourceFile('test/app/mock.ts', 'export class TuiDay {}');

createSourceFile('test/app/app.template.html', `<app></app>`);

createAngularJson();
}
Original file line number Diff line number Diff line change
Expand Up @@ -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');

Expand Down Expand Up @@ -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();
}
Original file line number Diff line number Diff line change
Expand Up @@ -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');

Expand Down Expand Up @@ -450,4 +451,5 @@ function createMainFiles(): void {
'test/inline-html-child/inline-html-child.component.ts',
INLINE_HTML_CHILD_COMPONENT_BEFORE,
);
createAngularJson();
}
Original file line number Diff line number Diff line change
Expand Up @@ -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');

Expand Down Expand Up @@ -89,4 +90,6 @@ function createMainFiles(): void {
createSourceFile('test/app/app.component.ts', BEFORE);

createSourceFile('test/app/app.template.html', `<app></app>`);

createAngularJson();
}
Original file line number Diff line number Diff line change
Expand Up @@ -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');

Expand Down Expand Up @@ -163,4 +164,6 @@ function createMainFiles(): void {
createSourceFile('test/app/app.component.ts', BEFORE);

createSourceFile('test/app/app.template.html', `<app></app>`);

createAngularJson();
}
Original file line number Diff line number Diff line change
Expand Up @@ -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');

Expand Down Expand Up @@ -143,4 +144,6 @@ function createMainFiles(): void {
createSourceFile('test/app/app.component.ts', BEFORE);

createSourceFile('test/app/app.template.html', `<app></app>`);

createAngularJson();
}
Original file line number Diff line number Diff line change
Expand Up @@ -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');

Expand Down Expand Up @@ -59,4 +60,6 @@ export class AppComponent {}`,
);

createSourceFile('test/app/app.template.html', `<app></app>`);

createAngularJson();
}
Original file line number Diff line number Diff line change
Expand Up @@ -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');

Expand Down Expand Up @@ -849,4 +850,6 @@ function createMainFiles(): void {
createSourceFile('test/app/app.component.ts', BEFORE);

createSourceFile('test/app/app.template.html', `<app></app>`);

createAngularJson();
}
Original file line number Diff line number Diff line change
Expand Up @@ -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');

Expand Down Expand Up @@ -79,4 +80,6 @@ export class AppComponent {
);

createSourceFile('test/app/app.template.html', `<app></app>`);

createAngularJson();
}
Original file line number Diff line number Diff line change
Expand Up @@ -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');

Expand Down Expand Up @@ -97,4 +98,6 @@ function createMainFiles(): void {
createSourceFile('test/app/app.component.ts', BEFORE);

createSourceFile('test/app/app.template.html', `<app></app>`);

createAngularJson();
}
Original file line number Diff line number Diff line change
Expand Up @@ -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');

Expand Down Expand Up @@ -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();
});
Expand All @@ -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();
}
Loading

0 comments on commit 8719c50

Please sign in to comment.