Index: trunk/grails-app/conf/BootStrap.groovy
===================================================================
--- trunk/grails-app/conf/BootStrap.groovy	(revision 136)
+++ trunk/grails-app/conf/BootStrap.groovy	(revision 137)
@@ -358,5 +358,5 @@
 
         //Entry #1
-        entryInstance = new Entry(enteredBy: Person.get(6),
+        entryInstance = new Entry(enteredBy: Person.get(3),
                                                     task: Task.get(1),
                                                     entryType: EntryType.findByName("Fault"),
@@ -611,5 +611,5 @@
 
         //MaintenanceAction #1
-        maintenanceActionInstance = new MaintenanceAction(description: "Check all E-stops, active E-stop S1-S12 and ensure machine cannot run",
+        maintenanceActionInstance = new MaintenanceAction(description: "Check all E-stops, activate E-stops S1-S12 and ensure machine cannot run",
                                                                                                         procedureStepNumber: 1,
                                                                                                         maintenancePolicy: MaintenancePolicy.get(1),
Index: trunk/grails-app/controllers/TaskDetailedController.groovy
===================================================================
--- trunk/grails-app/controllers/TaskDetailedController.groovy	(revision 136)
+++ trunk/grails-app/controllers/TaskDetailedController.groovy	(revision 137)
@@ -31,4 +31,16 @@
 			params.order = "desc"
 			params.sort = "id"
+			
+			def entryWorkDoneList = Entry.withCriteria {
+																def entryType = EntryType.findByName("WorkDone")
+																eq("entryType", entryType)
+																eq("task", taskInstance)
+														}
+			
+			def entryFaultList = Entry.withCriteria {
+																def entryType = EntryType.findByName("Fault")
+																eq("entryType", entryType)
+																eq("task", taskInstance)
+														}
 
 			def subTaskInstanceList = Task.findAllByParentTask(taskInstance, params)
@@ -53,5 +65,7 @@
             }
 			
-            return [ taskInstance : taskInstance,
+            return [ taskInstance: taskInstance,
+							entryWorkDoneList: entryWorkDoneList,
+	   						entryFaultList: entryFaultList,
                             taskProcedureInstance: taskProcedureInstance,
                             taskProcedureExits: taskProcedureExits,
Index: trunk/grails-app/controllers/TaskRecurringScheduleDetailedController.groovy
===================================================================
--- trunk/grails-app/controllers/TaskRecurringScheduleDetailedController.groovy	(revision 136)
+++ trunk/grails-app/controllers/TaskRecurringScheduleDetailedController.groovy	(revision 137)
@@ -1,7 +1,10 @@
 import org.codehaus.groovy.grails.plugins.springsecurity.Secured
 import org.codehaus.groovy.runtime.TimeCategory
+import java.text.SimpleDateFormat
 
 class TaskRecurringScheduleDetailedController extends BaseController {
     
+	def dateUtilService
+	
     def index = { redirect(action:list,params:params) }
 
@@ -51,36 +54,61 @@
         }
         else {
-            return [ taskRecurringScheduleInstance : taskRecurringScheduleInstance ]
+            return [ taskRecurringScheduleInstance : taskRecurringScheduleInstance]
         }
     }
 
     def update = {
-        def taskRecurringScheduleInstance = TaskRecurringSchedule.get( params.id )
-        if(taskRecurringScheduleInstance) {
-            if(params.version) {
-                def version = params.version.toLong()
-                if(taskRecurringScheduleInstance.version > version) {
+		TaskRecurringSchedule.withTransaction { status ->
+        
+        	def taskRecurringScheduleInstance = TaskRecurringSchedule.get( params.id )
+			if(taskRecurringScheduleInstance) {
+				
+				if(params.version) {
+					def version = params.version.toLong()
+					if(taskRecurringScheduleInstance.version > version) {
+						taskRecurringScheduleInstance.errors.rejectValue("version", "taskRecurringSchedule.optimistic.locking.failure", "Another user has updated this TaskRecurringSchedule while you were editing.")
+						render(view:'edit',model:[taskRecurringScheduleInstance:taskRecurringScheduleInstance])
+						return
+					}
+				}
+					
+				Date originalDate = taskRecurringScheduleInstance.startDate
+				taskRecurringScheduleInstance.properties = params  // Domain object is now 'dirty'.
+				Date newDate = taskRecurringScheduleInstance.startDate
+	
+				// If user changes startDate then ensure it is in the future, otherwise it's ok to keep the original date.
+				if(originalDate.getTime() != newDate.getTime())
+				{
+					if(newDate < dateUtilService.getToday()) 
+					{
+						status.setRollbackOnly()  // Only allow the transaction to Rollback, preventing flush due to 'dirty'.
+						taskRecurringScheduleInstance.errors.rejectValue("startDate", "taskRecurring.startDate.NotInTheFuture")
+						render(view:'edit',model:[taskRecurringScheduleInstance:taskRecurringScheduleInstance])
+						return
+					}
+				}
+					
+				taskRecurringScheduleInstance.nextTargetStartDate = taskRecurringScheduleInstance.startDate
+				taskRecurringScheduleInstance.setNextGenerationDate() 
+				taskRecurringScheduleInstance.setNextTargetCompletionDate()
                     
-                    taskRecurringScheduleInstance.errors.rejectValue("version", "taskRecurringSchedule.optimistic.locking.failure", "Another user has updated this TaskRecurringSchedule while you were editing.")
-                    render(view:'edit',model:[taskRecurringScheduleInstance:taskRecurringScheduleInstance])
-                    return
-                }
-            }
-//             taskRecurringScheduleInstance.properties = params
-            setUpdateProperties()
-                    
-            if(!taskRecurringScheduleInstance.hasErrors() && taskRecurringScheduleInstance.save()) {
-                flash.message = "TaskRecurringSchedule ${params.id} updated"
-                redirect(action:show,id:taskRecurringScheduleInstance.id)
-            }
-            else {
-                render(view:'edit',model:[taskRecurringScheduleInstance:taskRecurringScheduleInstance])
-            }
-        }
-        else {
-            flash.message = "TaskRecurringSchedule not found with id ${params.id}"
-            redirect(action:edit,id:params.id)
-        }
-    }
+				if(!taskRecurringScheduleInstance.hasErrors() && taskRecurringScheduleInstance.save()) 
+				{
+					flash.message = "TaskRecurringSchedule ${params.id} updated"
+					redirect(action:show,id:taskRecurringScheduleInstance.id)
+				}
+				else 
+				{
+					render(view:'edit',model:[taskRecurringScheduleInstance:taskRecurringScheduleInstance])
+				}
+			}
+			else 
+			{
+				flash.message = "TaskRecurringSchedule not found with id ${params.id}"
+				redirect(action:edit,id:params.id)
+			}
+			
+		} // end withTransaction			
+	} // end update()
 	
     def create = {
@@ -95,5 +123,5 @@
             redirect(controller:"taskDetailed", action:"list")
         }
-    }
+    } // end create()
 
     def save = {
@@ -106,4 +134,8 @@
 		}
 		else {
+			
+			if(taskRecurringScheduleInstance.startDate < dateUtilService.getToday()) {
+				taskRecurringScheduleInstance.errors.rejectValue("startDate", "taskRecurring.startDate.NotInTheFuture")
+			}
 			
 			if(!taskRecurringScheduleInstance.hasErrors() && taskRecurringScheduleInstance.save()) {
@@ -125,48 +157,5 @@
 		}
 
-    }
-                
-    private setUpdateProperties() {
-        def originalStartDate = taskRecurringScheduleInstance.startDate
-        
-        if(taskRecurringScheduleInstance.startDate == params.startDate) {
-            taskRecurringScheduleInstance.properties = params
-        }
-        else {
-            taskRecurringScheduleInstance.properties = params
-            taskRecurringScheduleInstance.nextTargetStartDate = params.startDate
-        }
-        
-    }
+    } // end save()
 
