Quick Start

Describes a quick start for new teams, projects etc. and best practices.

1. Introduction

ProjectForge® is designed to improve the efficiency of projects and project teams from single-person-projects up to large-sized projects. This document contains techniques and concepts for your successful project management, supported by ProjectForge®, the project management portal.

You can use the action links while reading this tutorial and create the objects of this tutorial by simply clicking on those action links (in the html version of this tutorial). You can change the tutorial data (user names etc.) like you want. The tutorial only needs the reference names placed in the description fields. Quick start, create your first project step-by-step: ACME web portal

After the creation of the users you can use the wizard of the structure tree page to generate groups and access rights very quickly. Follow this tutorial to understand the things behind the wizard…​

1.1. Set-up of your team members

Login as admin user and create one account per project member (administration sub-menu users). In this example we start with three team members, one project manager and two team members:

Username Description (team role) E-Mail Assigned groups

linda

Project manager

l.evans@javagurus.com

PF_ProjectManager

dave

Developer

d.jones@javagurus.com

-

betty

Developer

b.brown@javagurus.com

-

1.2. Set-up your company: JavaGurus Inc.

1.2.1. Create your company’s top level structure element

Login as admin user and create a top level structure element with the name of your company (JavaGurus Inc.). Click on the menu item "structure tree" and on the button "add". Select the ProjectForge®'s root structure element as parent. Create this structure element (and click the search button in the tree view for refreshing your structure tree).

Name of structure element Parent structure element

JavaGurus Inc.

ProjectForge®'s root structure element

1.3. Create a group for all employees

Add a user group (meu item "Administration" → "Groups") named e. g. "JavaGurus employees".

Group name Assigned members

JavaGurus employees

Lind, Dave, Betty.

1.4. Create project member group

Go to administration → groups and create a new group:

Group name Assigned members

ACME web portal team

Linda, Dave, Betty.

Assign the members while selecting all members and clicking the left-arrow-icon. You can select multiple entries by using the keys Shift or Ctrl for assigning them at once.

1.5. Create your project root structure element, e. g. ACME Web portal

Click on the menu entry 'structure tree' and create a structure element named as your project:

Name of structure element Parent structure element

ACME web portal

Root (select parent structure element by clicking on the hierarchy icon and simply select Root).

can change the hierarchy and the names of your structure elements (e. g. for organizing your projects per customer) later, so start with your project as top level structure element. Also user names, group names etc. can be changed any time you want without loosing any references in the system.

You can change the hierarchy and the names of your structure elements (e. g. for organizing your projects per customer) later, so start with your project as top level structure element. Also user names, group names etc. can be changed any time you want without loosing any references in the system.

1.6. Assign the required team access

ProjectForge® has an very detailed access management, so you can configure which user has which access to the system. Enable your ACME web portal team for working with the project. Some access rights depends on the structure elements, so define the access to a structure element by choosing the menu entry 'access management' and clicking the button 'create':

Structure element Group Recursive Description Access rights

JavaGurus Inc.

JavaGurus employees

yes

The employee’s main structure element for books, addresses, for time sheets not assigned to projects such as ill-ness, holiday, research and development etc.

Choose template 'employee'.

ACME web portal

ACME web portal team

yes

The top-level structure element for the ACME web portal project.

Choose template 'employee'.

If they’re are any labels or text fields with italic letters (such as the label 'recursive') you’ll get a tool-tip explaning the component when you place your mouse over such elements. Finish

Now your project team members are able to book time sheets on your ACME web portal project. They’re also able to give their project a sub structure, explaining in the next chapter: ProjectForge Quickstart Structure of your projects ProjectForge Quickstart Structure of your projects The idea of structure trees and hierarchy

ProjectForge® supports a hierarchy of your structure elements without any limitations concerning the depth of your tree or the number of your structure elements. structure element is a general term which can represent customers, projects, project phases, work packages, tasks, issues and further more. Best practice: recommended structure element structure for your projects

It’s recommended to organize your project as followed, see fig. 2 for an example: Level Type Description Top level Customer e. g. ACME. This is useful for grouping a lot of projects per customers. You can start without this level and can insert it later, if needed. Level two Project name Simply the name of your project, e. g. ACME web portal Level three Release Your project will have hopefully several releases, so you can group your activities per release. In non-IT projects the release can be something such as e. g. year for annual conferences etc. Level four Phases Your project consists of several phases, e. g. akquisition, specification, build, maintenance. Level five Work packages For large projects (more than 10 md) it’s useful to break down your packages. Level six Issues For very large projects it’s useful to break down your packages in issues. If you’re using the issue tracking system JIRA it’s recommended to link the JIRA-Issues to your structure elements and/or time sheets..

Recommended structure hierarchy of a project.

Please remember: You can change your hierarchy whenever you want, so you can start for example with your project as a top level structure element and insert the customer later, if you'll have more projects and customers.

You can add sub structure elements by selecting your the parent structure element and pressing the button 'create structure sub element'. A more convenient method to organize the structure tree of your project is by using the menu entry Gantt. ProjectForge Quickstart Time sheet booking Adding time sheets

All team members should book every activity on the project as time sheets. They can book their time sheets in a very convenient way. The easiest way is to use the calendar, click on a day or the start-/stop-times of an existing time-sheet to book new time sheets. Every time sheet needs at least a start- and stop time, the structure element on which the user has worked on. Optional the user can enter a JIRA-issue-id for having a direct link to your JIRA-system.

Please choose yourself as the user in the calendar view by simply clicking on the smiley at the right top, for displaying all your time sheets you have already booked.

Consumption of work packages

