JSPM

require-dir-watch

1.0.0
  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 6
  • Score
    100M100P100Q34761F
  • License MIT

Reimport the files from a directory when they are being updated.

Package Exports

  • require-dir-watch
  • require-dir-watch/lib/index.js

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (require-dir-watch) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

require-dir-watch

Support me on Patreon Buy me a book PayPal Ask me anything Version Downloads Get help on Codementor

Buy Me A Coffee

Reimport the files from a directory when they are being updated.

☁️ Installation

# Using npm
npm install --save require-dir-watch

# Using yarn
yarn add require-dir-watch

📋 Example

const path = require("path");
const requireDirWatch = require("require-dir-watch");

// Define the directory to watch
const functionsDir = path.join(__dirname, "functions");

// Load and watch the functions directory
const functions = requireDirWatch(functionsDir, {
    onError: err => console.error("[ERROR]", err),
    onCreate: (name, module) => console.log(`[CREATE] Module '${name}' loaded:`, module),
    onUpdate: (name, module) => console.log(`[UPDATE] Module '${name}' reloaded:`, module),
    onDelete: name => console.log(`[DELETE] Module '${name}' removed.`)
});

// Periodically invoke a function if it exists and log the function map
setInterval(() => {
    if (typeof functions.sum === "function") {
        console.log("sum(35, 7) =", functions.sum(35, 7));
    } else {
        console.log("Function 'sum' is not available.");
    }
    console.log("Current modules:", functions);
}, 1000);

📝 Documentation

requireDirWatch(directoryPath, [options], [options.onError], [options.onCreate], [options.onUpdate], [options.onDelete])

Reimport the files from a directory when they are being updated.

Params

  • String directoryPath: The directory to watch.
  • Object [options]: Configuration options.
  • Function [options.onError]: A callback function to handle errors.
  • Function [options.onCreate]: A callback function when a file is created.
  • Function [options.onUpdate]: A callback function when a file is updated.
  • Function [options.onDelete]: A callback function when a file is deleted.

Return

  • Object An object with file base names as keys and their exports as values.

❓ Get Help

There are few ways to get help:

  1. Please post questions on Stack Overflow. You can open issues with questions, as long you add a link to your Stack Overflow question.
  2. For bug reports and feature requests, open issues. 🐛
  3. For direct and quick help, you can use Codementor. 🚀

😋 How to contribute

Have an idea? Found a bug? See how to contribute.

💖 Support my projects

I open-source almost everything I can, and I try to reply to everyone needing help using these projects. Obviously, this takes time. You can integrate and use these projects in your applications for free! You can even change the source code and redistribute (even resell it).

However, if you get some profit from this or just want to encourage me to continue creating stuff, there are few ways you can do it:

  • Starring and sharing the projects you like 🚀

  • Buy me a book—I love books! I will remember you after years if you buy me one. 😁 📖

  • PayPal—You can make one-time donations via PayPal. I'll probably buy a coffee tea. 🍵

  • Support me on Patreon—Set up a recurring monthly donation and you will get interesting news about what I'm doing (things that I don't share with everyone).

  • Bitcoin—You can send me bitcoins at this address (or scanning the code below): 1P9BRsmazNQcuyTxEqveUsnf5CERdq35V6

Thanks! ❤️

📜 License

MIT © Ionică Bizău