-/*    
-    private Date calculateNextDueDate(recurEvery, period, startDate) {
-        def nextDue = new Date()
-        
-        switch (period) {
-            case "Day(s)":
-                use(TimeCategory) {
-                    nextDue = startDate + recurEvery.days
-                }
-                return nextDue
-            case "Week(s)":
-                use(TimeCategory) {
-                    nextDue = startDate + recurEvery.weeks
-                }
-                return nextDue
-            case "Month(s)":
-                use(TimeCategory) {
-                    nextDue = startDate + recurEvery.months
-                }
-                return nextDue
-            case "Year(s)":
-                use(TimeCategory) {
-                    nextDue = startDate + recurEvery.years
-                }
-                return nextDue
-            default:
-                return nextDue
-        }
-        
-    }*/
 }
Index: trunk/grails-app/domain/TaskRecurringSchedule.groovy
===================================================================
--- trunk/grails-app/domain/TaskRecurringSchedule.groovy	(revision 136)
+++ trunk/grails-app/domain/TaskRecurringSchedule.groovy	(revision 137)
@@ -23,6 +23,5 @@
 
     static constraints = {
-// 		startDate(validator: {return (it > new Date())})
-        recurEvery(min:0, max:365)
+        recurEvery(min:1, max:365)
         taskDuration(min:0, max:365)
         generateAhead(min:0, max:365)
@@ -35,12 +34,14 @@
     }
     
