The present disclosure relates to user interfaces, and more specifically, to configurable user interfaces.
Graphical user interfaces (GUIs) can be created using a variety of different techniques. However, ultimately the goal of the user interface is to define how a user will see data and be able to interact with that data. Although a developer can create source code in a programming language (e.g., Java, C#, etc.) to implement a GUI, toolkits of reusable widgets have been developed that simplify creation of GUIs. For example, a drag-and-drop development environment may be provided that allows a developer to select from a variety of pre-defined widgets and place them onto a pallet so as to create a basic GUI for a particular software application. The developer can then associate various portions of programming code with components of the widgets that will be invoked when a user eventually interacts with the elements of the GUI so as to perform the functionality of the software application.
The availability of widget toolkits and similar GUI design applications allows re-use of common widgets such as, for example, buttons, check boxes, forms, slider controls, drop-down menus, tree views, toolbars, text boxes, table views, query boxes, pop-up help windows, status bars, etc. without a developer recreating each widget from scratch each time it is needed. When the data to be viewed and interacted with is well known and defined, the widget toolkits and drag-and-drop development environments can simplify many aspects of defining a GUI. However, even with a toolkit of available widgets, development of a GUI to potentially handle multiple, disparate types of data, or even data that may not be known at development time, often requires a level of programming proficiency and effort that offsets some of the benefits provided by availability of the toolkits.
According to one aspect of the present disclosure, a method of providing a configurable user interface comprises receiving, by a server computer, a request for information to be rendered in a user interface; and in response to the request, sending, by the server computer, the information to be rendered and an identifier related to one of a plurality of user interface components. Also, in response to the request, the server computer sends a registry of the plurality of user interface components, wherein the registry comprises a respective entry for each of the plurality of user interface components. More particularly, the respective entry for a particular one of the plurality of user interface components comprises: a) a location of a configuration associated with the particular one user interface component; and b) a plurality of attributes and corresponding attribute values associated with the particular one user interface component.
According to another aspect of the disclosure, a system for providing a configurable user interface comprises a server computer comprising a communication module configured to receive a request for information to be rendered in a user interface; wherein the communication module further configured, in response to receiving the request, to send the information to be rendered and an identifier related to one of a plurality of user interface components. The communication module is further configured to send a registry of the plurality of user interface components, wherein the registry comprises a respective entry for each of the plurality of user interface components. More particularly, the respective entry for a particular one of the plurality of user interface components comprises: a) a location of a configuration associated with the particular one user interface component; and b) a plurality of attributes and corresponding attribute values associated with the particular one user interface component.
According to yet another aspect of the disclosure, a computer program product for providing a configurable user interface comprises a computer readable storage medium having computer readable program code embodied therewith. The computer readable program code, itself, comprises computer readable program code configured to receive a request for information to be rendered in a user interface; computer readable program code configured to send the information to be rendered and an identifier related to one of a plurality of user interface components; and computer readable program code configured to send a registry of the plurality of user interface components. The registry comprises a respective entry for each of the plurality of user interface components. More particularly, the respective entry for a particular one of the plurality of user interface components comprises: a) a location of a configuration associated with the particular one user interface component; and b) a plurality of attributes and corresponding attribute values associated with the particular one user interface component.
Another aspect of the present disclosure relates to a method of maintaining a registry of a plurality of user interface components that comprises determining a location of a configuration associated with a new one of the plurality of user interface components; assigning a respective value to each of a plurality of attributes associated with the new one of the plurality of user interface components, wherein at least a subset of the plurality of attributes relates to a runtime environment in which the new one of the plurality of user interface components can be instantiated; and adding a corresponding entry for the new one of the plurality of user interface components in the registry, wherein the entry comprises the location and plurality of respective values.
An additional aspect of the present disclosure relates to a system for maintaining a registry of a plurality of user interface components that comprises a computer-readable storage medium configured to store the registry; a component editing module configured to specify a location of a configuration associated with a new one of the plurality of user interface components; and wherein the component editing module is further configured to assign a respective value to each of a plurality of attributes associated with the new one of the plurality of user interface components, wherein at least a subset of the plurality of attributes relates to a runtime environment in which the new one of the plurality of user interface components can be instantiated. The component editing module, in communication with the computer-readable storage medium, is further configured to add a corresponding entry for the new one of the plurality of user interface components to the registry stored on the computer-readable storage medium, wherein the entry comprises the location and plurality of respective values.
Yet another aspect of the present disclosure relates to a computer program product for maintaining a registry of a plurality of user interface components that comprises a computer readable storage medium having computer readable program code embodied therewith. In particular, the computer readable program code comprises a) computer readable program code configured to determine a location of a configuration associated with a new one of the plurality of user interface components; b) computer readable program code configured to assign a respective value to each of a plurality of attributes associated with the new one of the plurality of user interface components, wherein at least a subset of the plurality of attributes relates to a runtime environment in which the new one of the plurality of user interface components can be instantiated; and c) computer readable program code configured to add a corresponding entry for the new one of the plurality of user interface components in the registry, wherein the entry comprises the location and plurality of respective values. An additional aspect of the present disclosure relates to a method for a runtime configurable user interface that comprises executing an application configured to render information within a user interface; analyzing a registry of a plurality of user interface components, wherein the registry comprises a respective entry for each of the plurality of user interface components; selecting a selected user interface component from among the plurality of user interface components; and rendering the information using the selected user interface component.
Another aspect of the present disclosure relates to a system providing a runtime configurable user interface. The system comprises a processor, memory and display configured to execute an application rendering information within a user interface. Also, the application is configured to analyze a registry of a plurality of user interface components, wherein the registry comprises a respective entry for each of the plurality of user interface components; and is further configured to select a selected user interface component from among the plurality of user interface components and to render the information using the selected user interface component.
One additional aspect of the present disclosure relates to a computer program product for providing a runtime configurable user interface that comprises a computer readable storage medium having computer readable program code embodied therewith. In particular, the computer readable program code comprises computer readable program code configured to execute an application configured to render information within a user interface; computer readable program code configured to analyze a registry of a plurality of user interface components, wherein the registry comprises a respective entry for each of the plurality of user interface components; computer readable program code configured to select a selected user interface component from among the plurality of user interface components; and computer readable program code configured to render the information using the selected user interface component
Aspects of the present disclosure are illustrated by way of example and are not limited by the accompanying figures with like references indicating like elements.
As will be appreciated by one skilled in the art, aspects of the present disclosure may be illustrated and described herein in any of a number of patentable classes or context including any new and useful process, machine, manufacture, or composition of matter, or any new and useful improvement thereof. Accordingly, aspects of the present disclosure may be implemented entirely hardware, entirely software (including firmware, resident software, micro-code, etc.) or combining software and hardware implementation that may all generally be referred to herein as a “circuit,” “module,” “component,” or “system.” Furthermore, aspects of the present disclosure may take the form of a computer program product embodied in one or more computer readable media having computer readable program code embodied thereon.
Any combination of one or more computer readable media may be utilized. The computer readable media may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an appropriate optical fiber with a repeater, a portable compact disc read-only memory (CORaM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device. Program code embodied on a computer readable signal medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
Computer program code for carrying out operations for aspects of the present disclosure may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Scala, Smalltalk, Eiffel, JADE, Emerald, C++, CII, VB.NET, Python or the like, conventional procedural programming languages, such as the “c” programming language, Visual Basic, Fortran 2003, Perl, COBOL 2002, PHP, ABAP, dynamic programming languages such as Python, Ruby and Groovy, or other programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider) or in a cloud computing environment or offered as a service such as a Software as a Service (SaaS).
Aspects of the present disclosure are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatuses (systems) and computer program products according to embodiments of the disclosure. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable instruction execution apparatus, create a mechanism for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
These computer program instructions may also be stored in a computer readable medium that when executed can direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions when stored in the computer readable medium produce an article of manufacture including instructions which when executed, cause a computer to implement the function/act specified in the flowchart and/or block diagram block or blocks. The computer program instructions may also be loaded onto a computer, other programmable instruction execution apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatuses or other devices to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
To aid in understanding aspects of the present disclosure, an example environment of Java-implemented portals and portlets is described, with respect to
Referring to
As mentioned above, the environment of
While any of a variety of widgets can be used to construct a user interface, different “views” are a basic component of almost all user interfaces. For example, a table view is view in which a plurality of objects of a similar type are depicted in a list, often with multiple columns such as a table view 202
An application developer may want to develop an application that includes the composite view 200. Thus, the composite view 200 can include the table view 202 which includes a table of entries 206 having a plurality of rows wherein each row is associated with a particular object (e.g., a computer system). The table view 202 is constructed so that a user can select a row (e.g., by selecting a hyperlink in one of the cells of the table 206). Based on a user's selection, the form view 204 will display detailed information about the computer system associated with the user's selected row.
The composite view 200 of
In accordance with the principles and techniques described in this disclosure, a view registry 490 is implemented that identifies different views created by application developers and, for each such view, identifies attributes which help identify when that particular view may be better to use than other views in the view registry. In parts of the previous discussion and in the examples described below, the term “view” is used as one example of a user interface component. Thus, even though the term “view” may be used, other components of a user interface that are rendered for a user either to display data or to allow interaction with data are contemplated within the scope of the term “view”.
In step 302, of
Using the basic view “Example”, the application developer modifies, or configures, the view, in step 304, to create a new version of “Example”. As an example, the application developer can configure the table view and the form view in a side-by-side configuration as shown in
The same application developer or another application developer, in step 304, can configure the “Example” view such that a table view is shown in a full screen by itself. When a user selects an item in the table, then the screen is replaced by a form view shown in the full screen. The form view includes a “BACK” button or some other design element to return to the table view. This configuration, or version, of the “Example” view can be registered in the view registry as “Example_mobile”.
Some languages read from right to left instead of left to right. Thus, an application developer may want to create yet another configuration of the Example view that places the table view on the right half of a window and the form view on the left half of the window. This configuration may be registered in the view registry as “Example_RtoL”.
The form view and table view can themselves be used to create different configurations to be registered with the view registry. Thus, the form view 204 can be a generic form view that can display any type of object having attributes. According to the form view, the attributes are displayed in a default order in a simple list. An application developer may, however, desire a custom form view when the object being displayed is of a particular type (e.g., objects of type A). The application developer can modify the generic form view such that the attribute fields for objects of type A appear in a particular order and in a particular arrangement (e.g., 3 columns of 3 elements each). The application developer could then register that form view as “form_ObjectA” in the view registry.
As part of configuring the new view that is to be registered, the application developer, in step 306, determines attributes associated with that new view that help identify user devices or user platforms that particularly benefit from the new view configuration. An example of some attributes that may be beneficial are provided in the table below:
Thus, in step 306, the application developer identifies one or more attributes that help differentiate one view configuration from another. Values are assigned to the identified attributes and the new view configuration is registered in step 308 into the view registry.
A register entry (e.g., 492, 496) for a view may also include values for a plurality of attributes that help distinguish one view from another. Example attributes are identified in the table above but one of ordinary skill will recognize that other attributes may be added to that example list and all the listed attributes may not necessarily be used. As explained below, these attributes may be used at runtime to provide a user interface that is customized for the user's device or platform. Some of these attributes may also relate to the data (e.g., the object type) to be displayed. Thus, the user interface may be customized based on the runtime data being displayed.
Initially, in step 502, a request from a browser is received by a server requesting a portal page. The request from the browser can include information about the browser (e.g., an Operating System on which the browser is running, a processor of a user device which is running the browser, a character set used by the browser, a language and locale of the environment in which the browser is running, etc.). In response to the request for a portal page, the server constructs a portal page to send to the browser, in step 504. Each portlet included in the portal page will be comprised of its own portion of javascript that the browser will use to render the portlet in a window viewable by the user.
In step 506, the server may optionally determine which parts of the view registry 490 is relevant to the requested portal page. For example, if the request of step 502 indicates that a requesting device is a mobile device, then views in the view registry 490 related to requiring desktop interaction may not be relevant to the requested portal page and may not be sent. An example of portions of a view registry, for two registered views, that can be provided by a server is shown below:
In the above example, the first field provides a name for the view and the next fields provide a list of attributes and an associated value for the view. The last item in each view entry is a location where the actual configuration script, or code, for instantiating that view may be located so that it can be retrieved as needed.
In step 508, the server serves to the browser the portal page and the view registry, or at least a relevant portion of the view registry. The server may also include with the portal page a script, or similar executable statements, that can analyze the view registry, as explained below. Alternatively, the portal page may include javascript that, when executed, separately requests the view registry. In step 510, the browser receives the portal page, the view registry, and the javascript, for example, which can analyze the view registry.
In a portlet implemented using javascript, for example, the javascript may include a line referencing a function ViewRegistry that is executed, in step 512, to determine which view in the view registry is to be used to render the current portlet. The ViewRegistry function is included, as mentioned above, by the server as part of the portal page and is capable of analyzing the view registry. The syntax or format of the ViewRegistry function can vary greatly but, in concept, it specifies one or more criteria for the view that is to be used to render the portlet. For example, the ViewRegistry function can specify a value for alias, dataClass, etc. and identify those views in the view registry that best match the specified values considering attributes of the runtime environment.
In general, the executable line provided for a portlet can include an identifier that is related to one of the attributes of the views in the view registry. For example, the executable line provided for this portlet by the server for the ViewRegistry function can specify that alias=“Example”. The functionality of the ViewRegistry function can then search the view registry locating all the entries having a matching value (e.g., Example) for the attribute alias. The ViewRegistry function can also evaluate the other attributes such as desktop, touch, locale, etc. as compared to those same attributes of the system on which the portlet is to be rendered. Of the entries in the view registry, the function ViewRegistry identifies, in step 514, the view entry that provides a “best” match to the current user environment. The call of the ViewRegistry function can also specify alternative criteria such as, for example, ViewName=“Example_mobile” or DataClass=“list”. In the former example, this will result in identifying a particular view by name so that its configuration file is used for instantiating the view when rendering the portlet; and the latter example, will avoid looking a tables and forms when identifying a best view from the view registry.
One of ordinary skill will recognize that there are a variety of ways to identify a “best match”. For example, in the above example of the portion of the view registry, there is an attribute “Locale: {*_*:1}”. This example syntax may be interpreted that any language and location (e.g., the wildcard *_*) will match this view entry but that it will be given a weight, or value, of “1”. An alternative view entry in the registry might have the same exact syntax for all the other attributes except for “Locale: {EN_US:5}”. In this instance, if the user local is identified as the English language in the United States, then this match has a weight, or value, of “5”. Thus, the ViewRegistry function can determine a best matching view by assigning a “1” to each attribute that matches and a “0” to all not matching attributes. A sum can be tallied for each view entry in the view registry and used to rank the view entries to determine the “best match”. Also, assigning weighted values to one or more attributes may be used when generating a score.
Once the ViewRegistry function has identified the best matching view from the view registry, the location of the configuration information is retrieved from the registry entry, in step 516. The location may point to code that has already been loaded as part of the current portal page, code that may be present in a browser cache because it was referenced earlier, or code that is resident on the portal server or other system. If the view is a re-configuration of a previous view, configuration information that re-configures previous view into a new view is loaded. If the view is a wholly new view, then the code that implements that view can be loaded. The retrieved view configuration code can itself include references to ViewRegistry to be resolved for selecting additional views from the view registry. In other words, the configuration for a view may include sub-views and these sub-views may be loaded and parsed for any sub-views that they may contain. Thus, in step 518, the executable code that was provided by the server for analyzing the view registry recursively parses through the JavaScript, for example, for rendering a portlet to select the various, potentially nested views and sub-views to use to render the portlet. Thus, the loop between steps 512 and 518 in
Because a view entry in the view registry can point to a location on the portal server, or other system, where the configuration code for implementing that view resides, the views which are used to provide the user interface can be easily updated and used even while a user is accessing the portal page. Also, new views can be added to a view registry to take advantage of new devices or different capabilities as they are developed without requiring any change to the portal server.
Referring to
Also connected to the I/O bus may be devices such as a graphics adapter 416, storage 418 and a computer usable storage medium 420 having computer usable program code embodied thereon. The computer usable program code may be executed to execute any aspect of the present disclosure, for example, to implement aspect of any of the methods, computer program products and/or system components illustrated in
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various aspects of the present disclosure. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
The terminology used herein is for the purpose of describing particular aspects only and is not intended to be limiting of the disclosure. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
The corresponding structures, material s, acts, and equivalents of any means or step plus function elements in the claims below are intended to include any disclosed structure, material, or act for performing the function in combination with other claimed elements as specifically claimed. The description of the present disclosure has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the disclosure in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the disclosure. The aspects of the disclosure herein were chosen and described in order to best explain the principles of the disclosure and the practical application, and to enable others of ordinary skill in the art to understand the disclosure with various modifications as are suited to the particular use contemplated.
The present application is a divisional of, and claims benefit from, U.S. application Ser. No. 13/617,066, filed Sep. 14, 2012, entitled USER INTERFACE WITH CONFIGURATION, REGISTRATION, AND RUNTIME SELECTION OF VIEWS, the contents of which are incorporated herein by reference in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
6404445 | Galea et al. | Jun 2002 | B1 |
6546397 | Rempell | Apr 2003 | B1 |
6804816 | Liu et al. | Oct 2004 | B1 |
6950850 | Leff | Sep 2005 | B1 |
6990654 | Carroll | Jan 2006 | B2 |
6996800 | Lucassen | Feb 2006 | B2 |
7089530 | Dardinski et al. | Aug 2006 | B1 |
7103853 | Patil | Sep 2006 | B1 |
7106337 | Lu | Sep 2006 | B2 |
7162697 | Markel | Jan 2007 | B2 |
7210094 | Dovin | Apr 2007 | B2 |
7216298 | Ballard et al. | May 2007 | B1 |
7225424 | Cherdron | May 2007 | B2 |
7263663 | Ballard et al. | Aug 2007 | B2 |
7272815 | Eldridge et al. | Sep 2007 | B1 |
7308649 | Ehrich | Dec 2007 | B2 |
7409692 | Ittel | Aug 2008 | B2 |
7603657 | Gassner et al. | Oct 2009 | B2 |
7636852 | Balasubramanian | Dec 2009 | B1 |
7681138 | Grasser et al. | Mar 2010 | B2 |
7752637 | Gunduc et al. | Jul 2010 | B2 |
7788214 | Fernandez | Aug 2010 | B2 |
7801949 | Sundaresan | Sep 2010 | B2 |
8108404 | Sylthe | Jan 2012 | B2 |
8166455 | Voss | Apr 2012 | B2 |
8266202 | Colton | Sep 2012 | B1 |
8271703 | Wang | Sep 2012 | B2 |
8429630 | Nickolov et al. | Apr 2013 | B2 |
8516442 | Grechanik et al. | Aug 2013 | B2 |
8533661 | Nucci et al. | Sep 2013 | B2 |
8589446 | Peterson | Nov 2013 | B2 |
8612947 | LeRoux et al. | Dec 2013 | B2 |
8704775 | Cantrell | Apr 2014 | B2 |
8713520 | Bank et al. | Apr 2014 | B2 |
8793584 | Chen et al. | Jul 2014 | B2 |
8806329 | Steelberg | Aug 2014 | B2 |
8839132 | Reichert | Sep 2014 | B2 |
8843827 | Koo et al. | Sep 2014 | B2 |
8935147 | Stern | Jan 2015 | B2 |
8996987 | Rivera | Mar 2015 | B2 |
9009110 | Brunswig | Apr 2015 | B2 |
9143378 | Behl | Sep 2015 | B2 |
9208253 | Zoheir | Dec 2015 | B2 |
9294538 | Rana | Mar 2016 | B1 |
9575949 | Delancy, Jr. | Feb 2017 | B2 |
20020085020 | Carroll, Jr. | Jul 2002 | A1 |
20020088008 | Markel | Jul 2002 | A1 |
20020101448 | Sanderson | Aug 2002 | A1 |
20020124076 | Lindstrom-Tamer | Sep 2002 | A1 |
20020156922 | Chan | Oct 2002 | A1 |
20030046401 | Abbott | Mar 2003 | A1 |
20030058277 | Bowman-Amuah | Mar 2003 | A1 |
20030195923 | Bloch et al. | Oct 2003 | A1 |
20040064802 | Cherdron | Apr 2004 | A1 |
20050071749 | Goerke | Mar 2005 | A1 |
20050071758 | Ehrich | Mar 2005 | A1 |
20050071850 | Ittel | Mar 2005 | A1 |
20050256852 | McNall et al. | Nov 2005 | A1 |
20050273762 | Lesh | Dec 2005 | A1 |
20060053411 | Takamiya | Mar 2006 | A1 |
20060143220 | Spencer, Jr. | Jun 2006 | A1 |
20060173808 | Peterson et al. | Aug 2006 | A1 |
20060206866 | Eldrige et al. | Sep 2006 | A1 |
20060224946 | Barrett et al. | Oct 2006 | A1 |
20060248166 | Milosevic | Nov 2006 | A1 |
20070180066 | Sherwood | Aug 2007 | A1 |
20070180432 | Gassner | Aug 2007 | A1 |
20070239291 | Wayland | Oct 2007 | A1 |
20070271501 | Vasilik | Nov 2007 | A1 |
20070277109 | Chen | Nov 2007 | A1 |
20080120594 | Lucas | May 2008 | A1 |
20080244560 | Neagu | Oct 2008 | A1 |
20080288459 | Kim | Nov 2008 | A1 |
20090063178 | Pousti | Mar 2009 | A1 |
20090106366 | Virtanen | Apr 2009 | A1 |
20090132915 | McCraw | May 2009 | A1 |
20090132954 | Cupitt | May 2009 | A1 |
20090171655 | Stern | Jul 2009 | A1 |
20090172569 | Arthursson et al. | Jul 2009 | A1 |
20090210781 | Hagerott | Aug 2009 | A1 |
20090217182 | Grechanik | Aug 2009 | A1 |
20090217250 | Grechanik | Aug 2009 | A1 |
20090217303 | Grechanik | Aug 2009 | A1 |
20090217309 | Grechanik | Aug 2009 | A1 |
20090265686 | Lucas | Oct 2009 | A1 |
20090288098 | Abd-El-Malek | Nov 2009 | A1 |
20090320050 | Pousti | Dec 2009 | A1 |
20100121879 | Greenberg | May 2010 | A1 |
20100313122 | Sandford | Dec 2010 | A1 |
20110119652 | Yu | May 2011 | A1 |
20110173221 | Ahiakpor | Jul 2011 | A1 |
20110296375 | Mooney | Dec 2011 | A1 |
20110314078 | Morris | Dec 2011 | A1 |
20110314097 | Morris | Dec 2011 | A1 |
20120089669 | Berg et al. | Apr 2012 | A1 |
20120144334 | Reichert | Jun 2012 | A1 |
20120173760 | Jog | Jul 2012 | A1 |
20120179987 | Mohan | Jul 2012 | A1 |
20120185821 | Yaseen et al. | Jul 2012 | A1 |
20120260154 | Delancy, Jr. | Oct 2012 | A1 |
20120296999 | Kuo | Nov 2012 | A1 |
20130007107 | Behl | Jan 2013 | A1 |
20130007590 | Rivera | Jan 2013 | A1 |
20130031462 | Calvo | Jan 2013 | A1 |
20130041882 | Brodsky | Feb 2013 | A1 |
20130067372 | Boeke | Mar 2013 | A1 |
20130106885 | Clark | May 2013 | A1 |
20130111506 | Guddanti | May 2013 | A1 |
20130117351 | Zoheir | May 2013 | A1 |
20130132818 | Anders | May 2013 | A1 |
20130166697 | Manning | Jun 2013 | A1 |
20130173549 | Brunswig | Jul 2013 | A1 |
20130290786 | Artzi | Oct 2013 | A1 |
20130326046 | Chan | Dec 2013 | A1 |
20130328888 | Beaver et al. | Dec 2013 | A1 |
20130339835 | Marum | Dec 2013 | A1 |
20130346943 | Bharatia | Dec 2013 | A1 |
20140089419 | Morris | Mar 2014 | A1 |
20140089420 | Morris | Mar 2014 | A1 |
20140195337 | Taylor | Jul 2014 | A1 |
20140195890 | Taylor | Jul 2014 | A1 |
20140250422 | Bank et al. | Sep 2014 | A1 |
20140304690 | Wohlberg et al. | Oct 2014 | A1 |
20140372205 | Ray | Dec 2014 | A1 |
20150121448 | Burch | Apr 2015 | A1 |
20150254222 | Shadfar | Sep 2015 | A1 |
20160063872 | Trujillo | Mar 2016 | A1 |
20160077694 | Christoph | Mar 2016 | A1 |
20160103815 | Suryadi | Apr 2016 | A1 |
20160147828 | Yu | May 2016 | A1 |
20170060812 | Williams | Mar 2017 | A1 |
Entry |
---|
Jung-Mu Chuang, Notice of Allowance, U.S. Appl. No. 13/617,066, dated Sep. 23, 2015, United States Patent and Trademark Office, Alexandria, VA. |
Project Orchard; Basic Orchard Concepts—Orchard Documentation; http://web.archive.org/web/20110817114710/http://orchardproject.net/docs/Default.aspx?Page=Basic_Orchard-Concepts&NS-&AspxAutoDetectCookieSupport=1; 10 pages; Jun. 23, 2011. |
Walkthrough: Creating a Basic asp.net MVC Project; http://web.archive.org/web/20110905133448/http://msdn.microsoft.com/en-us/library/dd410123%28v=vs.98%29.aspx; 8 pages; Sep. 6, 2011. |
Walkthrough: Using Templated Helpers to Display Data in asp.net MVC; http://webarchive.org/web/20110905075734/http://msdn.microsoft.com/en-us/library/ee308450%28v=VS.98%29aspx; 8 pages Sep. 5, 2011. |
Lo, Weilun; Non-Final Office Action; U.S. Appl. No. 13/617,066, filed Sep. 14, 2012; United States Patent and trademark Office; Alexandria, VA. |
Related U.S. Appl. No. 13/617,066; Entitled “User Interface With Configuration, Registration, and Runtime Selection of Views,” filed Sep. 14, 2012 by Howard A. Abrams. |
Related U.S. Appl. No. 14/672,821; Entitled “User Interface With Runtime Selection of Views,” filed Mar. 30, 2015 by Howard A. Abrams. |
Chuang, Jung-Mu T.; Non-final Office Action; U.S. Appl. No. 14/672,821; dated May 22, 2017; United States Patent and Trademark Office; Alexandria, VA. |
Chuang, Jung-Mu; Final Office Action; U.S. Appl. No. 14/672,821; dated Sep. 21, 2017; U.S. Patent and Trademark Office, Alexandria, VA. |
Number | Date | Country | |
---|---|---|---|
20150205470 A1 | Jul 2015 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13617066 | Sep 2012 | US |
Child | 14672734 | US |