Index: /trunk/grails-app/controllers/TaskBudgetStatusController.groovy
===================================================================
--- /trunk/grails-app/controllers/TaskBudgetStatusController.groovy	(revision 252)
+++ /trunk/grails-app/controllers/TaskBudgetStatusController.groovy	(revision 252)
@@ -0,0 +1,99 @@
+import org.codehaus.groovy.grails.plugins.springsecurity.Secured
+
+class TaskBudgetStatusController extends BaseAppAdminController {
+    
+    def index = { redirect(action:list,params:params) }
+
+    // the delete, save and update actions only accept POST requests
+    static allowedMethods = [delete:'POST', save:'POST', update:'POST']
+
+    def list = {
+        params.max = Math.min( params.max ? params.max.toInteger() : 10,  100)
+        [ taskBudgetStatusInstanceList: TaskBudgetStatus.list( params ), taskBudgetStatusInstanceTotal: TaskBudgetStatus.count() ]
+    }
+
+    def show = {
+        def taskBudgetStatusInstance = TaskBudgetStatus.get( params.id )
+
+        if(!taskBudgetStatusInstance) {
+            flash.message = "TaskBudgetStatus not found with id ${params.id}"
+            redirect(action:list)
+        }
+        else { return [ taskBudgetStatusInstance : taskBudgetStatusInstance ] }
+    }
+
+    def delete = {
+        def taskBudgetStatusInstance = TaskBudgetStatus.get( params.id )
+        if(taskBudgetStatusInstance) {
+            try {
+                taskBudgetStatusInstance.delete(flush:true)
+                flash.message = "TaskBudgetStatus ${params.id} deleted"
+                redirect(action:list)
+            }
+            catch(org.springframework.dao.DataIntegrityViolationException e) {
+                flash.message = "TaskBudgetStatus ${params.id} could not be deleted"
+                redirect(action:show,id:params.id)
+            }
+        }
+        else {
+            flash.message = "TaskBudgetStatus not found with id ${params.id}"
+            redirect(action:list)
+        }
+    }
+
+    def edit = {
+        def taskBudgetStatusInstance = TaskBudgetStatus.get( params.id )
+
+        if(!taskBudgetStatusInstance) {
+            flash.message = "TaskBudgetStatus not found with id ${params.id}"
+            redirect(action:list)
+        }
+        else {
+            return [ taskBudgetStatusInstance : taskBudgetStatusInstance ]
+        }
+    }
+
+    def update = {
+        def taskBudgetStatusInstance = TaskBudgetStatus.get( params.id )
+        if(taskBudgetStatusInstance) {
+            if(params.version) {
+                def version = params.version.toLong()
+                if(taskBudgetStatusInstance.version > version) {
+                    
+                    taskBudgetStatusInstance.errors.rejectValue("version", "taskBudgetStatus.optimistic.locking.failure", "Another user has updated this TaskBudgetStatus while you were editing.")
+                    render(view:'edit',model:[taskBudgetStatusInstance:taskBudgetStatusInstance])
+                    return
+                }
+            }
+            taskBudgetStatusInstance.properties = params
+            if(!taskBudgetStatusInstance.hasErrors() && taskBudgetStatusInstance.save(flush: true)) {
+                flash.message = "TaskBudgetStatus ${params.id} updated"
+                redirect(action:show,id:taskBudgetStatusInstance.id)
+            }
+            else {
+                render(view:'edit',model:[taskBudgetStatusInstance:taskBudgetStatusInstance])
+            }
+        }
+        else {
+            flash.message = "TaskBudgetStatus not found with id ${params.id}"
+            redirect(action:list)
+        }
+    }
+
+    def create = {
+        def taskBudgetStatusInstance = new TaskBudgetStatus()
+        taskBudgetStatusInstance.properties = params
+        return ['taskBudgetStatusInstance':taskBudgetStatusInstance]
+    }
+
+    def save = {
+        def taskBudgetStatusInstance = new TaskBudgetStatus(params)
+        if(!taskBudgetStatusInstance.hasErrors() && taskBudgetStatusInstance.save(flush: true)) {
+            flash.message = "TaskBudgetStatus ${taskBudgetStatusInstance.id} created"
+            redirect(action:show,id:taskBudgetStatusInstance.id)
+        }
+        else {
+            render(view:'create',model:[taskBudgetStatusInstance:taskBudgetStatusInstance])
+        }
+    }
+}
Index: /trunk/grails-app/domain/Task.groovy
===================================================================
--- /trunk/grails-app/domain/Task.groovy	(revision 251)
+++ /trunk/grails-app/domain/Task.groovy	(revision 252)
@@ -4,4 +4,5 @@
     TaskStatus taskStatus
     TaskPriority taskPriority