-    //As of Grails 1.1 this does not fire/pass before validation.
-    //But setting defaults above and placing this code here in the hope that this will be fixed in future versions.
+    // As of Grails 1.1.1 this does not fire/pass before validation.
+    // But setting some defaults above to pass validation and placing this code here 
+	// in the hope that this will be fixed in future versions.
     def beforeInsert = {
-        def now = new Date()
-        
         nextTargetStartDate = startDate
-        
-        //nextGenerationDate
+        setNextGenerationDate()
+        setNextTargetCompletionDate()
+    }
+    
+    public void setNextGenerationDate() {
         switch (generateAheadPeriod.period) {
             case "Day(s)":
@@ -67,8 +68,9 @@
                 break
         }
-        
+        def now = new Date()
         if( nextGenerationDate < now) {nextGenerationDate = now}
-        
-        //nextTargetCompletionDate
+    }
+    
+    public void setNextTargetCompletionDate() {
         switch (taskDurationPeriod.period) {
             case "Day(s)":
@@ -92,10 +94,9 @@
                 }
                 break
-        default:
+            default:
                 break
         }
-        
     }
-
+    
 }
 
Index: trunk/grails-app/i18n/messages.properties
===================================================================
--- trunk/grails-app/i18n/messages.properties	(revision 136)
+++ trunk/grails-app/i18n/messages.properties	(revision 137)
@@ -18,4 +18,8 @@
 task.leadPerson=Lead Person
 task.leadPerson.help=The primay contact person.
+    
+taskRecurring.startDate.NotInTheFuture=Please select a start date that is not in the past, or use original date.
+taskRecurring.startDate=Start Date
+taskRecurring.startDate.help=The tartget start date for the first auto generated subTask.
 
 default.doesnt.match.message=Property [{0}] of class [{1}] with value [{2}] does not match the required pattern [{3}]
