2013-07-25 170 views
0

enter image description here從彈出窗口彈出的視圖之間的導航

我工作的Flex應用程序。我遇到了以下問題:事實上,在第一頁中顯示的認證彈出窗口僅在用戶存在於數據庫中時纔會關閉。這部分工作正常,但我想在彈出窗口中創建一個鏈接,幫助用戶恢復其帳戶。我的問題,我不知道如何導航到恢復電子郵件的頁面,我使用狀態,但它沒有工作,請你能幫助我。這是鑑別彈出

<?xml version="1.0" encoding="utf-8"?> 
<s:TitleWindow xmlns:fx="http://ns.adobe.com/mxml/2009" 
       xmlns:s="library://ns.adobe.com/flex/spark" 
       xmlns:mx="library://ns.adobe.com/flex/mx" 
       xmlns:services="services.*" 
       x="400" y="400" width="400" height="196" cornerRadius="10" 
       creationComplete="doInit();" fontSize="12" title="Authentication" xmlns:local="*"> 
    <fx:Declarations> 
     <s:CallResponder id="authenticateUserResult"/> 
     <services:UserServiceImpl id="userServiceImpl" 
            fault="Alert.show(event.fault.faultString + '\n' + event.fault.faultDetail)" 
            showBusyCursor="true"> 
      <services:channelSet> 
       <s:ChannelSet> 
        <s:AMFChannel uri="http://localhost:8080/SmartSupport/messagebroker/amf"/> 
       </s:ChannelSet> 
      </services:channelSet> 
     </services:UserServiceImpl> 
     <s:CallResponder id="setMyStringResult"/> 
     <services:MySessionHandler id="mySessionHandler" 
            fault="Alert.show(event.fault.faultString + '\n' + event.fault.faultDetail)" 
            showBusyCursor="true"> 
      <services:channelSet> 
       <s:ChannelSet> 
        <s:AMFChannel uri="http://localhost:8080/SmartSupport/messagebroker/amf"/> 
       </s:ChannelSet> 
      </services:channelSet> 
     </services:MySessionHandler> 

      <s:CallResponder id="authenticationResp"/> 

     <!-- Placer ici les éléments non visuels (services et objets de valeur, par exemple). --> 
    </fx:Declarations> 


    <fx:Script> 
     <![CDATA[ 
      import com.roamsmart.acl.CurrentUser; 

      import mx.controls.Alert; 
      import mx.core.Application; 
      import mx.core.FlexGlobals; 
      import mx.events.CloseEvent; 
      import mx.managers.PopUpManager; 
      import mx.rpc.events.ResultEvent; 

      import valueObjects.UserEntity; 

      [Bindable] 
      public var currentU : UserEntity = new UserEntity(); 

      protected function Login_clickHandler(event:MouseEvent):void 
      { 
       authenticateUserResult.addEventListener(ResultEvent.RESULT,activateUser); 
       authenticateUserResult.token = userServiceImpl.authenticateUser(name_.text, pass.text);    
      } 
      private function doInit():void 
      {    
       this.addEventListener(KeyboardEvent.KEY_UP, handleKeyStrokes); 

      } 

      public function handleKeyStrokes(evt:KeyboardEvent):void 
      { 
       if(evt.keyCode == Keyboard.ENTER) 
       {     
        authenticateUserResult.addEventListener(ResultEvent.RESULT,activateUser); 
        authenticateUserResult.token = userServiceImpl.authenticateUser(name_.text, pass.text);  
       } 
      } 

      private function activateUser(event:Object):void{ 
       var user:UserEntity = authenticateUserResult.lastResult as UserEntity; 
       if(user) 
       { 
        if(user.enabled) 
        { 
         CurrentUser.currentUser=user; 
         PopUpManager.removePopUp(this); 
         currentU = user; 
         dispatchEvent(new CloseEvent(CloseEvent.CLOSE, true, false)); 
        } 
        else 
        { 
         errorHbox.visible = true; 
         errorLabel.text = "this user account is disabled"; 
         name_.text = ""; 
         pass.text = ""; 
        } 

       } 
       else 
       { 
        errorHbox.visible = true; 
        name_.text = ""; 
        pass.text = ""; 
       } 

      } 

      protected function authenticateUser(arg0:String, arg1:String):void 
      { 
       authenticateUserResult.token = userServiceImpl.authenticateUser(arg0, arg1); 
      } 


     ]]> 
    </fx:Script> 
    <s:states> 
     <s:State name="forgivepasswordState"/> 
     <s:State name="index"/> 

    </s:states> 


    <mx:HBox id="errorHbox" visible="false" width="98%" horizontalAlign="center" paddingLeft="10" 
      paddingTop="10" verticalAlign="middle"> 
     <s:Image width="32" height="32" source="@Embed('assets/warning.png')"/> 
     <s:Label id="errorLabel" color="red" fontSize="12" fontWeight="bold" 
       text="Wrong Username/Password combination"/> 
    </mx:HBox> 
    <!--<s:Label x="10" y="13" color="#F6800E" fontSize="14" 
    text="Your session has been expired, please Log in again"/>--> 
    <!--<mx:TextInput id="name_" x="192" y="43" width="157" height="22" text=""/> --> 
    <mx:TextInput id="name_" x="189" y="42" width="159" fontSize="15" fontWeight="normal" text=""/> 
    <mx:TextInput id="pass" x="191" y="71" width="158" displayAsPassword="true"/> 
    <mx:Label x="95" y="44" width="86" height="21" color="#024C9E" fontSize="12" text="User name"/> 
    <mx:Label x="96" y="74" width="65" height="21" color="#024C9E" fontSize="12" text="Password"/> 
    <s:Button id="linkBtnForgPwd" left="10" bottom="28" width="157" label="I forgot my password" 
      color="#000000" cornerRadius="5" 
       enabled="true" fontSize="12" icon="assets/lock_key.png" 
       skinClass="spark.skins.spark.ButtonSkin" styleName="linkButton"/> 
    <s:Button x="191" y="114" width="157" label="Log In" click="Login_clickHandler(event)" 
       cornerRadius="5" fontSize="12"/> 
    <s:Image x="7" y="115" width="29" height="20" source="assets/forgot_icon.png"/> 

