npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

jshaper

v1.0.2

Published

Semantic object mapper written in TypeScript.

Downloads

5

Readme

JShaper

JShaper is a Typescript library that maps source data to a target object using textual feature extraction. To match keys between objects, the cosine similarity of each source embedding to target embeddings is computed.

Source data in JSON and XML file formats are only accepted.

Installation

Npm: install the jshaper package

npm i jshaper

Github: clone the repository and install the necessary dependencies

git clone https://github.com/danmxli/JShaper.git
cd JShaper
npm install

Usage

import { MapObject } from "jshaper";
import exampleJson from "./example.json"
import * as fs from "fs";

async function main() {
    const jsonMapTarget = {
        username: '',
        email: '',
        contact: {
            phone: '',
            address: {
                street: '',
                zipCode: 0
            }
        },
        preferences: {
            newsletter: false,
            notifications: false
        }
    };

    const xmlMapTarget = {
        booktitle: '',
        bookauthor: '',
        bookyear: '',
    }
  
    const objectMapper = new MapObject()
    const mappedJsonData = await objectMapper.mapObject(exampleJson, jsonMapTarget)
    console.log(mappedJsonData)

    fs.readFile(__dirname + '/example.xml', async function read(err, data) {
        if (err) {
            throw err;
        }
      
        const mappedXmlData = await objectMapper.mapObject(data, xmlMapTarget)
        console.log(mappedXmlData)
    });
}

main();

// {
//   email: '[email protected]',
//   contact: {
//     phone: '123-456-7890',
//     address: { street: 'Oak St', zipCode: 98765 }
//   },
//   preferences: { newsletter: true, notifications: true }
// }
// {
//   booktitle: 'The Great Gatsby',
//   bookauthor: 'F. Scott Fitzgerald',
//   bookyear: '1925'
// }

API

MapObject Class

Constructor

/**
 * 
 * @param {string} model - the Hugging Face model to perform text feature extraction. Default is "Xenova/all-MiniLM-L6-v2"
 * @param {number} similarityThreshold - the cosine similarity threshold. Default is 0.5
 */
new MapObject(model?: string, similarityThreshold?: number): MapObject

Public methods

/**
 * 
 * @param source - the source object. Supports JSON and XML file formats.
 * @param target - the target object that the source maps to.
 * @returns {TJsonObject} the target object with populated values from source.
 */
async mapObject(source: TJsonObject, target: TJsonObject): Promise<TJsonObject>

Supported models

Hugging Face feature extraction models

How it works

MapObject preserves source and target data by flattening nested objects to a depth of 1.

Keys are represented using dot-notation, which is used to unflatten the target object into its original depth.

The text embeddings of the flattened source and target keys are computed using the feature-extraction pipeline from the Transformers.js library.

By computing the cosine similarity of embeddings, it determines which key in the flattened target object is most semantically similar to each key in the flattened source object.

The value from the source object is mapped to the matching key in the target object if the similarity score is higher than the threshold.

Dependencies

@xenova/transformers

xml2js

License

This project is licensed under the MIT License.