mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-08-15 19:26:42 +08:00

* chore: move tns-core-modules to nativescript-core * chore: preparing compat generate script * chore: add missing definitions * chore: no need for http-request to be private * chore: packages chore * test: generate tests for tns-core-modules * chore: add anroid module for consistency * chore: add .npmignore * chore: added privateModulesWhitelist * chore(webpack): added bundle-entry-points * chore: scripts * chore: tests changed to use @ns/core * test: add scoped-packages test project * test: fix types * test: update test project * chore: build scripts * chore: update build script * chore: npm scripts cleanup * chore: make the compat pgk work with old wp config * test: generate diff friendly tests * chore: create barrel exports * chore: move files after rebase * chore: typedoc config * chore: compat mode * chore: review of barrels * chore: remove tns-core-modules import after rebase * chore: dev workflow setup * chore: update developer-workflow * docs: experiment with API extractor * chore: api-extractor and barrel exports * chore: api-extractor configs * chore: generate d.ts rollup with api-extractor * refactor: move methods inside Frame * chore: fic tests to use Frame static methods * refactor: create Builder class * refactor: use Builder class in tests * refactor: include Style in ui barrel * chore: separate compat build script * chore: fix tslint errors * chore: update NATIVESCRIPT_CORE_ARGS * chore: fix compat pack * chore: fix ui-test-app build with linked modules * chore: Application, ApplicationSettings, Connectivity and Http * chore: export Trace, Profiling and Utils * refactor: Static create methods for ImageSource * chore: fix deprecated usages of ImageSource * chore: move Span and FormattedString to ui * chore: add events-args and ImageSource to index files * chore: check for CLI >= 6.2 when building for IOS * chore: update travis build * chore: copy Pod file to compat package * chore: update error msg ui-tests-app * refactor: Apply suggestions from code review Co-Authored-By: Martin Yankov <m.i.yankov@gmail.com> * chore: typings and refs * chore: add missing d.ts files for public API * chore: adress code review FB * chore: update api-report * chore: dev-workflow for other apps * chore: api update * chore: update api-report
128 lines
4.3 KiB
TypeScript
128 lines
4.3 KiB
TypeScript
type ModuleLoader = (name?: string) => any;
|
|
|
|
interface Context {
|
|
keys(): string[];
|
|
(key: string): any;
|
|
}
|
|
|
|
interface ExtensionMap {
|
|
[originalFileExtension: string]: string;
|
|
}
|
|
|
|
const modules: Map<string, { moduleId: string, loader: ModuleLoader }> = new Map<string, { moduleId: string, loader: ModuleLoader }>();
|
|
const modulesLoadedForUI = new Set<string>();
|
|
const defaultExtensionMap: ExtensionMap = {
|
|
".js": ".js",
|
|
".ts": ".js",
|
|
".css": ".css",
|
|
".scss": ".css",
|
|
".less": ".css",
|
|
".sass": ".css",
|
|
".xml": ".xml"
|
|
};
|
|
|
|
// Cast to <any> because moduleResolvers is read-only in definitions
|
|
(<any>global).moduleResolvers = [global.require];
|
|
|
|
global.registerModule = function (name: string, loader: ModuleLoader): void {
|
|
modules.set(name, { loader, moduleId: name });
|
|
};
|
|
|
|
global._unregisterModule = function _unregisterModule(name: string): void {
|
|
modules.delete(name);
|
|
};
|
|
|
|
global._isModuleLoadedForUI = function _isModuleLoadedForUI(moduleName: string): boolean {
|
|
return modulesLoadedForUI.has(moduleName);
|
|
};
|
|
|
|
global.registerWebpackModules = function registerWebpackModules(context: Context, extensionMap: ExtensionMap = {}) {
|
|
context.keys().forEach(moduleId => {
|
|
const extDotIndex = moduleId.lastIndexOf(".");
|
|
const base = moduleId.substr(0, extDotIndex);
|
|
const originalExt = moduleId.substr(extDotIndex);
|
|
const registerExt = extensionMap[originalExt] || defaultExtensionMap[originalExt] || originalExt;
|
|
|
|
// We prefer source files for webpack scenarios before compilation leftovers,
|
|
// e. g. if we get a .js and .ts for the same module, the .js is probably the compiled version of the .ts file,
|
|
// so we register the .ts with higher priority, similar is the case with us preferring the .scss to .css
|
|
const isSourceFile = originalExt !== registerExt;
|
|
const registerName = base + registerExt;
|
|
|
|
const registerWithName = (nickName: string) => {
|
|
modules.set(nickName, {
|
|
moduleId,
|
|
loader: () => {
|
|
return context(moduleId);
|
|
}
|
|
});
|
|
};
|
|
|
|
if (registerName.startsWith("./") && registerName.endsWith(".js")) {
|
|
const jsNickNames = [
|
|
// This is extremely short version like "main-page" that was promoted to be used with global.registerModule("module-name", loaderFunc);
|
|
registerName.substr(2, registerName.length - 5),
|
|
// This is for supporting module names like "./main/main-page"
|
|
registerName.substr(0, registerName.length - 3),
|
|
// This is for supporting module names like "main/main-page.js"
|
|
registerName.substr(2),
|
|
];
|
|
|
|
jsNickNames.forEach(jsNickName => {
|
|
if (isSourceFile || !global.moduleExists(jsNickName)) {
|
|
registerWithName(jsNickName);
|
|
}
|
|
});
|
|
} else if (registerName.startsWith("./")) {
|
|
const moduleNickNames = [
|
|
// This is for supporting module names like "main/main-page.xml"
|
|
registerName.substr(2),
|
|
];
|
|
|
|
moduleNickNames.forEach(moduleNickName => {
|
|
if (!global.moduleExists(moduleNickName)) {
|
|
registerWithName(moduleNickName);
|
|
}
|
|
});
|
|
}
|
|
|
|
if (isSourceFile || !global.moduleExists(registerName)) {
|
|
registerWithName(registerName);
|
|
}
|
|
});
|
|
};
|
|
|
|
global.moduleExists = function moduleExists(name: string): boolean {
|
|
return modules.has(name);
|
|
};
|
|
|
|
global.loadModule = function loadModule(name: string, isUIModule: boolean = false): any {
|
|
const moduleInfo = modules.get(name);
|
|
if (moduleInfo) {
|
|
if (isUIModule) {
|
|
modulesLoadedForUI.add(moduleInfo.moduleId);
|
|
}
|
|
|
|
const result = moduleInfo.loader(name);
|
|
|
|
if (result.enableAutoAccept) {
|
|
result.enableAutoAccept();
|
|
}
|
|
|
|
return result;
|
|
}
|
|
|
|
for (let resolver of (<any>global).moduleResolvers) {
|
|
const result = resolver(name);
|
|
if (result) {
|
|
modules.set(name, { moduleId: name, loader: () => result });
|
|
|
|
return result;
|
|
}
|
|
}
|
|
};
|
|
|
|
global.getRegisteredModules = function getRegisteredModules(): string[] {
|
|
return Array.from(modules.keys());
|
|
};
|