docu and fixes
This commit is contained in:
		
							parent
							
								
									360f6d6755
								
							
						
					
					
						commit
						2e13bf4ca2
					
				
					 5 changed files with 87 additions and 29 deletions
				
			
		|  | @ -98,7 +98,7 @@ public class LoginPage implements TemplateComposer { | ||||||
|                                     .getLoggedInUser() |                                     .getLoggedInUser() | ||||||
|                                     .getOrThrow().language); |                                     .getOrThrow().language); | ||||||
| 
 | 
 | ||||||
|                     pageContext.forwardToMainPage(pageContext); |                     pageContext.forwardToMainPage(); | ||||||
| 
 | 
 | ||||||
|                 } else { |                 } else { | ||||||
|                     loginError(pageContext, "sebserver.login.failed.message"); |                     loginError(pageContext, "sebserver.login.failed.message"); | ||||||
|  |  | ||||||
|  | @ -217,7 +217,7 @@ public class UserAccountForm implements TemplateComposer { | ||||||
|                     final Action postChanges = formHandle.postChanges(action); |                     final Action postChanges = formHandle.postChanges(action); | ||||||
|                     if (ownAccount) { |                     if (ownAccount) { | ||||||
|                         this.currentUser.refresh(); |                         this.currentUser.refresh(); | ||||||
|                         pageContext.forwardToMainPage(pageContext); |                         pageContext.forwardToMainPage(); | ||||||
|                     } |                     } | ||||||
|                     return postChanges; |                     return postChanges; | ||||||
|                 }) |                 }) | ||||||
|  |  | ||||||
|  | @ -19,21 +19,12 @@ import ch.ethz.seb.sebserver.gui.service.i18n.LocTextKey; | ||||||
| import ch.ethz.seb.sebserver.gui.service.page.action.Action; | import ch.ethz.seb.sebserver.gui.service.page.action.Action; | ||||||
| import ch.ethz.seb.sebserver.gui.service.page.event.PageEvent; | import ch.ethz.seb.sebserver.gui.service.page.event.PageEvent; | ||||||
| 
 | 
 | ||||||
