1 В избранное 0 Ответвления 0

OSCHINA-MIRROR/open-hand-choerodon-ui

Присоединиться к Gitlife
Откройте для себя и примите участие в публичных проектах с открытым исходным кодом с участием более 10 миллионов разработчиков. Приватные репозитории также полностью бесплатны :)
Присоединиться бесплатно
Клонировать/Скачать
MouseDown.tsx 1.7 КБ
Копировать Редактировать Исходные данные Просмотреть построчно История
Vink Dong Отправлено 7 лет назад f03bd7d
import * as React from 'react';
export type Size = { x: number, y: number, width: number, height: number, position: string };
export interface MouseDownProps {
children: (size?: Size) => React.ReactElement<any>;
}
export interface MouseDownState {
size?: Size;
}
export default class MouseDown extends React.Component<MouseDownProps> {
state: MouseDownState = {};
render() {
const element = this.props.children(this.state.size);
const { visible } = element.props;
const newProps = {
onMouseDown: wrapEvent(element, 'onMouseDown', this.show),
};
if (visible) {
Object.assign(newProps, {
onMouseUp: wrapEvent(element, 'onMouseUp', this.hide),
onMouseLeave: wrapEvent(element, 'onMouseLeave', this.hide),
onDragEnd: wrapEvent(element, 'onDragEnd', this.hide),
});
}
return React.cloneElement(element, newProps);
}
show = (e: React.MouseEvent<HTMLElement>) => {
const { currentTarget } = e;
const pos: ClientRect = currentTarget.getBoundingClientRect();
this.setState({
size: {
x: e.clientX - pos.left,
y: e.clientY - pos.top,
width: currentTarget.clientWidth,
height: currentTarget.clientHeight,
position: document.defaultView.getComputedStyle(currentTarget).position,
},
});
};
hide = () => {
this.setState({
size: undefined,
});
};
}
function wrapEvent(element: React.ReactElement<any>, eventName: string, callback: (e: React.MouseEvent<HTMLElement>) => void) {
return (e: React.MouseEvent<HTMLElement>) => {
const originalEvent = element.props[eventName];
if (originalEvent) {
originalEvent(e);
}
callback(e);
};
}

Опубликовать ( 0 )

Вы можете оставить комментарий после Вход в систему

1
https://gitlife.ru/oschina-mirror/open-hand-choerodon-ui.git
git@gitlife.ru:oschina-mirror/open-hand-choerodon-ui.git
oschina-mirror
open-hand-choerodon-ui
open-hand-choerodon-ui
release-0.2.2