@jsenv/url-meta

8.4.0 • Public • Published

url meta

Associate value to urls using pattern matching.

import { URL_META } from "@jsenv/url-meta";

// conditionally associates url and values
const associations = {
  color: {
    "file:///*": "black",
    "file:///*.js": "red",
  },
};
const getUrlColor = (url) => {
  const { color } = URL_META.applyAssociations({ url, associations });
  return color;
};
console.log(`file.json color is ${getUrlColor("file:///file.json")}`);
console.log(`file.js color is ${getUrlColor("file:///file.js")}`);

Code above logs

file.json color is black
file.js color is red

Common pattern example

pattern Description
**/ Everything
*/**/ Inside a directory
**/.*/ Inside directory starting with a dot
**/node_modules/ Inside any node_modules directory
node_modules/ Inside root node_modules directory
**/*.map Ending with .map
**/*.test.* Contains .test.
* Inside the root directory only
*/* Inside a directory of depth 1

Read more at ./pattern_matching.md

associations

associations below translates into: "files are visible except thoose in .git/ directory"

const associations = {
  visible: {
    "**/*/": true,
    "**/.git/": false,
  },
};

associations allows to group patterns per property which are easy to read and compose. All keys in associations must be absolute urls, this can be done with resolveAssociations.

resolveAssociations

resolveAssociations is a function resolving associations keys that may contain relative urls against an url.

import { URL_META } from "@jsenv/url-meta";

const associations = URL_META.resolveAssociations(
  {
    visible: {
      "**/*/": true,
      "**/.git/": false,
    },
  },
  "file:///Users/directory/",
);
console.log(JSON.stringify(associations, null, "  "));
{
  "visible": {
    "file:///Users/directory/**/*/": true,
    "file:///Users/directory/**/.git/": false
  }
}

Readme

Keywords

none

Package Sidebar

Install

npm i @jsenv/url-meta

Weekly Downloads

200

Version

8.4.0

License

MIT

Unpacked Size

18.5 kB

Total Files

5

Last publish

Collaborators

  • jsenv-admin
  • dmail