Search in sources :

Example 1 with TimesheetLineService

use of com.axelor.apps.hr.service.timesheet.TimesheetLineService in project axelor-open-suite by axelor.

the class TimesheetLineController method setDuration.

/**
 * Called from timesheet editor Get the timesheet corresponding to timesheetline and call {@link
 * TimesheetLineService#computeHoursDuration(Timesheet, BigDecimal, boolean)}
 *
 * @param request
 * @param response
 */
public void setDuration(ActionRequest request, ActionResponse response) {
    try {
        TimesheetLine timesheetLine = request.getContext().asType(TimesheetLine.class);
        Timesheet timesheet;
        Context parent = request.getContext().getParent();
        if (parent != null && parent.getContextClass().equals(Timesheet.class)) {
            timesheet = parent.asType(Timesheet.class);
        } else {
            timesheet = timesheetLine.getTimesheet();
        }
        BigDecimal duration = Beans.get(TimesheetLineService.class).computeHoursDuration(timesheet, timesheetLine.getHoursDuration(), false);
        response.setValue(DURATION_FIELD, duration);
    } catch (Exception e) {
        TraceBackService.trace(response, e);
    }
}
Also used : Context(com.axelor.rpc.Context) TimesheetLine(com.axelor.apps.hr.db.TimesheetLine) Timesheet(com.axelor.apps.hr.db.Timesheet) TimesheetLineService(com.axelor.apps.hr.service.timesheet.TimesheetLineService) BigDecimal(java.math.BigDecimal)

Example 2 with TimesheetLineService

use of com.axelor.apps.hr.service.timesheet.TimesheetLineService in project axelor-open-suite by axelor.

the class TimesheetLineController method setStoredDuration.

/**
 * Called from timesheet line editable grid or form. Get the timesheet corresponding to
 * timesheetline and call {@link TimesheetLineService#computeHoursDuration(Timesheet, BigDecimal,
 * boolean)}
 *
 * @param request
 * @param response
 */
public void setStoredDuration(ActionRequest request, ActionResponse response) {
    try {
        TimesheetLine timesheetLine = request.getContext().asType(TimesheetLine.class);
        Timesheet timesheet;
        Context parent = request.getContext().getParent();
        if (parent != null && parent.getContextClass().equals(Timesheet.class)) {
            timesheet = parent.asType(Timesheet.class);
        } else {
            timesheet = timesheetLine.getTimesheet();
        }
        BigDecimal hoursDuration = Beans.get(TimesheetLineService.class).computeHoursDuration(timesheet, timesheetLine.getDuration(), true);
        response.setValue(HOURS_DURATION_FIELD, hoursDuration);
    } catch (Exception e) {
        TraceBackService.trace(response, e);
    }
}
Also used : Context(com.axelor.rpc.Context) TimesheetLine(com.axelor.apps.hr.db.TimesheetLine) Timesheet(com.axelor.apps.hr.db.Timesheet) TimesheetLineService(com.axelor.apps.hr.service.timesheet.TimesheetLineService) BigDecimal(java.math.BigDecimal)

Example 3 with TimesheetLineService

use of com.axelor.apps.hr.service.timesheet.TimesheetLineService in project axelor-open-suite by axelor.

the class HumanResourceMobileController method insertOrUpdateTSLine.

/*
   * This method is used in mobile application.
   * It was in TimesheetServiceImpl
   * @param request
   * @param response
   *
   * POST /open-suite-webapp/ws/action/com.axelor.apps.hr.mobile.HumanResourceMobileController:insertOrUpdateTSLine
   * Content-Type: application/json
   *
   * URL: com.axelor.apps.hr.mobile.HumanResourceMobileController:insertOrUpdateTSLine
   * fields: (id,) project, activity, date, duration, comments
   *
   * payload:
   * { "data": {
   * 		"action": "com.axelor.apps.hr.mobile.HumanResourceMobileController:insertOrUpdateTSLine",
   *        "id": 1,
   * 		"project": 1,
   * 		"activity": 2,
   * 		"date": "2018-02-22",
   * 		"duration": 10,
   * 		"comments": "no"
   * } }
   */
