Compare commits
No commits in common. "6f96a69900e1419fe933daffeb13316a253a76ed" and "96b3414d22ad6519a4cbdb92c2fcd2c503a8fee9" have entirely different histories.
6f96a69900
...
96b3414d22
@ -1,35 +1,6 @@
|
|||||||
import { Modular, Manager } from "../../core/Module";
|
import { Modular, Manager } from "../../core/Module";
|
||||||
|
|
||||||
/**
|
class Mask<M extends Manager> extends Modular<M> {
|
||||||
* 蒙版事件
|
|
||||||
*/
|
|
||||||
type IMaskEvent = {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 蒙版显示事件
|
|
||||||
*/
|
|
||||||
show: void;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 蒙版隐藏事件
|
|
||||||
*/
|
|
||||||
hide: void;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 蒙版状态改变事件
|
|
||||||
*/
|
|
||||||
change: boolean;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 蒙版点击事件
|
|
||||||
*/
|
|
||||||
click: void;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 蒙版 Modular
|
|
||||||
*/
|
|
||||||
class Mask<M extends Manager> extends Modular<M, {}, IMaskEvent> {
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 动画运行时间
|
* 动画运行时间
|
||||||
@ -54,41 +25,22 @@ class Mask<M extends Manager> extends Modular<M, {}, IMaskEvent> {
|
|||||||
isShow: false
|
isShow: false
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
|
||||||
* 当点击时是否自动关闭蒙版
|
|
||||||
*/
|
|
||||||
public autoCloseOnClick: boolean = true;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 消失动画计时器
|
|
||||||
*/
|
|
||||||
private disappearTimer?: number;
|
private disappearTimer?: number;
|
||||||
|
|
||||||
public override onLoad() {
|
|
||||||
this.setFunc(this.handleClickMask, "handleClickMask");
|
|
||||||
this.on("show", this.showMask);
|
|
||||||
this.on("hide", this.hideMask);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 显示蒙版
|
* 显示蒙版
|
||||||
*/
|
*/
|
||||||
private showMask = () => {
|
public showMask() {
|
||||||
|
|
||||||
this.disappearTimer && clearTimeout(this.disappearTimer);
|
|
||||||
|
|
||||||
this.setData({
|
this.setData({
|
||||||
isShow: true,
|
isShow: true,
|
||||||
isDisplay: true
|
isDisplay: true
|
||||||
});
|
});
|
||||||
|
|
||||||
this.emit("change", true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 隐藏蒙版
|
* 隐藏蒙版
|
||||||
*/
|
*/
|
||||||
private hideMask = () => {
|
public hideMask() {
|
||||||
this.setData({
|
this.setData({
|
||||||
isShow: false
|
isShow: false
|
||||||
});
|
});
|
||||||
@ -98,16 +50,15 @@ class Mask<M extends Manager> extends Modular<M, {}, IMaskEvent> {
|
|||||||
isDisplay: false
|
isDisplay: false
|
||||||
});
|
});
|
||||||
}, Mask.animateTime);
|
}, Mask.animateTime);
|
||||||
|
|
||||||
this.emit("change", false);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override onLoad() {
|
||||||
|
this.setFunc(this.handleClickMask, "handleClickMask");
|
||||||
|
// Do something
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* 处理蒙版点击事件
|
|
||||||
*/
|
|
||||||
private handleClickMask() {
|
private handleClickMask() {
|
||||||
if (this.autoCloseOnClick) this.emit("hide", void 0);
|
this.hideMask();
|
||||||
this.emit("click", void 0);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5,15 +5,7 @@ type IUserCardDependent<M extends Manager> = {
|
|||||||
mask: Mask<M>
|
mask: Mask<M>
|
||||||
}
|
}
|
||||||
|
|
||||||
type IUserCardEvent = {
|
class UserCard<M extends Manager> extends Modular<M, IUserCardDependent<M>> {
|
||||||
|
|
||||||
/**
|
|
||||||
* 主题更换按钮点击事件
|
|
||||||
*/
|
|
||||||
clickChangeTheme: void;
|
|
||||||
}
|
|
||||||
|
|
||||||
class UserCard<M extends Manager> extends Modular<M, IUserCardDependent<M>, IUserCardEvent> {
|
|
||||||
|
|
||||||
public override onLoad() {
|
public override onLoad() {
|
||||||
this.setFunc(this.handleChangeTheme, "changeTheme")
|
this.setFunc(this.handleChangeTheme, "changeTheme")
|
||||||
@ -23,8 +15,7 @@ class UserCard<M extends Manager> extends Modular<M, IUserCardDependent<M>, IUse
|
|||||||
* 处理主题更换
|
* 处理主题更换
|
||||||
*/
|
*/
|
||||||
private handleChangeTheme() {
|
private handleChangeTheme() {
|
||||||
this.depends?.mask.emit("show", void 0);
|
this.depends?.mask.showMask();
|
||||||
this.emit("clickChangeTheme", void 0);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user