source: trunk/grails-app/controllers/dbnp/studycapturing/AssayController.groovy @ 1633

Last change on this file since 1633 was 1633, checked in by s.h.sikkema@…, 10 years ago

Fixed 'Assay has no value (null)' error in assay exporter

  • Property svn:keywords set to Rev Author Date
File size: 8.8 KB
Line 
1package dbnp.studycapturing
2
3class AssayController {
4
5    def assayService
6    def authenticationService
7   
8    static allowedMethods = [save: "POST", update: "POST", delete: "POST"]
9
10    def index = {
11        redirect(action: "list", params: params)
12    }
13
14    def list = {
15        params.max = Math.min(params.max ? params.int('max') : 10, 100)
16        [assayInstanceList: Assay.list(params), assayInstanceTotal: Assay.count()]
17    }
18
19    def create = {
20        def assayInstance = new Assay()
21        assayInstance.properties = params
22        return [assayInstance: assayInstance]
23    }
24
25    def save = {
26        def assayInstance = new Assay(params)
27
28        // The following lines deviate from the generate-all generated code.
29        // See http://jira.codehaus.org/browse/GRAILS-3783 for why we have this shameful workaround...
30        def study = assayInstance.parent
31        study.addToAssays(assayInstance)
32
33        if (assayInstance.save(flush: true)) {
34            flash.message = "${message(code: 'default.created.message', args: [message(code: 'assay.label', default: 'Assay'), assayInstance.id])}"
35            redirect(action: "show", id: assayInstance.id)
36        }
37        else {
38            render(view: "create", model: [assayInstance: assayInstance])
39        }
40    }
41
42    def show = {
43        def assayInstance = Assay.get(params.id)
44        if (!assayInstance) {
45            flash.message = "${message(code: 'default.not.found.message', args: [message(code: 'assay.label', default: 'Assay'), params.id])}"
46            redirect(action: "list")
47        }
48        else {
49            [assayInstance: assayInstance]
50        }
51    }
52
53        def showByToken = {
54            def assayInstance = Assay.findByAssayUUID(params.id)
55            if (!assayInstance) {
56                flash.message = "${message(code: 'default.not.found.message', args: [message(code: 'assay.label', default: 'Assay'), params.id])}"
57                redirect(action: "list")
58            }
59            else {
60                    redirect(action: "show", id: assayInstance.id)
61            }
62        }
63
64    def edit = {
65        def assayInstance = Assay.get(params.id)
66        if (!assayInstance) {
67            flash.message = "${message(code: 'default.not.found.message', args: [message(code: 'assay.label', default: 'Assay'), params.id])}"
68            redirect(action: "list")
69        }
70        else {
71            return [assayInstance: assayInstance]
72        }
73    }
74
75    def update = {
76        def assayInstance = Assay.get(params.id)
77        if (assayInstance) {
78            if (params.version) {
79                def version = params.version.toLong()
80                if (assayInstance.version > version) {
81                   
82                    assayInstance.errors.rejectValue("version", "default.optimistic.locking.failure", [message(code: 'assay.label', default: 'Assay')] as Object[], "Another user has updated this Assay while you were editing")
83                    render(view: "edit", model: [assayInstance: assayInstance])
84                    return
85                }
86            }
87            assayInstance.properties = params
88            if (!assayInstance.hasErrors() && assayInstance.save(flush: true)) {
89                flash.message = "${message(code: 'default.updated.message', args: [message(code: 'assay.label', default: 'Assay'), assayInstance.id])}"
90                redirect(action: "show", id: assayInstance.id)
91            }
92            else {
93                render(view: "edit", model: [assayInstance: assayInstance])
94            }
95        }
96        else {
97            flash.message = "${message(code: 'default.not.found.message', args: [message(code: 'assay.label', default: 'Assay'), params.id])}"
98            redirect(action: "list")
99        }
100    }
101
102    def delete = {
103        def assayInstance = Assay.get(params.id)
104        if (assayInstance) {
105            try {
106                assayInstance.delete(flush: true)
107                flash.message = "${message(code: 'default.deleted.message', args: [message(code: 'assay.label', default: 'Assay'), params.id])}"
108                redirect(action: "list")
109            }
110            catch (org.springframework.dao.DataIntegrityViolationException e) {
111                flash.message = "${message(code: 'default.not.deleted.message', args: [message(code: 'assay.label', default: 'Assay'), params.id])}"
112                redirect(action: "show", id: params.id)
113            }
114        }
115        else {
116            flash.message = "${message(code: 'default.not.found.message', args: [message(code: 'assay.label', default: 'Assay'), params.id])}"
117            redirect(action: "list")
118        }
119    }
120
121    /**
122     * Shows a page where an assay from a study can be selected
123     *
124     * @param none
125     */
126    def selectAssay = {
127        def user = authenticationService.getLoggedInUser()
128        def studies = Study.findAllByOwner(user)
129        def assays = Assay.findAllByParent(studies[0])
130
131        [userStudies: studies, assays: assays]
132    }
133
134    /**
135     * Shows a page where individual fields for the different categories (ie.
136     * subject data, sampling events... etc.) can be selected for export
137     *
138     * @param params.id Assay id
139     */
140    def selectFields = {
141        // receives an assay id
142        def assayId = params.assayId
143
144        // did the assay id value come across?
145        if (!assayId) {
146            flash.errorMessage = "An error occurred: assayId = ${assayId}."
147            redirect action: 'selectAssay'
148            return
149        }
150
151        Assay assay = Assay.get(assayId)
152
153        // check if assay exists
154        if (!assay) {
155
156            flash.errorMessage = "No assay found with id: ${assayId}"
157            redirect action: 'selectAssay'
158            return
159        }
160
161        // obtain fields for each category
162                def fieldMap
163        try {
164            fieldMap = assayService.collectAssayTemplateFields(assay)
165        } catch (Exception e) {
166                        e.printStackTrace();
167            flash.errorMessage = e.message
168            redirect action: 'selectAssay'
169                        return
170
171        }
172        def measurementTokens = fieldMap.remove('Module Measurement Data')
173
174        flash.fieldMap = fieldMap
175        flash.measurementTokens = measurementTokens
176        flash.assayId = assayId
177
178        // remove me
179        println flash
180
181        [fieldMap: fieldMap, measurementTokens: measurementTokens.name]
182    }
183
184    /**
185     * Exports all assay information as an Excel file.
186     *
187     * @param params.id Assay id
188     */
189    def compileExportData = {
190
191        def fieldMap = flash.fieldMap
192        def assayId = flash.assayId
193
194        // remove me
195        println flash
196
197        // did the assay id value come across?
198        if (!assayId) {
199            flash.errorMessage = "An error occurred: assayId = ${assayId}."
200            redirect action: 'selectAssay'
201            return
202        }
203
204        Assay assay = Assay.get(assayId)
205
206        // check if assay exists
207        if (!assay) {
208
209            flash.errorMessage = "No assay found with id: ${assayId}"
210            redirect action: 'selectAssay'
211            return
212        }
213
214        def fieldMapSelection = [:]
215
216        fieldMap.eachWithIndex { cat, cat_i ->
217
218            if (params."cat_$cat_i" == 'on') {
219                fieldMapSelection[cat.key] = []
220
221                cat.value.eachWithIndex { field, field_i ->
222
223                    if (params."cat_${cat_i}_${field_i}" == 'on') {
224
225                        fieldMapSelection[cat.key] += field
226
227                    }
228
229                }
230
231                if (fieldMapSelection[cat.key] == []) fieldMapSelection.remove(cat.key)
232
233            }
234
235        }
236
237        def measurementTokensSelection = []
238
239        if (params."cat_4" == 'on') {
240
241            def measurementToken = params.measurementToken
242
243            if (measurementToken) {
244
245                if (measurementToken instanceof String)
246                    measurementTokensSelection = [[name: measurementToken]]
247                else
248                    measurementTokensSelection = measurementToken.collect{[name: it]}
249
250            } else {
251                measurementTokensSelection = flash.measurementTokens
252            }
253
254        }
255
256        try {
257
258            def assayData = assayService.collectAssayData(assay, fieldMapSelection, measurementTokensSelection)
259
260            def rowData = assayService.convertColumnToRowStructure(assayData)
261
262            flash.rowData = rowData
263
264            def assayDataPreview = rowData[0..4].collect{it[0..4]}
265
266            [assayDataPreview: assayDataPreview]
267
268        } catch (Exception e) {
269
270            flash.errorMessage = e.message
271            redirect action: 'selectAssay'
272
273        }
274    }
275
276    def doExport = {
277
278        def filename = 'export.xlsx'
279        response.setHeader("Content-disposition", "attachment;filename=\"${filename}\"")
280        response.setContentType("application/octet-stream")
281        try {
282           
283            assayService.exportRowWiseDataToExcelFile(flash.rowData, response.outputStream)
284
285        } catch (Exception e) {
286
287            flash.errorMessage = e.message
288            redirect action: 'selectAssay'
289
290        }
291
292
293    }
294}
Note: See TracBrowser for help on using the repository browser.