/// <reference types="node" />
import type { BuildOptions, CommonServerOptions, Plugin, ServerOptions } from 'vite';
import tailwindcss from 'tailwindcss';
import type { Options as RemoveSelectorOptions } from '@plugin-light/postcss-plugin-remove-selector';
import type { Options as TransformWebTagOptions } from '@plugin-light/postcss-plugin-transform-web-tag';
import type { ICrossGameStyleOptions } from '@plugin-light/vite-plugin-cross-game-style';
import type { IRemoveVueDirectionOptions } from '@plugin-light/vite-plugin-remove-vue-directive';
import type { UniTailwindPluginUserOptions } from '@uni-helper/vite-plugin-uni-tailwind';
import type { Options as LegacyOptions } from '@vitejs/plugin-legacy';
import type { Server } from 'node:https';
import type { Options as ESBuildOptions } from 'rollup-plugin-esbuild';
export interface IUniViteConfigOptions {
    /**
     * 模式
     */
    mode: string;
    /**
     * uni 插件
     */
    uni: any;
    /**
     * 端口，传递给 server.port
     *
     * @default 443
     */
    port?: CommonServerOptions['port'];
    /**
     * https 配置，传递给 server.https
     */
    https?: Server;
    /**
     * host 配置，传递给 server.host
     * @default true
     */
    host?: CommonServerOptions['host'];
    /**
     * 前置插件
     */
    prePlugins?: Array<Plugin>;
    /**
     * 后置插件
     */
    postPlugins?: Array<Plugin>;
    /**
     * 对应 optimizeDeps.include
     */
    optimizeDepsIncludes?: Array<string>;
    /**
     * remove-vue-direction 插件参数
     */
    removeVueDirectionOptions?: IRemoveVueDirectionOptions;
    /**
     * hmr 选项
     * @default { timeout: 1000 * 60 * 5 }
     */
    hmr?: ServerOptions['hmr'];
    /**
     * 语法警报列表，比如 v-model，destroyed
     */
    warnList?: ICrossGameStyleOptions['warnList'];
    /**
     * transform-web-tag postcss 插件参数
     */
    transformWebTagOptions?: boolean | TransformWebTagOptions;
    /**
     * remove selector postcss 插件参数
     */
    removeSelectorOptions?: boolean | RemoveSelectorOptions;
    /**
     * uniTailwind 插件参数
     */
    uniTailwindOptions?: boolean | UniTailwindPluginUserOptions;
    /**
     * tailwindcss postcss 插件参数
     */
    tailwindcssOptions?: boolean | Parameters<typeof tailwindcss>[0];
    /**
     * 构建选项
     */
    buildOptions?: BuildOptions;
    /**
     * 是否使用 chunk-split
     * @default false
     */
    useChunkSplit?: boolean;
    /**
     * 是否使用 @vitejs/plugin-legacy，传递对象格式将作为插件参数
     * @default false
     */
    useLegacy?: boolean | LegacyOptions;
    /**
     * 传递给 uni 插件的参数
     */
    uniOptions?: any;
    /**
     * 是否使用 rollup-plugin-esbuild，传递对象格式将作为插件参数
     */
    useESBuildPlugin?: boolean | ESBuildOptions;
    /**
     * 是否使用 pmd-network-v2
     * @default false
     */
    usePMDNetworkV2?: boolean;
    /**
     * 是否使用文件轮询监听（usePolling）
     *
     * 轮询比原生 fs.watch 慢且 CPU 占用高，仅在 Docker/WSL 等不支持 inotify 的环境下需要开启
     * @default true
     */
    usePolling?: boolean;
    /**
     * 是否开启 visualizer 产物分析插件
     *
     * 设为 false 可跳过 gzip/brotli 计算，加快构建速度
     * @default true
     */
    useVisualizer?: boolean;
    /**
     * 是否使用 @rollup/plugin-node-resolve
     *
     * Vite 内部已有 resolve 能力，关闭可减少重复解析开销
     * @default true
     */
    useNodeResolve?: boolean;
    /**
     * 构建目标，传递给 build.target（仅 H5 生效）
     *
     * 如果不需要兼容旧浏览器，可设为 'es2020' 或 'esnext' 以减少 polyfill，加快构建
     * @default 'es2015'
     */
    buildTarget?: string;
}
