扫码修改

lh_dev_ksck
yewj 2 months ago
parent 1ad2e2e5f2
commit de317f9591

@ -6,110 +6,141 @@
* 1.0 * 1.0
*/ */
const KeyScaner = /** @class */ (function () { const KeyScaner = /** @class */ (function () {
function KeyScaner(_dom) { function KeyScaner(_dom) {
this.keybufs = []; this.keybufs = [];
this.altBuf = []; this.altBuf = [];
this.isShift = false; this.isShift = false;
this.lastTime = 0; this.lastTime = 0;
/** /**
* 在收集到文本输入时触发 * 在收集到文本输入时触发
* @param text 收集到的连续文本 * @param text 收集到的连续文本
*/ */
this.onInput = function (text) { this.onInput = function (text) {
};
this.dom = _dom;
_dom.addEventListener('keydown', this.onKeyDown.bind(this));
_dom.addEventListener('keyup', this.onKeyUp.bind(this));
this.interval = setInterval(this.onTick.bind(this), 100);
}
KeyScaner.prototype.appendChar = function (c) {
this.keybufs.push(c);
}; };
KeyScaner.prototype.onKeyDown = function (ev) { this.dom = _dom;
this.lastTime = new Date().getTime(); _dom.addEventListener('keydown', this.onKeyDown.bind(this));
if (ev.key == "Alt") { _dom.addEventListener('keyup', this.onKeyUp.bind(this));
if (ev.shiftKey || ev.ctrlKey || ev.metaKey) { _dom.addEventListener('keypress', this.onKeyPress.bind(this));
return; this.interval = setInterval(this.onTick.bind(this), 100);
} }
} else if (ev.key == "Shift") {
if (ev.altKey || ev.ctrlKey || ev.metaKey) { KeyScaner.prototype.appendChar = function (c) {
return; this.keybufs.push(c);
} // console.log('appendChar:', c, this.keybufs)
this.isShift = true; };
} else if (ev.key == "Enter") { KeyScaner.prototype.onKeyDown = function (ev) {
if (ev.shiftKey || ev.altKey || ev.ctrlKey || ev.metaKey) { this.lastTime = new Date().getTime();
return; if (ev.key == "Alt") {
} if (ev.shiftKey || ev.ctrlKey || ev.metaKey) {
this.appendChar("\r"); return;
this.completeInput(); //立即完成输入 }
} else if (ev.key == "Delete" || ev.key == "Backspace") { } else if (ev.key == "Shift") {
this.dom.innerTex = ""; if (ev.altKey || ev.ctrlKey || ev.metaKey) {
this.appendChar("delete"); return;
this.completeInput(); //立即完成输入 }
this.isShift = true;
} else if (ev.key == "Enter") {
if (ev.shiftKey || ev.altKey || ev.ctrlKey || ev.metaKey) {
return;
}
this.appendChar("\r");
this.completeInput(); //立即完成输入
} else if (ev.key == "Delete" || ev.key == "Backspace") {
this.dom.innerTex = "";
this.appendChar("delete");
this.completeInput(); //立即完成输入
} else {
if (ev.key.length == 1) {
var charCode = ev.key.charCodeAt(0);
// console.log("key="+charCode);
if (charCode >= 48 && charCode <= 57) {
if (ev.altKey) {
this.altBuf.push(ev.key);
} else {
this.appendChar(ev.key);
}
} else if ((charCode >= 65 && charCode <= 90) || (charCode >= 97 && charCode <= 122)) {
//忽略大小写锁定键直接通过SHIFT键判断大小写
if (ev.shiftKey) {
this.appendChar(ev.key.toUpperCase());
} else {
this.appendChar(ev.key.toLowerCase());
}
} else { } else {
if (ev.key.length == 1) { this.appendChar(ev.key);
var charCode = ev.key.charCodeAt(0);
console.log("key="+charCode);
if (charCode >= 48 && charCode <= 57) {
if (ev.altKey) {
this.altBuf.push(ev.key);
} else {
this.appendChar(ev.key);
}
} else if ((charCode >= 65 && charCode <= 90) || (charCode >= 97 && charCode <= 122)) {
//忽略大小写锁定键直接通过SHIFT键判断大小写
if (ev.shiftKey) {
this.appendChar(ev.key.toUpperCase());
} else {
this.appendChar(ev.key.toLowerCase());
}
} else {
this.appendChar(ev.key);
}
}
//忽略其他控制键
}
};
KeyScaner.prototype.onKeyUp = function (ev) {
this.lastTime = new Date().getTime();
if (ev.key == "Alt") {
if (this.altBuf && this.altBuf.length > 0) {
var str = this.altBuf.join("");
var num = parseInt(str);
var c = String.fromCharCode(num);
this.appendChar(c);
this.altBuf = [];
}
} else if (ev.key == "Shift") {
this.isShift = false;
}
};
KeyScaner.prototype.completeInput = function () {
var text = this.keybufs.join("");
this.keybufs = [];
if (this.onInput) {
this.onInput.bind(this)(text);
}
};
KeyScaner.prototype.onTick = function () {
if (this.keybufs && this.keybufs.length > 0 && (!this.altBuf || this.altBuf.length == 0) && new Date().getTime() - this.lastTime > 500) {
//有缓存的字符且没有缓存的alt字符 且 与上次按键时间超过500毫秒。 收集输入
// this.completeInput();
} }
}; }
//忽略其他控制键
}
};
KeyScaner.prototype.onKeyUp = function (ev) {
this.lastTime = new Date().getTime();
if (ev.charCode === 29) {
var str = this.altBuf.join("");
var num = parseInt(str);
var c = String.fromCharCode(num);
this.appendChar(c);
this.altBuf = [];
console.log('onKeyUp success:', ev.charCode, this.keybufs);
} else if (ev.key == "Alt") {
if (this.altBuf && this.altBuf.length > 0) {
var str = this.altBuf.join("");
var num = parseInt(str);
var c = String.fromCharCode(num);
this.appendChar(c);
this.altBuf = [];
}
} else if (ev.key == "Shift") {
this.isShift = false;
}
};
KeyScaner.prototype.onKeyPress = function (ev) {
this.lastTime = new Date().getTime();
const char = String.fromCharCode(ev.charCode);
console.log('KeyPress:', ev.charCode, char);
/** /**
* 释放资源 * if (ev.charCode === 29) {
this.appendChar(char);
// console.log('KeyPress success:', ev.charCode, this.keybufs);
} else
*/ */
KeyScaner.prototype.dispose = function () { if (char == '\n') {
this.dom.removeEventListener('keydown', this.onKeyDown); this.completeInput();
this.dom.removeEventListener('keyup', this.onKeyUp); }
clearInterval(this.interval);
}; // if (ev.charCode === 49) {
return KeyScaner; // const char = String.fromCharCode(ev.charCode);
// this.appendChar(char);
// }
};
KeyScaner.prototype.completeInput = function () {
var text = this.keybufs.join("");
this.keybufs = [];
if (this.onInput) {
this.onInput.bind(this)(text);
}
};
KeyScaner.prototype.onTick = function () {
if (this.keybufs && this.keybufs.length > 0 && (!this.altBuf || this.altBuf.length == 0) && new Date().getTime() - this.lastTime > 500) {
//有缓存的字符且没有缓存的alt字符 且 与上次按键时间超过500毫秒。 收集输入
// this.completeInput();
}
};
/**
* 释放资源
*/
KeyScaner.prototype.dispose = function () {
this.dom.removeEventListener('keydown', this.onKeyDown);
this.dom.removeEventListener('keyup', this.onKeyUp);
this.dom.removeEventListener('keypress', this.onKeyPress);
clearInterval(this.interval);
};
return KeyScaner;
}()); }());
export default { export default {
KeyScaner KeyScaner
} }

@ -1069,7 +1069,7 @@ export default {
this.findMethod(); this.findMethod();
} else if (this.curAction.corpType == 3) { } else if (this.curAction.corpType == 3) {
//2. //2.
if (this.orderQuery == null || this.orderQuery.billNo == null){ if (this.orderQuery == null || this.orderQuery.billNo == null) {
this.orderFormData.fromInvCode = null; this.orderFormData.fromInvCode = null;
} }
this.findFromInvList(); this.findFromInvList();
@ -1558,24 +1558,24 @@ export default {
); );
tQuery.orderId = this.orderFormData.billNo; tQuery.orderId = this.orderFormData.billNo;
console.log(tQuery.orderId); console.log(tQuery.orderId);
if (val == 1){ if (val == 1) {
//btn //btn
this.checkLoading = true this.checkLoading = true
}else if (val == 2){ } else if (val == 2) {
//btn //btn
this.codeLoading = true this.codeLoading = true
}else { } else {
this.submitLoading = true this.submitLoading = true
} }
if (this.viewType == 2) { // if (this.viewType == 2) { //
submitCodes(tQuery).then((response) => { submitCodes(tQuery).then((response) => {
if (val == 1){ if (val == 1) {
//btn //btn
this.checkLoading = false this.checkLoading = false
}else if (val == 2){ } else if (val == 2) {
//btn //btn
this.codeLoading = false this.codeLoading = false
}else { } else {
this.submitLoading = false this.submitLoading = false
} }
@ -1592,13 +1592,13 @@ export default {
else else
tQuery.fromVailPi = 1; tQuery.fromVailPi = 1;
submitBiz(tQuery).then((response) => { submitBiz(tQuery).then((response) => {
if (val == 1){ if (val == 1) {
//btn //btn
this.checkLoading = false this.checkLoading = false
}else if (val == 2){ } else if (val == 2) {
//btn //btn
this.codeLoading = false this.codeLoading = false
}else { } else {
this.submitLoading = false this.submitLoading = false
} }
if (response.code === 20000) { if (response.code === 20000) {
@ -1610,13 +1610,13 @@ export default {
}); });
} else if (this.viewType == 4) { } else if (this.viewType == 4) {
submitAllocateBiz(tQuery).then((response) => { submitAllocateBiz(tQuery).then((response) => {
if (val == 1){ if (val == 1) {
//btn //btn
this.checkLoading = false this.checkLoading = false
}else if (val == 2){ } else if (val == 2) {
//btn //btn
this.codeLoading = false this.codeLoading = false
}else { } else {
this.submitLoading = false this.submitLoading = false
} }

Loading…
Cancel
Save