39 lines
1.6 KiB
JavaScript
39 lines
1.6 KiB
JavaScript
![]() |
import URL from 'url-parse';
|
||
|
export function getFilename(url) {
|
||
|
const { pathname } = new URL(url, {});
|
||
|
return pathname.substring(pathname.lastIndexOf('/') + 1);
|
||
|
}
|
||
|
export function getFileExtension(url) {
|
||
|
const filename = getFilename(url);
|
||
|
const dotIndex = filename.lastIndexOf('.');
|
||
|
// Ignore leading dots for hidden files
|
||
|
return dotIndex > 0 ? filename.substring(dotIndex) : '';
|
||
|
}
|
||
|
/**
|
||
|
* Returns the base URL from a manifest's URL. For example, given a manifest hosted at
|
||
|
* https://example.com/app/manifest.json, the base URL would be https://example.com/app/. Query
|
||
|
* parameters and fragments also are removed.
|
||
|
*
|
||
|
* For an Expo-hosted project with a manifest hosted at https://expo.io/@user/project/index.exp, the
|
||
|
* base URL would be https://expo.io/@user/project.
|
||
|
*
|
||
|
* We also normalize the "exp" protocol to "http" to handle internal URLs with the Expo schemes used
|
||
|
* to tell the OS to open the URLs in the the Expo client.
|
||
|
*/
|
||
|
export function getManifestBaseUrl(manifestUrl) {
|
||
|
const urlObject = new URL(manifestUrl, {});
|
||
|
// Change the scheme to http(s) if it is exp(s)
|
||
|
if (urlObject.protocol === 'exp:') {
|
||
|
urlObject.set('protocol', 'http:');
|
||
|
}
|
||
|
else if (urlObject.protocol === 'exps:') {
|
||
|
urlObject.set('protocol', 'https:');
|
||
|
}
|
||
|
// Trim filename, query parameters, and fragment, if any
|
||
|
const directory = urlObject.pathname.substring(0, urlObject.pathname.lastIndexOf('/') + 1);
|
||
|
urlObject.set('pathname', directory);
|
||
|
urlObject.set('query', '');
|
||
|
urlObject.set('hash', '');
|
||
|
return urlObject.href;
|
||
|
}
|
||
|
//# sourceMappingURL=AssetUris.js.map
|