Closed
Bug 1478102
Opened 7 years ago
Closed 7 years ago
can't type on numbers fields on two of my banks after latest update (nightly)
Categories
(Core :: DOM: Events, defect, P3)
Tracking
()
VERIFIED
FIXED
mozilla65
People
(Reporter: gabriel2007, Assigned: masayuki)
References
(Regression)
Details
(Keywords: regression)
Attachments
(1 file)
95 bytes,
text/html
|
Details |
User Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:63.0) Gecko/20100101 Firefox/63.0
Build ID: 20180724100052
Steps to reproduce:
Tried to type an amount to make a transfer on my bank
Actual results:
Can't type on that box
Expected results:
number should have been allowed to be typed as it used to be before the update
Please provide the detailed steps to reproduce, which bank website, how to enter.
Flags: needinfo?(gabriel2007)
Reporter | ||
Comment 2•7 years ago
|
||
(In reply to YF (Yang) from comment #1)
> Please provide the detailed steps to reproduce, which bank website, how to
> enter.
This is the source code of the area, if you want the whole page I can save it, the problem is in a private section so I can't give you that info
<td>
<table class="TMNavInfo" cellspacing="0" cellpadding="0">
<tbody><tr>
<td style="width: 0.2px;">
<div class="ConDiv">
<div class="icon-exclamacion" style="color: #FFFFFF; font-size: 26px; background: #CC0000; position: relative; top: 15%"></div>
</div>
</td>
<td style="width: 98%">
<div class="ConDivTx"></div>
</td>
</tr>
<tr>
<td colspan="2">
<div class="InfoDiv">
Esta opción le permite realizar transferencias en línea a Cuentas Banesco de Terceros, para lo cual debe poseer la Clave de Operaciones Especiales.<br><br>Por su seguridad lo contactaremos vía telefónica para confirmar ciertas transacciones.<br><br><b>Recuerde verificar que todos los datos estén correctos, antes de presionar "Aceptar".</b><br><br><b>Nota: Ud. no podrá realizar pagos de Servicios a través de esta opción.</b><br><br><b>
</b></div><b>
</b></td>
</tr>
</tbody></table>
<table style="height: 20px;">
<tbody><tr>
<td> </td>
</tr>
</tbody></table>
<table class="TM"><tbody><tr><td class="HmGVTltWidth"></td><td class="HmGVTltSup">Código cuenta cliente a debitar</td><td class="HmGVTltWidth"></td></tr></tbody></table>
<table class="TDat">
<tbody><tr>
<td>
<select name="ctl00$cp$wz$ddlCuentaDebitar" id="ctl00_cp_wz_ddlCuentaDebitar" class="DefDdl" onchange="SetCompareValidator('ctl00_cp_wz_ddlCuentaDebitar', 'ctl00_cp_wz_txtMonto_LTVal', 'ctl00_cp_wz_lblSaldoDisp');">
<option value=""></option><option value="4|9.239.858,39">0134-****-**-***2135464 Cuenta de Ahorros</option><option value="5|956.526.138,24">0134-****-**-***1234567 Cuenta Corriente C/Intereses</option><option value="6|12.848.960,41">0134-****-**-***1234567 Cuenta Corriente C/Intereses</option>
</select>
<span id="ctl00_cp_wz_ctl02" style="color:Red;margin-left:2px;display:none;">*</span>
</td>
</tr>
<tr><td>Saldo Disponible: <span id="ctl00_cp_wz_lblSaldoDisp" class="Neg"></span></td></tr>
</tbody></table>
<br>
<table class="TM"><tbody><tr><td class="HmGVTltWidth"></td><td class="HmGVTltSup">Datos de la transferencia</td><td class="HmGVTltWidth"></td></tr></tbody></table>
<table class="TDat">
<tbody><tr><td colspan="2" class="NoBr">Haga click en el directorio para seleccionar los datos de la transferencia:<input type="button" value="Directorio" onclick="AbrirDirectorio('../AdministracionDirectorios/IndividualTran.aspx?Id=' + GetCuentaID(ctl00_cp_wz_ddlCuentaDebitar.value));" class="Bal"></td></tr>
<tr>
<td style="width:40%">Código Cuenta Cliente o Tarjeta Electrónica a Transferir:</td>
<td style="width:60%">
<input name="ctl00$cp$wz$txtCuentaTransferir" type="text" maxlength="20" id="ctl00_cp_wz_txtCuentaTransferir" class="DefTxt" onkeypress="return onlyDigits(event, this.value,false,false,false,',','.',0);" size="22" style="background-image: url(""); background-repeat: no-repeat; background-attachment: scroll; background-size: 16px 18px; background-position: 98% 50%; cursor: auto;" autocomplete="off"><span id="ctl00_cp_wz_txtCuentaTransferir_ReqVal" style="color:Red;display:none;margin-left:2px;;">*</span><span id="ctl00_cp_wz_txtCuentaTransferir_RegVal" style="color:Red;display:none;margin-left:2px;;">*</span>
<span id="ctl00_cp_wz_ctl07" style="color:Red;margin-left:2px;display:none;">*</span>
<span id="ctl00_cp_wz_cvNoBancaComYOtras" style="color:Red;margin-left:2px;visibility:hidden;">*</span>
</td>
</tr>
<tr>
<td>Beneficiario:</td>
<td><input name="ctl00$cp$wz$txtBen" type="text" maxlength="30" id="ctl00_cp_wz_txtBen" class="DefTxt" size="32"><span id="ctl00_cp_wz_txtBen_ReqVal" style="color:Red;display:none;margin-left:2px;;">*</span><span id="ctl00_cp_wz_txtBen_RegVal" style="color:Red;display:none;margin-left:2px;;">*</span></td>
</tr>
<tr>
<td>Cédula/RIF asociada a la Cuenta Cliente o Tarjeta Electrónica:</td>
<td>
<select name="ctl00$cp$wz$ddlNac" id="ctl00_cp_wz_ddlNac" class="DefDdl">
<option value="" selected="selected"></option><option value="V">V</option><option value="E">E</option><option value="J">J</option><option value="P">P</option><option value="G">G</option>
</select><span id="ctl00_cp_wz_RequiredFieldValidator1" style="color:Red;margin-left:2px;visibility:hidden;">*</span>
<input name="ctl00$cp$wz$txtCedula" type="text" maxlength="9" id="ctl00_cp_wz_txtCedula" class="Cedula" onkeypress="return onlyDigits(event, this.value,true,true,true,',','.',2);" size="11"><span id="ctl00_cp_wz_txtCedula_ReqVal" style="color:Red;display:none;margin-left:2px;;">*</span><span id="ctl00_cp_wz_txtCedula_RegVal" style="color:Red;display:none;margin-left:2px;;">*</span>
</td>
</tr>
<tr>
<td>Monto:</td>
<td><input name="ctl00$cp$wz$txtMonto" type="text" maxlength="19" id="ctl00_cp_wz_txtMonto" class="DefTxt" onblur="this.value=formatMoneda(this.value,',','.',2);" onkeyup="formatMoneda(this.value,',','.',2);" onkeypress="return onlyDigits(event, this.value,true,true,true,',','.',2);" size="21"><span id="ctl00_cp_wz_txtMonto_ReqVal" style="color:Red;display:none;margin-left:2px;;">*</span><span id="ctl00_cp_wz_txtMonto_RegVal" style="color:Red;display:none;margin-left:2px;;">*</span><span id="ctl00_cp_wz_txtMonto_LTVal" style="color:Red;display:none;">*</span><span id="ctl00_cp_wz_txtMonto_GTVal" style="color:Red;display:none;">*</span></td>
</tr>
<tr>
<td>Concepto:</td>
<td><input name="ctl00$cp$wz$txtConcepto" type="text" maxlength="40" id="ctl00_cp_wz_txtConcepto" class="DefTxt" onkeydown="if(event.which || event.keyCode){if((event.which == 13) || (event.keyCode == 13)) {if(document.getElementById('ctl00_cp_wz_StartNavigationTemplateContainerID_btnNext')) document.getElementById('ctl00_cp_wz_StartNavigationTemplateContainerID_btnNext').click();return false; }} else {return true};" size="42" data-com.bitwarden.browser.user-edited="yes"><span id="ctl00_cp_wz_txtConcepto_RegVal" style="color:Red;display:none;margin-left:2px;;"></span></td>
</tr>
</tbody></table>
<div id="ctl00_cp_wz_ctl12" class="DefSm" style="color:Red;display:none;">
</div>
</td>
Flags: needinfo?(gabriel2007)
Unfortunately, I failed to reproduce the problem with the above code, Nightly 63.0a1 (20180725103029) on Win10.
Can you indicate which bank? Just the domain that this problem occurs with.
Component: Untriaged → Layout: Form Controls
Product: Firefox → Core
Comment 4•7 years ago
|
||
Another super-helpful thing would be to find the regression range:
https://mozilla.github.io/mozregression/quickstart.html
Let me know if you'd need any help with that.
Updated•7 years ago
|
Keywords: regression,
regressionwindow-wanted
Updated•7 years ago
|
Priority: -- → P3
Comment 5•7 years ago
•
|
||
Same problem here since 63.0.
Here is an example of field that is not modifiable anymore :
<input id="numvoie"
type="text"
name="numvoie"
maxlength="4"
size="4"
value="199"
class="obligatoire"
onKeypress="if (event.keyCode < 45 || event.keyCode > 57) event.returnValue = false;"
onKeyUp="javascript:getXxxx('/mywebapp/MyServlet?cmd=xxx-yyy-zzz');"
/>
If I empty the keypress attribute, I can type numbers again.
Comment 6•7 years ago
|
||
Thanks for that test-case!
Updated•7 years ago
|
Attachment #9020774 -
Attachment mime type: text/plain → text/html
Comment 7•7 years ago
|
||
There are various things that have happened relatively to keypress events in 63. Also there's window.event and such.
Status: UNCONFIRMED → NEW
Component: Layout: Form Controls → DOM: Events
Ever confirmed: true
Flags: needinfo?(masayuki)
Comment 8•7 years ago
|
||
This one was regressed by bug 1452569.
Comment 9•7 years ago
|
||
[Tracking Requested - why for this release]: Compat regression.
tracking-firefox64:
--- → ?
tracking-firefox65:
--- → ?
Comment 10•7 years ago
|
||
Bug 1452569 implement event.returnValue.
So "event.returnValue = false" don't have any effect before.
Does this make sense if the code is revised to the following?
<input onKeypress="if (event.keycode && (event.keyCode < 45 || event.keyCode > 57)) event.returnValue = false;">
Flags: needinfo?(alchen)
Comment 11•7 years ago
|
||
Why other browsers have no problem? Due to poor sniffing?
Comment 12•7 years ago
|
||
The testcase I uploaded works in WebKit / Chrome, so that's why I ni?d Masayuki regarding keyCode.
Comment 13•7 years ago
|
||
Yeah, in Gecko keyCode is always zero. I guess this is bug 1479964.
Blocks: 1479964
Comment 15•7 years ago
|
||
In FireFox, there is no "keycode" in the "keypress" event.
However, there is "keycode" in "keydown" event.
So the following is also works.
<input onKeydown="if (event.keyCode < 45 || event.keyCode > 57) event.returnValue = false;">
Updated•7 years ago
|
Comment 16•7 years ago
|
||
The problem does not seem to be related to returnValue. The problem seems to be related to keyCode and onKeyPress as FF63 returns 0 for all keys when using onKeyPress.
Here is my test case that fails in FF63 but works in GC70:
<input type="text" onKeyPress="if(event.keyCode < 48 || event.keyCode > 57) event.returnValue = false;">
What is the recommended fix? Will FF release an immediate update to allow this code to keep working? This completely breaks our website for FF users.
We can't just change onKeyPress to onKeyDown, it does not have the same behavior or results and it won't work. For the same reason, using "key" instead of "keycode" will not work.
Comment 17•7 years ago
|
||
If you need an immediate workaround, something like <input type="text" onKeyPress="if((event.keyCode || event.charCode) < 48 || (event.keyCode || event.charCode) > 57) event.returnValue = false;"> will do it.
Is there any reason you can't use event.key?
Flags: needinfo?(mikebaretta)
Assignee | ||
Comment 18•7 years ago
|
||
Yeah, in these days, the keypress event handler should be:
if (/^[0-9]$/.test(event.key)) {
event.preventDefault();
}
KeyboardEvent.key is available on most modern browsers now.
https://caniuse.com/#feat=keyboardevent-key
Anyway, this is not enough for input from IME, paste, d&d, etc, though. Perhaps, you want to do:
oninput="
if (event.isComposing) {
return;
}
if (!/$[0-9]*^/.test(event.target.value)) {
event.target.value = event.target.previousValue;
} else {
event.target.previousValue = event.target.value;
}
"
Flags: needinfo?(masayuki)
Comment 19•7 years ago
|
||
Well, it's important for us that this regression can be fixed as soon as possible.
We can't fix that old school code easily, because our customers use different versions of our product.
Our customers may use FF, FF ESR, IE, Chrome but switching from a browser to another can be very tricky and in some cases impossible in the short term.
So please, is it possible to hope a fix soon ?
Thanks a lot for you job.
Assignee | ||
Comment 20•7 years ago
|
||
Perhaps, not so soon since we confirmed that some websites are broken with enabling the fix of bug 1479964. We need to wait such websites fix their bug.
Comment 21•7 years ago
|
||
Thank you for your help Masayuki.
Can you provide simple code to allow numbers plus all command and navigation keys?
We want to allow numbers 0-9 (from both top of keyboard and number pad) as well Backspace, Delete, Home, End, all Arrows (Left, Right, Up, Down), and Tab.
We want to block all letters, symbols, spaces.
We're really just looking at keyboard input - we can ignore cut & paste, drag & drop, etc.
We need simple code that works on all current browsers (FF, Chrome, Safari, IE11, Edge) and can be placed within the <input> tag using onKeyPress attribute.
I agree that e.key is probably better than e.keyCode, but there are a few differences among browsers (specifically the key given for certain Command keys in IE).
If you think FF will revert this issue in a matter of days then I won't worry about it. But if not then I would greatly appreciate a new coding solution.
Thank you!
Flags: needinfo?(mikebaretta)
Comment 22•7 years ago
|
||
@miketbaretta, shouldn't comment #17 work for you? As long as you're checking `event.keyCode || event.charCode`, it should work as expected.
Comment 23•7 years ago
|
||
@Mike Taylor
Comment #17 doesn't allow use of Command of Navigation keys.
You see, in GC and IE the Command and Navigation keys do not trigger an onKeyPress event, so they are given a "pass" and will work. I assume that this was also the case with FF62, but now with FF63 the Command and Navigation keys trigger onKeyPress and thus Comment #17 doesn't work.
Comment 24•7 years ago
|
||
Meant to write "doesn't allow use of Command *or* Navigation keys."
Updated•7 years ago
|
status-firefox63:
--- → wontfix
status-firefox64:
--- → affected
status-firefox65:
--- → affected
status-firefox-esr60:
--- → unaffected
Flags: needinfo?(gabriel2007)
Comment 25•7 years ago
|
||
firefox63 wontfix
Really ?
Does it means no patch before FF64 release (dec 11th) ?
Comment 26•7 years ago
|
||
wontfix might have been a bit premature, but the lack of an assignee or patch doesn't make it seem very likely that a fix will materialize in time for an out-of-band bugfix release for Fx63 either.
Comment 27•7 years ago
|
||
Here's what I came up with, please tell me if you think this will work in FF63 and all proposed/known future FF versions:
<input name="Quantity" type="text" onKeyPress="if((event.charCode >= 48 && event.charCode <= 57) || (event.charCode == 0)) {return true;} else {event.preventDefault();}">
The purpose of this is to allow only numbers to be keyed/entered, but to also allow all Command and Navigation keys.
I took advantage of the fact that FF63 uses a charCode of 0 for all Command and Navigation keys. Will FF continue to do this or is it in jeopardy? (As I mentioned previously, GC and IE do not trigger an onKeyPress event at all for Command and Navigation keys.)
Thank you!
Assignee | ||
Comment 29•7 years ago
|
||
When we fix bug 1502795 in release channel, bug 968056 (and bug 354358) are also fixed in release channel because some frameworks depend on bug 968056 and we want to reduce change cost of web developers.
Flags: needinfo?(masayuki)
Comment 30•7 years ago
|
||
I understand that this report comes a bit late, considering the work done in the meantime, but you should know that not resolving this problem early requires us to redirect our users to GC or IE (if possible).
So please, do your best to patch this rapidly.
Thank you.
Comment 31•7 years ago
|
||
(In reply to Laurent Barbareau from comment #30)
> I understand that this report comes a bit late, considering the work done in
> the meantime, but you should know that not resolving this problem early
> requires us to redirect our users to GC or IE (if possible).
>
> So please, do your best to patch this rapidly.
>
> Thank you.
Laurent, can you email me at miket@mozilla.com? I'm happy to help you come up with a workaround for your users.
Flags: needinfo?(lbarbareau)
Comment 32•7 years ago
|
||
Wontfix for 63 as we are unlikely to have another dot release before 64 ships.
Comment 33•7 years ago
|
||
Can we please confirm the current status of this bug? We'll be fixing it in 64 via bug 1510985 and for 65+ we've got other patches landed which address this issue?
Flags: needinfo?(masayuki)
Comment 34•7 years ago
|
||
I will let Masayuki also reply, but yes that is correct. The 65+ bug is 1496288.
Assignee | ||
Comment 35•7 years ago
|
||
In 64, we'll disable Event.returnValue temporarily for this bug. And in 65, we'll ship all new keyboard event behaviors so that this is also "fixed" in 65 even though Event.returnValue is available again in 65.
Flags: needinfo?(masayuki)
Comment 36•7 years ago
|
||
Disabled in 64 by 1510985
Comment 37•7 years ago
|
||
So it won't be fixed before 2019-01-29 ?... :roll:
Will it be fixed into 65 for sure or there are still some uncertainties ?
Flags: needinfo?(lbarbareau)
Assignee | ||
Comment 38•7 years ago
|
||
In 64, returnValue is temporarily disabled. Then, in 65, it'll be enabled again with changes of keypress event behavior.
Comment 39•7 years ago
|
||
Laurent, my understanding is that Firefox 65 (currently on Beta) contains the fixes needed for things to Just Work. It would be nice if we could verify that prior to next month's release, however, so we don't find ourselves scrambling at the last second to fix any remaining issues :). Are you able to confirm that the current Beta release works as expected for you?
Flags: needinfo?(lbarbareau)
Comment 40•7 years ago
|
||
In our opinion this is not the kind of regression with which you can decide to postpone the fix, whatever the difficulties to deal with... Some of our customers are quite angry because of this. We've advised them to switch to another browser or FF ESR, but this is not something a final user can always do himself (because of rights/policy).
Our application has been rid of the onkeypress attribute issue (50 occurrences), but this will be effective only when we could deploy a new version for each of our customers, that is absolutely not something we can decide alone.
That means we're still awaiting the fix as soon as possible because some of our customers have to switch between browsers according what they have to do.
I add that a coworker of mine said it wasn't the first time this issue occurred with the onkeypress attribute, so maybe you could set up non-regression tests to prevent this definitely.
Flags: needinfo?(lbarbareau)
Comment 41•7 years ago
|
||
I'm not sure what you're talking about in comment 40. We believe this is fixed both in firefox 64 (current release) and 65 (current beta).
Comment 42•7 years ago
|
||
Ok... after some tries with FF64 and FF65, here is the translation of your "In 64, returnValue is temporarily disabled" :
- In FF64 you are no longer prevented from typing characters into the fields where onkeypress attribute is supposed to control which characters are accepted and which ones are not. But you can type any character, the control is not effective.
- In FF65, everything seems to be back in order.
So, at least users are not blocked. Thank you.
Comment 43•7 years ago
|
||
Thanks for confirming. Glad to hear we're all on the same page now! Calling this fixed for 65+.
Assignee: nobody → masayuki
Status: NEW → RESOLVED
Closed: 7 years ago
Resolution: --- → FIXED
Target Milestone: --- → mozilla65
Comment 44•7 years ago
|
||
I have reproduced this issue using Firefox 64.0a1 (2018.10.18) on Win 10 x64.
I can confirm this issue is fixed, I verified using Firefox 65.0 on Win 10 x64, Mac OS X 10.13 and Ubuntu 18.04 x64 using the attached testcase, now in FF 65.0 in that box you can type any character this is expected?
Flags: needinfo?(masayuki)
Assignee | ||
Comment 45•7 years ago
|
||
(In reply to Timea Zsoldos [:zstimi/tzsoldos], Desktop Release QA from comment #44)
now in FF 65.0 in that box you can type any character this is expected?
Yes, it is. For restricting the acceptable characters, it uses Event.returnValue, but this is disabled at release of 65 due to bug 1514940. Sorry for really complicated status of these bugs.
Flags: needinfo?(masayuki)
Updated•7 years ago
|
Status: RESOLVED → VERIFIED
Updated•2 years ago
|
You need to log in
before you can comment on or make changes to this bug.
Description
•