Example #1
0
  private CompoundPropertyModel<ReportCriteria> createModelForMonth(Calendar forMonth) {
    ReportCriteria reportCriteria = getReportCriteria();

    reportCriteria.getUserCriteria().setReportRange(DateUtil.getDateRangeForMonth(forMonth));

    if (reportCriteria.getUserCriteria().getProjects() == null) {
      reportCriteria.getUserCriteria().setProjects(new ArrayList<Project>());
    }

    return new CompoundPropertyModel<ReportCriteria>(reportCriteria);
  }
  /** Update available report criteria */
  public ReportCriteria syncUserReportCriteria(
      ReportCriteria reportCriteria, ReportCriteriaUpdateType updateType) {
    UserCriteria userCriteria = reportCriteria.getUserCriteria();
    AvailableCriteria availCriteria = reportCriteria.getAvailableCriteria();

    if (userCriteria.isSingleUser()) {
      syncCriteriaForSingleUser(reportCriteria);
    } else {
      if (updateType == ReportCriteriaUpdateType.UPDATE_CUSTOMERS
          || updateType == ReportCriteriaUpdateType.UPDATE_ALL) {
        availCriteria.setCustomers(getAvailableCustomers(userCriteria));
      }

      if (updateType == ReportCriteriaUpdateType.UPDATE_PROJECTS
          || updateType == ReportCriteriaUpdateType.UPDATE_ALL) {
        availCriteria.setProjects(getAvailableProjects(userCriteria));
      }

      if (updateType == ReportCriteriaUpdateType.UPDATE_ALL) {
        availCriteria.setUserDepartments(userDepartmentDAO.findAll());

        availCriteria.setReportRange(reportAggregatedDAO.getMinMaxDateTimesheetEntry());
      }

      if (updateType == ReportCriteriaUpdateType.UPDATE_USERS
          || updateType == ReportCriteriaUpdateType.UPDATE_ALL) {
        availCriteria.setUsers(getAvailableUsers(userCriteria));
      }
    }

    return reportCriteria;
  }
  /**
   * Sync criteria for users, only customers & projects are displayed for users in this list
   *
   * @param reportCriteria
   */
  private void syncCriteriaForSingleUser(ReportCriteria reportCriteria) {
    Set<Customer> customers = new HashSet<Customer>();
    Set<Project> projects = new HashSet<Project>();
    AvailableCriteria availCriteria = reportCriteria.getAvailableCriteria();
    User user;

    user = reportCriteria.getUserCriteria().getUsers().get(0);

    List<ProjectAssignment> assignments =
        projectAssignmentDAO.findProjectAssignmentsForUser(
            user.getUserId(), reportCriteria.getUserCriteria().getReportRange());

    for (ProjectAssignment assignment : assignments) {
      customers.add(assignment.getProject().getCustomer());
      projects.add(assignment.getProject());
    }

    availCriteria.setCustomers(new ArrayList<Customer>(customers));
    availCriteria.setProjects(new ArrayList<Project>(projects));

    availCriteria.setReportRange(reportAggregatedDAO.getMinMaxDateTimesheetEntry(user));
  }