Welcome Guest Search | Active Topics | Sign In | Register

Enter key causes dialog control to close Options
Sterling
Posted: Thursday, November 13, 2008 4:53:46 PM
Rank: Member
Groups: Member

Joined: 9/24/2008
Posts: 11
When I open a modal dialog control and press the ENTER key, the dialog closes. How do I trap or disable that?
eo_support
Posted: Thursday, November 13, 2008 5:29:51 PM
Rank: Administration
Groups: Administration

Joined: 5/27/2007
Posts: 24,229
Hi,

The dialog handles a few special keys. This include ESC and ENTER key. ESC cancels the dialog and ENTER triggers "accept" event for the dialog. It is possible to disable ENTER key by handling and cancel "accept" event with JavaScript. It is not possible to disable ESC key.

The code to handle and cancel "accept" event would be something like this:

Code: JavaScript
function accept_handler()
{
    return false;
}


Code: HTML/ASPX
<eo:Dialog id="Dialog1" ClientSideOnAccept="accept_handler" ...>
....
</eo:Dialog>


Note this will also disable AcceptButton. In order to close the dialog, you would need to call the dialog's close function. You can put something like this in the dialog's ContentTemplate or FooterTemplate:

Code: HTML/ASPX
<input type="button" 
    onclick="eo_GetObject('Dialog1').close();" 
    value="close dialog" />


Hope this helps.

Thanks
Mark Rae
Posted: Tuesday, November 25, 2008 3:26:11 AM
Rank: Advanced Member
Groups: Member

Joined: 11/13/2008
Posts: 43
eo_support wrote:
It is possible to disable ENTER key by handling and cancel "accept" event with JavaScript.

Following the instructions above certainly stops the ENTER key from closing the dialog. The problem is that it appears to disable the ENTER key completely!

E.g. in the dialog below, I have a multi-line text box, an OK button and a Cancel button. Clearly, the user needs to use the ENTER (or carriage return) key to create line breaks in the text of the multiline textbox.

If I remove the ClientSideOnAccept handler, pressing the ENTER key closes the dialog. If I enable the ClientSideOnAccept handler, pressing the ENTER key does nothing at all. Is there a way to get round this?

Code: HTML/ASPX
<%@ Page Language="C#" AutoEventWireup="true" %>
<%@ Register Assembly="EO.Web" Namespace="EO.Web" TagPrefix="eo" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>Test</title>
	<script type="text/javascript">
		function accept_handler()
		{
			return false;
		}
    </script>
</head>
<body>
    <form id="form1" runat="server">
		<input type="button" value="Show dialog" onclick="eo_GetObject('dlgTest').show();" />
		<eo:Dialog runat="server" id="dlgTest" HeaderImageUrl="00020441" HeaderImageHeight="27" 
			MinHeight="100" MinWidth="150" AllowResize="false" ControlSkinID="None" 
			HeaderHtml='
"padding-top:5px;">Test</div>' BackColor="#ECE9D8" CloseButtonUrl="00020440" ConfineElementID="" ClientSideOnAccept="accept_handler"> <HeaderStyleActive CssText="background-image:url(00020442);color:#444444;font-family:'trebuchet ms';font-size:10pt;font-weight:bold;padding-bottom:7px;padding-left:8px;padding-right:0px;padding-top:0px;" /> <ContentStyleActive CssText="background-color:#f0f0f0;font-family:tahoma;font-size:8pt;padding-bottom:4px;padding-left:4px;padding-right:4px;padding-top:4px;" /> <BorderImages BottomBorder="00020409,00020429" RightBorder="00020407,00020427" TopRightCornerBottom="00020405,00020425" TopRightCorner="00020403,00020423" LeftBorder="00020406,00020426" TopLeftCorner="00020401,00020421" BottomRightCorner="00020410,00020430" TopLeftCornerBottom="00020404,00020424" BottomLeftCorner="00020408,00020428" TopBorder="00020402,00020422" /> <ContentTemplate> <asp:TextBox ID="txtMulti" runat="server" Rows="6" Width="300px" TextMode="MultiLine" /> <br /> <asp:Button ID="cmdOK" runat="server" Text="OK" /> <asp:Button ID="cmdClose" runat="server" Text="Close" /> </ContentTemplate> </eo:Dialog> </form> </body> </html>

eo_support
Posted: Tuesday, November 25, 2008 6:18:33 AM
Rank: Administration
Groups: Administration

Joined: 5/27/2007
Posts: 24,229
Hi Mark,

I blieve the dialog does not distinguish different scenarios because it does not know when it should close on enter and when it should not. However it does pass the DOM event object so that you can decide whether to cancel it based on the event. It will be something like this:

