Marketplace móvil para negocios locales mexicanos. Estructura inicial: - apps/backend (NestJS API) - apps/frontend (React Web) - apps/mobile (Expo/React Native) - apps/mcp-server (Claude MCP Server) - apps/whatsapp-service (WhatsApp Business API) - database/ (PostgreSQL DDL) - docs/ (Documentación) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
50 lines
1.3 KiB
JavaScript
50 lines
1.3 KiB
JavaScript
/*
|
|
MIT License http://www.opensource.org/licenses/mit-license.php
|
|
Author Tobias Koppers @sokra
|
|
*/
|
|
|
|
"use strict";
|
|
|
|
const { URL, fileURLToPath } = require("url");
|
|
const { NormalModule } = require("..");
|
|
|
|
/** @typedef {import("../Compiler")} Compiler */
|
|
|
|
class FileUriPlugin {
|
|
/**
|
|
* Apply the plugin
|
|
* @param {Compiler} compiler the compiler instance
|
|
* @returns {void}
|
|
*/
|
|
apply(compiler) {
|
|
compiler.hooks.compilation.tap(
|
|
"FileUriPlugin",
|
|
(compilation, { normalModuleFactory }) => {
|
|
normalModuleFactory.hooks.resolveForScheme
|
|
.for("file")
|
|
.tap("FileUriPlugin", resourceData => {
|
|
const url = new URL(resourceData.resource);
|
|
const path = fileURLToPath(url);
|
|
const query = url.search;
|
|
const fragment = url.hash;
|
|
resourceData.path = path;
|
|
resourceData.query = query;
|
|
resourceData.fragment = fragment;
|
|
resourceData.resource = path + query + fragment;
|
|
return true;
|
|
});
|
|
const hooks = NormalModule.getCompilationHooks(compilation);
|
|
hooks.readResource
|
|
.for(undefined)
|
|
.tapAsync("FileUriPlugin", (loaderContext, callback) => {
|
|
const { resourcePath } = loaderContext;
|
|
loaderContext.addDependency(resourcePath);
|
|
loaderContext.fs.readFile(resourcePath, callback);
|
|
});
|
|
}
|
|
);
|
|
}
|
|
}
|
|
|
|
module.exports = FileUriPlugin;
|