source: trunk/grails-app/controllers/EntryDetailedController.groovy @ 824

Last change on this file since 824 was 822, checked in by gav, 14 years ago

Refactor task show view to use templates.

File size: 5.0 KB
Line 
1import org.codehaus.groovy.grails.plugins.springsecurity.Secured
2
3@Secured(['ROLE_AppAdmin', 'ROLE_Manager', 'ROLE_TaskManager', 'ROLE_TaskUser'])
4class EntryDetailedController extends BaseController {
5
6    def authService
7    def taskService
8
9    def index = { redirect(action:list,params:params) }
10
11    // the delete, save and update actions only accept POST requests
12    static allowedMethods = [delete:'POST', save:'POST', update:'POST']
13
14    def list = {
15        if(!params.max) params.max = 10
16        [ entryInstanceList: Entry.list( params ) ]
17    }
18
19    def show = {
20        def entryInstance = Entry.get( params.id )
21
22        if(!entryInstance) {
23            flash.message = "Entry not found with id ${params.id}"
24            redirect(controller: 'taskDetailed', action: 'search')
25        }
26        else { return [ entryInstance : entryInstance ] }
27    }
28
29    def delete = {
30        def entryInstance = Entry.get( params.id )
31        if(entryInstance) {
32            if(entryInstance.enteredBy.loginName == authService.currentUser.loginName) {
33                def taskID = entryInstance.task.id
34                entryInstance.delete(flush:true)
35                flash.message = "Entry ${params.id} deleted"
36                redirect(controller: 'taskDetailed', action: 'show', id: taskID)
37            }
38            else {
39                flash.message = "You may only delete your own entries."
40                redirect(action:show,id:entryInstance.id)
41            }
42
43        }
44        else {
45            flash.message = "Entry not found with id ${params.id}"
46            redirect(controller: "taskDetailed", action:"search")
47        }
48    }
49
50    def edit = {
51        def entryInstance = Entry.get( params.id )
52        if(!entryInstance) {
53                flash.message = "Entry not found with id ${params.id}"
54                redirect(controller: "taskDetailed", action:"search")
55        }
56        else {
57
58            if(entryInstance.enteredBy.loginName == authService.currentUser.loginName) {
59                return [ entryInstance : entryInstance ]
60            }
61            else {
62                flash.message = "You may only edit your own entries."
63                redirect(action:show,id:entryInstance.id)
64            }
65
66        }
67    }
68
69    def update = {
70        def entryInstance = Entry.get( params.id )
71        if(entryInstance) {
72            // The update method only accepts post requests, so this is just in case.
73            if(entryInstance.enteredBy.loginName == authService.currentUser.loginName) {
74                entryInstance.properties = params
75                if(!entryInstance.hasErrors() && entryInstance.save(flush: true)) {
76                    flash.message = "Entry ${params.id} updated"
77                    redirect(action:show,id:entryInstance.id)
78                }
79                else {
80                    render(view:'edit',model:[entryInstance:entryInstance])
81                }
82            }
83            else {
84                flash.message = "You may only edit your own entries."
85                redirect(action:show,id:entryInstance.id)
86            }
87        }
88        else {
89            flash.message = "Entry not found with id ${params.id}"
90            redirect(controller: "taskDetailed", action:"search")
91        }
92    }
93
94    def createMaintenanceAction = {
95
96//         if(!params.taskInstance?.id || !params.entryType?.id) {
97//             flash.message = g.message(code:"entry.create.no.params")
98//             redirect(controller:"taskDetailed", action:"search")
99//             return
100//         }
101
102        def taskInstance = Task.read(params.taskInstance.id)
103        println taskInstance
104        render "Done"
105    }
106
107    def create = {
108        if(!params.taskInstance?.id || !params.entryType?.id) {
109            flash.message = g.message(code:"entry.create.no.params")
110            redirect(controller:"taskDetailed", action:"search")
111            return
112        }
113
114        def taskInstance = Task.read(params.taskInstance.id)
115
116        if(!taskInstance) {
117            flash.message = g.message(code:"task.notFound")
118            redirect(controller:"taskDetailed", action:"search")
119            return
120        }
121
122        // Check for Complete task.
123        if(taskInstance.taskStatus.id == 3) {
124            flash.errorMessage = g.message(code:"task.operationNotPermittedOnCompleteTask")
125            redirect(controller:"taskDetailed", action:"show", id: taskInstance.id)
126            return
127        }
128
129        def entryInstance = new Entry()
130        entryInstance.task = taskInstance
131        entryInstance.entryType = EntryType.read(params.entryType.id)
132        return ['entryInstance': entryInstance]
133    } // create
134
135    def save = {
136        def result = taskService.saveEntry(params)
137
138        if(!result.error) {
139            flash.message = "Entry created."
140            redirect(controller: "taskDetailed", action: "show", id: result.taskId)
141            return
142        }
143
144        if(result.error.code != "default.create.failure") {
145            params.errorMessage = g.message(code: result.error.code)
146        }
147
148        render(view:'create',model:[entryInstance: result.entryInstance])
149    } // save
150
151} // end class
Note: See TracBrowser for help on using the repository browser.