source: trunk/grails-app/controllers/dbnp/studycapturing/WizardController.groovy @ 172

Last change on this file since 172 was 172, checked in by duh, 10 years ago
  • added table-editor.js which makes tables multi editable (see the wizard subjects page and drag a selection over table rows and start editting)
  • updated css and templates
  • Property svn:keywords set to
    Date
    Author
    Rev
File size: 4.1 KB
Line 
1package dbnp.studycapturing
2
3import dbnp.studycapturing.*
4import dbnp.data.*
5import grails.converters.*
6
7/**
8 * Wizard Controler
9 *
10 * The wizard controller handles the handeling of pages and data flow
11 * through the study capturing wizard.
12 *
13 * @author Jeroen Wesbeek
14 * @since 20100107
15 * @package studycapturing
16 *
17 * Revision information:
18 * $Rev: 172 $
19 * $Author: duh $
20 * $Date: 2010-02-04 16:50:31 +0000 (do, 04 feb 2010) $
21 */
22class WizardController {
23        /**
24         * index method, redirect to the webflow
25         * @void
26         */
27        def index = {
28                /**
29                 * Do you believe it in your head?
30                 * I can go with the flow
31                 * Don't say it doesn't matter (with the flow) matter anymore
32                 * I can go with the flow (I can go)
33                 * Do you believe it in your head?
34                 */
35                redirect(action: 'pages')
36        }
37
38        /**
39         * WebFlow definition
40         * @see http://grails.org/WebFlow
41         * @void
42         */
43        def pagesFlow = {
44                // start the flow
45                onStart {
46                        // define flow variables
47                        flow.page = 0
48                        flow.pages = [
49                                [title: 'Study'],               // study
50                                [title: 'Subjects'],    // subjects
51                                [title: 'Groups'],              // groups
52                                [title: 'Form elements demo page']
53                        ]
54
55                }
56
57                // render the main wizard page which immediately
58                // triggers the 'next' action (hence, the main
59                // page dynamically renders the study template
60                // and makes the flow jump to the study logic)
61                mainPage {
62                        render(view: "/wizard/index")
63                        onRender {
64                                flow.page = 1
65                        }
66                        on("next").to "study"
67                }
68
69                // render the study page and handle study logic
70                study {
71                        render(view: "_study")
72                        onRender {
73                                flow.page = 1
74                        }
75                        on("next") {
76                                // create date instance from date string?
77                                // @see WizardTagLibrary::dateElement{...}
78                                if (params.get('startDate')) {
79                                        params.startDate = new Date().parse("d/M/yyyy", params.get('startDate').toString())
80                                }
81
82                                // if a template is selected, get template instance
83                                if (params.get('template')) {
84                                        params.template = Template.findByName(params.get('template'))
85                                }
86
87                                // create a study instance
88                                flow.study = new Study(params)
89
90                                // validate study
91                                if (flow.study.validate()) {
92                                        success()
93                                } else {
94                                        // validation failed, feedback errors
95                                        flash.errors = new LinkedHashMap()
96                                        this.appendErrors(flow.study,flash.errors)
97                                        error()
98                                }
99                        }.to "subjects"
100                }
101
102                // render page two
103                subjects {
104                        render(view: "_subjects")
105                        onRender {
106                                flow.page = 2
107
108                                if (!flow.subjects) {
109                                        flow.subjects = []
110                                }
111                        }
112                        on ("add") {
113                                // fetch species by name (as posted by the form)
114                                def speciesTerm = Term.findByName(params.addSpecies)
115                               
116                                // add x subject of species y
117                                (params.addNumber as int).times {
118                                        def increment = flow.subjects.size()
119                                        flow.subjects[ increment ] = new Subject(
120                                                name: 'Subject ' + (increment+1),
121                                                species: speciesTerm
122                                        )
123                                }
124                        }.to "subjects"
125                        on("next") {
126                                // got one or more subjects?
127                                if (flow.subjects.size() < 1) {
128                                        error()
129                                }
130                                println params
131                        }.to "groups"
132                        on("previous") {
133                                // TODO
134                        }.to "study"
135                }
136
137                groups {
138                        render(view: "_groups")
139                        onRender {
140                                flow.page = 3
141
142                                if (!flow.groups) {
143                                        flow.groups = []
144                                }
145                        }
146                        on("next") {
147                                // TODO
148                        }.to "demo"
149                        on("previous") {
150                                // TODO
151                        }.to "subjects"
152                }
153
154                // render page three
155                demo {
156                        render(view: "_three")
157                        onRender {
158                                flow.page = 4
159                        }
160                        on("previous") {
161                                // TODO
162                        }.to "groups"
163                }
164        }
165
166        /**
167         * transform domain class validation errors into a human readable
168         * linked hash map
169         * @param object validated domain class
170         * @returns object  linkedHashMap
171         */
172        def getHumanReadableErrors(object) {
173                def errors = new LinkedHashMap()
174
175                object.errors.getAllErrors().each() {
176                        errors[it.getArguments()[0]] = it.getDefaultMessage()
177                }
178
179                return errors
180        }
181
182        /**
183         * append errors of a particular object to a map
184         * @param object
185         * @param map linkedHashMap
186         * @void
187         */
188        def appendErrors(object, map) {
189                this.appendErrorMap(this.getHumanReadableErrors(object), map)
190        }
191
192        /**
193         * append errors of one map to another map
194         * @param map linkedHashMap
195         * @param map linkedHashMap
196         * @void
197         */
198        def appendErrorMap(map, mapToExtend) {
199                map.each() {key, value ->
200                        mapToExtend[key] = value
201                }
202        }
203}
Note: See TracBrowser for help on using the repository browser.