@expo/metro-config
Version:
A Metro config for running React Native projects with the Metro bundler
41 lines • 1.42 kB
JavaScript
;
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.compileSass = exports.matchSass = void 0;
const resolve_from_1 = __importDefault(require("resolve-from"));
let sassInstance = null;
function getSassInstance(projectRoot) {
if (!sassInstance) {
const sassPath = resolve_from_1.default.silent(projectRoot, 'sass');
if (!sassPath) {
throw new Error(`Cannot parse Sass files without the module 'sass' installed. Run 'yarn add sass' and try again.`);
}
sassInstance = require(sassPath);
}
return sassInstance;
}
function matchSass(filename) {
if (filename.endsWith('.sass')) {
return 'indented';
}
else if (filename.endsWith('.scss')) {
return 'scss';
}
return null;
}
exports.matchSass = matchSass;
function compileSass(projectRoot, { filename, src },
// TODO: Expose to users somehow...
options) {
const sass = getSassInstance(projectRoot);
const result = sass.compileString(src, options);
return {
src: result.css,
// TODO: Should we use this? Leaning towards no since the CSS will be parsed again by the CSS loader.
map: result.sourceMap,
};
}
exports.compileSass = compileSass;
//# sourceMappingURL=sass.js.map