@phcode/language-support

1.1.0 • Public • Published

Phoenix language-support

This library provides the language intelligence for CSS/LESS/HTML etc...

Installation

The library can be either installed using npm or using the CDN link (See usage in browser below ).

Getting the code locally

Install the library can be downloaded locally with the following command:

npm install @phcode/fs

Once installed, the language-worker.js lib will be present in the following location

<project_root>/node_modules/@phcode/language-support/dist/language-worker.js

Usage in browser

This library can only be run in a web worker.

Usage in web-worker in browser

Inside your web-worker, import the library as below.

importScripts('<project_root>/node_modules/@phcode/language-support/dist/language-worker.js');
// OR from CDN directly as
importScripts('https://unpkg.com/@phcode/language-support@latest/dist/language-worker.js');

Development

This segment is dedicated to those contributing or modifying the codebase of this repository. If you are just using this as a library, please skip this section.

To build it:

npm install
npm run build

The npm run build command will create two files dist/language-worker.js and dist/language-worker-debnug.js.

Tests in Browser

While developing, use test script to open browser tests.

  • Test runs tests against the built artifacts in dist folder.
  • You should npm run build if any changes were made to the src folder
npm run build
npm run test-browser

NOTE: you can also use npm run serve to also start a web server for development.

Debug Symbols in tests.

By default, tests are run against the release build test/virtualfs.js. As it is heavily optimized it might be hard to debug with the release lib.

If you want to debug the tests with more debug symbols, search for <script src="virtualfs-debug.js"></script> in file test/index.html and follow steps there.

Publishing to npm

Inorder to publish the package to npm, do the following

  1. run npm run relese and push changes to main branch.
  2. raise a pull request from main branch to npm branch. Once the pull request is merged and the code pushed to npm branch, GitHub actions will automatically publish the library to npm.

API

Below is a markdown documentation for the CSSLanguageService object, detailing its functions and usage. This can be used as part of a project's documentation, README, or developer guide.


CSSLanguageService API

The CSSLanguageService provides utility functions for parsing CSS and retrieving CSS selectors(document symbols such as classes, IDs, and other selectors) from given text content.

Methods

getAllSymbols(text, cssMode, filePath)

Retrieves all CSS selectors from the provided CSS text as an array of strings.

Parameters:

  • text (string): The CSS code to analyze.
  • cssMode (string): The mode of the CSS document. This should correspond to one of the supported CSS modes (e.g., CSS, SCSS, LESS) defined in CSS_MODES.
  • filePath (string): Optional. The path of the CSS file, used for resolving relative URLs within the CSS. Defaults to "file://placeholder.css".

Returns:

  • Array[string]: An array containing all the CSS selectors found in the document.

Example Usage:

const cssText = ".class { color: red; } #id { margin: 10px; }";
const selectors = CSSLanguageService.getAllSymbols(cssText, CSSLanguageService.CSS_MODES.CSS);
console.log(selectors); // Output: [".class", "#id"]

validateCSS(text, cssMode, filePath, lintSettings)

Validates CSS code using specified settings and returns an array of diagnostic messages.

Parameters:

  • text (string): The CSS code to be validated.

  • cssMode (string): The CSS mode used for parsing the code.

  • filePath (string): The path of the CSS file being validated.

  • lintSettings (object): The lint settings to be used for validation.

    Possible keys and their descriptions:

    • compatibleVendorPrefixes: Unnecessary vendor prefixes checker.
    • vendorPrefix: Warns on missing vendor prefixes.
    • duplicateProperties: Flags duplicated CSS properties.
    • emptyRules: Detects CSS rules that have no properties.
    • importStatement: Flags the use of @import within CSS files.
    • boxModel: Warns if CSS box model is potentially misused.
    • universalSelector: Warns against the use of the universal selector (*).
    • zeroUnits: Warns when units specification for zero values is unnecessary.
    • fontFaceProperties: Ensures necessary properties are included in @font-face declarations.
    • hexColorLength: Enforces consistency in hex color definitions.
    • argumentsInColorFunction: Validates arguments within color functions.
    • unknownProperties: Warns on unrecognized or mistyped CSS properties.
    • ieHack: Warns about CSS hacks for older versions of Internet Explorer.
    • unknownVendorSpecificProperties: Flags vendor-specific properties that might not be universally recognized.
    • propertyIgnoredDueToDisplay: Notifies when CSS properties are ignored due to the display setting of an element.
    • important: Warns against the excessive use of !important.
    • float: Advises on the use of float, recommending modern layout alternatives.
    • idSelector: Advises against using ID selectors for styling.

Each key's value can be "warning" or "error".

Return Value:

Returns an Array of objects with the following properties:

  • code (string)
  • source (string)
  • message (string)
  • severity (number)
  • range (object) which includes:
    • start (object): contains line (number) and character (number)
    • end (object): contains line (number) and character (number)

These objects represent the diagnostic messages produced during validation.

Constants

CSSLanguageService.CSS_MODES

Defines the supported CSS modes for the getAllSymbols function. Includes:

  • CSS: Standard CSS.
  • SCSS: Sassy CSS (SCSS).
  • LESS: Leaner Style Sheets (LESS).

Example:

console.log(CSSLanguageService.CSS_MODES.CSS); // Output: "CSS"

HTMLLanguageService API

The HTMLLanguageService provides utility functions for parsing and operating on HTML/PHP/HTML Like content.

Methods

getAllDocumentLinks(text, htmlMode, filePath)

Extracts all links from the provided HTML text.

Parameters:

  • text (string): The CSS code to analyze.
  • cssMode (string): The mode of the HTML document. This should correspond to one of the supported HTML modes (e.g., HTML, PHP, XHTML, HTM) defined in HTML_MODES.
  • filePath (string): Optional. The path of the html file, used for resolving relative URLs within the CSS. Defaults to "file:///placeholder.html".

Returns:

  • Array[string]: An array containing all the html links found in the document.

Example Usage:

const htmlContent = `<a href="http://example.com">Visit Example</a>`;
const links = HTMLLanguageService.getAllDocumentLinks(htmlContent,
        HTMLLanguageService.HTML_MODES.HTML, "file:///your-path.html");
console.log(links); // Output: ["http://example.com"]

Constants

CSSLanguageService.HTML_MODES

Defines the supported HTML modes. Includes:

  • HTML: Standard HTML documents.
  • XHTML: XHTML documents.
  • HTM: HTM files, commonly an alternate extension for HTML files.
  • PHP: PHP files that contain HTML content.

Example:

console.log(HTMLLanguageService.HTML_MODES.HTML); // Output: "HTML"

Package Sidebar

Install

npm i @phcode/language-support

Weekly Downloads

166

Version

1.1.0

License

GNU-AGPL3.0

Unpacked Size

21.2 MB

Total Files

8

Last publish

Collaborators

  • core.ai