Skip to content

Commit

Permalink
fix(@angular-devkit/build-angular): issue warning when using deprecat…
Browse files Browse the repository at this point in the history
…ed tilde imports

With this change we add a warning when using deprecated tilde/`~` imports.

(cherry picked from commit 9aab9ad)
  • Loading branch information
alan-agius4 authored and clydin committed Aug 30, 2022
1 parent 918418e commit 17b7e1b
Showing 1 changed file with 29 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
import * as fs from 'fs';
import MiniCssExtractPlugin from 'mini-css-extract-plugin';
import * as path from 'path';
import { Configuration, RuleSetUseItem } from 'webpack';
import { Configuration, RuleSetUseItem, WebpackError } from 'webpack';
import { StyleElement } from '../../builders/browser/schema';
import { SassWorkerImplementation } from '../../sass/sass-service';
import { WebpackConfigOptions } from '../../utils/build-options';
Expand Down Expand Up @@ -112,11 +112,21 @@ export function getStylesConfig(wco: WebpackConfigOptions): Configuration {
}

const sassImplementation = new SassWorkerImplementation();
const sassTildeUsageMessage = new Set<string>();

extraPlugins.push({
apply(compiler) {
compiler.hooks.shutdown.tap('sass-worker', () => {
sassImplementation.close();
});

compiler.hooks.afterCompile.tap('sass-worker', (compilation) => {
for (const message of sassTildeUsageMessage) {
compilation.warnings.push(new WebpackError(message));
}

sassTildeUsageMessage.clear();
});
},
});

Expand Down Expand Up @@ -274,6 +284,15 @@ export function getStylesConfig(wco: WebpackConfigOptions): Configuration {
implementation: sassImplementation,
sourceMap: true,
sassOptions: {
importer: (url: string, from: string) => {
if (url.charAt(0) === '~') {
sassTildeUsageMessage.add(
`'${from}' imports '${url}' with a tilde. Usage of '~' in imports is deprecated.`,
);
}

return null;
},
// Prevent use of `fibers` package as it no longer works in newer Node.js versions
fiber: false,
// bootstrap-sass requires a minimum precision of 8
Expand Down Expand Up @@ -306,6 +325,15 @@ export function getStylesConfig(wco: WebpackConfigOptions): Configuration {
implementation: sassImplementation,
sourceMap: true,
sassOptions: {
importer: (url: string, from: string) => {
if (url.charAt(0) === '~') {
sassTildeUsageMessage.add(
`'${from}' imports '${url}' with a tilde. Usage of '~' in imports is deprecated.`,
);
}

return null;
},
// Prevent use of `fibers` package as it no longer works in newer Node.js versions
fiber: false,
indentedSyntax: true,
Expand Down

0 comments on commit 17b7e1b

Please sign in to comment.