7.6.0 • Published 1 year ago

trophyutil v7.6.0

Weekly downloads
-
License
GPL-3.0-or-later
Repository
github
Last release
1 year ago

TrophyUtil

TrophyUtil is a specialized utility library designed for parsing, modelling, and manipulating core PSNProfiles (PSNP) entities like trophies, games, and game series.

Features

  • Isomorphic, working seamlessly in both frontend and backend (via jsdom) projects.
  • Compatible with both CommonJS and ESM.
  • HTML parsers for core PSNP entities like trophies, games, and game series.
  • Richly-annotated interfaces and classes that provide helpful methods, like transforming a completion time into a timestamp and vice versa.
  • Additional interfaces for MongoDB/Mongoose provide smoother database integration with properties like createdAt and updatedAt.
  • Specialized utility functions for trophy-specific use cases like parsing formatted numbers and checking for relative equality between entities.

Installation

Install TrophyUtil using npm:

npm install trophyutil

Usage

Here's how you might use this library to parse games, for example:

import {getPsnpPageType, PsnpGameStandard, ParserGameStandard} from 'trophyutil';

// Select nodes based on page type
const pageType = getPsnpPageType(window.location);
const gameNodes = PsnpGameStandard.getGameNodes(pageType, window.document);

// Parse nodes into richly-interfaced data
const parser = new ParserGameStandard();
const gameData = gameNodes.map(node => parser.parse(node));
const speed = gameData[0].completionSpeed; // 3661

// Classes wrap data with utility methods
const games = gameData.map(data => new PsnpGameStandard(data));
const speedString = PsnpGameStandard.secondsToSpeedString(speed); // "1 hour, 1 minute"

Contributing

Contributions are welcome! Submit a pull request or create an issue to contribute to this project.

License

This project is licensed under the GPLv3 License - see COPYING.txt for details.

7.6.0

1 year ago

7.4.0

2 years ago

7.3.1

2 years ago

7.3.0

2 years ago

7.4.4

2 years ago

7.4.3

2 years ago

7.5.1

2 years ago

7.4.2

2 years ago

7.5.0

2 years ago

7.4.1

2 years ago

7.3.2

2 years ago

7.2.4

2 years ago

7.2.3

2 years ago

7.2.2

2 years ago

7.2.1

2 years ago

7.2.0

2 years ago

7.1.3

2 years ago

7.1.2

2 years ago

7.1.1

2 years ago

7.1.0

2 years ago

7.0.0

2 years ago

6.0.5

2 years ago

6.0.4

2 years ago

6.0.3

2 years ago