Options
All
  • Public
  • Public/Protected
  • All
Menu

An extension subject defines a way to declare that subjects in the domain should be represented by a certain Javascript class.

Extension subjects can be declared using declare, and are used in one of two modes:

  1. To load a singleton from a graph subject having type http://js.m-ld.org/CommonJSExport. In this case a SingletonExtensionSubject (or a subclass) should be instantiated directly using {@link OrmUpdating#get}, and the singleton object obtained with singleton, e.g. with data:

    {
     "@id": "myCustomSingleton",
     "@type": "http://js.m-ld.org/CommonJSExport",
     "http://js.m-ld.org/#require": "my-custom-module",
     "http://js.m-ld.org/#class": "MyExtClass"
    }
    

    The single custom instance for this class might be loaded with:

    const extType = orm.get('myCustomSingleton',
     src => new SingletonExtensionSubject<MyExtType>({ src, orm });
    const ext: MyExtType = extType.singleton;
    
  2. To load an instance from a graph subject having a type that is itself of type http://js.m-ld.org/CommonJSExport. This indirection allows for many graph subjects to have custom type without re-declaring the module & export. The instance method is provided to load the instance, e.g. with data:

    {
     "@id": "myCustomInstance",
     "@type": {
       "@id": "myCustomClass",
       "@type": "http://js.m-ld.org/CommonJSExport",
       "http://js.m-ld.org/#require": "my-custom-module",
       "http://js.m-ld.org/#class": "MyExtClass"
     }
    }
    

    A custom instance for this class might be loaded with:

    const ext: MyExtType = orm.get('myCustomInstance',
     src => ExtensionSubject.instance<MyExtType>({ src, orm });
    
experimental

Type parameters

Hierarchy

Index

Constructors

Protected constructor

Properties

Static Protected factoryProps

factoryProps: SubjectProperty[] = ['moduleType', 'cjsModule', 'className']

Accessors

Protected factory

  • get factory(): { construct?: undefined | {}; err?: any }
  • Returns { construct?: undefined | {}; err?: any }

    • Optional construct?: undefined | {}
    • Optional err?: any

      ERR_MODULE_NOT_FOUND or any constructor errors

Methods

Protected initialisedInstance

Protected invalidate

  • invalidate(): void
  • Returns void

Protected newInstance

Protected onPropertyUpdated

  • onPropertyUpdated(property: SubjectProperty, result: unknown | Promise<unknown>): void

Static declare

  • declare(id: Iri | undefined, moduleId: string, className: string, properties?: Subject): Subject
  • Extension subject declaration. Insert into the domain data to register a module export to be instantiated by an extension subject.

    For example (assuming a m-ld clone object):

    clone.write(ExtensionSubject.declare(
      'myCustomClass',
      'my-custom-module',
      'MyExtClass'
    ));
    

    Parameters

    • id: Iri | undefined
    • moduleId: string

      the CommonJS module (must be accessible using require)

    • className: string

      the constructor name exported by the module

    • Optional properties: Subject

      additional properties

    Returns Subject

Static instance

  • Obtain an instance of a custom class declared in the data as the type of the given graph subject.

    throws

    TypeError if the given graph subject does not have an extension type

    Type parameters

    • T

    Parameters

    Returns Promise<T>

Legend

  • Constructor
  • Property
  • Method
  • Property
  • Method
  • Inherited property
  • Inherited method
  • Static property
  • Static method
  • Protected method

Generated using TypeDoc. Delivered by Vercel. @m-ld/m-ld - v0.10.0-edge.2 Source code licensed MIT. Privacy policy