| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- 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 => {
- function imageSize(functionContext, filePathNode) {
- let filePath = filePathNode.value;
- const currentFileInfo = functionContext.currentFileInfo;
- const currentDirectory = currentFileInfo.rewriteUrls ?
- currentFileInfo.currentDirectory : currentFileInfo.entryPath;
- const fragmentStart = filePath.indexOf('#');
- if (fragmentStart !== -1) {
- filePath = filePath.slice(0, fragmentStart);
- }
- const fileManager = environment.getFileManager(filePath, currentDirectory, functionContext.context, environment, true);
- if (!fileManager) {
- throw {
- type: 'File',
- message: `Can not set up FileManager for ${filePathNode}`
- };
- }
- const 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};
- }
- const imageFunctions = {
- 'image-size': function(filePathNode) {
- const size = imageSize(this, filePathNode);
- return new Expression([
- new Dimension(size.width, 'px'),
- new Dimension(size.height, 'px')
- ]);
- },
- 'image-width': function(filePathNode) {
- const size = imageSize(this, filePathNode);
- return new Dimension(size.width, 'px');
- },
- 'image-height': function(filePathNode) {
- const size = imageSize(this, filePathNode);
- return new Dimension(size.height, 'px');
- }
- };
- functionRegistry.addMultiple(imageFunctions);
- };
|