@Transactional
public void insertOrUpdateTSLine(ActionRequest request, ActionResponse response) {
    // insert TimesheetLine
    try {
        Map<String, Object> requestData = request.getData();
        User user = AuthUtils.getUser();
        Project project = Beans.get(ProjectRepository.class).find(new Long(request.getData().get("project").toString()));
        Product product = Beans.get(ProductRepository.class).find(new Long(request.getData().get("activity").toString()));
        LocalDate date = LocalDate.parse(request.getData().get("date").toString(), DateTimeFormatter.ISO_DATE);
        TimesheetRepository timesheetRepository = Beans.get(TimesheetRepository.class);
        TimesheetService timesheetService = Beans.get(TimesheetService.class);
        TimesheetLineService timesheetLineService = Beans.get(TimesheetLineService.class);
        if (user != null) {
            Timesheet timesheet = timesheetRepository.all().filter("self.statusSelect = 1 AND self.user.id = ?1", user.getId()).order("-id").fetchOne();
            if (timesheet == null) {
                timesheet = timesheetService.createTimesheet(user, date, date);
            }
            BigDecimal hours = new BigDecimal(request.getData().get("duration").toString());
            TimesheetLine line;
            Object idO = requestData.get("id");
            if (idO != null) {
                line = timesheetLineService.updateTimesheetLine(Beans.get(TimesheetLineRepository.class).find(Long.valueOf(idO.toString())), project, product, user, date, timesheet, hours, request.getData().get("comments").toString());
            } else {
                line = timesheetLineService.createTimesheetLine(project, product, user, date, timesheet, hours, request.getData().get("comments").toString());
            }
            // convert hours to what is defined in timeLoggingPreferenceSelect
            BigDecimal duration = timesheetLineService.computeHoursDuration(timesheet, hours, false);
            line.setDuration(duration);
            timesheet.addTimesheetLineListItem(line);
            timesheetRepository.save(timesheet);
            response.setTotal(1);
            HashMap<String, Object> data = new HashMap<>();
            data.put("id", line.getId());
            response.setData(data);
        }
    } catch (Exception e) {
        TraceBackService.trace(e);
    }
}
Also used : User(com.axelor.auth.db.User) ProjectRepository(com.axelor.apps.project.db.repo.ProjectRepository) TimesheetLine(com.axelor.apps.hr.db.TimesheetLine) HashMap(java.util.HashMap) ProductRepository(com.axelor.apps.base.db.repo.ProductRepository) Timesheet(com.axelor.apps.hr.db.Timesheet) Product(com.axelor.apps.base.db.Product) TimesheetService(com.axelor.apps.hr.service.timesheet.TimesheetService) LocalDate(java.time.LocalDate) BigDecimal(java.math.BigDecimal) AxelorException(com.axelor.exception.AxelorException) Project(com.axelor.apps.project.db.Project) TimesheetLineRepository(com.axelor.apps.hr.db.repo.TimesheetLineRepository) TimesheetRepository(com.axelor.apps.hr.db.repo.TimesheetRepository) TimesheetLineService(com.axelor.apps.hr.service.timesheet.TimesheetLineService) Transactional(com.google.inject.persist.Transactional)

Example 4 with TimesheetLineService

use of com.axelor.apps.hr.service.timesheet.TimesheetLineService in project axelor-open-suite by axelor.

the class OperationOrderTimesheetServiceImpl method updateOperationOrders.

@Override
@Transactional(rollbackOn = { Exception.class })
public void updateOperationOrders(Timesheet timesheet) throws AxelorException {
    if (timesheet.getTimesheetLineList() == null) {
        return;
    }
    // ensure that correct hoursDuration is filled
    TimesheetLineService timesheetLineService = Beans.get(TimesheetLineService.class);
    for (TimesheetLine timesheetLine : timesheet.getTimesheetLineList()) {
        BigDecimal hoursDuration = timesheetLineService.computeHoursDuration(timesheet, timesheetLine.getDuration(), true);
        timesheetLine.setHoursDuration(hoursDuration);
    }
    if (!Beans.get(AppProductionService.class).getAppProduction().getEnableTimesheetOnManufOrder()) {
        return;
    }
    List<TimesheetLine> oldTimesheetLineList = Beans.get(TimesheetLineRepository.class).all().filter("self.timesheet.id = :timesheetId").bind("timesheetId", timesheet.getId()).fetch();
    List<TimesheetLine> newTimesheetLineList = timesheet.getTimesheetLineList();
    List<TimesheetLine> allTimesheetLineList = new ArrayList<>(oldTimesheetLineList);
    allTimesheetLineList.addAll(newTimesheetLineList);
    List<OperationOrder> operationOrdersToUpdate = allTimesheetLineList.stream().map(TimesheetLine::getOperationOrder).filter(Objects::nonNull).distinct().collect(Collectors.toList());
    operationOrdersToUpdate.forEach(operationOrder -> updateOperationOrder(operationOrder, oldTimesheetLineList, newTimesheetLineList));
}
Also used : TimesheetLine(com.axelor.apps.hr.db.TimesheetLine) TimesheetLineService(com.axelor.apps.hr.service.timesheet.TimesheetLineService) ArrayList(java.util.ArrayList) Objects(java.util.Objects) OperationOrder(com.axelor.apps.production.db.OperationOrder) BigDecimal(java.math.BigDecimal) AppProductionService(com.axelor.apps.production.service.app.AppProductionService) Transactional(com.google.inject.persist.Transactional)

Aggregations

TimesheetLine (com.axelor.apps.hr.db.TimesheetLine)4 TimesheetLineService (com.axelor.apps.hr.service.timesheet.TimesheetLineService)4 BigDecimal (java.math.BigDecimal)4 Timesheet (com.axelor.apps.hr.db.Timesheet)3 Context (com.axelor.rpc.Context)2 Transactional (com.google.inject.persist.Transactional)2 Product (com.axelor.apps.base.db.Product)1 ProductRepository (com.axelor.apps.base.db.repo.ProductRepository)1 TimesheetLineRepository (com.axelor.apps.hr.db.repo.TimesheetLineRepository)1 TimesheetRepository (com.axelor.apps.hr.db.repo.TimesheetRepository)1 TimesheetService (com.axelor.apps.hr.service.timesheet.TimesheetService)1 OperationOrder (com.axelor.apps.production.db.OperationOrder)1 AppProductionService (com.axelor.apps.production.service.app.AppProductionService)1 Project (com.axelor.apps.project.db.Project)1 ProjectRepository (com.axelor.apps.project.db.repo.ProjectRepository)1 User (com.axelor.auth.db.User)1 AxelorException (com.axelor.exception.AxelorException)1 LocalDate (java.time.LocalDate)1 ArrayList (java.util.ArrayList)1 HashMap (java.util.HashMap)1