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

typeorm-pg-adjacency-list-tree

v2.0.0

Published

A library that allows to use an adjacency list tree with typeorm and postgres

Downloads

349

Readme

typeorm-pg-adjacency-list-tree

tests npm version

This library helps to manage trees that are structured as as adjacency list in postgres.

It partially implements public interface of TreeRepository from typeorm. Check tree-repository.interface.ts

Current version of the library is compatible with typeorm >= 0.3.0. If you use typeorm < 0.3.0, please use typeorm-pg-adjacency-list-tree < 2.0.0.

Installation

npm i typeorm-pg-adjacency-list-tree

Quick start

Decorators

There are three decorators exported from this module: Tree, TreeParent and TreeChildren.

Tree is used to specify that decoratable entity is a tree.

@Tree()
@Entity()
export class Node {
  @PrimaryGeneratedColumn()
  public id!: number

  @Column()
  public value!: number
}

TreeParent is used to identify class property which will hold entities parent:

@Tree()
@Entity()
export class Node {
  @PrimaryGeneratedColumn()
  public id!: number

  @TreeParent()
  public parent!: Node

  @Column()
  public value!: number
}

TreeChildren is used to identify class property which will hold children of current entity:

@Tree()
@Entity()
export class Node {
  @PrimaryGeneratedColumn()
  public id!: number

  @TreeParent()
  public parent!: Node

  @TreeChildren()
  public children!: Node[]

  @Column()
  public value!: number
}

Tree repository

In the latest major version of typeorm, they decided to drop support for creating custom repositories with classes. And now the only way to create a custom repository is to call dataSource.getRepository(Entity).extend({ /* your custom repo here */ }).

To simplify the process of getting the tree repo, there's a helper function extendTreeRepository.

If you have any suggestions on how to implement this in a better way, please create an issue or send a pr.

Instantiating a tree repo from connection:

import { extendTreeRepository } from 'typeorm-pg-adjacency-list-tree'

const nodeRepo = extendTreeRepository(dataSource.getRepository(Node))
const roots = await nodeRepo.findRoots()

After 0.3, extending a tree repo is not as simple as just extending a class.

We have to get our tree repository first.

import { extendTreeRepository } from 'typeorm-pg-adjacency-list-tree'

const userRepo = extendTreeRepository(dataSource.getRepository(User)).extend({
  async getByName(name: string) {
    return this.find({ where: { name } })
  },
})

Tree repository methods

findTrees(options?: FindTreeOptions): Promise<Entity[]>

Gets complete trees for all roots in the table.

findRoots(options?: FindTreeOptions): Promise<Entity[]>

Roots are entities that have no ancestors. Finds them all.

findDescendants(entity: Entity, options?: FindTreeOptions): Promise<Entity[]>

Gets all children (descendants) of the given entity. Returns them all in a flat array.

findDescendantsTree(entity: Entity, options?: FindTreeOptions): Promise<Entity>

Gets all children (descendants) of the given entity. Returns them in a tree - nested into each other.

countDescendants(entity: Entity): Promise<number>

Gets number of descendants of the entity.

createDescendantsQueryBuilder(alias: string, entity: Entity): Promise<SelectQueryBuilder<Entity>>

Creates a query builder used to get descendants of the entities in a tree.

findAncestors(entity: Entity, options?: FindTreeOptions): Promise<Entity[]>

Creates a query builder used to get descendants of the entities in a tree.

findAncestorsTree(entity: Entity, options?: FindTreeOptions): Promise<Entity>

Gets all parents (ancestors) of the given entity. Returns them in a tree - nested into each other.

countAncestors(entity: Entity): Promise<number>

Gets number of ancestors of the entity.

createAncestorsQueryBuilder(alias: string, entity: Entity): Promise<SelectQueryBuilder<Entity>>

Creates a query builder used to get ancestors of the entities in the tree.