🚀 Big News: Socket Acquires Coana to Bring Reachability Analysis to Every Appsec Team.Learn more
Socket
Sign inDemoInstall
Socket

@uiw/react-split

Package Overview
Dependencies
Maintainers
1
Versions
23
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@uiw/react-split - npm Package Compare versions

Comparing version

to
5.7.3

lib/dist.css

6

lib/cjs/index.js

@@ -28,2 +28,4 @@ "use strict";

var _excluded = ["prefixCls", "className", "children", "mode", "visiable", "lineBar", "disable", "onDragEnd", "onDragging"];
var Split = /*#__PURE__*/function (_React$Component) {

@@ -189,3 +191,3 @@ (0, _inherits2.default)(Split, _React$Component);

onDragging = _this$props2.onDragging,
other = (0, _objectWithoutProperties2.default)(_this$props2, ["prefixCls", "className", "children", "mode", "visiable", "lineBar", "disable", "onDragEnd", "onDragging"]);
other = (0, _objectWithoutProperties2.default)(_this$props2, _excluded);
var dragging = this.state.dragging;

@@ -232,2 +234,2 @@ var cls = [prefixCls, className, "".concat(prefixCls, "-").concat(mode), dragging ? 'dragging' : null].filter(Boolean).join(' ').trim();

module.exports = exports.default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["Split","props","state","dragging","warpper","paneNumber","startX","startY","move","target","boxWidth","boxHeight","preWidth","nextWidth","preHeight","nextHeight","preSize","nextSize","onDragEnd","bind","onDragging","removeEvent","window","removeEventListener","env","clientX","clientY","parentNode","prevTarget","previousElementSibling","nextTarget","nextElementSibling","clientWidth","clientHeight","addEventListener","setState","mode","x","y","style","width","height","prefixCls","className","children","visiable","lineBar","disable","other","cls","filter","Boolean","join","trim","child","React","Children","toArray","node","map","element","idx","Object","assign","visiableBar","includes","barProps","createElement","onMouseDown","cloneElement","Component","defaultProps"],"mappings":"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","sourcesContent":["import React from 'react';\nimport './style/index.less';\n\nexport interface SplitProps extends  Omit<React.HTMLAttributes<HTMLDivElement>, 'onDragEnd'> {\n  style?: React.CSSProperties;\n  className?: string;\n  prefixCls?: string;\n  /**\n   * 拖拽宽度/高度变化回调函数，宽度或者高度根据 mode 参数来确定\n   */\n  onDragging?: (preSize: number, nextSize: number, paneNumber: number) => void;\n  /**\n   * 拖拽结束的回调函数\n   */\n  onDragEnd?: (preSize: number, nextSize: number, paneNumber: number) => void;\n  /**\n   * 设置拖拽的工具条，为线条样式。\n   */\n  lineBar?: boolean;\n  /**\n   * 设置拖拽的工具条，是否可见\n   */\n  visiable?: boolean | number[];\n  /**\n   * 设置拖拽的工具条，禁用\n   */\n  disable?: boolean | number[];\n  /**\n   * 类型，可选值为 `horizontal` 或 `vertical`\n   */\n  mode?: 'horizontal' | 'vertical';\n}\nexport interface SplitState {\n  dragging: boolean;\n}\n\nexport default class Split extends React.Component<SplitProps, SplitState> {\n  public static defaultProps: SplitProps = {\n    prefixCls: 'w-split',\n    visiable: true,\n    mode: 'horizontal',\n  }\n  public state: SplitState = {\n    dragging: false,\n  }\n  public warpper!: HTMLDivElement | null;\n  public paneNumber!: number;\n  public startX!: number;\n  public startY!: number;\n  public move!: boolean;\n  public target!: HTMLDivElement;\n\n  public boxWidth!: number;\n  public boxHeight!: number;\n  public preWidth!: number;\n  public nextWidth!: number;\n  public preHeight!: number;\n  public nextHeight!: number;\n\n  public preSize!: number;\n  public nextSize!: number;\n  constructor(props: SplitProps) {\n    super(props);\n    this.onDragEnd = this.onDragEnd.bind(this);\n    this.onDragging = this.onDragging.bind(this);\n  }\n  public componentWillUnmount() {\n    this.removeEvent();\n  }\n  private removeEvent() {\n    window.removeEventListener('mousemove', this.onDragging, false);\n    window.removeEventListener('mouseup', this.onDragEnd, false);\n  }\n  onMouseDown(paneNumber: number, env: React.MouseEvent<HTMLDivElement, MouseEvent>) {\n    if (!env.target || !this.warpper) {\n      return;\n    }\n    this.paneNumber = paneNumber;\n    this.startX = env.clientX;\n    this.startY = env.clientY;\n    this.move = true;\n    this.target = (env.target as HTMLDivElement).parentNode as HTMLDivElement;\n    const prevTarget = this.target.previousElementSibling;\n    const nextTarget = this.target.nextElementSibling;\n    this.boxWidth = this.warpper.clientWidth;\n    this.boxHeight = this.warpper.clientHeight;\n    if (prevTarget) {\n      this.preWidth = prevTarget.clientWidth;\n      this.preHeight = prevTarget.clientHeight;\n    }\n    if (nextTarget) {\n      this.nextWidth = nextTarget.clientWidth;\n      this.nextHeight = nextTarget.clientHeight;\n    }\n    window.addEventListener('mousemove', this.onDragging);\n    window.addEventListener('mouseup', this.onDragEnd, false);\n    this.setState({ dragging: true });\n  }\n  onDragging(env: Event) {\n    if (!this.move) {\n      return;\n    }\n    if (!this.state.dragging) {\n      this.setState({ dragging: true });\n    }\n    const { mode, onDragging } = this.props;\n    const nextTarget = this.target.nextElementSibling as HTMLDivElement;\n    const prevTarget = this.target.previousElementSibling as HTMLDivElement;\n    const x = (env as MouseEvent).clientX - this.startX;\n    const y = (env as MouseEvent).clientY - this.startY;\n    this.preSize = 0;\n    this.nextSize = 0;\n    if (mode === 'horizontal') {\n      this.preSize = this.preWidth + x > -1 ? this.preWidth + x : 0;\n      this.nextSize = this.nextWidth - x > -1 ? this.nextWidth - x : 0;\n      if (this.preSize === 0 || this.nextSize === 0) {\n        return;\n      }\n      this.preSize = (this.preSize / this.boxWidth >= 1 ? 1 : this.preSize / this.boxWidth) * 100;\n      this.nextSize = (this.nextSize / this.boxWidth >= 1 ? 1 : this.nextSize / this.boxWidth) * 100;\n      if (prevTarget && nextTarget) {\n        prevTarget.style.width = `${this.preSize}%`;\n        nextTarget.style.width = `${this.nextSize}%`;\n      }\n    }\n    if (mode === 'vertical' && this.preHeight + y > -1 && this.nextHeight - y > -1) {\n      this.preSize = this.preHeight + y > -1 ? this.preHeight + y : 0;\n      this.nextSize = this.nextHeight - y > -1 ? this.nextHeight - y : 0;\n      this.preSize = (this.preSize / this.boxHeight >= 1 ? 1 : this.preSize / this.boxHeight) * 100;\n      this.nextSize = (this.nextSize / this.boxHeight >= 1 ? 1 : this.nextSize / this.boxHeight) * 100;\n      if (this.preSize === 0 || this.nextSize === 0) {\n        return;\n      }\n      if (prevTarget && nextTarget) {\n        prevTarget.style.height = `${this.preSize}%`;\n        nextTarget.style.height = `${this.nextSize}%`;\n      }\n    }\n    onDragging && onDragging(this.preSize, this.nextSize, this.paneNumber);\n  }\n  onDragEnd() {\n    const { onDragEnd } = this.props;\n    this.move = false;\n    onDragEnd && onDragEnd(this.preSize, this.nextSize, this.paneNumber);\n    this.removeEvent();\n    this.setState({ dragging: false });\n  }\n  render() {\n    const { prefixCls, className, children, mode, visiable, lineBar, disable, onDragEnd, onDragging, ...other } = this.props;\n    const { dragging } = this.state;\n    const cls = [prefixCls, className, `${prefixCls}-${mode}`, dragging ? 'dragging' : null].filter(Boolean)\n    .join(' ')\n    .trim();\n    const child = React.Children.toArray(children);\n    return (\n      <div className={cls} {...other} ref={node => this.warpper = node}>\n        {React.Children.map(child, (element: any, idx: number) => {\n          const props = Object.assign({}, element.props, {\n            className: [`${prefixCls}-pane`, element.props.className].filter(Boolean)\n            .join(' ')\n            .trim(),\n            style: { ...element.props.style },\n          });\n          const visiableBar = (visiable === true || (visiable && visiable.includes((idx + 1) as never))) || false;\n          const barProps = {\n            className: [`${prefixCls}-bar`, \n            lineBar ? `${prefixCls}-line-bar` : null,\n            !lineBar ? `${prefixCls}-large-bar` : null].filter(Boolean)\n            .join(' ')\n            .trim(),\n          };\n          if (disable === true || (disable && disable.includes((idx + 1) as never))) {\n            barProps.className = [barProps.className, disable ? 'disable' : null].filter(Boolean)\n            .join(' ')\n            .trim();\n          }\n          return (\n            <React.Fragment>\n              {idx !== 0 && visiableBar && React.createElement('div', { ...barProps }, <div onMouseDown={this.onMouseDown.bind(this, idx + 1)} />)}\n              {React.cloneElement(element, { ...props })}\n            </React.Fragment>\n          );\n        })}\n      </div>\n    );\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["Split","props","state","dragging","warpper","paneNumber","startX","startY","move","target","boxWidth","boxHeight","preWidth","nextWidth","preHeight","nextHeight","preSize","nextSize","onDragEnd","bind","onDragging","removeEvent","window","removeEventListener","env","clientX","clientY","parentNode","prevTarget","previousElementSibling","nextTarget","nextElementSibling","clientWidth","clientHeight","addEventListener","setState","mode","x","y","style","width","height","prefixCls","className","children","visiable","lineBar","disable","other","cls","filter","Boolean","join","trim","child","React","Children","toArray","node","map","element","idx","Object","assign","visiableBar","includes","barProps","createElement","onMouseDown","cloneElement","Component","defaultProps"],"mappings":"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","sourcesContent":["import React from 'react';\nimport './style/index.less';\n\nexport interface SplitProps extends  Omit<React.HTMLAttributes<HTMLDivElement>, 'onDragEnd'> {\n  style?: React.CSSProperties;\n  className?: string;\n  prefixCls?: string;\n  /**\n   * 拖拽宽度/高度变化回调函数，宽度或者高度根据 mode 参数来确定\n   */\n  onDragging?: (preSize: number, nextSize: number, paneNumber: number) => void;\n  /**\n   * 拖拽结束的回调函数\n   */\n  onDragEnd?: (preSize: number, nextSize: number, paneNumber: number) => void;\n  /**\n   * 设置拖拽的工具条，为线条样式。\n   */\n  lineBar?: boolean;\n  /**\n   * 设置拖拽的工具条，是否可见\n   */\n  visiable?: boolean | number[];\n  /**\n   * 设置拖拽的工具条，禁用\n   */\n  disable?: boolean | number[];\n  /**\n   * 类型，可选值为 `horizontal` 或 `vertical`\n   */\n  mode?: 'horizontal' | 'vertical';\n}\nexport interface SplitState {\n  dragging: boolean;\n}\n\nexport default class Split extends React.Component<SplitProps, SplitState> {\n  public static defaultProps: SplitProps = {\n    prefixCls: 'w-split',\n    visiable: true,\n    mode: 'horizontal',\n  }\n  public state: SplitState = {\n    dragging: false,\n  }\n  public warpper!: HTMLDivElement | null;\n  public paneNumber!: number;\n  public startX!: number;\n  public startY!: number;\n  public move!: boolean;\n  public target!: HTMLDivElement;\n\n  public boxWidth!: number;\n  public boxHeight!: number;\n  public preWidth!: number;\n  public nextWidth!: number;\n  public preHeight!: number;\n  public nextHeight!: number;\n\n  public preSize!: number;\n  public nextSize!: number;\n  constructor(props: SplitProps) {\n    super(props);\n    this.onDragEnd = this.onDragEnd.bind(this);\n    this.onDragging = this.onDragging.bind(this);\n  }\n  public componentWillUnmount() {\n    this.removeEvent();\n  }\n  private removeEvent() {\n    window.removeEventListener('mousemove', this.onDragging, false);\n    window.removeEventListener('mouseup', this.onDragEnd, false);\n  }\n  onMouseDown(paneNumber: number, env: React.MouseEvent<HTMLDivElement, MouseEvent>) {\n    if (!env.target || !this.warpper) {\n      return;\n    }\n    this.paneNumber = paneNumber;\n    this.startX = env.clientX;\n    this.startY = env.clientY;\n    this.move = true;\n    this.target = (env.target as HTMLDivElement).parentNode as HTMLDivElement;\n    const prevTarget = this.target.previousElementSibling;\n    const nextTarget = this.target.nextElementSibling;\n    this.boxWidth = this.warpper.clientWidth;\n    this.boxHeight = this.warpper.clientHeight;\n    if (prevTarget) {\n      this.preWidth = prevTarget.clientWidth;\n      this.preHeight = prevTarget.clientHeight;\n    }\n    if (nextTarget) {\n      this.nextWidth = nextTarget.clientWidth;\n      this.nextHeight = nextTarget.clientHeight;\n    }\n    window.addEventListener('mousemove', this.onDragging);\n    window.addEventListener('mouseup', this.onDragEnd, false);\n    this.setState({ dragging: true });\n  }\n  onDragging(env: Event) {\n    if (!this.move) {\n      return;\n    }\n    if (!this.state.dragging) {\n      this.setState({ dragging: true });\n    }\n    const { mode, onDragging } = this.props;\n    const nextTarget = this.target.nextElementSibling as HTMLDivElement;\n    const prevTarget = this.target.previousElementSibling as HTMLDivElement;\n    const x = (env as MouseEvent).clientX - this.startX;\n    const y = (env as MouseEvent).clientY - this.startY;\n    this.preSize = 0;\n    this.nextSize = 0;\n    if (mode === 'horizontal') {\n      this.preSize = this.preWidth + x > -1 ? this.preWidth + x : 0;\n      this.nextSize = this.nextWidth - x > -1 ? this.nextWidth - x : 0;\n      if (this.preSize === 0 || this.nextSize === 0) {\n        return;\n      }\n      this.preSize = (this.preSize / this.boxWidth >= 1 ? 1 : this.preSize / this.boxWidth) * 100;\n      this.nextSize = (this.nextSize / this.boxWidth >= 1 ? 1 : this.nextSize / this.boxWidth) * 100;\n      if (prevTarget && nextTarget) {\n        prevTarget.style.width = `${this.preSize}%`;\n        nextTarget.style.width = `${this.nextSize}%`;\n      }\n    }\n    if (mode === 'vertical' && this.preHeight + y > -1 && this.nextHeight - y > -1) {\n      this.preSize = this.preHeight + y > -1 ? this.preHeight + y : 0;\n      this.nextSize = this.nextHeight - y > -1 ? this.nextHeight - y : 0;\n      this.preSize = (this.preSize / this.boxHeight >= 1 ? 1 : this.preSize / this.boxHeight) * 100;\n      this.nextSize = (this.nextSize / this.boxHeight >= 1 ? 1 : this.nextSize / this.boxHeight) * 100;\n      if (this.preSize === 0 || this.nextSize === 0) {\n        return;\n      }\n      if (prevTarget && nextTarget) {\n        prevTarget.style.height = `${this.preSize}%`;\n        nextTarget.style.height = `${this.nextSize}%`;\n      }\n    }\n    onDragging && onDragging(this.preSize, this.nextSize, this.paneNumber);\n  }\n  onDragEnd() {\n    const { onDragEnd } = this.props;\n    this.move = false;\n    onDragEnd && onDragEnd(this.preSize, this.nextSize, this.paneNumber);\n    this.removeEvent();\n    this.setState({ dragging: false });\n  }\n  render() {\n    const { prefixCls, className, children, mode, visiable, lineBar, disable, onDragEnd, onDragging, ...other } = this.props;\n    const { dragging } = this.state;\n    const cls = [prefixCls, className, `${prefixCls}-${mode}`, dragging ? 'dragging' : null].filter(Boolean)\n    .join(' ')\n    .trim();\n    const child = React.Children.toArray(children);\n    return (\n      <div className={cls} {...other} ref={node => this.warpper = node}>\n        {React.Children.map(child, (element: any, idx: number) => {\n          const props = Object.assign({}, element.props, {\n            className: [`${prefixCls}-pane`, element.props.className].filter(Boolean)\n            .join(' ')\n            .trim(),\n            style: { ...element.props.style },\n          });\n          const visiableBar = (visiable === true || (visiable && visiable.includes((idx + 1) as never))) || false;\n          const barProps = {\n            className: [`${prefixCls}-bar`, \n            lineBar ? `${prefixCls}-line-bar` : null,\n            !lineBar ? `${prefixCls}-large-bar` : null].filter(Boolean)\n            .join(' ')\n            .trim(),\n          };\n          if (disable === true || (disable && disable.includes((idx + 1) as never))) {\n            barProps.className = [barProps.className, disable ? 'disable' : null].filter(Boolean)\n            .join(' ')\n            .trim();\n          }\n          return (\n            <React.Fragment>\n              {idx !== 0 && visiableBar && React.createElement('div', { ...barProps }, <div onMouseDown={this.onMouseDown.bind(this, idx + 1)} />)}\n              {React.cloneElement(element, { ...props })}\n            </React.Fragment>\n          );\n        })}\n      </div>\n    );\n  }\n}\n"]}

@@ -9,2 +9,3 @@ import _extends from "@babel/runtime/helpers/extends";

import _createSuper from "@babel/runtime/helpers/createSuper";
var _excluded = ["prefixCls", "className", "children", "mode", "visiable", "lineBar", "disable", "onDragEnd", "onDragging"];
import React from 'react';

@@ -174,3 +175,3 @@ import "./style/index.css";

onDragging = _this$props2.onDragging,
other = _objectWithoutProperties(_this$props2, ["prefixCls", "className", "children", "mode", "visiable", "lineBar", "disable", "onDragEnd", "onDragging"]);
other = _objectWithoutProperties(_this$props2, _excluded);

@@ -216,2 +217,2 @@ var dragging = this.state.dragging;

export { Split as default };
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["React","Split","props","state","dragging","warpper","paneNumber","startX","startY","move","target","boxWidth","boxHeight","preWidth","nextWidth","preHeight","nextHeight","preSize","nextSize","onDragEnd","bind","onDragging","removeEvent","window","removeEventListener","env","clientX","clientY","parentNode","prevTarget","previousElementSibling","nextTarget","nextElementSibling","clientWidth","clientHeight","addEventListener","setState","mode","x","y","style","width","height","prefixCls","className","children","visiable","lineBar","disable","other","cls","filter","Boolean","join","trim","child","Children","toArray","node","map","element","idx","Object","assign","visiableBar","includes","barProps","createElement","onMouseDown","cloneElement","Component","defaultProps"],"mappings":"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","sourcesContent":["import React from 'react';\nimport './style/index.less';\n\nexport interface SplitProps extends  Omit<React.HTMLAttributes<HTMLDivElement>, 'onDragEnd'> {\n  style?: React.CSSProperties;\n  className?: string;\n  prefixCls?: string;\n  /**\n   * 拖拽宽度/高度变化回调函数，宽度或者高度根据 mode 参数来确定\n   */\n  onDragging?: (preSize: number, nextSize: number, paneNumber: number) => void;\n  /**\n   * 拖拽结束的回调函数\n   */\n  onDragEnd?: (preSize: number, nextSize: number, paneNumber: number) => void;\n  /**\n   * 设置拖拽的工具条，为线条样式。\n   */\n  lineBar?: boolean;\n  /**\n   * 设置拖拽的工具条，是否可见\n   */\n  visiable?: boolean | number[];\n  /**\n   * 设置拖拽的工具条，禁用\n   */\n  disable?: boolean | number[];\n  /**\n   * 类型，可选值为 `horizontal` 或 `vertical`\n   */\n  mode?: 'horizontal' | 'vertical';\n}\nexport interface SplitState {\n  dragging: boolean;\n}\n\nexport default class Split extends React.Component<SplitProps, SplitState> {\n  public static defaultProps: SplitProps = {\n    prefixCls: 'w-split',\n    visiable: true,\n    mode: 'horizontal',\n  }\n  public state: SplitState = {\n    dragging: false,\n  }\n  public warpper!: HTMLDivElement | null;\n  public paneNumber!: number;\n  public startX!: number;\n  public startY!: number;\n  public move!: boolean;\n  public target!: HTMLDivElement;\n\n  public boxWidth!: number;\n  public boxHeight!: number;\n  public preWidth!: number;\n  public nextWidth!: number;\n  public preHeight!: number;\n  public nextHeight!: number;\n\n  public preSize!: number;\n  public nextSize!: number;\n  constructor(props: SplitProps) {\n    super(props);\n    this.onDragEnd = this.onDragEnd.bind(this);\n    this.onDragging = this.onDragging.bind(this);\n  }\n  public componentWillUnmount() {\n    this.removeEvent();\n  }\n  private removeEvent() {\n    window.removeEventListener('mousemove', this.onDragging, false);\n    window.removeEventListener('mouseup', this.onDragEnd, false);\n  }\n  onMouseDown(paneNumber: number, env: React.MouseEvent<HTMLDivElement, MouseEvent>) {\n    if (!env.target || !this.warpper) {\n      return;\n    }\n    this.paneNumber = paneNumber;\n    this.startX = env.clientX;\n    this.startY = env.clientY;\n    this.move = true;\n    this.target = (env.target as HTMLDivElement).parentNode as HTMLDivElement;\n    const prevTarget = this.target.previousElementSibling;\n    const nextTarget = this.target.nextElementSibling;\n    this.boxWidth = this.warpper.clientWidth;\n    this.boxHeight = this.warpper.clientHeight;\n    if (prevTarget) {\n      this.preWidth = prevTarget.clientWidth;\n      this.preHeight = prevTarget.clientHeight;\n    }\n    if (nextTarget) {\n      this.nextWidth = nextTarget.clientWidth;\n      this.nextHeight = nextTarget.clientHeight;\n    }\n    window.addEventListener('mousemove', this.onDragging);\n    window.addEventListener('mouseup', this.onDragEnd, false);\n    this.setState({ dragging: true });\n  }\n  onDragging(env: Event) {\n    if (!this.move) {\n      return;\n    }\n    if (!this.state.dragging) {\n      this.setState({ dragging: true });\n    }\n    const { mode, onDragging } = this.props;\n    const nextTarget = this.target.nextElementSibling as HTMLDivElement;\n    const prevTarget = this.target.previousElementSibling as HTMLDivElement;\n    const x = (env as MouseEvent).clientX - this.startX;\n    const y = (env as MouseEvent).clientY - this.startY;\n    this.preSize = 0;\n    this.nextSize = 0;\n    if (mode === 'horizontal') {\n      this.preSize = this.preWidth + x > -1 ? this.preWidth + x : 0;\n      this.nextSize = this.nextWidth - x > -1 ? this.nextWidth - x : 0;\n      if (this.preSize === 0 || this.nextSize === 0) {\n        return;\n      }\n      this.preSize = (this.preSize / this.boxWidth >= 1 ? 1 : this.preSize / this.boxWidth) * 100;\n      this.nextSize = (this.nextSize / this.boxWidth >= 1 ? 1 : this.nextSize / this.boxWidth) * 100;\n      if (prevTarget && nextTarget) {\n        prevTarget.style.width = `${this.preSize}%`;\n        nextTarget.style.width = `${this.nextSize}%`;\n      }\n    }\n    if (mode === 'vertical' && this.preHeight + y > -1 && this.nextHeight - y > -1) {\n      this.preSize = this.preHeight + y > -1 ? this.preHeight + y : 0;\n      this.nextSize = this.nextHeight - y > -1 ? this.nextHeight - y : 0;\n      this.preSize = (this.preSize / this.boxHeight >= 1 ? 1 : this.preSize / this.boxHeight) * 100;\n      this.nextSize = (this.nextSize / this.boxHeight >= 1 ? 1 : this.nextSize / this.boxHeight) * 100;\n      if (this.preSize === 0 || this.nextSize === 0) {\n        return;\n      }\n      if (prevTarget && nextTarget) {\n        prevTarget.style.height = `${this.preSize}%`;\n        nextTarget.style.height = `${this.nextSize}%`;\n      }\n    }\n    onDragging && onDragging(this.preSize, this.nextSize, this.paneNumber);\n  }\n  onDragEnd() {\n    const { onDragEnd } = this.props;\n    this.move = false;\n    onDragEnd && onDragEnd(this.preSize, this.nextSize, this.paneNumber);\n    this.removeEvent();\n    this.setState({ dragging: false });\n  }\n  render() {\n    const { prefixCls, className, children, mode, visiable, lineBar, disable, onDragEnd, onDragging, ...other } = this.props;\n    const { dragging } = this.state;\n    const cls = [prefixCls, className, `${prefixCls}-${mode}`, dragging ? 'dragging' : null].filter(Boolean)\n    .join(' ')\n    .trim();\n    const child = React.Children.toArray(children);\n    return (\n      <div className={cls} {...other} ref={node => this.warpper = node}>\n        {React.Children.map(child, (element: any, idx: number) => {\n          const props = Object.assign({}, element.props, {\n            className: [`${prefixCls}-pane`, element.props.className].filter(Boolean)\n            .join(' ')\n            .trim(),\n            style: { ...element.props.style },\n          });\n          const visiableBar = (visiable === true || (visiable && visiable.includes((idx + 1) as never))) || false;\n          const barProps = {\n            className: [`${prefixCls}-bar`, \n            lineBar ? `${prefixCls}-line-bar` : null,\n            !lineBar ? `${prefixCls}-large-bar` : null].filter(Boolean)\n            .join(' ')\n            .trim(),\n          };\n          if (disable === true || (disable && disable.includes((idx + 1) as never))) {\n            barProps.className = [barProps.className, disable ? 'disable' : null].filter(Boolean)\n            .join(' ')\n            .trim();\n          }\n          return (\n            <React.Fragment>\n              {idx !== 0 && visiableBar && React.createElement('div', { ...barProps }, <div onMouseDown={this.onMouseDown.bind(this, idx + 1)} />)}\n              {React.cloneElement(element, { ...props })}\n            </React.Fragment>\n          );\n        })}\n      </div>\n    );\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["React","Split","props","state","dragging","warpper","paneNumber","startX","startY","move","target","boxWidth","boxHeight","preWidth","nextWidth","preHeight","nextHeight","preSize","nextSize","onDragEnd","bind","onDragging","removeEvent","window","removeEventListener","env","clientX","clientY","parentNode","prevTarget","previousElementSibling","nextTarget","nextElementSibling","clientWidth","clientHeight","addEventListener","setState","mode","x","y","style","width","height","prefixCls","className","children","visiable","lineBar","disable","other","cls","filter","Boolean","join","trim","child","Children","toArray","node","map","element","idx","Object","assign","visiableBar","includes","barProps","createElement","onMouseDown","cloneElement","Component","defaultProps"],"mappings":"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","sourcesContent":["import React from 'react';\nimport './style/index.less';\n\nexport interface SplitProps extends  Omit<React.HTMLAttributes<HTMLDivElement>, 'onDragEnd'> {\n  style?: React.CSSProperties;\n  className?: string;\n  prefixCls?: string;\n  /**\n   * 拖拽宽度/高度变化回调函数，宽度或者高度根据 mode 参数来确定\n   */\n  onDragging?: (preSize: number, nextSize: number, paneNumber: number) => void;\n  /**\n   * 拖拽结束的回调函数\n   */\n  onDragEnd?: (preSize: number, nextSize: number, paneNumber: number) => void;\n  /**\n   * 设置拖拽的工具条，为线条样式。\n   */\n  lineBar?: boolean;\n  /**\n   * 设置拖拽的工具条，是否可见\n   */\n  visiable?: boolean | number[];\n  /**\n   * 设置拖拽的工具条，禁用\n   */\n  disable?: boolean | number[];\n  /**\n   * 类型，可选值为 `horizontal` 或 `vertical`\n   */\n  mode?: 'horizontal' | 'vertical';\n}\nexport interface SplitState {\n  dragging: boolean;\n}\n\nexport default class Split extends React.Component<SplitProps, SplitState> {\n  public static defaultProps: SplitProps = {\n    prefixCls: 'w-split',\n    visiable: true,\n    mode: 'horizontal',\n  }\n  public state: SplitState = {\n    dragging: false,\n  }\n  public warpper!: HTMLDivElement | null;\n  public paneNumber!: number;\n  public startX!: number;\n  public startY!: number;\n  public move!: boolean;\n  public target!: HTMLDivElement;\n\n  public boxWidth!: number;\n  public boxHeight!: number;\n  public preWidth!: number;\n  public nextWidth!: number;\n  public preHeight!: number;\n  public nextHeight!: number;\n\n  public preSize!: number;\n  public nextSize!: number;\n  constructor(props: SplitProps) {\n    super(props);\n    this.onDragEnd = this.onDragEnd.bind(this);\n    this.onDragging = this.onDragging.bind(this);\n  }\n  public componentWillUnmount() {\n    this.removeEvent();\n  }\n  private removeEvent() {\n    window.removeEventListener('mousemove', this.onDragging, false);\n    window.removeEventListener('mouseup', this.onDragEnd, false);\n  }\n  onMouseDown(paneNumber: number, env: React.MouseEvent<HTMLDivElement, MouseEvent>) {\n    if (!env.target || !this.warpper) {\n      return;\n    }\n    this.paneNumber = paneNumber;\n    this.startX = env.clientX;\n    this.startY = env.clientY;\n    this.move = true;\n    this.target = (env.target as HTMLDivElement).parentNode as HTMLDivElement;\n    const prevTarget = this.target.previousElementSibling;\n    const nextTarget = this.target.nextElementSibling;\n    this.boxWidth = this.warpper.clientWidth;\n    this.boxHeight = this.warpper.clientHeight;\n    if (prevTarget) {\n      this.preWidth = prevTarget.clientWidth;\n      this.preHeight = prevTarget.clientHeight;\n    }\n    if (nextTarget) {\n      this.nextWidth = nextTarget.clientWidth;\n      this.nextHeight = nextTarget.clientHeight;\n    }\n    window.addEventListener('mousemove', this.onDragging);\n    window.addEventListener('mouseup', this.onDragEnd, false);\n    this.setState({ dragging: true });\n  }\n  onDragging(env: Event) {\n    if (!this.move) {\n      return;\n    }\n    if (!this.state.dragging) {\n      this.setState({ dragging: true });\n    }\n    const { mode, onDragging } = this.props;\n    const nextTarget = this.target.nextElementSibling as HTMLDivElement;\n    const prevTarget = this.target.previousElementSibling as HTMLDivElement;\n    const x = (env as MouseEvent).clientX - this.startX;\n    const y = (env as MouseEvent).clientY - this.startY;\n    this.preSize = 0;\n    this.nextSize = 0;\n    if (mode === 'horizontal') {\n      this.preSize = this.preWidth + x > -1 ? this.preWidth + x : 0;\n      this.nextSize = this.nextWidth - x > -1 ? this.nextWidth - x : 0;\n      if (this.preSize === 0 || this.nextSize === 0) {\n        return;\n      }\n      this.preSize = (this.preSize / this.boxWidth >= 1 ? 1 : this.preSize / this.boxWidth) * 100;\n      this.nextSize = (this.nextSize / this.boxWidth >= 1 ? 1 : this.nextSize / this.boxWidth) * 100;\n      if (prevTarget && nextTarget) {\n        prevTarget.style.width = `${this.preSize}%`;\n        nextTarget.style.width = `${this.nextSize}%`;\n      }\n    }\n    if (mode === 'vertical' && this.preHeight + y > -1 && this.nextHeight - y > -1) {\n      this.preSize = this.preHeight + y > -1 ? this.preHeight + y : 0;\n      this.nextSize = this.nextHeight - y > -1 ? this.nextHeight - y : 0;\n      this.preSize = (this.preSize / this.boxHeight >= 1 ? 1 : this.preSize / this.boxHeight) * 100;\n      this.nextSize = (this.nextSize / this.boxHeight >= 1 ? 1 : this.nextSize / this.boxHeight) * 100;\n      if (this.preSize === 0 || this.nextSize === 0) {\n        return;\n      }\n      if (prevTarget && nextTarget) {\n        prevTarget.style.height = `${this.preSize}%`;\n        nextTarget.style.height = `${this.nextSize}%`;\n      }\n    }\n    onDragging && onDragging(this.preSize, this.nextSize, this.paneNumber);\n  }\n  onDragEnd() {\n    const { onDragEnd } = this.props;\n    this.move = false;\n    onDragEnd && onDragEnd(this.preSize, this.nextSize, this.paneNumber);\n    this.removeEvent();\n    this.setState({ dragging: false });\n  }\n  render() {\n    const { prefixCls, className, children, mode, visiable, lineBar, disable, onDragEnd, onDragging, ...other } = this.props;\n    const { dragging } = this.state;\n    const cls = [prefixCls, className, `${prefixCls}-${mode}`, dragging ? 'dragging' : null].filter(Boolean)\n    .join(' ')\n    .trim();\n    const child = React.Children.toArray(children);\n    return (\n      <div className={cls} {...other} ref={node => this.warpper = node}>\n        {React.Children.map(child, (element: any, idx: number) => {\n          const props = Object.assign({}, element.props, {\n            className: [`${prefixCls}-pane`, element.props.className].filter(Boolean)\n            .join(' ')\n            .trim(),\n            style: { ...element.props.style },\n          });\n          const visiableBar = (visiable === true || (visiable && visiable.includes((idx + 1) as never))) || false;\n          const barProps = {\n            className: [`${prefixCls}-bar`, \n            lineBar ? `${prefixCls}-line-bar` : null,\n            !lineBar ? `${prefixCls}-large-bar` : null].filter(Boolean)\n            .join(' ')\n            .trim(),\n          };\n          if (disable === true || (disable && disable.includes((idx + 1) as never))) {\n            barProps.className = [barProps.className, disable ? 'disable' : null].filter(Boolean)\n            .join(' ')\n            .trim();\n          }\n          return (\n            <React.Fragment>\n              {idx !== 0 && visiableBar && React.createElement('div', { ...barProps }, <div onMouseDown={this.onMouseDown.bind(this, idx + 1)} />)}\n              {React.cloneElement(element, { ...props })}\n            </React.Fragment>\n          );\n        })}\n      </div>\n    );\n  }\n}\n"]}
{
"name": "@uiw/react-split",
"version": "5.7.2",
"version": "5.7.3",
"description": "A piece of view can be divided into areas where the width or height can be adjusted by dragging.",

@@ -22,3 +22,3 @@ "main": "lib/cjs/index.js",

"css:watch": "compile-less -d src -o lib/esm --watch",
"css:build:dist": "compile-less -d src --combine lib/w-split.css --rm-global",
"css:build:dist": "compile-less -d src --combine lib/dist.css --rm-global",
"ts:watch": "tsbb watch --env-name esm:dev --env-name cjs --target react",

@@ -42,18 +42,18 @@ "ts:build": "tsbb build --target react"

"devDependencies": {
"@kkt/less-modules": "6.9.0",
"@kkt/raw-modules": "6.9.0",
"@kkt/scope-plugin-options": "6.9.0",
"@types/react": "17.0.9",
"@types/react-dom": "17.0.6",
"@kkt/less-modules": "6.10.4",
"@kkt/raw-modules": "6.10.4",
"@kkt/scope-plugin-options": "6.10.4",
"@types/react": "17.0.11",
"@types/react-dom": "17.0.8",
"@uiw/react-code-preview": "1.11.13",
"@uiw/react-github-corners": "1.2.0",
"@uiw/react-markdown-preview": "3.0.6",
"@uiw/react-github-corners": "1.4.0",
"@uiw/react-markdown-preview": "3.1.1",
"@uiw/reset.css": "1.0.4",
"compile-less-cli": "1.8.0",
"kkt": "6.9.0",
"kkt": "6.10.4",
"rehype-attr": "1.3.2",
"react": "17.0.2",
"react-dom": "17.0.2",
"tsbb": "2.2.0",
"uiw": "4.7.16"
"tsbb": "2.2.1",
"uiw": "4.9.1"
},

@@ -60,0 +60,0 @@ "eslintConfig": {

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet