Commit 2fb4886a by Harsh Shah

Finish Hotfix-20190411

parents 3835e65c 24281d25
package performa.search; package performa.search;
import oneit.objstore.BaseBusinessClass; import java.util.ArrayList;
import java.util.List;
import oneit.logging.LogLevel;
import oneit.logging.LogMgr;
import oneit.logging.LoggingArea;
import oneit.objstore.*;
import oneit.objstore.rdbms.filters.EqualsFilter; import oneit.objstore.rdbms.filters.EqualsFilter;
import performa.orm.Answer; import oneit.objstore.services.TransactionTask;
import performa.orm.AssessmentCriteriaAnswer; import oneit.utils.parsers.FieldException;
import performa.orm.CultureCriteriaAnswer; import performa.orm.*;
import performa.orm.JobApplication; import performa.orm.types.*;
public class SearchApplicant extends BaseSearchApplicant public class SearchApplicant extends BaseSearchApplicant
{ {
private static final long serialVersionUID = 0L; private static final long serialVersionUID = 0L;
public static final LoggingArea LOG = LoggingArea.createLoggingArea("SearchApplicant");
// This constructor should not be called // This constructor should not be called
public SearchApplicant () public SearchApplicant ()
...@@ -21,16 +27,27 @@ public class SearchApplicant extends BaseSearchApplicant ...@@ -21,16 +27,27 @@ public class SearchApplicant extends BaseSearchApplicant
@Override @Override
public BaseBusinessClass[] doSearch() public BaseBusinessClass[] doSearch()
{ {
JobApplication[] appResults = JobApplication.SearchByDetails() final List<JobApplication> appResults = new ArrayList<>();
.byName(getDetails())
.andJob(new EqualsFilter<>(getJob()))
.search(getTransaction());
// add to make sure to have any new ones try
if(getJob() != null) {
getTransaction().runInNewTX(new TransactionTask()
{
@Override
public void run(ObjectTransaction newObjTran) throws FieldException, StorageException
{ {
for(JobApplication app : appResults) JobApplication[] results = JobApplication.SearchByDetails()
.byName(getDetails())
.andJob(new EqualsFilter<>(getJob()))
.search(newObjTran);
for(JobApplication app : results)
{ {
ApplicationStatus appStatus = app.getApplicationStatus();
app = app.getInTransaction(getTransaction());
app.setApplicationStatus(appStatus);
Answer[] answers = Answer.SearchByAll().andCandidate(new EqualsFilter<>(app.getCandidate())).search(getTransaction()); Answer[] answers = Answer.SearchByAll().andCandidate(new EqualsFilter<>(app.getCandidate())).search(getTransaction());
for (Answer answer: answers) for (Answer answer: answers)
...@@ -53,9 +70,18 @@ public class SearchApplicant extends BaseSearchApplicant ...@@ -53,9 +70,18 @@ public class SearchApplicant extends BaseSearchApplicant
} }
getJob().addToJobApplications(app); getJob().addToJobApplications(app);
appResults.add(app);
} }
} }
return appResults; });
}
catch (FieldException | StorageException ex)
{
LogMgr.log(LOG, LogLevel.PROCESSING2 , ex, "Error when searching job applications");
}
return appResults.toArray(new JobApplication[0]);
} }
} }
\ No newline at end of file
...@@ -135,9 +135,7 @@ ...@@ -135,9 +135,7 @@
value="<%= job.getOccupation() != null ? job.getOccupation() : "Select the occupation classification"%>"></input> value="<%= job.getOccupation() != null ? job.getOccupation() : "Select the occupation classification"%>"></input>
<oneit:ormInput obj="<%= job %>" id="select-occupation-id" attributeName="OccupationId" type="hidden"/> --%> <oneit:ormInput obj="<%= job %>" id="select-occupation-id" attributeName="OccupationId" type="hidden"/> --%>
<oneit:ormInput obj="<%= job %>" attributeName="OccupationId" type="hidden"/>
<oneit:recalc mode="EscapeHTML" script="job.displayOccupation()" job="<%= job %>"/> <oneit:recalc mode="EscapeHTML" script="job.displayOccupation()" job="<%= job %>"/>
</div> </div>
</div> </div>
......
...@@ -387,9 +387,7 @@ ...@@ -387,9 +387,7 @@
value="<%= job.getOccupation() != null ? job.getOccupation() : "Select the occupation classification"%>"></input> value="<%= job.getOccupation() != null ? job.getOccupation() : "Select the occupation classification"%>"></input>
<oneit:ormInput obj="<%= job %>" id="select-occupation-id" attributeName="OccupationId" type="hidden"/> --%> <oneit:ormInput obj="<%= job %>" id="select-occupation-id" attributeName="OccupationId" type="hidden"/> --%>
<oneit:ormInput obj="<%= template %>" attributeName="OccupationId" type="hidden"/>
<oneit:recalc mode="EscapeHTML" script="template.displayOccupation()" template="<%= template %>"/> <oneit:recalc mode="EscapeHTML" script="template.displayOccupation()" template="<%= template %>"/>
</div> </div>
</div> </div>
......
...@@ -396,11 +396,7 @@ ...@@ -396,11 +396,7 @@
value="<%= job.getOccupation() != null ? job.getOccupation() : "Select the occupation classification"%>"></input> value="<%= job.getOccupation() != null ? job.getOccupation() : "Select the occupation classification"%>"></input>
<oneit:ormInput obj="<%= job %>" id="select-occupation-id" attributeName="OccupationId" type="hidden"/> --%> <oneit:ormInput obj="<%= job %>" id="select-occupation-id" attributeName="OccupationId" type="hidden"/> --%>
<oneit:ormInput obj="<%= job %>" attributeName="OccupationId" type="hidden"/>
<oneit:recalc mode="EscapeHTML" script="job.displayOccupation()" job="<%= job %>"/> <oneit:recalc mode="EscapeHTML" script="job.displayOccupation()" job="<%= job %>"/>
</div> </div>
</div> </div>
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment