This present disclosure relates to software application user interfaces, and more particularly to handling violations of user-interface-related consistency rules.
Modern software applications, adapted for use with human users, typically employ at least one user interface to display data, controls, media, and other information to the user. Software application user interfaces (or “user interfaces,” or “UIs”) can also be interactive, allowing a user to interact with elements, controls, and data displayed on a graphical user interface device via a keyboard, mouse, touchscreen, and other devices. In some modern software applications and services, a single program or application can include several different user interfaces that can be displayed to and interacted with by the user. Further, in some enterprise software solutions offering or serving dozens of different software programs and services to end users, hundreds, and even thousands of related user interfaces can be provided and maintained within the software environment.
As computing and software markets mature, the development of user interfaces for software solutions and systems has grown more sophisticated. For instance, user experience design principles have been integrated into the design of modern software products. User experience design is user-centered, focusing on designing products, in this case software, with a primary focus on the user's experience and interaction with the product. User experience (or “UX”) design principles aim to make users' interactions as simple, efficient, and enjoyable as possible. Considerations of user experience design can include various dimensions including the look, feel, access to tools and services, and communication and co-operation support provided through the user interface. Indeed, international standard (e.g., ISO 9241) have established describing interface design requirements for usability.
Some products have been developed to assist product designers in realizing user-centered design, such as user interface prototyping and simulation tools. In some cases, software user interface design solutions can be proposed and promoted through a user interface style guide defining rules, conventions, preferences, and guidelines for user interfaces within a system. In some cases, user interface style guide can also focus on maintaining user interface consistency across a software product, for example, to promote a consistent particular product appearance, familiar user controls, or maintain a product trade dress.
This disclosure provides various embodiments for generating reports relating to UI models' compliance with a set of UI style guide rules. A digital UI model can be parsed to determine whether a user interface, in a plurality of user interfaces within a software environment, satisfies at least one UI style guide rule in a plurality of UI style guide rules associated with the software environment. The digital UI model can define a plurality of attributes of the user interface. At least one statistical measure can be calculated relating to compliance with UI style guide rules. The calculation of the statistical measure can be based at least in part on the determination of whether the user interface satisfies the at least one UI style guide rule. A report can then be generated identifying the at least one statistical measure, the report configured for presentation on a user interface of a computing device.
While generally described as computer implemented software that processes and transforms the respective data, some or all of the aspects may be computer implemented methods or further included in respective systems or other devices for performing this described functionality. The details of these and other aspects and embodiments of the present disclosure are set forth in the accompanying drawings and the description below. Other features, objects, and advantages of the disclosure will be apparent from the description and drawings, and from the claims.
Like reference symbols in the various drawings indicate like elements.
Developing user interfaces (UIs) for software applications can be an expensive and resource-intensive process. Further, developing UIs within an existing software application environment can be further complicated by efforts to maintain consistency across all user interfaces in an application or software environment. Software products are rarely static however, and designers can opt for modifications to existing or previous UIs. Propagating these changes across each and every UI within a multi-UI system can be challenging and, in some cases, require redevelopment of one or more user interfaces in the system. Indeed, in large software environments, such as distributed enterprise software systems employing thousands of UIs within the system, making changes to and discovering inconsistencies among the design of the multiple UI can be prohibitively burdensome.
In some instances, parsable, digital UI models can be used to model attributes of user interfaces within a software environment. For instance, the location, labeling, color, size, and formatting of various UI elements within a particular UI can be described and defined within the UI model. Similar UI models can be generated and maintained for each UI within a particular software environment. A common UI style guide can be employed for UIs within the environment, with a plurality of executable UI rule check scripts being maintained and made available to automatically check the UI models to determine whether particular UIs in the environment are in violation of one or more UI style guide rules. Such UI rule check scripts can be integrated within UI development tools to further give users immediate feedback regarding UI design choices and can further be the basis of UI development planning and consistency reporting within the context of a UI design time effort. UI rule check scripts can facilitate quick and system-wide UI style guide rule consistency checks and can facilitate mass modifications of UI models to correct violations of UI style guide rules.
Turning to the example implementation of
UI rule engine 110 can access and, in some examples, modify one or more UI models (e.g., 130, 132, 134) and UI rule check scripts (e.g., 136, 138) stored in and/or served by one or more data repositories 112, 114, 116. For example, the UI rule engine can retrieve and execute one or more UI rule check scripts (e.g., 136, 138) to parse one or more UI models (e.g., 130, 132, 134) to determine whether UIs (e.g., 126, 128) modeled by the UI models (e.g., 130, 132, 134) satisfy UI rules, such as UI style guide rules, corresponding to the UI rule check scripts (e.g., 136, 138). UIs 126, 128 can be UIs of one or more applications and services (e.g., 120, 122) served by application servers 106, 108 to clients 102, 104. Result data (e.g., 139) can be generated based on the execution of the UI rule check scripts (e.g., 136, 138) and stored in data repositories (e.g., 114) for use, for example, by UI rule engine in performing reporting and further analysis of UI style guide compliance.
In some instances, UI rule engine 110 can operate in connection with a UI development framework 118. UI development framework can include software and systems adapted to develop and modify UIs, for example, in a graphical development environment. Design decisions implemented for a UI under development using the UI development framework can be analyzed using UI rule engine to provide feedback regarding the design decision's consistency with UI style guide rules. In some instances, UI rule engine can be integrated with UI development framework 118 and UI development framework 118 can access and modify UI models (e.g., 130, 132, 134) in connection with development of a UI corresponding to the UI model.
Application servers 106, 108 can each include one or more processors 140, 142, at least one interface 146, 148, and computer-readable memory 150, 152. Application servers can be configured to serve web services (e.g., 120, 122), such as SOA-based or enterprise web services, for example. In some instances, some combination of application servers 106, 108 can be hosted on a common computing system, server, or server pool, and share computing resources, including shared memory, processors, and interfaces, such as in an enterprise software system serving services to a plurality of distinct clients and customers. The interfaces 146, 148 can be used for communicating with other systems in a client-server or other distributed environment (including within environment 100) connected to the network 120, for example the one or more clients 102, 104, external data sources (e.g., 116), or any other computing device adapted to interface with the servers 106, 108, including devices not illustrated in
Each processor 140, 142 can execute instructions and manipulate data to perform the operations of an associated server or system (e.g., 106, 108) and may comprise, for example, a central processing unit (CPU), a blade, an application specific integrated circuit (ASIC), or a field-programmable gate array (FPGA), among other suitable options. Although each processor 140, 142 is illustrated as a single processor, multiple processors may be used according to the particular needs of the associated server. References to a single processor 140, 142 are meant to include multiple processors where applicable. The operations that each processor 140, 142 executes are determined by the purpose and operations of its associated server. Generally, the processor 140, 142 executes instructions and manipulates data to perform the operations of its respective server and, specifically, the software systems, services, and applications hosted by the servers 106, 108.
At a high level, each “server” (e.g., 106, 108) includes one or more electronic computing devices operable to receive, transmit, process, store, or manage data and information associated with the environment 100. Specifically, a server is responsible for receiving requests from one or more clients and sending the appropriate response to the requesting client. In addition to requests from external clients, requests may also be sent from internal users, external or third-party customers, other automated applications, as well as any other appropriate entities, individuals, systems, or computers. For example, although
In the case of servers hosting, serving, or otherwise providing software services or products, a processor (e.g., 140, 142) can execute the functionality required to receive and respond to requests from clients, as well as client applications interfacing with the server's hosted application (e.g., 120, 122). It will be understood that the term “application server” (e.g., 106, 108) can include any suitable software component or module, or computing device(s) capable of hosting and/or serving a software application, including distributed, enterprise, or cloud-based software applications. Regardless of the particular implementation, “software” may include computer-readable instructions, firmware, wired or programmed hardware, or any combination thereof on a tangible medium operable when executed to perform at least the processes and operations described herein. Indeed, each software component may be fully or partially written or described in any appropriate computer language including C, C++, Java, Visual Basic, assembler, Perl, any suitable version of 4GL, as well as others. Applications can be implemented as individual modules that implement the various features and functionality through various objects, methods, or other processes, or may instead include a number of sub-modules, third party services, components, libraries, and such, as appropriate. Conversely, the features and functionality of various components can be combined into single components as appropriate.
At a high level, each of the one or more hosted applications and services (e.g., 120, 122) illustrated in the environment 100 can include any application, program, module, process, or other software that may execute, change, delete, generate, or otherwise manage information according to the present disclosure, particularly in response to and in connection with one or more requests received from the illustrated clients 102, 104, as well as other applications. In certain cases, only one hosted application may be located at a particular server. In others, a plurality of related and/or unrelated hosted applications may be stored at a single server, or located across a plurality of other servers, as well. In certain cases, environment 100 may implement a composite hosted application. For example, portions of the composite application may be implemented as Enterprise Java Beans (EJBs) or design-time components may have the ability to generate run-time implementations into different platforms, such as J2EE (Java 2 Platform, Enterprise Edition), ABAP (Advanced Business Application Programming) objects, or Microsoft's .NET, among others. Additionally, applications may represent web-based applications accessed and executed via the network 120 (e.g., through the Internet). Further, one or more processes associated with a particular hosted application or service may be stored, referenced, or executed remotely. For example, a portion of a particular hosted application or service may be a web service associated with the application that is remotely called, while another portion of the hosted application may be an interface object or agent bundled for processing at a remote client (e.g., 102, 104). Moreover, any or all of the hosted applications and software service may be a child or sub-module of another software module or enterprise application (not illustrated) without departing from the scope of this disclosure. Still further, portions of a hosted application can be executed by a user working directly at a server hosting the application, as well as remotely at a client.
Each of the example servers 106, 108 can also include a memory (150, 152 respectively). Further repositories 112, 114, 116 and client computing devices (e.g., 102, 104) can also each include at least one memory device. Each memory may include any memory or database module and may take the form of volatile or non-volatile memory including, without limitation, non-transitory memory elements, magnetic media, optical media, random access memory (RAM), read-only memory (ROM), removable media, or any other suitable local or remote memory component. Each memory may further store various objects or data, including classes, frameworks, applications, backup data, business objects, jobs, web pages, web page templates, database tables, content repositories storing business or other dynamic information, or other information including any parameters, variables, algorithms, instructions, rules, constraints, or references thereto relevant to the purposes of the particular server. Each memory may also include any other appropriate data, such as VPN applications, firmware logs and policies, firewall policies, a security or access log, print or other reporting files, as well as others. Again, the particular data and instructions stored in each memory (e.g., 112, 114, 116, 150, 152) will be described in detail below in connection with the illustrated implementations of the software environment 100 and components thereof.
Generally, the network 120 facilitates wireless or wireline communications between the components of the software environment 100 (e.g., between the UI rule engine 110, data repositories 112, 114, 116 and one or more clients (e.g., 102, 104) as well as between other components as appropriate), as well as with any other local or remote computer, such as those associated with one or more applications or external data sources. The network 120 can be implemented as one or more distinct networks. In any implementation, the network 120 may be a continuous or discontinuous network without departing from the scope of this disclosure, so long as at least a portion of the network 120 may facilitate communications between senders and recipients. The network 120 may be all or a portion of an enterprise or secured network. As an example, in
The illustrated implementation of
The GUI 160, 162 comprises a graphical user interface operable to allow the user to interface with at least a portion of environment 100 for any suitable purpose, including allowing a user to interact with one or more software applications and services (e.g., 120, 122). Generally, the GUI 160, 162 provides users with an efficient and user-friendly presentation of data provided by or communicated within the system, such as UI of the UI development framework 118 or an application managed using UI rule engine 110 or developed using UI development framework 118. The term “graphical user interface,” or GUI, may be used in the singular or in the plural to describe one or more graphical user interfaces and each of the displays of a particular graphical user interface. Therefore, the GUI 160, 162 can be any graphical user interface, such as a web browser, touch screen, or command line interface (CLI) that processes information in the environment 100 and efficiently presents the results to the user. In general, UIs displayed using the GUI 160, 162 may include a plurality of user interface (UI) elements such as interactive fields, pull-down lists, media players, tables, graphics, virtual machine interfaces, buttons, etc. operable by the user at the client. These UI elements may be related to the functions of one or more applications or services (e.g., 120, 122), including applications hosted locally at the client.
While
As shown in
Returning to
Reporting module 230 can be used in connection with a certification process for applications developed for use within a particular software environment. For instance, a particular software environment can require that applications offered, sold, executed, or otherwise used in connection comply with a minimum standard of style guide consistency for UIs within the software environment in order to be certified for use in connection with the environment. For example, UIs within a particular software environment may be required to be in 80% compliance with style guide rules set forth in connection with the particular software environment, such as a modular, enterprise software system. Applications submitted, for example, by third-party vendors and developers, can be tested for compliance using the rule check module 225, the reporting module 230 determining, from the rule check module result data 215, the aggregate compliance of the submitted application's UIs with the software environment's UI style guide rules. In some examples, applications for use within the software environment can be offered for download, purchase, subscription, or use through an electronic storefront, or application store, affiliate with the software environment. Applications may be required to be certified prior to being offered for access through the storefront, a portion of the certification being tied to UI style guide compliance.
While reports can be generated from previously-collected result data 215, reports can also be based on a real time snapshot of UI compliance with one or more UI style guide rules by one or more UIs. This can be useful within dynamic software environments where UI attributes and style guide rules are frequently evolving, being modified and fine-tuned. Accordingly, to obtain the most accurate reporting data, a style guide check can be performed using rule check module 225, the results of the check being immediately passed to reporting module 230 for analysis and use in generating a report based on the check.
As noted above, in some instances, administrators or developers of UIs within a particular software system may desire to modify UI models 205 or UI rule check scripts 210 to reflect corresponding modifications to UIs and UI style guide rules respectively. A rule manager 240 can be adapted to perform modifications on UI rule check scripts 210, for instance, to reflect the addition of a new style guide rule or the modification or deletion of an existing style guide rule. Further, modifications can be made to UI models via a UI model manager 245, for example, to resolve UI style guide violations in the underlying UIs. In some cases, UI model manager 245 can modify UI models 205 as a batch, for example, to correct a particular style guide violation common to UIs within the batch. This can be particularly advantageous in systems where dozens to thousands of UIs exist that potentially require the same, consistent modification.
Mass changes of UIs (and their corresponding UI models) can be required, for example, by virtue of a change to the UI style guide and, accordingly, UI style guide scripts, given that many UIs within a system may have been developed prior to the introduction of the new or modified UI style guide rule. As a result, modifying a particular style guide rule or performing a mass (or batch) UI model modification can impose costs despite the cost savings realized by batch UI modifications. Consequently, it can be useful to survey a set of UIs, in advance of a rule change or batch modification to forecast the impact of a particular change. Accordingly, a planning module 235 can be included within a UI rule engine 200 to perform hypothetical reporting and forecasting of changes to UI style guide rules or UI models. For instance, a new style guide rule may be proposed for a software environment including a set of existing UIs. A temporary UI rule check script can be generated, corresponding to and modeling the new rule. The temporary UI rule check script can be “temporary” in the sense that the new rule modeled by the temporary UI rule is only a proposed, hypothetical rule. Accordingly, the temporary UI rule check script modeling the new UI style guide rule should not be added to the set of standard UI style guide check scripts 210 until the new rule is approved and implemented as one of the standard UI style guide rules. The temporary UI rule check script can, however, be used to parse the set of existing UI models 205 in a manner similar to other UI rule check scripts 210 to determine whether and which of the UI models would satisfy the new, proposed style guide rule. Through the generation and execution of a temporary UI rule check script, a developer can determine, in advance of a change to a style guide rule, how many UIs will be affected by the change.
In some implementations, UI rule engine can operate in connection with a UI development tool, such as UI development tool 118, shown in the example of
In typical systems, UI development tools are not tied to UI style guide rules, and UI developers are left unassisted in maintaining an understanding of style guide requirements for a particular UI developed for a particular software system having its own unique style guide rules. Integrating or coupling a UI development tool with UI rule engine 200 can allow a UI developer to receive immediate feedback for design decision implemented or contemplated using a UI development tool. For instance, a UI developer may designate, using a UI development tool, that a text form field, button, or other control be positioned in a particular location of a UI developed using the UI development tool. The UI development tool may include a graphical representation of the UI being built. While the decision of the UI designer to place a particular UI control in a particular location within the UI may be appealing to the UI designer, the decision may violate a particular UI style guide rule. A user modification of a UI in development using a UI development tool can trigger a UI rule consistency check using, for example, rule check module 225 and one or more rule check scripts 210. For instance, as a user builds a UI using a UI development tool, a corresponding, parsable UI model can be developed. While the UI model may be incomplete, UI attributes that have been defined in the UI model can nonetheless be parsed, using one or more rule check scripts 210 to determine whether the defined attributes satisfy one or more UI style guide rules action. The results of the UI rules consistency check can then be presented to the user of the UI development tool, via UI developer interface 250, providing immediate feedback to the user regarding the style guide consistency of a UI design choice implemented using the UI development tool.
In some examples, the nature of the user's actions defining UI attributes using the UI development tool can be used to dynamically select UI rule check scripts 210 determined to be relevant to the user's action. For instance, in the example of a user defining the number of columns within a table in a UI developed using the UI development tool, the UI developer interface 250 can identify that the user action relates to table UI elements and dynamically select one or more UI rule check scripts 210 identified as pertaining to style guide rules defining guidelines for table UI elements. In this manner, the number of UI consistency checks can be focused to the relevant actions of the UI development tool user, thereby improving the performance and efficiency of the UI rule engine's interaction with and service of the UI development tool.
UI developer interface 250 can also be used to assist a UI developer in understanding UI style guide rules relating to a particular UI design project. For instance, a rule library 255 can be provided with descriptions detailing particular UI style guide rules. The rule library 255 can, in some examples, be a wiki-based guide outlining descriptions of and known solutions to violations of UI style guide rules, with one or more users of the UI rule engine 200 providing content to the rule library 255. A user can select a link, for example, to a particular UI style guide rule, and access a detailed explanation of the rule, to assist the user in avoiding UI style guide rule violations during development. In some examples, the identification of a UI style guide rule can be presented in connection with UI rule consistency check feedback provided through the UI developer interface 250 to the UI development tool, as explained above, for example in connection with a UI design choice implemented using the UI development tool. The feedback can include the identification of a UI style guide rule violation, identifying the violated rule. A user can select the identified rule to access the rule library 255 content explaining the identified style guide rule. In this manner, a user can be assisted in understanding style guide requirements, as well as understanding how style guide violations can be remedied (using the UI development tool) and avoided. Such knowledge base functionality can be particularly useful in connection with systems employing multiple UI designers, including third-party UI designers who may develop UIs according to multiple different style guides, improving style guide rule compliance through education of a particular UI style guide. Further, UI rule engine 200 can maintain UI rule check scripts 215 for multiple different style guides and perform UI style guide compliance checks, reporting, planning, and UI development integration for each of the multiple different style guides. Indeed, some UI rule check scripts 215 can be reused across multiple different style guides sharing one or more style guide rules. Further, a UI developer interface 250 can identify the relevant style guide applying to a particular UI development project, and dynamically select those UI rule check scripts 215 pertaining to the identified UI style guide.
Turning to
Turning now to
A UI style guide consistency check can check one or more UI models against one or more UI style guide rules (using one or more corresponding UI rule check scripts). For example, defined sets of UIs can be checked as a group, such as a set of UIs of a particular type, UI developed by a particular developer, or UIs of a particular application, among other examples. In some instances, a plurality of UIs can be checked against one or more UI style guide rules. Further, a single system can include thousands of UIs. In typical UI development, hundreds of man hours can be spent manually checking UIs for compliance with style guide requirements. In some instances, given the cost of checking each UI for style guide compliance, a UI administrator may only be able to spot check UIs, leaving the possibility that several style guide violations may not be identified and remedied prior to the UIs being released for commercial runtime consumption. Using the concepts described above, large batches of parsable UI models can be parsed, identifying attributes of the represented UI. The attributes can then be examined to determine which attributes of which UIs in the batch comply or do not comply with which UI style guide rules. Indeed, an entire set of UIs can be checked for compliance with UI style guide rules in a single batch check, reducing the time necessary to ensure UI style guide compliance to a fraction of the time typically spent manually checking during typical UI development efforts.
One or more UIs, or a batch of UIs, can be checked against one or more UI style guide rules during a single style guide compliance check. A set of UI style guide rules can be identified to serve as the basis of a UI style guide consistency check. For instance, a particular category of style guide rules, or set of style guide rules associated with a particular developer or company can be bundled together with corresponding UI rule check scripts for use in a particular style guide compliance check. Indeed, one or more UIs can be checked against an entire set of UI style guide rules. Each corresponding UI model can be parsed by a corresponding UI rule check script corresponding to the set of UI style guide rules. Indeed, in some examples, parsing of multiple UI models by multiple UI rule check scripts can be performed in parallel to expedite performance of the entire consistency check. For example, checking can begin with a first UI rule check script parsing a first UI model in parallel with a second UI rule check script parsing a second UI model. Later, the first UI rule check script can parse the second UI model in parallel with the second UI rule check script parsing the first UI model, and so on. In some implementations, style guide consistency checks can be further expedited by first matching UI style guide rules with UIs to which the UI style guide rules are relevant, prior to executing the UI rule check scripts to parse the corresponding UI models. For instance, a first UI may include a table UI component, while a second UI may not. Accordingly, in the set of UI style guide rules against which the consistency check is to be performed, one or more UI style guide rules may apply to table UI components. By first identifying that the second UI does not include a table UI component, parsing of the UI model corresponding to the second UI by the table-related UI rule check scripts can be avoided, with the table-related UI rule check scripts only parsing those UI models that include table UI components. Indeed, in any UI rule consistency check, parsing of UI models can be preceded by filtering the set of UI models for attributes related to the UI style guide rule to be checked.
In response to receiving data identifying results of a particular style guide consistency check, one or more UI attributes can be identified that violate one or more of the checked UI style guide rules. In some instances, the perceived seriousness of a particular style guide violation can also be identified and presented to the user to assist the user in assessing how to address the violation. Indeed, a user can trigger resolution of the one or more style guide violations in response to being notified of the violations. A resolution can be as simple as, for example, receiving a user request to ignore an identified style guide violation. Allowing a user to ignore a style guide violation provides for the sometimes needed flexibility for a particular UI to be developed with attributes that are an exception to a particular one-size-fits-all style guide rule, for example. A user, upon reviewing a particular style guide violation can, for instance, determine that the violation is not serious, accurate, or appropriate for a particular UI. Receiving a user request to ignore a particular style guide violation can cause future checks to ignore the violation as well.
In other instances, identification of a UI style guide rule violation can motivate the user to access the offending UI model and edit the UI model to redefine the offending UI attribute to bring the corresponding UI in compliance with the violated style guide rule. Redefining of the UI model to bring the UI model in compliance with a particular UI style guide rule can also be automated and performed by instructions executed by one or more computing devices. Further, where multiple UI models have been identified as violating UI style guide rules, one or more known solutions to the violation can be identified and performed on each of the offending UI models as a batch to consistently remedy the one or more violations across the batch of UIs. A solution can be identified or generated, dynamically, by one or more computing devices, or, alternatively, by the user, specifying how the offending UI models should be modified in response to the detect UI style guide violations. In one example, a common style guide error relating to the naming convention of certain button UI control elements can be identified in several UIs. For instance, a particular style guide rule can specify that button UI controls used to start a process be labeled “Start.” Through a UI style guide consistency check of the particular style guide rule, it can be identified that several UIs labeled the button UI control “Go,” rather than “Start,” in violation of the style guide rule. Amending the definition of the button's labeling can be accomplished by identifying and amending a line of code with each offending UI's respective UI model. Accordingly, an instruction can be executed to automatically identify each of the UI models of the offending UIs, identify the offending attribute in each UI model, and amend the offending attribute in each UI model to re-label each button “Start,” rather than “Go.” By so doing, common UI style guide violations can be both detected and remedied by performing batch check and modification operations on, sometimes, large sets of UIs via parsable UI models of the UIs.
Turning to
The UI development tool can be directly integrated with the functionality of software implementing UI style guide consistency checks. For instance, UI rule check scripts can be integrated into the UI development tool, allowing the UI development tool to trigger execution of one or more UI rule check scripts to parse the UI model of a UI currently edited or under development using a UI development tool. Execution of one or more UI rule check scripts through a UI development tool can be triggered, for example, in response to a user request to perform a style guide consistency check or automatically, in response to a UI development tool event. For instance, user can perform operations using the UI development tool to modify and define attributes of a UI. Such operations can trigger style guide consistency checks to check the modified UI against the style guide rule. Further, detected style guide violations can be conveniently resolved using the UI development tool, where the user can directly redefine aspects of the UIs underlying UI model. In some instance, UI development tools can highlight or provide direction to the user to implement a resolution to a detected UI style guide rule violation. For instance, the UI development tool can highlight a UI component relating to an offending UI attribute or launch a help tool to suggest known remedies for the particular style guide violation.
Reports can be generated that include a wide variety of statistical measures based on the results of one or more style guide consistency checks, including consistency checks launched in connection with a reporting request. Reports can provide style guide violation statistics at the UI level, identifying style guide violations or style guide rule compliance rates for each UI, UI type, UI grouping, or UI component checked for style guide compliance. For instance, an aggregate compliance rate can be calculated for a particular UI based on the UI's compliance with a set of UI style guide rules. Style guide compliance trends can also be calculated and reported. For instance, common style guide violations can be identified for logical groupings of UI. For instance, a set of UIs developed by a particular vendor or associated with a particular software application can be analyzed to see if recurring violations of one or more style guide rules exist across the set of UIs. Further, rule-based statistics can be calculated, for instance, to identify the rate of compliance with each UI style guide rule in a set of UI style guide rules. UI style guide rules and UIs can be ranked or graded based on compliance statistics. For instance, a most-violated set of UI rules can be identified. This can be useful, for instance, in identifying style guide rules that are poorly defined, impractical, or outdated. Alternatively, reports showing style guide rules with poor compliance can serve as the basis of training initiatives designed to better educate participating UI designers with regard to the oft-violated rule. Further, a low compliance rate can also suggest potential errors in UI rule check scripts used to detect violations of the underlying UI style guide rule.
UI models and UI rule check scripts can be also used to produce data for reports not directly related to style guide rule violations. For instance, parsing of a UI model by a UI rule check script can result in the detection of the presence (or absence) of particular UI attribute generally with the UI model. Accordingly, reports can be generated, based on these findings, that compile statistics regarding the general frequency of a UI attribute or UI component's inclusion in UIs within a software environment. For instance, a UI rule check script relating to drop-down UI menus can identify those UI models including such elements. As a result, the number or percentage of UIs in the system that include drop-down menus can be quickly discovered for potentially large sets of UIs within a system.
As in other examples, hypothetical style guide rule consistency checks can be carried out on a batch-basis across multiple UI models. Further, consistency checks can be limited, as in other examples, to UI models dynamically identified as potentially affected by the proposed UI style guide rule. Proposed UI style guide rules can represent potential new style guide rules, or potential modifications or deletions of existing style guide rules. A hypothetical style guide rule consistency check based on one or more proposed UI style guide rules can be used in a planning phase, prior to the formal adoption of the proposed rules. Accordingly, in addition to identifying the potential effect the adoption of a particular proposed UI style guide rule would have on a set of UIs, a cost of implementing the proposed UI style guide rule can also be calculated. For instance, potential violations of the proposed UI style guide rule can be detected through a hypothetical style guide rule consistency check. The severity of the violation can also be identified. A cost, or grade, assigning a quantitative measure to the potential effect of adopting a proposed UI style guide rule, can be calculated based both on the number and the severity of the detected, potential violations of the rule detected during the check. Such quantitative measures can be used by administrators in their decision to adopt and deploy a particular proposed UI style guide rule.
Adoption of a proposed UI style guide rule can result in the addition of a corresponding rule check script to a plurality of UI rule check scripts. Further, subsequent UI style guide consistency checks can check UIs' continued compliance with the newly-adopted UI style guide rule following adoption of the rule. Indeed, modification operations can be performed across one or more UI models found to violate a newly-adopted UI style guide rule in order to bring offending UIs in compliance with the new rule.
As shown in the screenshot 600a of
Turning to
As shown in
Additional details can also be made available to users surveying the results of the forecasted effect of adopting proposed UI style guide rules. For instance, an expansion control (e.g., 650) can be used to expand a row and display additional information relating to a particular analysis of a proposed UI style guide rule. For instance, the expansion control 650 of row 652 has been selected in the screenshot 600c displaying additional details to a user relating to the proposed rule of row 652. For instance, a listing of a plurality of UI categories (e.g., 654) can be presented that would be affected by a proposed UI style guide rule relating to making inclusion of a “Save/Close” button mandatory. The expanded details can further include presentation of the number of potential violations detected in each UI category. For example, a sub-row 654 corresponding to a “FIN” UI category can indicate that eighteen separate violations of the “Save/Close” button rule were identified in UIs of category “FIN.” A UI category can, in some instances, correspond to a particular software application. Depending on the needs of the user, a user can further expand the presentation of forecast information by selecting expansion control 656, for instance, to expand forecast statistics relating to a UI category, such as to display identifications of individual UIs or UI attributes that would violate the proposed UI style guide rule of row 652 within category “FIN.” Similar details can be identified for each of the UI style guide rows and UI categories. The screenshot 600c of
Although this disclosure has been described in terms of certain implementations and generally associated methods, alterations and permutations of these implementations and methods will be apparent to those skilled in the art. For example, the actions described herein can be performed in a different order than as described and still achieve the desirable results. As one example, the processes depicted in the accompanying figures do not necessarily require the particular order shown, or sequential order, to achieve the desired results. In certain implementations, multitasking and parallel processing may be advantageous. Additionally, other user interface layouts and functionality can be supported. Other variations are within the scope of the following claims.
Number | Name | Date | Kind |
---|---|---|---|
5327529 | Fults et al. | Jul 1994 | A |
5677997 | Talatik | Oct 1997 | A |
5850535 | Maystrovsky et al. | Dec 1998 | A |
5990887 | Redpath et al. | Nov 1999 | A |
6430599 | Baker et al. | Aug 2002 | B1 |
6983227 | Thalhammer-Reyero | Jan 2006 | B1 |
7243335 | Andrew et al. | Jul 2007 | B1 |
7296017 | Larcheveque et al. | Nov 2007 | B2 |
7398469 | Kisamore et al. | Jul 2008 | B2 |
7424410 | Orofino et al. | Sep 2008 | B2 |
7451403 | Srinivasan | Nov 2008 | B1 |
7584457 | Hammerich et al. | Sep 2009 | B2 |
7792934 | Klein | Sep 2010 | B2 |
7853678 | Khemani et al. | Dec 2010 | B2 |
7853679 | Khemani et al. | Dec 2010 | B2 |
7865589 | Khemani et al. | Jan 2011 | B2 |
7870277 | Korrapati et al. | Jan 2011 | B2 |
7925694 | Harris | Apr 2011 | B2 |
8090877 | Agarwal et al. | Jan 2012 | B2 |
8127237 | Beringer | Feb 2012 | B2 |
8131668 | Beringer et al. | Mar 2012 | B2 |
8161399 | Kannan | Apr 2012 | B2 |
8181155 | Pinto et al. | May 2012 | B2 |
8184070 | Taubman | May 2012 | B1 |
8191042 | Pinto et al. | May 2012 | B2 |
8234332 | Jaudon et al. | Jul 2012 | B2 |
8239239 | Malhotra et al. | Aug 2012 | B1 |
8250169 | Beringer et al. | Aug 2012 | B2 |
8276193 | Cox et al. | Sep 2012 | B2 |
8341287 | Khemani et al. | Dec 2012 | B2 |
8453065 | Chaudhrl | May 2013 | B2 |
8458662 | Grechannik et al. | Jun 2013 | B2 |
8467133 | Miller | Jun 2013 | B2 |
8472120 | Border et al. | Jun 2013 | B2 |
8477425 | Border et al. | Jul 2013 | B2 |
8482859 | Border et al. | Jul 2013 | B2 |
8488246 | Border et al. | Jul 2013 | B2 |
8490148 | Sikka et al. | Jul 2013 | B2 |
8527313 | Beringer et al. | Sep 2013 | B2 |
8560941 | Burns | Oct 2013 | B2 |
8572500 | Salva et al. | Oct 2013 | B2 |
8615712 | Porter et al. | Dec 2013 | B2 |
8667415 | Rudolph et al. | Mar 2014 | B2 |
8671351 | Riggs et al. | Mar 2014 | B2 |
8671352 | Hsu et al. | Mar 2014 | B1 |
8726174 | Ehret et al. | May 2014 | B2 |
8799808 | Satterfield et al. | Aug 2014 | B2 |
8832572 | Waher | Sep 2014 | B2 |
8869027 | Louch et al. | Oct 2014 | B2 |
8881034 | Pereira et al. | Nov 2014 | B2 |
8954870 | Martin et al. | Feb 2015 | B2 |
8954871 | Louch et al. | Feb 2015 | B2 |
8972895 | Gonsalves et al. | Mar 2015 | B2 |
20020085020 | Carroll et al. | Jul 2002 | A1 |
20030040997 | Rousseau et al. | Feb 2003 | A1 |
20030083767 | Karlsberg | May 2003 | A1 |
20030188291 | Fisher | Oct 2003 | A1 |
20040001092 | Rothwein | Jan 2004 | A1 |
20040015819 | Romano-Critchley et al. | Jan 2004 | A1 |
20040148586 | Gilboa | Jul 2004 | A1 |
20040153992 | Molina-Moreno et al. | Aug 2004 | A1 |
20040250257 | Koutyrine et al. | Dec 2004 | A1 |
20040260568 | Johnson | Dec 2004 | A1 |
20050166094 | Blackwell et al. | Jul 2005 | A1 |
20060130048 | Ho | Jun 2006 | A1 |
20060248467 | Elvanoglu et al. | Nov 2006 | A1 |
20070118813 | Forstall | May 2007 | A1 |
20070300185 | Macbeth et al. | Dec 2007 | A1 |
20080104140 | Vierich et al. | May 2008 | A1 |
20080104617 | Apacible | May 2008 | A1 |
20080148221 | Letkeman et al. | Jun 2008 | A1 |
20080148235 | Foresti et al. | Jun 2008 | A1 |
20080163078 | Van Der Sanden | Jul 2008 | A1 |
20080178102 | Kannan et al. | Jul 2008 | A1 |
20080275910 | Molina-Moreno et al. | Nov 2008 | A1 |
20080301553 | Basu et al. | Dec 2008 | A1 |
20080313650 | Arnquist | Dec 2008 | A1 |
20090024944 | Louch | Jan 2009 | A1 |
20090112832 | Kandogan | Apr 2009 | A1 |
20090172632 | Kashai | Jul 2009 | A1 |
20090217100 | Grechanik et al. | Aug 2009 | A1 |
20090217182 | Grechanik et al. | Aug 2009 | A1 |
20090217302 | Grechanik et al. | Aug 2009 | A1 |
20090293005 | Hooyman et al. | Nov 2009 | A1 |
20100222000 | Sauer et al. | Sep 2010 | A1 |
20110153293 | Coldicott et al. | Jun 2011 | A1 |
20110161941 | Thomson | Jun 2011 | A1 |
20110208855 | Robertson et al. | Aug 2011 | A1 |
20110270959 | Schlusser | Nov 2011 | A1 |
20120030612 | Aziz et al. | Feb 2012 | A1 |
20120124494 | Grechanik et al. | May 2012 | A1 |
20120143777 | Jensen | Jun 2012 | A1 |
20120174000 | Zavatone | Jul 2012 | A1 |
20140040788 | Malhotra et al. | Feb 2014 | A9 |
20140040790 | Nurse et al. | Feb 2014 | A1 |
20140208243 | Werner | Jul 2014 | A1 |
20140365895 | Magahern et al. | Dec 2014 | A1 |
20150040041 | Yang et al. | Feb 2015 | A1 |
20150040043 | Sakhardande et al. | Feb 2015 | A1 |
20150050633 | Christmas et al. | Feb 2015 | A1 |
Number | Date | Country |
---|---|---|
2 065 799 | Jun 2009 | EP |
Entry |
---|
bing search q=adapt+user+interface+style&src=IE—May 1, 2016. |
web style guide 3rd edition Lynch et al 2011. |
Jouault, Frederic et al.: “Transforming Models with ATL”; Satellite Events at the Models, 2005 Conference; Lecture Notes in Computer Science; Jan. 2006; pp. 128-138. |
Office Action issued in U.S. Appl. No. 13/018,106, dated Dec. 21, 2012; 28 pages. |
Extended European Search Report issued in European Application No. 12000578.0 dated Jul. 26, 2012; 7 pages. |
Il-Kyu Ha: Byung-Wook Kang, Meta-validation of UML structural diagrams and behavioral diagrams with consistency rules,: Communications, Computers, and signal Processing, 2003, PACRIM. 2003 IEEE Pacific Rim Conference om vol. 2. pp. 679-683, Aug. 2003. |
Office Action issued in U.S. Appl. No. 13/017,748, dated Dec. 2, 2013; 25 pages. |
Tai, H.; Mitsui, K.: nerome, T.: Abe, M.; no, K.: Hort M., “Model-driven development of large-scale Web applications ”IBM Journal of Research and Development, vol. 48, No. 56 pp. 797,809, Sep. 2004. |
Office Action issued in U.S. Appl. No. 13/017,748, dated Oct. 3, 2014; 27 pages. |
Office Action issued in U.S. Appl. No. 13/017,748, dated Jun. 11, 2014; 26 pages. |
Office Action issued in U.S. Appl. No. 13/017,790. dated Dec. 17, 2014; 36 pages. |
Office Action issued in U.S. Appl. No. 13/017,790, dated Jun. 6, 2014; 35 pages. |
Office Action issued in U.S. Appl. No. 13/017,920, dated Dec. 19, 2014; 34 pages. |
Office Action issued in U.S. Appl. No. 13/017,920, dated Jun. 26, 2014; 28 pages. |
Office Action issued in U.S. Appl. No. 13/018,106, dated Oct. 10, 2014; 36 pages. |
Office Action issued in U.S. Appl. No. 13/018,106, dated Jul. 19, 2013; 30 pages. |
Office Action issued in U.S. Appl. No. 13/018,106, dated Jun. 19, 2014; 36 pages. |
Office Action issued in U.S. Appl. No. 13/017,790, dated Jun. 27, 2016; 20 pages. |
Office Action issued in U.S. Appl. No. 13/017,790, dated May 20, 2015; 36 pages. |
Office Action issued in U.S. Appl. No. 13/017,790, dated Sep. 11, 2015; 35 pages. |
Office Action issued in U.S. Appl. No. 13/017,920, dated Jun. 27, 2016; 21 pages. |
Office Action issued in U.S. Appl. No. 13/017,920, dated Sep. 10, 2015; 33 pages. |
Office Action issued in U.S. Appl. No. 13/018,106, dated Oct. 21, 2015; 27 pages. |
Notice of Allowance issued in U.S. Appl. No. 13/018,106, dated May 2, 2016; 13 pages. |
Number | Date | Country | |
---|---|---|---|
20120198364 A1 | Aug 2012 | US |