+    TaskBudgetStatus taskBudgetStatus
     TaskType taskType
     Task parentTask
@@ -38,4 +39,5 @@
         leadPerson()
         taskPriority()
+        taskBudgetStatus()
         taskStatus()
         parentTask(nullable:true)
Index: /trunk/grails-app/domain/TaskBudgetStatus.groovy
===================================================================
--- /trunk/grails-app/domain/TaskBudgetStatus.groovy	(revision 252)
+++ /trunk/grails-app/domain/TaskBudgetStatus.groovy	(revision 252)
@@ -0,0 +1,14 @@
+class TaskBudgetStatus {
+    String name
+    String description = ""
+    boolean isActive = true
+
+    static hasMany = [tasks : Task]
+
+    static constraints = {
+        name(maxSize:50,unique:true,blank:false)
+        description(maxSize:100)
+    }
+
+    String toString() {"${this.name}"}
+}
Index: /trunk/grails-app/services/CreateDataService.groovy
===================================================================
--- /trunk/grails-app/services/CreateDataService.groovy	(revision 251)
+++ /trunk/grails-app/services/CreateDataService.groovy	(revision 252)
@@ -64,4 +64,5 @@
         createBaseTaskStatus()
         createBaseTaskPriorities()
+        createBaseTaskBudgetStatus()
         createBaseTaskTypes()
         createBaseTaskModificationTypes()
@@ -499,4 +500,16 @@
     }
 
+    def createBaseTaskBudgetStatus() {
+
+        //TaskBudgetStatus
+        def taskBudgetStatusInstance
+
+        taskBudgetStatusInstance = new TaskBudgetStatus(name:"Unplanned") // #1
+        saveAndTest(taskBudgetStatusInstance)
+
+        taskBudgetStatusInstance = new TaskBudgetStatus(name:"Planned") // #2
+        saveAndTest(taskBudgetStatusInstance)
+    }
+
     def createBaseTaskTypes() {
 
Index: /trunk/grails-app/services/TaskSearchService.groovy
===================================================================
--- /trunk/grails-app/services/TaskSearchService.groovy	(revision 251)
+++ /trunk/grails-app/services/TaskSearchService.groovy	(revision 252)
@@ -87,7 +87,7 @@
             sort: params.sort,
             order: params.order) {
-                ne("taskType", TaskType.findByName("Unscheduled Breakin"))
+                eq("taskBudgetStatus", TaskBudgetStatus.get(2))
                 ge("targetStartDate", dateUtilService.oneWeekAgo)
-                lt("targetStartDate", dateUtilService.getTomorrow())
+                lt("targetStartDate", dateUtilService.tomorrow)
                 eq("trash", false)
             }
@@ -105,5 +105,5 @@
             sort: params.sort,
             order: params.order) {
-                eq("taskType", TaskType.findByName("Unscheduled Breakin"))
+                eq("taskBudgetStatus", TaskBudgetStatus.get(1))
                 ge("targetStartDate", dateUtilService.oneWeekAgo)
                 lt("targetStartDate", dateUtilService.getTomorrow())
Index: /trunk/grails-app/services/TaskService.groovy
===================================================================
--- /trunk/grails-app/services/TaskService.groovy	(revision 251)
+++ /trunk/grails-app/services/TaskService.groovy	(revision 252)
@@ -38,4 +38,11 @@
             // Default status to "not started" if not supplied.
             params.taskStatus = params.taskStatus ?: TaskStatus.get(1)
+
+            // Set budgetStatus.
+            if(params.taskType?.id?.toLong() == 1) // Unscheduled Breakin.
+                params.taskBudgetStatus = params.taskBudgetStatus ?: TaskBudgetStatus.get(1) // Unplanned.
+            else
+                params.taskBudgetStatus = params.taskBudgetStatus ?: TaskBudgetStatus.get(2) // Planned.
+
             def taskInstance = new Task(params)
             result.taskInstance = taskInstance
Index: /trunk/grails-app/views/task/create.gsp
===================================================================
--- /trunk/grails-app/views/task/create.gsp	(revision 251)
+++ /trunk/grails-app/views/task/create.gsp	(revision 252)
@@ -77,4 +77,13 @@
                                 <td valign="top" class="value ${hasErrors(bean:taskInstance,field:'taskPriority','errors')}">
                                     <g:select optionKey="id" from="${TaskPriority.list()}" name="taskPriority.id" value="${taskInstance?.taskPriority?.id}" ></g:select>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="taskBudgetStatus">Task Budget Status:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:taskInstance,field:'taskBudgetStatus','errors')}">
