|
1 |
|
2 <!DOCTYPE html |
|
3 PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> |
|
4 <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"/><meta name="copyright" content="(C) Copyright 2009"/><meta name="DC.rights.owner" content="(C) Copyright 2009"/><meta name="DC.Type" content="concept"/><meta name="DC.Title" content="STEW: managing user interaction"/><meta name="abstract" content="This section contains an example of how users interact with a view and how you save and load persistent data."/><meta name="description" content="This section contains an example of how users interact with a view and how you save and load persistent data."/><meta name="DC.Relation" scheme="URI" content="GUID-0FCBC574-2328-4986-99D3-7DC4BDE9C3A4"/><meta name="DC.Relation" scheme="URI" content="GUID-C6AC727B-52DC-4C7B-8689-19E98126346D"/><meta name="DC.Relation" scheme="URI" content="GUID-775005BC-2FF8-45A9-BBA6-6CED6B5780A2"/><meta name="DC.Relation" scheme="URI" content="GUID-EB2043BB-E557-429B-BA0A-E350A6D06597"/><meta name="DC.Format" content="XHTML"/><meta name="DC.Identifier" content="GUID-5906D140-663D-4EE2-B0C1-4FECA5759384"/><meta name="DC.Language" content="en"/><title>STEW: managing user interaction </title><script type="text/javascript"> |
|
5 function initPage() {} |
|
6 </script><link href="../PRODUCT_PLUGIN/book.css" rel="stylesheet" type="text/css"/><link href="css/s60/style.css" rel="stylesheet" type="text/css" media="all"/></head><body onload="initPage();"><div class="body"><div class="contentLeft prTxt"><h1 class="pageHeading" id="GUID-5906D140-663D-4EE2-B0C1-4FECA5759384">STEW: managing user interaction</h1><div><p>This section contains an example of how users interact with a view and how you save and load persistent data.</p> |
|
7 <div class="figure" id="GUID-1B9E4A9F-3959-446B-9624-3768CF94AA02"><img src="GUID-38EF5741-0A6A-4A55-BDE5-4DB3F686D21E_d0e11532_href.jpg"/><p class="figure-title"><strong>Figure: </strong>STEW Login view</p></div> |
|
8 <p>The <code>LoginScreen.js</code> file implements the functionality of the STEW <span class="uicontrol">Login</span> view. For more information on how to implement the functionality of the other STEW views, see <code>UpdateScreen.js</code>, <code>SearchScreen.js</code>, and <code>SettingsScreen.js</code>.</p> |
|
9 <p>In the <code>LoginScreen</code> function, the <code>onclick</code> event handler is assigned to the <span class="uicontrol">Login</span> button and the values of the screen controls that collect user input (<span class="uicontrol">Username</span>, <span class="uicontrol">Password</span>, and <span class="uicontrol">Remember Me</span> ) are remembered.</p> |
|
10 <pre class="codeblock">function LoginScreen() { |
|
11 // Get the login button element and assign an event handler to it. |
|
12 var self = this; |
|
13 var loginButton = document.getElementById( "login_button" ); |
|
14 loginButton.onclick = function() { |
|
15 self.onLoginClicked(); |
|
16 }; |
|
17 |
|
18 // Get all the UI elements that we can interact with. |
|
19 this.tbUsername = document.getElementById( "login_username" ); |
|
20 this.tbPassword = document.getElementById( "login_password" ); |
|
21 this.cbRememberMe = document.getElementById( "login_remember_me" ); |
|
22 } |
|
23 </pre> |
|
24 <div><h3>Saving persistent data</h3><p>The <code>onclick</code> event handler triggers the activation of the next view. Users can specify settings to determine which view appears after the <span class="uicontrol">Login</span> view, so the logic needs to find out which view is the default view. </p><p>If the user checks the <span class="uicontrol">Remember Me</span> check box, the credentials are stored. This is done by calling the WRT <code>widget.setPreferenceForKey</code> and <code>widget.preferenceForKey</code> API methods after reading the input for <span class="uicontrol">Username</span>, <span class="uicontrol">Password</span>, and the <span class="uicontrol">Remember Me</span> check box.</p><pre class="codeblock">LoginScreen.prototype.onLoginClicked = function() { |
|
25 var username = this.tbUsername.value; |
|
26 var password = this.tbPassword.value; |
|
27 var rememberMe = this.cbRememberMe.checked; |
|
28 |
|
29 // Save the data to the storage if the user checked "Remember Me". |
|
30 widget.setPreferenceForKey( rememberMe.toString(), LoginScreen.KEY_REMEMBER_ME ); |
|
31 // If "Remember Me" is unchecked, the username and password are cleared because |
|
32 // default values for username and password values are null. |
|
33 widget.setPreferenceForKey( rememberMe ? username : null, LoginScreen.KEY_USERNAME ); |
|
34 // REMEMBER: Never store passwords uncoded. See encryption algorithms on |
|
35 // how to encode the password before saving it. |
|
36 widget.setPreferenceForKey( rememberMe ? password : null, LoginScreen.KEY_PASSWORD ); |
|
37 |
|
38 // Remember the username and password. |
|
39 twitterService.setCredentials( username, password ); |
|
40 |
|
41 // Check which view is the startup view. |
|
42 var startupPage = widget.preferenceForKey( SettingsScreen.KEY_STARTUP_PAGE ); |
|
43 if ( startupPage == SettingsScreen.SEARCH_PAGE ) { |
|
44 widgetMenu.activate( Menu.SEARCH_SCREEN ); |
|
45 } else { |
|
46 widgetMenu.activate( Menu.UPDATE_STATUS_SCREEN ); |
|
47 } |
|
48 } |
|
49 </pre><p>The startup view is stored into the <code>startupPage</code> variable by calling the <code>widget.preferenceForKey</code> API method. The code checks whether the <span class="uicontrol">Search</span> view is the startup view. If not, the <span class="uicontrol">Update status</span> view is displayed.</p></div> |
|
50 <div><h3>Loading persistent data</h3><p>The button menu calls the <code>onActivated</code> function to inform views that they are being activated. In the <span class="uicontrol">Login</span> view, this function is implemented and credentials are read if they were saved when users previously used the application. If the value of the key for <span class="uicontrol">Remember Me</span> check box is set to true, the function loads the username and password from the widget store using the predefined key constants <code>LoginScreen.KEY_USERNAME</code> and <code>LoginScreen.KEY_PASSWORD</code>.</p><pre class="codeblock">LoginScreen.prototype.onActivated = function() { |
|
51 // Check if any credentials were stored - if they were, load them |
|
52 // up and prefill the screen. |
|
53 var rememberMe = widget.preferenceForKey( LoginScreen.KEY_REMEMBER_ME ); |
|
54 if ( rememberMe == "true" ) { |
|
55 // Load up the rest; username and password. |
|
56 var username = widget.preferenceForKey( LoginScreen.KEY_USERNAME ); |
|
57 var password = widget.preferenceForKey( LoginScreen.KEY_PASSWORD ); |
|
58 |
|
59 // Assign to UI controls. Also check if username and passwords are not null; |
|
60 // the reason for this is that the user can also check the Remember Me checkbox |
|
61 // on the settings view. |
|
62 if ( username != null ) { |
|
63 this.tbUsername.value = username; |
|
64 } |
|
65 if ( password != null ) { |
|
66 this.tbPassword.value = password; |
|
67 } |
|
68 this.cbRememberMe.checked = true; |
|
69 } else { |
|
70 this.tbUsername.value = ""; |
|
71 this.tbPassword.value = ""; |
|
72 this.cbRememberMe.checked = false; |
|
73 } |
|
74 } |
|
75 </pre></div> |
|
76 <div><h3>Logging users in automatically</h3><p>If users save their credentials in STEW, they are logged into Twitter automatically when they start STEW. The following code checks that users stored valid credentials and calls the <code>onLoginClicked</code> function, which is also called when users select the <span class="uicontrol">Login</span> button.</p><pre class="codeblock">LoginScreen.prototype.loginIfPossible = function(){ |
|
77 var username = this.tbUsername.value; |
|
78 var password = this.tbPassword.value; |
|
79 var rememberMe = this.cbRememberMe.checked; |
|
80 |
|
81 // If username and password are provided then login automatically. |
|
82 if ( rememberMe && username && username.length && password && password.length ) { |
|
83 this.onLoginClicked(); |
|
84 } |
|
85 } |
|
86 </pre></div> |
|
87 <div><h3>Providing users with tactile feedback</h3><p>Tactile feedback is only triggered when a user interacts with a link element. To provide tactile feedback for screen controls specified as <code>div</code> elements, for example, call the <code>WrtHelper</code> <code>tactileFeedback</code> function.</p><p>For more information, see <a href="GUID-04ABC9FC-26FE-4854-9F88-63A2C4911886.html#GUID-04ABC9FC-26FE-4854-9F88-63A2C4911886">Providing tactile feedback for user actions</a>.</p></div> |
|
88 </div></div></div><div class="footer"><hr/><div class="copy">© Nokia 2009.</div></div></body></html> |