12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- import Dimension from '../less/tree/dimension';
- import Expression from '../less/tree/expression';
- import functionRegistry from './../less/functions/function-registry';
- 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('#');
- let fragment = '';
- if (fragmentStart !== -1) {
- fragment = filePath.slice(fragmentStart);
- 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(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')
- ]);
- },
- '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);
- };
|