nav tabs on admin dashboard
This commit is contained in:
53
node_modules/webpack/lib/DependenciesBlockVariable.js
generated
vendored
53
node_modules/webpack/lib/DependenciesBlockVariable.js
generated
vendored
@@ -4,47 +4,68 @@
|
||||
*/
|
||||
"use strict";
|
||||
|
||||
const ReplaceSource = require("webpack-sources").ReplaceSource;
|
||||
const RawSource = require("webpack-sources").RawSource;
|
||||
const { RawSource, ReplaceSource } = require("webpack-sources");
|
||||
|
||||
/** @typedef {import("./Dependency")} Dependency */
|
||||
/** @typedef {import("./Dependency").DependencyTemplate} DependencyTemplate */
|
||||
/** @typedef {import("./RuntimeTemplate")} RuntimeTemplate */
|
||||
/** @typedef {import("./util/createHash").Hash} Hash */
|
||||
/** @typedef {(d: Dependency) => boolean} DependencyFilterFunction */
|
||||
/** @typedef {Map<Function, DependencyTemplate>} DependencyTemplates */
|
||||
|
||||
class DependenciesBlockVariable {
|
||||
/**
|
||||
* Creates an instance of DependenciesBlockVariable.
|
||||
* @param {string} name name of DependenciesBlockVariable
|
||||
* @param {string} expression expression string
|
||||
* @param {Dependency[]=} dependencies dependencies tied to this varaiable
|
||||
*/
|
||||
constructor(name, expression, dependencies) {
|
||||
this.name = name;
|
||||
this.expression = expression;
|
||||
this.dependencies = dependencies || [];
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {Hash} hash hash for instance to update
|
||||
* @returns {void}
|
||||
*/
|
||||
updateHash(hash) {
|
||||
hash.update(this.name);
|
||||
hash.update(this.expression);
|
||||
this.dependencies.forEach(d => {
|
||||
for (const d of this.dependencies) {
|
||||
d.updateHash(hash);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
expressionSource(dependencyTemplates, outputOptions, requestShortener) {
|
||||
/**
|
||||
* @param {DependencyTemplates} dependencyTemplates Dependency constructors and templates Map.
|
||||
* @param {RuntimeTemplate} runtimeTemplate runtimeTemplate to generate expression souce
|
||||
* @returns {ReplaceSource} returns constructed source for expression via templates
|
||||
*/
|
||||
expressionSource(dependencyTemplates, runtimeTemplate) {
|
||||
const source = new ReplaceSource(new RawSource(this.expression));
|
||||
this.dependencies.forEach(dep => {
|
||||
for (const dep of this.dependencies) {
|
||||
const template = dependencyTemplates.get(dep.constructor);
|
||||
if(!template) throw new Error(`No template for dependency: ${dep.constructor.name}`);
|
||||
template.apply(dep, source, outputOptions, requestShortener, dependencyTemplates);
|
||||
});
|
||||
if (!template) {
|
||||
throw new Error(`No template for dependency: ${dep.constructor.name}`);
|
||||
}
|
||||
template.apply(dep, source, runtimeTemplate, dependencyTemplates);
|
||||
}
|
||||
return source;
|
||||
}
|
||||
|
||||
disconnect() {
|
||||
this.dependencies.forEach(d => {
|
||||
for (const d of this.dependencies) {
|
||||
d.disconnect();
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
hasDependencies(filter) {
|
||||
if(filter) {
|
||||
if(this.dependencies.some(filter)) return true;
|
||||
} else {
|
||||
if(this.dependencies.length > 0) return true;
|
||||
if (filter) {
|
||||
return this.dependencies.some(filter);
|
||||
}
|
||||
return false;
|
||||
return this.dependencies.length > 0;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user