import type { EventEmitter } from './EventEmitter';
import type { NativeModule } from './NativeModule';
import type { SharedObject } from './SharedObject';
import type { SharedRef } from './SharedRef';
export interface ExpoGlobal {
    /**
     * Host object that is used to access native Expo modules.
     */
    modules: Record<string, any>;
    /**
     * @see EventEmitter
     */
    EventEmitter: typeof EventEmitter;
    /**
     * @see SharedObject
     */
    SharedObject: typeof SharedObject;
    /**
     * @see SharedRef
     */
    SharedRef: typeof SharedRef;
    /**
     * @see NativeModule
     */
    NativeModule: typeof NativeModule;
    /**
     * The version of the `expo-modules-core` package.
     * @platform android
     * @platform ios
     */
    expoModulesCoreVersion?: {
        version: string;
        major: number;
        minor: number;
        patch: number;
    };
    /**
     * The path to the cache directory
     * @platform android
     * @platform ios
     */
    cacheDir?: string;
    /**
     * The path to the documents directory
     * @platform android
     * @platform ios
     */
    documentsDir?: string;
    /**
     * Generates a random UUID v4 string.
     */
    uuidv4(): string;
    /**
     * Generates a UUID v5 string representation of the value in the specified namespace.
     */
    uuidv5(name: string, namespace: string): string;
    /**
     * Returns a static view config of the native view with the given name
     * or `null` if the view has not been registered.
     */
    getViewConfig(moduleName: string, viewName?: string): ViewConfig | null;
    /**
     * Reloads the app.
     */
    reloadAppAsync(reason: string): Promise<void>;
}
type ViewConfig = {
    validAttributes: Record<string, any>;
    directEventTypes: Record<string, {
        registrationName: string;
    }>;
};
export interface ExpoProcessEnv {
    NODE_ENV: string;
    /** Used in `@expo/metro-runtime`. */
    EXPO_DEV_SERVER_ORIGIN?: string;
    EXPO_ROUTER_IMPORT_MODE?: string;
    EXPO_ROUTER_ABS_APP_ROOT?: string;
    EXPO_ROUTER_APP_ROOT?: string;
    /** Maps to the `experiments.baseUrl` property in the project Expo config. This is injected by `babel-preset-expo` and supports automatic cache invalidation. */
    EXPO_BASE_URL?: string;
    /** Build-time representation of the `Platform.OS` value that the current JavaScript was bundled for. Does not support platform shaking wrapped require statements. */
    EXPO_OS?: string;
    [key: string]: any;
}
export interface ExpoProcess {
    env: ExpoProcessEnv;
    [key: string]: any;
}
declare global {
    namespace NodeJS {
        interface ProcessEnv extends ExpoProcessEnv {
        }
        interface Process extends ExpoProcess {
            env: ProcessEnv;
        }
    }
    /**
     * Global object containing all the native bindings installed by Expo.
     * This object is not available in projects without the `expo` package installed.
     */
    var expo: ExpoGlobal;
    var process: NodeJS.Process;
    /**
     * ExpoDomWebView is defined in `@expo/dom-webview` runtime.
     */
    var ExpoDomWebView: Record<string, any> | undefined;
}
export {};
//# sourceMappingURL=global.d.ts.map