feat(planning): grille hebdomadaire complète avec API et filtres
- Connexion API via proxy Angular (résolution CORS, base path /api) - Import CSS ng-zorro global pour les modales et composants - Filtres Camion/Show câblés sur l'affichage de la grille - Camions affichés via TrucksService (linkés au show du même créneau) - Panneau de détails : spectacles + camions du jour sélectionné - Modale de création de spectacle stylisée avec fond et centrage - Positionnement précis des events à la minute dans leur créneau - Auto-scroll vers l'heure courante au chargement - Ligne "maintenant" sur la colonne du jour actuel - Régénération des services OpenAPI (nouveaux noms de types) Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
+8
-32
@@ -1,43 +1,19 @@
|
||||
import { createRequire } from 'module';
|
||||
|
||||
const require = createRequire(import.meta.url);
|
||||
|
||||
class SourceMapGeneratorFallback {
|
||||
addMapping(){}
|
||||
setSourceContent(){}
|
||||
toJSON(){
|
||||
return null;
|
||||
}
|
||||
};
|
||||
|
||||
export default {
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.default = {
|
||||
encodeBase64: function encodeBase64(str) {
|
||||
// Avoid Buffer constructor on newer versions of Node.js.
|
||||
const buffer = (Buffer.from ? Buffer.from(str) : (new Buffer(str)));
|
||||
var buffer = (Buffer.from ? Buffer.from(str) : (new Buffer(str)));
|
||||
return buffer.toString('base64');
|
||||
},
|
||||
mimeLookup: function (filename) {
|
||||
try {
|
||||
const mimeModule = require('mime');
|
||||
return mimeModule ? mimeModule.lookup(filename) : "application/octet-stream";
|
||||
} catch (e) {
|
||||
return "application/octet-stream";
|
||||
}
|
||||
return require('mime').lookup(filename);
|
||||
},
|
||||
charsetLookup: function (mime) {
|
||||
try {
|
||||
const mimeModule = require('mime');
|
||||
return mimeModule ? mimeModule.charsets.lookup(mime) : undefined;
|
||||
} catch (e) {
|
||||
return undefined;
|
||||
}
|
||||
return require('mime').charsets.lookup(mime);
|
||||
},
|
||||
getSourceMapGenerator: function getSourceMapGenerator() {
|
||||
try {
|
||||
const sourceMapModule = require('source-map');
|
||||
return sourceMapModule ? sourceMapModule.SourceMapGenerator : SourceMapGeneratorFallback;
|
||||
} catch (e) {
|
||||
return SourceMapGeneratorFallback;
|
||||
}
|
||||
return require('source-map').SourceMapGenerator;
|
||||
}
|
||||
};
|
||||
//# sourceMappingURL=environment.js.map
|
||||
+45
-62
@@ -1,42 +1,37 @@
|
||||
import path from 'path';
|
||||
import { createRequire } from 'module';
|
||||
import fs from './fs.js';
|
||||
import AbstractFileManager from '../less/environment/abstract-file-manager.js';
|
||||
|
||||
const require = createRequire(import.meta.url);
|
||||
|
||||
const FileManager = function() {}
|
||||
FileManager.prototype = Object.assign(new AbstractFileManager(), {
|
||||
supports() {
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
var tslib_1 = require("tslib");
|
||||
var path_1 = tslib_1.__importDefault(require("path"));
|
||||
var fs_1 = tslib_1.__importDefault(require("./fs"));
|
||||
var abstract_file_manager_js_1 = tslib_1.__importDefault(require("../less/environment/abstract-file-manager.js"));
|
||||
var FileManager = function () { };
|
||||
FileManager.prototype = Object.assign(new abstract_file_manager_js_1.default(), {
|
||||
supports: function () {
|
||||
return true;
|
||||
},
|
||||
|
||||
supportsSync() {
|
||||
supportsSync: function () {
|
||||
return true;
|
||||
},
|
||||
|
||||
loadFile(filename, currentDirectory, options, environment, callback) {
|
||||
let fullFilename;
|
||||
const isAbsoluteFilename = this.isPathAbsolute(filename);
|
||||
const filenamesTried = [];
|
||||
const self = this;
|
||||
const prefix = filename.slice(0, 1);
|
||||
const explicit = prefix === '.' || prefix === '/';
|
||||
let result = null;
|
||||
let isNodeModule = false;
|
||||
const npmPrefix = 'npm://';
|
||||
|
||||
loadFile: function (filename, currentDirectory, options, environment, callback) {
|
||||
var fullFilename;
|
||||
var isAbsoluteFilename = this.isPathAbsolute(filename);
|
||||
var filenamesTried = [];
|
||||
var self = this;
|
||||
var prefix = filename.slice(0, 1);
|
||||
var explicit = prefix === '.' || prefix === '/';
|
||||
var result = null;
|
||||
var isNodeModule = false;
|
||||
var npmPrefix = 'npm://';
|
||||
options = options || {};
|
||||
|
||||
const paths = isAbsoluteFilename ? [''] : [currentDirectory];
|
||||
|
||||
if (options.paths) { paths.push.apply(paths, options.paths); }
|
||||
|
||||
if (!isAbsoluteFilename && paths.indexOf('.') === -1) { paths.push('.'); }
|
||||
|
||||
const prefixes = options.prefixes || [''];
|
||||
const fileParts = this.extractUrlParts(filename);
|
||||
|
||||
var paths = isAbsoluteFilename ? [''] : [currentDirectory];
|
||||
if (options.paths) {
|
||||
paths.push.apply(paths, options.paths);
|
||||
}
|
||||
if (!isAbsoluteFilename && paths.indexOf('.') === -1) {
|
||||
paths.push('.');
|
||||
}
|
||||
var prefixes = options.prefixes || [''];
|
||||
var fileParts = this.extractUrlParts(filename);
|
||||
if (options.syncImport) {
|
||||
getFileData(returnData, returnData);
|
||||
if (callback) {
|
||||
@@ -52,7 +47,6 @@ FileManager.prototype = Object.assign(new AbstractFileManager(), {
|
||||
// to be closed before it continues with the next file
|
||||
return new Promise(getFileData);
|
||||
}
|
||||
|
||||
function returnData(data) {
|
||||
if (!data.filename) {
|
||||
result = { error: data };
|
||||
@@ -61,12 +55,10 @@ FileManager.prototype = Object.assign(new AbstractFileManager(), {
|
||||
result = data;
|
||||
}
|
||||
}
|
||||
|
||||
function getFileData(fulfill, reject) {
|
||||
(function tryPathIndex(i) {
|
||||
function tryWithExtension() {
|
||||
const extFilename = options.ext ? self.tryAppendExtension(fullFilename, options.ext) : fullFilename;
|
||||
|
||||
var extFilename = options.ext ? self.tryAppendExtension(fullFilename, options.ext) : fullFilename;
|
||||
if (extFilename !== fullFilename && !explicit && paths[i] === '.') {
|
||||
try {
|
||||
fullFilename = require.resolve(extFilename);
|
||||
@@ -86,16 +78,9 @@ FileManager.prototype = Object.assign(new AbstractFileManager(), {
|
||||
if (j < prefixes.length) {
|
||||
isNodeModule = false;
|
||||
fullFilename = fileParts.rawPath + prefixes[j] + fileParts.filename;
|
||||
|
||||
if (paths[i]) {
|
||||
if (paths[i].startsWith('#')) {
|
||||
// Handling paths starting with '#'
|
||||
fullFilename = paths[i].substr(1) + fullFilename;
|
||||
}else{
|
||||
fullFilename = path.join(paths[i], fullFilename);
|
||||
}
|
||||
fullFilename = path_1.default.join(paths[i], fullFilename);
|
||||
}
|
||||
|
||||
if (!explicit && paths[i] === '.') {
|
||||
try {
|
||||
fullFilename = require.resolve(fullFilename);
|
||||
@@ -108,16 +93,15 @@ FileManager.prototype = Object.assign(new AbstractFileManager(), {
|
||||
}
|
||||
else {
|
||||
tryWithExtension();
|
||||
}
|
||||
|
||||
const readFileArgs = [fullFilename];
|
||||
}
|
||||
var readFileArgs = [fullFilename];
|
||||
if (!options.rawBuffer) {
|
||||
readFileArgs.push('utf-8');
|
||||
}
|
||||
if (options.syncImport) {
|
||||
try {
|
||||
const data = fs.readFileSync.apply(this, readFileArgs);
|
||||
fulfill({ contents: data, filename: fullFilename});
|
||||
var data = fs_1.default.readFileSync.apply(this, readFileArgs);
|
||||
fulfill({ contents: data, filename: fullFilename });
|
||||
}
|
||||
catch (e) {
|
||||
filenamesTried.push(isNodeModule ? npmPrefix + fullFilename : fullFilename);
|
||||
@@ -125,32 +109,31 @@ FileManager.prototype = Object.assign(new AbstractFileManager(), {
|
||||
}
|
||||
}
|
||||
else {
|
||||
readFileArgs.push(function(e, data) {
|
||||
readFileArgs.push(function (e, data) {
|
||||
if (e) {
|
||||
filenamesTried.push(isNodeModule ? npmPrefix + fullFilename : fullFilename);
|
||||
return tryPrefix(j + 1);
|
||||
}
|
||||
fulfill({ contents: data, filename: fullFilename});
|
||||
}
|
||||
fulfill({ contents: data, filename: fullFilename });
|
||||
});
|
||||
fs.readFile.apply(this, readFileArgs);
|
||||
fs_1.default.readFile.apply(this, readFileArgs);
|
||||
}
|
||||
|
||||
}
|
||||
else {
|
||||
tryPathIndex(i + 1);
|
||||
}
|
||||
})(0);
|
||||
} else {
|
||||
reject({ type: 'File', message: `'${filename}' wasn't found. Tried - ${filenamesTried.join(',')}` });
|
||||
}
|
||||
else {
|
||||
reject({ type: 'File', message: "'".concat(filename, "' wasn't found. Tried - ").concat(filenamesTried.join(',')) });
|
||||
}
|
||||
}(0));
|
||||
}
|
||||
},
|
||||
|
||||
loadFileSync(filename, currentDirectory, options, environment) {
|
||||
loadFileSync: function (filename, currentDirectory, options, environment) {
|
||||
options.syncImport = true;
|
||||
return this.loadFile(filename, currentDirectory, options, environment);
|
||||
}
|
||||
});
|
||||
|
||||
export default FileManager;
|
||||
exports.default = FileManager;
|
||||
//# sourceMappingURL=file-manager.js.map
|
||||
+8
-11
@@ -1,14 +1,11 @@
|
||||
/** @typedef {import('fs')} FS */
|
||||
import nodeFs from 'fs';
|
||||
import { createRequire } from 'module';
|
||||
|
||||
const require = createRequire(import.meta.url);
|
||||
|
||||
/** @type {FS} */
|
||||
let fs;
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
var fs;
|
||||
try {
|
||||
fs = require('graceful-fs');
|
||||
} catch (e) {
|
||||
fs = nodeFs;
|
||||
}
|
||||
export default fs;
|
||||
catch (e) {
|
||||
fs = require('fs');
|
||||
}
|
||||
exports.default = fs;
|
||||
//# sourceMappingURL=fs.js.map
|
||||
+31
-40
@@ -1,59 +1,50 @@
|
||||
import { createRequire } from 'module';
|
||||
import Dimension from '../less/tree/dimension.js';
|
||||
import Expression from '../less/tree/expression.js';
|
||||
import functionRegistry from './../less/functions/function-registry.js';
|
||||
|
||||
const require = createRequire(import.meta.url);
|
||||
|
||||
export default environment => {
|
||||
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
var tslib_1 = require("tslib");
|
||||
var dimension_1 = tslib_1.__importDefault(require("../less/tree/dimension"));
|
||||
var expression_1 = tslib_1.__importDefault(require("../less/tree/expression"));
|
||||
var function_registry_1 = tslib_1.__importDefault(require("./../less/functions/function-registry"));
|
||||
exports.default = (function (environment) {
|
||||
function imageSize(functionContext, filePathNode) {
|
||||
let filePath = filePathNode.value;
|
||||
const currentFileInfo = functionContext.currentFileInfo;
|
||||
const currentDirectory = currentFileInfo.rewriteUrls ?
|
||||
var filePath = filePathNode.value;
|
||||
var currentFileInfo = functionContext.currentFileInfo;
|
||||
var currentDirectory = currentFileInfo.rewriteUrls ?
|
||||
currentFileInfo.currentDirectory : currentFileInfo.entryPath;
|
||||
|
||||
const fragmentStart = filePath.indexOf('#');
|
||||
var fragmentStart = filePath.indexOf('#');
|
||||
if (fragmentStart !== -1) {
|
||||
filePath = filePath.slice(0, fragmentStart);
|
||||
}
|
||||
|
||||
const fileManager = environment.getFileManager(filePath, currentDirectory, functionContext.context, environment, true);
|
||||
|
||||
var fileManager = environment.getFileManager(filePath, currentDirectory, functionContext.context, environment, true);
|
||||
if (!fileManager) {
|
||||
throw {
|
||||
type: 'File',
|
||||
message: `Can not set up FileManager for ${filePathNode}`
|
||||
message: "Can not set up FileManager for ".concat(filePathNode)
|
||||
};
|
||||
}
|
||||
|
||||
const fileSync = fileManager.loadFileSync(filePath, currentDirectory, functionContext.context, environment);
|
||||
|
||||
var fileSync = fileManager.loadFileSync(filePath, currentDirectory, functionContext.context, environment);
|
||||
if (fileSync.error) {
|
||||
throw fileSync.error;
|
||||
}
|
||||
|
||||
const sizeOf = require('image-size');
|
||||
return sizeOf ? sizeOf(fileSync.filename) : {width: 0, height: 0};
|
||||
var sizeOf = require('image-size');
|
||||
return sizeOf(fileSync.filename);
|
||||
}
|
||||
|
||||
const imageFunctions = {
|
||||
'image-size': function(filePathNode) {
|
||||
const size = imageSize(this, filePathNode);
|
||||
return new Expression([
|
||||
new Dimension(size.width, 'px'),
|
||||
new Dimension(size.height, 'px')
|
||||
var imageFunctions = {
|
||||
'image-size': function (filePathNode) {
|
||||
var size = imageSize(this, filePathNode);
|
||||
return new expression_1.default([
|
||||
new dimension_1.default(size.width, 'px'),
|
||||
new dimension_1.default(size.height, 'px')
|
||||
]);
|
||||
},
|
||||
'image-width': function(filePathNode) {
|
||||
const size = imageSize(this, filePathNode);
|
||||
return new Dimension(size.width, 'px');
|
||||
'image-width': function (filePathNode) {
|
||||
var size = imageSize(this, filePathNode);
|
||||
return new dimension_1.default(size.width, 'px');
|
||||
},
|
||||
'image-height': function(filePathNode) {
|
||||
const size = imageSize(this, filePathNode);
|
||||
return new Dimension(size.height, 'px');
|
||||
'image-height': function (filePathNode) {
|
||||
var size = imageSize(this, filePathNode);
|
||||
return new dimension_1.default(size.height, 'px');
|
||||
}
|
||||
};
|
||||
|
||||
functionRegistry.addMultiple(imageFunctions);
|
||||
};
|
||||
function_registry_1.default.addMultiple(imageFunctions);
|
||||
});
|
||||
//# sourceMappingURL=image-size.js.map
|
||||
+19
-28
@@ -1,31 +1,22 @@
|
||||
import { createRequire } from 'module';
|
||||
import environment from './environment.js';
|
||||
import FileManager from './file-manager.js';
|
||||
import UrlFileManager from './url-file-manager.js';
|
||||
import createFromEnvironment from '../less/index.js';
|
||||
import lesscHelper from './lessc-helper.js';
|
||||
import PluginLoader from './plugin-loader.js';
|
||||
import fs from './fs.js';
|
||||
import defaultOptions from '../less/default-options.js';
|
||||
import imageSize from './image-size.js';
|
||||
|
||||
const require = createRequire(import.meta.url);
|
||||
const { version } = require('../../package.json');
|
||||
|
||||
const less = createFromEnvironment(environment, [new FileManager(), new UrlFileManager()], version);
|
||||
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
var tslib_1 = require("tslib");
|
||||
var environment_1 = tslib_1.__importDefault(require("./environment"));
|
||||
var file_manager_1 = tslib_1.__importDefault(require("./file-manager"));
|
||||
var url_file_manager_1 = tslib_1.__importDefault(require("./url-file-manager"));
|
||||
var less_1 = tslib_1.__importDefault(require("../less"));
|
||||
var less = (0, less_1.default)(environment_1.default, [new file_manager_1.default(), new url_file_manager_1.default()]);
|
||||
var lessc_helper_1 = tslib_1.__importDefault(require("./lessc-helper"));
|
||||
// allow people to create less with their own environment
|
||||
less.createFromEnvironment = createFromEnvironment;
|
||||
less.lesscHelper = lesscHelper;
|
||||
less.PluginLoader = PluginLoader;
|
||||
less.fs = fs;
|
||||
less.FileManager = FileManager;
|
||||
less.UrlFileManager = UrlFileManager;
|
||||
|
||||
less.createFromEnvironment = less_1.default;
|
||||
less.lesscHelper = lessc_helper_1.default;
|
||||
less.PluginLoader = require('./plugin-loader').default;
|
||||
less.fs = require('./fs').default;
|
||||
less.FileManager = file_manager_1.default;
|
||||
less.UrlFileManager = url_file_manager_1.default;
|
||||
// Set up options
|
||||
less.options = defaultOptions();
|
||||
|
||||
less.options = require('../less/default-options').default();
|
||||
// provide image-size functionality
|
||||
imageSize(less.environment);
|
||||
|
||||
export default less;
|
||||
require('./image-size').default(less.environment);
|
||||
exports.default = less;
|
||||
//# sourceMappingURL=index.js.map
|
||||
+28
-28
@@ -1,25 +1,23 @@
|
||||
// lessc_helper.js
|
||||
//
|
||||
// helper functions for lessc
|
||||
const lessc_helper = {
|
||||
|
||||
var lessc_helper = {
|
||||
// Stylize a string
|
||||
stylize : function(str, style) {
|
||||
const styles = {
|
||||
'reset' : [0, 0],
|
||||
'bold' : [1, 22],
|
||||
'inverse' : [7, 27],
|
||||
'underline' : [4, 24],
|
||||
'yellow' : [33, 39],
|
||||
'green' : [32, 39],
|
||||
'red' : [31, 39],
|
||||
'grey' : [90, 39]
|
||||
stylize: function (str, style) {
|
||||
var styles = {
|
||||
'reset': [0, 0],
|
||||
'bold': [1, 22],
|
||||
'inverse': [7, 27],
|
||||
'underline': [4, 24],
|
||||
'yellow': [33, 39],
|
||||
'green': [32, 39],
|
||||
'red': [31, 39],
|
||||
'grey': [90, 39]
|
||||
};
|
||||
return `\x1b[${styles[style][0]}m${str}\x1b[${styles[style][1]}m`;
|
||||
return "\u001B[".concat(styles[style][0], "m").concat(str, "\u001B[").concat(styles[style][1], "m");
|
||||
},
|
||||
|
||||
// Print command line options
|
||||
printUsage: function() {
|
||||
printUsage: function () {
|
||||
console.log('usage: lessc [option option=parameter ...] <source> [destination]');
|
||||
console.log('');
|
||||
console.log('If source is set to `-\' (dash or hyphen-minus), input is read from stdin.');
|
||||
@@ -34,7 +32,7 @@ const lessc_helper = {
|
||||
console.log(' -l, --lint Syntax check only (lint).');
|
||||
console.log(' -s, --silent Suppresses output of error messages.');
|
||||
console.log(' --quiet Suppresses output of warnings.');
|
||||
console.log(' --strict-imports (DEPRECATED) Ignores .less imports inside selector blocks. Has confusing behavior.');
|
||||
console.log(' --strict-imports Forces evaluation of imports.');
|
||||
console.log(' --insecure Allows imports from insecure https hosts.');
|
||||
console.log(' -v, --version Prints version number and exit.');
|
||||
console.log(' --verbose Be verbose.');
|
||||
@@ -70,19 +68,16 @@ const lessc_helper = {
|
||||
console.log(' or --clean-css="advanced"');
|
||||
console.log(' --disable-plugin-rule Disallow @plugin statements');
|
||||
console.log('');
|
||||
console.log(' --quiet-deprecations Suppress deprecation warnings only (keeps other warnings).');
|
||||
console.log('');
|
||||
console.log('-------------------------- Deprecated ----------------');
|
||||
console.log(' -sm=on|off Legacy parens-only math. Use --math');
|
||||
console.log(' --strict-math=on|off ');
|
||||
console.log('');
|
||||
console.log(' --line-numbers=TYPE (DEPRECATED) Outputs filename and line numbers.');
|
||||
console.log(' TYPE can be either \'comments\', \'mediaquery\', or \'all\'.');
|
||||
console.log(' The entire dumpLineNumbers option is deprecated.');
|
||||
console.log(' Use sourcemaps (--source-map) instead.');
|
||||
console.log(' All modes will be removed in a future version.');
|
||||
console.log(' Note: \'mediaquery\' and \'all\' modes generate @media -sass-debug-info');
|
||||
console.log(' which had short-lived usage and is no longer recommended.');
|
||||
console.log(' --line-numbers=TYPE Outputs filename and line numbers.');
|
||||
console.log(' TYPE can be either \'comments\', which will output');
|
||||
console.log(' the debug info within comments, \'mediaquery\'');
|
||||
console.log(' that will output the information within a fake');
|
||||
console.log(' media query which is compatible with the SASS');
|
||||
console.log(' format, and \'all\' which will do both.');
|
||||
console.log(' -x, --compress Compresses output by removing some whitespaces.');
|
||||
console.log(' We recommend you use a dedicated minifer like less-plugin-clean-css');
|
||||
console.log('');
|
||||
@@ -90,6 +85,11 @@ const lessc_helper = {
|
||||
console.log('Home page: <http://lesscss.org/>');
|
||||
}
|
||||
};
|
||||
|
||||
export const { stylize, printUsage } = lessc_helper;
|
||||
export default lessc_helper;
|
||||
// Exports helper functions
|
||||
// eslint-disable-next-line no-prototype-builtins
|
||||
for (var h in lessc_helper) {
|
||||
if (lessc_helper.hasOwnProperty(h)) {
|
||||
exports[h] = lessc_helper[h];
|
||||
}
|
||||
}
|
||||
//# sourceMappingURL=lessc-helper.js.map
|
||||
+27
-35
@@ -1,20 +1,19 @@
|
||||
import path from 'path';
|
||||
import { createRequire } from 'module';
|
||||
import AbstractPluginLoader from '../less/environment/abstract-plugin-loader.js';
|
||||
|
||||
const require = createRequire(import.meta.url);
|
||||
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
var tslib_1 = require("tslib");
|
||||
var path_1 = tslib_1.__importDefault(require("path"));
|
||||
var abstract_plugin_loader_js_1 = tslib_1.__importDefault(require("../less/environment/abstract-plugin-loader.js"));
|
||||
/**
|
||||
* Node Plugin Loader
|
||||
*/
|
||||
const PluginLoader = function(less) {
|
||||
var PluginLoader = function (less) {
|
||||
this.less = less;
|
||||
this.require = prefix => {
|
||||
prefix = path.dirname(prefix);
|
||||
return id => {
|
||||
const str = id.slice(0, 2);
|
||||
this.require = function (prefix) {
|
||||
prefix = path_1.default.dirname(prefix);
|
||||
return function (id) {
|
||||
var str = id.substr(0, 2);
|
||||
if (str === '..' || str === './') {
|
||||
return require(path.join(prefix, id));
|
||||
return require(path_1.default.join(prefix, id));
|
||||
}
|
||||
else {
|
||||
return require(id);
|
||||
@@ -22,41 +21,34 @@ const PluginLoader = function(less) {
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
PluginLoader.prototype = Object.assign(new AbstractPluginLoader(), {
|
||||
loadPlugin(filename, basePath, context, environment, fileManager) {
|
||||
const prefix = filename.slice(0, 1);
|
||||
const explicit = prefix === '.' || prefix === '/' || filename.slice(-3).toLowerCase() === '.js';
|
||||
PluginLoader.prototype = Object.assign(new abstract_plugin_loader_js_1.default(), {
|
||||
loadPlugin: function (filename, basePath, context, environment, fileManager) {
|
||||
var prefix = filename.slice(0, 1);
|
||||
var explicit = prefix === '.' || prefix === '/' || filename.slice(-3).toLowerCase() === '.js';
|
||||
if (!explicit) {
|
||||
context.prefixes = ['less-plugin-', ''];
|
||||
}
|
||||
|
||||
if (context.syncImport) {
|
||||
return fileManager.loadFileSync(filename, basePath, context, environment);
|
||||
}
|
||||
|
||||
return new Promise((fulfill, reject) => {
|
||||
fileManager.loadFile(filename, basePath, context, environment).then(
|
||||
data => {
|
||||
try {
|
||||
fulfill(data);
|
||||
}
|
||||
catch (e) {
|
||||
console.log(e);
|
||||
reject(e);
|
||||
}
|
||||
return new Promise(function (fulfill, reject) {
|
||||
fileManager.loadFile(filename, basePath, context, environment).then(function (data) {
|
||||
try {
|
||||
fulfill(data);
|
||||
}
|
||||
).catch(err => {
|
||||
catch (e) {
|
||||
console.log(e);
|
||||
reject(e);
|
||||
}
|
||||
}).catch(function (err) {
|
||||
reject(err);
|
||||
});
|
||||
});
|
||||
},
|
||||
|
||||
loadPluginSync(filename, basePath, context, environment, fileManager) {
|
||||
loadPluginSync: function (filename, basePath, context, environment, fileManager) {
|
||||
context.syncImport = true;
|
||||
return this.loadPlugin(filename, basePath, context, environment, fileManager);
|
||||
}
|
||||
});
|
||||
|
||||
export default PluginLoader;
|
||||
|
||||
exports.default = PluginLoader;
|
||||
//# sourceMappingURL=plugin-loader.js.map
|
||||
+31
-33
@@ -1,60 +1,58 @@
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
var tslib_1 = require("tslib");
|
||||
/* eslint-disable no-unused-vars */
|
||||
/**
|
||||
* @todo - remove top eslint rule when FileManagers have JSDoc type
|
||||
* and are TS-type-checked
|
||||
*/
|
||||
import { createRequire } from 'module';
|
||||
|
||||
const require = createRequire(import.meta.url);
|
||||
|
||||
const isUrlRe = /^(?:https?:)?\/\//i;
|
||||
import url from 'url';
|
||||
let request;
|
||||
import AbstractFileManager from '../less/environment/abstract-file-manager.js';
|
||||
import logger from '../less/logger.js';
|
||||
|
||||
const UrlFileManager = function() {}
|
||||
UrlFileManager.prototype = Object.assign(new AbstractFileManager(), {
|
||||
supports(filename, currentDirectory, options, environment) {
|
||||
return isUrlRe.test( filename ) || isUrlRe.test(currentDirectory);
|
||||
var isUrlRe = /^(?:https?:)?\/\//i;
|
||||
var url_1 = tslib_1.__importDefault(require("url"));
|
||||
var request;
|
||||
var abstract_file_manager_js_1 = tslib_1.__importDefault(require("../less/environment/abstract-file-manager.js"));
|
||||
var logger_1 = tslib_1.__importDefault(require("../less/logger"));
|
||||
var UrlFileManager = function () { };
|
||||
UrlFileManager.prototype = Object.assign(new abstract_file_manager_js_1.default(), {
|
||||
supports: function (filename, currentDirectory, options, environment) {
|
||||
return isUrlRe.test(filename) || isUrlRe.test(currentDirectory);
|
||||
},
|
||||
|
||||
loadFile(filename, currentDirectory, options, environment) {
|
||||
return new Promise((fulfill, reject) => {
|
||||
loadFile: function (filename, currentDirectory, options, environment) {
|
||||
return new Promise(function (fulfill, reject) {
|
||||
if (request === undefined) {
|
||||
try { request = require('needle'); }
|
||||
catch (e) { request = null; }
|
||||
try {
|
||||
request = require('needle');
|
||||
}
|
||||
catch (e) {
|
||||
request = null;
|
||||
}
|
||||
}
|
||||
if (!request) {
|
||||
reject({ type: 'File', message: 'optional dependency \'needle\' required to import over http(s)\n' });
|
||||
return;
|
||||
}
|
||||
|
||||
let urlStr = isUrlRe.test( filename ) ? filename : url.resolve(currentDirectory, filename);
|
||||
|
||||
var urlStr = isUrlRe.test(filename) ? filename : url_1.default.resolve(currentDirectory, filename);
|
||||
/** native-request currently has a bug */
|
||||
const hackUrlStr = urlStr.indexOf('?') === -1 ? urlStr + '?' : urlStr
|
||||
|
||||
request.get(hackUrlStr, { follow_max: 5 }, (err, resp, body) => {
|
||||
var hackUrlStr = urlStr.indexOf('?') === -1 ? urlStr + '?' : urlStr;
|
||||
request.get(hackUrlStr, { follow_max: 5 }, function (err, resp, body) {
|
||||
if (err || resp && resp.statusCode >= 400) {
|
||||
const message = resp && resp.statusCode === 404
|
||||
? `resource '${urlStr}' was not found\n`
|
||||
: `resource '${urlStr}' gave this Error:\n ${err || resp.statusMessage || resp.statusCode}\n`;
|
||||
reject({ type: 'File', message });
|
||||
var message = resp && resp.statusCode === 404
|
||||
? "resource '".concat(urlStr, "' was not found\n")
|
||||
: "resource '".concat(urlStr, "' gave this Error:\n ").concat(err || resp.statusMessage || resp.statusCode, "\n");
|
||||
reject({ type: 'File', message: message });
|
||||
return;
|
||||
}
|
||||
if (resp.statusCode >= 300) {
|
||||
reject({ type: 'File', message: `resource '${urlStr}' caused too many redirects` });
|
||||
reject({ type: 'File', message: "resource '".concat(urlStr, "' caused too many redirects") });
|
||||
return;
|
||||
}
|
||||
body = body.toString('utf8');
|
||||
if (!body) {
|
||||
logger.warn(`Warning: Empty body (HTTP ${resp.statusCode}) returned by "${urlStr}"`);
|
||||
logger_1.default.warn("Warning: Empty body (HTTP ".concat(resp.statusCode, ") returned by \"").concat(urlStr, "\""));
|
||||
}
|
||||
fulfill({ contents: body || '', filename: urlStr });
|
||||
});
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
export default UrlFileManager;
|
||||
exports.default = UrlFileManager;
|
||||
//# sourceMappingURL=url-file-manager.js.map
|
||||
Reference in New Issue
Block a user