For getting an overview every time you work with ProjectForge® it’s recommended to configure your estimated time budgets to every structure element. If the user books his time sheet on a structure element he can instantly see the consumption of this structure element. In the structure tree you can see all consumptions of every displayed structure element. There are two ways to configure budgets. The easiest way is to enter the budget in hours on every structure element. If a structure element has structure sub elements with given maximum hours and the structure element has itself no budget setting, the budget for this parent structure element is automatically calculated (sum of all structure sub elements budgets). The other way is to define your budgets by assigning orders (described not here). You can mix both approaches. ProjectForge Quickstart Gantt charts

Planning a project and controlling a project to keep the project on track, Gantt charts are a very often used technique. ProjectForge® supports Gantt charts as descriped in this chapter. You can edit all Gantt parameters such as start/stop dates, duration, predecessors etc. by editing the structure element in the structure tree. But it’s more convenient to edit the parameters of the structure element in the Gantt tree directly. You’ll get the Gantt functionality by choosing the menu entry 'Gantt'. Add a new chart and choose your structure element (project, release of project phase) you like to plan. In this example we choose the project’s main structure element 'ACME web portal'.

2. ProjectForge Quickstart Cost-unit accounting

Project managers and especially controller like reports, reports and reports. If you like to answer one of the following questions regarding your project(s), you should use the cost features of ProjectForge® as introduced below.

  • What is the profit of our project ACME Web portal and of the company ACME over all?

  • How many travel costs did we spent for the project ACME Web and for the ACME company at all?

  • How many costs did we spent for the warranty for …​?

  • How many costs for acquisition for …​

  • What was the budget for R&D for our whole company?

2.1. Setting up cost objectives, requirements (optional)

Following steps are required to enable your ProjectForge installation for having cost objectives:

2.1.1. Activating cost

Set the flag "is cost activated" to true (see configuration menu).

2.1.2. Access rights and required group of the financial administrative user

Please ensure that the financial adminstrative user is assigned to the group PF_FINANCE and the right "cost *" is set to read/write, same for projects.

2.1.3. Define cost2 types

You’ve to define cost2 types which are valid for all structure elements and projects. Later you’ll be able to do cost calculation based on those cost type, e. g. how much profit do you have with "maintenance" for all projects of customer ACME. Here is an example list to get an idea (feel free to find your own numbers and descriptions, you can extend this list any time later):

Number Description

00

akuisition

02

realisation (invoiced)

03

testing (invoiced)

04

maintenance (invoiced)

05

license fees (invoiced)

06

specification/documentation (invoiced)

07

warranty

08

project management (invoiced)

11

meetings

12

meetings, invoiced (invoiced)

13

travelling

14

traveling, invoiced (invoiced)

20

R&D

…​

Please note: invoiced is only a flag which you can use later in your reporting scripts.

2.1.4. Define customers and projects

For project/customer specific cost objectives you’ll need to define customers first and then the customer’s projects. It’s a best practice to have a misc project for every customer to assign time-sheets and cost which aren’t specific to a project or for small projects where you don’t need a separate cost calculation for.

2.1.5. Define cost2

You can define cost2 entries (independant from projects) or project specific cost2 entries by selecting the project first.

2.1.6. Assign projects or cost2 to structure elements

You can assign projects to structure elements in your structure tree (in the project edit page) or by adding non-project-specific cost2 entries directly to a structure element. For project-specific cost-assignments you can use a black/white-list to reduce the available cost2 objects for a sub structure element / or structure sub tree. Please see the structure element edit page for a better understanding.

2.2. ProjectForge Quickstart Calendars

Please refer the user guide for further information.

2.3. ProjectForge Quickstart Best practices

Fast and mouse-less editing - default buttons

In almost all dialogs the change button is the default submit button (green button). This button is used automatically if the user hits the RETURN key inside form fields. In Text-areas you may use the CTRL-RETURN key because the normal return key produces a new line.

2.3.1. Making your life easier: with Favorites

As a project manager you need often to select users, so have a look at the select box right to each user selection panel. Select a user and then choose 'create' for generating a favorite entry for users. It’s also possible to create favorites for structure elements, time sheets (templates) etc. You can manage your favorites by choosing the menu entry 'my preferences'.

2.3.2. Sharing addresses and books

Go to "Administration" → "Settings" and configure the top level structure element of your company (JavaGurus Inc.) as default value for addresses and books. Afterwards all your employees are able to work with your library and company address book.

2.3.3. Administrators, financial administrative user, organisational staff members and controlling users

In larger companies it’s use-full to split this role.

2.3.4. System administrators

You should have system administrators who’re responsible to manage users, groups and access rights to structure elements and functionalities.

2.3.5. Financial administrative users

You should have users of your financial administrative staff who’re responsible to manage employees (and salaries), customers, order book, cost objectives, projects as well as invoices (outbound and inbound). You can specify which rights each user should have. The user’s of the group "PF_Organization" (if exist) have reduced rights at default.

2.3.6. Project managers

Project managers are able to plan human resources and to organize the order book for the projects they’re members of the project manager group (set in project details).

2.3.7. Controllers

Members of the group "PF_Controlling" have read-only access to most areas of ProjectForge at default. The also have the possibility to use, create and modify scripts. The scripts are run with read-only access. The rights of the user who runs a script is checked for every object read of the data-base. If the user has no read-access to one object, the object is removed from the result-set. (In future releases scripting will be accessible by all user with the "scripting"-right). ProjectForge ensures, that a scripting user will always have access to only those objects he has the read-access for. But you should only give this access to well-known users, because a fraud has the possibility to get write access via e. g. Java reflection API.


Installation

Related Docs