</s:TitleWindow> 

我已經糾正了這個代碼,但我想它當此按鈕,用戶點擊「我忘記了密碼」看起來像它出現在彈出的面板中的代碼在屏幕截圖中提到

![<?xml version="1.0" encoding="utf-8"?> 
<s:TitleWindow xmlns:fx="http://ns.adobe.com/mxml/2009" 
       xmlns:s="library://ns.adobe.com/flex/spark" 
       xmlns:mx="library://ns.adobe.com/flex/mx" 
       xmlns:services="services.*" 
       x="400" y="400" width="400" height="196" cornerRadius="10" 
       creationComplete="doInit();" fontSize="12" title="Authentication" xmlns:local="*"> 
    <fx:Declarations> 
     <s:CallResponder id="authenticateUserResult"/> 
     <services:UserServiceImpl id="userServiceImpl" 
            fault="Alert.show(event.fault.faultString + '\n' + event.fault.faultDetail)" 
            showBusyCursor="true"> 
      <services:channelSet> 
       <s:ChannelSet> 
        <s:AMFChannel uri="http://localhost:8080/SmartSupport/messagebroker/amf"/> 
       </s:ChannelSet> 
      </services:channelSet> 
     </services:UserServiceImpl> 
     <s:CallResponder id="setMyStringResult"/> 
     <services:MySessionHandler id="mySessionHandler" 
            fault="Alert.show(event.fault.faultString + '\n' + event.fault.faultDetail)" 
            showBusyCursor="true"> 
      <services:channelSet> 
       <s:ChannelSet> 
        <s:AMFChannel uri="http://localhost:8080/SmartSupport/messagebroker/amf"/> 
       </s:ChannelSet> 
      </services:channelSet> 
     </services:MySessionHandler> 

      <s:CallResponder id="authenticationResp"/> 

     <!-- Placer ici les éléments non visuels (services et objets de valeur, par exemple). --> 
    </fx:Declarations> 


    <fx:Script> 
     <!\[CDATA\[ 
      import com.roamsmart.acl.CurrentUser; 

      import mx.controls.Alert; 
      import mx.core.Application; 
      import mx.core.FlexGlobals; 
      import mx.events.CloseEvent; 
      import mx.managers.PopUpManager; 
      import mx.rpc.events.ResultEvent; 

      import valueObjects.UserEntity; 

      \[Bindable\] 
      public var currentU : UserEntity = new UserEntity(); 

      protected function Login_clickHandler(event:MouseEvent):void 
      { 
       authenticateUserResult.addEventListener(ResultEvent.RESULT,activateUser); 
       authenticateUserResult.token = userServiceImpl.authenticateUser(name_.text, pass.text);    
      } 
      private function doInit():void 
      {    
       this.addEventListener(KeyboardEvent.KEY_UP, handleKeyStrokes); 

      } 

      public function handleKeyStrokes(evt:KeyboardEvent):void 
      { 
       if(evt.keyCode == Keyboard.ENTER) 
       {     
        authenticateUserResult.addEventListener(ResultEvent.RESULT,activateUser); 
        authenticateUserResult.token = userServiceImpl.authenticateUser(name_.text, pass.text);  
       } 
      } 

      private function activateUser(event:Object):void{ 
       var user:UserEntity = authenticateUserResult.lastResult as UserEntity; 
       if(user) 
       { 
        if(user.enabled) 
        { 
         CurrentUser.currentUser=user; 
         PopUpManager.removePopUp(this); 
         currentU = user; 
         dispatchEvent(new CloseEvent(CloseEvent.CLOSE, true, false)); 
        } 
        else 
        { 
         errorHbox.visible = true; 
         errorLabel.text = "this user account is disabled"; 
         name_.text = ""; 
         pass.text = ""; 
        } 

       } 
       else 
       { 
        errorHbox.visible = true; 
        name_.text = ""; 
        pass.text = ""; 
       } 

      } 

      protected function authenticateUser(arg0:String, arg1:String):void 
      { 
       authenticateUserResult.token = userServiceImpl.authenticateUser(arg0, arg1); 
      } 


     \]\]> 
    </fx:Script> 
    <s:states> 
     <s:State name="forgivepasswordState"/> 
     <s:State name="index"/> 

    </s:states> 


    <mx:HBox id="errorHbox" visible="false" width="98%" horizontalAlign="center" paddingLeft="10" 
      paddingTop="10" verticalAlign="middle"> 
     <s:Image width="32" height="32" source="@Embed('assets/warning.png')"/> 
     <s:Label id="errorLabel" color="red" fontSize="12" fontWeight="bold" 
       text="Wrong Username/Password combination"/> 
    </mx:HBox> 
    <!--<s:Label x="10" y="13" color="#F6800E" fontSize="14" 
    text="Your session has been expired, please Log in again"/>--> 
    <!--<mx:TextInput id="name_" x="192" y="43" width="157" height="22" text=""/> --> 
    <mx:TextInput id="name_" x="189" y="42" width="159" fontSize="15" fontWeight="normal" text=""/> 
    <mx:TextInput id="pass" x="191" y="71" width="158" displayAsPassword="true"/> 
    <mx:Label x="95" y="44" width="86" height="21" color="#024C9E" fontSize="12" text="User name"/> 
    <mx:Label x="96" y="74" width="65" height="21" color="#024C9E" fontSize="12" text="Password"/> 
    <s:Button id="linkBtnForgPwd" left="10" bottom="28" width="157" label="I forgot my password" click="this.currentState='forgivepasswordState'" 
      color="#000000" cornerRadius="5" 
       enabled="true" fontSize="12" icon="assets/lock_key.png" 
       skinClass="spark.skins.spark.ButtonSkin" styleName="linkButton"/> 
    <s:Button x="191" y="114" width="157" label="Log In" click="Login_clickHandler(event)" 
       cornerRadius="5" fontSize="12"/> 
    <s:Image x="7" y="115" width="29" height="20" source="assets/forgot_icon.png"/> 
    <local:forgotPassword includeIn="forgivepasswordState"/> 

</s:TitleWindow>][1] 
+0

請問您能告訴我們什麼不起作用嗎?你預期的結果是什麼?究竟發生了什麼? – JeffryHouser

回答

0

我看不到任何代碼,您嘗試更改狀態。你只需要在「忘記圖標」圖像上添加一個事件監聽器?

<s:Image x="7" y="115" width="29" height="20" source="assets/forgot_icon.png" click="{currentstate='forgivepasswordState'}"/> 
+0

我糾正了它,但我希望導航到面板上,當我點擊按鈕出現在第一次,當我點擊按鈕沒有什麼 – hana

+0

這聽起來像你的狀態設置錯了,然後 – JeffryHouser

+0

但我讓狀態點擊! – hana