Merge pull request #1012 from kuangshen04/test-Branch
check增加hook接口+bugfix
This commit is contained in:
commit
8ecd4cc4ec
|
@ -5861,6 +5861,8 @@ export class Game extends Uninstantable {
|
||||||
* @param { GameEventPromise } [event]
|
* @param { GameEventPromise } [event]
|
||||||
*/
|
*/
|
||||||
static check(event = _status.event) {
|
static check(event = _status.event) {
|
||||||
|
game.callHook("checkBegin", [event]);
|
||||||
|
|
||||||
event._checked = true;
|
event._checked = true;
|
||||||
let ok = true, auto = true, auto_confirm = lib.config.auto_confirm;
|
let ok = true, auto = true, auto_confirm = lib.config.auto_confirm;
|
||||||
const player = event.player;
|
const player = event.player;
|
||||||
|
@ -5890,7 +5892,7 @@ export class Game extends Uninstantable {
|
||||||
game.Check.skill(event);
|
game.Check.skill(event);
|
||||||
|
|
||||||
player.node.equips.classList.remove('popequip');
|
player.node.equips.classList.remove('popequip');
|
||||||
if (event.filterCard && lib.config.popequip && get.is.phoneLayout() &&
|
if (event.filterCard && lib.config.popequip && !_status.nopopequip && get.is.phoneLayout() &&
|
||||||
typeof event.position === 'string' && event.position.includes('e') &&
|
typeof event.position === 'string' && event.position.includes('e') &&
|
||||||
player.node.equips.querySelector('.card.selectable')) {
|
player.node.equips.querySelector('.card.selectable')) {
|
||||||
player.node.equips.classList.add('popequip');
|
player.node.equips.classList.add('popequip');
|
||||||
|
@ -5927,6 +5929,7 @@ export class Game extends Uninstantable {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (event.isMine()) game.Check.confirm(event, { ok, auto, auto_confirm });
|
if (event.isMine()) game.Check.confirm(event, { ok, auto, auto_confirm });
|
||||||
|
|
||||||
// if (ui.confirm && ui.confirm.lastChild.link == 'cancel') {
|
// if (ui.confirm && ui.confirm.lastChild.link == 'cancel') {
|
||||||
// if (_status.event.type == 'phase' && !_status.event.skill) {
|
// if (_status.event.type == 'phase' && !_status.event.skill) {
|
||||||
// ui.confirm.lastChild.innerHTML = '结束';
|
// ui.confirm.lastChild.innerHTML = '结束';
|
||||||
|
@ -5935,6 +5938,8 @@ export class Game extends Uninstantable {
|
||||||
// ui.confirm.lastChild.innerHTML = '取消';
|
// ui.confirm.lastChild.innerHTML = '取消';
|
||||||
// }
|
// }
|
||||||
// }
|
// }
|
||||||
|
|
||||||
|
game.callHook("checkEnd", [event]);
|
||||||
return ok;
|
return ok;
|
||||||
}
|
}
|
||||||
static Check = class extends Uninstantable {
|
static Check = class extends Uninstantable {
|
||||||
|
@ -5953,12 +5958,12 @@ export class Game extends Uninstantable {
|
||||||
|
|
||||||
if (useCache) {
|
if (useCache) {
|
||||||
if (!event[`_${type}Choice`]) event[`_${type}Choice`] = {};
|
if (!event[`_${type}Choice`]) event[`_${type}Choice`] = {};
|
||||||
const cacheId = Object.keys(ui.selected).reduce((result, Type) => {
|
let cacheId = 0;
|
||||||
if (Type === type + 's') return result;
|
for (let Type of ['button', 'card', 'target']) {
|
||||||
let idType = Type.slice(0, -1);
|
if (type === Type) break;
|
||||||
if (idType === "target") idType = "player";
|
if (Type === "target") Type = "player";
|
||||||
return ui.selected[Type].reduce((t, i) => t ^= i[`${idType}id`], result);
|
ui.selected[`${Type}s`].forEach(i => cacheId ^= i[`${Type}id`]);
|
||||||
}, 0);
|
}
|
||||||
if (!event[`_${type}Choice`][cacheId]) {
|
if (!event[`_${type}Choice`][cacheId]) {
|
||||||
event[`_${type}Choice`][cacheId] = [];
|
event[`_${type}Choice`][cacheId] = [];
|
||||||
firstCheck = true;
|
firstCheck = true;
|
||||||
|
@ -6017,8 +6022,6 @@ export class Game extends Uninstantable {
|
||||||
const players = game.players.slice();
|
const players = game.players.slice();
|
||||||
if (event.deadTarget) players.addArray(game.dead);
|
if (event.deadTarget) players.addArray(game.dead);
|
||||||
const cards = player.getCards(event.position);
|
const cards = player.getCards(event.position);
|
||||||
let firstCheck = false;
|
|
||||||
const range = get.select(event.selectCard);
|
|
||||||
const isSelectable = card => {
|
const isSelectable = card => {
|
||||||
if (card.classList.contains('uncheck')) return false;
|
if (card.classList.contains('uncheck')) return false;
|
||||||
if (player.isOut()) return false;
|
if (player.isOut()) return false;
|
||||||
|
|
|
@ -325,6 +325,9 @@ export class Library extends Uninstantable {
|
||||||
game.dynamicStyle.addObject(result2);
|
game.dynamicStyle.addObject(result2);
|
||||||
}
|
}
|
||||||
}],
|
}],
|
||||||
|
//game.check美化
|
||||||
|
checkBegin: [],
|
||||||
|
checkEnd: [],
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in New Issue