create-expo-cljs-app
Version:
Create a react native application with Expo and Shadow-CLJS!
67 lines (57 loc) • 1.93 kB
text/typescript
import { RawExpoModuleConfig, SupportedPlatform } from './types';
/**
* A class that wraps the raw config (`expo-module.json` or `unimodule.json`).
*/
export class ExpoModuleConfig {
constructor(readonly rawConfig: RawExpoModuleConfig) {}
/**
* Whether the module supports given platform.
*/
supportsPlatform(platform: SupportedPlatform): boolean {
return this.rawConfig.platforms?.includes(platform) ?? false;
}
/**
* Returns a list of names of Swift native modules classes to put to the generated modules provider file.
*/
iosModulesClassNames() {
return this.rawConfig.ios?.modulesClassNames ?? [];
}
/**
* Returns a list of names of Swift classes that receives AppDelegate life-cycle events.
*/
iosAppDelegateSubscribers(): string[] {
return this.rawConfig.ios?.appDelegateSubscribers ?? [];
}
/**
* Returns a list of names of Swift classes that implement `ExpoReactDelegateHandler`.
*/
iosReactDelegateHandlers(): string[] {
return this.rawConfig.ios?.reactDelegateHandlers ?? [];
}
/**
* Returns a podspec path defined by the module author.
*/
iosPodspecPath(): string | undefined {
return this.rawConfig.ios?.podspecPath;
}
/**
* Returns a list of names of Kotlin native modules classes to put to the generated package provider file.
*/
androidModulesClassNames() {
return this.rawConfig.android?.modulesClassNames ?? [];
}
/**
* Returns serializable raw config.
*/
toJSON(): RawExpoModuleConfig {
return this.rawConfig;
}
}
/**
* Reads the config at given path and returns the config wrapped by `ExpoModuleConfig` class.
*/
export function requireAndResolveExpoModuleConfig(path: string): ExpoModuleConfig {
// TODO: Validate the raw config against a schema.
// TODO: Support for `*.js` files, not only static `*.json`.
return new ExpoModuleConfig(require(path) as RawExpoModuleConfig);
}