skypager-registry

24.1.0 • Public • Published

Skypager Registry

A Registry is a queryable directory of functions.

Registries can be used for a variety of purposes, such as dependency injection, asynchronous module loading using something like Webpack's require.ensure or System.import functionality, or for building a database of plugins or middlewares that can be dynamically required using different kinds of application logic at runtime.

Installation

npm install skypager-registry --save

Usage Examples

Building a registry of React Components

import registry from 'skypager-registry'
import glob from 'glob'
import { dirname, basename } from 'path'
 
const componentIndexes = (cwd, componentFolder='components') => {
  const filePaths = glob.sync(`${componentFolder}/*/index.js`, { cwd })
 
  return filePaths.map((path) => (
    [basename(dirname(path)), path]
  )
}
 
const components = registry({}, 'components')
 
componentIndexes.forEach([componentId, modulePath] => {
  components.register(componentId, () => {
    const component = require(modulePath)
    return component.default ? component.default : component
  })
})

Other Examples

For people familiar with react-native for example, there is the AppRegistry

import React, { Component } from 'react'
import { AppRegistry, View } from 'react-native'
 
const MyScreen = (props = {}) => (
  <View>Hello World</View>
)
 
AppRegistry.registerComponent('MyScreen', () => MyScreen)

Readme

Keywords

none

Package Sidebar

Install

npm i skypager-registry

Weekly Downloads

8

Version

24.1.0

License

UNLICENSED

Last publish

Collaborators

  • soederpop