Subversion Repositories bacoAlunos

Rev

Rev 1860 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
1830 jmachado 1
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
2
<%@ page import="jomm.dao.impl.AbstractDao" %>
3
<%@ page import="pt.estgp.estgweb.domain.CourseImpl" %>
4
<%@ page import="pt.estgp.estgweb.domain.dao.DaoFactory" %>
5
<%@ page import="pt.estgp.estgweb.utils.documentBuilder.TextComponent" %>
6
<%@ page import="pt.estgp.estgweb.utils.documentBuilder.ImageComponent" %>
1848 jmachado 7
<%@ page import="pt.estgp.estgweb.services.courses.CourseReportServices" %>
8
<%@ page import="pt.estgp.estgweb.services.courses.coursereport.documentmodel.CourseReportDocument" %>
9
<%@ page import="org.json.JSONException" %>
1830 jmachado 10
<%@ taglib uri="/WEB-INF/tlds/struts-logic.tld" prefix="logic" %>
11
<%@ taglib uri="/WEB-INF/tlds/struts-html.tld" prefix="html" %>
12
<%@ taglib uri="/WEB-INF/tlds/jomm.tld" prefix="jomm" %>
13
<%@ taglib uri="/WEB-INF/tlds/struts-bean.tld" prefix="bean" %>
14
<%@ taglib uri="/WEB-INF/tlds/struts-nested.tld" prefix="nested" %>
15
<%@ taglib uri="/WEB-INF/tlds/baco.tld" prefix="baco" %>
16
<%@taglib prefix="t" tagdir="/WEB-INF/tags" %>
17
 
18
<link rel="stylesheet" href="<%=request.getContextPath()%>/js/jquery-ui-1.12.1/jquery-ui.css">
19
<script src="<%=request.getContextPath()%>/js/jquery-ui-1.12.1/jquery-ui.min.js"></script>
20
<link rel="stylesheet" href="<%=request.getContextPath()%>/css/flora-commons/flora.resizable.css">
21
<script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf/1.3.2/jspdf.min.js"></script>
22
<script>
23
    function demoFromHTML() {
24
        var pdf = new jsPDF('p', 'pt', 'letter');
25
        // source can be HTML-formatted string, or a reference
26
        // to an actual DOM element from which the text will be scraped.
27
        source = $('#courseReportApp')[0];
28
 
29
        // we support special element handlers. Register them with jQuery-style
30
        // ID selector for either ID or node name. ("#iAmID", "div", "span" etc.)
31
        // There is no support for any other type of selectors
32
        // (class, of compound) at this time.
33
        specialElementHandlers = {
34
            // element with id of "bypass" - jQuery style selector
35
            '#bypassme': function (element, renderer) {
36
                // true = "handled elsewhere, bypass text extraction"
37
                return true
38
            }
39
        };
40
        margins = {
41
            top: 80,
42
            bottom: 60,
43
            left: 40,
44
            width: 522
45
        };
46
        // all coords and widths are in jsPDF instance's declared units
47
        // 'inches' in this case
48
        pdf.fromHTML(
49
                source, // HTML string or DOM elem ref.
50
                margins.left, // x coord
51
                margins.top, { // y coord
52
                    'width': margins.width, // max width of content on PDF
53
                    'elementHandlers': specialElementHandlers
54
                },
55
 
56
                function (dispose) {
57
                    // dispose: object with X, Y of the last line add to the PDF
58
                    //          this allow the insertion of new lines after html
59
                    //var pdfDocument =  pdf.save('Test.pdf');
60
                    var pdfDocument = pdf.output();
61
 
62
                    var boundary = '---------------------------';
63
                    boundary += Math.floor(Math.random()*32768);
64
                    boundary += Math.floor(Math.random()*32768);
65
                    boundary += Math.floor(Math.random()*32768);
66
 
67
                    var body = '';
68
                    body += '--' + boundary + '\r\n' +
69
                            'Content-Disposition: form-data; name="filesInputId-UPLOAD[]"; filename="20170530_210340.pdf"' + '\r\n';
70
                    body += 'Content-Type: application/pdf';
71
                    body += '\r\n\r\n';
72
                    body += pdfDocument;
73
                    body += '\r\n'
74
                    body += '--' + boundary + '--';
75
 
76
 
77
 
78
                    $.ajax({
79
                        type: "POST",
80
                        cache: false,
81
                        url: "<%=request.getContextPath()%>/filesUpload",
82
                        data: body ,
83
                        processData: false,
84
                        contentType : 'multipart/form-data; boundary=' + boundary,
85
                        success: function (data) {
86
                            alert('success');
87
                            return false;
88
                        }
89
                    });
90
                }, margins
91
        );
92
    }
