import BaseFoundation, { DefaultAdapter } from '../base/foundation'; import warning from '../utils/warning'; export interface AvatarAdapter
, S = Record  {
    notifyImgState(isImgExist: boolean): void;
    notifyLeave(event: any): void;
    notifyEnter(event: any): void;
    setFocusVisible: (focusVisible: boolean) => void;
}
export default class AvatarFoundation , S = Record ) {
        super({ ...adapter });
    }
    init() { } // eslint-disable-line
    destroy() { } // eslint-disable-line
    handleImgLoadError() {
        const { onError } = this.getProps();
        const errorFlag = onError ? onError() : undefined;
        if (errorFlag !== false) {
            this._adapter.notifyImgState(false);
        }
    }
    handleEnter(e: any) {
        this._adapter.notifyEnter(e);
    }
    handleLeave(e: any) {
        this._adapter.notifyLeave(e);
    }
    handleFocusVisible = (event: any) => {
        const { target } = event;
        try {
            if (target.matches(':focus-visible')) {
                this._adapter.setFocusVisible(true);
            }
        } catch (error){
            warning(true, 'Warning: [Semi Avatar] The current browser does not support the focus-visible');
        }
    }
    handleBlur = () => {
        this._adapter.setFocusVisible(false);
    }
}