Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/honoluluhenk/typesafe-json-path

Build simple JSON-paths in a typesafe way
https://github.com/honoluluhenk/typesafe-json-path

Last synced: about 2 months ago
JSON representation

Build simple JSON-paths in a typesafe way

Awesome Lists containing this project

README

        


# typesafe-json-path

Typesafe navigation in JSON data structures for typescrpt.

[![Contributors][contributors-shield]][contributors-url]
[![Forks][forks-shield]][forks-url]
[![Stargazers][stars-shield]][stars-url]
[![Issues][issues-shield]][issues-url]
[![MIT License][license-shield]][license-url]

[![CI][Workflow-build-shield]][Workflow-build-url]
[![NPM][npm-package-shield]][npm-package-shield-url]

Table of Contents


  1. About The Project


  2. Usage



  3. Getting Started


  4. Changelog

  5. Roadmap

  6. Contributing

  7. License

  8. Contact

  9. Acknowledgments

## About The Project

* Ever had a JSON data structure that is implemented in more than one file? Translation-files anyone?
* You wanted to access these values in a typesafe manner? I.e.: without resorting to string-keys?
* You want refactoring support from your IDE when renaming properties?
* You want compilation to fail if you mistyped a property name?

Read the examples in Usage to find out how!

(back to top)

## Usage

Best shown by example:

### Minimal example
```typescript
import {TypesafeJsonPath} from '@honoluluhenk/typesafe-json-path';

const translationsRoot = {
FOO: {
BAR: {
BAZ: 'Baz was here!',
HELLO: 'Hello World',
}
}
};

const path = TypesafeJsonPath.init();

// please note: this is not string but real property access!
const pathAsString = path.FOO.BAR.HELLO.$path.path;
// 'FOO.BAR.HELLO'
const value = path.FOO.BAR.HELLO.$path.get(translationsRoot);

console.log(value);
// 'Hello World'
```

(back to top)

### Full example
The full power can be seen here:
use a custom Resolver and go wild.

This example implements a translation service that is not access-by-string but fully typesafe!

```typescript
import {type PathSegment, Resolver, TypesafeJsonPath} from '@honoluluhenk/typesafe-json-path';

const translationsRoot = {
FOO: {
BAR: {
BAZ: 'Baz was here!',
HELLO: 'Hello %s',
RUCKSACK: 'Rucksack',
},
},
};
// some other translation
const translationsDE = {
FOO: {
BAR: {
BAZ: 'Baz war hier!',
HELLO: 'Hallo %s',
},
},
};

// your custom path resolver
class Translator extends Resolver {
constructor(
path: ReadonlyArray,
private readonly myTranslateService: MyCustomTranslateService,
) {
super(path);
}

translate(...args: unknown[]): string {
// Delegate to some translation service.
return this.myTranslateService.translate(this.path, args);
}
}

// include all variants to have full refactoring support in your IDE
type TranslationType = typeof translationsRoot & typeof translationsDE;

// Now the real fun begins...
const translations = TypesafeJsonPath.init>(
path => new Translator(
path,
new MyCustomTranslateService(navigator.languages[0], {en: translationsRoot, de: translationsDE}),
),
);

// again: this is not string but real property access in a typesafe and refactoring-friendly way!
const text = translations.FOO.BAR.HELLO.$path.translate('Welt');
// internally, myTranslateService.translate() was called with the path-string 'FOO.BAR.HELLO'.
console.log(text);
// Assuming the user language was some german (de) locale:
// 'Hallo Welt'

```

(back to top)

## Getting Started

### Prerequisites
The implementation makes heavy use of the [Proxy][mdn-proxy-url] object.

As such, this lib can only be used if [it is available](https://caniuse.com/?search=proxy).

### Installation

This npm library is intended to be used in typescript projects where the

Just install the NPM package:
```sh
npm install @honoluluhenk/typesafe-json-path
```

(back to top)

## Changelog
See [releases][releases-url]

(back to top)

## Contributing

Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are **greatly appreciated**.

If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement".
Don't forget to give the project a star! Thanks again!

1. Fork the Project
2. Create your Feature Branch (`git checkout -b feature/AmazingFeature`)
3. Commit your Changes (`git commit -m 'Add some AmazingFeature'`)
4. Run tests/linting (`npm run prepush`)
5. Push to the Branch (`git push origin feature/AmazingFeature`)
6. Open a Pull Request

(back to top)

## License

Distributed under the Lesser Gnu Public License 2.1 (LGPL-2.1) License. See [`LICENSE`](LICENSE) for more information.

(back to top)

## Contact

Christoph Linder - [email protected]

Project Link: [https://github.com/HonoluluHenk/typesafe-json-path](https://github.com/HonoluluHenk/typesafe-json-path)

(back to top)

[contributors-shield]: https://img.shields.io/github/contributors/HonoluluHenk/typesafe-json-path.svg?style=for-the-badge
[contributors-url]: https://github.com/HonoluluHenk/typesafe-json-path/graphs/contributors
[forks-shield]: https://img.shields.io/github/forks/HonoluluHenk/typesafe-json-path.svg?style=for-the-badge
[forks-url]: https://github.com/HonoluluHenk/typesafe-json-path/network/members
[stars-shield]: https://img.shields.io/github/stars/HonoluluHenk/typesafe-json-path.svg?style=for-the-badge
[stars-url]: https://github.com/HonoluluHenk/typesafe-json-path/stargazers
[issues-shield]: https://img.shields.io/github/issues/HonoluluHenk/typesafe-json-path.svg?style=for-the-badge
[issues-url]: https://github.com/HonoluluHenk/typesafe-json-path/issues
[releases-url]: https://github.com/HonoluluHenk/typesafe-json-path/releases
[license-shield]: https://img.shields.io/github/license/HonoluluHenk/typesafe-json-path.svg?style=for-the-badge
[license-url]: https://github.com/HonoluluHenk/typesafe-json-path/blob/master/LICENSE.txt
[npm-package-shield]: https://badge.fury.io/js/@honoluluhenk%2Ftypesafe-json-path.svg
[npm-package-shield-url]: https://badge.fury.io/js/@honoluluhenk%2Ftypesafe-json-path
[Workflow-build-shield]: https://github.com/HonoluluHenk/typesafe-json-path/actions/workflows/build-and-publish.yml/badge.svg?branch=main
[Workflow-build-url]: https://github.com/HonoluluHenk/typesafe-json-path/actions/workflows/build-and-publish.yml
[mdn-proxy-url]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Proxy