+                                    <g:select optionKey="id" from="${TaskBudgetStatus.list()}" name="taskBudgetStatus.id" value="${taskInstance?.taskBudgetStatus?.id}" ></g:select>
                                 </td>
                             </tr> 
Index: /trunk/grails-app/views/task/edit.gsp
===================================================================
--- /trunk/grails-app/views/task/edit.gsp	(revision 251)
+++ /trunk/grails-app/views/task/edit.gsp	(revision 252)
@@ -85,4 +85,13 @@
                             <tr class="prop">
                                 <td valign="top" class="name">
+                                    <label for="taskBudgetStatus">Task Budget Status:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:taskInstance,field:'taskBudgetStatus','errors')}">
+                                    <g:select optionKey="id" from="${TaskBudgetStatus.list()}" name="taskBudgetStatus.id" value="${taskInstance?.taskBudgetStatus?.id}" ></g:select>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
                                     <label for="taskStatus">Task Status:</label>
                                 </td>
Index: /trunk/grails-app/views/task/show.gsp
===================================================================
--- /trunk/grails-app/views/task/show.gsp	(revision 251)
+++ /trunk/grails-app/views/task/show.gsp	(revision 252)
@@ -72,4 +72,11 @@
                     
                         <tr class="prop">
+                            <td valign="top" class="name">Task Budget Status:</td>
+                            
+                            <td valign="top" class="value"><g:link controller="taskBudgetStatus" action="show" id="${taskInstance?.taskBudgetStatus?.id}">${taskInstance?.taskBudgetStatus?.encodeAsHTML()}</g:link></td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
                             <td valign="top" class="name">Task Status:</td>
                             
