package WebGUI::Asset::Wobject::TimeTracking; use strict; our $VERSION = "1.0.0"; #------------------------------------------------------------------- # WebGUI is Copyright 2001-2012 Plain Black Corporation. #------------------------------------------------------------------- # Please read the legal notices (docs/legal.txt) and the license # (docs/license.txt) that came with this distribution before using # this software. #------------------------------------------------------------------- # http://www.plainblack.com info@plainblack.com #------------------------------------------------------------------- use DateTime; use Tie::IxHash; use WebGUI::International; use POSIX qw(ceil floor); use Moose; use WebGUI::Definition::Asset; extends 'WebGUI::Asset::Wobject'; define assetName => ['assetName', 'Asset_TimeTracking']; define icon => 'timetrack.gif'; define tableName => 'TT_wobject'; property userViewTemplateId => ( fieldType => "template", default => 'TimeTrackingTMPL000001', tab => "display", namespace => "TimeTracking_user", hoverHelp => ['userViewTemplate hoverhelp', 'Asset_TimeTracking'], label => ['userViewTemplate label', 'Asset_TimeTracking'], ); property managerViewTemplateId => ( fieldType => "template", default => 'TimeTrackingTMPL000002', tab => "display", namespace => "TimeTracking_manager", hoverHelp => ['managerViewTemplate hoverhelp', 'Asset_TimeTracking'], label => ['managerViewTemplate label', 'Asset_TimeTracking'], ); property timeRowTemplateId => ( fieldType => "template", default => 'TimeTrackingTMPL000003', tab => "display", namespace => "TimeTracking_row", hoverHelp => ['timeRowTemplateId hoverhelp', 'Asset_TimeTracking'], label => ['timeRowTemplateId label', 'Asset_TimeTracking'], ); property groupToManage => ( fieldType => "group", default => 3, tab => "security", hoverHelp => ['groupToManage hoverhelp', 'Asset_TimeTracking'], label => ['groupToManage label', 'Asset_TimeTracking'], ); property pmIntegration => ( fieldType => "yesNo", default => 0, tab => "properties", hoverHelp => ["Choose yes to pull projects and task information from the various project management assets on your site", 'Asset_TimeTracking'], label => ["Project Management Integration", 'Asset_TimeTracking'], ); use WebGUI::Asset::Wobject::ProjectManager; #------------------------------------------------------------------- =head2 prepareView =cut override prepareView => sub { my $self = shift; super(); my $template; $template = WebGUI::Asset::Template->newById($self->session, $self->userViewTemplateId); if (!$template) { WebGUI::Error::ObjectNotFound::Template->throw( error => qq{Template not found}, templateId => $self->userViewTemplateId, assetId => $self->getId, ); } $template->prepare($self->getMetaDataAsTemplateVariables); $self->{_viewTemplate} = $template; }; #------------------------------------------------------------------- =head2 processErrors =cut sub processErrors { my $self = shift; my $errors = ""; if($_[0]) { $errors = ""; } return $errors; } #------------------------------------------------------------------- =head2 getDaysInWeek =cut sub getDaysInWeek { my $self = shift; my $week = $_[0]; return [] unless $week; my ($session,$dt,$log) = $self->getSessionVars("datetime","log"); my $i18n = WebGUI::International->new($session,'Asset_TimeTracking'); #Week View Below my ($dayStart,$dayEnd) = $dt->dayStartEnd($week); my $dayOfWeek = $dt->getDayOfWeek($dayStart); my $sundayAdjust = ((7 - $dayOfWeek) - 7); my $weekStart = $dt->addToDateTime($dayStart,0,0,$sundayAdjust,1); tie my %hash, "Tie::IxHash"; $hash{"0"} = $dt->epochToSet($weekStart); for (my $i = 1; $i < 7; $i++) { $hash{$i} = $dt->epochToSet($dt->addToDate($weekStart,0,0,$i)); } return \%hash; } #------------------------------------------------------------------- =head2 getSessionVars =cut sub getSessionVars { my $self = shift; my @vars = @_; my $session = $self->session; return ($session) unless (scalar(@vars) > 0); my @list = (); push(@list, $session); foreach my $var (@vars) { push(@list, $session->$var); } return @list; } #------------------------------------------------------------------- =head2 view =cut sub view { my $self = shift; my $var = $self->get; my ($session,$privilege,$form,$db,$dt,$user,$log,$config) = $self->getSessionVars("privilege","form","db","datetime","user","log","config"); my $i18n = WebGUI::International->new($session,'Asset_TimeTracking'); $var->{'extras'} = $session->url->make_urlmap_work($config->get("extrasURL"))."/wobject/TimeTracking"; if($user->isInGroup($self->groupToManage)) { $var->{'project.manage.url'} = $self->getUrl("func=manageProjects"); $var->{'project.manage.label'} = $i18n->get("project manage label"); } $var->{'form.header'} = WebGUI::Form::formHeader($session,{ action=>$self->getUrl, extras=>q|name="editTimeForm" onsubmit="return validateForm(this);"| }); $var->{'form.header'} .= WebGUI::Form::hidden($session, { -name=>"func", -value=>"editTimeEntrySave" }); $var->{'form.header'} .= WebGUI::Form::hidden($session, { -name=>"rowTotal", -value=>"" }); $var->{'form.footer'} = WebGUI::Form::formFooter($session); $var->{'js.alert.removeRow.error'} = $i18n->get("There must be at least one row. Please add more rows if you wish to delete this one"); $var->{'js.alert.validate.hours.error'} = $i18n->get("You may not submit more hours than are available during any given week."); $var->{'js.alert.validate.incomplete.error'} = $i18n->get("The highlighted fields are required if you wish to submit this form."); $var->{'form.timetracker'} = $self->www_buildTimeTable($var); return $self->processTemplate($var, undef, $self->{_viewTemplate}); } #------------------------------------------------------------------- =head2 www_editTimeEntrySave =cut sub www_editTimeEntrySave { my $self = shift; my ($session,$privilege,$form,$db,$user,$log,$dt) = $self->getSessionVars("privilege","form","db","user","log","datetime"); return $privilege->insufficient unless ($self->canView); my $now = $dt->time(); my $currUser = $user->userId; my $props = {}; my $reportId = $form->get("reportId"); $props->{reportId} = $reportId; $props->{startDate} = $form->process("startDate","hidden"); $props->{endDate} = $form->process("endDate","hidden"); $props->{reportComplete} = $form->process("isComplete","checkbox") || 0; $props->{resourceId} = $form->process("resourceId","hidden"); if ($reportId eq "new") { $props->{creationDate} = $now; $props->{createdBy} = $currUser; } $props->{lastUpdatedBy} = $currUser; $props->{lastUpdateDate} = $now; $reportId = $self->setCollateral("TT_report","reportId",$props,0,1); my %deltaHours = (); foreach my $entry (@{$db->buildArrayRefOfHashRefs("SELECT * FROM TT_timeEntry WHERE reportId = ?", [$reportId])}) { $deltaHours{$entry->{projectId}}{$entry->{taskId}} -= $entry->{hours}; } my $rowTotal = $form->get("rowTotal"); my @entryIds = (); for (my $i = 1; $i <= $rowTotal; $i++) { my $entryId = $form->get("taskEntryId_$i"); next unless $entryId; my $props = {}; $props->{entryId} = $entryId; $props->{reportId} = $reportId; $props->{taskDate} = $form->process("taskDate_$i","selectBox"); $props->{projectId} = $form->process("projectId_$i","selectBox"); $props->{taskId} = $form->process("taskId_$i","selectBox"); $props->{hours} = $form->process("hours_$i","float"); $props->{comments} = $form->process("comments_$i","text"); $deltaHours{$props->{projectId}}{$props->{taskId}} += $props->{hours}; next unless $props->{taskDate} and $props->{projectId} and $props->{taskId} and $props->{hours}; $entryId = $self->setCollateral("TT_timeEntry","entryId",$props,0,0); push @entryIds, $entryId; } # Clobber other entries. We can't just do this beforehand # because otherwise setCollateral will fail. if(scalar(@entryIds) > 0) { $db->write("DELETE FROM TT_timeEntry WHERE reportId = ? AND entryId NOT IN (".join(', ', ('?') x @entryIds).")", [$reportId, @entryIds]); } # Update Project Management App if integrated if ($self->pmIntegration) { foreach my $projectId (keys %deltaHours) { foreach my $taskId (keys %{$deltaHours{$projectId}}) { my $deltaHours = $deltaHours{$projectId}{$taskId}; if (my $pmAsset = WebGUI::Asset::Wobject::ProjectManager->getProjectInstance($session, $projectId)) { $pmAsset->updateProjectTask($taskId, $projectId, $deltaHours); } } } } return ""; } #------------------------------------------------------------------- =head2 www_deleteProject =cut sub www_deleteProject { my $self = shift; my ($session,$privilege,$form,$db,$user,$log,$config) = $self->getSessionVars("privilege","form","db","user","log","config"); my $i18n = WebGUI::International->new($session,'Asset_TimeTracking'); #Check Privileges return $privilege->insufficient unless ($user->isInGroup($self->groupToManage)); my $projectId = $form->get("projectId"); my ($count) = $db->quickArray("select count(*) from TT_timeEntry where projectId=".$db->quote($projectId)); if($count > 0) { my $error = $i18n->get("This project cannot be deleted as it is currently being used by existing time entry records and would corrupt this data. The records must be deleted if you wish to remove this project"); return $self->www_manageProjects($error); } $db->write("delete from TT_projectResourceList where projectId=".$db->quote($projectId)); $db->write("delete from TT_projectTasks where projectId=".$db->quote($projectId)); $db->write("delete from TT_projectList where projectId=".$db->quote($projectId)); return $self->www_manageProjects(); } #------------------------------------------------------------------- =head2 www_editProject =cut sub www_editProject { my $self = shift; my ($session,$privilege,$form,$db,$user,$log,$config) = $self->getSessionVars("privilege","form","db","user","log","config"); my $i18n = WebGUI::International->new($session,'Asset_TimeTracking'); #Check Privileges return $privilege->insufficient unless ($user->isInGroup($self->groupToManage)); my $projectId = $_[0] || $form->get("projectId") || "new"; my $taskError = qq|
$_[1]| if($_[1]); my $extras = $session->url->make_urlmap_work($config->get("extrasURL"))."/wobject/TimeTracking"; my $project = $db->quickHashRef("select * from TT_projectList where projectId=".$db->quote($projectId)); #Build Form my $f = WebGUI::HTMLForm->new($self->session,-action=>$self->getUrl); $f->hidden( -name=>"func", -value=>"editProjectSave" ); $f->hidden( -name=>"projectId", -value=>$projectId ); $f->hidden( -name=>"action", -value=>"post" ); $f->readOnly( -label=>$i18n->get("edit project id label"), -hoverHelp => $i18n->get('edit project id hoverhelp'), -value=>$projectId ); $f->text( -name => "projectName", -value => $form->get("projectName") || $project->{projectName}, -hoverHelp => $i18n->get('edit project name hoverhelp'), -label => $i18n->get('edit project name label') ); tie my %users, "Tie::IxHash"; %users = $db->buildHash("select userId,username from users where userId not in ('1','3') order by username"); my $resources = $db->buildArrayRef("select resourceId from TT_projectResourceList where projectId=".$db->quote($projectId)); $f->selectList( -name => "resources", -options => \%users, -value => $resources, -hoverHelp => $i18n->get('edit project resource hoverhelp'), -label => $i18n->get('edit project resource label') ); #Add Tasks my $taskNameLabel = $i18n->get("New Task Name"); my $taskAddButtonLabel = $i18n->get("Add"); my $taskTitleLabel = $i18n->get("Tasks"); my $taskDeletePrompt = $i18n->echo("Are you sure you want to delete this activity?"); $taskDeletePrompt =~ s/'/\\'/g; my $taskLabel = $i18n->get("edit project tasks label"); my $taskLoop = ""; tie my %tasks, "Tie::IxHash"; %tasks = $db->buildHash("select taskId,taskName from TT_projectTasks where projectId=".$db->quote($projectId)); foreach my $taskId (keys %tasks) { my $deleteUrl = $self->getUrl("func=editProjectSave;taskId=".$taskId.";action=deleteTask"); my $taskName = $tasks{$taskId}; $taskLoop .= qq| $taskName |; } my $html = qq| $taskLoop
$taskError
$taskTitleLabel
|; $f->raw(qq|$taskLabel$html|); $f->submit(); my $ac = $self->getAdminConsole; my $newProjectUrl = $self->getUrl('func=editProject;projectId=new'); $ac->addSubmenuItem($newProjectUrl,$i18n->get("add project label")); return $ac->render($f->print,$i18n->get("edit project screen label")); } #------------------------------------------------------------------- =head2 www_editProjectSave =cut sub www_editProjectSave { my $self = shift; my ($session,$privilege,$form,$db,$dt,$user,$log) = $self->getSessionVars("privilege","form","db","datetime","user","log"); my $i18n = WebGUI::International->new($session,'Asset_TimeTracking'); #Check Privileges return $privilege->insufficient unless ($user->isInGroup($self->groupToManage)); my $action = $form->get("action"); if ($action eq "deleteTask") { my $taskId = $form->get("taskId"); my ($pid) = $db->quickArray("select projectId from TT_projectTasks where taskId=".$db->quote($taskId)); $db->write("delete from TT_projectTasks where taskId=".$db->quote($taskId)); return $self->www_editProject($pid); } #Add Project my $projectId = $form->process("projectId","hidden") || "new"; my $props = {}; $props->{projectId} = $projectId; $props->{projectName} = $form->process("projectName","text") || "Not Named"; if($projectId eq "new") { $props->{creationDate} = $dt->time(); $props->{createdBy} = $user->userId; } $props->{lastUpdatedBy} = $user->userId; $props->{lastUpdateDate} = $dt->time(); $projectId = $self->setCollateral("TT_projectList","projectId",$props,0,1); #Add Resources $db->write("delete from TT_projectResourceList where projectId=".$db->quote($projectId)); my @resources = $form->process("resources","selectList"); foreach (@resources) { $db->write("insert into TT_projectResourceList (projectId,resourceId) values (".$db->quote($projectId).",".$db->quote($_).")"); } #Add Tasks my $newTaskLabel = $i18n->get("New Task Name"); my $newTaskValue = $form->process("newTaskName","text"); my $newTaskId = ""; if($newTaskValue ne $newTaskLabel && $newTaskValue ne "") { $props = {}; $props->{taskId} = "new"; $props->{projectId} = $projectId; $props->{taskName} = $newTaskValue; $newTaskId = $self->setCollateral("TT_projectTasks","taskId",$props,0,0); } if($action eq "addTask") { my $taskError = ""; $taskError = $i18n->get("No name was entered for new task") if($newTaskId eq ""); return $self->www_editProject($projectId,$taskError); } return $self->www_manageProjects(); } #------------------------------------------------------------------- =head2 www_manageProjects =cut sub www_manageProjects { my $self = shift; my ($session,$privilege,$form,$db,$dt,$user,$log,$config) = $self->getSessionVars("privilege","form","db","datetime","user","log","config"); my $i18n = WebGUI::International->new($session,'Asset_TimeTracking'); #Check Privileges return $privilege->insufficient unless ($user->isInGroup($self->groupToManage)); my $pnLabel = $i18n->get("manage project name label"); my $atLabel = $i18n->get("manage project available task label"); my $resLabel = $i18n->get("manage project resource label"); my $extras = $session->url->make_urlmap_work($config->get("extrasURL"))."/wobject/TimeTracking"; my $errorMessage = ""; $errorMessage = qq|$_[0]| if($_[0]); my $output .= qq| $errorMessage
|; my $projects = $db->buildHashRef("select projectId, projectName from TT_projectList where assetId=".$db->quote($self->getId)); my $count = 0; foreach my $projectId (keys %{$projects}) { my $projectName = $projects->{$projectId}; my $projectId = $projectId; my @tasks = $db->buildArray("select taskName from TT_projectTasks where projectId=".$db->quote($projectId)); my $taskList = join("
",@tasks); my @resources = $db->buildArray("select resourceId from TT_projectResourceList where projectId=".$db->quote($projectId)); for(my $i = 0; $i < scalar(@resources); $i++) { my $u = WebGUI::User->new($session,$resources[$i]); my $fname = $u->profileField("firstName"); my $lname = $u->profileField("lastName"); my $r = $u->username; if($fname && $lname) { $r = $fname." ".$lname; } $resources[$i] = $r; } my $resourceList = join("
",@resources); my $editUrl = $self->getUrl("func=editProject;projectId=".$projectId); my $editIcon = $session->icon->getBaseURL."edit.gif"; my $editLink = qq|get('Edit', 'Icon').q| />|; my $deletePrompt = $i18n->echo("Deleting this project will also delete all associated resources and tasks. Are you sure you'd like to continue?"); $deletePrompt =~ s/'/\\'/g; my $deleteUrl = $self->getUrl("func=deleteProject;projectId=".$projectId); my $deleteIcon = $session->icon->getBaseURL."delete.gif"; my $deleteLink = qq|get('Delete', 'Icon').q|/>|; my $cl = ""; $cl = q|class="alt"| if($count++ % 2 eq 0); $output .= qq| |; } my $newProjectUrl = $self->getUrl('func=editProject;projectId=new'); if(scalar(keys %{$projects}) == 0) { my $noProjects = sprintf($i18n->get("no project message"),$newProjectUrl); $output .= qq|| } $output .= "
$pnLabel $atLabel $resLabel  
$projectName $taskList $resourceList $editLink   $deleteLink
$noProjects
"; my $css = q| |; $output = $css.$output; my $ac = $self->getAdminConsole; $ac->addSubmenuItem($newProjectUrl,$i18n->get("add project label")); return $ac->render($output,$i18n->get("manage projects screen label")); } #------------------------------------------------------------------- =head2 www_buildTimeTable =cut sub www_buildTimeTable { my $self = shift; my $viewVar = $_[0]; my $var = {}; $var->{'extras'} = $viewVar->{'extras'}; my ($session,$dt,$log,$form,$db,$user,$privilege) = $self->getSessionVars("datetime","log","form","db","user","privilege"); my $i18n = WebGUI::International->new($session,'Asset_TimeTracking'); return $privilege->insufficient unless ($self->canView); my $pmIntegration = $self->pmIntegration; my $week = $form->get("week") || $dt->time; my $nextWeek = $dt->addToDate($week,0,0,7); my $lastWeek = $dt->addToDate($week,0,0,-7); my $daysInWeek = $self->getDaysInWeek($week); my $weekStart = $daysInWeek->{"0"}; my $weekEnd = $daysInWeek->{"6"}; #It's this week, don't allow next week url to be seen $var->{'report.nextWeek.url'} = $self->getUrl("func=view;week=$nextWeek"); $var->{'report.lastWeek.url'} = $self->getUrl("func=view;week=$lastWeek"); $var->{'time.report.header'} = sprintf($i18n->get("time report header"),$weekEnd); $var->{'time.report.totalHours.label'} = $i18n->get("total hours label"); $var->{'time.report.date.label'} = $i18n->get("time report date label"); $var->{'time.report.project.label'} = $i18n->get("time report project label"); $var->{'time.report.task.label'} = $i18n->get("time report task label"); $var->{'time.report.hours.label'} = $i18n->get("time report hours label"); $var->{'time.report.comments.label'} = $i18n->get("time report comments label"); $var->{'time.add.row.label'} = $i18n->get("Add Row"); $var->{'time.save.label'} = $i18n->get("Save"); $var->{'time.report.complete.label'} = $i18n->get("Report Complete"); #my ($junk,$weekEnd) = $dt->dayStartEnd($daysInWeek->{"6"}); #Rebuild days in week hash to contain set values tie my %setDaysHash,"Tie::IxHash"; foreach my $day (keys %{$daysInWeek}) { my $set = $daysInWeek->{$day}; $setDaysHash{$set} = $set; } #Build Project List tie my %projectList, "Tie::IxHash"; %projectList = $db->buildHash("select a.projectId, a.projectName from TT_projectList a, TT_projectResourceList b where a.assetId=? and a.projectId=b.projectId and b.resourceId=? order by a.projectName",[$self->getId,$user->userId]); my $pmAsset; if($pmIntegration) { #Build project list and task lists from project management app my ($pmAssetId) = $db->quickArray("select a.assetId from PM_wobject a, asset b where a.assetId=b.assetId and b.state not like 'trash%'"); if($pmAssetId) { $pmAsset = WebGUI::Asset->newById($session,$pmAssetId); my %pmProjectList = (%projectList, %{$pmAsset->getProjectList($user->userId)}); %projectList = map { @$_ } sort { $a->[1] cmp $b->[1] } map { [ $_, $pmProjectList{$_} ] } keys %pmProjectList; } } my $chooseLabel = $i18n->get("Choose One"); #Build Task Lists based on Project Ids tie my %taskList, "Tie::IxHash"; #Build task list javascript: my $counter = 0; my $js = "{\n"; foreach my $projectId (keys %projectList) { tie my %taskHash, "Tie::IxHash"; %taskHash = $db->buildHash("select taskId, taskName from TT_projectTasks where projectId=?",[$projectId]); if($pmAsset && scalar(keys %taskHash) == 0) { my $pmTaskRef = $pmAsset->getTaskList($projectId,$user->userId) || {}; %taskHash = %{$pmTaskRef}; } %taskHash = (""=>$chooseLabel,%taskHash); $taskList{$projectId} = \%taskHash; #Build JavaScript Hash $js .= ",\n" if($counter++ > 0); $js .= qq|"$projectId": {|; my $ind = 0; foreach my $taskId (keys %taskHash) { next if ($taskId eq ""); my $taskName = $taskHash{$taskId}; $js .= ",\n" if($ind++ > 0); $js .= qq| "$taskId":"$taskName"|; } $js .= q| }|; } $js .= "\n};\n"; $viewVar->{'project.task.array'} = $js; #Set default project for project list %projectList = (""=>$chooseLabel,%projectList); my $resourceIdFromForm = $form->get("resourceId"); my $resourceId = ($user->isInGroup($self->groupToManage) && $resourceIdFromForm)?$resourceIdFromForm:$user->userId; #Build Report Info my $report = $db->quickHashRef("select * from TT_report where resourceId=? and assetId=? and startDate=? and endDate=?",[$resourceId,$self->getId,$weekStart,$weekEnd]); my $reportId = $report->{reportId}; #$log->warn($reportId); #Add Report Stuff to form header $viewVar->{'form.header'} .= WebGUI::Form::hidden($session, { -name=>"reportId", -value=>$reportId || "new" }); $viewVar->{'form.header'} .= WebGUI::Form::hidden($session, { -name=>"startDate", -value=>$weekStart }); $viewVar->{'form.header'} .= WebGUI::Form::hidden($session, { -name=>"endDate", -value=>$weekEnd }); $viewVar->{'form.header'} .= WebGUI::Form::hidden($session, { -name=>"week", -value=>$week }); $viewVar->{'form.header'} .= WebGUI::Form::hidden($session, { -name=>"resourceId", -value=>$resourceId }); my $reportComplete = $report->{reportComplete}; $var->{'form.isComplete'} = WebGUI::Form::checkbox($session, { -name=>"isComplete", -value=>1, -checked=>$reportComplete }); #Build Entries Loop my $entries = $db->buildArrayRefOfHashRefs("select * from TT_timeEntry where reportId=? order by taskDate",[$reportId]); my $rowCount = 1; my @timeEntries = (); my $totalHours = 0; foreach my $entry (@{$entries}) { my $hash = {}; push (@timeEntries,$self->_buildRow($entry,$rowCount++,\%setDaysHash, \%projectList, \%taskList,$hash,$reportComplete)); $totalHours += $hash->{'entry.hours'}; } $var->{'report.isComplete'} = $reportComplete; $var->{'time.totalHours'} = $totalHours; #Seed time tracker with 10 empty rows and build the dummy row unless($reportComplete) { for( my $i = $rowCount; $i < ($rowCount + 10); $i++) { push(@timeEntries,$self->_buildRow(undef,$i,\%setDaysHash, \%projectList, \%taskList)); } $self->_buildRow(undef,"x",\%setDaysHash, \%projectList, \%taskList,$var); } $var->{'time.entry.loop'} = \@timeEntries; $viewVar->{'time.report.rows.total'} = (scalar(@timeEntries)+1); return $self->processTemplate($var,$self->timeRowTemplateId); } #------------------------------------------------------------------- =head2 _buildRow =cut sub _buildRow { my $self = shift; my ($session,$dt,$log,$form,$db,$user) = $self->getSessionVars("datetime","log","form","db","user"); my $i18n = WebGUI::International->new($session,'Asset_TimeTracking'); my $entry = $_[0] || {}; my $rowCount = $_[1]; my $daysInWeek = $_[2]; my $projectList = $_[3]; my $taskList = $_[4]; my $var = $_[5] || {}; my $reportComplete = $_[6] || 0; my $entryId = $entry->{entryId} || "new"; $var->{'row.id'} = "row_$rowCount"; #$var->{'row.id'} .= "_$entryId" if($entryId); my $projectId = $entry->{projectId}; my $taskId = $entry->{taskId}; #Task Entry Id $var->{'form.taskEntryId'} = WebGUI::Form::hidden($session,{ -name=>"taskEntryId_$rowCount", -value=>$entryId }); ##Handle cases when a user has been removed from a project. The projectList ##and taskList hash refs that have been passed in will not contain entries for ##their old project info #Entry Task tie my %taskHash, "Tie::IxHash"; if ($projectId) { if (! exists $projectList->{$projectId}) { my $projectName = $db->quickScalar('select projectName from TT_projectList where projectId=?',[$projectId]); $projectList->{$projectId} = $projectName; } if (! exists $taskList->{$projectId}) { %taskHash = $db->buildHash("select taskId, taskName from TT_projectTasks where projectId=?",[$projectId]); } else { %taskHash = %{$taskList->{$projectId}}; } #$log->warn($projectId); } my $chooseLabel = $i18n->get("Choose One"); %taskHash = (""=>$chooseLabel,%taskHash); #Entry Date $var->{'entry.hours'} = $entry->{hours}; if($reportComplete) { $var->{'form.date'} = $entry->{taskDate}; $var->{'form.project'} = $projectList->{$projectId}; $var->{'form.task'} = $taskHash{$entry->{taskId}}; $var->{'form.hours'} = $var->{'entry.hours'}; $var->{'form.comments'} = $entry->{comments}; } else { tie my %days, "Tie::IxHash"; %days = (""=>$chooseLabel, %{$daysInWeek}); $var->{'form.date'} = WebGUI::Form::selectBox($session,{ -name=>"taskDate_$rowCount", -value=>$entry->{taskDate}, -options=>\%days, -extras=>qq|class="date-select"| }); my $taskName = "taskId_$rowCount"; $taskId = "taskId_".$rowCount."_formId"; $var->{'form.project'} = WebGUI::Form::selectBox($session,{ -name=>"projectId_$rowCount", -options=>$projectList, -value=>$projectId, -extras=>qq|onchange="changeOptions(this,document.getElementById('$taskId'));" class="pt-select"| }); $var->{'form.task'} = WebGUI::Form::selectBox($session,{ -name=>$taskName, -options=>\%taskHash, -value=>$entry->{taskId}, -extras=>qq|class="pt-select"| }); #Entry Hours $var->{'form.hours'} = WebGUI::Form::float($session, { -name=>"hours_$rowCount", -value=>$var->{'entry.hours'}, -size=>5, -extras=>qq|onchange="recalcHours();"| }); #Entry Comments $var->{'form.comments'} = WebGUI::Form::text($session, { -name=>"comments_$rowCount", -value=>$entry->{comments}, -size=>40 }); } return $var; } __PACKAGE__->meta->make_immutable; 1;