Subversion Repositories bacoAlunos

Rev

Rev 1830 | Rev 1862 | 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");
1830 jmachado 98
    AbstractDao.getCurrentSession().beginTransaction();
1848 jmachado 99
    CourseImpl courseImpl = DaoFactory.getCourseDaoImpl().findCourseByCode(courseCode);
1830 jmachado 100
    request.setAttribute("course",courseImpl);
1848 jmachado 101
    CourseReportDocument courseReport = null;
102
    try {
103
        courseReport = new CourseReportServices().createNewCourseReportDocument("44", "201617");
104
    } catch (Throwable e) {
105
        System.out.println(e);
106
        e.printStackTrace();
107
    }
108
    String courseReportJson = courseReport.toJson();
109
    request.setAttribute("courseDocumentJson",courseReportJson);
110
    request.setAttribute("courseDocument",courseReport);
1830 jmachado 111
 
112
%>
1848 jmachado 113
<%--<a href="javascript:demoFromHTML()" class="button">Run Code</a>--%>
1830 jmachado 114
 
115
<div class="container-fluid">
116
 
117
    <style>
118
        .separatorSection
119
        {
120
            border: 1px solid #ddd;
121
        }
122
    </style>
123
 
124
 
125
    <!-- Apresentacao da Unidade -->
126
 
127
    <div class="panel panel-default">
128
        <div class="panel-heading">
129
             Relatório Anual do curso: ${course.name}
130
        </div>
131
        <div class="panel-body">
132
 
133
            <p><b class="label-info">Tipo de Curso:</b> <bean:message key="course.${course.degree}"/></p>
134
            <p><b class="label-info">Ano Lectivo:</b> ${course.importYear}</p>
135
            <p><b class="label-info">Departamento:</b> ${course.department.name}</p>
136
            <p><b class="label-info">Escola:</b> ${course.department.courseSchool.name}</p>
137
 
138
 
139
 
140
 
1848 jmachado 141
            <script>
1830 jmachado 142
 
143
                //Especifico da aplicacao
144
                var courseReportApp = angular.module('courseReportApp', []);
145
                GLOBAL_BacoAngularAppDependencies.push('courseReportApp');
146
 
147
 
148
                courseReportApp.directive('resizable', function () {
149
                    return {
150
                        restrict: 'A',
151
                        scope: {
152
                            callback: '&onResize'
153
                        },
154
                        link: function postLink(scope, elem, attrs) {
155
                            elem.resizable();
156
                            elem.on('resize', function (evt, ui, comp) {
157
                                scope.$apply(function() {
158
                                    if (scope.callback) {
159
                                        scope.callback({$evt: evt, $ui: ui, $comp: comp });
160
                                    }
161
                                })
162
                            });
163
                        }
164
                    };
165
                });
166
 
167
 