Index: /trunk/grails-app/views/taskBudgetStatus/create.gsp
===================================================================
--- /trunk/grails-app/views/taskBudgetStatus/create.gsp	(revision 252)
+++ /trunk/grails-app/views/taskBudgetStatus/create.gsp	(revision 252)
@@ -0,0 +1,64 @@
+
+
+<html>
+    <head>
+        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
+        <meta name="layout" content="main" />
+        <title>Create TaskBudgetStatus</title>
+    </head>
+    <body>
+        <div class="nav">
+            <span class="menuButton"><g:link class="list" action="list">TaskBudgetStatus List</g:link></span>
+        </div>
+        <div class="body">
+            <h1>Create TaskBudgetStatus</h1>
+            <g:if test="${flash.message}">
+            <div class="message">${flash.message}</div>
+            </g:if>
+            <g:hasErrors bean="${taskBudgetStatusInstance}">
+            <div class="errors">
+                <g:renderErrors bean="${taskBudgetStatusInstance}" as="list" />
+            </div>
+            </g:hasErrors>
+            <g:form action="save" method="post" >
+                <div class="dialog">
+                    <table>
+                        <tbody>
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="name">Name:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:taskBudgetStatusInstance,field:'name','errors')}">
+                                    <input type="text" maxlength="50" id="name" name="name" value="${fieldValue(bean:taskBudgetStatusInstance,field:'name')}"/>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="description">Description:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:taskBudgetStatusInstance,field:'description','errors')}">
+                                    <input type="text" maxlength="100" id="description" name="description" value="${fieldValue(bean:taskBudgetStatusInstance,field:'description')}"/>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="isActive">Is Active:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:taskBudgetStatusInstance,field:'isActive','errors')}">
+                                    <g:checkBox name="isActive" value="${taskBudgetStatusInstance?.isActive}" ></g:checkBox>
+                                </td>
+                            </tr> 
+                        
+                        </tbody>
+                    </table>
+                </div>
+                <div class="buttons">
+                    <span class="button"><input class="save" type="submit" value="Create" /></span>
+                </div>
+            </g:form>
+        </div>
+    </body>
+</html>
Index: /trunk/grails-app/views/taskBudgetStatus/edit.gsp
===================================================================
--- /trunk/grails-app/views/taskBudgetStatus/edit.gsp	(revision 252)
+++ /trunk/grails-app/views/taskBudgetStatus/edit.gsp	(revision 252)
@@ -0,0 +1,84 @@
+
+
+<html>
+    <head>
+        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
+        <meta name="layout" content="main" />
+        <title>Edit TaskBudgetStatus</title>
+    </head>
+    <body>
+        <div class="nav">
+            <span class="menuButton"><g:link class="list" action="list">TaskBudgetStatus List</g:link></span>
+            <span class="menuButton"><g:link class="create" action="create">New TaskBudgetStatus</g:link></span>
+        </div>
+        <div class="body">
+            <h1>Edit TaskBudgetStatus</h1>
+            <g:if test="${flash.message}">
+            <div class="message">${flash.message}</div>
+            </g:if>
+            <g:hasErrors bean="${taskBudgetStatusInstance}">
+            <div class="errors">
+                <g:renderErrors bean="${taskBudgetStatusInstance}" as="list" />
+            </div>
+            </g:hasErrors>
+            <g:form method="post" >
+                <input type="hidden" name="id" value="${taskBudgetStatusInstance?.id}" />
+                <input type="hidden" name="version" value="${taskBudgetStatusInstance?.version}" />
+                <div class="dialog">
+                    <table>
+                        <tbody>
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="name">Name:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:taskBudgetStatusInstance,field:'name','errors')}">
+                                    <input type="text" maxlength="50" id="name" name="name" value="${fieldValue(bean:taskBudgetStatusInstance,field:'name')}"/>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="description">Description:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:taskBudgetStatusInstance,field:'description','errors')}">
+                                    <input type="text" maxlength="100" id="description" name="description" value="${fieldValue(bean:taskBudgetStatusInstance,field:'description')}"/>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="isActive">Is Active:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:taskBudgetStatusInstance,field:'isActive','errors')}">
+                                    <g:checkBox name="isActive" value="${taskBudgetStatusInstance?.isActive}" ></g:checkBox>
+                                </td>
+                            </tr> 
+                        
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="tasks">Tasks:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:taskBudgetStatusInstance,field:'tasks','errors')}">
+                                    
+<ul>
+<g:each var="t" in="${taskBudgetStatusInstance?.tasks?}">
+    <li><g:link controller="task" action="show" id="${t.id}">${t?.encodeAsHTML()}</g:link></li>
+</g:each>
+</ul>
+<g:link controller="task" params="['taskBudgetStatus.id':taskBudgetStatusInstance?.id]" action="create">Add Task</g:link>
+
+                                </td>
+                            </tr> 
+                        
+                        </tbody>
+                    </table>
+                </div>
+                <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>
+                </div>
+            </g:form>
+        </div>
+    </body>
+</html>
Index: /trunk/grails-app/views/taskBudgetStatus/list.gsp
===================================================================
--- /trunk/grails-app/views/taskBudgetStatus/list.gsp	(revision 252)
+++ /trunk/grails-app/views/taskBudgetStatus/list.gsp	(revision 252)
@@ -0,0 +1,55 @@
+
+
+<html>
+    <head>
+        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
+        <meta name="layout" content="main" />
+        <title>TaskBudgetStatus List</title>
+    </head>
+    <body>
+        <div class="nav">
+            <span class="menuButton"><g:link class="create" action="create">New TaskBudgetStatus</g:link></span>
+        </div>
+        <div class="body">
+            <h1>TaskBudgetStatus List</h1>
+            <g:if test="${flash.message}">
+            <div class="message">${flash.message}</div>
+            </g:if>
+            <div class="list">
+                <table>
+                    <thead>
+                        <tr>
+                        
+                   	        <g:sortableColumn property="id" title="Id" />
+                        
+                   	        <g:sortableColumn property="name" title="Name" />
+                        
+                   	        <g:sortableColumn property="description" title="Description" />
+                        
+                   	        <g:sortableColumn property="isActive" title="Is Active" />
+                        
+                        </tr>
+                    </thead>
+                    <tbody>
+                    <g:each in="${taskBudgetStatusInstanceList}" status="i" var="taskBudgetStatusInstance">
+                        <tr class="${(i % 2) == 0 ? 'odd' : 'even'}">
+                        
+                            <td><g:link action="show" id="${taskBudgetStatusInstance.id}">${fieldValue(bean:taskBudgetStatusInstance, field:'id')}</g:link></td>
+                        
+                            <td>${fieldValue(bean:taskBudgetStatusInstance, field:'name')}</td>
+                        
+                            <td>${fieldValue(bean:taskBudgetStatusInstance, field:'description')}</td>
+                        
+                            <td>${fieldValue(bean:taskBudgetStatusInstance, field:'isActive')}</td>
+                        
+                        </tr>
+                    </g:each>
+                    </tbody>
+                </table>
+            </div>
+            <div class="paginateButtons">
+                <g:paginate total="${taskBudgetStatusInstanceTotal}" />
+            </div>
+        </div>
+    </body>
+</html>
Index: /trunk/grails-app/views/taskBudgetStatus/show.gsp
===================================================================
--- /trunk/grails-app/views/taskBudgetStatus/show.gsp	(revision 252)
+++ /trunk/grails-app/views/taskBudgetStatus/show.gsp	(revision 252)
@@ -0,0 +1,77 @@
+
+
+<html>
+    <head>
+        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
+        <meta name="layout" content="main" />
+        <title>Show TaskBudgetStatus</title>
+    </head>
+    <body>
+        <div class="nav">
+            <span class="menuButton"><g:link class="list" action="list">TaskBudgetStatus List</g:link></span>
+            <span class="menuButton"><g:link class="create" action="create">New TaskBudgetStatus</g:link></span>
+        </div>
+        <div class="body">
+            <h1>Show TaskBudgetStatus</h1>
+            <g:if test="${flash.message}">
+            <div class="message">${flash.message}</div>
+            </g:if>
+            <div class="dialog">
+                <table>
+                    <tbody>
+
+                    
+                        <tr class="prop">
+                            <td valign="top" class="name">Id:</td>
+                            
+                            <td valign="top" class="value">${fieldValue(bean:taskBudgetStatusInstance, field:'id')}</td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
+                            <td valign="top" class="name">Name:</td>
+                            
+                            <td valign="top" class="value">${fieldValue(bean:taskBudgetStatusInstance, field:'name')}</td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
+                            <td valign="top" class="name">Description:</td>
+                            
+                            <td valign="top" class="value">${fieldValue(bean:taskBudgetStatusInstance, field:'description')}</td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
+                            <td valign="top" class="name">Is Active:</td>
+                            
+                            <td valign="top" class="value">${fieldValue(bean:taskBudgetStatusInstance, field:'isActive')}</td>
+                            
+                        </tr>
+                    
+                        <tr class="prop">
+                            <td valign="top" class="name">Tasks:</td>
+                            
+                            <td  valign="top" style="text-align:left;" class="value">
+                                <ul>
+                                <g:each var="t" in="${taskBudgetStatusInstance.tasks}">
+                                    <li><g:link controller="task" action="show" id="${t.id}">${t?.encodeAsHTML()}</g:link></li>
+                                </g:each>
+                                </ul>
+                            </td>
+                            
+                        </tr>
+                    
+                    </tbody>
+                </table>
+            </div>
+            <div class="buttons">
+                <g:form>
+                    <input type="hidden" name="id" value="${taskBudgetStatusInstance?.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>
+                </g:form>
+            </div>
+        </div>
+    </body>
+</html>
Index: /trunk/grails-app/views/taskDetailed/edit.gsp
===================================================================
--- /trunk/grails-app/views/taskDetailed/edit.gsp	(revision 251)
+++ /trunk/grails-app/views/taskDetailed/edit.gsp	(revision 252)
@@ -129,4 +129,13 @@
                                     <g:select optionKey="id" from="${TaskPriority.list()}" name="taskPriority.id" value="${taskInstance?.taskPriority?.id}" ></g:select>
                                 </td>
+                            </tr>
+                            
+                            <tr class="prop">
+                                <td valign="top" class="name">
+                                    <label for="taskBudgetStatus">Budget Status:</label>
+                                </td>
+                                <td valign="top" class="value ${hasErrors(bean:taskInstance,field:'taskBudgetStatus','errors')}">
+                                    <g:select optionKey="id" from="${TaskBudgetStatus.list()}" name="taskBudgetStatus.id" value="${taskInstance?.taskBudgetStatus?.id}" ></g:select>
+                                </td>
                             </tr> 
                         
Index: /trunk/grails-app/views/taskDetailed/show.gsp
===================================================================
--- /trunk/grails-app/views/taskDetailed/show.gsp	(revision 251)
+++ /trunk/grails-app/views/taskDetailed/show.gsp	(revision 252)
@@ -149,4 +149,11 @@
 
                                     <tr class="prop">
+                                        <td valign="top" class="name">Budget Status:</td>
+
+                                        <td valign="top" class="value">${taskInstance?.taskBudgetStatus?.encodeAsHTML()}</td>
+
+                                    </tr>
+
+                                    <tr class="prop">
                                         <td valign="top" class="name">Approved:</td>
 
