uiik 1.1.0 → 1.3.0-alpha

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,4 +1,18 @@
1
1
  # Changelog
2
+
3
+ ## [1.3.0] - 2023/10/4 ⚠️BreakChange
4
+ ### 优化
5
+ - 重构 draggable/resizable/rotatable/selectable,支持transform变形后的操作识别
6
+ - 重新设计的事件框架,优化执行流
7
+ ### 新增
8
+ - handle 属性变更,支持更多类型
9
+ - onPointerDown 事件,可用于阻止后续逻辑
10
+ - draggable watch参数,可用于dom变动自动检测
11
+
12
+ ## [1.2.0] - 2023/9/3
13
+ ### Add
14
+ - SVG support —— draggable/resizable/selectable/rotatable
15
+
2
16
  ## [1.1.0] - 2023/6/6 ⚠️BreakChange
3
17
  ### Add
4
18
  - Sortable
package/README.md CHANGED
@@ -12,6 +12,7 @@ A UI interaction kit includes draggable, splittable, rotatable, selectable, etc.
12
12
  - Draggable/Droppable/Splittable/rotatable/selectable/Resizable
13
13
  - Customizable CSS interfaces like 'uii-draggable-handle', 'uii-splittable-handle'...
14
14
  - Rich options
15
+ - SVG support
15
16
 
16
17
  ## Quick start
17
18
  1. install
package/detector.d.ts CHANGED
@@ -6,29 +6,10 @@ export declare class CollisionDetector {
6
6
  elData: CollisionData;
7
7
  opts: Record<string, any>;
8
8
  constructor(el: string | HTMLElement, targets: (() => Array<HTMLElement>) | string | HTMLElement | Array<HTMLElement> | NodeList | HTMLCollection, opts?: CollisionDetectorOptions);
9
- /**
10
- * update targets data if them changed
11
- */
12
9
  update(): void;
13
- /**
14
- * detect targets and return overlaps
15
- * @returns
16
- */
17
10
  getOverlaps(): Array<HTMLElement>;
18
11
  getOverlaps(x1: number, y1: number, x2: number, y2: number): Array<HTMLElement>;
19
- /**
20
- * detect targets and return inclusions
21
- * @returns
22
- */
23
12
  getInclusions(): Array<HTMLElement>;
24
13
  getInclusions(x1: number, y1: number, x2: number, y2: number): Array<HTMLElement>;
25
14
  }
26
- /**
27
- * create a detector for the el and return
28
- * @param el element to be detected
29
- * @param targets
30
- * @param opts CollisionDetectorOptions
31
- * @param opts.container a root element of targets
32
- * @returns
33
- */
34
15
  export declare function newCollisionDetector(el: string | HTMLElement, targets: (() => Array<HTMLElement>) | string | HTMLElement | Array<HTMLElement> | NodeList | HTMLCollection, opts?: CollisionDetectorOptions): CollisionDetector;
package/draggable.d.ts CHANGED
@@ -1,25 +1,8 @@
1
1
  import { DraggableOptions, Uii } from "./types";
2
- /**
3
- * 用于表示一个或多个可拖动元素的定义
4
- * > 可用CSS接口
5
- * - .uii-draggable
6
- * - .uii-draggable-handle
7
- * - .uii-draggable-active
8
- * - .uii-draggable-ghost
9
- * @public
10
- */
11
2
  export declare class Draggable extends Uii {
12
3
  #private;
13
4
  constructor(els: string | HTMLElement | Array<string | HTMLElement>, opts?: DraggableOptions);
14
- /**
15
- * @internal
16
- */
5
+ bindEvent(bindTarget: Element, opts: DraggableOptions, handleMap: WeakMap<Element, Element>): void;
17
6
  onOptionChanged(opts: Record<string, any>): void;
18
7
  }
19
- /**
20
- * create a draggable pattern for one or more elements with opts
21
- * @param els selector string / html element
22
- * @param opts
23
- * @returns Draggable instance
24
- */
25
8
  export declare function newDraggable(els: string | HTMLElement | Array<string | HTMLElement>, opts?: DraggableOptions): Draggable;
package/droppable.d.ts CHANGED
@@ -1,30 +1,9 @@
1
1
  import { DroppableOptions, Uii } from "./types";
2
- /**
3
- * 用于表示一个或多个可响应拖动元素的定义
4
- * > 可用CSS接口
5
- * - .uii-droppable
6
- * @public
7
- */
8
2
  export declare class Droppable extends Uii {
9
3
  #private;
10
4
  constructor(el: string | HTMLElement | Array<string | HTMLElement>, opts?: DroppableOptions);
11
- /**
12
- * @internal
13
- */
14
5
  bindEvent(droppable: HTMLElement, opts: DroppableOptions): void;
15
- /**
16
- * @internal
17
- */
18
6
  active(target: HTMLElement): void;
19
- /**
20
- * @internal
21
- */
22
7
  deactive(target: HTMLElement): void;
23
8
  }
24
- /**
25
- * Enable els to response to draggable objects
26
- * @param els selector string / html element
27
- * @param opts
28
- * @returns
29
- */
30
9
  export declare function newDroppable(els: string | HTMLElement | Array<string | HTMLElement>, opts?: DroppableOptions): Droppable;
package/index.d.ts CHANGED
@@ -14,6 +14,8 @@ export * from './selectable';
14
14
  export * from './sortable';
15
15
  export * from './detector';
16
16
  export * from './types';
17
+ export * from './transform';
18
+ export * from './utils';
17
19
  export declare const VERSION: string;
18
20
  declare const _default: {
19
21
  VERSION: string;