markus / MarkusLogview / MARKUS_LOGVIEW / Scripts / signalR.js @ d0385e5c
이력 | 보기 | 이력해설 | 다운로드 (16.4 KB)
1 |
(function () { |
---|---|
2 | |
3 |
//MarkusHub
|
4 |
// doftech url
|
5 |
$.connection.hub.url = "http://cloud.devdoftech.co.kr:5100/signalr/js"; |
6 | |
7 |
// hyosung url
|
8 |
//$.connection.hub.url = "http://10.11.252.3:9875/signalr/js";
|
9 | |
10 |
var markusNotificationHub = $.connection.MarkusHub; |
11 | |
12 |
$.extend(markusNotificationHub.client, {
|
13 |
// [ Convert ]
|
14 |
// Insert
|
15 |
BroadcastConvertTableInserted: function (item, projStatus) { |
16 | |
17 |
var projectTable = $("#ProjectList").DataTable(); |
18 |
var selectedProjectNO = !!projectTable.row('.selected').data() ? projectTable.row('.selected').data()[0] : null; |
19 | |
20 |
if (selectedProjectNO === item["PROJECT_NO"]) { |
21 |
TableAddData(GLOBAL_REQUEST_NAME.Convert, item, projStatus); |
22 |
} |
23 | |
24 |
}, |
25 |
// Change
|
26 |
BroadcastConvertTableChanged: function (data, projStatus) { |
27 |
updateConvertTable(data, projStatus); |
28 |
$.connection.MarkusHub.server.GetProjectList(data.PROJECT_NO, GLOBAL_REQUEST_NAME.Convert);
|
29 |
}, |
30 |
// Delete
|
31 |
BroadcastConvertTableDeleted: function (data) { |
32 |
deleteConvertTable(data); |
33 |
$.connection.MarkusHub.server.GetProjectList(data.PROJECT_NO, GLOBAL_REQUEST_NAME.Convert);
|
34 |
}, |
35 |
// [ Merge ]
|
36 |
// Insert
|
37 |
BroadcastMergeTableInserted: function (item, projStatus) { |
38 | |
39 |
var projectTable = $("#ProjectList").DataTable(); |
40 |
var selectedProjectNO = !!projectTable.row('.selected').data() ? projectTable.row('.selected').data()[0] : null; |
41 | |
42 |
if (selectedProjectNO === item["PROJECT_NO"]) { |
43 |
TableAddData(GLOBAL_REQUEST_NAME.Merge, item, projStatus); |
44 |
} |
45 | |
46 |
}, |
47 |
// Change
|
48 |
BroadcastMergeTableChanged: function (data, projStatus) { |
49 |
updateMergeTable(data, projStatus); |
50 |
$.connection.MarkusHub.server.GetProjectList(data.PROJECT_NO, GLOBAL_REQUEST_NAME.Merge);
|
51 |
}, |
52 |
// Delete
|
53 |
BroadcastMergeTableDeleted: function (data) { |
54 |
deleteMergeTable(data); |
55 |
$.connection.MarkusHub.server.GetProjectList(data.PROJECT_NO, GLOBAL_REQUEST_NAME.Merge);
|
56 |
} |
57 | |
58 |
}); |
59 | |
60 |
$.connection.hub.start({ transport: 'longPolling' }) |
61 |
.done(function () {
|
62 |
$.connection.hub.logging = true; |
63 |
console.log("connection hub id :" + $.connection.hub.id); |
64 |
console.log("Connected, transport = " + $.connection.hub.transport.name); |
65 |
//$.connection.MarkusHub.server.announce("connected!!!");
|
66 |
}) |
67 |
.fail(function () {
|
68 |
console.log("failed");
|
69 |
}); |
70 | |
71 | |
72 |
$.connection.MarkusHub.client.UpdateProjectList = function (data, type) { |
73 | |
74 |
if (location.pathname.toLowerCase().indexOf(type.replace("Document", "")) != -1) { |
75 |
updateProjectTable(data[0]);
|
76 |
} |
77 | |
78 |
}; |
79 | |
80 |
var tryingToReconnect = false; |
81 | |
82 |
$.connection.hub.reconnecting(function () { |
83 |
tryingToReconnect = true;
|
84 |
console.log("[ Makrus Hub reconnecting ]");
|
85 |
}); |
86 | |
87 |
$.connection.hub.reconnected(function () { |
88 |
tryingToReconnect = false;
|
89 |
console.log("[ Makrus Hub reconnected ]");
|
90 |
}); |
91 | |
92 |
$.connection.hub.disconnected(function () { |
93 | |
94 |
if ($.connection.hub.lastError) { |
95 |
console.log("Disconnected. Reason: " + $.connection.hub.lastError.message); |
96 |
} |
97 | |
98 |
$.connection.hub.start({ transport: 'longPolling' }) |
99 |
.done(function () {
|
100 | |
101 |
console.log("Disconnected !! reconnection hub id :" + $.connection.hub.id); |
102 |
console.log("Connected, transport = " + $.connection.hub.transport.name); |
103 | |
104 |
}) |
105 |
.fail(function () {
|
106 |
console.log("failed");
|
107 |
}); |
108 | |
109 |
}); |
110 | |
111 |
//클라이언트 느리거나 자주 삭제 연결을 검색 하는 경우 발생 합니다.
|
112 |
$.connection.hub.connectionSlow(function () { |
113 |
console.log('We are currently experiencing difficulties with the connection.')
|
114 |
}); |
115 | |
116 |
})(); |
117 | |
118 |
var TableAddData = function (type, addData, projStat) { |
119 | |
120 |
var addRow = null; |
121 |
var targetTable = null; |
122 | |
123 |
if (type == GLOBAL_REQUEST_NAME.Convert) {
|
124 | |
125 |
targetTable = $("#ConvertList").DataTable(); |
126 | |
127 |
} else if (type == GLOBAL_REQUEST_NAME.Merge) { |
128 | |
129 |
targetTable = $("#MergePdfList").DataTable(); |
130 | |
131 |
} |
132 | |
133 |
targetTable.ajax.reload(); |
134 | |
135 |
} |
136 | |
137 |
var updateProjectTable = function (projData) { |
138 | |
139 |
var projectListTable = $("#ProjectList").DataTable(); |
140 | |
141 |
for (var idx = 0; idx < projectListTable.rows().count(); idx++) { |
142 | |
143 |
var thisRow = projectListTable.row(idx);
|
144 |
var rowData = thisRow.data();
|
145 | |
146 |
if (rowData[0] === projData["ProjectNO"]) { |
147 | |
148 |
rowData[STATUS_DEFAULT_INDEX.add] = projData["Insert"];
|
149 |
rowData[STATUS_DEFAULT_INDEX.wait] = projData["Wait"];
|
150 |
rowData[STATUS_DEFAULT_INDEX.process] = projData["Crop"];
|
151 |
rowData[STATUS_DEFAULT_INDEX.success] = projData["Success"];
|
152 |
rowData[STATUS_DEFAULT_INDEX.error] = projData["Error"];
|
153 |
rowData[STATUS_DEFAULT_INDEX.entrie] = projData["Entire"];
|
154 | |
155 |
thisRow.data(rowData).draw(false);
|
156 |
//convTable.draw(false);
|
157 | |
158 |
break;
|
159 | |
160 |
} |
161 | |
162 |
}; |
163 |
} |
164 | |
165 |
var updateConvertTable = function (convData, status) { |
166 | |
167 |
var changeData = convData;
|
168 |
var convTable = $("#ConvertList").DataTable(); |
169 | |
170 |
for (var i = 0; i < convTable.rows().count(); i++) { |
171 | |
172 |
var targetRow = convTable.row(i);
|
173 |
//var rowData = targetRow.data();
|
174 |
var dataCells = $(targetRow.node()).find("td"); |
175 | |
176 |
if (targetRow.data()["ID"] == changeData["ID"]) { |
177 | |
178 |
// 변경될 데이터
|
179 |
var COLUMN_FIX_NO = initConverDocumentColumn();
|
180 | |
181 |
for (var item in COLUMN_FIX_NO) { |
182 | |
183 |
var fixCol = COLUMN_FIX_NO[item];
|
184 |
var cellData = $(dataCells[fixCol.index]).text() |
185 | |
186 |
switch (fixCol.key) {
|
187 |
case COLUMN_FIX_NO.totalPage.key:
|
188 | |
189 |
if (cellData != changeData[fixCol.key]) {
|
190 |
convTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).data(changeData[fixCol.key]);
|
191 |
} |
192 | |
193 |
break;
|
194 | |
195 |
case COLUMN_FIX_NO.createdDate.key:
|
196 | |
197 |
var viewCreatedDate = viewDate(changeData[fixCol.key]);
|
198 |
if (cellData != viewCreatedDate) {
|
199 |
convTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).data(viewCreatedDate);
|
200 |
} |
201 |
break;
|
202 | |
203 |
case COLUMN_FIX_NO.currentPage.key:
|
204 | |
205 |
var targetNode = $(convTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).node()) |
206 |
var targetNodeData = parseInt(convTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).data()) |
207 | |
208 |
if (targetNodeData !== changeData[fixCol.key]) {
|
209 |
targetNode.addClass("update-row");
|
210 |
} else {
|
211 |
targetNode.removeClass("update-row");
|
212 |
} |
213 | |
214 |
convTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).data(changeData[fixCol.key]);
|
215 | |
216 |
break;
|
217 |
case COLUMN_FIX_NO.startDateTime.key:
|
218 | |
219 |
var viewStartDate = viewDate(changeData[fixCol.key]);
|
220 |
if (cellData != viewStartDate) {
|
221 |
convTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).data(viewStartDate);
|
222 |
} |
223 | |
224 |
break;
|
225 |
case COLUMN_FIX_NO.endDateTime.key:
|
226 | |
227 |
var viewEndDate = viewDate(changeData[fixCol.key]);
|
228 |
if (cellData != viewEndDate) {
|
229 |
convTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).data(viewEndDate);
|
230 |
} |
231 | |
232 |
break;
|
233 |
case COLUMN_FIX_NO.converTime.key:
|
234 | |
235 |
var viewConvertDate = calcDate(changeData[COLUMN_FIX_NO.startDateTime.key], changeData[COLUMN_FIX_NO.endDateTime.key]);
|
236 |
if (cellData != viewConvertDate) {
|
237 |
convTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).data(viewConvertDate);
|
238 |
} |
239 | |
240 |
break;
|
241 |
case COLUMN_FIX_NO.status.key:
|
242 | |
243 |
var statConvert = pdfStatusConvert(changeData[COLUMN_FIX_NO.status.key], status)
|
244 | |
245 |
// 성공 상태로 바뀌면 Convert URL , Viewinfo Data 를 가져와야 한다.
|
246 |
if (cellData != statConvert) {
|
247 | |
248 |
convTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).data(statConvert);
|
249 | |
250 |
if (changeData[COLUMN_FIX_NO.status.key] == COMPLETE_FIX_NO) {
|
251 |
completeConverting(changeData, dataCells); |
252 |
} |
253 | |
254 |
} |
255 |
break;
|
256 | |
257 |
} |
258 | |
259 |
} |
260 | |
261 |
return false; |
262 | |
263 |
} |
264 |
} |
265 | |
266 |
} |
267 | |
268 |
var completeConverting = function (completeData, element) { |
269 | |
270 |
$.ajax({
|
271 |
url: "/api/convert/complete", |
272 |
type: "POST", |
273 |
headers: transportHeader(),
|
274 |
data: completeData,
|
275 |
success: function (ret) { |
276 | |
277 |
var colNum = initConverDocumentColumn();
|
278 |
var convertTable = $("#ConvertList").DataTable(); |
279 |
var tableData = convertTable.rows().data();
|
280 | |
281 |
for (var i = 0; i < tableData.length; i++) { |
282 | |
283 |
var delData = tableData[i];
|
284 | |
285 |
if (delData[0] == ret["ID"]) { |
286 | |
287 |
// view info
|
288 |
$(convertTable.row(i).column(colNum.viewInfo.index).cell($(element[colNum.viewInfo.index])).node()).children().attr("href", "kcom://" + ret["ViewInfo"]).text("View"); |
289 |
// document url
|
290 |
$(convertTable.row(i).column(colNum.convertURL.index).cell($(element[colNum.convertURL.index])).node()).children().attr("href", ret["ConvertURL"]).text("PDF"); |
291 | |
292 |
} |
293 |
} |
294 | |
295 |
} |
296 |
}) |
297 |
} |
298 | |
299 |
var deleteConvertTable = function (data) { |
300 | |
301 |
var convertTable = $("#ConvertList").DataTable(); |
302 |
var tableData = convertTable.rows().data();
|
303 |
convertTable.row("#" + data["ID"]).remove().draw(false); |
304 | |
305 |
} |
306 | |
307 | |
308 |
var updateMergeTable = function (mergeData, status) { |
309 | |
310 |
var MergeTable = $("#MergePdfList").DataTable(); |
311 |
var changeData = mergeData;
|
312 |
// change type 3 : update
|
313 |
for (var i = 0; i < MergeTable.rows().count(); i++) { |
314 | |
315 |
var targetRow = MergeTable.row(i);
|
316 |
//var rowData = targetRow.data();
|
317 |
var dataCells = $(targetRow.node()).find("td"); |
318 |
var rowData = targetRow.data();
|
319 | |
320 |
if (rowData["ID"] == changeData["ID"]) { |
321 | |
322 |
// 변경될 데이터
|
323 | |
324 |
var COLUMN_FIX_NO = initFinalDocumentColumn();
|
325 | |
326 |
for (var item in COLUMN_FIX_NO) { |
327 | |
328 |
var fixCol = COLUMN_FIX_NO[item];
|
329 |
var cellData = $(dataCells[fixCol.index]).text() |
330 | |
331 |
switch (fixCol.key) {
|
332 |
case COLUMN_FIX_NO.totalPage.key:
|
333 | |
334 |
if (cellData != changeData[fixCol.key]) {
|
335 |
MergeTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).data(changeData[fixCol.key]);
|
336 |
} |
337 | |
338 | |
339 |
break;
|
340 | |
341 |
case COLUMN_FIX_NO.createdDate.key:
|
342 | |
343 |
var viewCreatedDate = viewDate(changeData[fixCol.key]);
|
344 |
if (cellData != viewCreatedDate) {
|
345 |
MergeTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).data(viewCreatedDate);
|
346 |
} |
347 | |
348 | |
349 |
break;
|
350 | |
351 |
case COLUMN_FIX_NO.currentPage.key:
|
352 | |
353 |
var targetNode = $(MergeTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).node()) |
354 |
var targetNodeData = parseInt(MergeTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).data()) |
355 | |
356 |
if (targetNodeData !== changeData[fixCol.key]) {
|
357 |
targetNode.addClass("update-row");
|
358 |
} else {
|
359 |
targetNode.removeClass("update-row");
|
360 |
} |
361 | |
362 |
MergeTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).data(changeData[fixCol.key]);
|
363 | |
364 |
break;
|
365 |
case COLUMN_FIX_NO.startDateTime.key:
|
366 | |
367 |
var viewStartDate = viewDate(changeData[fixCol.key]);
|
368 |
if (cellData != viewStartDate) {
|
369 |
MergeTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).data(viewStartDate);
|
370 |
} |
371 | |
372 | |
373 |
break;
|
374 |
case COLUMN_FIX_NO.endDateTime.key:
|
375 | |
376 |
var viewEndDate = viewDate(changeData[fixCol.key]);
|
377 |
if (cellData != viewEndDate) {
|
378 |
MergeTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).data(viewEndDate);
|
379 |
} |
380 | |
381 | |
382 |
break;
|
383 |
case COLUMN_FIX_NO.converTime.key:
|
384 | |
385 |
var viewConvertDate = calcDate(changeData[COLUMN_FIX_NO.startDateTime.key], changeData[COLUMN_FIX_NO.endDateTime.key]);
|
386 |
if (cellData != viewConvertDate) {
|
387 |
MergeTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).data(viewConvertDate);
|
388 |
} |
389 | |
390 | |
391 |
break;
|
392 |
case COLUMN_FIX_NO.status.key:
|
393 | |
394 |
var statConvert = pdfStatusConvert(changeData[COLUMN_FIX_NO.status.key], status)
|
395 |
if (cellData != statConvert) {
|
396 | |
397 |
MergeTable.row(i).column(fixCol.index).cell($(dataCells[fixCol.index])).data(statConvert);
|
398 | |
399 |
if (changeData[COLUMN_FIX_NO.status.key] == COMPLETE_FIX_NO) {
|
400 |
completeMerge(changeData, dataCells); |
401 |
} |
402 | |
403 |
} |
404 | |
405 |
break;
|
406 | |
407 |
} |
408 | |
409 |
} |
410 | |
411 |
return false; |
412 | |
413 |
} |
414 | |
415 |
} |
416 |
} |
417 | |
418 |
var completeMerge = function (completeData, element) { |
419 | |
420 |
$.ajax({
|
421 |
url: "/api/merge/complete", |
422 |
type: "POST", |
423 |
headers: transportHeader(),
|
424 |
data: completeData,
|
425 |
success: function (ret) { |
426 | |
427 |
var colNum = initFinalDocumentColumn();
|
428 |
var MergeTable = $("#MergePdfList").DataTable(); |
429 |
var tableData = MergeTable.rows().data();
|
430 | |
431 |
for (var i = 0; i < tableData.length; i++) { |
432 | |
433 |
var delData = tableData[i];
|
434 | |
435 |
if (delData[0] == ret["ID"]) { |
436 | |
437 |
// view info
|
438 |
$(MergeTable.row(i).column(colNum.viewInfo.index).cell($(element[colNum.viewInfo.index])).node()).children().attr("href", "kcom://" + ret["ViewInfo"]).text("View"); |
439 |
// document url
|
440 |
$(MergeTable.row(i).column(colNum.finalDocumentURL.index).cell($(element[colNum.finalDocumentURL.index])).node()).children().attr("href", ret["MergeURL"]).text("PDF"); |
441 |
} |
442 |
} |
443 | |
444 |
} |
445 | |
446 |
}) |
447 | |
448 |
} |
449 | |
450 |
var deleteMergeTable = function (data) { |
451 | |
452 |
var MergeTable = $("#MergePdfList").DataTable(); |
453 |
var tableData = MergeTable.rows().data();
|
454 |
MergeTable.row("#" + data["ID"]).remove().draw(false); |
455 |
} |
456 | |
457 |
var deleteDocument_Complete = function () { |
458 | |
459 |
var notify = $.notify({ |
460 |
// options
|
461 |
icon: 'glyphicon glyphicon-warning-sign', |
462 |
message: 'Hello World' |
463 |
}, { |
464 |
// settings
|
465 |
type: 'success', |
466 |
allow_dismiss: false, |
467 |
newest_on_top: true, |
468 |
offset: 25, |
469 |
delay: 2000, |
470 |
animate: {
|
471 |
enter: 'animated fadeInDown', |
472 |
exit: 'animated fadeOutUp' |
473 |
}, |
474 |
placement: {
|
475 |
from: "top", |
476 |
align: "right" |
477 |
}, |
478 |
spacing: 10, |
479 |
icon_type: 'class', |
480 |
mouse_over: null, |
481 |
}); |
482 | |
483 |
//notify.update("message", "test");
|
484 | |
485 |
} |
486 | |
487 | |
488 |
var pdfStatusConvert = function (docStatus, list) { |
489 |
var statusNo = parseInt(docStatus);
|
490 |
for (var i = 0; i < list.length; i++) { |
491 |
if (parseInt(list[i].Value) === statusNo) {
|
492 |
return list[i].Property
|
493 |
} |
494 |
} |
495 |
} |