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

ts-traits

v0.0.0-experimental-f474149

Published

![GitHub package.json version](https://img.shields.io/github/package-json/v/tony-tsx/ts-traits?style=for-the-badge) ![GitHub](https://img.shields.io/github/license/tony-tsx/ts-traits?style=for-the-badge) ![GitHub Workflow Status](https://img.shields.io/gi

Downloads

3

Readme

Typesript Traits

GitHub package.json version GitHub GitHub Workflow Status

Typesript Traits is a lib that, as its name says, creates our beloved traits, helping to improve the syntax of our class.

Installation

npm install @prunus/mixin

or

yarn add @prunus/mixin

Usage

The best way:

This is the purpose of this lib, to give readability to your code in a clean way and with little code. This, along with the typescript mixin feature, makes it even more exciting as they complement each other extremely well.

import { Mix } from '@prunus/mixin'

class Trait1 {}
class Trait2 {}

class Class extends Mix(Trait1, Trait2) {}

Or

import { Mixin } from '@prunus/mixin'

class Trait1 {}
class Trait2 {}

@Mixin(Trait1, Trait2)
class Class {}

interface Class extends Trait1, Trait2 {}

Test! Write some properties of your traits and your class and watch the magic happen.

The not so good way:

We certainly do not encourage you to do this, but it is a feature that could not be left out, due to some specific needs that the developer may have.

import { Mixin } from '@prunus/mixin'

class Trait1 {}

class Trait2 {}

class TestClass {}

const Test: TestConstructor = Mixin(Trait1, Trait2)(TestClass)

interface TestClass extends Trait1, Trait2 {}
interface TestConstructor {
  new (): TestClass
}

As you can see in this way, we lose readability, it can make the code confusing depending on how complex our trait or class code is, even separating it into files... But it works, so your imagination is the limit.

Supers

We haven't forgotten about the overlay, and we never will, that's why we remember our super. Unfortunately we can't fight js for the position of super inside the class, but it is a property of our this.supers.

import { Mix } from '@prunus/mixin'

class Trait {
  say() {
    console.log('Hello world i\'am a trait')
  }
}

class Class extends Mix(Trait) {
  say() {
    this.supers.for(Trait).say()

    console.log('Hello world i\'am a mixin')
  }
}

All instanceof instructions working correctly

In your code you can check if that instance of your dear mix is an instance of some other class within the mix. Example:

import { Mix } from '@prunus/mixin'

class Trait1 {}

class Trait2 {}

class Trait3 {}

class Class1 extends Mix(Trai1, Trait3)

class Class2 extends Mix(Trait1, Trait2) {}

console.log(new Class2() instanceof Trait1) // true
console.log(new Class2() instanceof Trait2) // true
console.log(new Class2() instanceof Trait3) // false
console.log(new Class2() instanceof Class1) // false
console.log(new Class1() instanceof Trait3) // true
console.log(new Class1() instanceof Trait1) // false
console.log(new Class1() instanceof Trait2) // false
console.log(new Class1() instanceof Class2) // false