93
</script>
94
 
95
<%
96
 
1848 jmachado 97
    String courseCode = request.getParameter("courseCode");
1918 grupo4 98
    String year = request.getParameter("year");
1830 jmachado 99
    AbstractDao.getCurrentSession().beginTransaction();
1848 jmachado 100
    CourseImpl courseImpl = DaoFactory.getCourseDaoImpl().findCourseByCode(courseCode);
1830 jmachado 101
    request.setAttribute("course",courseImpl);
1848 jmachado 102
    CourseReportDocument courseReport = null;
103
    try {
1918 grupo4 104
        courseReport = new CourseReportServices().createNewCourseReportDocument(courseCode, year);
1848 jmachado 105
    } catch (Throwable e) {
106
        System.out.println(e);
107
        e.printStackTrace();
108
    }
109
    String courseReportJson = courseReport.toJson();
110
    request.setAttribute("courseDocumentJson",courseReportJson);
111
    request.setAttribute("courseDocument",courseReport);
1830 jmachado 112
 
113
%>
1848 jmachado 114
<%--<a href="javascript:demoFromHTML()" class="button">Run Code</a>--%>
1830 jmachado 115
 
116
<div class="container-fluid">
117
 
1918 grupo4 118
<style>
119
    .separatorSection
120
    {
121
        border: 1px solid #ddd;
122
    }
123
</style>
1830 jmachado 124
 
125
 
1918 grupo4 126
<!-- Apresentacao da Unidade -->
1830 jmachado 127
 
1918 grupo4 128
<div class="panel panel-default">
129
<div class="panel-heading">
130
    Relatório Anual do curso: ${course.name}
131
</div>
132
<div class="panel-body">
1830 jmachado 133
 
1918 grupo4 134
<p><b class="label-info">Tipo de Curso:</b> <bean:message key="course.${course.degree}"/></p>
135
<p><b class="label-info">Ano Lectivo:</b> ${course.importYear}</p>
136
<p><b class="label-info">Departamento:</b> ${course.department.name}</p>
137
<p><b class="label-info">Escola:</b> ${course.department.courseSchool.name}</p>
1830 jmachado 138
 
139
 
140
 
141
 
1918 grupo4 142
<script>
1830 jmachado 143
 
1918 grupo4 144
    //Especifico da aplicacao
145
    var courseReportApp = angular.module('courseReportApp', ['ui.tree']);
146
    GLOBAL_BacoAngularAppDependencies.push('courseReportApp');
1830 jmachado 147
 
148
 
1918 grupo4 149
    courseReportApp.directive('resizable', function () {
150
        return {
151
            restrict: 'A',
152
            scope: {
153
                callback: '&onResize'
154
            },
155
            link: function postLink(scope, elem, attrs) {
156
                elem.resizable();
157
                elem.on('resize', function (evt, ui, comp) {
158
                    scope.$apply(function() {
159
                        if (scope.callback) {
160
                            scope.callback({$evt: evt, $ui: ui, $comp: comp });
1830 jmachado 161
                        }
1918 grupo4 162
                    })
1830 jmachado 163
                });
1918 grupo4 164
            }
165
        };
166
    });
1830 jmachado 167
 
168
 
