import { SFCWithInstall } from "../../../utils/vue/typescript.js";
import { EpPropMergeType } from "../../../utils/vue/props/types.js";
import { ComponentSize } from "../../../constants/size.js";
import "../../../utils/index.js";
import { Translator } from "../../../hooks/use-locale/index.js";
import "../../../hooks/index.js";
import { CheckboxProps, CheckboxValueType } from "../../checkbox/src/checkbox.js";
import { _default as _default$1 } from "../../checkbox/src/checkbox-button.vue.js";
import { _default as _default$2 } from "../../checkbox/src/checkbox-group.vue.js";
import { UseTooltipProps } from "../../tooltip/src/tooltip.js";
import { TreeData } from "./store/tree.js";
import { TableColumnCtx } from "./table-column/defaults.js";
import { StoreFilter } from "./store/index.js";
import { TableHeaderProps } from "./table-header/index.js";
import { TableLayout } from "./table-layout.js";
import { DefaultRow, Filter, RenderExpanded, Sort, Table, TableProps, TableSortOrder, TreeProps } from "./table/defaults.js";
import { TableBodyProps } from "./table-body/defaults.js";
import { TableFooter } from "./table-footer/index.js";
import { ScrollbarDirection, ScrollbarProps } from "../../scrollbar/src/scrollbar.js";
import "../../scrollbar/index.js";
import { MousewheelCallback, WheelElement } from "../../../directives/mousewheel/index.js";
import { hColgroup } from "./h-helper.js";
import "../../../index.js";
import * as vue from "vue";
import * as lodash_unified0 from "lodash-unified";

