import { Context, Schema } from 'koishi';
export declare const name = "best-cave";
export declare const inject: string[];
export declare const usage = "\n<div style=\"border-radius: 10px; border: 1px solid #ddd; padding: 16px; margin-bottom: 20px; box-shadow: 0 2px 5px rgba(0,0,0,0.1);\">\n  <h2 style=\"margin-top: 0; color: #4a6ee0;\">\uD83D\uDCCC \u63D2\u4EF6\u8BF4\u660E</h2>\n  <p>\uD83D\uDCD6 <strong>\u4F7F\u7528\u6587\u6863</strong>\uFF1A\u8BF7\u70B9\u51FB\u5DE6\u4E0A\u89D2\u7684 <strong>\u63D2\u4EF6\u4E3B\u9875</strong> \u67E5\u770B\u63D2\u4EF6\u4F7F\u7528\u6587\u6863</p>\n  <p>\uD83D\uDD0D <strong>\u66F4\u591A\u63D2\u4EF6</strong>\uFF1A\u53EF\u8BBF\u95EE <a href=\"https://github.com/YisRime\" style=\"color:#4a6ee0;text-decoration:none;\">\u82E1\u6DDE\u7684 GitHub</a> \u67E5\u770B\u672C\u4EBA\u7684\u6240\u6709\u63D2\u4EF6</p>\n</div>\n\n<div style=\"border-radius: 10px; border: 1px solid #ddd; padding: 16px; margin-bottom: 20px; box-shadow: 0 2px 5px rgba(0,0,0,0.1);\">\n  <h2 style=\"margin-top: 0; color: #e0574a;\">\u2764\uFE0F \u652F\u6301\u4E0E\u53CD\u9988</h2>\n  <p>\uD83C\uDF1F \u559C\u6B22\u8FD9\u4E2A\u63D2\u4EF6\uFF1F\u8BF7\u5728 <a href=\"https://github.com/YisRime\" style=\"color:#e0574a;text-decoration:none;\">GitHub</a> \u4E0A\u7ED9\u6211\u4E00\u4E2A Star\uFF01</p>\n  <p>\uD83D\uDC1B \u9047\u5230\u95EE\u9898\uFF1F\u8BF7\u901A\u8FC7 <strong>Issues</strong> \u63D0\u4EA4\u53CD\u9988\uFF0C\u6216\u52A0\u5165 QQ \u7FA4 <a href=\"https://qm.qq.com/q/PdLMx9Jowq\" style=\"color:#e0574a;text-decoration:none;\"><strong>855571375</strong></a> \u8FDB\u884C\u4EA4\u6D41</p>\n</div>\n";
/**
 * 基础元素类型
 * @interface BaseElement
 * @property {('text'|'img'|'video')} type - 元素类型
 * @property {number} index - 排序索引
 */
export interface BaseElement {
    type: 'text' | 'img' | 'video';
    index: number;
}
/**
 * 文本元素类型
 * @interface TextElement
 * @extends {BaseElement}
 * @property {'text'} type - 文本类型
 * @property {string} content - 文本内容
 */
export interface TextElement extends BaseElement {
    type: 'text';
    content: string;
}
/**
 * 媒体元素类型
 * @interface MediaElement
 * @extends {BaseElement}
 * @property {('img'|'video')} type - 媒体类型
 * @property {string} [file] - 文件名
 * @property {string} [fileName] - 原始文件名
 * @property {string} [fileSize] - 文件大小
 * @property {string} [filePath] - 文件路径
 */
export interface MediaElement extends BaseElement {
    type: 'img' | 'video';
    file?: string;
    fileName?: string;
    fileSize?: string;
    filePath?: string;
}
export type Element = TextElement | MediaElement;
/**
 * 回声洞对象
 * @interface CaveObject
 * @property {number} cave_id - 回声洞ID
 * @property {Element[]} elements - 元素列表
 * @property {string} contributor_number - 投稿者ID
 * @property {string} contributor_name - 投稿者名称
 */
export interface CaveObject {
    cave_id: number;
    elements: Element[];
    contributor_number: string;
    contributor_name: string;
}
export interface PendingCave extends CaveObject {
}
export interface Config {
    manager: string[];
    number: number;
    enableAudit: boolean;
    allowVideo: boolean;
    videoMaxSize: number;
    imageMaxSize: number;
    blacklist: string[];
    whitelist: string[];
    enablePagination: boolean;
    itemsPerPage: number;
    enableImageDuplicate: boolean;
    imageDuplicateThreshold: number;
    textDuplicateThreshold: number;
    enableTextDuplicate: boolean;
}
/**
 * 插件配置项
 * @type {Schema}
 */
export declare const Config: Schema<Config>;
/**
 * 插件主入口
 * @param {Context} ctx - Koishi上下文
 * @param {Config} config - 插件配置
 */
export declare function apply(ctx: Context, config: Config): Promise<void>;
