UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

147 lines (146 loc) 5.3 kB
/** * DevExtreme (esm/renovation/ui/draggable/container.js) * Version: 23.2.6 * Build date: Wed May 01 2024 * * Copyright (c) 2012 - 2024 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose"; import _extends from "@babel/runtime/helpers/esm/extends"; var _excluded = ["children", "className", "data", "disabled", "onDragEnd", "onDragMove", "onDragStart"]; import { createVNode, normalizeProps } from "inferno"; import { InfernoEffect, InfernoComponent } from "@devextreme/runtime/inferno"; import { start, move, end } from "../../../events/drag"; import eventsEngine from "../../../events/core/events_engine"; import { combineClasses } from "../../utils/combine_classes"; export var viewFunction = _ref => { var { cssClasses: cssClasses, props: { children: children }, restAttributes: restAttributes, widgetRef: widgetRef } = _ref; return normalizeProps(createVNode(1, "div", cssClasses, children, 0, _extends({}, restAttributes), null, widgetRef)) }; export var DraggableContainerProps = { className: "" }; import { createRef as infernoCreateRef } from "inferno"; export class DraggableContainer extends InfernoComponent { constructor(props) { super(props); this.widgetRef = infernoCreateRef(); this.state = { isDragging: false }; this.dragEffect = this.dragEffect.bind(this); this.dragStartHandler = this.dragStartHandler.bind(this); this.dragMoveHandler = this.dragMoveHandler.bind(this); this.dragEndHandler = this.dragEndHandler.bind(this); this.getEventArgs = this.getEventArgs.bind(this) } createEffects() { return [new InfernoEffect(this.dragEffect, [this.props.disabled, this.props.data, this.props.onDragStart, this.props.onDragMove, this.props.onDragEnd])] } updateEffects() { var _this$_effects$; null === (_this$_effects$ = this._effects[0]) || void 0 === _this$_effects$ ? void 0 : _this$_effects$.update([this.props.disabled, this.props.data, this.props.onDragStart, this.props.onDragMove, this.props.onDragEnd]) } dragEffect() { if (this.props.disabled) { return } eventsEngine.on(this.widgetRef.current, start, this.dragStartHandler); eventsEngine.on(this.widgetRef.current, move, this.dragMoveHandler); eventsEngine.on(this.widgetRef.current, end, this.dragEndHandler); return () => { eventsEngine.off(this.widgetRef.current, start, this.dragStartHandler); eventsEngine.off(this.widgetRef.current, move, this.dragMoveHandler); eventsEngine.off(this.widgetRef.current, end, this.dragEndHandler) } } get cssClasses() { var { className: className, disabled: disabled } = this.props; var classesMap = { [className]: !!className, "dx-draggable": true, "dx-draggable-dragging": this.state.isDragging, "dx-state-disabled": !!disabled }; return combineClasses(classesMap) } dragStartHandler(event) { this.setState(__state_argument => ({ isDragging: true })); var dragStartArgs = this.getEventArgs(event); var { onDragStart: onDragStart } = this.props; null === onDragStart || void 0 === onDragStart ? void 0 : onDragStart(dragStartArgs) } dragMoveHandler(event) { var dragMoveArgs = this.getEventArgs(event); var { onDragMove: onDragMove } = this.props; null === onDragMove || void 0 === onDragMove ? void 0 : onDragMove(dragMoveArgs) } dragEndHandler(event) { this.setState(__state_argument => ({ isDragging: false })); var dragEndArgs = this.getEventArgs(event); var { onDragEnd: onDragEnd } = this.props; null === onDragEnd || void 0 === onDragEnd ? void 0 : onDragEnd(dragEndArgs) } getEventArgs(e) { return { event: e, data: this.props.data, itemElement: this.widgetRef.current } } get restAttributes() { var _this$props = this.props, restProps = _objectWithoutPropertiesLoose(_this$props, _excluded); return restProps } render() { var props = this.props; return viewFunction({ props: _extends({}, props), isDragging: this.state.isDragging, widgetRef: this.widgetRef, cssClasses: this.cssClasses, dragStartHandler: this.dragStartHandler, dragMoveHandler: this.dragMoveHandler, dragEndHandler: this.dragEndHandler, getEventArgs: this.getEventArgs, restAttributes: this.restAttributes }) } } DraggableContainer.defaultProps = DraggableContainerProps;