//#region ../../packages/components/table/src/table.vue.d.ts
declare const _default: typeof __VLS_export;
declare const __VLS_export: vue.DefineComponent<vue.ExtractPropTypes<{
  data: {
    type: vue.PropType<any[]>;
    default: () => never[];
  };
  size: {
    readonly type: vue.PropType<EpPropMergeType<StringConstructor, "" | "default" | "large" | "small", never>>;
    readonly required: false;
    readonly validator: ((val: unknown) => boolean) | undefined;
    __epPropKey: true;
  };
  width: (NumberConstructor | StringConstructor)[];
  height: (NumberConstructor | StringConstructor)[];
  maxHeight: (NumberConstructor | StringConstructor)[];
  fit: {
    type: BooleanConstructor;
    default: boolean;
  };
  stripe: BooleanConstructor;
  border: BooleanConstructor;
  rowKey: vue.PropType<TableProps<any>["rowKey"]>;
  showHeader: {
    type: BooleanConstructor;
    default: boolean;
  };
  showSummary: BooleanConstructor;
  sumText: StringConstructor;
  summaryMethod: vue.PropType<TableProps<any>["summaryMethod"]>;
  rowClassName: vue.PropType<TableProps<any>["rowClassName"]>;
  rowStyle: vue.PropType<TableProps<any>["rowStyle"]>;
  cellClassName: vue.PropType<TableProps<any>["cellClassName"]>;
  cellStyle: vue.PropType<TableProps<any>["cellStyle"]>;
  headerRowClassName: vue.PropType<TableProps<any>["headerRowClassName"]>;
  headerRowStyle: vue.PropType<TableProps<any>["headerRowStyle"]>;
  headerCellClassName: vue.PropType<TableProps<any>["headerCellClassName"]>;
  headerCellStyle: vue.PropType<TableProps<any>["headerCellStyle"]>;
  highlightCurrentRow: BooleanConstructor;
  currentRowKey: (NumberConstructor | StringConstructor)[];
  emptyText: StringConstructor;
  expandRowKeys: vue.PropType<TableProps<any>["expandRowKeys"]>;
  defaultExpandAll: BooleanConstructor;
  rowExpandable: {
    type: vue.PropType<TableProps<any>["rowExpandable"]>;
  };
  defaultSort: vue.PropType<TableProps<any>["defaultSort"]>;
  tooltipEffect: StringConstructor;
  tooltipOptions: vue.PropType<TableProps<any>["tooltipOptions"]>;
  spanMethod: vue.PropType<TableProps<any>["spanMethod"]>;
  selectOnIndeterminate: {
    type: BooleanConstructor;
    default: boolean;
  };
  indent: {
    type: NumberConstructor;
    default: number;
  };
  treeProps: {
    type: vue.PropType<TableProps<any>["treeProps"]>;
    default: () => {
      hasChildren: string;
      children: string;
      checkStrictly: boolean;
    };
  };
  lazy: BooleanConstructor;
  load: vue.PropType<TableProps<any>["load"]>;
  style: {
    type: vue.PropType<TableProps<any>["style"]>;
    default: () => {};
  };
  className: {
    type: StringConstructor;
    default: string;
  };
  tableLayout: {
    type: vue.PropType<"auto" | "fixed">;
    default: string;
  };
  scrollbarAlwaysOn: BooleanConstructor;
  flexible: BooleanConstructor;
  showOverflowTooltip: {
    type: vue.PropType<TableProps<any>["showOverflowTooltip"]>;
    default: undefined;
  };
  tooltipFormatter: vue.PropType<TableProps<any>["tooltipFormatter"]>;
  appendFilterPanelTo: StringConstructor;
  scrollbarTabindex: {
    type: (NumberConstructor | StringConstructor)[];
    default: undefined;
  };
  allowDragLastColumn: {
    type: BooleanConstructor;
    default: boolean;
  };
  preserveExpandedContent: BooleanConstructor;
  nativeScrollbar: BooleanConstructor;
}>, {
  ns: {
    namespace: vue.ComputedRef<string>;
    b: (blockSuffix?: string) => string;
    e: (element?: string) => string;
    m: (modifier?: string) => string;
    be: (blockSuffix?: string, element?: string) => string;
    em: (element?: string, modifier?: string) => string;
    bm: (blockSuffix?: string, modifier?: string) => string;
    bem: (blockSuffix?: string, element?: string, modifier?: string) => string;
    is: {
      (name: string, state: boolean | undefined): string;
      (name: string): string;
    };
    cssVar: (object: Record<string, string>) => Record<string, string>;
    cssVarName: (name: string) => string;
    cssVarBlock: (object: Record<string, string>) => Record<string, string>;
    cssVarBlockName: (name: string) => string;
  };
  layout: TableLayout<any>;
  store: {
    mutations: {
      setData(states: {
        _currentRowKey: vue.Ref<string | null, string | null>;
        currentRow: vue.Ref<any, any>;
        expandRowKeys: vue.Ref<string[], string[]>;
        treeData: vue.Ref<Record<string, TreeData>, Record<string, TreeData>>;
        indent: vue.Ref<number, number>;
        lazy: vue.Ref<boolean, boolean>;
        lazyTreeNodeMap: vue.Ref<Record<string, any[]>, Record<string, any[]>>;
        lazyColumnIdentifier: vue.Ref<string, string>;
        childrenColumnName: vue.Ref<string, string>;
        checkStrictly: vue.Ref<boolean, boolean>;
        expandRows: vue.Ref<any[], any[]>;
        defaultExpandAll: vue.Ref<boolean, boolean>;
        tableSize: vue.Ref<any, any>;
        rowKey: vue.Ref<string | null, string | null>;
        data: vue.Ref<any[], any[]>;
        _data: vue.Ref<any[], any[]>;
        isComplex: vue.Ref<boolean, boolean>;
        _columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        originColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        leafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        updateOrderFns: (() => void)[];
        leafColumnsLength: vue.Ref<number, number>;
        fixedLeafColumnsLength: vue.Ref<number, number>;
        rightFixedLeafColumnsLength: vue.Ref<number, number>;
        isAllSelected: vue.Ref<boolean, boolean>;
        selection: vue.Ref<any[], any[]>;
        reserveSelection: vue.Ref<boolean, boolean>;
        selectOnIndeterminate: vue.Ref<boolean, boolean>;
        selectable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        rowExpandable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        filters: vue.Ref<StoreFilter, StoreFilter>;
        filteredData: vue.Ref<any[] | null, any[] | null>;
        sortingColumn: vue.Ref<TableColumnCtx<any> | null, TableColumnCtx<any> | null>;
        sortProp: vue.Ref<string | null, string | null>;
        sortOrder: vue.Ref<string | number | null, string | number | null>;
        hoverRow: vue.Ref<any, any>;
      }, data: any[]): void;
      insertColumn(states: {
        _currentRowKey: vue.Ref<string | null, string | null>;
        currentRow: vue.Ref<any, any>;
        expandRowKeys: vue.Ref<string[], string[]>;
        treeData: vue.Ref<Record<string, TreeData>, Record<string, TreeData>>;
        indent: vue.Ref<number, number>;
        lazy: vue.Ref<boolean, boolean>;
        lazyTreeNodeMap: vue.Ref<Record<string, any[]>, Record<string, any[]>>;
        lazyColumnIdentifier: vue.Ref<string, string>;
        childrenColumnName: vue.Ref<string, string>;
        checkStrictly: vue.Ref<boolean, boolean>;
        expandRows: vue.Ref<any[], any[]>;
        defaultExpandAll: vue.Ref<boolean, boolean>;
        tableSize: vue.Ref<any, any>;
        rowKey: vue.Ref<string | null, string | null>;
        data: vue.Ref<any[], any[]>;
        _data: vue.Ref<any[], any[]>;
        isComplex: vue.Ref<boolean, boolean>;
        _columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        originColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        leafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        updateOrderFns: (() => void)[];
        leafColumnsLength: vue.Ref<number, number>;
        fixedLeafColumnsLength: vue.Ref<number, number>;
        rightFixedLeafColumnsLength: vue.Ref<number, number>;
        isAllSelected: vue.Ref<boolean, boolean>;
        selection: vue.Ref<any[], any[]>;
        reserveSelection: vue.Ref<boolean, boolean>;
        selectOnIndeterminate: vue.Ref<boolean, boolean>;
        selectable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        rowExpandable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        filters: vue.Ref<StoreFilter, StoreFilter>;
        filteredData: vue.Ref<any[] | null, any[] | null>;
        sortingColumn: vue.Ref<TableColumnCtx<any> | null, TableColumnCtx<any> | null>;
        sortProp: vue.Ref<string | null, string | null>;
        sortOrder: vue.Ref<string | number | null, string | number | null>;
        hoverRow: vue.Ref<any, any>;
      }, column: TableColumnCtx<any>, parent: TableColumnCtx<any>, updateColumnOrder: () => void): void;
      updateColumnOrder(states: {
        _currentRowKey: vue.Ref<string | null, string | null>;
        currentRow: vue.Ref<any, any>;
        expandRowKeys: vue.Ref<string[], string[]>;
        treeData: vue.Ref<Record<string, TreeData>, Record<string, TreeData>>;
        indent: vue.Ref<number, number>;
        lazy: vue.Ref<boolean, boolean>;
        lazyTreeNodeMap: vue.Ref<Record<string, any[]>, Record<string, any[]>>;
        lazyColumnIdentifier: vue.Ref<string, string>;
        childrenColumnName: vue.Ref<string, string>;
        checkStrictly: vue.Ref<boolean, boolean>;
        expandRows: vue.Ref<any[], any[]>;
        defaultExpandAll: vue.Ref<boolean, boolean>;
        tableSize: vue.Ref<any, any>;
        rowKey: vue.Ref<string | null, string | null>;
        data: vue.Ref<any[], any[]>;
        _data: vue.Ref<any[], any[]>;
        isComplex: vue.Ref<boolean, boolean>;
        _columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        originColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        leafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        updateOrderFns: (() => void)[];
        leafColumnsLength: vue.Ref<number, number>;
        fixedLeafColumnsLength: vue.Ref<number, number>;
        rightFixedLeafColumnsLength: vue.Ref<number, number>;
        isAllSelected: vue.Ref<boolean, boolean>;
        selection: vue.Ref<any[], any[]>;
        reserveSelection: vue.Ref<boolean, boolean>;
        selectOnIndeterminate: vue.Ref<boolean, boolean>;
        selectable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        rowExpandable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        filters: vue.Ref<StoreFilter, StoreFilter>;
        filteredData: vue.Ref<any[] | null, any[] | null>;
        sortingColumn: vue.Ref<TableColumnCtx<any> | null, TableColumnCtx<any> | null>;
        sortProp: vue.Ref<string | null, string | null>;
        sortOrder: vue.Ref<string | number | null, string | number | null>;
        hoverRow: vue.Ref<any, any>;
      }, column: TableColumnCtx<any>): void;
      removeColumn(states: {
        _currentRowKey: vue.Ref<string | null, string | null>;
        currentRow: vue.Ref<any, any>;
        expandRowKeys: vue.Ref<string[], string[]>;
        treeData: vue.Ref<Record<string, TreeData>, Record<string, TreeData>>;
        indent: vue.Ref<number, number>;
        lazy: vue.Ref<boolean, boolean>;
        lazyTreeNodeMap: vue.Ref<Record<string, any[]>, Record<string, any[]>>;
        lazyColumnIdentifier: vue.Ref<string, string>;
        childrenColumnName: vue.Ref<string, string>;
        checkStrictly: vue.Ref<boolean, boolean>;
        expandRows: vue.Ref<any[], any[]>;
        defaultExpandAll: vue.Ref<boolean, boolean>;
        tableSize: vue.Ref<any, any>;
        rowKey: vue.Ref<string | null, string | null>;
        data: vue.Ref<any[], any[]>;
        _data: vue.Ref<any[], any[]>;
        isComplex: vue.Ref<boolean, boolean>;
        _columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        originColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        leafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        updateOrderFns: (() => void)[];
        leafColumnsLength: vue.Ref<number, number>;
        fixedLeafColumnsLength: vue.Ref<number, number>;
        rightFixedLeafColumnsLength: vue.Ref<number, number>;
        isAllSelected: vue.Ref<boolean, boolean>;
        selection: vue.Ref<any[], any[]>;
        reserveSelection: vue.Ref<boolean, boolean>;
        selectOnIndeterminate: vue.Ref<boolean, boolean>;
        selectable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        rowExpandable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        filters: vue.Ref<StoreFilter, StoreFilter>;
        filteredData: vue.Ref<any[] | null, any[] | null>;
        sortingColumn: vue.Ref<TableColumnCtx<any> | null, TableColumnCtx<any> | null>;
        sortProp: vue.Ref<string | null, string | null>;
        sortOrder: vue.Ref<string | number | null, string | number | null>;
        hoverRow: vue.Ref<any, any>;
      }, column: TableColumnCtx<any>, parent: TableColumnCtx<any>, updateColumnOrder: () => void): void;
      sort(states: {
        _currentRowKey: vue.Ref<string | null, string | null>;
        currentRow: vue.Ref<any, any>;
        expandRowKeys: vue.Ref<string[], string[]>;
        treeData: vue.Ref<Record<string, TreeData>, Record<string, TreeData>>;
        indent: vue.Ref<number, number>;
        lazy: vue.Ref<boolean, boolean>;
        lazyTreeNodeMap: vue.Ref<Record<string, any[]>, Record<string, any[]>>;
        lazyColumnIdentifier: vue.Ref<string, string>;
        childrenColumnName: vue.Ref<string, string>;
        checkStrictly: vue.Ref<boolean, boolean>;
        expandRows: vue.Ref<any[], any[]>;
        defaultExpandAll: vue.Ref<boolean, boolean>;
        tableSize: vue.Ref<any, any>;
        rowKey: vue.Ref<string | null, string | null>;
        data: vue.Ref<any[], any[]>;
        _data: vue.Ref<any[], any[]>;
        isComplex: vue.Ref<boolean, boolean>;
        _columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        originColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        leafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        updateOrderFns: (() => void)[];
        leafColumnsLength: vue.Ref<number, number>;
        fixedLeafColumnsLength: vue.Ref<number, number>;
        rightFixedLeafColumnsLength: vue.Ref<number, number>;
        isAllSelected: vue.Ref<boolean, boolean>;
        selection: vue.Ref<any[], any[]>;
        reserveSelection: vue.Ref<boolean, boolean>;
        selectOnIndeterminate: vue.Ref<boolean, boolean>;
        selectable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        rowExpandable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        filters: vue.Ref<StoreFilter, StoreFilter>;
        filteredData: vue.Ref<any[] | null, any[] | null>;
        sortingColumn: vue.Ref<TableColumnCtx<any> | null, TableColumnCtx<any> | null>;
        sortProp: vue.Ref<string | null, string | null>;
        sortOrder: vue.Ref<string | number | null, string | number | null>;
        hoverRow: vue.Ref<any, any>;
      }, options: Sort): void;
      changeSortCondition(states: {
        _currentRowKey: vue.Ref<string | null, string | null>;
        currentRow: vue.Ref<any, any>;
        expandRowKeys: vue.Ref<string[], string[]>;
        treeData: vue.Ref<Record<string, TreeData>, Record<string, TreeData>>;
        indent: vue.Ref<number, number>;
        lazy: vue.Ref<boolean, boolean>;
        lazyTreeNodeMap: vue.Ref<Record<string, any[]>, Record<string, any[]>>;
        lazyColumnIdentifier: vue.Ref<string, string>;
        childrenColumnName: vue.Ref<string, string>;
        checkStrictly: vue.Ref<boolean, boolean>;
        expandRows: vue.Ref<any[], any[]>;
        defaultExpandAll: vue.Ref<boolean, boolean>;
        tableSize: vue.Ref<any, any>;
        rowKey: vue.Ref<string | null, string | null>;
        data: vue.Ref<any[], any[]>;
        _data: vue.Ref<any[], any[]>;
        isComplex: vue.Ref<boolean, boolean>;
        _columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        originColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        leafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        updateOrderFns: (() => void)[];
        leafColumnsLength: vue.Ref<number, number>;
        fixedLeafColumnsLength: vue.Ref<number, number>;
        rightFixedLeafColumnsLength: vue.Ref<number, number>;
        isAllSelected: vue.Ref<boolean, boolean>;
        selection: vue.Ref<any[], any[]>;
        reserveSelection: vue.Ref<boolean, boolean>;
        selectOnIndeterminate: vue.Ref<boolean, boolean>;
        selectable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        rowExpandable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        filters: vue.Ref<StoreFilter, StoreFilter>;
        filteredData: vue.Ref<any[] | null, any[] | null>;
        sortingColumn: vue.Ref<TableColumnCtx<any> | null, TableColumnCtx<any> | null>;
        sortProp: vue.Ref<string | null, string | null>;
        sortOrder: vue.Ref<string | number | null, string | number | null>;
        hoverRow: vue.Ref<any, any>;
      }, options: Sort): void;
      filterChange(_states: {
        _currentRowKey: vue.Ref<string | null, string | null>;
        currentRow: vue.Ref<any, any>;
        expandRowKeys: vue.Ref<string[], string[]>;
        treeData: vue.Ref<Record<string, TreeData>, Record<string, TreeData>>;
        indent: vue.Ref<number, number>;
        lazy: vue.Ref<boolean, boolean>;
        lazyTreeNodeMap: vue.Ref<Record<string, any[]>, Record<string, any[]>>;
        lazyColumnIdentifier: vue.Ref<string, string>;
        childrenColumnName: vue.Ref<string, string>;
        checkStrictly: vue.Ref<boolean, boolean>;
        expandRows: vue.Ref<any[], any[]>;
        defaultExpandAll: vue.Ref<boolean, boolean>;
        tableSize: vue.Ref<any, any>;
        rowKey: vue.Ref<string | null, string | null>;
        data: vue.Ref<any[], any[]>;
        _data: vue.Ref<any[], any[]>;
        isComplex: vue.Ref<boolean, boolean>;
        _columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        originColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        leafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        updateOrderFns: (() => void)[];
        leafColumnsLength: vue.Ref<number, number>;
        fixedLeafColumnsLength: vue.Ref<number, number>;
        rightFixedLeafColumnsLength: vue.Ref<number, number>;
        isAllSelected: vue.Ref<boolean, boolean>;
        selection: vue.Ref<any[], any[]>;
        reserveSelection: vue.Ref<boolean, boolean>;
        selectOnIndeterminate: vue.Ref<boolean, boolean>;
        selectable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        rowExpandable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        filters: vue.Ref<StoreFilter, StoreFilter>;
        filteredData: vue.Ref<any[] | null, any[] | null>;
        sortingColumn: vue.Ref<TableColumnCtx<any> | null, TableColumnCtx<any> | null>;
        sortProp: vue.Ref<string | null, string | null>;
        sortOrder: vue.Ref<string | number | null, string | number | null>;
        hoverRow: vue.Ref<any, any>;
      }, options: Filter<any>): void;
      toggleAllSelection(): void;
      rowSelectedChanged(_states: {
        _currentRowKey: vue.Ref<string | null, string | null>;
        currentRow: vue.Ref<any, any>;
        expandRowKeys: vue.Ref<string[], string[]>;
        treeData: vue.Ref<Record<string, TreeData>, Record<string, TreeData>>;
        indent: vue.Ref<number, number>;
        lazy: vue.Ref<boolean, boolean>;
        lazyTreeNodeMap: vue.Ref<Record<string, any[]>, Record<string, any[]>>;
        lazyColumnIdentifier: vue.Ref<string, string>;
        childrenColumnName: vue.Ref<string, string>;
        checkStrictly: vue.Ref<boolean, boolean>;
        expandRows: vue.Ref<any[], any[]>;
        defaultExpandAll: vue.Ref<boolean, boolean>;
        tableSize: vue.Ref<any, any>;
        rowKey: vue.Ref<string | null, string | null>;
        data: vue.Ref<any[], any[]>;
        _data: vue.Ref<any[], any[]>;
        isComplex: vue.Ref<boolean, boolean>;
        _columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        originColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        leafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        updateOrderFns: (() => void)[];
        leafColumnsLength: vue.Ref<number, number>;
        fixedLeafColumnsLength: vue.Ref<number, number>;
        rightFixedLeafColumnsLength: vue.Ref<number, number>;
        isAllSelected: vue.Ref<boolean, boolean>;
        selection: vue.Ref<any[], any[]>;
        reserveSelection: vue.Ref<boolean, boolean>;
        selectOnIndeterminate: vue.Ref<boolean, boolean>;
        selectable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        rowExpandable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        filters: vue.Ref<StoreFilter, StoreFilter>;
        filteredData: vue.Ref<any[] | null, any[] | null>;
        sortingColumn: vue.Ref<TableColumnCtx<any> | null, TableColumnCtx<any> | null>;
        sortProp: vue.Ref<string | null, string | null>;
        sortOrder: vue.Ref<string | number | null, string | number | null>;
        hoverRow: vue.Ref<any, any>;
      }, row: any): void;
      setHoverRow(states: {
        _currentRowKey: vue.Ref<string | null, string | null>;
        currentRow: vue.Ref<any, any>;
        expandRowKeys: vue.Ref<string[], string[]>;
        treeData: vue.Ref<Record<string, TreeData>, Record<string, TreeData>>;
        indent: vue.Ref<number, number>;
        lazy: vue.Ref<boolean, boolean>;
        lazyTreeNodeMap: vue.Ref<Record<string, any[]>, Record<string, any[]>>;
        lazyColumnIdentifier: vue.Ref<string, string>;
        childrenColumnName: vue.Ref<string, string>;
        checkStrictly: vue.Ref<boolean, boolean>;
        expandRows: vue.Ref<any[], any[]>;
        defaultExpandAll: vue.Ref<boolean, boolean>;
        tableSize: vue.Ref<any, any>;
        rowKey: vue.Ref<string | null, string | null>;
        data: vue.Ref<any[], any[]>;
        _data: vue.Ref<any[], any[]>;
        isComplex: vue.Ref<boolean, boolean>;
        _columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        originColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        leafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        updateOrderFns: (() => void)[];
        leafColumnsLength: vue.Ref<number, number>;
        fixedLeafColumnsLength: vue.Ref<number, number>;
        rightFixedLeafColumnsLength: vue.Ref<number, number>;
        isAllSelected: vue.Ref<boolean, boolean>;
        selection: vue.Ref<any[], any[]>;
        reserveSelection: vue.Ref<boolean, boolean>;
        selectOnIndeterminate: vue.Ref<boolean, boolean>;
        selectable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        rowExpandable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        filters: vue.Ref<StoreFilter, StoreFilter>;
        filteredData: vue.Ref<any[] | null, any[] | null>;
        sortingColumn: vue.Ref<TableColumnCtx<any> | null, TableColumnCtx<any> | null>;
        sortProp: vue.Ref<string | null, string | null>;
        sortOrder: vue.Ref<string | number | null, string | number | null>;
        hoverRow: vue.Ref<any, any>;
      }, row: any): void;
      setCurrentRow(_states: {
        _currentRowKey: vue.Ref<string | null, string | null>;
        currentRow: vue.Ref<any, any>;
        expandRowKeys: vue.Ref<string[], string[]>;
        treeData: vue.Ref<Record<string, TreeData>, Record<string, TreeData>>;
        indent: vue.Ref<number, number>;
        lazy: vue.Ref<boolean, boolean>;
        lazyTreeNodeMap: vue.Ref<Record<string, any[]>, Record<string, any[]>>;
        lazyColumnIdentifier: vue.Ref<string, string>;
        childrenColumnName: vue.Ref<string, string>;
        checkStrictly: vue.Ref<boolean, boolean>;
        expandRows: vue.Ref<any[], any[]>;
        defaultExpandAll: vue.Ref<boolean, boolean>;
        tableSize: vue.Ref<any, any>;
        rowKey: vue.Ref<string | null, string | null>;
        data: vue.Ref<any[], any[]>;
        _data: vue.Ref<any[], any[]>;
        isComplex: vue.Ref<boolean, boolean>;
        _columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        originColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        leafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        fixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        rightFixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
        updateOrderFns: (() => void)[];
        leafColumnsLength: vue.Ref<number, number>;
        fixedLeafColumnsLength: vue.Ref<number, number>;
        rightFixedLeafColumnsLength: vue.Ref<number, number>;
        isAllSelected: vue.Ref<boolean, boolean>;
        selection: vue.Ref<any[], any[]>;
        reserveSelection: vue.Ref<boolean, boolean>;
        selectOnIndeterminate: vue.Ref<boolean, boolean>;
        selectable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        rowExpandable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
        filters: vue.Ref<StoreFilter, StoreFilter>;
        filteredData: vue.Ref<any[] | null, any[] | null>;
        sortingColumn: vue.Ref<TableColumnCtx<any> | null, TableColumnCtx<any> | null>;
        sortProp: vue.Ref<string | null, string | null>;
        sortOrder: vue.Ref<string | number | null, string | number | null>;
        hoverRow: vue.Ref<any, any>;
      }, row: any): void;
    };
    commit: (name: "sort" | "setData" | "insertColumn" | "updateColumnOrder" | "removeColumn" | "changeSortCondition" | "filterChange" | "toggleAllSelection" | "rowSelectedChanged" | "setHoverRow" | "setCurrentRow", ...args: any[]) => void;
    updateTableScrollY: () => void;
    assertRowKey: () => void;
    updateColumns: () => void;
    scheduleLayout: (needUpdateColumns?: boolean, immediate?: boolean) => void;
    isSelected: (row: any) => boolean;
    clearSelection: () => void;
    cleanSelection: () => void;
    getSelectionRows: () => any[];
    toggleRowSelection: (row: any, selected?: boolean, emitChange?: boolean, ignoreSelectable?: boolean) => void;
    _toggleAllSelection: () => void;
    toggleAllSelection: (() => void) | null;
    updateAllSelected: () => void;
    updateFilters: (column: TableColumnCtx<any>, values: string[]) => Record<string, string[]>;
    updateCurrentRow: (_currentRow: any) => void;
    updateSort: (column: TableColumnCtx<any> | null, prop: string | null, order: TableSortOrder | null) => void;
    execFilter: () => void;
    execSort: () => void;
    execQuery: (ignore?: {
      filter: boolean;
    } | undefined) => void;
    clearFilter: (columnKeys?: string[] | string) => void;
    clearSort: () => void;
    toggleRowExpansion: (row: any, expanded?: boolean) => void;
    setExpandRowKeysAdapter: (val: string[]) => void;
    setCurrentRowKey: (key: string) => void;
    toggleRowExpansionAdapter: (row: any, expanded?: boolean) => void;
    isRowExpanded: (row: any) => boolean;
    updateExpandRows: () => void;
    updateCurrentRowData: () => void;
    loadOrToggle: (row: any) => void;
    updateTreeData: (ifChangeExpandRowKeys?: boolean, ifExpandAll?: boolean) => void;
    updateKeyChildren: (key: string, data: any[]) => void;
    states: {
      _currentRowKey: vue.Ref<string | null, string | null>;
      currentRow: vue.Ref<any, any>;
      expandRowKeys: vue.Ref<string[], string[]>;
      treeData: vue.Ref<Record<string, TreeData>, Record<string, TreeData>>;
      indent: vue.Ref<number, number>;
      lazy: vue.Ref<boolean, boolean>;
      lazyTreeNodeMap: vue.Ref<Record<string, any[]>, Record<string, any[]>>;
      lazyColumnIdentifier: vue.Ref<string, string>;
      childrenColumnName: vue.Ref<string, string>;
      checkStrictly: vue.Ref<boolean, boolean>;
      expandRows: vue.Ref<any[], any[]>;
      defaultExpandAll: vue.Ref<boolean, boolean>;
      tableSize: vue.Ref<any, any>;
      rowKey: vue.Ref<string | null, string | null>;
      data: vue.Ref<any[], any[]>;
      _data: vue.Ref<any[], any[]>;
      isComplex: vue.Ref<boolean, boolean>;
      _columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
      originColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
      columns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
      fixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
      rightFixedColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
      leafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
      fixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
      rightFixedLeafColumns: vue.Ref<TableColumnCtx<any>[], TableColumnCtx<any>[]>;
      updateOrderFns: (() => void)[];
      leafColumnsLength: vue.Ref<number, number>;
      fixedLeafColumnsLength: vue.Ref<number, number>;
      rightFixedLeafColumnsLength: vue.Ref<number, number>;
      isAllSelected: vue.Ref<boolean, boolean>;
      selection: vue.Ref<any[], any[]>;
      reserveSelection: vue.Ref<boolean, boolean>;
      selectOnIndeterminate: vue.Ref<boolean, boolean>;
      selectable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
      rowExpandable: vue.Ref<((row: any, index: number) => boolean) | null, ((row: any, index: number) => boolean) | null>;
      filters: vue.Ref<StoreFilter, StoreFilter>;
      filteredData: vue.Ref<any[] | null, any[] | null>;
      sortingColumn: vue.Ref<TableColumnCtx<any> | null, TableColumnCtx<any> | null>;
      sortProp: vue.Ref<string | null, string | null>;
      sortOrder: vue.Ref<string | number | null, string | number | null>;
      hoverRow: vue.Ref<any, any>;
    };
    ns: {
      namespace: vue.ComputedRef<string>;
      b: (blockSuffix?: string) => string;
      e: (element?: string) => string;
      m: (modifier?: string) => string;
      be: (blockSuffix?: string, element?: string) => string;
      em: (element?: string, modifier?: string) => string;
      bm: (blockSuffix?: string, modifier?: string) => string;
      bem: (blockSuffix?: string, element?: string, modifier?: string) => string;
      is: {
        (name: string, state: boolean | undefined): string;
        (name: string): string;
      };
      cssVar: (object: Record<string, string>) => Record<string, string>;
      cssVarName: (name: string) => string;
      cssVarBlock: (object: Record<string, string>) => Record<string, string>;
      cssVarBlockName: (name: string) => string;
    };
    t: Translator;
  };
  columns: vue.ComputedRef<TableColumnCtx<any>[]>;
  handleHeaderFooterMousewheel: (_event: WheelEvent, data: any) => void;
  handleMouseLeave: () => void;
  tableId: string;
  tableSize: vue.ComputedRef<"" | "default" | "large" | "small">;
  isHidden: vue.Ref<boolean, boolean>;
  isEmpty: vue.ComputedRef<boolean>;
  renderExpanded: vue.Ref<RenderExpanded<any> | null, RenderExpanded<any> | null>;
  resizeProxyVisible: vue.Ref<boolean, boolean>;
  resizeState: vue.Ref<{
    width: null | number;
    height: null | number;
    headerHeight: null | number;
  }, {
    width: null | number;
    height: null | number;
    headerHeight: null | number;
  } | {
    width: null | number;
    height: null | number;
    headerHeight: null | number;
  }>;
  isGroup: vue.Ref<boolean, boolean>;
  bodyWidth: vue.ComputedRef<string>;
  tableBodyStyles: vue.ComputedRef<{
    width: string;
  }>;
  emptyBlockStyle: vue.ComputedRef<{
    width: string;
    height: string;
  } | undefined>;
  debouncedUpdateLayout: lodash_unified0.DebouncedFunc<() => void>;
  /**
   * @description used in single selection Table, set a certain row selected. If called without any parameter, it will clear selection
   */
  setCurrentRow: (row: any) => void;
  /**
   * @description returns the currently selected rows
   */
  getSelectionRows: () => any[];
  /**
   * @description used in multiple selection Table, toggle if a certain row is selected. With the second parameter, you can directly set if this row is selected
   */
  toggleRowSelection: (row: any, selected?: boolean, ignoreSelectable?: boolean) => void;
  /**
   * @description used in multiple selection Table, clear user selection
   */
  clearSelection: () => void;
  /**
   * @description clear filters of the columns whose `columnKey` are passed in. If no params, clear all filters
   */
  clearFilter: (columnKeys?: string[] | string) => void;
  /**
   * @description used in multiple selection Table, toggle select all and deselect all
   */
  toggleAllSelection: () => void;
  /**
   * @description used in expandable Table or tree Table, toggle if a certain row is expanded. With the second parameter, you can directly set if this row is expanded or collapsed
   */
  toggleRowExpansion: (row: any, expanded?: boolean) => void;
  /**
   * @description clear sorting, restore data to the original order
   */
  clearSort: () => void;
  /**
   * @description refresh the layout of Table. When the visibility of Table changes, you may need to call this method to get a correct layout
   */
  doLayout: () => void;
  /**
   * @description sort Table manually. Property `prop` is used to set sort column, property `order` is used to set sort order
   */
  sort: (prop: string, order: string) => void;
  /**
   * @description used in lazy Table, must set `rowKey`, update key children
   */
  updateKeyChildren: (key: string, data: any[]) => void;
  t: Translator;
  setDragVisible: (visible: boolean) => void;
  context: Table<any>;
  computedSumText: vue.ComputedRef<string>;
  computedEmptyText: vue.ComputedRef<string>;
  computedTooltipEffect: vue.ComputedRef<string | undefined>;
  computedTooltipOptions: vue.ComputedRef<Partial<Pick<UseTooltipProps, "effect" | "placement" | "popperClass" | "enterable" | "offset" | "popperOptions" | "showArrow" | "appendTo" | "transition" | "showAfter" | "hideAfter">> | undefined>;
  tableLayout: vue.ComputedRef<"auto" | "fixed">;
  scrollbarViewStyle: {
    display: string;
    verticalAlign: string;
  };
  scrollbarStyle: vue.ComputedRef<{
    height: string;
    maxHeight?: undefined;
  } | {
    maxHeight: string;
    height?: undefined;
  } | {
    height?: undefined;
    maxHeight?: undefined;
  }>;
  scrollBarRef: vue.Ref<any, any>;
  /**
   * @description scrolls to a particular set of coordinates
   */
  scrollTo: (options: ScrollToOptions | number, yCoord?: number) => void;
  /**
   * @description set horizontal scroll position
   */
  setScrollLeft: (left?: number) => void;
  /**
   * @description set vertical scroll position
   */
  setScrollTop: (top?: number) => void;
  /**
   * @description whether to allow drag the last column
   */
  allowDragLastColumn: boolean;
}, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, ("scroll" | "select" | "expand-change" | "select-all" | "current-change" | "selection-change" | "cell-mouse-enter" | "cell-mouse-leave" | "cell-contextmenu" | "cell-click" | "cell-dblclick" | "row-click" | "row-contextmenu" | "row-dblclick" | "header-click" | "header-contextmenu" | "sort-change" | "filter-change" | "header-dragend")[], "scroll" | "select" | "expand-change" | "select-all" | "current-change" | "selection-change" | "cell-mouse-enter" | "cell-mouse-leave" | "cell-contextmenu" | "cell-click" | "cell-dblclick" | "row-click" | "row-contextmenu" | "row-dblclick" | "header-click" | "header-contextmenu" | "sort-change" | "filter-change" | "header-dragend", vue.PublicProps, Readonly<vue.ExtractPropTypes<{
  data: {
    type: vue.PropType<any[]>;
    default: () => never[];
  };
  size: {
    readonly type: vue.PropType<EpPropMergeType<StringConstructor, "" | "default" | "large" | "small", never>>;
    readonly required: false;
    readonly validator: ((val: unknown) => boolean) | undefined;
    __epPropKey: true;
  };
  width: (NumberConstructor | StringConstructor)[];
  height: (NumberConstructor | StringConstructor)[];
  maxHeight: (NumberConstructor | StringConstructor)[];
  fit: {
    type: BooleanConstructor;
    default: boolean;
  };
  stripe: BooleanConstructor;
  border: BooleanConstructor;
  rowKey: vue.PropType<TableProps<any>["rowKey"]>;
  showHeader: {
    type: BooleanConstructor;
    default: boolean;
  };
  showSummary: BooleanConstructor;
  sumText: StringConstructor;
  summaryMethod: vue.PropType<TableProps<any>["summaryMethod"]>;
  rowClassName: vue.PropType<TableProps<any>["rowClassName"]>;
  rowStyle: vue.PropType<TableProps<any>["rowStyle"]>;
  cellClassName: vue.PropType<TableProps<any>["cellClassName"]>;
  cellStyle: vue.PropType<TableProps<any>["cellStyle"]>;
  headerRowClassName: vue.PropType<TableProps<any>["headerRowClassName"]>;
  headerRowStyle: vue.PropType<TableProps<any>["headerRowStyle"]>;
  headerCellClassName: vue.PropType<TableProps<any>["headerCellClassName"]>;
  headerCellStyle: vue.PropType<TableProps<any>["headerCellStyle"]>;
  highlightCurrentRow: BooleanConstructor;
  currentRowKey: (NumberConstructor | StringConstructor)[];
  emptyText: StringConstructor;
  expandRowKeys: vue.PropType<TableProps<any>["expandRowKeys"]>;
  defaultExpandAll: BooleanConstructor;
  rowExpandable: {
    type: vue.PropType<TableProps<any>["rowExpandable"]>;
  };
  defaultSort: vue.PropType<TableProps<any>["defaultSort"]>;
  tooltipEffect: StringConstructor;
  tooltipOptions: vue.PropType<TableProps<any>["tooltipOptions"]>;
  spanMethod: vue.PropType<TableProps<any>["spanMethod"]>;
  selectOnIndeterminate: {
    type: BooleanConstructor;
    default: boolean;
  };
  indent: {
    type: NumberConstructor;
    default: number;
  };
  treeProps: {
    type: vue.PropType<TableProps<any>["treeProps"]>;
    default: () => {
      hasChildren: string;
      children: string;
      checkStrictly: boolean;
    };
  };
  lazy: BooleanConstructor;
  load: vue.PropType<TableProps<any>["load"]>;
  style: {
    type: vue.PropType<TableProps<any>["style"]>;
    default: () => {};
  };
  className: {
    type: StringConstructor;
    default: string;
  };
  tableLayout: {
    type: vue.PropType<"auto" | "fixed">;
    default: string;
  };
  scrollbarAlwaysOn: BooleanConstructor;
  flexible: BooleanConstructor;
  showOverflowTooltip: {
    type: vue.PropType<TableProps<any>["showOverflowTooltip"]>;
    default: undefined;
  };
  tooltipFormatter: vue.PropType<TableProps<any>["tooltipFormatter"]>;
  appendFilterPanelTo: StringConstructor;
  scrollbarTabindex: {
    type: (NumberConstructor | StringConstructor)[];
    default: undefined;
  };
  allowDragLastColumn: {
    type: BooleanConstructor;
    default: boolean;
  };
  preserveExpandedContent: BooleanConstructor;
  nativeScrollbar: BooleanConstructor;
}>> & Readonly<{
  "onExpand-change"?: ((...args: any[]) => any) | undefined;
  onSelect?: ((...args: any[]) => any) | undefined;
  onScroll?: ((...args: any[]) => any) | undefined;
  "onCurrent-change"?: ((...args: any[]) => any) | undefined;
  "onSelect-all"?: ((...args: any[]) => any) | undefined;
  "onSelection-change"?: ((...args: any[]) => any) | undefined;
  "onCell-mouse-enter"?: ((...args: any[]) => any) | undefined;
  "onCell-mouse-leave"?: ((...args: any[]) => any) | undefined;
  "onCell-contextmenu"?: ((...args: any[]) => any) | undefined;
  "onCell-click"?: ((...args: any[]) => any) | undefined;
  "onCell-dblclick"?: ((...args: any[]) => any) | undefined;
  "onRow-click"?: ((...args: any[]) => any) | undefined;
  "onRow-contextmenu"?: ((...args: any[]) => any) | undefined;
  "onRow-dblclick"?: ((...args: any[]) => any) | undefined;
  "onHeader-click"?: ((...args: any[]) => any) | undefined;
  "onHeader-contextmenu"?: ((...args: any[]) => any) | undefined;
  "onSort-change"?: ((...args: any[]) => any) | undefined;
  "onFilter-change"?: ((...args: any[]) => any) | undefined;
  "onHeader-dragend"?: ((...args: any[]) => any) | undefined;
}>, {
  lazy: boolean;
  border: boolean;
  data: any[];
  style: vue.StyleValue;
  className: string;
  tableLayout: "auto" | "fixed";
  scrollbarAlwaysOn: boolean;
  fit: boolean;
  allowDragLastColumn: boolean;
  stripe: boolean;
  treeProps: TreeProps | undefined;
  showOverflowTooltip: boolean | Partial<Pick<UseTooltipProps, "effect" | "placement" | "popperClass" | "enterable" | "offset" | "popperOptions" | "showArrow" | "appendTo" | "transition" | "showAfter" | "hideAfter">> | undefined;
  showHeader: boolean;
  showSummary: boolean;
  highlightCurrentRow: boolean;
  defaultExpandAll: boolean;
  selectOnIndeterminate: boolean;
  indent: number;
  flexible: boolean;
  scrollbarTabindex: string | number;
  preserveExpandedContent: boolean;
  nativeScrollbar: boolean;
}, {}, {
  TableHeader: vue.DefineComponent<vue.ExtractPropTypes<{
    fixed: {
      type: StringConstructor;
      default: string;
    };
    store: {
      required: true;
      type: vue.PropType<TableHeaderProps<any>["store"]>;
    };
    border: BooleanConstructor;
    defaultSort: {
      type: vue.PropType<TableHeaderProps<any>["defaultSort"]>;
      default: () => {
        prop: string;
        order: string;
      };
    };
    appendFilterPanelTo: {
      type: StringConstructor;
    };
    allowDragLastColumn: {
      type: BooleanConstructor;
    };
  }>, {
    ns: {
      namespace: vue.ComputedRef<string>;
      b: (blockSuffix?: string) => string;
      e: (element?: string) => string;
      m: (modifier?: string) => string;
      be: (blockSuffix?: string, element?: string) => string;
      em: (element?: string, modifier?: string) => string;
      bm: (blockSuffix?: string, modifier?: string) => string;
      bem: (blockSuffix?: string, element?: string, modifier?: string) => string;
      is: {
        (name: string, state: boolean | undefined): string;
        (name: string): string;
      };
      cssVar: (object: Record<string, string>) => Record<string, string>;
      cssVarName: (name: string) => string;
      cssVarBlock: (object: Record<string, string>) => Record<string, string>;
      cssVarBlockName: (name: string) => string;
    };
    t: Translator;
    filterPanels: vue.Ref<{}, {}>;
    onColumnsChange: (layout: TableLayout<DefaultRow>) => void;
    onScrollableChange: (layout: TableLayout<DefaultRow>) => void;
    columnRows: vue.ComputedRef<TableColumnCtx<any>[][]>;
    getHeaderRowClass: (rowIndex: number) => string;
    getHeaderRowStyle: (rowIndex: number) => any;
    getHeaderCellClass: (rowIndex: number, columnIndex: number, row: any, column: TableColumnCtx<any>) => string;
    getHeaderCellStyle: (rowIndex: number, columnIndex: number, row: any, column: TableColumnCtx<any>) => vue.CSSProperties;
    handleHeaderClick: (event: Event, column: TableColumnCtx<any>) => void;
    handleHeaderContextMenu: (event: Event, column: TableColumnCtx<any>) => void;
    handleMouseDown: (event: MouseEvent, column: TableColumnCtx<any>) => void;
    handleMouseMove: (event: MouseEvent, column: TableColumnCtx<any>) => void;
    handleMouseOut: () => void;
    handleSortClick: (event: Event, column: TableColumnCtx<any>, givenOrder?: TableSortOrder | boolean) => void;
    handleFilterClick: (event: Event) => void;
    isGroup: vue.ComputedRef<boolean>;
    toggleAllSelection: (event: Event) => void;
    saveIndexSelection: vue.Reactive<Map<any, any>>;
    isTableLayoutAuto: boolean;
    theadRef: vue.Ref<any, any>;
    updateFixedColumnStyle: () => void;
  }, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {}, string, vue.PublicProps, Readonly<vue.ExtractPropTypes<{
    fixed: {
      type: StringConstructor;
      default: string;
    };
    store: {
      required: true;
      type: vue.PropType<TableHeaderProps<any>["store"]>;
    };
    border: BooleanConstructor;
    defaultSort: {
      type: vue.PropType<TableHeaderProps<any>["defaultSort"]>;
      default: () => {
        prop: string;
        order: string;
      };
    };
    appendFilterPanelTo: {
      type: StringConstructor;
    };
    allowDragLastColumn: {
      type: BooleanConstructor;
    };
  }>> & Readonly<{}>, {
    border: boolean;
    fixed: string;
    defaultSort: Sort;
    allowDragLastColumn: boolean;
  }, {}, {
    ElCheckbox: {
      new (...args: any[]): vue.CreateComponentPublicInstanceWithMixins<Readonly<CheckboxProps> & Readonly<{
        onChange?: ((val: CheckboxValueType) => any) | undefined;
        "onUpdate:modelValue"?: ((val: CheckboxValueType) => any) | undefined;
      }>, {}, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
        change: (val: CheckboxValueType) => void;
        "update:modelValue": (val: CheckboxValueType) => void;
      }, vue.PublicProps, {
        value: string | boolean | number | object;
        label: string | boolean | number | object;
        disabled: boolean;
        validateEvent: boolean;
        modelValue: number | string | boolean;
        id: string;
        name: string;
        trueValue: string | number;
        falseValue: string | number;
        trueLabel: string | number;
        falseLabel: string | number;
      }, false, {}, {}, vue.GlobalComponents, vue.GlobalDirectives, string, {}, any, vue.ComponentProvideOptions, {
        P: {};
        B: {};
        D: {};
        C: {};
        M: {};
        Defaults: {};
      }, Readonly<CheckboxProps> & Readonly<{
        onChange?: ((val: CheckboxValueType) => any) | undefined;
        "onUpdate:modelValue"?: ((val: CheckboxValueType) => any) | undefined;
      }>, {}, {}, {}, {}, {
        value: string | boolean | number | object;
        label: string | boolean | number | object;
        disabled: boolean;
        validateEvent: boolean;
        modelValue: number | string | boolean;
        id: string;
        name: string;
        trueValue: string | number;
        falseValue: string | number;
        trueLabel: string | number;
        falseLabel: string | number;
      }>;
      __isFragment?: never;
      __isTeleport?: never;
      __isSuspense?: never;
    } & vue.ComponentOptionsBase<Readonly<CheckboxProps> & Readonly<{
      onChange?: ((val: CheckboxValueType) => any) | undefined;
      "onUpdate:modelValue"?: ((val: CheckboxValueType) => any) | undefined;
    }>, {}, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
      change: (val: CheckboxValueType) => void;
      "update:modelValue": (val: CheckboxValueType) => void;
    }, string, {
      value: string | boolean | number | object;
      label: string | boolean | number | object;
      disabled: boolean;
      validateEvent: boolean;
      modelValue: number | string | boolean;
      id: string;
      name: string;
      trueValue: string | number;
      falseValue: string | number;
      trueLabel: string | number;
      falseLabel: string | number;
    }, {}, string, {}, vue.GlobalComponents, vue.GlobalDirectives, string, vue.ComponentProvideOptions> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & (new () => {
      $slots: {
        default?: (props: {}) => any;
      };
    }) & vue.ObjectPlugin & {
      setPropsDefaults: (defaults: Partial<{
        readonly modelValue?: (number | string | boolean) | undefined;
        readonly label?: (string | boolean | number | object) | undefined;
        readonly value?: (string | boolean | number | object) | undefined;
        readonly indeterminate?: boolean | undefined;
        readonly disabled?: boolean | undefined;
        readonly checked?: boolean | undefined;
        readonly name?: string | undefined;
        readonly trueValue?: (string | number) | undefined;
        readonly falseValue?: (string | number) | undefined;
        readonly trueLabel?: (string | number) | undefined;
        readonly falseLabel?: (string | number) | undefined;
        readonly id?: string | undefined;
        readonly border?: boolean | undefined;
        readonly size?: ComponentSize | undefined;
        readonly tabindex?: (string | number) | undefined;
        readonly validateEvent?: boolean | undefined;
        readonly ariaLabel?: string | undefined;
        readonly ariaControls?: string | undefined;
        readonly onChange?: ((val: CheckboxValueType) => any) | undefined;
        readonly "onUpdate:modelValue"?: ((val: CheckboxValueType) => any) | undefined;
      } & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps>) => void;
    } & {
      CheckboxButton: typeof _default$1;
      CheckboxGroup: typeof _default$2;
    };
  }, {}, string, vue.ComponentProvideOptions, true, {}, any>;
  TableBody: vue.DefineComponent<vue.ExtractPropTypes<{
    store: {
      required: boolean;
      type: vue.PropType<TableBodyProps<any>["store"]>;
    };
    stripe: BooleanConstructor;
    tooltipEffect: StringConstructor;
    tooltipOptions: {
      type: vue.PropType<TableBodyProps<any>["tooltipOptions"]>;
    };
    context: {
      default: () => {};
      type: vue.PropType<TableBodyProps<any>["context"]>;
    };
    rowClassName: vue.PropType<TableBodyProps<any>["rowClassName"]>;
    rowStyle: vue.PropType<TableBodyProps<any>["rowStyle"]>;
    fixed: {
      type: StringConstructor;
      default: string;
    };
    highlight: BooleanConstructor;
  }>, {
    ns: {
      namespace: vue.ComputedRef<string>;
      b: (blockSuffix?: string) => string;
      e: (element?: string) => string;
      m: (modifier?: string) => string;
      be: (blockSuffix?: string, element?: string) => string;
      em: (element?: string, modifier?: string) => string;
      bm: (blockSuffix?: string, modifier?: string) => string;
      bem: (blockSuffix?: string, element?: string, modifier?: string) => string;
      is: {
        (name: string, state: boolean | undefined): string;
        (name: string): string;
      };
      cssVar: (object: Record<string, string>) => Record<string, string>;
      cssVarName: (name: string) => string;
      cssVarBlock: (object: Record<string, string>) => Record<string, string>;
      cssVarBlockName: (name: string) => string;
    };
    onColumnsChange: (layout: TableLayout<DefaultRow>) => void;
    onScrollableChange: (layout: TableLayout<DefaultRow>) => void;
    wrappedRowRender: (row: any, $index: number) => vue.VNode<vue.RendererNode, vue.RendererElement, {
      [key: string]: any;
    }> | vue.VNode<vue.RendererNode, vue.RendererElement, {
      [key: string]: any;
    }>[] | vue.VNode<vue.RendererNode, vue.RendererElement, {
      [key: string]: any;
    }>[][];
    tooltipContent: vue.Ref<string, string>;
    tooltipTrigger: vue.Ref<vue.VNode<vue.RendererNode, vue.RendererElement, {
      [key: string]: any;
    }>, vue.VNode<vue.RendererNode, vue.RendererElement, {
      [key: string]: any;
    }>>;
  }, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {}, string, vue.PublicProps, Readonly<vue.ExtractPropTypes<{
    store: {
      required: boolean;
      type: vue.PropType<TableBodyProps<any>["store"]>;
    };
    stripe: BooleanConstructor;
    tooltipEffect: StringConstructor;
    tooltipOptions: {
      type: vue.PropType<TableBodyProps<any>["tooltipOptions"]>;
    };
    context: {
      default: () => {};
      type: vue.PropType<TableBodyProps<any>["context"]>;
    };
    rowClassName: vue.PropType<TableBodyProps<any>["rowClassName"]>;
    rowStyle: vue.PropType<TableBodyProps<any>["rowStyle"]>;
    fixed: {
      type: StringConstructor;
      default: string;
    };
    highlight: BooleanConstructor;
  }>> & Readonly<{}>, {
    fixed: string;
    highlight: boolean;
    context: Table<any>;
    stripe: boolean;
  }, {}, {}, {}, string, vue.ComponentProvideOptions, true, {}, any>;
  TableFooter: vue.DefineComponent<vue.ExtractPropTypes<{
    fixed: {
      type: StringConstructor;
      default: string;
    };
    store: {
      required: true;
      type: vue.PropType<TableFooter<any>["store"]>;
    };
    summaryMethod: vue.PropType<TableFooter<any>["summaryMethod"]>;
    sumText: StringConstructor;
    border: BooleanConstructor;
    defaultSort: {
      type: vue.PropType<TableFooter<any>["defaultSort"]>;
      default: () => {
        prop: string;
        order: string;
      };
    };
  }>, {
    ns: {
      namespace: vue.ComputedRef<string>;
      b: (blockSuffix?: string) => string;
      e: (element?: string) => string;
      m: (modifier?: string) => string;
      be: (blockSuffix?: string, element?: string) => string;
      em: (element?: string, modifier?: string) => string;
      bm: (blockSuffix?: string, modifier?: string) => string;
      bem: (blockSuffix?: string, element?: string, modifier?: string) => string;
      is: {
        (name: string, state: boolean | undefined): string;
        (name: string): string;
      };
      cssVar: (object: Record<string, string>) => Record<string, string>;
      cssVarName: (name: string) => string;
      cssVarBlock: (object: Record<string, string>) => Record<string, string>;
      cssVarBlockName: (name: string) => string;
    };
    onScrollableChange: (layout: TableLayout<any>) => void;
    onColumnsChange: (layout: TableLayout<any>) => void;
    getCellClasses: (columns: TableColumnCtx<any>[], cellIndex: number) => string[];
    getCellStyles: (column: TableColumnCtx<any>, cellIndex: number) => vue.CSSProperties | undefined;
    columns: vue.ComputedRef<TableColumnCtx<DefaultRow>[]>;
  }, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {}, string, vue.PublicProps, Readonly<vue.ExtractPropTypes<{
    fixed: {
      type: StringConstructor;
      default: string;
    };
    store: {
      required: true;
      type: vue.PropType<TableFooter<any>["store"]>;
    };
    summaryMethod: vue.PropType<TableFooter<any>["summaryMethod"]>;
    sumText: StringConstructor;
    border: BooleanConstructor;
    defaultSort: {
      type: vue.PropType<TableFooter<any>["defaultSort"]>;
      default: () => {
        prop: string;
        order: string;
      };
    };
  }>> & Readonly<{}>, {
    border: boolean;
    fixed: string;
    defaultSort: Sort;
  }, {}, {}, {}, string, vue.ComponentProvideOptions, true, {}, any>;
  ElScrollbar: SFCWithInstall<{
    new (...args: any[]): vue.CreateComponentPublicInstanceWithMixins<Readonly<ScrollbarProps> & Readonly<{
      onScroll?: ((args_0: {
        scrollTop: number;
        scrollLeft: number;
      }) => any) | undefined;
      "onEnd-reached"?: ((direction: ScrollbarDirection) => any) | undefined;
    }>, {
      wrapRef: vue.Ref<HTMLDivElement | undefined, HTMLDivElement | undefined>;
      update: () => void;
      scrollTo: {
        (xCord: number, yCord?: number): void;
        (options: ScrollToOptions): void;
      };
      setScrollTop: (value: number) => void;
      setScrollLeft: (value: number) => void;
      handleScroll: () => void;
    }, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
      scroll: (args_0: {
        scrollTop: number;
        scrollLeft: number;
      }) => void;
      "end-reached": (direction: ScrollbarDirection) => void;
    }, vue.PublicProps, {
      height: number | string;
      maxHeight: number | string;
      tabindex: number | string;
      tag: keyof HTMLElementTagNameMap | (string & {});
      distance: number;
      wrapStyle: string | false | vue.CSSProperties | vue.StyleValue[] | null;
      wrapClass: string | string[];
      viewClass: string | string[];
      viewStyle: string | false | vue.CSSProperties | vue.StyleValue[] | null;
      minSize: number;
    }, false, {}, {}, vue.GlobalComponents, vue.GlobalDirectives, string, {}, any, vue.ComponentProvideOptions, {
      P: {};
      B: {};
      D: {};
      C: {};
      M: {};
      Defaults: {};
    }, Readonly<ScrollbarProps> & Readonly<{
      onScroll?: ((args_0: {
        scrollTop: number;
        scrollLeft: number;
      }) => any) | undefined;
      "onEnd-reached"?: ((direction: ScrollbarDirection) => any) | undefined;
    }>, {
      wrapRef: vue.Ref<HTMLDivElement | undefined, HTMLDivElement | undefined>;
      update: () => void;
      scrollTo: {
        (xCord: number, yCord?: number): void;
        (options: ScrollToOptions): void;
      };
      setScrollTop: (value: number) => void;
      setScrollLeft: (value: number) => void;
      handleScroll: () => void;
    }, {}, {}, {}, {
      height: number | string;
      maxHeight: number | string;
      tabindex: number | string;
      tag: keyof HTMLElementTagNameMap | (string & {});
      distance: number;
      wrapStyle: string | false | vue.CSSProperties | vue.StyleValue[] | null;
      wrapClass: string | string[];
      viewClass: string | string[];
      viewStyle: string | false | vue.CSSProperties | vue.StyleValue[] | null;
      minSize: number;
    }>;
    __isFragment?: never;
    __isTeleport?: never;
    __isSuspense?: never;
  } & vue.ComponentOptionsBase<Readonly<ScrollbarProps> & Readonly<{
    onScroll?: ((args_0: {
      scrollTop: number;
      scrollLeft: number;
    }) => any) | undefined;
    "onEnd-reached"?: ((direction: ScrollbarDirection) => any) | undefined;
  }>, {
    wrapRef: vue.Ref<HTMLDivElement | undefined, HTMLDivElement | undefined>;
    update: () => void;
    scrollTo: {
      (xCord: number, yCord?: number): void;
      (options: ScrollToOptions): void;
    };
    setScrollTop: (value: number) => void;
    setScrollLeft: (value: number) => void;
    handleScroll: () => void;
  }, {}, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
    scroll: (args_0: {
      scrollTop: number;
      scrollLeft: number;
    }) => void;
    "end-reached": (direction: ScrollbarDirection) => void;
  }, string, {
    height: number | string;
    maxHeight: number | string;
    tabindex: number | string;
    tag: keyof HTMLElementTagNameMap | (string & {});
    distance: number;
    wrapStyle: string | false | vue.CSSProperties | vue.StyleValue[] | null;
    wrapClass: string | string[];
    viewClass: string | string[];
    viewStyle: string | false | vue.CSSProperties | vue.StyleValue[] | null;
    minSize: number;
  }, {}, string, {}, vue.GlobalComponents, vue.GlobalDirectives, string, vue.ComponentProvideOptions> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & (new () => {
    $slots: {
      default?: (props: {}) => any;
    };
  })>;
  hColgroup: typeof hColgroup;
}, {
  Mousewheel: vue.ObjectDirective<WheelElement, MousewheelCallback, string, any>;
}, string, vue.ComponentProvideOptions, true, {}, any>;
//#endregion
export { _default };