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

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

Assay export functionality

  • Property svn:keywords set to Rev Author Date
File size: 7.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 assay = Assay.get(params.assayId)
143
144        // obtain fields for each category
145        try {
146
147            def fieldMap = assayService.collectAssayTemplateFields(assay)
148           
149        } catch (Exception e) {
150
151            flash.errorMessage = e.message
152            redirect action: 'selectAssay'
153
154        }
155        def measurementTokens = fieldMap.remove('Module Measurement Data')
156
157        flash.fieldMap = fieldMap
158        flash.measurementTokens = measurementTokens
159        flash.assayId = params.assayId
160
161        [fieldMap: fieldMap, measurementTokens: measurementTokens*.name]
162    }
163
164    /**
165     * Exports all assay information as an Excel file.
166     *
167     * @param params.id Assay id
168     */
169    def compileExportData = {
170
171        def fieldMap = flash.fieldMap
172        def measurementTokens = flash.measurementTokens
173
174        def fieldMapSelection = [:]
175
176        fieldMap.eachWithIndex { cat, cat_i ->
177
178            if (params."cat_$cat_i" == 'on') {
179                fieldMapSelection[cat.key] = []
180
181                cat.value.eachWithIndex { field, field_i ->
182
183                    if (params."cat_${cat_i}_${field_i}" == 'on') {
184
185                        fieldMapSelection[cat.key] += field
186
187                    }
188
189                }
190
191                if (fieldMapSelection[cat.key] == []) fieldMapSelection.remove(cat.key)
192
193            }
194
195        }
196
197        def measurementTokensSelection = []
198
199        if (params."cat_4" == 'on') {
200
201            measurementTokensSelection = params.measurementToken == 'null' ? measurementTokens : [ name: params.measurementToken]
202
203        }
204
205        Assay assay = Assay.get(flash.assayId)
206
207        // check if assay exists
208        if (!assay) {
209
210            flash.errorMessage = flash.assayId ? "No assay found with id: ${flash.assayId}" : 'Assay has no value (null).'
211            redirect action: 'selectAssay'
212            return
213
214        }
215
216        try {
217
218            def assayData = assayService.collectAssayData(assay, fieldMapSelection, measurementTokensSelection)
219
220            def rowData = assayService.convertColumnToRowStructure(assayData)
221
222            flash.rowData = rowData
223
224            def assayDataPreview = rowData[0..4].collect{it[0..4]}
225
226
227            [assayDataPreview: assayDataPreview]
228
229        } catch (Exception e) {
230
231            flash.errorMessage = e.message
232            redirect action: 'selectAssay'
233
234        }
235    }
236
237    def doExport = {
238
239        def filename = 'export.xlsx'
240        response.setHeader("Content-disposition", "attachment;filename=\"${filename}\"")
241        response.setContentType("application/octet-stream")
242        try {
243           
244            assayService.exportRowWiseDataToExcelFile(flash.rowData, response.outputStream)
245
246        } catch (Exception e) {
247
248            flash.errorMessage = e.message
249            redirect action: 'selectAssay'
250
251        }
252
253
254    }
255}
Note: See TracBrowser for help on using the repository browser.