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 🙏

© 2025 – Pkg Stats / Ryan Hefner

banggood-store

v0.0.20

Published

bang data store

Downloads

7

Readme

brain-store

use

import {Store,resource,IResource} from 'banggood-store';
const user:IResource = resource('PMS/User');
export default class StoreBase extends Store {
    static meta = {
        ...Store.meta,
        namespace: 'bang.portal'
    }
    context:any
    constructor(context){
        super(context)
    }
}

class Counter extends StoreBase {
  completed:string;
  name: string;
  get fullName() {
    return `${this.name} new`;
  }
  setCompleted(value) {
    this.completed = value;
  }
  setName(value) {
    this.name = value;
  }
}

class ContainerStore extends StoreBase{
    static meta={
        ...StoreBase.meta,
        eventScopes:[user],
        contextTypes:{
            CounterApp:Counter,
        }
    }
    _title='';
    get name():string{
        return this._title
    };
    constructor(context){
        super(context);
    }
    contextCounterStore():Counter{
        return this.context.CounterApp
    }
    triggerEvent(payload) { //事件广播,批量修改store里面数据状态 在相应store里面定义onEvent 函数并且eventScopes值设为user
        this.context.dispatch(user.created,payload);
    }
    setName(value) {
        this._title = value;
    }
}

class UserListStore extends StoreBase {
    static meta = {
        ...StoreBase.meta,
        eventScopes: [user],
    };

    getContextAppStore() {
       // return this.context.app;
    }
    payloadModel = null;
    onEvent(event) {
        if(typeof event.payload==='object'){
            Object.keys(event.payload).forEach(key =>{
                this[`${key}`] = event.payload[key];
            });
        }
        else {
            this.payloadModel = event.payload;
        }
    }
}
--- angular -----

import { Component,OnInit,OnChanges,SimpleChange,EventEmitter,Output } from '@angular/core';
import ContainerStore from './store/ContainerStore';
import {bind} from 'banggood-store'

@bind({store:ContainerStore})
@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  store:ContainerStore
  constructor(){
    console.log(this)
  }
	onVoted(agreed: boolean) {
     this.store.setName('设置mobx');
  }
}

observablePromise

我们所有服务端数据结构都用此类构造出来

MapperEntity&JsonProperty

介绍(Introduction)

背景:对于单页应用,数据源是从API服务器获得的。 我们不用直接使用api数据。这时就需要适配器层赖根据需要转换数据。 此外,该适配器与API服务器的数据依赖关系相反(API Server被视为不可控制的非常不可靠,因为数据结构可能由后端 编码器为某些特定目的编辑)到我们的适配器这变得可靠。 因此,该库被创建为适配器。

USING

npm install json-mapper-object --save
or
yarn add json-mapper-object

Example

import {MapperEntity,JsonProperty} from 'json-mapper-object';

class Student {
    @JsonProperty('name')
    fullName=void 0;

    constructor() {
    }
}

class Address {
    @JsonProperty('first-line')
    firstLine=void 0;
    @JsonProperty('second-line')
    secondLine=void 0;
    @JsonProperty({clazz: Student})
    student=void 0;
    city=void 0;

    constructor() {
    }
}

class Person {
    @JsonProperty('Name')
    name=void 0;

    age=void 0;

    @JsonProperty('xing')
    surname=void 0;

    age=void 0;

    @JsonProperty({clazz: Address, name: 'AddressArr'})
    addressArr=void 0;

    @JsonProperty({clazz: Address, name: 'Address'})
    address=void 0;

    constructor() {
    }
}

现在这里是API服务器返回的数据,假设它已经被解析为JSON对象。

let json = {
  "Name": "Mark",
  "xing": "Galea",
  "age": 30,
  "AddressArr": [
      {
          "first-line": "Some where",
          "second-line": "Over Here",
          "city": "In This City",
          "student": {
              name1: "Ailun"
          }
      },
      {
          "first-line": "Some where",
          "second-line": "Over Here",
          "city": "In This City",
          "student": {
              name1: "Ailun"
          }
      }
  ],
  "Address": {
      "first-line": "Some where",
      "second-line": "Over Here",
      "city": "In This City",
      "student": {
          name: "Ailun"
      }
  }

只需使用以下代码即可映射。 该映射基于@JsonProperty装饰器元数据。

const person = MapperEntity(Person, json);