UNPKG

projen

Version:

CDK for software projects

181 lines • 24.3 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.Prettier = exports.TrailingComma = exports.QuoteProps = exports.ProseWrap = exports.HTMLWhitespaceSensitivity = exports.EndOfLine = exports.EmbeddedLanguageFormatting = exports.ArrowParens = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const component_1 = require("../component"); const ignore_file_1 = require("../ignore-file"); const json_1 = require("../json"); const source_code_1 = require("../source-code"); const yaml_1 = require("../yaml"); var ArrowParens; (function (ArrowParens) { /** * Always include parens. Example: `(x) => x` */ ArrowParens["ALWAYS"] = "always"; /** * Omit parens when possible. Example: `x => x` */ ArrowParens["AVOID"] = "avoid"; })(ArrowParens || (exports.ArrowParens = ArrowParens = {})); var EmbeddedLanguageFormatting; (function (EmbeddedLanguageFormatting) { /** * Format embedded code if Prettier can automatically identify it. */ EmbeddedLanguageFormatting["AUTO"] = "auto"; /** * Never automatically format embedded code. */ EmbeddedLanguageFormatting["OFF"] = "off"; })(EmbeddedLanguageFormatting || (exports.EmbeddedLanguageFormatting = EmbeddedLanguageFormatting = {})); var EndOfLine; (function (EndOfLine) { /** * Maintain existing (mixed values within one file are normalised by looking * at what's used after the first line) */ EndOfLine["AUTO"] = "auto"; /** * Carriage Return character only (\r), used very rarely */ EndOfLine["CR"] = "cr"; /** * Carriage Return + Line Feed characters (\r\n), common on Windows */ EndOfLine["CRLF"] = "crlf"; /** * Line Feed only (\n), common on Linux and macOS as well as inside git repos */ EndOfLine["LF"] = "lf"; })(EndOfLine || (exports.EndOfLine = EndOfLine = {})); var HTMLWhitespaceSensitivity; (function (HTMLWhitespaceSensitivity) { /** * Respect the default value of CSS display property. */ HTMLWhitespaceSensitivity["CSS"] = "css"; /** * Whitespaces are considered insignificant. */ HTMLWhitespaceSensitivity["IGNORE"] = "ignore"; /** * Whitespaces are considered significant. */ HTMLWhitespaceSensitivity["STRICT"] = "strict"; })(HTMLWhitespaceSensitivity || (exports.HTMLWhitespaceSensitivity = HTMLWhitespaceSensitivity = {})); var ProseWrap; (function (ProseWrap) { /** * Wrap prose if it exceeds the print width. */ ProseWrap["ALWAYS"] = "always"; /** * Do not wrap prose. */ ProseWrap["NEVER"] = "never"; /** * Wrap prose as-is. */ ProseWrap["PRESERVE"] = "preserve"; })(ProseWrap || (exports.ProseWrap = ProseWrap = {})); var QuoteProps; (function (QuoteProps) { /** * Only add quotes around object properties where required. */ QuoteProps["ASNEEDED"] = "as-needed"; /** * If at least one property in an object requires quotes, quote all properties. */ QuoteProps["CONSISTENT"] = "consistent"; /** * Respect the input use of quotes in object properties. */ QuoteProps["PRESERVE"] = "preserve"; })(QuoteProps || (exports.QuoteProps = QuoteProps = {})); var TrailingComma; (function (TrailingComma) { /** * Trailing commas wherever possible (including function arguments). */ TrailingComma["ALL"] = "all"; /** * Trailing commas where valid in ES5 (objects, arrays, etc.) */ TrailingComma["ES5"] = "es5"; /** * No trailing commas. */ TrailingComma["NONE"] = "none"; })(TrailingComma || (exports.TrailingComma = TrailingComma = {})); /** * Represents prettier configuration. */ class Prettier extends component_1.Component { static of(project) { const isPrettier = (c) => c instanceof Prettier; return project.components.find(isPrettier); } constructor(project, options) { super(project); this._overrides = options.overrides ?? []; if (options.ignoreFile ?? true) { this.ignoreFile = new ignore_file_1.IgnoreFile(project, ".prettierignore", options.ignoreFileOptions); project.addPackageIgnore("/.prettierignore"); } project.addDevDeps("prettier"); this.settings = { ...options.settings, }; if (options.yaml) { new yaml_1.YamlFile(project, ".prettierrc.yml", { obj: () => ({ ...this.settings, overrides: [...this._overrides] }), marker: true, }); project.addPackageIgnore("/.prettierrc.yml"); } else { new json_1.JsonFile(project, ".prettierrc.json", { obj: () => ({ ...this.settings, overrides: [...this._overrides] }), marker: false, }); project.addPackageIgnore("/.prettierrc.json"); } } /** * Add a prettier override * @see https://prettier.io/docs/en/configuration.html#configuration-overrides * @param {PrettierOverride} override */ addOverride(override) { this._overrides.push(override); } /** * Defines Prettier ignore Patterns * these patterns will be added to the file .prettierignore * * @param pattern filepatterns so exclude from prettier formatting */ addIgnorePattern(pattern) { this.ignoreFile?.addPatterns(pattern); } /** * Returns all Prettier overrides */ get overrides() { return [...this._overrides]; } preSynthesize() { // Add automatically generated SourceCode files to .prettierignore as they may not be formatted correctly. const isSourceCode = (c) => c instanceof source_code_1.SourceCode; this.project.components.filter(isSourceCode).forEach((c) => { this.addIgnorePattern(c.filePath); }); } } exports.Prettier = Prettier; _a = JSII_RTTI_SYMBOL_1; Prettier[_a] = { fqn: "projen.javascript.Prettier", version: "0.95.2" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"prettier.js","sourceRoot":"","sources":["../../src/javascript/prettier.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component } from \"../component\";\nimport { IgnoreFile, IgnoreFileOptions } from \"../ignore-file\";\nimport { NodeProject } from \"../javascript\";\nimport { JsonFile } from \"../json\";\nimport { Project } from \"../project\";\nimport { SourceCode } from \"../source-code\";\nimport { YamlFile } from \"../yaml\";\n/**\n * Options for Prettier\n *\n */\nexport interface PrettierOptions {\n  /**\n   * Defines an .prettierIgnore file\n   *\n   * @default true\n   */\n  readonly ignoreFile?: boolean;\n\n  /**\n   * Configuration options for .prettierignore file\n   */\n  readonly ignoreFileOptions?: IgnoreFileOptions;\n\n  /**\n   * Prettier settings.\n   * @default - default settings\n   */\n  readonly settings?: PrettierSettings;\n\n  /**\n   * Provide a list of patterns to override prettier configuration.\n   *\n   * @default []\n   * @see https://prettier.io/docs/en/configuration.html#configuration-overrides\n   */\n  readonly overrides?: PrettierOverride[];\n\n  /**\n   * Write prettier configuration as YAML instead of JSON\n   * @default false\n   */\n  readonly yaml?: boolean;\n}\n/**\n * Options to set in Prettier directly or through overrides\n *\n * @see https://prettier.io/docs/en/options.html\n */\nexport interface PrettierSettings {\n  /**\n   * Include parentheses around a sole arrow function parameter.\n   *\n   * @default ArrowParens.ALWAYS\n   */\n  readonly arrowParens?: ArrowParens;\n  /**\n   * Put > of opening tags on the last line instead of on a new line.\n   *\n   * @default false\n   */\n  readonly bracketSameLine?: boolean;\n  /**\n   * Print spaces between brackets.\n   *\n   * @default true\n   */\n  readonly bracketSpacing?: boolean;\n  /**\n   * Print (to stderr) where a cursor at the given position would move to after formatting.\n   * This option cannot be used with --range-start and --range-end.\n   *\n   * @default -1\n   */\n  readonly cursorOffset?: number;\n  /**\n   * Control how Prettier formats quoted code embedded in the file.\n   *\n   * @default EmbeddedLanguageFormatting.AUTO\n   */\n  readonly embeddedLanguageFormatting?: EmbeddedLanguageFormatting;\n  /**\n   * Which end of line characters to apply.\n   *\n   * @default EndOfLine.LF\n   */\n  readonly endOfLine?: EndOfLine;\n  /**\n   * Specify the input filepath. This will be used to do parser inference.\n   * @default none\n   */\n  readonly filepath?: string;\n  /**\n   * How to handle whitespaces in HTML.\n   *\n   * @default HTMLWhitespaceSensitivity.CSS\n   */\n  readonly htmlWhitespaceSensitivity?: HTMLWhitespaceSensitivity;\n  /**\n   * Insert @format pragma into file's first docblock comment.\n   *\n   * @default false\n   */\n  readonly insertPragma?: boolean;\n  /**\n   * Use single quotes in JSX.\n   *\n   * @default false\n   */\n  readonly jsxSingleQuote?: boolean;\n  /**\n   * Which parser to use.\n   *\n   * @default - Prettier automatically infers the parser from the input file path, so you shouldn’t have to change this setting.\n   */\n  readonly parser?: string;\n  /**\n   * Add a plugin. Multiple plugins can be passed as separate `--plugin`s.\n   *\n   * @default []\n   */\n  readonly plugins?: string[];\n  /**\n   * Custom directory that contains prettier plugins in node_modules subdirectory.\n   * Overrides default behavior when plugins are searched relatively to the location of\n   * Prettier.\n   * Multiple values are accepted.\n   *\n   * @default []\n   */\n  readonly pluginSearchDirs?: string[];\n  /**\n   * The line length where Prettier will try wrap.\n   *\n   * @default 80\n   */\n  readonly printWidth?: number;\n  /**\n   * How to wrap prose.\n   *\n   * @default ProseWrap.PRESERVE\n   */\n  readonly proseWrap?: ProseWrap;\n  /**\n   * Change when properties in objects are quoted.\n   *\n   * @default QuoteProps.ASNEEDED\n   */\n  readonly quoteProps?: QuoteProps;\n  /**\n   * Format code ending at a given character offset (exclusive).\n   * The range will extend forwards to the end of the selected statement.\n   * This option cannot be used with --cursor-offset.\n   *\n   * @default null\n   */\n  readonly rangeEnd?: number;\n  /**\n   * Format code starting at a given character offset.\n   * The range will extend backwards to the start of the first line containing the selected\n   * statement.\n   * This option cannot be used with --cursor-offset.\n   *\n   * @default 0\n   */\n  readonly rangeStart?: number;\n  /**\n   * Require either '@prettier' or '@format' to be present in the file's first docblock\n   * comment\n   * in order for it to be formatted.\n   *\n   * @default false\n   */\n  readonly requirePragma?: boolean;\n  /**\n   * Print semicolons.\n   *\n   * @default true\n   */\n  readonly semi?: boolean;\n  /**\n   * Use single quotes instead of double quotes.\n   *\n   * @default false\n   */\n  readonly singleQuote?: boolean;\n  /**\n   * Number of spaces per indentation level.\n   *\n   * @default 2\n   */\n  readonly tabWidth?: number;\n  /**\n   * Print trailing commas wherever possible when multi-line.\n   *\n   * @default TrailingComma.ES5\n   */\n  readonly trailingComma?: TrailingComma;\n  /**\n   * Indent with tabs instead of spaces.\n   *\n   * @default false\n   */\n  readonly useTabs?: boolean;\n  /**\n   * Indent script and style tags in Vue files.\n   *\n   * @default false\n   */\n  readonly vueIndentScriptAndStyle?: boolean;\n}\n\nexport enum ArrowParens {\n  /**\n   * Always include parens. Example: `(x) => x`\n   */\n  ALWAYS = \"always\",\n\n  /**\n   * Omit parens when possible. Example: `x => x`\n   */\n  AVOID = \"avoid\",\n}\n\nexport enum EmbeddedLanguageFormatting {\n  /**\n   * Format embedded code if Prettier can automatically identify it.\n   */\n  AUTO = \"auto\",\n\n  /**\n   * Never automatically format embedded code.\n   */\n  OFF = \"off\",\n}\n\nexport enum EndOfLine {\n  /**\n   * Maintain existing (mixed values within one file are normalised by looking\n   * at what's used after the first line)\n   */\n  AUTO = \"auto\",\n\n  /**\n   * Carriage Return character only (\\r), used very rarely\n   */\n  CR = \"cr\",\n\n  /**\n   * Carriage Return + Line Feed characters (\\r\\n), common on Windows\n   */\n  CRLF = \"crlf\",\n\n  /**\n   * Line Feed only (\\n), common on Linux and macOS as well as inside git repos\n   */\n  LF = \"lf\",\n}\n\nexport enum HTMLWhitespaceSensitivity {\n  /**\n   * Respect the default value of CSS display property.\n   */\n  CSS = \"css\",\n\n  /**\n   * Whitespaces are considered insignificant.\n   */\n  IGNORE = \"ignore\",\n\n  /**\n   * Whitespaces are considered significant.\n   */\n  STRICT = \"strict\",\n}\n\nexport interface PrettierOverride {\n  /**\n   * Exclude these files from this override.\n   */\n  readonly excludeFiles?: Files;\n  /**\n   * Include these files in this override.\n   */\n  readonly files: Files;\n  /**\n   * The options to apply for this override.\n   */\n  readonly options: PrettierSettings;\n}\n\n/**\n * Exclude these files from this override.\n *\n * Include these files in this override.\n */\nexport type Files = string[] | string;\n\nexport enum ProseWrap {\n  /**\n   * Wrap prose if it exceeds the print width.\n   */\n  ALWAYS = \"always\",\n\n  /**\n   * Do not wrap prose.\n   */\n  NEVER = \"never\",\n\n  /**\n   * Wrap prose as-is.\n   */\n  PRESERVE = \"preserve\",\n}\n\nexport enum QuoteProps {\n  /**\n   * Only add quotes around object properties where required.\n   */\n  ASNEEDED = \"as-needed\",\n\n  /**\n   * If at least one property in an object requires quotes, quote all properties.\n   */\n  CONSISTENT = \"consistent\",\n\n  /**\n   * Respect the input use of quotes in object properties.\n   */\n  PRESERVE = \"preserve\",\n}\n\nexport enum TrailingComma {\n  /**\n   * Trailing commas wherever possible (including function arguments).\n   */\n  ALL = \"all\",\n\n  /**\n   * Trailing commas where valid in ES5 (objects, arrays, etc.)\n   */\n  ES5 = \"es5\",\n\n  /**\n   * No trailing commas.\n   */\n  NONE = \"none\",\n}\n\n/**\n * Represents prettier configuration.\n */\nexport class Prettier extends Component {\n  public static of(project: Project): Prettier | undefined {\n    const isPrettier = (c: Component): c is Prettier => c instanceof Prettier;\n    return project.components.find(isPrettier);\n  }\n  /**\n   * Direct access to the prettier settings\n   */\n  public readonly settings: PrettierSettings;\n\n  /**\n   * The .prettierIgnore file.\n   */\n  public readonly ignoreFile?: IgnoreFile;\n\n  /**\n   * Direct access to the prettier overrides\n   *\n   * @internal\n   */\n  private readonly _overrides: PrettierOverride[];\n\n  constructor(project: NodeProject, options: PrettierOptions) {\n    super(project);\n\n    this._overrides = options.overrides ?? [];\n\n    if (options.ignoreFile ?? true) {\n      this.ignoreFile = new IgnoreFile(\n        project,\n        \".prettierignore\",\n        options.ignoreFileOptions\n      );\n\n      project.addPackageIgnore(\"/.prettierignore\");\n    }\n\n    project.addDevDeps(\"prettier\");\n\n    this.settings = {\n      ...options.settings,\n    };\n\n    if (options.yaml) {\n      new YamlFile(project, \".prettierrc.yml\", {\n        obj: () => ({ ...this.settings, overrides: [...this._overrides] }),\n        marker: true,\n      });\n      project.addPackageIgnore(\"/.prettierrc.yml\");\n    } else {\n      new JsonFile(project, \".prettierrc.json\", {\n        obj: () => ({ ...this.settings, overrides: [...this._overrides] }),\n        marker: false,\n      });\n      project.addPackageIgnore(\"/.prettierrc.json\");\n    }\n  }\n\n  /**\n   * Add a prettier override\n   * @see https://prettier.io/docs/en/configuration.html#configuration-overrides\n   * @param {PrettierOverride} override\n   */\n  public addOverride(override: PrettierOverride) {\n    this._overrides.push(override);\n  }\n\n  /**\n   * Defines Prettier ignore Patterns\n   * these patterns will be added to the file .prettierignore\n   *\n   * @param pattern filepatterns so exclude from prettier formatting\n   */\n  public addIgnorePattern(pattern: string) {\n    this.ignoreFile?.addPatterns(pattern);\n  }\n\n  /**\n   *  Returns all Prettier overrides\n   */\n  public get overrides() {\n    return [...this._overrides];\n  }\n\n  public preSynthesize() {\n    // Add automatically generated SourceCode files to .prettierignore as they may not be formatted correctly.\n    const isSourceCode = (c: Component): c is SourceCode =>\n      c instanceof SourceCode;\n    this.project.components.filter(isSourceCode).forEach((c) => {\n      this.addIgnorePattern(c.filePath);\n    });\n  }\n}\n"]}