Index: trunk/grails-app/jobs/TaskRecurringScheduleJob.groovy
===================================================================
--- trunk/grails-app/jobs/TaskRecurringScheduleJob.groovy	(revision 136)
+++ trunk/grails-app/jobs/TaskRecurringScheduleJob.groovy	(revision 137)
@@ -1,10 +1,10 @@
 
 class TaskRecurringScheduleJob {/*
-//     def timeout = 5000 // execute job once in 5 seconds
-    def timeout = 60000
+    def timeout = 1000 // execute job once in 1 seconds
+//     def timeout = 60000
 
     def execute() {
-//         println "TaskRecurringScheduleJob: tick"
-//         println "TaskRecurringScheduleJob: tock"
+        println "TaskRecurringScheduleJob: tick"
+        println "TaskRecurringScheduleJob: tock"/*
         def recurringScheduleInstanceList = RecurringSchedule.list()
         def now = new Date()
Index: trunk/grails-app/services/DateUtilService.groovy
===================================================================
--- trunk/grails-app/services/DateUtilService.groovy	(revision 137)
+++ trunk/grails-app/services/DateUtilService.groovy	(revision 137)
@@ -0,0 +1,24 @@
+class DateUtilService {
+
+    boolean transactional = false
+    static scope = "request"
+	
+	public static Date getToday() {
+        return setMidnight(new Date())
+    }
+
+    public static Date getTomorrow() {
+        return (getToday() + 1) as Date
+    }
+
+    public static Date setMidnight(Date theDate) {
+        Calendar cal = Calendar.getInstance()
+        cal.setTime(theDate)
+        cal.set(Calendar.HOUR_OF_DAY, 0)
+        cal.set(Calendar.MINUTE, 0)
+        cal.set(Calendar.SECOND, 0)
+        cal.set(Calendar.MILLISECOND, 0)
+        cal.getTime()
+    }
+
+}
Index: trunk/grails-app/services/TaskService.groovy
===================================================================
--- trunk/grails-app/services/TaskService.groovy	(revision 137)
+++ trunk/grails-app/services/TaskService.groovy	(revision 137)
@@ -0,0 +1,13 @@
+class TaskService {
+
+    boolean transactional = true
+    static scope = "request"
+
+	def dateUtilService
+
+    def taskDates(taskInstance, params) {
+		println "yes"
+		
+    }
+
+}
Index: trunk/grails-app/views/entryDetailed/edit.gsp
===================================================================
--- trunk/grails-app/views/entryDetailed/edit.gsp	(revision 136)
+++ trunk/grails-app/views/entryDetailed/edit.gsp	(revision 137)
@@ -62,9 +62,9 @@
 
                                 <td valign="top" class="value">
-                                    <input class="duration ${hasErrors(bean:entryInstance,field:'durationHour','errors')}" 
+                                    <input class="time ${hasErrors(bean:entryInstance,field:'durationHour','errors')}" 
                                         type="text" id="durationHour" name="durationHour" 
                                         value="${fieldValue(bean:entryInstance,field:'durationHour')}" />
                                     :
-                                    <input class="duration ${hasErrors(bean:entryInstance,field:'durationMinute','errors')}" 
+                                    <input class="time ${hasErrors(bean:entryInstance,field:'durationMinute','errors')}" 
                                         type="text" id="durationMinute" name="durationMinute" 
                                         value="${fieldValue(bean:entryInstance,field:'durationMinute')}" />
Index: trunk/grails-app/views/taskDetailed/show.gsp
===================================================================
--- trunk/grails-app/views/taskDetailed/show.gsp	(revision 136)
+++ trunk/grails-app/views/taskDetailed/show.gsp	(revision 137)
@@ -158,5 +158,4 @@
                         </div>
             
-            
                         <div class="buttons">
                             <g:form>
@@ -186,6 +185,5 @@
                                 </thead>
                                 <tbody>
-                                <g:each in="${taskInstance?.entries}" status="i" var="entry">
-                                    <g:if test="${entry.entryType == EntryType.findByName('Fault')}">
+                                <g:each in="${entryFaultList}" status="i" var="entry">
                                         <tr class="${(i % 2) == 0 ? 'clickableOdd' : 'clickableEven'}" onclick='window.location = "${request.getContextPath()}/entryDetailed/edit/${entry.id}"'/>
                                         
@@ -202,5 +200,4 @@
             
                                         </tr>
-                                    </g:if>
                                 </g:each>
                                 </tbody>
@@ -227,6 +224,5 @@
                                 </thead>
                                 <tbody>
-                                <g:each in="${taskInstance?.entries}" status="i" var="entry">
-                                    <g:if test="${entry.entryType == EntryType.findByName('WorkDone')}">
+                                <g:each in="${entryWorkDoneList}" status="i" var="entry">
                                         <tr class="${(i % 2) == 0 ? 'clickableOdd' : 'clickableEven'}" onclick='window.location = "${request.getContextPath()}/entryDetailed/edit/${entry.id}"'/>
             
@@ -243,5 +239,4 @@
             
                                         </tr>
-                                    </g:if>
                                 </g:each>
                                 </tbody>
@@ -261,4 +256,6 @@
                     </richui:tabContent>
 <!-- End Task tab -->
+
+
 
 <!-- Start Task Procedure tab-->
@@ -398,4 +395,23 @@
 												<g:formatDate date="${taskRecurringScheduleInstance.startDate}" format="EEE, dd MMM yyyy"/>
 											</td>
+                            
+                                        </tr>
+                                    
+                                        <tr class="prop">
+                                            <td valign="top" class="name">Task Duration:</td>
+                                            
+                                            <td valign="top" class="value">
+                                                ${taskRecurringScheduleInstance?.taskDuration} ${taskRecurringScheduleInstance?.taskDurationPeriod}
+                                            </td>
+                                        </tr>
+                    
+                                        <tr class="prop">
+                                            <td valign="top" class="name">Generate Ahead:</td>
+                                            
+                                            <td valign="top" class="value">
+                                                ${taskRecurringScheduleInstance?.generateAhead} ${taskRecurringScheduleInstance?.generateAheadPeriod}
+                                            </td>
+                                            
+                                        </tr>
 											
 										</tr>
@@ -407,21 +423,36 @@
 											
 										</tr>
+                                        
+                                    </tbody>
+                                </table>
+                
+                                <table>
+                                    <tbody>
                         
 										<tr class="prop">
-											<td></td>
-										</tr>
-										
-										<tr class="prop">
-											<td></td>
-										</tr>
-				
-										<tr class="prop">
-											<td valign="top" class="name">Next Due Date:</td>   
+											<td valign="top" class="name">Next Target Start Date:</td>   
 											                         
 											<td valign="top" class="value">
-												<g:formatDate date="${taskRecurringScheduleInstance.nextDueDate}" format="EEE, dd MMM yyyy"/>
+												<g:formatDate date="${taskRecurringScheduleInstance.nextTargetStartDate}" format="EEE, dd MMM yyyy"/>
 											</td>
 											
 										</tr>
+                
+                                        <tr class="prop">
+                                            <td valign="top" class="name">Next Target Completion Date:</td>   
+                                                                     
+                                            <td valign="top" class="value">
+                                                <g:formatDate date="${taskRecurringScheduleInstance.nextTargetCompletionDate}" format="EEE, dd MMM yyyy"/>
+                                            </td>
+                                            
+                                        </tr>
+                        
+                                        <tr class="prop">
+                                            <td valign="top" class="name">Next Generation Date:</td>
+                                            
+                                            <td valign="top" class="value">
+                                                <g:formatDate date="${taskRecurringScheduleInstance.nextGenerationDate}" format="EEE, dd MMM yyyy"/>
+                                            </td>
+                                        </tr>
 				
 										<tr class="prop">
Index: trunk/grails-app/views/taskRecurringSchedule/create.gsp
===================================================================
--- trunk/grails-app/views/taskRecurringSchedule/create.gsp	(revision 136)
+++ trunk/grails-app/views/taskRecurringSchedule/create.gsp	(revision 137)
@@ -47,4 +47,22 @@
                             <tr class="prop">
                                 <td valign="top" class="name">
+                                    <label for="generateAhead">Generate Ahead:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:taskRecurringScheduleInstance,field:'generateAhead','errors')}">
+                                    <input type="text" id="generateAhead" name="generateAhead" value="${fieldValue(bean:taskRecurringScheduleInstance,field:'generateAhead')}" />
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="generateAheadPeriod">Generate Ahead Period:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:taskRecurringScheduleInstance,field:'generateAheadPeriod','errors')}">
+                                    <g:select optionKey="id" from="${Period.list()}" name="generateAheadPeriod.id" value="${taskRecurringScheduleInstance?.generateAheadPeriod?.id}" ></g:select>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
                                     <label for="isEnabled">Is Enabled:</label>
                                 </td>
@@ -65,8 +83,8 @@
                             <tr class="prop">
                                 <td valign="top" class="name">
-                                    <label for="period">Period:</label>
+                                    <label for="nextGenerationDate">Next Generation Date:</label>
                                 </td>
-                                <td valign="top" class="value ${hasErrors(bean:taskRecurringScheduleInstance,field:'period','errors')}">
-                                    <g:select optionKey="id" from="${Period.list()}" name="period.id" value="${taskRecurringScheduleInstance?.period?.id}" ></g:select>
+                                <td valign="top" class="value ${hasErrors(bean:taskRecurringScheduleInstance,field:'nextGenerationDate','errors')}">
+                                    <g:datePicker name="nextGenerationDate" value="${taskRecurringScheduleInstance?.nextGenerationDate}" ></g:datePicker>
                                 </td>
                             </tr> 
@@ -78,4 +96,13 @@
                                 <td valign="top" class="value ${hasErrors(bean:taskRecurringScheduleInstance,field:'recurEvery','errors')}">
                                     <input type="text" id="recurEvery" name="recurEvery" value="${fieldValue(bean:taskRecurringScheduleInstance,field:'recurEvery')}" />
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="recurPeriod">Recur Period:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:taskRecurringScheduleInstance,field:'recurPeriod','errors')}">
+                                    <g:select optionKey="id" from="${Period.list()}" name="recurPeriod.id" value="${taskRecurringScheduleInstance?.recurPeriod?.id}" ></g:select>
                                 </td>
                             </tr> 
Index: trunk/grails-app/views/taskRecurringSchedule/edit.gsp
===================================================================
--- trunk/grails-app/views/taskRecurringSchedule/edit.gsp	(revision 136)
+++ trunk/grails-app/views/taskRecurringSchedule/edit.gsp	(revision 137)
@@ -50,4 +50,22 @@
                             <tr class="prop">
                                 <td valign="top" class="name">
+                                    <label for="generateAhead">Generate Ahead:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:taskRecurringScheduleInstance,field:'generateAhead','errors')}">
+                                    <input type="text" id="generateAhead" name="generateAhead" value="${fieldValue(bean:taskRecurringScheduleInstance,field:'generateAhead')}" />
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="generateAheadPeriod">Generate Ahead Period:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:taskRecurringScheduleInstance,field:'generateAheadPeriod','errors')}">
+                                    <g:select optionKey="id" from="${Period.list()}" name="generateAheadPeriod.id" value="${taskRecurringScheduleInstance?.generateAheadPeriod?.id}" ></g:select>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
                                     <label for="isEnabled">Is Enabled:</label>
                                 </td>
@@ -68,8 +86,8 @@
                             <tr class="prop">
                                 <td valign="top" class="name">
-                                    <label for="period">Period:</label>
+                                    <label for="nextGenerationDate">Next Generation Date:</label>
                                 </td>
-                                <td valign="top" class="value ${hasErrors(bean:taskRecurringScheduleInstance,field:'period','errors')}">
-                                    <g:select optionKey="id" from="${Period.list()}" name="period.id" value="${taskRecurringScheduleInstance?.period?.id}" ></g:select>
+                                <td valign="top" class="value ${hasErrors(bean:taskRecurringScheduleInstance,field:'nextGenerationDate','errors')}">
+                                    <g:datePicker name="nextGenerationDate" value="${taskRecurringScheduleInstance?.nextGenerationDate}" ></g:datePicker>
                                 </td>
                             </tr> 
@@ -81,4 +99,13 @@
                                 <td valign="top" class="value ${hasErrors(bean:taskRecurringScheduleInstance,field:'recurEvery','errors')}">
                                     <input type="text" id="recurEvery" name="recurEvery" value="${fieldValue(bean:taskRecurringScheduleInstance,field:'recurEvery')}" />
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="recurPeriod">Recur Period:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:taskRecurringScheduleInstance,field:'recurPeriod','errors')}">
+                                    <g:select optionKey="id" from="${Period.list()}" name="recurPeriod.id" value="${taskRecurringScheduleInstance?.recurPeriod?.id}" ></g:select>
                                 </td>
                             </tr> 
Index: trunk/grails-app/views/taskRecurringSchedule/list.gsp
===================================================================
--- trunk/grails-app/views/taskRecurringSchedule/list.gsp	(revision 136)
+++ trunk/grails-app/views/taskRecurringSchedule/list.gsp	(revision 137)
@@ -28,10 +28,10 @@
                    	        <th>Last Generated Sub Task</th>
                    	    
+                   	        <g:sortableColumn property="generateAhead" title="Generate Ahead" />
+                        
+                   	        <th>Generate Ahead Period</th>
+                   	    
                    	        <g:sortableColumn property="isEnabled" title="Is Enabled" />
                         
-                   	        <g:sortableColumn property="nextDueDate" title="Next Due Date" />
-                        
-                   	        <th>Period</th>
-                   	    
                         </tr>
                     </thead>
@@ -46,9 +46,9 @@
                             <td>${fieldValue(bean:taskRecurringScheduleInstance, field:'lastGeneratedSubTask')}</td>
                         
+                            <td>${fieldValue(bean:taskRecurringScheduleInstance, field:'generateAhead')}</td>
+                        
+                            <td>${fieldValue(bean:taskRecurringScheduleInstance, field:'generateAheadPeriod')}</td>
+                        
                             <td>${fieldValue(bean:taskRecurringScheduleInstance, field:'isEnabled')}</td>
-                        
-                            <td>${fieldValue(bean:taskRecurringScheduleInstance, field:'nextDueDate')}</td>
-                        
-                            <td>${fieldValue(bean:taskRecurringScheduleInstance, field:'period')}</td>
                         
                         </tr>
Index: trunk/grails-app/views/taskRecurringSchedule/show.gsp
===================================================================
--- trunk/grails-app/views/taskRecurringSchedule/show.gsp	(revision 136)
+++ trunk/grails-app/views/taskRecurringSchedule/show.gsp	(revision 137)
@@ -45,4 +45,18 @@
                     
                         <tr class="prop">
+                            <td valign="top" class="name">Generate Ahead:</td>
+                            
+                            <td valign="top" class="value">${fieldValue(bean:taskRecurringScheduleInstance, field:'generateAhead')}</td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
+                            <td valign="top" class="name">Generate Ahead Period:</td>
+                            
+                            <td valign="top" class="value"><g:link controller="period" action="show" id="${taskRecurringScheduleInstance?.generateAheadPeriod?.id}">${taskRecurringScheduleInstance?.generateAheadPeriod?.encodeAsHTML()}</g:link></td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
                             <td valign="top" class="name">Is Enabled:</td>
                             
@@ -59,7 +73,7 @@
                     
                         <tr class="prop">
-                            <td valign="top" class="name">Period:</td>
+                            <td valign="top" class="name">Next Generation Date:</td>
                             
-                            <td valign="top" class="value"><g:link controller="period" action="show" id="${taskRecurringScheduleInstance?.period?.id}">${taskRecurringScheduleInstance?.period?.encodeAsHTML()}</g:link></td>
+                            <td valign="top" class="value">${fieldValue(bean:taskRecurringScheduleInstance, field:'nextGenerationDate')}</td>
                             
                         </tr>
@@ -69,4 +83,11 @@
                             
                             <td valign="top" class="value">${fieldValue(bean:taskRecurringScheduleInstance, field:'recurEvery')}</td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
+                            <td valign="top" class="name">Recur Period:</td>
+                            
+                            <td valign="top" class="value"><g:link controller="period" action="show" id="${taskRecurringScheduleInstance?.recurPeriod?.id}">${taskRecurringScheduleInstance?.recurPeriod?.encodeAsHTML()}</g:link></td>
                             
                         </tr>
Index: trunk/grails-app/views/taskRecurringScheduleDetailed/create.gsp
===================================================================
--- trunk/grails-app/views/taskRecurringScheduleDetailed/create.gsp	(revision 136)
+++ trunk/grails-app/views/taskRecurringScheduleDetailed/create.gsp	(revision 137)
@@ -53,5 +53,27 @@
                                     <input type="text" class="time ${hasErrors(bean:taskRecurringScheduleInstance,field:'recurEvery','errors')}"
  										id="recurEvery" name="recurEvery" value="${fieldValue(bean:taskRecurringScheduleInstance,field:'recurEvery')}" />
-                                    <g:select optionKey="id" from="${Period.list()}" name="period.id" value="${taskRecurringScheduleInstance?.period?.id}" ></g:select>
+                                    <g:select optionKey="id" from="${Period.list()}" name="recurPeriod.id" value="${taskRecurringScheduleInstance?.recurPeriod?.id}" ></g:select>
+                                </td>
+                            </tr>   
+                      
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="recurEvery">Task Duration:</label>
+                                </td>
+                                <td valign="top" class="value" >
+                                    <input type="text" class="time ${hasErrors(bean:taskRecurringScheduleInstance,field:'taskDuration','errors')}"
+                                        id="taskDuration" name="taskDuration" value="${fieldValue(bean:taskRecurringScheduleInstance,field:'taskDuration')}" />
+                                    <g:select optionKey="id" from="${Period.list()}" name="taskDurationPeriod.id" value="${taskRecurringScheduleInstance?.taskDurationPeriod?.id}" ></g:select>
+                                </td>
+                            </tr>   
+                      
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="recurEvery">Generate Ahead:</label>
+                                </td>
+                                <td valign="top" class="value" >
+                                    <input type="text" class="time ${hasErrors(bean:taskRecurringScheduleInstance,field:'generateAhead','errors')}"
+                                        id="generateAhead" name="generateAhead" value="${fieldValue(bean:taskRecurringScheduleInstance,field:'generateAhead')}" />
+                                    <g:select optionKey="id" from="${Period.list()}" name="generateAheadPeriod.id" value="${taskRecurringScheduleInstance?.generateAheadPeriod?.id}" ></g:select>
                                 </td>
                             </tr>
Index: trunk/grails-app/views/taskRecurringScheduleDetailed/edit.gsp
===================================================================
--- trunk/grails-app/views/taskRecurringScheduleDetailed/edit.gsp	(revision 136)
+++ trunk/grails-app/views/taskRecurringScheduleDetailed/edit.gsp	(revision 137)
@@ -55,7 +55,29 @@
                                     <input type="text" class="time ${hasErrors(bean:taskRecurringScheduleInstance,field:'recurEvery','errors')}"
  										id="recurEvery" name="recurEvery" value="${fieldValue(bean:taskRecurringScheduleInstance,field:'recurEvery')}" />
-                                    <g:select optionKey="id" from="${Period.list()}" name="period.id" value="${taskRecurringScheduleInstance?.period?.id}" ></g:select>
+                                    <g:select optionKey="id" from="${Period.list()}" name="recurPeriod.id" value="${taskRecurringScheduleInstance?.recurPeriod?.id}" ></g:select>
                                 </td>
-                            </tr> 
+                            </tr>   
+                      
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="recurEvery">Task Duration:</label>
+                                </td>
+                                <td valign="top" class="value" >
+                                    <input type="text" class="time ${hasErrors(bean:taskRecurringScheduleInstance,field:'taskDuration','errors')}"
+                                        id="taskDuration" name="taskDuration" value="${fieldValue(bean:taskRecurringScheduleInstance,field:'taskDuration')}" />
+                                    <g:select optionKey="id" from="${Period.list()}" name="taskDurationPeriod.id" value="${taskRecurringScheduleInstance?.taskDurationPeriod?.id}" ></g:select>
+                                </td>
+                            </tr>       
+                      
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="recurEvery">Generate Ahead:</label>
+                                </td>
+                                <td valign="top" class="value" >
+                                    <input type="text" class="time ${hasErrors(bean:taskRecurringScheduleInstance,field:'generateAhead','errors')}"
+                                        id="generateAhead" name="generateAhead" value="${fieldValue(bean:taskRecurringScheduleInstance,field:'generateAhead')}" />
+                                    <g:select optionKey="id" from="${Period.list()}" name="generateAheadPeriod.id" value="${taskRecurringScheduleInstance?.generateAheadPeriod?.id}" ></g:select>
+                                </td>
+                            </tr>
                         
                             <tr class="prop">
@@ -73,5 +95,5 @@
                 <div class="buttons">
                     <span class="button"><g:actionSubmit class="save" value="Update" /></span>
-                    <span class="button"><g:actionSubmit class="delete" onclick="return confirm('Are you sure?');" value="Delete" /></span>
+<!--                     <span class="button"><g:actionSubmit class="delete" onclick="return confirm('Are you sure?');" value="Delete" /></span> -->
                 </div>
             </g:form>
Index: trunk/grails-app/views/taskRecurringScheduleDetailed/list.gsp
===================================================================
--- trunk/grails-app/views/taskRecurringScheduleDetailed/list.gsp	(revision 136)
+++ trunk/grails-app/views/taskRecurringScheduleDetailed/list.gsp	(revision 137)
@@ -28,5 +28,5 @@
                    	        <g:sortableColumn property="recurEvery" title="Recur Every" />
                    	        
-                   	        <g:sortableColumn property="period" title="Period" />
+                   	        <g:sortableColumn property="recurPeriod" title="Recur Period" />
                    	        
                    	        <g:sortableColumn property="isEnabled" title="Is Enabled" />
@@ -47,5 +47,5 @@
                             <td>${fieldValue(bean:taskRecurringScheduleInstance, field:'recurEvery')}</td>
                         
-                            <td>${fieldValue(bean:taskRecurringScheduleInstance, field:'period')}</td>
+                            <td>${fieldValue(bean:taskRecurringScheduleInstance, field:'recurPeriod')}</td>
                         
                             <td>${fieldValue(bean:taskRecurringScheduleInstance, field:'isEnabled')}</td>
Index: trunk/grails-app/views/taskRecurringScheduleDetailed/show.gsp
===================================================================
--- trunk/grails-app/views/taskRecurringScheduleDetailed/show.gsp	(revision 136)
+++ trunk/grails-app/views/taskRecurringScheduleDetailed/show.gsp	(revision 137)
@@ -39,8 +39,16 @@
                     
                         <tr class="prop">
+                            <td valign="top" class="name">Start Date:</td>
+                            
+                            <td valign="top" class="value">
+                                <g:formatDate date="${taskRecurringScheduleInstance.startDate}" format="EEE, dd MMM yyyy"/>
+                            </td>
+                        </tr>
+                    
+                        <tr class="prop">
                             <td valign="top" class="name">Recur Every:</td>
                             
                             <td valign="top" class="value">
-								${taskRecurringScheduleInstance?.recurEvery} ${taskRecurringScheduleInstance?.period}
+								${taskRecurringScheduleInstance?.recurEvery} ${taskRecurringScheduleInstance?.recurPeriod}
 							</td>
                             
@@ -48,9 +56,18 @@
                     
                         <tr class="prop">
-                            <td valign="top" class="name">Start Date:</td>
+                            <td valign="top" class="name">Task Duration:</td>
                             
-							<td valign="top" class="value">
-								<g:formatDate date="${taskRecurringScheduleInstance.startDate}" format="EEE, dd MMM yyyy"/>
-							</td>
+                            <td valign="top" class="value">
+                                ${taskRecurringScheduleInstance?.taskDuration} ${taskRecurringScheduleInstance?.taskDurationPeriod}
+                            </td>
+                        </tr>
+                    
+                        <tr class="prop">
+                            <td valign="top" class="name">Generate Ahead:</td>
+                            
+                            <td valign="top" class="value">
+                                ${taskRecurringScheduleInstance?.generateAhead} ${taskRecurringScheduleInstance?.generateAheadPeriod}
+                            </td>
+                            
                         </tr>
                     
@@ -61,20 +78,33 @@
                             
                         </tr>
+                    </tbody>
+                </table>
+                
+                <table>
+                    <tbody>
+                        <tr class="prop">
+                            <td valign="top" class="name">Next Target Start Date:</td>
+                            
+                            <td valign="top" class="value">
+								<g:formatDate date="${taskRecurringScheduleInstance.nextTargetStartDate}" format="EEE, dd MMM yyyy"/>
+							</td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
+                            <td valign="top" class="name">Next Target Completion Date:</td>
+                            
+                            <td valign="top" class="value">
+                                <g:formatDate date="${taskRecurringScheduleInstance.nextTargetCompletionDate}" format="EEE, dd MMM yyyy"/>
+                            </td>
+                            
+                        </tr>
                         
                         <tr class="prop">
-                    		<td></td>
-						</tr>
-                        
-                        <tr class="prop">
-                    		<td></td>
-						</tr>
-                    
-                        <tr class="prop">
-                            <td valign="top" class="name">Next Due Date:</td>
+                            <td valign="top" class="name">Next Generation Date:</td>
                             
                             <td valign="top" class="value">
-								<g:formatDate date="${taskRecurringScheduleInstance.nextDueDate}" format="EEE, dd MMM yyyy"/>
-							</td>
-                            
+                                <g:formatDate date="${taskRecurringScheduleInstance.nextGenerationDate}" format="EEE, dd MMM yyyy"/>
+                            </td>
                         </tr>
 						
@@ -105,5 +135,5 @@
                     <input type="hidden" name="id" value="${taskRecurringScheduleInstance?.id}" />
                     <span class="button"><g:actionSubmit class="edit" value="Edit" /></span>
-                    <span class="button"><g:actionSubmit class="delete" onclick="return confirm('Are you sure?');" value="Delete" /></span>
+<!--                     <span class="button"><g:actionSubmit class="delete" onclick="return confirm('Are you sure?');" value="Delete" /></span> -->
                 </g:form>
             </div>
