Files
flights_web_raw/ClientApp/node_modules/prettier-plugin-organize-imports/index.js
T
gnezim 0a5ab058a6 Initial commit: Aeroflot Flights Web - Angular 12 baseline
- Angular 12 application with PrimeNG components
- 5 existing Cypress e2e test suites
- SCSS styling with BEM naming convention
- i18n support (10 languages)
- Leaflet map integration
- Complete component hierarchy and routing structure

This baseline will be used for Angular → React migration.
2026-04-05 18:47:57 +03:00

80 lines
2.1 KiB
JavaScript

/**
* @todo change these to their new locations (`prettier/plugins/<parser>`) with
* the next major release.
*/
const { parsers: babelParsers } = require('prettier/parser-babel');
const { parsers: htmlParsers } = require('prettier/parser-html');
const { parsers: typescriptParsers } = require('prettier/parser-typescript');
const { organize } = require('./lib/organize');
/**
* Organize the code's imports using the `organizeImports` feature of the TypeScript language service API.
*
* @param {string} code
* @param {import('prettier').ParserOptions} options
*/
const organizeImports = (code, options) => {
if (code.includes('// organize-imports-ignore') || code.includes('// tslint:disable:ordered-imports')) {
return code;
}
const isRange =
Boolean(options.originalText) ||
options.rangeStart !== 0 ||
(options.rangeEnd !== Infinity && options.rangeEnd !== code.length);
if (isRange) {
return code; // processing a range doesn't make sense
}
try {
return organize(code, options);
} catch (error) {
if (process.env.DEBUG) {
console.error(error);
}
return code;
}
};
/**
* Set `organizeImports` as the given parser's `preprocess` hook, or merge it with the existing one.
*
* @param {import('prettier').Parser} parser prettier parser
*/
const withOrganizeImportsPreprocess = (parser) => {
return {
...parser,
/**
* @param {string} code
* @param {import('prettier').ParserOptions} options
*/
preprocess: (code, options) =>
organizeImports(parser.preprocess ? parser.preprocess(code, options) : code, options),
};
};
/**
* @type {import('prettier').Plugin}
*/
const plugin = {
options: {
organizeImportsSkipDestructiveCodeActions: {
type: 'boolean',
default: false,
category: 'OrganizeImports',
description: 'Skip destructive code actions like removing unused imports.',
},
},
parsers: {
babel: withOrganizeImportsPreprocess(babelParsers.babel),
'babel-ts': withOrganizeImportsPreprocess(babelParsers['babel-ts']),
typescript: withOrganizeImportsPreprocess(typescriptParsers.typescript),
vue: withOrganizeImportsPreprocess(htmlParsers.vue),
},
};
module.exports = plugin;