|  | /** Holds a page-context and defines some convenient functionality for page handling */ | ||||||
| public interface PageContext { | public interface PageContext { | ||||||
| 
 | 
 | ||||||
|     Logger log = LoggerFactory.getLogger(PageContext.class); |     Logger log = LoggerFactory.getLogger(PageContext.class); | ||||||
| 
 | 
 | ||||||
|     public static final class PageAttr { |     /** Defines attribute keys that can be used to store attribute values within the page context state */ | ||||||
| 
 |  | ||||||
|         public final String name; |  | ||||||
|         public final String value; |  | ||||||
| 
 |  | ||||||
|         public PageAttr(final String name, final String value) { |  | ||||||
|             this.name = name; |  | ||||||
|             this.value = value; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     public interface AttributeKeys { |     public interface AttributeKeys { | ||||||
| 
 | 
 | ||||||
|         public static final String PAGE_TEMPLATE_COMPOSER_NAME = "ATTR_PAGE_TEMPLATE_COMPOSER_NAME"; |         public static final String PAGE_TEMPLATE_COMPOSER_NAME = "ATTR_PAGE_TEMPLATE_COMPOSER_NAME"; | ||||||
|  | @ -47,8 +38,14 @@ public interface PageContext { | ||||||
| 
 | 
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /** Use this to get the ComposerService used by this PageContext | ||||||
|  |      * | ||||||
|  |      * @return the ComposerService used by this PageContext */ | ||||||
|     ComposerService composerService(); |     ComposerService composerService(); | ||||||
| 
 | 
 | ||||||
|  |     /** Get the RWT Shell that is bound within this PageContext | ||||||
|  |      * | ||||||
|  |      * @return the RWT Shell that is bound within this PageContext */ | ||||||
|     Shell getShell(); |     Shell getShell(); | ||||||
| 
 | 
 | ||||||
|     /** Get the page root Component. |     /** Get the page root Component. | ||||||
|  | @ -61,9 +58,14 @@ public interface PageContext { | ||||||
|      * @return the parent Component */ |      * @return the parent Component */ | ||||||
|     Composite getParent(); |     Composite getParent(); | ||||||
| 
 | 
 | ||||||
|  |     /** Get a copy of this PageContext. | ||||||
|  |      * | ||||||
|  |      * @return */ | ||||||
|     PageContext copy(); |     PageContext copy(); | ||||||
| 
 | 
 | ||||||
|     /** Create a copy of this PageContext with a new parent Composite. |     /** Create a copy of this PageContext with a new parent Composite. | ||||||
|  |      * The implementation should take care of the imutability of PageContext and return a copy with the new parent | ||||||
|  |      * by leave this PageContext as is. | ||||||
|      * |      * | ||||||
|      * @param parent the new parent Composite |      * @param parent the new parent Composite | ||||||
|      * @return a copy of this PageContext with a new parent Composite. */ |      * @return a copy of this PageContext with a new parent Composite. */ | ||||||
|  | @ -71,34 +73,74 @@ public interface PageContext { | ||||||
| 
 | 
 | ||||||
|     /** Create a copy of this PageContext with and additionally page context attributes. |     /** Create a copy of this PageContext with and additionally page context attributes. | ||||||
|      * The additionally page context attributes will get merged with them already defined |      * The additionally page context attributes will get merged with them already defined | ||||||
|  |      * The implementation should take care of the imutability of PageContext and return a copy with the merge | ||||||
|  |      * by leave this and the given PageContext as is. | ||||||
|      * |      * | ||||||
|      * @param attributes additionally page context attributes. |      * @param attributes additionally page context attributes. | ||||||
|      * @return a copy of this PageContext with with and additionally page context attributes. */ |      * @return a copy of this PageContext with with and additionally page context attributes. */ | ||||||
|     PageContext copyOfAttributes(PageContext otherContext); |     PageContext copyOfAttributes(PageContext otherContext); | ||||||
| 
 | 
 | ||||||
|     /** Adds the specified attribute to the existing page context attributes. |     /** Adds the specified attribute to the existing page context attributes. | ||||||
|  |      * The implementation should take care of the imutability of PageContext and return a copy | ||||||
|  |      * by leave this PageContext as is. | ||||||
|      * |      * | ||||||
|      * @param key the key of the attribute |      * @param key the key of the attribute | ||||||
|      * @param value the value of the attribute |      * @param value the value of the attribute | ||||||
|      * @return this PageContext instance (builder pattern) */ |      * @return this PageContext instance (builder pattern) */ | ||||||
|     PageContext withAttribute(String key, String value); |     PageContext withAttribute(String key, String value); | ||||||
| 
 | 
 | ||||||
|  |     /** Get the attribute value that is mapped to the given name or null of no mapping exists | ||||||
|  |      * | ||||||
|  |      * @param name the attribute name | ||||||
|  |      * @return the attribute value that is mapped to the given name or null if no mapping exists */ | ||||||
|     String getAttribute(String name); |     String getAttribute(String name); | ||||||
| 
 | 
 | ||||||
|  |     /** Get the attribute value that is mapped to the given name or a default value if no mapping exists | ||||||
|  |      * | ||||||
|  |      * @param name the attribute name | ||||||
|  |      * @param def the default value | ||||||
|  |      * @return the attribute value that is mapped to the given name or null of no mapping exists */ | ||||||
|     String getAttribute(String name, String def); |     String getAttribute(String name, String def); | ||||||
| 
 | 
 | ||||||
|  |     /** Indicates if the attribute with the key READ_ONLY is set to true within this PageContext | ||||||
|  |      * | ||||||
|  |      * @return true if the attribute with the key READ_ONLY is set to true */ | ||||||
|     boolean isReadonly(); |     boolean isReadonly(); | ||||||
| 
 | 
 | ||||||
|  |     /** Gets an EntityKey for the base Entity that is associated within this PageContext by using | ||||||
|  |      * the attribute keys ENTITY_ID and ENTITY_TYPE to fetch the attribute values for an EntityKey | ||||||
|  |      * | ||||||
|  |      * @return the EntityKey of the base Entity that is associated within this PageContext */ | ||||||
|     EntityKey getEntityKey(); |     EntityKey getEntityKey(); | ||||||
| 
 | 
 | ||||||
|  |     /** Gets an EntityKey for the parent Entity that is associated within this PageContext by using | ||||||
|  |      * the attribute keys PARENT_ENTITY_ID and PARENT_ENTITY_TYPE to fetch the attribute values for an EntityKey | ||||||
|  |      * | ||||||
|  |      * @return the EntityKey of the parent Entity that is associated within this PageContext */ | ||||||
|     EntityKey getParentEntityKey(); |     EntityKey getParentEntityKey(); | ||||||
| 
 | 
 | ||||||
|  |     /** Adds a given EntityKey as base Entity key to a new PageContext that is returned as a copy of this PageContext. | ||||||
|  |      * | ||||||
|  |      * @param entityKey the EntityKey to add as base Entity key | ||||||
|  |      * @return the new PageContext with the EntityKey added */ | ||||||
|     PageContext withEntityKey(EntityKey entityKey); |     PageContext withEntityKey(EntityKey entityKey); | ||||||
| 
 | 
 | ||||||
|  |     /** Adds a given EntityKey as parent Entity key to a new PageContext that is returned as a copy of this PageContext. | ||||||
|  |      * | ||||||
|  |      * @param entityKey the EntityKey to add as parent Entity key | ||||||
|  |      * @return the new PageContext with the EntityKey added */ | ||||||
|     PageContext withParentEntityKey(EntityKey entityKey); |     PageContext withParentEntityKey(EntityKey entityKey); | ||||||
| 
 | 
 | ||||||
|  |     /** Indicates if an attribute with the specified name exists within this PageContext | ||||||
|  |      * | ||||||
|  |      * @param name the name of the attribute | ||||||
|  |      * @return true if the attribute with the specified name exists within this PageContext */ | ||||||
|     boolean hasAttribute(String name); |     boolean hasAttribute(String name); | ||||||
| 
 | 
 | ||||||
|  |     /** Returns a new PageContext with the removed attribute by name | ||||||
|  |      * | ||||||
|  |      * @param name the name of the attribute to remove | ||||||
|  |      * @return a copy of this PageContext with the removed attribute */ | ||||||
|     PageContext removeAttribute(String name); |     PageContext removeAttribute(String name); | ||||||
| 
 | 
 | ||||||
|     /** Publishes a given PageEvent to the current page tree |     /** Publishes a given PageEvent to the current page tree | ||||||
|  | @ -117,14 +159,19 @@ public interface PageContext { | ||||||
|      * @param onOK callback code block that will be executed on users OK selection */ |      * @param onOK callback code block that will be executed on users OK selection */ | ||||||
|     void applyConfirmDialog(LocTextKey confirmMessage, Runnable onOK); |     void applyConfirmDialog(LocTextKey confirmMessage, Runnable onOK); | ||||||
| 
 | 
 | ||||||
|     void forwardToPage( |     /** This can be used to forward to a defined page. | ||||||
|             PageDefinition pageDefinition, |      * | ||||||
|             PageContext pageContext); |      * @param pageDefinition the defined page */ | ||||||
|  |     void forwardToPage(PageDefinition pageDefinition); | ||||||
| 
 | 
 | ||||||
|     void forwardToMainPage(PageContext pageContext); |     /** Forward to main page */ | ||||||
|  |     void forwardToMainPage(); | ||||||
| 
 | 
 | ||||||
|     void forwardToLoginPage(PageContext pageContext); |     /** Forward to login page */ | ||||||
|  |     void forwardToLoginPage(); | ||||||
| 
 | 
 | ||||||
|  |     /** This triggers a logout on the current authorization context to logout the current user | ||||||
|  |      * and forward to the login page with showing a successful logout message to the user. */ | ||||||
|     void logout(); |     void logout(); | ||||||
| 
 | 
 | ||||||
|     /** Notify an error dialog to the user with specified error message and |     /** Notify an error dialog to the user with specified error message and | ||||||
|  | @ -134,6 +181,11 @@ public interface PageContext { | ||||||
|      * @param error the error as Throwable */ |      * @param error the error as Throwable */ | ||||||
|     void notifyError(String errorMessage, Throwable error); |     void notifyError(String errorMessage, Throwable error); | ||||||
| 
 | 
 | ||||||
|  |     /** Shows an error message to the user with the message of the given Throwable. | ||||||
|  |      * This mainly is used for debugging so far | ||||||
|  |      * | ||||||
|  |      * @param error the Throwable to display | ||||||
|  |      * @return adaption to be used with functional approaches */ | ||||||
|     <T> T notifyError(Throwable error); |     <T> T notifyError(Throwable error); | ||||||
| 
 | 
 | ||||||
|     default <T> T logoutOnError(final Throwable t) { |     default <T> T logoutOnError(final Throwable t) { | ||||||
|  | @ -142,7 +194,15 @@ public interface PageContext { | ||||||
|         return null; |         return null; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /** Publish and shows a message to the user with the given localized title and | ||||||
|  |      * localized message. The message text can also be HTML text as far as RWT supports it. | ||||||
|  |      * | ||||||
|  |      * @param title the localized text key of the title message | ||||||
|  |      * @param message the localized text key of the message */ | ||||||
|     void publishPageMessage(LocTextKey title, LocTextKey message); |     void publishPageMessage(LocTextKey title, LocTextKey message); | ||||||
| 
 | 
 | ||||||
|  |     /** Publish and shows a formatted PageMessageException to the user. | ||||||
|  |      * | ||||||
|  |      * @param pme the PageMessageException */ | ||||||
|     void publishPageMessage(PageMessageException pme); |     void publishPageMessage(PageMessageException pme); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -135,7 +135,7 @@ public class DefaultPageLayout implements TemplateComposer { | ||||||
|                 MainPageState.clear(); |                 MainPageState.clear(); | ||||||
| 
 | 
 | ||||||
|                 // forward to login page with success message |                 // forward to login page with success message | ||||||
|                 pageContext.forwardToLoginPage(pageContext); |                 pageContext.forwardToLoginPage(); | ||||||
| 
 | 
 | ||||||
|                 // show successful logout message |                 // show successful logout message | ||||||
|                 final MessageBox logoutSuccess = new Message( |                 final MessageBox logoutSuccess = new Message( | ||||||
|  |  | ||||||
|  | @ -258,23 +258,21 @@ public class PageContextImpl implements PageContext { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public void forwardToPage( |     public void forwardToPage(final PageDefinition pageDefinition) { | ||||||
|             final PageDefinition pageDefinition, |  | ||||||
|             final PageContext pageContext) { |  | ||||||
| 
 | 
 | ||||||
|         this.composerService.compose( |         this.composerService.compose( | ||||||
|                 pageDefinition.composer(), |                 pageDefinition.composer(), | ||||||
|                 pageDefinition.applyPageContext(pageContext.copyOf(pageContext.getRoot()))); |                 pageDefinition.applyPageContext(copyOf(this.root))); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public void forwardToMainPage(final PageContext pageContext) { |     public void forwardToMainPage() { | ||||||
|         forwardToPage(this.composerService.mainPage(), pageContext); |         forwardToPage(this.composerService.mainPage()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public void forwardToLoginPage(final PageContext pageContext) { |     public void forwardToLoginPage() { | ||||||
|         forwardToPage(this.composerService.loginPage(), pageContext); |         forwardToPage(this.composerService.loginPage()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|  | @ -339,7 +337,7 @@ public class PageContextImpl implements PageContext { | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         MainPageState.clear(); |         MainPageState.clear(); | ||||||
|         forwardToLoginPage(this); |         forwardToLoginPage(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|  | @ -350,7 +348,7 @@ public class PageContextImpl implements PageContext { | ||||||
| 
 | 
 | ||||||
|     private final class ConfirmDialogCallback implements DialogCallback { |     private final class ConfirmDialogCallback implements DialogCallback { | ||||||
|         private static final long serialVersionUID = 1491270214433492441L; |         private static final long serialVersionUID = 1491270214433492441L; | ||||||
|         private final Runnable onOK; |         private transient final Runnable onOK; | ||||||
| 
 | 
 | ||||||
|         private ConfirmDialogCallback(final Runnable onOK) { |         private ConfirmDialogCallback(final Runnable onOK) { | ||||||
|             this.onOK = onOK; |             this.onOK = onOK; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 anhefti
						anhefti