Resolve import-maps
Part of Open Web Components
Open Web Components provides a set of defaults, recommendations and tools to help facilitate your web component project. Our recommendations include: developing, linting, testing, building, tooling, demoing, publishing and automating.
data:image/s3,"s3://crabby-images/4f9fb/4f9fb7bddef4aee10d3581e5e06a32347ce7dfcd" alt="Renovate enabled"
This will allow you to parse and resolve urls by a given import-map.
Usage
yarn add @import-maps/resolve
You may then override a resolve method in your build process.
import { parseFromString, resolve } from '@import-maps/resolve';
const importMapCache = null;
function myResolve(specifier) {
const rootDir = process.cwd();
const basePath = importer ? importer.replace(rootDir, `${rootDir}::`) : `${rootDir}::`;
if (!importMapCache) {
const mapString = fs.readFileSync(path.join(rootDir, 'import-map.json'), 'utf-8');
mapCache = parseFromString(mapString, basePath);
}
const relativeSource = source.replace(rootDir, '');
const resolvedPath = resolve(relativeSource, importMapCache, basePath);
if (resolvedPath) {
return resolvedPath;
}
}
Additional info
The 3rd parameter of resolve
is the "baseUrl/basePath" and it's format is /path/to/root::/subdir/foo
.
You can compare it with an url http://example.com/subdir/foo
.
- Everything before the
::
is sort of the domain
e.g. http://example.com/
- Everything after is the path/directory to your appliaction
Such a path is needed as import maps support relative pathes as values.
Acknowledgments
This implementation is heavily based on the import-maps reference implementation.
Thanks to @domenic and @guybedford for sharing that prototype.
Some adjustments have been made
- Allow to process/resolve node pathes besides urls
- Use mocha/chai for testing (already available in our setup)