Code: JavaScript
function accept_handler(dialog, e)
{
     //returning true or false based on information provided
     //by the second argument e. Note e has different properties
     //for different browsers.
}


Hope this helps.

Thanks
Mark Rae
Posted: Tuesday, November 25, 2008 6:57:23 AM
Rank: Advanced Member
Groups: Member

Joined: 11/13/2008
Posts: 43
eo_support wrote:
I believe the dialog does not distinguish different scenarios because it does not know when it should close on enter and when it should not. However it does pass the DOM event object so that you can decide whether to cancel it based on the event. It will be something like this:

Code: JavaScript
function accept_handler(dialog, e)
{
     //returning true or false based on information provided
     //by the second argument e. Note e has different properties
     //for different browsers.
}


I see. Using this, I have been able to identify which control within the dialog's ContentTemplate had the focus when the Enter key was pressed, as follows:

Code: JavaScript
function accept_handler(dialog, e)
{
	switch (e.srcElement.id)
	{
		case "&lt;%=txtMulti.ClientID%&gt;":
		{
			return false;
			break;
		}
		case "&lt;%=cmdOK.ClientID%&gt;":
		{
			return true;
			break;	
		}
	}
	return false;
}


However, although I can stop the dialog from closing when the multiline textbox has the focus, what I can't figure out is how to cancel the event itself so that the carriage return is actually inserted into the text of the textbox. Is this possible...?
eo_support
Posted: Tuesday, November 25, 2008 7:32:04 AM
Rank: Administration
Groups: Administration

Joined: 5/27/2007
Posts: 24,229
Hi,

I am not sure if you can do that in the current release. We will look into it and see what we can find.

Thanks!
Mark Rae
Posted: Tuesday, November 25, 2008 7:39:53 AM
Rank: Advanced Member
Groups: Member

Joined: 11/13/2008
Posts: 43
eo_support wrote:
I am not sure if you can do that in the current release. We will look into it and see what we can find.

Hmm - OK. I hope there will be a solution because, as it stands currently, this means that dialogs can't be used with multiline textboxes, or any other control which can under normal circumstances accept a carriage return...
eo_support
Posted: Tuesday, November 25, 2008 8:32:19 AM
Rank: Administration
Groups: Administration

Joined: 5/27/2007
Posts: 24,229
Yes. We do understand that. We will see what we can do on this.
Mark Rae
Posted: Tuesday, November 25, 2008 8:45:43 AM
Rank: Advanced Member
Groups: Member

Joined: 11/13/2008
Posts: 43
eo_support wrote:
Yes. We do understand that. We will see what we can do on this.

I would greatly appreciate it.

I am investigating what can be done in JavaScript, but have hit a brick wall...

I know what control in the dialog has focus when the Enter key is pressed.

From this, I can work out the current value of the text in the multiline text box:
e.srcElement.value

I also know what keycode has been pressed (e.keyCode).

What I don't seem to be able to identify is the current position of the cursor when the Enter key is pressed. If I knew that, then it would be a fairly simple task to insert a carriage return at the cursor's current position...
eo_support
Posted: Tuesday, November 25, 2008 9:01:43 AM
Rank: Administration
Groups: Administration

Joined: 5/27/2007
Posts: 24,229
Hi,

I believe you can do that by getting document.selection first, then create a TextRange object by calling createRange method on the object returned by document.selection. You would then use that TextRange object to replace the current selection (which is empty) with whatever you would like to insert. Note this information is based on IE. Other browsers are similar but just like the DOM event object, the exact interface is different.

Thanks
Mark Rae
Posted: Tuesday, November 25, 2008 9:57:44 AM
Rank: Advanced Member
Groups: Member

Joined: 11/13/2008
Posts: 43
eo_support wrote:
I believe you can do that by getting document.selection first, then create a TextRange object by calling createRange method on the object returned by document.selection. You would then use that TextRange object to replace the current selection (which is empty) with whatever you would like to insert. Note this information is based on IE. Other browsers are similar but just like the DOM event object, the exact interface is different.

Thanks.
eo_support
Posted: Thursday, December 4, 2008 1:50:07 PM
Rank: Administration
Groups: Administration

Joined: 5/27/2007
Posts: 24,229
Build 2008.0.53 addressed this issue by introducing a new return value "0" for ClientSideOnAccept handler. Returning "0" instead of "false" from the handler indicates that the dialog should not close and the source event should not be discarded either.


You cannot post new topics in this forum.
You cannot reply to topics in this forum.
You cannot delete your posts in this forum.
You cannot edit your posts in this forum.
You cannot create polls in this forum.
You cannot vote in polls in this forum.