Generally, project management applications help users define project goals, plan tasks and allocate resources, display a project plan including a schedule, and carry out and manage projects. A project plan may define tasks. The schedule may define the sequence in which the tasks occur, the resources needed to complete each task, and calendar information pertaining to the tasks. Each task may be defined to include one or more attributes (e.g., scheduled dates, task length, cost, etc.). A user may create a project plan by assigning values to the attributes of each task.
One limitation of some project management applications is the rigidness of the structure used to define projects. The structure of a project might include various elements, such as the properties of the project, the organization of the properties, the workflow associated with the project, and the visual representation of the project. These elements are commonly fixed by project management applications or require heavy customization to attain a desired level of flexibility. The rigidity of project management applications may cause frustration on the part of users who desire to create projects having a structure that is inconsistent with the fixed structure that is natively provided.
It is with respect to these and other considerations that the disclosure made herein is presented.
Technologies are described herein for providing an enterprise project type. The enterprise project type is a feature that can be incorporated into a project management application. Generally, the enterprise project type is a wrapper that encapsulates, among other elements, stages, pages, and/or workflows. A stage may contain one or more pages. A project management application may include multiple enterprise project types, each of which enables a user to define a project, an application, a product, and other entities. The enterprise project types can also encompass and facilitate lifecycle management of these entities.
An enterprise project type may be created through an administrative interface. The administrative interface may provide at least two ways in which an administrator can create the enterprise project type. In one way, the administrator may choose not to associate a workflow with a newly created enterprise project type. In this case, the administrative interface may provide a list of pages from which the administrator can select for inclusion in the enterprise project type. In another way, the administrator may choose to associate a workflow with a newly created enterprise project type. In this case, the administrative interface does not provide a list of pages because the selected workflow dictates the stages and pages that are provided by the enterprise project type. Whether a workflow is associated or is not associated with the enterprise project type, a project page may also be associated with the enterprise project type. The project page may refer to the first page that is displayed when an entity of the associated enterprise project type is created.
After one or more enterprise project types are created, a user may access a client interface to create an entity through the enterprise project types. In particular, the client interface may provide a selection of project types from which a user can select one of the enterprise project types. When the user selects one of the enterprise project types, an instance of the enterprise project type is created. When an instance of the enterprise project type has been created by the user, the client interface may display pages as dictated by the enterprise project type. If the enterprise project type is not associated with a workflow, then the client interface may display the pages included in the enterprise project type. If the enterprise project type is associated with a workflow, then the client interface may display stages and pages according to the workflow. For example, the workflow may specify that that the stages and pages be displayed in a certain order and/or according to input specified in previous stages and pages.
Each page displayed to the user may include various input fields in which a user can define properties associated with the entity. For example, the input fields may include text boxes, drop-down menus, radio buttons, and other input interfaces. The input fields included in the pages may be pre-defined by the pages. Once the user has defined the properties contained in the pages provided by the enterprise project type, the client interface may generate the entity based on the properties.
According to one embodiment, a method is provided herein for generating an entity based on an instance of an enterprise project type. According to the method, a selection of an enterprise project type is received from a plurality of enterprise project types. The enterprise project type may include a plurality of pages. Each page may include a plurality of input fields for collecting values of properties. When a selection of the enterprise project type is received, a project page from the selected enterprise project type is displayed. The project page may include a create project interface element. When a selection of the create project interface element is received, an instance of the enterprise project type is generated. The instance of the enterprise project type represents an entity, such as a project plan, an application plan, or a product plan. When the instance of the enterprise project type is generated, the pages are displayed. The values of properties are collected through the pages. The entity is generated by transforming the values of properties into the entity.
It should also be appreciated that the above-described subject matter may also be implemented as a computer-controlled apparatus, a computer process, a computing system, or as an article of manufacture such as a computer-storage medium. These and various other features will be apparent from a reading of the following Detailed Description and a review of the associated drawings.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended that this Summary be used to limit the scope of the claimed subject matter. Furthermore, the claimed subject matter is not limited to implementations that solve any or all of the disadvantages noted in any part of this disclosure.
The following detailed description is directed to technologies for providing an enterprise project type. Through the utilization of the technologies and concepts presented herein, a project management application may provide an administrator interface for creating an enterprise project type and a client interface for creating an entity through an instance of the enterprise project type. While the subject matter described herein is presented in the general context of program modules that execute in conjunction with the execution of an operating system and application programs on a computer system, those skilled in the art will recognize that other implementations may be performed in combination with other types of program modules. Generally, program modules include routines, programs, components, data structures, and other types of structures that perform particular tasks or implement particular abstract data types. Moreover, those skilled in the art will appreciate that the subject matter described herein may be practiced with other computer system configurations, including hand-held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, mainframe computers, and the like.
In the following detailed description, references are made to the accompanying drawings that form a part hereof, and which are shown by way of illustration specific embodiments or examples. Referring now to the drawings, in which like numerals represent like elements through the several figures, a computing system and methodology for implementing a project management application will be described. In particular,
The data store 104 includes a first enterprise project type 112A and a second enterprise project type 112B. While the first enterprise project type 112A is associated with a workflow 114, the second enterprise project type 112B is not associated a workflow. The data store 104 further includes a first entity 116A and a second entity 116B (collectively referred to as entities 116). As described in greater detail below, in the example illustrated in
Also as illustrated in
The enterprise project type feature allows users to define entities outside of the conventional rigid project structure and with a greater level of customization. Examples of entities may include schedule-focused project plans, application plans, product plans, and other representations of processes/items through which a given project, application, product, or process/item can be executed, generated, and/or controlled. The entities may also encompass and facilitate lifecycle management of these processes and items. Although some embodiments described herein may refer primarily to projects and project plans, it should be appreciated that these embodiments may be similarly implemented for other processes and items represented by the entities.
The properties defined for enterprise project types can include a variety of custom metadata inputs, a project schedule tied to a scheduling engine (e.g., the scheduling engine provided by PROJECT SERVER from MICROSOFT CORPORATION), a customized workflow based on a workflow infrastructure (e.g., the workflow infrastructure provided by WINDOWS SHAREPOINT SERVICES (“WSS”) from MICROSOFT CORPORATION), business driver impact evaluation, and other WSS web parts and custom web parts.
In one embodiment, the enterprise project type is a wrapper that encapsulates, among other things, one or more stages, one or more pages, and a workflow. In another embodiment, the enterprise project type is a wrapper that encapsulates one or more pages with no workflow. Each stage may include one or more pages. Each page may be a custom web part that includes one or more input fields with which a user can define values of properties. The input fields may include text boxes, drop-down menus, radio buttons, and other input interfaces. The wrapper may further encapsulate business drivers
As described in greater detail below, the administrative interface enables an administrator or other user with administrative permissions to create an enterprise project type. In an embodiment, the administrative interface provides a user interface configured to create two types of enterprise project types: (1) an enterprise project type with no associated workflow and (2) an enterprise project type with an associated workflow.
In the case of the enterprise project type with no associated workflow, the administrative interface may provide a selection of pages from which the administrator can choose. Thus, the enterprise project type with no associated workflow defines the specific pages that are provided by the enterprise project type. In the case of the enterprise project type with an associated workflow, the administrative interface may provide a selection of workflows from which the administrator can choose one. The workflow defines stages and pages that are provided by the enterprise project type. Thus, the enterprise project type with an associated workflow does not define the specific pages that are provided by the enterprise project type. However, the administrator may still choose the project page.
Also as described in greater detail below, the client interface enables a user to create an entity through an instance of the enterprise project type. In an embodiment, the client interface provides a selection of enterprise project types from which a user can choose. Upon choosing an enterprise project type, the client interface creates an instance of the enterprise project type from which an entity can be created.
If the user selects an enterprise project type with no associated workflow, then the client interface may display a list of the pages defined by the enterprise project type. In this case, the user may have access to each of the pages defined by the enterprise project type. If the user selects an enterprise project type with an associated workflow, then the client interface may display stages and pages in accordance with the workflow. In this case, the user may not have access to each of the stages and pages defined by the workflow because the workflow defines the stages and pages that are displayed.
A user may define values of properties contained in pages provided through the instance of the enterprise project type. Once the user has defined values of properties contained in the pages, the client interface may generate the entity based on the properties. That is, the inputted values of the properties may be transformed into schedule-focused project plans, application plans, product plans, and other representations of processes/items.
Each enterprise project type may correspond to a single project type. In one embodiment, each project type is aligned with individual departments, such as marketing projects, information technology (“IT”) projects, human resources (“HR”) projects, and the like. Projects within the same department may be categorized together if they have a similar project life cycle. In other embodiments, each project type is aligned with other suitable categorizations.
Any number of customizable enterprise project types can be created through the administrative interface. The enterprise project types may be directly accessed through the client interface or programmatically through a suitable application program interface (“API”). The enterprise project types are extendable through the inclusion of additional web parts that provide additional functionality.
Referring now to
Referring to
The description section 204A includes a text box 214 where the administrator can enter a description for the enterprise project type. The site workflow association section 206A includes a drop-down menu 216 where the administrator can select a workflow. The new project page section 208A includes a selection interface 218 where the administrator can select pages to include in the enterprise project type. The selection interface 218 further includes a project page selection interface 220 where the administrator can select a project page for the enterprise project type. As previously described, the project page may refer to the first page that is displayed when an entity of the associated enterprise project type is created. When the administrator does not select a workflow in the drop-down menu 216, the administrative interface makes the new project page section 208A available.
Referring to
The name section 202B includes a text box 222 where the administrator has entered the name “Sample Proposal” for the enterprise interface type. The description section 204B includes a text box 224 where the administrator can enter a description for the enterprise project type. The site workflow association section 206B includes a drop-down menu 226 where the administrator selects a workflow called “Sample Proposal Workflow.” In contrast to the new project page section 208A illustrated in
As previously described, the screen display diagrams 200A-200B shown in
Referring now to
Referring to
Referring to
As illustrated in
Referring now to
The initial project page 410 is a form enabling a user to initiate an instance of the enterprise project type 112. The project detail pages 412 are the web part pages configured to display the input fields for collecting values of properties. The order in which the project detail pages 412 are displayed may be defined directly in the enterprise project type 112 or specified by the stage which is defined by the workflow 114. The project field web part 414 specifies the grouping and order of the input fields contained in the project detail pages 412. Thus, according to some embodiments, the workflow may specify the stages, the stages may specify pages, and the pages may specify fields, grouping, and order.
The project schedule 418 provides an interface where a user can schedule and assign various tasks for certain people, dates, and times. The project business driver impact 420 provides data regarding the impact of the project business driver. As used herein, a business driver refers to a strategic idea that is set out by senior management in a company. Examples of business drivers may include “Increase customer satisfaction,” “Increase employee morale,” “Expand into Asian markets.” and the like. When a project is defined, the administrator may assess the impact of the project against a business driver. For example, a project like “Acquire Tokyo Bank” may have a significant impact to the business driver “Expand into Asian markets,” but little or no impact to the business driver “Increase customer satisfaction.” Similarly, a project like “Give all employees a merit increase of 10%” may have a significant impact to the business driver “Increase employee morale,” but little or not impact to the business driver “Expand into Asian markets.”
The project workflow status 422 provides data regarding the status of the project workflow. For example, the workflow stage status 316 of
The workflow phases 428 specify phases of the workflow. As used herein, a workflow phase may refer to a grouping of workflow stages. The administrative interface works may enable an administrator to first define a list of workflow phases that represent big governance gates of a lifecycle such as “Create”, “Select”, “Plan”, “Manage”, “Finalize”, and the like. When a stage is created, the administrative interface may further enable the administrator to select a phase to which the stage belongs. For example, an “Initial Proposal Details” stage may belong to the “Create” phase, a “Selection Review” stage may belong to the “Select” phase, an “Execution” stage may belong to the “Manage” phase, and the like. In some embodiments, a stage belongs to a single phase.
The workflow stages 430 specify the stages included in the enterprise project type, the pages included in each of the stages, and the order in which the stages and pages are displayed to the users. The workflow stages 430 may also specify the state of the input fields (e.g., whether an input field is required, read-write, or read-only) provided by the pages. If the state of the input field is required, then the entity will not advance to the next stage until a value is provided. If the input field is read-only, then the administrator cannot modify the value of the input field. The state of the input fields may also be changed during the life of the workflow. For example, in an enterprise project type, an input field may be configured as required in early stages (e.g., Budget Cost) of the workflow. The same input field may be configured as read-only after the project has been approved.
The department 406 specifies the particular department with which the enterprise project type 112 is associated. In this way, enterprise project types may be filtered according to department through the user interface. Also, certain enterprise project types may be restricted to certain users also through the user interface. For example, users in a given department may only be able to access enterprise project types in that department. The project plan templates 407 include task and schedule templates that can be associated with the enterprise project type 112. The workspace templates 408 include WSS workspace templates that can be associated with the enterprise project type 112.
Referring now to
In
At operation 506, the enterprise project type user module 110 displays a plurality of pages. Each of the pages may comprise a web part. If the enterprise project type is not associated with a workflow, then the enterprise project type specifies the pages that are displayed. If the enterprise is associated with a workflow, then the workflow specifies the pages that are displayed. The routine 500 then proceeds to operation 508, where the enterprise project type user module 110 receives values of properties through the displayed pages. When the enterprise project type user module 110 receives values of properties through the displayed pages, the routine 500 proceeds to operation 510, where the enterprise project type user module 110 generates an entity based on the received values of properties. In particular, the received values of properties are transformed into the entity, which may represent a project plan, an application plan, or a product plan.
In
At operation 526, the enterprise project type admin module 108 receives one of the workflow selection options. The routine 520 then proceeds to operation 528, where the enterprise project type admin module 108 determines whether the received option has an associated workflow. In the example above, if the enterprise project type admin module 108 receives the first option with no associated workflow, then the routine 520 proceeds to operation 530, where the enterprise project type admin module 108 displays a list of pages. When the enterprise project type admin module 108 displays the list of pages, the routine 520 proceeds to operation 532.
At operation 532, the enterprise project type admin module 108 receives a selection of pages from the list of pages. The routine 520 then proceeds to operation 534, where the enterprise project type is generated based on the selection of pages. In particular, the selected pages are transformed into the enterprise project type. At operation 528 again, if the enterprise project type admin module 108 receives the second option with an associated workflow, then the routine 520 proceeds to operation 536, where the enterprise project type admin module 108 generates the enterprise project type based on the associated workflow. In particular, the workflow is transformed into the enterprise project type.
Referring now to
By way of example, and not limitation, computer-storage media may include volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage of information such as computer-storage instructions, data structures, program modules, or other data. For example, computer-storage media includes, but is not limited to, RAM, ROM, EPROM, EEPROM, flash memory or other solid state memory technology, CD-ROM, digital versatile disks (“DVD”), HD-DVD, BLU-RAY, or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by the computer 600.
According to various embodiments, the computer 600 may operate in a networked environment using logical connections to remote computers through a network such as the network 618. The computer 600 may connect to the network 618 through a network interface unit 610 connected to the bus 606. It should be appreciated that the network interface unit 610 may also be utilized to connect to other types of networks and remote computer systems. The computer 600 may also include an input/output controller 608 for receiving and processing input from a number of input devices (not shown), including a keyboard, a mouse, a microphone, and a game controller. Similarly, the input/output controller 608 may provide output to a display or other type of output device (not shown).
The bus 606 may enable the processing unit 602 to read code and/or data to/from the mass storage device 612 or other computer-storage media. The computer-storage media may represent apparatus in the form of storage elements that are implemented using any suitable technology, including but not limited to semiconductors, magnetic materials, optics, or the like. The computer-storage media may represent memory components, whether characterized as RAM, ROM, flash, or other types of technology. The computer-storage media may also represent secondary storage, whether implemented as hard drives or otherwise. Hard drive implementations may be characterized as solid state, or may include rotating media storing magnetically-encoded information.
The program modules 614 may include software instructions that, when loaded into the processing unit 602 and executed, cause the computer 600 to provide an enterprise project type. The program modules 614 may also provide various tools or techniques by which the computer 600 may participate within the overall systems or operating environments using the components, flows, and data structures discussed throughout this description. For example, the program modules 614 may implement interfaces for generating an enterprise project type and generating an entity based on an instance of the enterprise project type.
In general, the program modules 614 may, when loaded into the processing unit 602 and executed, transform the processing unit 602 and the overall computer 600 from a general-purpose computing system into a special-purpose computing system customized to provide an enterprise project type. The processing unit 602 may be constructed from any number of transistors or other discrete circuit elements, which may individually or collectively assume any number of states. More specifically, the processing unit 602 may operate as a finite-state machine, in response to executable instructions contained within the program modules 614. These computer-executable instructions may transform the processing unit 602 by specifying how the processing unit 602 transitions between states, thereby transforming the transistors or other discrete hardware elements constituting the processing unit 602.
Encoding the program modules 614 may also transform the physical structure of the computer-storage media. The specific transformation of physical structure may depend on various factors, in different implementations of this description. Examples of such factors may include, but are not limited to: the technology used to implement the computer-storage media, whether the computer-storage media are characterized as primary or secondary storage, and the like. For example, if the computer-storage media are implemented as semiconductor-based memory, the program modules 614 may transform the physical state of the semiconductor memory, when the software is encoded therein. For example, the program modules 614 may transform the state of transistors, capacitors, or other discrete circuit elements constituting the semiconductor memory.
As another example, the computer-storage media may be implemented using magnetic or optical technology. In such implementations, the program modules 614 may transform the physical state of magnetic or optical media, when the software is encoded therein. These transformations may include altering the magnetic characteristics of particular locations within given magnetic media. These transformations may also include altering the physical features or characteristics of particular locations within given optical media, to change the optical characteristics of those locations. Other transformations of physical media are possible without departing from the scope of the present description, with the foregoing examples provided only to facilitate this discussion.
Based on the foregoing, it should be appreciated that technologies for providing an enterprise project type are presented herein. Although the subject matter presented herein has been described in language specific to computer structural features, methodological acts, and computer readable media, it is to be understood that the invention defined in the appended claims is not necessarily limited to the specific features, acts, or media described herein. Rather, the specific features, acts and mediums are disclosed as example forms of implementing the claims.
The subject matter described above is provided by way of illustration only and should not be construed as limiting. Various modifications and changes may be made to the subject matter described herein without following the example embodiments and applications illustrated and described, and without departing from the true spirit and scope of the present invention, which is set forth in the following claims.