@leafer-in/scroll 1.1.2 → 1.2.0
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/dist/scroll.cjs +8 -7
- package/dist/scroll.esm.js +3 -2
- package/dist/scroll.esm.min.js +1 -1
- package/dist/scroll.js +10 -8
- package/dist/scroll.min.cjs +1 -1
- package/dist/scroll.min.js +1 -1
- package/package.json +4 -5
- package/src/ScrollBar.ts +1 -2
- package/src/index.ts +5 -1
- package/types/index.d.ts +1 -2
package/dist/scroll.cjs
CHANGED
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var draw = require('@leafer-ui/draw');
|
|
4
3
|
var core = require('@leafer-ui/core');
|
|
5
4
|
|
|
6
|
-
class ScrollBar extends
|
|
5
|
+
class ScrollBar extends core.Group {
|
|
7
6
|
get isOutside() { return true; }
|
|
8
7
|
constructor(target, userConfig) {
|
|
9
8
|
super();
|
|
@@ -18,7 +17,7 @@ class ScrollBar extends draw.Group {
|
|
|
18
17
|
}
|
|
19
18
|
this.target = target;
|
|
20
19
|
if (userConfig)
|
|
21
|
-
|
|
20
|
+
core.DataHelper.assign(this.config, userConfig);
|
|
22
21
|
this.changeTheme(this.config.theme);
|
|
23
22
|
this.waitLeafer(this.__listenEvents, this);
|
|
24
23
|
}
|
|
@@ -35,7 +34,7 @@ class ScrollBar extends draw.Group {
|
|
|
35
34
|
style = theme;
|
|
36
35
|
}
|
|
37
36
|
if (!this.scrollXBar)
|
|
38
|
-
this.addMany(this.scrollXBar = new
|
|
37
|
+
this.addMany(this.scrollXBar = new core.Box(), this.scrollYBar = new core.Box());
|
|
39
38
|
style = Object.assign({ strokeAlign: 'center', opacity: 0.5, width: 6, cornerRadius: 3, hoverStyle: { opacity: 0.6 }, pressStyle: { opacity: 0.7 } }, style);
|
|
40
39
|
if (!style.height)
|
|
41
40
|
style.height = style.width;
|
|
@@ -52,7 +51,7 @@ class ScrollBar extends draw.Group {
|
|
|
52
51
|
const { worldRenderBounds } = zoomLayer;
|
|
53
52
|
if (check && this.scrollBounds && this.scrollBounds.isSame(worldRenderBounds))
|
|
54
53
|
return;
|
|
55
|
-
this.scrollBounds = new
|
|
54
|
+
this.scrollBounds = new core.Bounds(worldRenderBounds);
|
|
56
55
|
const bounds = canvas.bounds.clone().shrink(padding);
|
|
57
56
|
const totalBounds = bounds.clone().add(worldRenderBounds);
|
|
58
57
|
const ratioX = this.ratioX = bounds.width / totalBounds.width;
|
|
@@ -96,8 +95,8 @@ class ScrollBar extends draw.Group {
|
|
|
96
95
|
scrollYBar.on_(core.DragEvent.DRAG, this.onDrag, this),
|
|
97
96
|
scrollXBar.on_(core.DragEvent.END, this.onDragEnd, this),
|
|
98
97
|
scrollYBar.on_(core.DragEvent.END, this.onDragEnd, this),
|
|
99
|
-
this.target.on_(
|
|
100
|
-
this.target.leafer.on_(
|
|
98
|
+
this.target.on_(core.RenderEvent.BEFORE, () => this.update(true)),
|
|
99
|
+
this.target.leafer.on_(core.ResizeEvent.RESIZE, () => this.update())
|
|
101
100
|
];
|
|
102
101
|
}
|
|
103
102
|
__removeListenEvents() {
|
|
@@ -112,4 +111,6 @@ class ScrollBar extends draw.Group {
|
|
|
112
111
|
}
|
|
113
112
|
}
|
|
114
113
|
|
|
114
|
+
core.Plugin.add('scroll');
|
|
115
|
+
|
|
115
116
|
exports.ScrollBar = ScrollBar;
|
package/dist/scroll.esm.js
CHANGED
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
import { Group, DataHelper, Box, Bounds, RenderEvent, ResizeEvent } from '@leafer-ui/
|
|
2
|
-
import { DragEvent } from '@leafer-ui/core';
|
|
1
|
+
import { Group, DataHelper, Box, Bounds, DragEvent, RenderEvent, ResizeEvent, Plugin } from '@leafer-ui/core';
|
|
3
2
|
|
|
4
3
|
class ScrollBar extends Group {
|
|
5
4
|
get isOutside() { return true; }
|
|
@@ -110,4 +109,6 @@ class ScrollBar extends Group {
|
|
|
110
109
|
}
|
|
111
110
|
}
|
|
112
111
|
|
|
112
|
+
Plugin.add('scroll');
|
|
113
|
+
|
|
113
114
|
export { ScrollBar };
|
package/dist/scroll.esm.min.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{Group as t,DataHelper as i,Box as s,Bounds as e,
|
|
1
|
+
import{Group as t,DataHelper as i,Box as s,Bounds as e,DragEvent as r,RenderEvent as h,ResizeEvent as o,Plugin as a}from"@leafer-ui/core";class n extends t{get isOutside(){return!0}constructor(t,s){super(),this.config={theme:"light",padding:0,minSize:10},t.isApp&&(t.sky.add(this),t=t.tree),this.target=t,s&&i.assign(this.config,s),this.changeTheme(this.config.theme),this.waitLeafer(this.__listenEvents,this)}changeTheme(t){let i;"string"==typeof t?(i={fill:"black",stroke:"rgba(255,255,255,0.8)"},"dark"===t&&(i.fill="white",i.stroke="rgba(0,0,0,0.2)")):i=t,this.scrollXBar||this.addMany(this.scrollXBar=new s,this.scrollYBar=new s),i=Object.assign({strokeAlign:"center",opacity:.5,width:6,cornerRadius:3,hoverStyle:{opacity:.6},pressStyle:{opacity:.7}},i),i.height||(i.height=i.width),this.scrollXBar.set(Object.assign(Object.assign({},i),{visible:!1})),this.scrollYBar.set(Object.assign(Object.assign({},i),{visible:!1})),this.leafer&&this.update()}update(t){if(this.dragScrolling)return;const{minSize:i,padding:s}=this.config,{zoomLayer:r,canvas:h}=this.target.leafer,{worldRenderBounds:o}=r;if(t&&this.scrollBounds&&this.scrollBounds.isSame(o))return;this.scrollBounds=new e(o);const a=h.bounds.clone().shrink(s),n=a.clone().add(o),l=this.ratioX=a.width/n.width,g=this.ratioY=a.height/n.height,d=(a.x-n.x)/n.width,c=(a.y-n.y)/n.height,u=l<1,p=g<1,{scrollXBar:_,scrollYBar:f}=this,{x:v,y:m,width:y,height:B}=a.shrink([2,p?f.width+6:2,u?_.height+6:2,2]);_.set({x:v+y*d,y:m+B+2,width:Math.max(y*l,i),visible:u}),f.set({x:v+y+2,y:m+B*c,height:Math.max(B*g,i),visible:p})}onDrag(t){this.dragScrolling=!0,this.__dragOut=this.app.config.move.dragOut,this.app.config.move.dragOut=!1;const i=t.current===this.scrollXBar,s=this.target.leafer.getValidMove(i?-t.moveX/this.ratioX:0,i?0:-t.moveY/this.ratioY);this.target.moveWorld(s.x,s.y),t.current.moveWorld(s.x&&-s.x*this.ratioX,s.y&&-s.y*this.ratioY)}onDragEnd(){this.dragScrolling=!1,this.app.config.move.dragOut=this.__dragOut}__listenEvents(){const{scrollXBar:t,scrollYBar:i}=this;this.__eventIds=[t.on_(r.DRAG,this.onDrag,this),i.on_(r.DRAG,this.onDrag,this),t.on_(r.END,this.onDragEnd,this),i.on_(r.END,this.onDragEnd,this),this.target.on_(h.BEFORE,(()=>this.update(!0))),this.target.leafer.on_(o.RESIZE,(()=>this.update()))]}__removeListenEvents(){this.off_(this.__eventIds)}destroy(){this.destroyed||(this.__removeListenEvents(),this.target=this.config=null,super.destroy())}}a.add("scroll");export{n as ScrollBar};
|
package/dist/scroll.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
this.LeaferIN = this.LeaferIN || {};
|
|
2
|
-
this.LeaferIN.scroll = (function (exports,
|
|
2
|
+
this.LeaferIN.scroll = (function (exports, core) {
|
|
3
3
|
'use strict';
|
|
4
4
|
|
|
5
|
-
class ScrollBar extends
|
|
5
|
+
class ScrollBar extends core.Group {
|
|
6
6
|
get isOutside() { return true; }
|
|
7
7
|
constructor(target, userConfig) {
|
|
8
8
|
super();
|
|
@@ -17,7 +17,7 @@ this.LeaferIN.scroll = (function (exports, draw, core) {
|
|
|
17
17
|
}
|
|
18
18
|
this.target = target;
|
|
19
19
|
if (userConfig)
|
|
20
|
-
|
|
20
|
+
core.DataHelper.assign(this.config, userConfig);
|
|
21
21
|
this.changeTheme(this.config.theme);
|
|
22
22
|
this.waitLeafer(this.__listenEvents, this);
|
|
23
23
|
}
|
|
@@ -34,7 +34,7 @@ this.LeaferIN.scroll = (function (exports, draw, core) {
|
|
|
34
34
|
style = theme;
|
|
35
35
|
}
|
|
36
36
|
if (!this.scrollXBar)
|
|
37
|
-
this.addMany(this.scrollXBar = new
|
|
37
|
+
this.addMany(this.scrollXBar = new core.Box(), this.scrollYBar = new core.Box());
|
|
38
38
|
style = Object.assign({ strokeAlign: 'center', opacity: 0.5, width: 6, cornerRadius: 3, hoverStyle: { opacity: 0.6 }, pressStyle: { opacity: 0.7 } }, style);
|
|
39
39
|
if (!style.height)
|
|
40
40
|
style.height = style.width;
|
|
@@ -51,7 +51,7 @@ this.LeaferIN.scroll = (function (exports, draw, core) {
|
|
|
51
51
|
const { worldRenderBounds } = zoomLayer;
|
|
52
52
|
if (check && this.scrollBounds && this.scrollBounds.isSame(worldRenderBounds))
|
|
53
53
|
return;
|
|
54
|
-
this.scrollBounds = new
|
|
54
|
+
this.scrollBounds = new core.Bounds(worldRenderBounds);
|
|
55
55
|
const bounds = canvas.bounds.clone().shrink(padding);
|
|
56
56
|
const totalBounds = bounds.clone().add(worldRenderBounds);
|
|
57
57
|
const ratioX = this.ratioX = bounds.width / totalBounds.width;
|
|
@@ -95,8 +95,8 @@ this.LeaferIN.scroll = (function (exports, draw, core) {
|
|
|
95
95
|
scrollYBar.on_(core.DragEvent.DRAG, this.onDrag, this),
|
|
96
96
|
scrollXBar.on_(core.DragEvent.END, this.onDragEnd, this),
|
|
97
97
|
scrollYBar.on_(core.DragEvent.END, this.onDragEnd, this),
|
|
98
|
-
this.target.on_(
|
|
99
|
-
this.target.leafer.on_(
|
|
98
|
+
this.target.on_(core.RenderEvent.BEFORE, () => this.update(true)),
|
|
99
|
+
this.target.leafer.on_(core.ResizeEvent.RESIZE, () => this.update())
|
|
100
100
|
];
|
|
101
101
|
}
|
|
102
102
|
__removeListenEvents() {
|
|
@@ -111,8 +111,10 @@ this.LeaferIN.scroll = (function (exports, draw, core) {
|
|
|
111
111
|
}
|
|
112
112
|
}
|
|
113
113
|
|
|
114
|
+
core.Plugin.add('scroll');
|
|
115
|
+
|
|
114
116
|
exports.ScrollBar = ScrollBar;
|
|
115
117
|
|
|
116
118
|
return exports;
|
|
117
119
|
|
|
118
|
-
})({}, LeaferUI
|
|
120
|
+
})({}, LeaferUI);
|
package/dist/scroll.min.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";var t=require("@leafer-ui/
|
|
1
|
+
"use strict";var t=require("@leafer-ui/core");class i extends t.Group{get isOutside(){return!0}constructor(i,s){super(),this.config={theme:"light",padding:0,minSize:10},i.isApp&&(i.sky.add(this),i=i.tree),this.target=i,s&&t.DataHelper.assign(this.config,s),this.changeTheme(this.config.theme),this.waitLeafer(this.__listenEvents,this)}changeTheme(i){let s;"string"==typeof i?(s={fill:"black",stroke:"rgba(255,255,255,0.8)"},"dark"===i&&(s.fill="white",s.stroke="rgba(0,0,0,0.2)")):s=i,this.scrollXBar||this.addMany(this.scrollXBar=new t.Box,this.scrollYBar=new t.Box),s=Object.assign({strokeAlign:"center",opacity:.5,width:6,cornerRadius:3,hoverStyle:{opacity:.6},pressStyle:{opacity:.7}},s),s.height||(s.height=s.width),this.scrollXBar.set(Object.assign(Object.assign({},s),{visible:!1})),this.scrollYBar.set(Object.assign(Object.assign({},s),{visible:!1})),this.leafer&&this.update()}update(i){if(this.dragScrolling)return;const{minSize:s,padding:e}=this.config,{zoomLayer:r,canvas:h}=this.target.leafer,{worldRenderBounds:a}=r;if(i&&this.scrollBounds&&this.scrollBounds.isSame(a))return;this.scrollBounds=new t.Bounds(a);const o=h.bounds.clone().shrink(e),n=o.clone().add(a),l=this.ratioX=o.width/n.width,g=this.ratioY=o.height/n.height,d=(o.x-n.x)/n.width,c=(o.y-n.y)/n.height,u=l<1,v=g<1,{scrollXBar:p,scrollYBar:_}=this,{x:f,y:y,width:m,height:B}=o.shrink([2,v?_.width+6:2,u?p.height+6:2,2]);p.set({x:f+m*d,y:y+B+2,width:Math.max(m*l,s),visible:u}),_.set({x:f+m+2,y:y+B*c,height:Math.max(B*g,s),visible:v})}onDrag(t){this.dragScrolling=!0,this.__dragOut=this.app.config.move.dragOut,this.app.config.move.dragOut=!1;const i=t.current===this.scrollXBar,s=this.target.leafer.getValidMove(i?-t.moveX/this.ratioX:0,i?0:-t.moveY/this.ratioY);this.target.moveWorld(s.x,s.y),t.current.moveWorld(s.x&&-s.x*this.ratioX,s.y&&-s.y*this.ratioY)}onDragEnd(){this.dragScrolling=!1,this.app.config.move.dragOut=this.__dragOut}__listenEvents(){const{scrollXBar:i,scrollYBar:s}=this;this.__eventIds=[i.on_(t.DragEvent.DRAG,this.onDrag,this),s.on_(t.DragEvent.DRAG,this.onDrag,this),i.on_(t.DragEvent.END,this.onDragEnd,this),s.on_(t.DragEvent.END,this.onDragEnd,this),this.target.on_(t.RenderEvent.BEFORE,(()=>this.update(!0))),this.target.leafer.on_(t.ResizeEvent.RESIZE,(()=>this.update()))]}__removeListenEvents(){this.off_(this.__eventIds)}destroy(){this.destroyed||(this.__removeListenEvents(),this.target=this.config=null,super.destroy())}}t.Plugin.add("scroll"),exports.ScrollBar=i;
|
package/dist/scroll.min.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
this.LeaferIN=this.LeaferIN||{},this.LeaferIN.scroll=function(t,s
|
|
1
|
+
this.LeaferIN=this.LeaferIN||{},this.LeaferIN.scroll=function(t,s){"use strict";class i extends s.Group{get isOutside(){return!0}constructor(t,i){super(),this.config={theme:"light",padding:0,minSize:10},t.isApp&&(t.sky.add(this),t=t.tree),this.target=t,i&&s.DataHelper.assign(this.config,i),this.changeTheme(this.config.theme),this.waitLeafer(this.__listenEvents,this)}changeTheme(t){let i;"string"==typeof t?(i={fill:"black",stroke:"rgba(255,255,255,0.8)"},"dark"===t&&(i.fill="white",i.stroke="rgba(0,0,0,0.2)")):i=t,this.scrollXBar||this.addMany(this.scrollXBar=new s.Box,this.scrollYBar=new s.Box),i=Object.assign({strokeAlign:"center",opacity:.5,width:6,cornerRadius:3,hoverStyle:{opacity:.6},pressStyle:{opacity:.7}},i),i.height||(i.height=i.width),this.scrollXBar.set(Object.assign(Object.assign({},i),{visible:!1})),this.scrollYBar.set(Object.assign(Object.assign({},i),{visible:!1})),this.leafer&&this.update()}update(t){if(this.dragScrolling)return;const{minSize:i,padding:e}=this.config,{zoomLayer:r,canvas:h}=this.target.leafer,{worldRenderBounds:a}=r;if(t&&this.scrollBounds&&this.scrollBounds.isSame(a))return;this.scrollBounds=new s.Bounds(a);const n=h.bounds.clone().shrink(e),o=n.clone().add(a),l=this.ratioX=n.width/o.width,g=this.ratioY=n.height/o.height,d=(n.x-o.x)/o.width,c=(n.y-o.y)/o.height,u=l<1,v=g<1,{scrollXBar:f,scrollYBar:p}=this,{x:_,y:y,width:m,height:B}=n.shrink([2,v?p.width+6:2,u?f.height+6:2,2]);f.set({x:_+m*d,y:y+B+2,width:Math.max(m*l,i),visible:u}),p.set({x:_+m+2,y:y+B*c,height:Math.max(B*g,i),visible:v})}onDrag(t){this.dragScrolling=!0,this.__dragOut=this.app.config.move.dragOut,this.app.config.move.dragOut=!1;const s=t.current===this.scrollXBar,i=this.target.leafer.getValidMove(s?-t.moveX/this.ratioX:0,s?0:-t.moveY/this.ratioY);this.target.moveWorld(i.x,i.y),t.current.moveWorld(i.x&&-i.x*this.ratioX,i.y&&-i.y*this.ratioY)}onDragEnd(){this.dragScrolling=!1,this.app.config.move.dragOut=this.__dragOut}__listenEvents(){const{scrollXBar:t,scrollYBar:i}=this;this.__eventIds=[t.on_(s.DragEvent.DRAG,this.onDrag,this),i.on_(s.DragEvent.DRAG,this.onDrag,this),t.on_(s.DragEvent.END,this.onDragEnd,this),i.on_(s.DragEvent.END,this.onDragEnd,this),this.target.on_(s.RenderEvent.BEFORE,(()=>this.update(!0))),this.target.leafer.on_(s.ResizeEvent.RESIZE,(()=>this.update()))]}__removeListenEvents(){this.off_(this.__eventIds)}destroy(){this.destroyed||(this.__removeListenEvents(),this.target=this.config=null,super.destroy())}}return s.Plugin.add("scroll"),t.ScrollBar=i,t}({},LeaferUI);
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@leafer-in/scroll",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.2.0",
|
|
4
4
|
"description": "@leafer-in/scroll",
|
|
5
5
|
"author": "Chao (Leafer) Wan",
|
|
6
6
|
"license": "MIT",
|
|
@@ -34,9 +34,8 @@
|
|
|
34
34
|
"leaferjs"
|
|
35
35
|
],
|
|
36
36
|
"peerDependencies": {
|
|
37
|
-
"@leafer-ui/
|
|
38
|
-
"@leafer-ui/
|
|
39
|
-
"@leafer-
|
|
40
|
-
"@leafer-in/interface": "^1.1.2"
|
|
37
|
+
"@leafer-ui/core": "^1.2.0",
|
|
38
|
+
"@leafer-ui/interface": "^1.2.0",
|
|
39
|
+
"@leafer-in/interface": "^1.2.0"
|
|
41
40
|
}
|
|
42
41
|
}
|
package/src/ScrollBar.ts
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { IApp, IBounds, IBox, IBoxInputData, IEventListenerId, IGroup } from '@leafer-ui/interface'
|
|
2
|
-
import { Group, RenderEvent, ResizeEvent, Box, Bounds, DataHelper } from '@leafer-ui/
|
|
3
|
-
import { DragEvent } from '@leafer-ui/core'
|
|
2
|
+
import { Group, RenderEvent, ResizeEvent, Box, Bounds, DataHelper, DragEvent } from '@leafer-ui/core'
|
|
4
3
|
|
|
5
4
|
import { IScrollBar, IScrollBarConfig, IScrollBarTheme } from '@leafer-in/interface'
|
|
6
5
|
|
package/src/index.ts
CHANGED
package/types/index.d.ts
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { IGroup, IBox, IBounds, IEventListenerId } from '@leafer-ui/interface';
|
|
2
|
-
import { Group } from '@leafer-ui/
|
|
3
|
-
import { DragEvent } from '@leafer-ui/core';
|
|
2
|
+
import { Group, DragEvent } from '@leafer-ui/core';
|
|
4
3
|
import { IScrollBar, IScrollBarConfig, IScrollBarTheme } from '@leafer-in/interface';
|
|
5
4
|
|
|
6
5
|
declare class ScrollBar extends Group implements IScrollBar {
|