168
                courseReportApp.controller('courseReportAppController', function($scope)
169
                {
170
 
1848 jmachado 171
                    $scope.docAppSelector = "#courseReportApp";
172
                    $scope.report = <%=courseReportJson%>
1830 jmachado 173
 
174
                    $scope.resize = function(evt,ui,comp) {
175
                        //console.log (evt,ui);
176
                        comp.width = ui.size.width;
177
                        comp.height = ui.size.height;
178
                    }
179
 
1848 jmachado 180
                    /**
181
                     * @classe class to match
182
                     * @superClasses array of strings
183
                     * */
184
                    $scope.contains = function(obj,classe)
185
                    {
186
                        if(obj['@class'] && obj['@class'] == classe)
187
                            return true;
188
                        if(obj.allSuperClasses)
189
                        {
190
                            for(var i in obj.allSuperClasses)
191
                            {
192
                                if(classe == obj.allSuperClasses[i])
193
                                    return true;
194
                            }
195
                        }
196
                        return false;
197
                    }
198
 
199
                    $scope.showSep = function(section)
200
                    {
201
                        $(".separatorSectionNav").each(function()
202
                        {
203
                            angular.element($(this)).scope().section.active = false;
204
                        });
205
                        section.active = true;
206
 
207
                    }
208
 
209
                    $scope.class2id = function(obj)
210
                    {
211
                        return obj["@class"].replaceAll(".","_");
212
                    }
213
 
1830 jmachado 214
                    $scope.addText = function(parentCustomPane)
215
                    {
1848 jmachado 216
                        $scope.addSimpleDocComponent(parentCustomPane,"pt.estgp.estgweb.utils.documentBuilder.TextComponent")
1830 jmachado 217
                    }
218
 
219
                    $scope.addImage = function(parentCustomPane)
220
                    {
1848 jmachado 221
                        $scope.addSimpleDocComponent(parentCustomPane,"pt.estgp.estgweb.utils.documentBuilder.ImageComponent")
1830 jmachado 222
                    }
223
 
224
                    $scope.addSimpleDocComponent = function(parentCustomPane,classComponent)
225
                    {
226
                        if(!parentCustomPane.components)
227
                        {
228
                            parentCustomPane.components = [];
229
                        }
230
                        parentCustomPane.components.push(
231
                                {
1848 jmachado 232
                                    "@class" : classComponent
1830 jmachado 233
                                }
234
                        );
235
                    }
236
                    $scope.removeComponent = function(index,array)
237
                    {
238
                        array.splice(index,1);
239
 
240
 
241
                    }
242
                    $scope.callbackUploadedFiles = function(filesUploadResult,token,targetElement)
243
                    {
244
                        var modelObject = BacoAngularUtils.getAngularElementModel(targetElement);
245
                        modelObject.filesUploadResult = filesUploadResult;
246
                        if(modelObject.image && modelObject.image.identifier)
247
                        {
248
                            widgetCallWithActionParameters(
249
                                    "<%=request.getContextPath()%>/user/json/repository.do",
250
                                    "replaceRepositoryFileFromTempPrivateDomain",
251
                                    {
252
                                        "identifier" : modelObject.image.identifier,
253
                                        "fileUploaded" : BacoJS.stringifyOrdered(filesUploadResult.uploadedFiles[0])
254
                                    },
255
                                    "#courseReportApp",
256
                                    function(repositoryFile4JsonView)
257
                                    {
258
                                        modelObject.image = repositoryFile4JsonView;
259
                                        modelObject.imageUrl = "<%=request.getContextPath()%>/repositoryStream/" + modelObject.image.identifier + "?" + new Date().getTime();
260
                                        delete modelObject.filesUploadResult;
261
                                        angular.element($("#courseReportApp")).scope().$apply();
262
                                    },
263
                                    function(){}
264
                            );
265
                        }
266
                        else
267
                        {
268
                            widgetCallWithActionParameters(
269
                                    "<%=request.getContextPath()%>/user/json/repository.do",
270
                                    "saveRepositoryFileFromTempPrivateDomain",
271
                                    {
272
                                        "fileUploaded" : BacoJS.stringifyOrdered(filesUploadResult.uploadedFiles[0])
273
                                    },
274
                                    "#courseReportApp",
275
                                    function(repositoryFile4JsonView)
276
                                    {
277
                                        modelObject.image = repositoryFile4JsonView;
278
                                        modelObject.imageUrl = "<%=request.getContextPath()%>/repositoryStream/" + modelObject.image.identifier + "?" + new Date().getTime();
279
                                        delete modelObject.filesUploadResult;
280
                                        angular.element($("#courseReportApp")).scope().$apply();
281
                                    },
282
                                    function(){}
283
                            );
284
                        }
285
                    }
286
 
287
 
288
                });
289
            </script>
1848 jmachado 290
 
291
            <!--TEMPLATES FOR DOCUMENT BUILDER-->
1830 jmachado 292
            <jsp:include page="../utils/documentsBuilder.jsp"/>
293
 
1848 jmachado 294
            <div class="form-vertical">
295
                <div id="courseReportApp" ng-app="courseReportApp" ng-controller="courseReportAppController">
1830 jmachado 296
 
297
 
1848 jmachado 298
                    <ul class="nav nav-tabs">
299
                        <li ng-model="section" class="separatorSectionNav" ng-class="{ active: section.active}" ng-repeat="section in report.sections">
300
                            <a ng-click="showSep(section)">{{section.title}}</a>
301
                        </li>
302
                    </ul>
1830 jmachado 303
 
304
 
305
 
1848 jmachado 306
                    <!--DocumentSection-->
307
                    <div ng-model="section" ng-class="{ hidden: !section.active}" ng-repeat="section in report.sections" class="separatorSection clearfix">
1830 jmachado 308
 
1848 jmachado 309
                       <div ng-repeat="comp in section.components" ng-include="class2id(comp)">
1830 jmachado 310
 
1848 jmachado 311
                        </div>
1830 jmachado 312
 
313
 
1848 jmachado 314
                    </div>
315
                    <!--/DocumentSection-->
1830 jmachado 316
 
1848 jmachado 317
<%--
318
                    <pre class="code">{{ report | json }}</pre>
319
--%>
1830 jmachado 320
 
321
 
1848 jmachado 322
                </div><!--App-->
323
            </div> <!--form-->
1830 jmachado 324
 
325
        </div><!--Panel Body-->
326
 
327
    </div><!--Panel-->
328
 
329
</div><!--container-fluid-->
330
 
331
<%
332
    AbstractDao.getCurrentSession().getTransaction().commit();
333
%>