Adjust European short trip heuristic from >3 days to >1 day to correctly detect when user has returned home from European trips. This fixes the April 29-30, 2023 case where the location incorrectly showed "Sankt Georg, Hamburg" instead of "Bristol" when the user was free (no events scheduled) after the foss-north trip ended on April 27. The previous logic required more than 3 days to pass before assuming return home from European countries, but for short European trips by rail/ferry, users typically return within 1-2 days. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
88 lines
2.8 KiB
JavaScript
88 lines
2.8 KiB
JavaScript
/*
|
|
MIT License http://www.opensource.org/licenses/mit-license.php
|
|
Author Tobias Koppers @sokra
|
|
*/
|
|
|
|
"use strict";
|
|
|
|
const RuntimeGlobals = require("../RuntimeGlobals");
|
|
const ExportWebpackRequireRuntimeModule = require("./ExportWebpackRequireRuntimeModule");
|
|
const ModuleChunkLoadingRuntimeModule = require("./ModuleChunkLoadingRuntimeModule");
|
|
|
|
/** @typedef {import("../Chunk")} Chunk */
|
|
/** @typedef {import("../Compiler")} Compiler */
|
|
|
|
class ModuleChunkLoadingPlugin {
|
|
/**
|
|
* Apply the plugin
|
|
* @param {Compiler} compiler the compiler instance
|
|
* @returns {void}
|
|
*/
|
|
apply(compiler) {
|
|
compiler.hooks.thisCompilation.tap(
|
|
"ModuleChunkLoadingPlugin",
|
|
compilation => {
|
|
const globalChunkLoading = compilation.outputOptions.chunkLoading;
|
|
/**
|
|
* @param {Chunk} chunk chunk to check
|
|
* @returns {boolean} true, when the plugin is enabled for the chunk
|
|
*/
|
|
const isEnabledForChunk = chunk => {
|
|
const options = chunk.getEntryOptions();
|
|
const chunkLoading =
|
|
options && options.chunkLoading !== undefined
|
|
? options.chunkLoading
|
|
: globalChunkLoading;
|
|
return chunkLoading === "import";
|
|
};
|
|
const onceForChunkSet = new WeakSet();
|
|
/**
|
|
* @param {Chunk} chunk chunk to check
|
|
* @param {Set<string>} set runtime requirements
|
|
*/
|
|
const handler = (chunk, set) => {
|
|
if (onceForChunkSet.has(chunk)) return;
|
|
onceForChunkSet.add(chunk);
|
|
if (!isEnabledForChunk(chunk)) return;
|
|
set.add(RuntimeGlobals.moduleFactoriesAddOnly);
|
|
set.add(RuntimeGlobals.hasOwnProperty);
|
|
compilation.addRuntimeModule(
|
|
chunk,
|
|
new ModuleChunkLoadingRuntimeModule(set)
|
|
);
|
|
};
|
|
compilation.hooks.runtimeRequirementInTree
|
|
.for(RuntimeGlobals.ensureChunkHandlers)
|
|
.tap("ModuleChunkLoadingPlugin", handler);
|
|
compilation.hooks.runtimeRequirementInTree
|
|
.for(RuntimeGlobals.baseURI)
|
|
.tap("ModuleChunkLoadingPlugin", handler);
|
|
compilation.hooks.runtimeRequirementInTree
|
|
.for(RuntimeGlobals.externalInstallChunk)
|
|
.tap("ModuleChunkLoadingPlugin", handler);
|
|
compilation.hooks.runtimeRequirementInTree
|
|
.for(RuntimeGlobals.onChunksLoaded)
|
|
.tap("ModuleChunkLoadingPlugin", handler);
|
|
compilation.hooks.runtimeRequirementInTree
|
|
.for(RuntimeGlobals.externalInstallChunk)
|
|
.tap("ModuleChunkLoadingPlugin", (chunk, set) => {
|
|
if (!isEnabledForChunk(chunk)) return;
|
|
compilation.addRuntimeModule(
|
|
chunk,
|
|
new ExportWebpackRequireRuntimeModule()
|
|
);
|
|
});
|
|
|
|
compilation.hooks.runtimeRequirementInTree
|
|
.for(RuntimeGlobals.ensureChunkHandlers)
|
|
.tap("ModuleChunkLoadingPlugin", (chunk, set) => {
|
|
if (!isEnabledForChunk(chunk)) return;
|
|
set.add(RuntimeGlobals.getChunkScriptFilename);
|
|
});
|
|
}
|
|
);
|
|
}
|
|
}
|
|
|
|
module.exports = ModuleChunkLoadingPlugin;
|