Files
notification-elements-demo/node_modules/webpack/lib/prefetch/ChunkPrefetchFunctionRuntimeModule.js
Giuliano Silvestro 5d0c9ec7eb Initial commit: notification-elements-demo app
Interactive Angular 19 demo for @sda/notification-elements-ui with
6 sections: Bell & Feed, Notification Center, Inbox, Comments &
Threads, Mention Input, and Full-Featured layout. Includes mock
data, dark mode toggle, and real-time event log.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-13 21:49:19 +10:00

47 lines
1.3 KiB
JavaScript

/*
MIT License http://www.opensource.org/licenses/mit-license.php
*/
"use strict";
const RuntimeModule = require("../RuntimeModule");
const Template = require("../Template");
/** @typedef {import("../Compilation")} Compilation */
/** @typedef {import("../RuntimeTemplate")} RuntimeTemplate */
class ChunkPrefetchFunctionRuntimeModule extends RuntimeModule {
/**
* @param {string} childType TODO
* @param {string} runtimeFunction TODO
* @param {string} runtimeHandlers TODO
*/
constructor(childType, runtimeFunction, runtimeHandlers) {
super(`chunk ${childType} function`);
this.childType = childType;
this.runtimeFunction = runtimeFunction;
this.runtimeHandlers = runtimeHandlers;
}
/**
* @returns {string | null} runtime code
*/
generate() {
const { runtimeFunction, runtimeHandlers } = this;
const compilation = /** @type {Compilation} */ (this.compilation);
const { runtimeTemplate } = compilation;
return Template.asString([
`${runtimeHandlers} = {};`,
`${runtimeFunction} = ${runtimeTemplate.basicFunction("chunkId", [
// map is shorter than forEach
`Object.keys(${runtimeHandlers}).map(${runtimeTemplate.basicFunction(
"key",
`${runtimeHandlers}[key](chunkId);`
)});`
])}`
]);
}
}
module.exports = ChunkPrefetchFunctionRuntimeModule;