Marthee commited on
Commit
8cb34de
·
verified ·
1 Parent(s): a0a4ce3

Upload tableDetection.html

Browse files
Files changed (1) hide show
  1. templates/tableDetection.html +1170 -0
templates/tableDetection.html ADDED
@@ -0,0 +1,1170 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ <!DOCTYPE html>
2
+ <html lang="en" dir="ltr">
3
+ <head>
4
+
5
+ <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
6
+ <link href="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.3/css/select2.min.css" rel="stylesheet"/>
7
+ <script src="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.3/js/select2.min.js"></script>
8
+ <script src="https://cdn.plot.ly/plotly-latest.min.js"></script>
9
+
10
+
11
+
12
+ <link rel="stylesheet" href="https://use.typekit.net/zos0ars.css">
13
+ <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">
14
+ <link rel="stylesheet" href="static/style.css">
15
+ <link rel="stylesheet" href="static/MenuStyle.css">
16
+ <link rel="stylesheet" href="static/LegendPageStyle.css">
17
+ <link rel="stylesheet" href="static/popups.css">
18
+ <link rel="stylesheet" href="static/IMG-Larger.css">
19
+ <link rel="stylesheet" href="static/searchButton.css">
20
+ <meta charset="utf-8">
21
+ <title>ADR Console</title>
22
+ <link rel = "icon" type = "image/png" sizes = "180x154" href = "static/images/TSAlogoCropped180x154.png">
23
+ <link rel = "icon" type = "image/png" sizes = "32x27" href = "static/images/TSAlogoCropped32x27.png">
24
+ <link rel = "icon" type = "image/png" sizes = "16x14" href = "static/images/TSAlogoCropped16x14.png">
25
+ <link rel = "mask-icon" href = "static/images/TSAlogoCropped180x154.png">
26
+ <link rel = "shortcut icon" href = "static/images/TSAlogoCropped180x154.png">
27
+
28
+ <script src="https://cdn.anychart.com/releases/8.9.0/js/anychart-core.min.js"></script>
29
+ <script src="https://cdn.anychart.com/releases/8.9.0/js/anychart-sunburst.min.js"></script>
30
+ <script src="https://cdn.anychart.com/releases/8.9.0/js/anychart-data-adapter.min.js"></script>
31
+
32
+
33
+
34
+ </head>
35
+ <body >
36
+ <div id="all">
37
+ {% include 'loading.html' %}
38
+ </div>
39
+ <!--Main tab links-->
40
+ <div class="tab" >
41
+ <div class="container" id="toggle">
42
+ <div class="bar1"></div>
43
+ <div class="bar2"></div>
44
+ <div class="bar3"></div>
45
+ </div>
46
+
47
+ <button class="tablinks" id="pagetitle" onclick="openTab(event, 'home')">ADR Console <i class="fa fa-home" > </i></button>
48
+ <!-- <button class="tablinks" id="LegendHist" onclick="openTab(event, 'legends')">Legends History <i class="fa fa-caret-down"></i></button> -->
49
+ <a class="tablinks" id="LegendHist" href="{{ url_for('legendDirectory') }}">Legends History <i class="fa fa-caret-down"></i></a>
50
+ <button class="dropbtn" onclick="userguideclick()"><img id="infoImg" src=""></button>
51
+ </div>
52
+
53
+
54
+ <div id="mySidebar" class="slide-out">
55
+ <div id="menuOptions">
56
+ <li><a href="{{ url_for('measurementConsoleFn') }}">Measure Plans </a></li>
57
+ <li><a href="{{ url_for('searchDocument') }}">Search in Documents</a></li>
58
+ <li onclick=redirectOmarSearch()>Table Detection</li>
59
+
60
+ </div>
61
+ </div>
62
+
63
+ <form method="post" id="myForm" enctype="multipart/form-data">
64
+
65
+
66
+ <div id ="">
67
+ <select name="selectproj" class="selectionsProj" id="selectionsProjid" required > </select>
68
+ </div>
69
+
70
+ <div id ="projectpart">
71
+ <select name="selectprojp" class="selectionsProjp" id="selectionsProjpid" required> </select>
72
+ </div>
73
+
74
+ <div id ="projectsection">
75
+ <select name="selectprojs" class="selectionsProjs" onchange=getproj() required> </select>
76
+ </div>
77
+
78
+
79
+ <div id ="tomeasurediv">
80
+ <div>
81
+ <label id="measureLabel">Document To Measure</label>
82
+ <input type="search" onkeyup=filterFunction(this.id) id="tomeasureSearchInput">
83
+ <!-- <button id="refreshDropboxButtonID"></button> -->
84
+ <i hidden class="fa fa-dropbox fa-lg" id="refreshDropboxButtonID">
85
+ <span class="dropboxtip">The console updates projects retrieved from Dropbox automatically at 9:00 am and 9:00 p.m. If you need to access any projects in between, just click on this button. Please note that it will refresh the files related to the project you chose only.</span> </i>
86
+
87
+ </div>
88
+ <div id="measureCheckbox">
89
+ <!-- <select style="margin-left: -1%;" hidden name="measureselectname" id="measureselectid" multiple size="5"></select> -->
90
+ <div id="measureContainer" hidden required></div>
91
+ </div>
92
+ </div>
93
+
94
+ <button id="measureADRbutton">Table Detect</button>
95
+
96
+ </form>
97
+
98
+ <div id="progressBar" hidden>
99
+ <div id="progress">0%</div>
100
+ </div>
101
+
102
+ <!-- Modal popup box -->
103
+ <div id="mpopupBox" class="mpopup" name="tobeclosed">
104
+ <!-- Modal content -->
105
+ <div class="modal-content">
106
+ <div class="modal-header">
107
+ <button type="button" class="closeModal" data-dismiss="modal">&times;</button>
108
+ <h2 id="TopTextModal">Error</h2>
109
+ </div>
110
+ <div class="modal-body">
111
+ <p id="modal-bodyText">
112
+ </p>
113
+ <br>
114
+ </div>
115
+
116
+ </div>
117
+ </div>
118
+
119
+ <!-- Modal popup box -->
120
+ <div id="mpopupBox" class="mpopup" name="tobeclosed">
121
+ <!-- Modal content -->
122
+ <div class="modal-content">
123
+ <div class="modal-header">
124
+ <button type="button" class="closeModal" data-dismiss="modal">&times;</button>
125
+ <h2 id="TopTextModal">Error</h2>
126
+ </div>
127
+ <div class="modal-body">
128
+ <p id="modal-bodyText">
129
+ </p>
130
+ <br>
131
+ </div>
132
+
133
+ </div>
134
+ </div>
135
+
136
+ <div id="loading" hidden> </div>
137
+
138
+ </body>
139
+ </html>
140
+
141
+ <script>
142
+
143
+ var closeButtons = document.querySelectorAll(".closeModal");
144
+ var allCloseDivs = document.getElementsByName("tobeclosed");
145
+
146
+ closeButtons.forEach(function(button) {
147
+ button.addEventListener("click", function() {
148
+ allCloseDivs.forEach(function(div) {
149
+ div.style.display = "none";
150
+ });
151
+ });
152
+ });
153
+
154
+ document.getElementById("myForm").addEventListener("submit", function (e) {
155
+ e.preventDefault(); // Prevent form submission
156
+ let isChecked = document.querySelector('input[name="measureCheckbox"]:checked') !== null;
157
+ // let sectionNumber = projsec.value; // Ensure projsec is defined
158
+ // let isRelvClicked = document.querySelector(".relv-item[style*='background-color']") !== null;
159
+
160
+ let TopTextModal = document.getElementById("TopTextModal");
161
+ TopTextModal.textContent = "Warning: Missing Inputs";
162
+ if (!isChecked){
163
+ PopupElement.textContent = "Please select at least one project from 'Documents to Measure' before proceeding!";
164
+ ShowPopUp();
165
+ return;
166
+ }
167
+
168
+
169
+
170
+ // If validation passes, proceed with form submission
171
+ getData(e.target);
172
+ });
173
+
174
+
175
+ function getData(form) {
176
+
177
+ document.getElementById("loading").hidden = false;
178
+
179
+ document.getElementById('measureADRbutton').setAttribute('disabled',true);
180
+ document.getElementById('measureADRbutton').style.cursor='not-allowed';
181
+ document.getElementById('measureADRbutton').style.boxShadow = 'none';
182
+ document.getElementById('measureADRbutton').style.color = 'white';
183
+ document.getElementById('measureADRbutton').style.backgroundColor="rgb(154,152,152)";
184
+
185
+
186
+ var formData = new FormData(form);
187
+
188
+
189
+
190
+
191
+ // clearInterval(interval)
192
+ val=0;
193
+ answers=[];
194
+ tomeasureproj='';
195
+ pdfpath=[];
196
+ formvalues=Object.fromEntries(formData);
197
+
198
+ tomeasureproj=formvalues['measureCheckbox']; //proj name
199
+
200
+ answers.push(tomeasureproj);
201
+ formData.append('answers',JSON.stringify(answers))
202
+
203
+ // Place this once in your JS before any $.ajax calls
204
+ $.ajaxTransport("+binary", function(options, originalOptions, jqXHR) {
205
+ if (window.FormData && (
206
+ (options.dataType && options.dataType === "binary") ||
207
+ (options.data && ((window.ArrayBuffer && options.data instanceof ArrayBuffer) ||
208
+ (window.Blob && options.data instanceof Blob)))
209
+ )) {
210
+ return {
211
+ send: function(headers, callback) {
212
+ const xhr = new XMLHttpRequest();
213
+ xhr.open(options.type, options.url, options.async ?? true,
214
+ options.username, options.password);
215
+ // Apply custom fields like responseType
216
+ xhr.responseType = options.responseType || "blob";
217
+ if (options.xhrFields) {
218
+ for (const field in options.xhrFields) {
219
+ xhr[field] = options.xhrFields[field];
220
+ }
221
+ }
222
+ xhr.onload = function() {
223
+ // Package the response as the declared dataType
224
+ const data = {};
225
+ data[options.dataType] = xhr.response;
226
+ callback(xhr.status, xhr.statusText, data, xhr.getAllResponseHeaders());
227
+ };
228
+ xhr.send(options.data || null);
229
+ },
230
+ abort: function() {
231
+ jqXHR.abort();
232
+ }
233
+ };
234
+ }
235
+ });
236
+
237
+ $.ajax({
238
+ // type: "POST",
239
+ // url: "/savedetectedtables/",
240
+ // // contentType: "application/json", // set content type header to use Flask response.get_json()
241
+ // data: formData,// convert data/object to JSON to send
242
+ // processData: false, // Prevent jQuery from automatically processing the data
243
+ // contentType: false,
244
+ // xhr: function() {
245
+ // const x = $.ajaxSettings.xhr();
246
+ // x.responseType = "blob"; // set blob mode
247
+ // return x;
248
+ // },
249
+ url: "/savedetectedtables/",
250
+ method: "POST",
251
+ data: formData,
252
+ processData: false,
253
+ contentType: false,
254
+ dataType: 'binary', // match your transport
255
+ responseType: 'blob', // tell the transport to use blob
256
+
257
+ success: function(blob) {
258
+ console.log(blob);
259
+ // downloadPdf(data,'detected_tables.xlsx')
260
+ console.log('typeof(blob) = ',typeof(blob))
261
+ downloadPdf(blob,'detected_tables.xlsx')
262
+
263
+
264
+ },
265
+ error: function(err) {
266
+ var TopTextModal = document.getElementById("TopTextModal");
267
+ TopTextModal.textContent='Error'
268
+ PopupElement.textContent='Error occured. Refresh and try again. If the error continues, please contact the ADR team to fix it. ';
269
+ ShowPopUp();
270
+
271
+ }
272
+ })
273
+ .done(function(data){
274
+ console.log(data)
275
+ document.getElementById("loading").hidden = true;
276
+ document.getElementById('measureADRbutton').removeAttribute('disabled');
277
+ document.getElementById('measureADRbutton').style.cursor='pointer';
278
+ document.getElementById('measureADRbutton').style.color = 'white';
279
+ document.getElementById('measureADRbutton').style.backgroundColor="#16c72e";
280
+ document.getElementById('measureADRbutton').style.padding='10px 102px';
281
+ document.getElementById('measureADRbutton').addEventListener('mouseover',function(){
282
+ document.getElementById('measureADRbutton').style.color='black';
283
+ document.getElementById('measureADRbutton').style.boxShadow=' 0 0 8px 2px #16c72e';
284
+ })
285
+ document.getElementById('measureADRbutton').addEventListener('mouseout',function(){
286
+ document.getElementById('measureADRbutton').style.color='white';
287
+ document.getElementById('measureADRbutton').style.boxShadow='none';
288
+ });
289
+
290
+ // downloadPdf(data,'detected_tables.xlsx')
291
+ // downloadPdf(blob,'detected_tables.xlsx')
292
+
293
+ })
294
+
295
+
296
+
297
+ }
298
+
299
+ document.getElementById('measureADRbutton').onclick= function()
300
+ {
301
+ if (!measSelect.value) {
302
+ measSelect.style.boxShadow = '0 0 8px 2px rgb(255, 0, 0)';
303
+ measSelect.setAttribute("required", "")
304
+ }
305
+ }
306
+ document.getElementById('measureADRbutton').addEventListener('click',function(){
307
+ if (!document.getElementsByClassName('selectionsProj')[0].value)
308
+ document.getElementsByClassName('selectionsProj')[0].style.boxShadow='0 0 8px 2px rgb(255, 0, 0)';
309
+ if (!document.getElementsByClassName('selectionsProjp')[0].value)
310
+ document.getElementsByClassName('selectionsProjp')[0].style.boxShadow='0 0 8px 2px rgb(255, 0, 0)';
311
+ if (!document.getElementsByClassName('selectionsProjs')[0].value)
312
+ document.getElementsByClassName('selectionsProjs')[0].style.boxShadow='0 0 8px 2px rgb(255, 0, 0)';
313
+ //___________________________________________________________________________________________________________
314
+ //___________________________________________________________________________________________________________
315
+ if (document.getElementById('imgContainer')) {
316
+ document.getElementById('imgContainer').innerHTML = '';
317
+ }
318
+ });
319
+ var mpopup = document.getElementById('mpopupBox');
320
+ // Select close action element
321
+ // var close = document.getElementsByClassName("closeModal")[0];
322
+ function ShowPopUp(){
323
+ // Open modal
324
+ mpopup.style.display = "block";
325
+ }
326
+ // Close modal once close element is clicked
327
+ // close.onclick = function() {
328
+ // mpopup.style.display = "none";
329
+ // };
330
+ // Close modal when user clicks outside of the modal box
331
+ window.onclick = function(event) {
332
+ if (event.target == mpopup) {
333
+ mpopup.style.display = "none";
334
+ }
335
+ };
336
+ // closeDialog.onclick = function() {
337
+ // dialog_container.style.display = "none";
338
+ // };
339
+
340
+ var dialog_container = document.getElementById('dialog-container');
341
+ // Select close action element
342
+ // var closeDialog = document.getElementsByClassName("closeModal")[0];
343
+ function ShowPopUpWarning(){
344
+ // Open modal
345
+ dialog_container.style.display = "block";
346
+ }
347
+ // Close modal once close element is clicked
348
+ // closeDialog.onclick = function() {
349
+ // console.log()
350
+ // dialog_container.style.display = "none";
351
+ // };
352
+ // Close modal when user clicks outside of the modal box
353
+ window.onclick = function(event) {
354
+ if (event.target == dialog_container) {
355
+ dialog_container.style.display = "none";
356
+ }
357
+ };
358
+
359
+ PopupElement=document.getElementById('modal-bodyText');
360
+
361
+ var ActiveSections=['1.0','2.1','2.6','2.7','2.8','3.2','3.3']
362
+
363
+ var menuItems = document.querySelectorAll("#UserGuidemenuOptions li");
364
+
365
+ menuItems.forEach(function (item) {
366
+ // Extract the section number (first part of the text)
367
+ var sectionNumber = item.textContent.trim().split(" ")[0];
368
+
369
+ // If the section is not in ActiveSections, disable it
370
+ if (!ActiveSections.includes(sectionNumber)) {
371
+ item.id = "disabledSection"; // Assign ID
372
+ item.style.color = "#bdbcbc"; // Greyed-out text
373
+ item.style.cursor = "not-allowed"; // Change cursor
374
+ item.onclick = null; // Disable clicking
375
+ }
376
+ });
377
+
378
+
379
+ function updateProgressBar(value) {
380
+ const progressBar = document.getElementById('progress');
381
+ progressBar.style.width = value + '%';
382
+ progressBar.innerText = Math.round(value) + '%';
383
+ }
384
+
385
+ function redirectOmarSearch(){
386
+ $toggle.classList.toggle("change");
387
+ var isOpen = $mySidebar.classList.contains('slide-out');
388
+ $mySidebar.setAttribute('class', isOpen ? 'slide-in' : 'slide-out');
389
+ w3_close()
390
+
391
+ }
392
+
393
+ sectionSelect=document.getElementById('section-select');
394
+ $(sectionSelect).select2({
395
+ closeOnSelect: true,
396
+ width:'20ch'
397
+
398
+ });
399
+ // add project names to first dropdown from google sheet
400
+ firstdropdown=document.getElementsByClassName('selectionsProj')[0];
401
+ seconddropdown=document.getElementsByClassName('selectionsProjp')[0];
402
+ thirddropdown=document.getElementsByClassName('selectionsProjs')[0];
403
+
404
+
405
+ $(firstdropdown).select2({
406
+ placeholder:'Projects',
407
+ closeOnSelect: true,
408
+ width:'51ch'
409
+
410
+ });
411
+
412
+ $(seconddropdown).select2({
413
+ placeholder:'Project Parts',
414
+ closeOnSelect: true,
415
+ width:'51ch'
416
+ });
417
+ $(thirddropdown).select2({
418
+ placeholder:'Sections',
419
+ closeOnSelect: true,
420
+ width:'51ch'
421
+ });
422
+ var measSelect = document.getElementById("measureselectid");
423
+
424
+ // var relvSelect = document.getElementById("relvselectid");
425
+ document.getElementById("all").style.display = "block";
426
+
427
+ PrjNamesArray=[];
428
+ PrjPartsArray=[];
429
+ PrjSectionsArray=[];
430
+ var partsArrwithID=[];
431
+ var firstDpwnValue;
432
+ var prjids=[]
433
+
434
+ displayprjnames()
435
+ function displayprjnames(){
436
+
437
+ var eventSource = new EventSource('/getprojectnames/');
438
+ document.getElementById('progressBar').removeAttribute('hidden')
439
+ document.getElementById('progressBar').style.display='block';
440
+ eventSource.onmessage = function (event) {
441
+ var progress = parseInt(event.data); // Progress value from Flask
442
+ if (progress <= 100) {
443
+ console.log(progress); // Log progress for debugging
444
+ document.getElementById('progress').style.width = progress + '%';
445
+ document.getElementById('progress').textContent = progress + '%';
446
+ } else {
447
+ // Final data handling when progress reaches 100%
448
+ console.log('Process completed!');
449
+
450
+ // Parse and handle the final response data (documentsToMeasure, RelevantDocuments, extracted_path)
451
+ var data = JSON.parse(event.data); // Assuming the result is a JSON array
452
+ console.log('Final result:', data);
453
+ // You can use this data to update your page or handle it accordingly
454
+
455
+ eventSource.close(); // Close the connection when finished
456
+ document.getElementById('progressBar').setAttribute('hidden',true)
457
+ document.getElementById('progressBar').style.display='none';
458
+ document.getElementById('progress').style.width = '0%'; // Reset progress for the next process
459
+ document.getElementById('progress').textContent = '0%';
460
+
461
+ document.getElementById("all").style.display = "none";
462
+ prjids=data[1];
463
+ var op0 = document.createElement("OPTION") ;
464
+ op0.text= 'Projects'
465
+ op0.value= "";
466
+ op0.hidden=true;
467
+ firstdropdown.add(op0);
468
+ for (let i=0;i<data[0].length;i++)
469
+ {
470
+ opt=document.createElement("option");
471
+ opt.textContent=data[0][i];
472
+ opt.text=data[0][i];
473
+ firstdropdown.append(opt);
474
+ PrjNamesArray.push(data[0][i]);
475
+ }
476
+
477
+ }
478
+ }
479
+
480
+
481
+ eventSource.onerror = function (error) {
482
+ console.error('Error occurred:', error);
483
+ eventSource.close(); // Close on error
484
+ PopupElement.textContent='Error occured while retrieving the Project Names. Refresh and try again. If the error continues, please contact the ADR team to fix it. ';
485
+ ShowPopUp();
486
+ };
487
+ }
488
+ /*Get chosen value and send to flask to get project parts*/
489
+
490
+ $(firstdropdown).on("change", function (e) {
491
+ console.log('clickeds')
492
+ firstDpwnValue=firstdropdown.value;
493
+ seconddropdown.innerHTML='';
494
+ var op0 = document.createElement("OPTION") ;
495
+ op0.text= 'Project Part'
496
+ op0.value= "";
497
+ op0.hidden=true;
498
+ seconddropdown.add(op0);
499
+ var ii, L = seconddropdown.options.length - 1;
500
+ for(ii = L; ii >= 0; ii--) {
501
+ if (seconddropdown.options[ii].value)
502
+ seconddropdown.remove(ii);
503
+ }
504
+
505
+ displayprojparts(prjids[(firstdropdown.selectedIndex)-1]);
506
+ })
507
+ var partsArrIDsonly=[]
508
+ function displayprojparts(val){
509
+ document.getElementById("all").style.display = "block";
510
+ console.log(val)
511
+ $.get('/getprojectparts/'+JSON.stringify(val))
512
+ .success(function(data){
513
+ document.getElementById("all").style.display = "none";
514
+ partsArrwithID= data[0];
515
+ partsArrIDsonly= data[1];
516
+
517
+ for (let i=0;i<data[0].length;i++)
518
+ {
519
+ opt=document.createElement("option");
520
+ opt.value=data[0][i];
521
+ opt.text=data[0][i];
522
+ seconddropdown.append(opt);
523
+ PrjPartsArray.push(data[0][i]);
524
+
525
+ }
526
+
527
+ })
528
+ .error(function(jqXHR, textStatus, errorThrown) {
529
+ PopupElement.textContent='Error occured while retrieving the Project Parts. Refresh and try again. If the error continues, please contact the ADR team to fix it. ';
530
+ ShowPopUp();
531
+ });
532
+ }
533
+ $(seconddropdown).on("change", function (e) {
534
+ thirddropdown.innerHTML='';
535
+ var op0 = document.createElement("OPTION") ;
536
+ op0.text= 'Section'
537
+ op0.value= "";
538
+ op0.hidden=true;
539
+ thirddropdown.add(op0);
540
+ displayprojsections(prjids[(firstdropdown.selectedIndex)-1],partsArrIDsonly[(seconddropdown.selectedIndex)-1]);
541
+ })
542
+ function isValueNotInDropdown(dropdown, value) {
543
+ // const dropdown = document.getElementById(dropdownId);
544
+ const values = Array.from(dropdown.options).map(option => option.value);
545
+ return !values.includes(value); // Check if the value is not in dropdown values
546
+ }
547
+ function displayprojsections(projectid,Partid){
548
+ console.log(seconddropdown.selectedIndex)
549
+ document.getElementById("all").style.display = "block";
550
+ if (measSelect && measSelect.hasChildNodes()) {
551
+ while (measSelect.firstChild) {
552
+ measSelect.removeChild(measSelect.firstChild);
553
+ }
554
+ }
555
+
556
+ // if (relvSelect && relvSelect.hasChildNodes()) {
557
+ // while (relvSelect.firstChild) {
558
+ // relvSelect.removeChild(relvSelect.firstChild);
559
+ // }
560
+ // }
561
+ $.get('/getprojectsections/' + JSON.stringify([projectid, Partid]))
562
+ .done(function(data) {
563
+ document.getElementById("all").style.display = "none";
564
+
565
+ for (let i = 0; i < data.length; i++) {
566
+ let valueDoesNotExist = isValueNotInDropdown(thirddropdown, data[i]);
567
+
568
+ if (valueDoesNotExist) {
569
+ let opt = document.createElement("option");
570
+ opt.value = data[i];
571
+ opt.text = data[i];
572
+
573
+ let isActive = false;
574
+ for (let d = 0; d < ActiveSections.length; d++) {
575
+ if (data[i].startsWith(ActiveSections[d])) {
576
+ isActive = true;
577
+ break; // Exit loop early if active
578
+ }
579
+ }
580
+
581
+ if (!isActive) {
582
+ opt.style.color = '#bdbcbc';
583
+ opt.style.cursor = 'not-allowed';
584
+ opt.setAttribute('disabled', true);
585
+ }
586
+
587
+ thirddropdown.append(opt);
588
+ PrjSectionsArray.push(data[i]);
589
+ }
590
+ }
591
+ })
592
+ .fail(function(jqXHR, textStatus, errorThrown) {
593
+ PopupElement.textContent='Error occured while retrieving the Project Sections. Refresh and try again. If the error continues, please contact the ADR team to fix it. ';
594
+ ShowPopUp();
595
+ });
596
+
597
+ }
598
+
599
+ function filterFunction(id) {
600
+ var input, filter, ul, li, a, i;
601
+ input = document.getElementById(id);
602
+ filter = input.value.toUpperCase();
603
+ if (id.toString().startsWith('tomeasure'))
604
+ a = document.querySelectorAll("#measureContainer .measure-item");
605
+
606
+ // a = document.getElementById("measureselectid").children;
607
+ // else
608
+ // // a = document.getElementById("relvselectid").children;
609
+ // a = document.querySelectorAll("#relvselectid .relv-item");
610
+ // a = div.getElementsByTagName("option");
611
+ for (i = 0; i < a.length; i++) {
612
+ txtValue = a[i].textContent || a[i].innerText;
613
+ if (txtValue.toUpperCase().indexOf(filter) > -1) {
614
+ a[i].style.display = "";
615
+ } else {
616
+ a[i].style.display = "none";
617
+ }
618
+ }
619
+ }
620
+
621
+ function getproj(){
622
+
623
+
624
+ var proj = document.getElementsByClassName("selectionsProj")[0];
625
+ var projectVal=proj.value.toString() //selected project
626
+
627
+ var inputs = document.getElementsByTagName("select")[1]; //second dropdown(project part)
628
+ var p=document.getElementById("selectionsProjpid") //project part
629
+
630
+ var sections = document.getElementsByClassName("selectionsProjs")[0];
631
+
632
+ var eventSource = new EventSource('/getmethod/' + JSON.stringify(projectVal));
633
+ document.getElementById('progressBar').removeAttribute('hidden')
634
+ document.getElementById('progressBar').style.display='block';
635
+ eventSource.onmessage = function (event) {
636
+ var progress = parseInt(event.data); // Progress value from Flask
637
+ if (progress <= 100) {
638
+ console.log(progress); // Log progress for debugging
639
+ document.getElementById('progress').style.width = progress + '%';
640
+ document.getElementById('progress').textContent = progress + '%';
641
+ } else {
642
+ // Final data handling when progress reaches 100%
643
+ console.log('Process completed!');
644
+
645
+ // Parse and handle the final response data (documentsToMeasure, RelevantDocuments, extracted_path)
646
+ var data = JSON.parse(event.data); // Assuming the result is a JSON array
647
+ console.log('Final result:', data);
648
+ // You can use this data to update your page or handle it accordingly
649
+
650
+ eventSource.close(); // Close the connection when finished
651
+ document.getElementById('progressBar').setAttribute('hidden',true)
652
+ document.getElementById('progressBar').style.display='none';
653
+ document.getElementById('progress').style.width = '0%'; // Reset progress for the next process
654
+ document.getElementById('progress').textContent = '0%';
655
+
656
+
657
+ document.getElementById('refreshDropboxButtonID').style.display = "block";
658
+ document.getElementById("all").style.display = "none";
659
+ // if (sections.value.startsWith('3.2') || sections.value.startsWith('3.3') || sections.value.startsWith('2.7') ){
660
+ // document.getElementById('dxfdiv').removeAttribute('hidden');
661
+ // document.getElementById('pdftodxfFile').setAttribute('required',true)
662
+ // }
663
+
664
+ // else{
665
+ // document.getElementById('dxfdiv').setAttribute('hidden',true)
666
+ // }
667
+
668
+ extracted_path=data[2]
669
+ var docsToMeasure=data[0]; //
670
+ // var relvDocs=data[1]
671
+ var projname = document.getElementsByClassName("selectionsProj")[0];
672
+ var projpart = document.getElementsByClassName("selectionsProjp")[0];
673
+ var projsec = document.getElementsByClassName("selectionsProjs")[0];
674
+
675
+ var meas = document.getElementById("measureCheckbox") ;
676
+ // var relv = document.getElementById("relvdiv") ;
677
+ const measids=[];
678
+ // const relvids=[];
679
+ const measoptns=[];
680
+
681
+ // var measSelect = document.getElementById("measureselectid");
682
+ var measSelect = document.getElementById("measureContainer");
683
+
684
+ // var relvSelect = document.getElementById("relvselectid");
685
+ // var levelcheckbox= document.getElementById("levelcheckbox");
686
+
687
+
688
+ measSelect.removeAttribute("hidden");
689
+ // relvSelect.removeAttribute("hidden");
690
+ if (measSelect && measSelect.hasChildNodes()) {
691
+ while (measSelect.firstChild) {
692
+ measSelect.removeChild(measSelect.firstChild);
693
+ }
694
+ }
695
+
696
+ var optn2 = document.createElement("div"); // Use a <div> instead of <option>
697
+ optn2.textContent = 'Select project to measure'; // Set text content
698
+ optn2.hidden = true; // Keep it hidden
699
+ optn2.id = 'hidden';
700
+
701
+ measSelect.appendChild(optn2); // Append to div instead of .add()
702
+ document.getElementById("hidden").required = true;
703
+
704
+
705
+ // if (relvSelect && relvSelect.hasChildNodes()) {
706
+ // while (relvSelect.firstChild) {
707
+ // relvSelect.removeChild(relvSelect.firstChild);
708
+ // }
709
+ // }
710
+ const nameSet = new Set(); // To track unique names
711
+ // const nameSetRelv = new Set(); // To track unique names
712
+
713
+ // Action foconst nameSet = new Set(); // To track unique names
714
+
715
+ // Action for when the checkbox is clicked
716
+ function handleCheckboxChange(event) {
717
+ // Uncheck all checkboxes before checking the current one
718
+ document.querySelectorAll('input[name="measureCheckbox"]').forEach(checkbox => {
719
+ checkbox.checked = false;
720
+ });
721
+
722
+ // Check the current checkbox
723
+ event.target.checked = true;
724
+
725
+ // Action when checkbox is clicked (e.g., log the selected project)
726
+ let selectedValue = event.target.value;
727
+ measSelect.value=selectedValue;
728
+ console.log("Selected project:", selectedValue);
729
+
730
+ // Highlight the selected item
731
+ document.querySelectorAll(".measure-item").forEach(item => {
732
+ item.style.backgroundColor = ''; // Reset background color for all items
733
+ });
734
+ event.target.closest(".measure-item").style.backgroundColor = '#d3f8d3'; // Highlight the selected item
735
+
736
+
737
+
738
+ // Show alert immediately to prompt the user
739
+ // if (projsec.value.startsWith('3.2') || projsec.value.startsWith('3.3') || projsec.value.startsWith('2.7')) {
740
+ // // downloadPdf(selectedValue);
741
+ // downloadPdf(selectedValue,'DXF_File_:'+selectedValue)
742
+ // // window.alert("Measure the purple shape drawn on the PDF using Foxit Reader, Bluebeam, or any other external tool, then enter its area and perimeter in your desired scale.");
743
+ // }
744
+ // else{
745
+ // window.alert("Measure the purple shape drawn on the PDF using Foxit Reader, Bluebeam, or any other external tool, then enter its area and perimeter in your desired scale.");
746
+ // }
747
+ canvasimg='';
748
+ ry=[[]];
749
+ // levelcheckbox.checked=false;
750
+ pdfname=selectedValue;
751
+ measSelect.style.boxShadow='none';
752
+
753
+ console.log(projsec.value)
754
+ // if (!(projsec.value.startsWith('2.6') || projsec.value.startsWith('2.8'))) {
755
+ // document.getElementById("all").style.display = "block";
756
+
757
+ // pixelArr=[projname.value, projpart.value,projsec.value, pdfname]
758
+ // var eventSource = new EventSource('/pixelimg/' + JSON.stringify(pixelArr));
759
+ // document.getElementById('progressBar').removeAttribute('hidden')
760
+ // document.getElementById('progressBar').style.display='block';
761
+ // eventSource.onmessage = function (event) {
762
+ // var progress = parseInt(event.data); // Progress value from Flask
763
+ // if (progress <= 100) {
764
+ // console.log(progress); // Log progress for debugging
765
+ // document.getElementById('progress').style.width = progress + '%';
766
+ // document.getElementById('progress').textContent = progress + '%';
767
+ // } else {
768
+ // var data = JSON.parse(event.data); // Assuming the result is a JSON array
769
+ // eventSource.close(); // Close the connection when finished
770
+
771
+ // document.getElementById('progressBar').setAttribute('hidden',true)
772
+ // document.getElementById('progressBar').style.display='none';
773
+ // document.getElementById('progress').style.width = '0%'; // Reset progress for the next process
774
+ // document.getElementById('progress').textContent = '0%';
775
+ // document.getElementById("all").style.display = "none";
776
+ // // Display link or any additional data if needed
777
+ // window.open(data[2]);
778
+ // downloadPdf(pdfname,'Pixel_Conversion_File_:'+pdfname)
779
+ // document.getElementById("all").style.display = "none";
780
+
781
+ // document.getElementById('measureADRbutton').onclick= function()
782
+ // {
783
+ // if (!areaRatio.value){
784
+ // if (!(projsec.value.startsWith('3.2')) & !(projsec.value.startsWith('2.8')) & !(projsec.value.startsWith('2.6')) & !(projsec.value.startsWith('3.3')) & !(projsec.value.startsWith('2.7')) )
785
+ // areaRatio.style.boxShadow='0 0 8px 2px rgb(255, 0, 0)';
786
+ // }
787
+ // if (!prmRatio.value) {
788
+ // if (!(projsec.value.startsWith('2.6') || projsec.value.startsWith('2.8'))) {
789
+ // prmRatio.style.boxShadow = '0 0 8px 2px rgb(255, 0, 0)';
790
+ // }
791
+ // }
792
+
793
+ // }
794
+ // document.getElementById('radiosColors').removeAttribute('hidden');
795
+ // var scalelbl= document.createElement("label");
796
+ // scalelbl.innerText='Scale Document';
797
+ // scalelbl.id='measureLabel';
798
+ // var br1= document.createElement("br");
799
+ // var areadiv=document.createElement("div");
800
+ // areadiv.id='areadiv'
801
+ // var areaRatiolbl= document.createElement("label");
802
+ // areaRatiolbl.innerText='Area:'
803
+ // areaRatiolbl.id='radiolbl';
804
+
805
+ // var areaRatio= document.createElement("input");
806
+ // areaRatio.type='number';
807
+ // areaRatio.id='arealvlinput';
808
+ // areaRatio.className='lvlinput';
809
+ // areaRatio.name='areaRatio';
810
+ // areaRatio.style.marginLeft='78px';
811
+ // areaRatio.style.textAlign='right';
812
+ // areaRatio.step=".0000001";
813
+ // areaRatio.min = "0"; // Allow only positive numbers (>= 0)
814
+ // if( projsec.value.startsWith('3.2') || projsec.value.startsWith('3.3') || projsec.value.startsWith('2.1') || projsec.value.startsWith('2.7')){
815
+ // areaRatio.setAttribute('disabled',true)
816
+ // areaRatio.style.cursor='not-allowed';
817
+ // areaRatio.style.backgroundColor='rgba(101, 101, 101, 0.27)'
818
+ // document.getElementById('selectunitA').setAttribute('disabled',true)
819
+ // document.getElementById('selectunitA').style.cursor='not-allowed';
820
+ // document.getElementById('selectunitA').style.backgroundColor='rgba(101, 101, 101, 0.27)'
821
+ // }
822
+
823
+ // else{ // section 1.0
824
+ // areaRatio.removeAttribute('disabled')
825
+ // areaRatio.style.cursor='pointer';
826
+ // document.getElementById('selectunitA').removeAttribute('disabled')
827
+ // document.getElementById('selectunitA').style.cursor='pointer';
828
+ // }
829
+ // areaRatio.addEventListener('change',function(){
830
+ // areaRatio.value=(Number(areaRatio.value)).toFixed(7)
831
+ // areaRatio.style.boxShadow='none';
832
+ // })
833
+ // areaRatio.required=true;
834
+ // selectunitA=document.getElementById('selectunitA')
835
+ // selectunitA.removeAttribute('hidden')
836
+
837
+ // areadiv.append(areaRatiolbl,areaRatio,selectunitA)
838
+ // var br2= document.createElement("br");
839
+ // var br3= document.createElement("br");
840
+ // var prmdiv=document.createElement("div");
841
+ // prmdiv.id='prmdiv'
842
+ // var prmRatiolbl= document.createElement("label");
843
+ // prmRatiolbl.innerText='Perimeter:'
844
+ // prmRatiolbl.id='radiolbl';
845
+
846
+ // var prmRatio= document.createElement("input");
847
+ // prmRatio.type='number';
848
+ // prmRatio.id='perimlvlinput';
849
+ // prmRatio.className='lvlinput';
850
+ // prmRatio.name='prmRatio';
851
+ // prmRatio.style.textAlign='right';
852
+ // prmRatio.style.marginLeft='49px';
853
+ // prmRatio.step=".0000001";
854
+ // prmRatio.min = "0"; // Allow only positive numbers (>= 0)
855
+ // prmRatio.addEventListener('change',function(){
856
+ // prmRatio.value=(Number(prmRatio.value)).toFixed(7)
857
+ // prmRatio.style.boxShadow='none';
858
+ // })
859
+ // prmRatio.required=true;
860
+ // selectunitP=document.getElementById('selectunitP')
861
+ // selectunitP.removeAttribute('hidden')
862
+
863
+ // prmdiv.append(prmRatiolbl, prmRatio,selectunitP)
864
+ // var ratiosdiv= document.getElementById("ratios");
865
+ // ratiosdiv.innerHTML='';
866
+ // ratiosdiv.append(scalelbl);
867
+ // ratiosdiv.append(br1);
868
+ // ratiosdiv.append(areadiv)
869
+ // ratiosdiv.append(prmdiv)
870
+ // areainpixels=data[0];
871
+ // prminpixels=data[1];
872
+
873
+
874
+ // if( projsec.value.startsWith('2.8') || projsec.value.startsWith('2.6')) {
875
+ // areaRatio.setAttribute('disabled',true)
876
+ // areaRatio.style.cursor='not-allowed';
877
+ // areaRatio.style.backgroundColor='rgba(101, 101, 101, 0.27)'
878
+ // document.getElementById('selectunitA').setAttribute('disabled',true)
879
+ // document.getElementById('selectunitA').style.cursor='not-allowed';
880
+ // document.getElementById('selectunitA').style.backgroundColor='rgba(101, 101, 101, 0.27)'
881
+
882
+ // prmRatio.setAttribute('disabled',true)
883
+ // prmRatio.style.cursor='not-allowed';
884
+ // prmRatio.style.backgroundColor='rgba(101, 101, 101, 0.27)'
885
+ // document.getElementById('selectunitP').setAttribute('disabled',true)
886
+ // document.getElementById('selectunitP').style.cursor='not-allowed';
887
+ // document.getElementById('selectunitP').style.backgroundColor='rgba(101, 101, 101, 0.27)'
888
+ // }
889
+ // };
890
+ // }
891
+
892
+
893
+ // eventSource.onerror = function (error) {
894
+ // console.error('Error occurred:', error);
895
+ // eventSource.close(); // Close on error
896
+ // PopupElement.textContent='Error occured while uploading the pdf to the Dropbox. Refresh and try again. If the error continues, please contact the ADR team to fix it. ';
897
+ // ShowPopUp();
898
+ // };
899
+
900
+ // selectunitA.addEventListener('change',function(){
901
+ // value=document.getElementById('selectunitA').value
902
+ // if (value=='mm2')
903
+ // ratioAunit=1000000;
904
+ // else
905
+ // ratioAunit=1;
906
+ // })
907
+ // selectunitP.addEventListener('change',function(){
908
+ // value=document.getElementById('selectunitP').value
909
+ // if (value=='mm'){
910
+ // ratioPunit=1000;
911
+ // }
912
+ // else
913
+ // ratioPunit=1;
914
+
915
+ // })
916
+ // // }
917
+ // // for 2.8 multiple pdfs
918
+ // // else{
919
+ // // pdfnames=getSelectValues(elem)
920
+ // // }
921
+ // }
922
+ // else{
923
+ // document.getElementById('radiosColors').removeAttribute('hidden')
924
+ // }
925
+ }
926
+ // Action for when the label is clicked (no checkbox change)
927
+ // function handleLabelClick(event) {
928
+ // let selectedLabel = event.target.textContent;
929
+ // console.log("Label clicked: ", selectedLabel);
930
+
931
+ // // Reset background only for items whose checkbox is **not** checked
932
+ // document.querySelectorAll(".measure-item").forEach(item => {
933
+ // const checkbox = item.querySelector('input[type="checkbox"]');
934
+ // if (!checkbox.checked) {
935
+ // item.style.backgroundColor = '';
936
+ // }
937
+ // });
938
+
939
+ // // Optionally highlight the clicked div (even though its checkbox isn’t selected)
940
+ // const clickedDiv = event.target.closest(".measure-item");
941
+ // clickedDiv.style.backgroundColor = '#919592';
942
+
943
+ // // Show loading spinner
944
+ // document.getElementById("all").style.display = "block";
945
+
946
+ // fetch('/getdropboxurl/' + JSON.stringify(selectedLabel), {
947
+ // method: 'POST',
948
+ // headers: { 'Content-Type': 'application/json' },
949
+ // body: JSON.stringify({ filename: "your_pdf_filename_here.pdf" }) // ← Replace with real value if dynamic
950
+ // })
951
+ // .then(response => response.blob())
952
+ // .then(blob => {
953
+ // document.getElementById("all").style.display = "none";
954
+ // const url = URL.createObjectURL(blob);
955
+ // // addIframeTab(selectedLabel, url);
956
+ // })
957
+ // .catch(function (jqXHR, textStatus, errorThrown) {
958
+ // PopupElement.textContent = 'Error occurred while retrieving the Dropbox URL. Refresh and try again. If the error continues, please contact the ADR team to fix it.';
959
+ // ShowPopUp();
960
+ // });
961
+ // }
962
+
963
+
964
+ for (let i = 0; i < docsToMeasure.length; i++) {
965
+ let name = docsToMeasure[i][0];
966
+
967
+ // Create div for the measure item
968
+ let div = document.createElement("div");
969
+ div.className = "measure-item";
970
+
971
+ // Create the checkbox
972
+ let checkbox = document.createElement("input");
973
+ checkbox.type = "checkbox";
974
+ checkbox.name = "measureCheckbox";
975
+ checkbox.value = name;
976
+
977
+ // Only clicking checkbox checks it and triggers handler
978
+ checkbox.onclick = function (e) {
979
+ e.stopPropagation(); // prevent bubbling to div
980
+ handleCheckboxChange(e);
981
+ };
982
+
983
+ // Create the label
984
+ let label = document.createElement("label");
985
+ label.textContent = name;
986
+
987
+ // Label click does not check the checkbox
988
+ label.onclick = function (e) {
989
+ e.stopPropagation(); // just to be safe
990
+ handleLabelClick(e, name);
991
+ };
992
+
993
+ // Div click also doesn't check the checkbox
994
+ div.onclick = function (e) {
995
+ handleLabelClick(e, name);
996
+ };
997
+
998
+ // Assemble
999
+ div.appendChild(checkbox);
1000
+ div.appendChild(label);
1001
+ measSelect.appendChild(div);
1002
+
1003
+ // Handle duplicates
1004
+ if (nameSet.has(name)) {
1005
+ label.style.color = "red";
1006
+ document.getElementById("TopTextModal").textContent = 'Error: Duplicates Error';
1007
+ PopupElement.textContent = 'Duplicate project names were detected while retrieving the project PDFs. Please visit Dropbox and rename the relevant files that you will be working on to ensure each project has a unique name. Once the renaming is complete, return to the console and click on the Dropbox icon to retrieve the updated project names.';
1008
+ ShowPopUp();
1009
+ } else {
1010
+ nameSet.add(name);
1011
+ }
1012
+ }
1013
+
1014
+
1015
+ // for (let i = 0; i < relvDocs.length; i++) {
1016
+ // let name = relvDocs[i][0];
1017
+
1018
+ // // Create div for the measure item
1019
+ // let divRelv = document.createElement("div");
1020
+ // divRelv.className = "relv-item";
1021
+
1022
+ // // Create the checkbox
1023
+ // let checkboxRelv = document.createElement("input");
1024
+ // checkboxRelv.type = "checkbox";
1025
+ // checkboxRelv.name = "measureCheckboxRelv";
1026
+ // checkboxRelv.value = name;
1027
+
1028
+ // // Create the label
1029
+ // let label = document.createElement("label");
1030
+ // label.textContent = name;
1031
+
1032
+ // // Shared click handler
1033
+ // function checkboxRelvClick(event) {
1034
+ // event.stopPropagation(); // Prevent event bubbling issues
1035
+
1036
+ // // Get the parent div from the event target
1037
+ // const container = event.currentTarget;
1038
+
1039
+ // // Get the checkbox inside this container
1040
+ // const checkbox = container.querySelector('input[type="checkbox"]');
1041
+
1042
+ // // Uncheck all checkboxes
1043
+ // document.querySelectorAll('input[name="measureCheckboxRelv"]').forEach(cb => cb.checked = false);
1044
+
1045
+ // // Check the clicked one
1046
+ // checkbox.checked = true;
1047
+
1048
+ // const relevantDocumentName = checkbox.value;
1049
+ // console.log("Item clicked: ", relevantDocumentName);
1050
+
1051
+ // if (projsec.value.startsWith('2.8') || projsec.value.startsWith('2.6')) {
1052
+ // doorSchedulePDF = relevantDocumentName;
1053
+ // console.log(doorSchedulePDF);
1054
+ // }
1055
+
1056
+ // // Highlight selection
1057
+ // document.querySelectorAll(".relv-item").forEach(item => {
1058
+ // item.style.backgroundColor = '';
1059
+ // });
1060
+ // container.style.backgroundColor = '#d3f8d3';
1061
+ // document.getElementById('relvselectid').style.boxShadow = '';
1062
+ // relvSelect.value = relevantDocumentName;
1063
+ // }
1064
+
1065
+ // // Assign the click event to the container div
1066
+ // divRelv.onclick = checkboxRelvClick;
1067
+
1068
+ // // Also attach to checkbox specifically to prevent bubbling issue
1069
+ // checkboxRelv.onclick = (e) => {
1070
+ // e.stopPropagation();
1071
+ // divRelv.click(); // Trigger div's click logic
1072
+ // };
1073
+
1074
+ // divRelv.appendChild(checkboxRelv);
1075
+ // divRelv.appendChild(label);
1076
+
1077
+ // relvSelect.appendChild(divRelv);
1078
+
1079
+ // if (nameSetRelv.has(name)) {
1080
+ // label.style.color = "red";
1081
+ // } else {
1082
+ // nameSetRelv.add(name);
1083
+ // }
1084
+ // }
1085
+
1086
+
1087
+ // relvids.push(relvSelect);
1088
+ measids.push(measSelect);
1089
+
1090
+ // document.addEventListener("click", function(event) {
1091
+ // const iframe = document.getElementById("pdfFrame");
1092
+ // if (!iframe.contains(event.target)) {
1093
+ // const iframe = document.getElementById("pdfFrame");
1094
+ // iframe.style.display = "none";
1095
+ // }
1096
+ // });
1097
+ document.getElementById('measureADRbutton').onclick= function()
1098
+ {
1099
+ if (!measSelect.value) {
1100
+ measSelect.style.boxShadow = '0 0 8px 2px rgb(255, 0, 0)';
1101
+ measSelect.setAttribute("required", "")
1102
+ }
1103
+
1104
+ // if (!relvSelect.value) {
1105
+ // if (sectionNumber.startsWith('2.8') || sectionNumber.startsWith('2.6')) {
1106
+ // relvSelect.style.boxShadow = '0 0 8px 2px rgb(255, 0, 0)';
1107
+ // relvSelect.setAttribute("required", "")
1108
+ // }
1109
+ // }
1110
+
1111
+
1112
+ }
1113
+
1114
+ }
1115
+
1116
+
1117
+ if (document.getElementById('arealvlinput')){
1118
+ if( projsec.value.startsWith('3.2') || projsec.value.startsWith('2.8') || projsec.value.startsWith('2.6') || projsec.value.startsWith('3.3') || projsec.value.startsWith('2.1') || projsec.value.startsWith('2.7')){
1119
+ document.getElementById('arealvlinput').setAttribute('disabled',true)
1120
+ document.getElementById('selectunitA').setAttribute('disabled',true)
1121
+ }
1122
+ else{ // section 1.0
1123
+ document.getElementById('arealvlinput').removeAttribute('disabled')
1124
+ document.getElementById('selectunitA').removeAttribute('disabled')
1125
+ }
1126
+ }
1127
+
1128
+
1129
+
1130
+ // if (!(thirddropdown.value.startsWith('2.8')||thirddropdown.value.startsWith('2.6')) ) {
1131
+ // document.getElementById("relvselectid").classList.add("disabled");
1132
+ // document.getElementById("relvoverlay").style.display = "block";
1133
+ // } else {
1134
+ // document.getElementById("relvselectid").classList.remove("disabled");
1135
+ // document.getElementById("relvoverlay").style.display = "none";
1136
+ // }
1137
+
1138
+ };
1139
+
1140
+ eventSource.onerror = function (error) {
1141
+ console.error('Error occurred:', error);
1142
+ eventSource.close(); // Close on error
1143
+ PopupElement.textContent='Error occured while retrieving the Project Names. Refresh and try again. If the error continues, please contact the ADR team to fix it. ';
1144
+ ShowPopUp();
1145
+ };
1146
+
1147
+ }
1148
+ //___________________________________________________________________________________________________________
1149
+ //___________________________________________________________________________________________________________
1150
+ function downloadPdf(blob,downloadPDFName) {
1151
+
1152
+ // const url = URL.createObjectURL(blob);
1153
+ // var link = document.createElement('a');
1154
+ // link.href = url;
1155
+ // link.download = downloadPDFName;
1156
+ // link.dispatchEvent(new MouseEvent('click'));
1157
+
1158
+
1159
+ const url = URL.createObjectURL(blob);
1160
+ const a = document.createElement('a');
1161
+ a.style.display = 'none';
1162
+ a.href = url;
1163
+ a.download = downloadPDFName;
1164
+ document.body.appendChild(a);
1165
+ a.click();
1166
+ document.body.removeChild(a);
1167
+ URL.revokeObjectURL(url);
1168
+
1169
+ }
1170
+ </script>