1918 grupo4 169
    courseReportApp.controller('courseReportAppController', function($scope)
170
    {
1830 jmachado 171
 
1918 grupo4 172
        $scope.docAppSelector = "#courseReportApp";
173
        $scope.report = <%=courseReportJson%>
1830 jmachado 174
 
1918 grupo4 175
                $scope.resize = function(evt,ui,comp) {
176
                    //console.log (evt,ui);
177
                    comp.width = ui.size.width;
178
                    comp.height = ui.size.height;
179
                }
1830 jmachado 180
 
1918 grupo4 181
        /**
182
         * @classe class to match
183
         * @superClasses array of strings
184
         * */
185
        $scope.contains = function(obj,classe)
186
        {
187
            if(obj['@class'] && obj['@class'] == classe)
188
                return true;
189
            if(obj.allSuperClasses)
190
            {
191
                for(var i in obj.allSuperClasses)
192
                {
193
                    if(classe == obj.allSuperClasses[i])
194
                        return true;
195
                }
196
            }
197
            return false;
198
        }
1848 jmachado 199
 
1918 grupo4 200
        $scope.showSep = function(section,subSection)
201
        {
202
            var s;
203
            for(s in section.sections)
204
            {
205
                section.sections[s].active = false;
206
            }
207
            /*$(".separatorSectionNav").each(function()
208
             {
209
             angular.element($(this)).scope().section.active = false;
210
             });*/
211
            subSection.active = true;
212
        }
1848 jmachado 213
 
1918 grupo4 214
        /**
215
         * Este metodo devolve o template mais profundo na hierarquia de classes
216
         * permitindo emular o override, quanto mais especifica for a classe
217
         * e caso exista template é esse o template devolvido
218
         * procura um script com o id da classe e se nao existir
219
         * vai subindo nas super classes
220
         * @param obj
221
         * @returns {*}
222
         */
223
        $scope.class2id = function(obj)
224
        {
225
            var objClassId = obj["@class"].replaceAll(".","_");
226
            if($("script#" + objClassId).length > 0)
227
            {
228
                return objClassId;
229
            }
230
            if(obj.allSuperClasses)
231
            {
232
                var s;
233
                for(s in obj.allSuperClasses)
234
                {
235
                    var superClass = obj.allSuperClasses[s];
236
                    var superClassId = superClass.replaceAll(".","_");
237
                    if($("script#" + superClassId).length > 0)
1848 jmachado 238
                    {
1918 grupo4 239
                        return superClassId;
1848 jmachado 240
                    }
1918 grupo4 241
                }
242
            }
243
            return obj["@class"].replaceAll(".","_");
244
        }
1848 jmachado 245
 
1918 grupo4 246
        $scope.addText = function(parentCustomPane)
247
        {
248
            $scope.addSimpleDocComponent(parentCustomPane,"pt.estgp.estgweb.utils.documentBuilder.TextComponent")
249
        }
1830 jmachado 250
 
1918 grupo4 251
        $scope.addImage = function(parentCustomPane)
252
        {
253
            $scope.addSimpleDocComponent(parentCustomPane,"pt.estgp.estgweb.utils.documentBuilder.ImageComponent")
254
        }
1830 jmachado 255
 
1918 grupo4 256
        $scope.addSimpleDocComponent = function(parentCustomPane,classComponent)
257
        {
258
            if(!parentCustomPane.components)
259
            {
260
                parentCustomPane.components = [];
261
            }
262
            parentCustomPane.components.push(
1830 jmachado 263
                    {
1918 grupo4 264
                        "@class" : classComponent
1830 jmachado 265
                    }
1918 grupo4 266
            );
267
        }
268
        $scope.removeComponent = function(index,array)
269
        {
270
            array.splice(index,1);
271
        }
1830 jmachado 272
 
1918 grupo4 273
        $scope.callbackUploadedFiles = function(filesUploadResult,token,targetElement)
274
        {
275
            var modelObject = BacoAngularUtils.getAngularElementModel(targetElement);
1830 jmachado 276
 
1918 grupo4 277
            if(modelObject.image && modelObject.image.identifier)
278
            {
279
                widgetCallWithActionParameters(
280
                        "<%=request.getContextPath()%>/user/json/repository.do",
281
                        "replaceRepositoryFileFromTempPrivateDomain",
1830 jmachado 282
                        {
1918 grupo4 283
                            "identifier" : modelObject.image.identifier,
284
                            "fileUploaded" : BacoJS.stringifyOrdered(filesUploadResult.uploadedFiles[0])
285
                        },
286
                        "#courseReportApp",
287
                        function(repositoryFile4JsonView)
1830 jmachado 288
                        {
1918 grupo4 289
                            modelObject.image = repositoryFile4JsonView;
290
                            //image URL is generated on reimport just to avoid caching
291
                            modelObject.imageUrl = "<%=request.getContextPath()%>/repositoryStream/" + modelObject.image.identifier + "?" + new Date().getTime();
292
                            angular.element($("#courseReportApp")).scope().$apply();
293
                        },
294
                        function(){}
295
                );
296
            }
297
            else
298
            {
299
                widgetCallWithActionParameters(
300
                        "<%=request.getContextPath()%>/user/json/repository.do",
301
                        "saveRepositoryFileFromTempPrivateDomain",
302
                        {
303
                            "fileUploaded" : BacoJS.stringifyOrdered(filesUploadResult.uploadedFiles[0])
304
                        },
305
                        "#courseReportApp",
306
                        function(repositoryFile4JsonView)
307
                        {
308
                            modelObject.image = repositoryFile4JsonView;
309
                            modelObject.imageUrl = "<%=request.getContextPath()%>/repositoryStream/" + modelObject.image.identifier + "?" + new Date().getTime();
310
                            angular.element($("#courseReportApp")).scope().$apply();
311
                        },
312
                        function(){}
313
                );
314
            }
315
        }
1830 jmachado 316
 
1918 grupo4 317
        $scope.save = function()
318
        {
1830 jmachado 319
 
1918 grupo4 320
                widgetCallWithActionParameters(
321
                    "<%=request.getContextPath()%>/user/courseReport.do",
322
                    "save",
323
                    {
324
                        "report" : BacoJS.stringifyOrdered($scope.report)
325
                    },
326
                    "#courseReportApp",
327
                    function(resposta)
328
                    {
329
                        $scope.report = resposta;
330
                        alert(resposta.courseName);
331
                        $scope.$apply();
332
                    },
333
                    function(){}
334
                );
1848 jmachado 335
 
1918 grupo4 336
        }
1830 jmachado 337
 
338
 
339
 
340
 
1918 grupo4 341
    });
342
</script>
1830 jmachado 343
 
1918 grupo4 344
<!--TEMPLATES FOR DOCUMENT BUILDER-->
345
<jsp:include page="../utils/documentsBuilder.jsp"/>
346
<jsp:include page="coursereport/templates.jsp"/>
1830 jmachado 347
 
1918 grupo4 348
<div class="form-vertical">
349
    <div id="courseReportApp" ng-app="courseReportApp" ng-controller="courseReportAppController">
1830 jmachado 350
 
1918 grupo4 351
        <div ng-init="section=report;" ng-include="'pt_estgp_estgweb_utils_documentBuilder_DocumentSection'">
1830 jmachado 352
 
1918 grupo4 353
        </div>
1830 jmachado 354
 
1918 grupo4 355
        <button ng-click="save()" class="btn btn-success">Salvar</button>
356
        <!-- <pre class="code">{{ report | json }}</pre>-->
1830 jmachado 357
 
358
 
359
 
1918 grupo4 360
    </div><!--App-->
361
</div> <!--form-->
1830 jmachado 362
 
1918 grupo4 363
</div><!--Panel Body-->
1830 jmachado 364
 
1918 grupo4 365
</div><!--Panel-->
1830 jmachado 366
 
367
</div><!--container-fluid-->
368
 
369
<%
370
    AbstractDao.getCurrentSession().getTransaction().commit();
371
%>