Marthee commited on
Commit
117c540
·
verified ·
1 Parent(s): 36cff54

Update templates/proposed-GUI.html

Browse files
Files changed (1) hide show
  1. templates/proposed-GUI.html +740 -440
templates/proposed-GUI.html CHANGED
@@ -33,7 +33,7 @@
33
  {% include 'loading.html' %}
34
  </div>
35
  <!--Main tab links-->
36
- <div class="tab">
37
  <div class="container" id="toggle">
38
  <div class="bar1"></div>
39
  <div class="bar2"></div>
@@ -45,11 +45,16 @@
45
  <a class="tablinks" id="LegendHist" href="{{ url_for('legendDirectory') }}">
46
  Legends History <i class="fa fa-caret-down"></i>
47
  </a>
48
-
 
 
 
 
 
49
  <button class="dropbtn" onclick="userguideclick()"><img id="infoImg" src=""></button>
50
- </div>
51
 
52
-
 
53
  <div id="mySidebar" class="slide-out">
54
  <div id="menuOptions">
55
  <li onclick="openTab(event, 'home')" >Measure Plans </li>
@@ -58,6 +63,7 @@
58
  </div>
59
 
60
  <div id="home" class="tabcontent" >
 
61
  <div id="loading" hidden> </div>
62
 
63
  <div id="canvaswindow" hidden="until-found">
@@ -70,8 +76,9 @@
70
  </div>
71
  <input type="button" value="Save" id="savecanvas" />
72
  </div>
73
-
74
  <div id="rightside" hidden="until-found">
 
75
  <div id="backgroundimg" >
76
  <div id="imgs">
77
  <!-- image here -->
@@ -123,7 +130,8 @@
123
 
124
  </div>
125
  <div id="measureCheckbox">
126
- <select style="margin-left: -1%;" hidden name="measureselectname" id="measureselectid" multiple size="5"></select>
 
127
  <div id="dxfdiv" hidden="until-found">
128
  <input type="button" id="pdftodxfFileButton" onclick="document.getElementById('pdftodxfFile').click();" value="Upload DXF File" >
129
  <input type="file" id="pdftodxfFile" name="pdftodxfFilename" >
@@ -144,7 +152,8 @@
144
  <input type="search" onkeyup=filterFunction(this.id) id="relevantSearchInput">
145
  <br>
146
  <div id ="relvdiv">
147
- <select style="margin-left: -1%;" hidden name="relvselectname" id="relvselectid" multiple size="5"> </select>
 
148
  <iframe id="pdfFrame" hidden></iframe>
149
  </div>
150
  </div>
@@ -184,6 +193,9 @@
184
  </div>
185
  <audio id="myAudio" autoplay></audio>
186
  </form>
 
 
 
187
 
188
  <div id ="duplicater" class="duplicaterclass" hidden="until-found">
189
  <label id="labelArrayId" hidden="until-found"> </label>
@@ -268,7 +280,7 @@
268
  </ul>
269
 
270
  </div>
271
-
272
  <div class="dropdown-content">
273
  <div id="userguidetext">
274
  <div id="textfirstpage">
@@ -544,7 +556,7 @@
544
  <input type="number" id="textextra" name="text0name" placeholder="Eg: 1" >
545
  <input type="text" id="text0extra" name="text1name" placeholder="Eg: Wall Type" >
546
  <input type="text" id="text1extra" name="text2name" placeholder="Eg:NBS K10/" >
547
- <input type="number" id="text2extra" name="text3name" placeholder="Eg: 3" >
548
 
549
  <script src="https://cdn.lordicon.com/bhenfmcm.js" ></script>
550
  <lord-icon
@@ -601,6 +613,15 @@
601
  <script >
602
 
603
  ///////////////////////////////////////////////BEGIN JS CODE//////////////////////////////////////////////////
 
 
 
 
 
 
 
 
 
604
  // Function to send the Dropbox link and keyword to the server
605
  function getURLParams() {
606
  const urlParams = new URLSearchParams(window.location.search);
@@ -686,32 +707,57 @@ var prjids=[]
686
 
687
  displayprjnames()
688
  function displayprjnames(){
689
- $.get('/getprojectnames/')
690
- .success(function(data) {
691
-
692
-
693
- document.getElementById("all").style.display = "none";
694
- prjids=data[1];
695
- var op0 = document.createElement("OPTION") ;
696
- op0.text= 'Projects'
697
- op0.value= "";
698
- op0.hidden=true;
699
- firstdropdown.add(op0);
700
- for (let i=0;i<data[0].length;i++)
701
- {
702
- opt=document.createElement("option");
703
- opt.textContent=data[0][i];
704
- opt.text=data[0][i];
705
- firstdropdown.append(opt);
706
- PrjNamesArray.push(data[0][i]);
707
- }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
708
 
709
- })
710
- .error(function(jqXHR, textStatus, errorThrown) {
711
- 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. ';
712
- ShowPopUp();
713
-
714
- });
 
 
 
 
715
  }
716
  /*Get chosen value and send to flask to get project parts*/
717
 
@@ -775,8 +821,17 @@ function isValueNotInDropdown(dropdown, value) {
775
  function displayprojsections(projectid,Partid){
776
  console.log(seconddropdown.selectedIndex)
777
  document.getElementById("all").style.display = "block";
778
- measSelect.innerHTML='';
779
- relvSelect.innerHTML='';
 
 
 
 
 
 
 
 
 
780
  $.get('/getprojectsections/'+JSON.stringify([projectid,Partid]))
781
  .success(function(data){
782
  document.getElementById("all").style.display = "none";
@@ -1043,52 +1098,131 @@ if (document.getElementById('imgContainer')) {
1043
  //___________________________________________________________________________________________________________
1044
  /*Toggle Tab View of Home and Legend along with the Menu bar icon*/
1045
  function openTab(evt, tabname) {
1046
- // Declare all variables
1047
  var i, tabcontent, tablinks;
1048
 
1049
- // Get all elements with class="tabcontent" and hide them
 
 
1050
  tabcontent = document.getElementsByClassName("tabcontent");
1051
  for (i = 0; i < tabcontent.length; i++) {
1052
  tabcontent[i].style.display = "none";
1053
  }
1054
 
1055
- // Get all elements with class="tablinks" and remove the class "active"
1056
  tablinks = document.getElementsByClassName("tablinks");
1057
  for (i = 0; i < tablinks.length; i++) {
1058
  tablinks[i].className = tablinks[i].className.replace(" active", "");
1059
  }
1060
 
1061
- // Show the current tab, and add an "active" class to the button that opened the tab
1062
- document.getElementById(tabname).style.display = "block";
1063
- evt.currentTarget.className += " active";
1064
- var isOpen = $mySidebar.classList.contains('slide-in');
1065
- if ($mySidebar.classList.contains('slide-in'))
1066
- {$mySidebar.setAttribute('class', isOpen ? 'slide-out' : 'slide-in');
1067
- document.getElementById("pagetitle").style.backgroundColor='rgb(0, 60, 255)';
1068
-
1069
- $toggle.classList.toggle("change");
1070
- }
1071
  }
1072
- // Start with the first page (Home)
 
1073
  document.getElementById("pagetitle").click();
1074
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1075
 
1076
- /// download file (made for 3.2 only)
1077
- // function downloadpdf(filename, pdfdata) {
1078
- // console.log('hereeee')
1079
- // var element = document.createElement('a');
1080
- // element.setAttribute('href', 'data:application/pdf;base64,[base64_encoded_pdf_data],' + encodeURIComponent(pdfdata));
1081
- // element.setAttribute('download', filename);
 
 
 
 
 
 
 
 
 
 
 
 
 
1082
 
1083
- // element.style.display = 'none';
1084
- // document.body.appendChild(element);
 
 
1085
 
1086
- // element.click();
 
1087
 
1088
- // document.body.removeChild(element);
1089
- // }
 
 
1090
 
1091
- function downloadPdf(pdfname) {
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1092
  console.log('pdfname===',pdfname)
1093
  fetch('/get-pdf/'+JSON.stringify(pdfname))
1094
  .then(response => response.blob())
@@ -1096,7 +1230,7 @@ function downloadPdf(pdfname) {
1096
  const url = URL.createObjectURL(blob);
1097
  var link = document.createElement('a');
1098
  link.href = url;
1099
- link.download = 'file.pdf';
1100
  link.dispatchEvent(new MouseEvent('click'));
1101
  })
1102
  .catch(error => console.error('Error fetching PDF:', error));
@@ -1352,7 +1486,7 @@ function getSelectValues(select) {
1352
  //___________________________________________________________________________________________________________
1353
 
1354
  //Retrieves list of projects
1355
-
1356
  function getproj(){
1357
  getALLMCTNAMES();
1358
 
@@ -1364,301 +1498,465 @@ function getSelectValues(select) {
1364
 
1365
  var sections = document.getElementsByClassName("selectionsProjs")[0];
1366
  chooseFirstdrpdwn();
1367
-
1368
- $.get( '/getmethod/'+JSON.stringify(projectVal))
1369
- .success (function(data){
1370
- document.getElementById('refreshDropboxButtonID').style.display = "block";
1371
- document.getElementById("all").style.display = "none";
1372
- if (sections.value.startsWith('3.2') || sections.value.startsWith('3.3') || sections.value.startsWith('2.7') ){
1373
- document.getElementById('dxfdiv').removeAttribute('hidden');
1374
- document.getElementById('pdftodxfFile').setAttribute('required',true)
1375
- }
1376
- else{
1377
- document.getElementById('dxfdiv').setAttribute('hidden',true)
1378
- }
1379
- extracted_path=data[2]
1380
- var docsToMeasure=data[0]; //
1381
- var relvDocs=data[1]
1382
- var projname = document.getElementsByClassName("selectionsProj")[0];
1383
- var projpart = document.getElementsByClassName("selectionsProjp")[0];
1384
- var projsec = document.getElementsByClassName("selectionsProjs")[0];
1385
-
1386
- var meas = document.getElementById("measureCheckbox") ;
1387
- var relv = document.getElementById("relvdiv") ;
1388
- const measids=[];
1389
- const relvids=[];
1390
- const measoptns=[];
1391
-
1392
- var measSelect = document.getElementById("measureselectid");
1393
- var relvSelect = document.getElementById("relvselectid");
1394
- var levelcheckbox= document.getElementById("levelcheckbox");
1395
-
1396
-
1397
- measSelect.removeAttribute("hidden");
1398
- relvSelect.removeAttribute("hidden");
1399
- measSelect.innerHTML='';
1400
-
1401
- var optn2 = document.createElement("OPTION");
1402
- optn2.text= 'Select project to measure';
1403
- optn2.value=''
1404
- optn2.hidden=true;
1405
- optn2.id='hidden';
1406
-
1407
- measSelect.add(optn2);
1408
- document.getElementById("hidden").required = true;
1409
-
1410
- relvSelect.innerHTML='';
1411
- for (i = 0; i < relvDocs.length; i++) {
1412
- //relevant documents
1413
- var optn1 = document.createElement("OPTION");
1414
- optn1.text= relvDocs[i][0];
1415
- optn1.value= relvDocs[i][0] ;
1416
- optn1.id=relvDocs[i][1] ;
1417
- relvSelect.add(optn1);
1418
- if (data=='No projects found'){
1419
- optn1.style.color='#bdbcbc';
1420
- optn1.style.cursor='not-allowed';
1421
- optn1.setAttribute('disabled',true);
1422
- }
1423
- }
1424
- const nameSet = new Set(); // To track unique names
1425
-
1426
- for (i = 0; i < docsToMeasure.length; i++) {
1427
- //to measure documents
1428
- var optn2 = document.createElement("OPTION");
1429
- let name = docsToMeasure[i][0]; // Extract name
1430
- optn2.text= docsToMeasure[i][0];
1431
- optn2.value= docsToMeasure[i][0] ;
1432
- optn2.id=docsToMeasure[i][1] ;
1433
- measSelect.add(optn2);
1434
- measoptns.push(optn2);
1435
-
1436
- // Check for duplicates
1437
- if (nameSet.has(name)) {
1438
- optn2.style.color = "red"; // Highlight duplicate (optional)
1439
- PopupElement.textContent = 'Duplicate project names were detected while retrieving the project PDFs. Please visit Dropbox and rename the files 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.';
1440
- ShowPopUp();
1441
- } else {
1442
- nameSet.add(name); // Add unique name to the set
1443
- }
1444
 
1445
- if (data=='No projects found'){
1446
- optn2.style.color='#bdbcbc';
1447
- optn2.style.cursor='not-allowed';
1448
- optn2.setAttribute('disabled',true);
1449
- }
1450
- }
1451
- console.log(nameSet)
1452
- relvids.push(relvSelect) ;
1453
- measids.push(measSelect);
1454
- //to open pdf in a new tab (relevant documents)
1455
 
 
 
 
 
 
 
1456
 
1457
- relvids.forEach(function(elem) {
1458
- elem.addEventListener("change", function() {
1459
- // Show loading indicator
1460
- document.getElementById("all").style.display = "block";
1461
- fetch('/getdropboxurl/'+ JSON.stringify(elem.value), {
1462
 
1463
- method: 'POST',
1464
- headers: { 'Content-Type': 'application/json' },
1465
- body: JSON.stringify({ filename: "your_pdf_filename_here.pdf" })
1466
- })
1467
- .then(response => response.blob())
1468
- .then(blob => {
1469
- document.getElementById("all").style.display = "none";
1470
- const url = URL.createObjectURL(blob);
1471
- // Set the URL to the iframe's src to load the content inside the page
1472
- const iframe = document.getElementById("pdfFrame");
1473
- iframe.src = url;
1474
- iframe.style.display = "block"; // Show the iframe
1475
- })
1476
- .catch(function(jqXHR, textStatus, errorThrown) {
1477
- // Handle error
1478
- 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.';
1479
- ShowPopUp();
1480
- });
1481
- });
1482
- });
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1483
 
1484
- measids.forEach(function(elem) {
 
1485
 
1486
- elem.addEventListener("change", function() {
1487
- // if (!(projsec.value.startsWith('2.8')))
1488
- // {
1489
- // Show alert immediately to prompt the user
 
 
 
 
 
 
 
 
 
1490
  if (projsec.value.startsWith('3.2') || projsec.value.startsWith('3.3') || projsec.value.startsWith('2.7')) {
1491
- downloadPdf(elem.value);
1492
- 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.");
1493
- }
1494
- else{
1495
- 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.");
1496
  }
 
 
 
1497
  canvasimg='';
1498
  ry=[[]];
1499
  levelcheckbox.checked=false;
1500
- pdfname=elem.value;
1501
  measSelect.style.boxShadow='none';
1502
 
1503
 
1504
  document.getElementById("all").style.display = "block";
1505
 
1506
  pixelArr=[projname.value, projpart.value,projsec.value, pdfname]
1507
- // Open popup immediately before initiating the PDF download
1508
-
1509
-
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1510
 
1511
 
1512
- $.get('/pixelimg/' + JSON.stringify(pixelArr))
1513
- .success(function(data) {
1514
- document.getElementById("all").style.display = "none";
1515
- // Display link or any additional data if needed
1516
- window.open(data[2]);
1517
- document.getElementById("all").style.display = "none";
1518
-
1519
- document.getElementById('measureADRbutton').onclick= function()
1520
- {
1521
- if (!areaRatio.value){
1522
- if (!(projsec.value.startsWith('3.2')) & !(projsec.value.startsWith('2.8')) & !(projsec.value.startsWith('3.3')) & !(projsec.value.startsWith('2.7')) )
1523
- areaRatio.style.boxShadow='0 0 8px 2px rgb(255, 0, 0)';
1524
- }
1525
- if (!prmRatio.value)
1526
- prmRatio.style.boxShadow='0 0 8px 2px rgb(255, 0, 0)';
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1527
 
1528
- }
1529
- document.getElementById('radiosColors').removeAttribute('hidden');
1530
- var scalelbl= document.createElement("label");
1531
- scalelbl.innerText='Scale Document';
1532
- scalelbl.id='measureLabel';
1533
- var br1= document.createElement("br");
1534
- var areadiv=document.createElement("div");
1535
- areadiv.id='areadiv'
1536
- var areaRatiolbl= document.createElement("label");
1537
- areaRatiolbl.innerText='Area:'
1538
- areaRatiolbl.id='radiolbl';
1539
-
1540
- var areaRatio= document.createElement("input");
1541
- areaRatio.type='number';
1542
- areaRatio.id='arealvlinput';
1543
- areaRatio.className='lvlinput';
1544
- areaRatio.name='areaRatio';
1545
- areaRatio.style.marginLeft='78px';
1546
- areaRatio.style.textAlign='right';
1547
- areaRatio.step=".0000001";
 
 
 
 
 
 
 
 
1548
 
1549
- if( projsec.value.startsWith('3.2') || projsec.value.startsWith('2.8') || projsec.value.startsWith('3.3') || projsec.value.startsWith('2.1') || projsec.value.startsWith('2.7')){
1550
- areaRatio.setAttribute('disabled',true)
1551
- document.getElementById('selectunitA').setAttribute('disabled',true)
1552
- }
1553
- else{ // section 1.0
1554
- areaRatio.removeAttribute('disabled')
1555
- document.getElementById('selectunitA').removeAttribute('disabled')
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1556
  }
1557
- areaRatio.addEventListener('change',function(){
1558
- areaRatio.value=(Number(areaRatio.value)).toFixed(7)
1559
- areaRatio.style.boxShadow='none';
1560
- })
1561
- areaRatio.required=true;
1562
- selectunitA=document.getElementById('selectunitA')
1563
- selectunitA.removeAttribute('hidden')
1564
-
1565
- areadiv.append(areaRatiolbl,areaRatio,selectunitA)
1566
- var br2= document.createElement("br");
1567
- var br3= document.createElement("br");
1568
- var prmdiv=document.createElement("div");
1569
- prmdiv.id='prmdiv'
1570
- var prmRatiolbl= document.createElement("label");
1571
- prmRatiolbl.innerText='Perimeter:'
1572
- prmRatiolbl.id='radiolbl';
1573
-
1574
- var prmRatio= document.createElement("input");
1575
- prmRatio.type='number';
1576
- prmRatio.id='perimlvlinput';
1577
- prmRatio.className='lvlinput';
1578
- prmRatio.name='prmRatio';
1579
- prmRatio.style.textAlign='right';
1580
- // prmRatio.onchange=setNumberDecimal();
1581
- prmRatio.style.marginLeft='49px';
1582
- prmRatio.step=".0000001";
1583
- prmRatio.addEventListener('change',function(){
1584
- prmRatio.value=(Number(prmRatio.value)).toFixed(7)
1585
- prmRatio.style.boxShadow='none';
1586
- })
1587
- prmRatio.required=true;
1588
- selectunitP=document.getElementById('selectunitP')
1589
- selectunitP.removeAttribute('hidden')
1590
-
1591
- prmdiv.append(prmRatiolbl, prmRatio,selectunitP)
1592
- var ratiosdiv= document.getElementById("ratios");
1593
- ratiosdiv.innerHTML='';
1594
- ratiosdiv.append(scalelbl);
1595
- ratiosdiv.append(br1);
1596
- ratiosdiv.append(areadiv)
1597
- ratiosdiv.append(prmdiv)
1598
- areainpixels=data[0];
1599
- prminpixels=data[1];
1600
-
1601
-
1602
- })
1603
- .error(function(jqXHR, textStatus, errorThrown) {
1604
- 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. ';
1605
- ShowPopUp();
1606
  });
1607
- selectunitA.addEventListener('change',function(){
1608
- value=document.getElementById('selectunitA').value
1609
- if (value=='mm2')
1610
- ratioAunit=1000000;
1611
- else
1612
- ratioAunit=1;
1613
- })
1614
- selectunitP.addEventListener('change',function(){
1615
- value=document.getElementById('selectunitP').value
1616
- if (value=='mm'){
1617
- ratioPunit=1000;
1618
- // if (projsec.value.startsWith('3.2'))
1619
- // ratioPunit=100;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1620
  }
1621
- else
1622
- ratioPunit=1;
1623
-
1624
- })
1625
- // }
1626
- // for 2.8 multiple pdfs
1627
- // else{
1628
- // pdfnames=getSelectValues(elem)
1629
- // }
1630
- });
1631
-
1632
- });
1633
-
1634
- document.addEventListener("click", function(event) {
1635
- const iframe = document.getElementById("pdfFrame");
1636
- if (!iframe.contains(event.target)) {
1637
- const iframe = document.getElementById("pdfFrame");
1638
- iframe.style.display = "none";
1639
- }
1640
- });
1641
- document.getElementById('measureADRbutton').onclick= function()
1642
- {
1643
- if (!measSelect.value)
1644
- measSelect.style.boxShadow='0 0 8px 2px rgb(255, 0, 0)';
1645
 
1646
- }
1647
- })
1648
- .error(function(jqXHR, textStatus, errorThrown) {
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1649
  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. ';
1650
  ShowPopUp();
1651
- });
1652
- if (document.getElementById('arealvlinput')){
1653
- if( projsec.value.startsWith('3.2') || projsec.value.startsWith('2.8') || projsec.value.startsWith('3.3') || projsec.value.startsWith('2.1') || projsec.value.startsWith('2.7')){
1654
- document.getElementById('arealvlinput').setAttribute('disabled',true)
1655
- document.getElementById('selectunitA').setAttribute('disabled',true)
1656
- }
1657
- else{ // section 1.0
1658
- document.getElementById('arealvlinput').removeAttribute('disabled')
1659
- document.getElementById('selectunitA').removeAttribute('disabled')
1660
- }
1661
- }
1662
  }
1663
  //___________________________________________________________________________________________________________
1664
  //___________________________________________________________________________________________________________
@@ -1740,9 +2038,16 @@ function ImgSide(imgdata, spreadsheetLink, pdfLink) {
1740
  legendbutton.style.boxShadow = 'none';
1741
  });
1742
 
1743
- legendbutton.addEventListener('click', function () {
 
 
 
 
 
 
1744
  window.open(spreadsheetLink);
1745
  });
 
1746
  //////////////////////////////////////////////////////////////
1747
  var imgbutton = document.createElement("button");
1748
  imgbutton.className = 'measureADRbutton2';
@@ -1882,8 +2187,7 @@ function getData(form) {
1882
 
1883
  console.log(formData,formvalues)
1884
  // iterate through entries...
1885
-
1886
- tomeasureproj=formvalues['measureselectname']; //proj name
1887
 
1888
 
1889
  if( formvalues['selectprojs'].startsWith('3.2') || formvalues['selectprojs'].startsWith('3.3') || formvalues['selectprojs'].startsWith('2.7') ){
@@ -1937,12 +2241,16 @@ function getData(form) {
1937
  answers.push(tomeasureproj, 0,[] , ratio1, ratio2 ,pdfpath);
1938
  formData.append('answers',JSON.stringify(answers))
1939
  }
1940
- else if (formvalues['selectprojs'].startsWith('2.8') || formvalues['selectprojs'].startsWith('2.1'))
1941
  {
1942
  answers.push(tomeasureproj, 0,[] , ratio1, ratio2 ,pdfpath);
1943
  formData.append('answers',JSON.stringify(answers))
1944
  }
1945
-
 
 
 
 
1946
  }
1947
 
1948
  if (formvalues['selectprojs'].startsWith('1.0') || formvalues['selectprojs'].startsWith('3.2') || formvalues['selectprojs'].startsWith('2.8') || formvalues['selectprojs'].startsWith('3.3') || formvalues['selectprojs'].startsWith('2.7') ) //formvalues['selectprojs'].startsWith('2.1')
@@ -1950,26 +2258,17 @@ function getData(form) {
1950
  // console.log(formData)
1951
  $.ajax({
1952
  type: "POST",
1953
-
1954
  url: "/savebase64Img/",
1955
-
1956
- // set content type header to use Flask response.get_json()
1957
- contentType: "application/json",
1958
-
1959
- // convert data/object to JSON to send
1960
- data: formData,
1961
  processData: false, // Prevent jQuery from automatically processing the data
1962
  contentType: false,
1963
- // files:formvalues['pdftodxfFilename'],
1964
-
1965
- // expect JSON data in return (e.g. Flask jsonify)
1966
- // dataType: "json",
1967
-
1968
- // handle response
1969
  success: function(response) {
1970
  console.log(response);
1971
  },
1972
  error: function(err) {
 
 
1973
  PopupElement.textContent='Error occured. Refresh and try again. If the error continues, please contact the ADR team to fix it. ';
1974
  ShowPopUp();
1975
 
@@ -1979,8 +2278,8 @@ function getData(form) {
1979
  // var mp3_url = 'https://media.geeksforgeeks.org/wp-content/uploads/20190531135120/beep.mp3';
1980
  // (new Audio(mp3_url)).play()
1981
  // retrieveLinks()
1982
-
1983
- startDropdownUpdates(); // Start the dropdown updates
1984
 
1985
 
1986
  document.getElementById("loading").hidden = true;
@@ -2034,16 +2333,14 @@ function getData(form) {
2034
 
2035
  }
2036
  if (formvalues['selectprojs'].startsWith('2.8'))
2037
- { //
2038
- // /* data[0]--> img , data[1]-->dataframe (goes to legend lsa ) , data [2] -->pdf dropbox shareable link ,data[3]-> spreadsheetId, data[4],spreadsheeturl */
2039
  // SimilarAreaDictionary=data[1];
2040
  // listofimages=data[0];
2041
  dropboxLink=data[1];
2042
- spreadsheetURL=data[2];
2043
- list1= data[3] // list of pdf markups
2044
- SimilarAreaDictionary=data[4];
2045
-
2046
-
2047
  }
2048
  if (formvalues['selectprojs'].startsWith('2.2'))
2049
  {
@@ -2080,6 +2377,26 @@ function getData(form) {
2080
  // if (!(formvalues['selectprojs'].startsWith('2.8')))
2081
  // {
2082
  ImgSide(data[0],spreadsheetURL,dropboxLink)
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2083
  // }
2084
 
2085
  // else{
@@ -2118,7 +2435,7 @@ if (formvalues['selectprojs'].startsWith('1.0') || formvalues['selectprojs'].sta
2118
  dict1: JSON.stringify(list1),
2119
  spreadsheetId: spreadsheetId,
2120
  pdfpathpath: JSON.stringify(pdfpath),
2121
- path: Object.fromEntries(formData)['measureselectname']
2122
  }),
2123
  dataType: "json",
2124
  success: function (data1) {
@@ -2127,6 +2444,8 @@ if (formvalues['selectprojs'].startsWith('1.0') || formvalues['selectprojs'].sta
2127
  },
2128
  error: function (err) {
2129
  console.error('Error occurred during first AJAX call:', err);
 
 
2130
  PopupElement.textContent = 'Error occurred. Refresh and try again. If the error continues, please contact the ADR team to fix it.';
2131
  ShowPopUp();
2132
  }
@@ -2146,7 +2465,7 @@ if (formvalues['selectprojs'].startsWith('1.0') || formvalues['selectprojs'].sta
2146
  dict1: JSON.stringify(list1),
2147
  spreadsheetId: spreadsheetId,
2148
  pdfpathpath: JSON.stringify(pdfpath),
2149
- path: Object.fromEntries(formData)['measureselectname']
2150
  }),
2151
  dataType: "json"
2152
  });
@@ -2165,7 +2484,7 @@ if (formvalues['selectprojs'].startsWith('1.0') || formvalues['selectprojs'].sta
2165
  document.getElementById("loading").style.marginTop = '20%';
2166
  document.getElementById("loading").style.marginLeft = '65%';
2167
 
2168
- updatepreview([pdfpath, Object.fromEntries(formData)['measureselectname']]);
2169
 
2170
  await $.ajax({
2171
  type: "POST",
@@ -2174,7 +2493,7 @@ if (formvalues['selectprojs'].startsWith('1.0') || formvalues['selectprojs'].sta
2174
  data: JSON.stringify({
2175
  dict: JSON.stringify(SimilarAreaDictionary),
2176
  deletedrows: delrows2,
2177
- path: Object.fromEntries(formData)['measureselectname'],
2178
  spreadsheetId: spreadsheetId,
2179
  areaPermArr: JSON.stringify(data[7]),
2180
  section: Object.fromEntries(formData)['selectprojs'],
@@ -2188,6 +2507,8 @@ if (formvalues['selectprojs'].startsWith('1.0') || formvalues['selectprojs'].sta
2188
  }
2189
 
2190
  } catch (err) {
 
 
2191
  console.error('Error occurred during fetchAndCompareData:', err);
2192
  PopupElement.textContent = 'Error occurred. Refresh and try again. If the error continues, please contact the ADR team to fix it.';
2193
  ShowPopUp();
@@ -2213,80 +2534,55 @@ if (formvalues['selectprojs'].startsWith('1.0') || formvalues['selectprojs'].sta
2213
  /////////////////////////
2214
  });
2215
  }
2216
- // trial for 2.1 - tameem's code--- delete and deploy in the above if statement
2217
- // else{
2218
- // $.ajax({
2219
- // type: "POST",
2220
- // url: "/2.1Trial/",
2221
-
2222
- // // set content type header to use Flask response.get_json()
2223
- // contentType: "application/json",
2224
-
2225
- // // convert data/object to JSON to send
2226
- // data: JSON.stringify({allvalues:answers}),
2227
-
2228
- // // expect JSON data in return (e.g. Flask jsonify)
2229
- // dataType: "json",
2230
-
2231
- // // handle response
2232
- // success: function(response) {
2233
- // console.log(response);
2234
- // },
2235
- // error: function(err) {
2236
- // PopupElement.textContent='Error occured. Refresh and try again. If the error continues, please contact the ADR team to fix it. ';
2237
- // ShowPopUp();
2238
- // }
2239
- // }).done(function(data){
2240
- // spreadsheetURL=data[0];
2241
- // var backimg=document.getElementById('backgroundimg');
2242
- // var rightside=document.getElementById('rightside');
2243
- // document.getElementById("loading").hidden = true;
2244
- // document.getElementById('duplicater').removeAttribute('hidden');
2245
- // document.getElementById('doneebackground').removeAttribute('hidden');
2246
- // document.getElementById('summarytoXML').removeAttribute('hidden');
2247
- // document.getElementById('measureADRbutton').removeAttribute('disabled');
2248
- // document.getElementById('measureADRbutton').style.cursor='pointer';
2249
- // document.getElementById('measureADRbutton').style.color = 'white';
2250
- // document.getElementById('measureADRbutton').style.backgroundColor="#16c72e";
2251
-
2252
- // document.getElementById('measureADRbutton').addEventListener('mouseover',function(){
2253
- // document.getElementById('measureADRbutton').style.color='black';
2254
- // document.getElementById('measureADRbutton').style.boxShadow=' 0 0 8px 2px #16c72e';
2255
- // })
2256
-
2257
- // document.getElementById('measureADRbutton').addEventListener('mouseout',function(){
2258
- // document.getElementById('measureADRbutton').style.color='white';
2259
- // document.getElementById('measureADRbutton').style.boxShadow='none';
2260
- // });
2261
-
2262
- // var legendbutton= document.createElement("button");
2263
- // legendbutton.className='measureADRbutton2';
2264
- // legendbutton.innerText='Legend and Data created';
2265
- // legendbutton.style.backgroundColor='rgb(5, 43, 235)';
2266
- // legendbutton.addEventListener('mouseover',function(){
2267
- // legendbutton.style.boxShadow='0 0 8px 2px rgb(5, 43, 235)';
2268
- // })
2269
- // legendbutton.addEventListener('mouseout',function(){
2270
- // legendbutton.style.boxShadow='none';
2271
- // })
2272
-
2273
- // legendbutton.addEventListener('click',function(){
2274
- // window.open( spreadsheetURL);
2275
-
2276
- // })
2277
- // underimg.append(legendbutton);
2278
-
2279
- // })
2280
-
2281
- // }
2282
 
2283
  }
2284
  //___________________________________________________________________________________________________________
2285
  //___________________________________________________________________________________________________________
2286
  document.getElementById("myForm").addEventListener("submit", function (e) {
2287
- e.preventDefault();
2288
- getData(e.target);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2289
  });
 
2290
  ////////////////////////////////////////////
2291
  var measitemVal='';
2292
 
@@ -2930,7 +3226,7 @@ console.log()
2930
  if (sectionNumber.startsWith('2.7'))
2931
  {
2932
  textextra= cloneExtra.children[0]
2933
- textextra.style.backgroundColor = "#7c7c7c;";
2934
  textextra.style.cursor='not-allowed';
2935
  textextra.disabled="disabled";
2936
 
@@ -2938,7 +3234,7 @@ if (sectionNumber.startsWith('2.7'))
2938
  if (sectionNumber.startsWith('2.8'))
2939
  {
2940
  text2extra= cloneExtra.children[3]
2941
- text2extra.style.backgroundColor = "#7c7c7c;";
2942
  text2extra.style.cursor='not-allowed';
2943
  text2extra.disabled="disabled";
2944
  }
@@ -3375,9 +3671,12 @@ function filterFunction(id) {
3375
  input = document.getElementById(id);
3376
  filter = input.value.toUpperCase();
3377
  if (id.toString().startsWith('tomeasure'))
3378
- a = document.getElementById("measureselectid").children;
 
 
3379
  else
3380
- a = document.getElementById("relvselectid").children;
 
3381
  // a = div.getElementsByTagName("option");
3382
  for (i = 0; i < a.length; i++) {
3383
  txtValue = a[i].textContent || a[i].innerText;
@@ -3401,7 +3700,7 @@ document.getElementById("refreshDropboxButtonID").disabled=false;
3401
 
3402
  document.getElementById("refreshDropboxButtonID").onclick = function()
3403
  {
3404
- TopTextModal.textContent='Warning!';
3405
  if (document.getElementById("refreshDropboxButtonID").disabled==false)
3406
  overlayme.style.display = "block";
3407
  overlaymeText.textContent='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.';
@@ -3415,7 +3714,7 @@ var TopTextModal = document.getElementById("TopTextModalWarning");
3415
  document.getElementById("refreshAPIbutton").disabled=false;
3416
  document.getElementById("refreshAPIbutton").onclick = function()
3417
  {
3418
- TopTextModal.textContent='Warning!';
3419
  if (document.getElementById("refreshAPIbutton").disabled==false)
3420
  {
3421
  console.log(overlaymeText.textContent)
@@ -3432,7 +3731,8 @@ document.getElementById("popupforextratext").onclick = function(){
3432
  if (sectionNumber.startsWith('2.7'))
3433
  {
3434
  textextra= document.getElementById("textextra")
3435
- textextra.style.backgroundColor = "#7c7c7c;";
 
3436
  textextra.style.cursor='not-allowed';
3437
  textextra.disabled="disabled";
3438
 
@@ -3440,7 +3740,7 @@ if (sectionNumber.startsWith('2.7'))
3440
  if (sectionNumber.startsWith('2.8'))
3441
  {
3442
  text2extra= document.getElementById("text2extra")
3443
- text2extra.style.backgroundColor = "#7c7c7c;";
3444
  text2extra.style.cursor='not-allowed';
3445
  text2extra.disabled="disabled";
3446
  }
@@ -3460,7 +3760,7 @@ function confirmDialogR() {
3460
  /* code executed if confirm is clicked */
3461
  overlayme.style.display = "none";
3462
  console.log(document.getElementById("confirm").parentElement.parentElement.children[0].textContent)
3463
- if (document.getElementById("confirm").parentElement.parentElement.children[0].textContent.startsWith('Are'))
3464
  {
3465
  console.log('hereeeeeeeee')
3466
  callrefreshDropbox();
 
33
  {% include 'loading.html' %}
34
  </div>
35
  <!--Main tab links-->
36
+ <div class="tab" >
37
  <div class="container" id="toggle">
38
  <div class="bar1"></div>
39
  <div class="bar2"></div>
 
45
  <a class="tablinks" id="LegendHist" href="{{ url_for('legendDirectory') }}">
46
  Legends History <i class="fa fa-caret-down"></i>
47
  </a>
48
+ <!-- Container for dynamic tabs -->
49
+
50
+ <div id="dynamicTabs" class="dynamicdropdownclass">
51
+ <!-- This will be the dropdown content (FramestabsDropdown) -->
52
+ <!-- <div id="FramestabsDropdown"></div> -->
53
+ </div>
54
  <button class="dropbtn" onclick="userguideclick()"><img id="infoImg" src=""></button>
 
55
 
56
+ </div>
57
+ <div id="FramestabsDropdown"> </div>
58
  <div id="mySidebar" class="slide-out">
59
  <div id="menuOptions">
60
  <li onclick="openTab(event, 'home')" >Measure Plans </li>
 
63
  </div>
64
 
65
  <div id="home" class="tabcontent" >
66
+
67
  <div id="loading" hidden> </div>
68
 
69
  <div id="canvaswindow" hidden="until-found">
 
76
  </div>
77
  <input type="button" value="Save" id="savecanvas" />
78
  </div>
79
+
80
  <div id="rightside" hidden="until-found">
81
+
82
  <div id="backgroundimg" >
83
  <div id="imgs">
84
  <!-- image here -->
 
130
 
131
  </div>
132
  <div id="measureCheckbox">
133
+ <!-- <select style="margin-left: -1%;" hidden name="measureselectname" id="measureselectid" multiple size="5"></select> -->
134
+ <div id="measureContainer" hidden required></div>
135
  <div id="dxfdiv" hidden="until-found">
136
  <input type="button" id="pdftodxfFileButton" onclick="document.getElementById('pdftodxfFile').click();" value="Upload DXF File" >
137
  <input type="file" id="pdftodxfFile" name="pdftodxfFilename" >
 
152
  <input type="search" onkeyup=filterFunction(this.id) id="relevantSearchInput">
153
  <br>
154
  <div id ="relvdiv">
155
+ <div id="relvselectid" hidden></div>
156
+ <!-- <select style="margin-left: -1%;" hidden name="relvselectname" id="relvselectid" multiple size="5"> </select> -->
157
  <iframe id="pdfFrame" hidden></iframe>
158
  </div>
159
  </div>
 
193
  </div>
194
  <audio id="myAudio" autoplay></audio>
195
  </form>
196
+ <div id="progressBar" hidden>
197
+ <div id="progress">0%</div>
198
+ </div>
199
 
200
  <div id ="duplicater" class="duplicaterclass" hidden="until-found">
201
  <label id="labelArrayId" hidden="until-found"> </label>
 
280
  </ul>
281
 
282
  </div>
283
+ <div id="consoleContent"></div>
284
  <div class="dropdown-content">
285
  <div id="userguidetext">
286
  <div id="textfirstpage">
 
556
  <input type="number" id="textextra" name="text0name" placeholder="Eg: 1" >
557
  <input type="text" id="text0extra" name="text1name" placeholder="Eg: Wall Type" >
558
  <input type="text" id="text1extra" name="text2name" placeholder="Eg:NBS K10/" >
559
+ <input type="number" id="text2extra" name="text3name" placeholder="Eg: 3" min="0">
560
 
561
  <script src="https://cdn.lordicon.com/bhenfmcm.js" ></script>
562
  <lord-icon
 
613
  <script >
614
 
615
  ///////////////////////////////////////////////BEGIN JS CODE//////////////////////////////////////////////////
616
+
617
+
618
+ function updateProgressBar(value) {
619
+ const progressBar = document.getElementById('progress');
620
+ progressBar.style.width = value + '%';
621
+ progressBar.innerText = Math.round(value) + '%';
622
+ }
623
+
624
+
625
  // Function to send the Dropbox link and keyword to the server
626
  function getURLParams() {
627
  const urlParams = new URLSearchParams(window.location.search);
 
707
 
708
  displayprjnames()
709
  function displayprjnames(){
710
+
711
+ var eventSource = new EventSource('/getprojectnames/');
712
+ document.getElementById('progressBar').removeAttribute('hidden')
713
+ document.getElementById('progressBar').style.display='block';
714
+ eventSource.onmessage = function (event) {
715
+ var progress = parseInt(event.data); // Progress value from Flask
716
+ if (progress <= 100) {
717
+ console.log(progress); // Log progress for debugging
718
+ document.getElementById('progress').style.width = progress + '%';
719
+ document.getElementById('progress').textContent = progress + '%';
720
+ } else {
721
+ // Final data handling when progress reaches 100%
722
+ console.log('Process completed!');
723
+
724
+ // Parse and handle the final response data (documentsToMeasure, RelevantDocuments, extracted_path)
725
+ var data = JSON.parse(event.data); // Assuming the result is a JSON array
726
+ console.log('Final result:', data);
727
+ // You can use this data to update your page or handle it accordingly
728
+
729
+ eventSource.close(); // Close the connection when finished
730
+ document.getElementById('progressBar').setAttribute('hidden',true)
731
+ document.getElementById('progressBar').style.display='none';
732
+ document.getElementById('progress').style.width = '0%'; // Reset progress for the next process
733
+ document.getElementById('progress').textContent = '0%';
734
+
735
+ document.getElementById("all").style.display = "none";
736
+ prjids=data[1];
737
+ var op0 = document.createElement("OPTION") ;
738
+ op0.text= 'Projects'
739
+ op0.value= "";
740
+ op0.hidden=true;
741
+ firstdropdown.add(op0);
742
+ for (let i=0;i<data[0].length;i++)
743
+ {
744
+ opt=document.createElement("option");
745
+ opt.textContent=data[0][i];
746
+ opt.text=data[0][i];
747
+ firstdropdown.append(opt);
748
+ PrjNamesArray.push(data[0][i]);
749
+ }
750
 
751
+ }
752
+ }
753
+
754
+
755
+ eventSource.onerror = function (error) {
756
+ console.error('Error occurred:', error);
757
+ eventSource.close(); // Close on error
758
+ 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. ';
759
+ ShowPopUp();
760
+ };
761
  }
762
  /*Get chosen value and send to flask to get project parts*/
763
 
 
821
  function displayprojsections(projectid,Partid){
822
  console.log(seconddropdown.selectedIndex)
823
  document.getElementById("all").style.display = "block";
824
+ if (measSelect && measSelect.hasChildNodes()) {
825
+ while (measSelect.firstChild) {
826
+ measSelect.removeChild(measSelect.firstChild);
827
+ }
828
+ }
829
+
830
+ if (relvSelect && relvSelect.hasChildNodes()) {
831
+ while (relvSelect.firstChild) {
832
+ relvSelect.removeChild(relvSelect.firstChild);
833
+ }
834
+ }
835
  $.get('/getprojectsections/'+JSON.stringify([projectid,Partid]))
836
  .success(function(data){
837
  document.getElementById("all").style.display = "none";
 
1098
  //___________________________________________________________________________________________________________
1099
  /*Toggle Tab View of Home and Legend along with the Menu bar icon*/
1100
  function openTab(evt, tabname) {
 
1101
  var i, tabcontent, tablinks;
1102
 
1103
+
1104
+
1105
+ // Hide all tab contents
1106
  tabcontent = document.getElementsByClassName("tabcontent");
1107
  for (i = 0; i < tabcontent.length; i++) {
1108
  tabcontent[i].style.display = "none";
1109
  }
1110
 
1111
+ // Remove "active" class from all tab buttons
1112
  tablinks = document.getElementsByClassName("tablinks");
1113
  for (i = 0; i < tablinks.length; i++) {
1114
  tablinks[i].className = tablinks[i].className.replace(" active", "");
1115
  }
1116
 
1117
+ // Show selected tab content and mark button as active
1118
+ var tab = document.getElementById(tabname);
1119
+ if (tab) {
1120
+ tab.style.display = "block";
1121
+ tab.className += " active";
1122
+ // evt.currentTarget.className += " active";
1123
+ } else {
1124
+ console.error('Tab content with ID ' + tabname + ' not found.');
1125
+ }
 
1126
  }
1127
+
1128
+ // Start with the first tab open
1129
  document.getElementById("pagetitle").click();
1130
 
1131
+ // Function to add a new tab dynamically
1132
+ function addIframeTab(title, url) {
1133
+ var tabId = "tab_" + Date.now(); // Unique ID for each tab
1134
+
1135
+ // Create a new button in the ribbon
1136
+ var newTab = document.createElement("button");
1137
+ newTab.className = "tablinks";
1138
+ newTab.innerHTML = title + ' <i class="fa fa-times" onclick="removeTab(event, \'' + tabId + '\')"></i>';
1139
+ newTab.onclick = function (event) {
1140
+ // Delay opening the tab to ensure it has been added to the DOM
1141
+ setTimeout(function() {
1142
+ openTab(event, tabId);
1143
+ }, 10); // 10ms delay to allow DOM rendering
1144
+ };
1145
 
1146
+ // Dynamically create tab labels and append them to FramestabsDropdown
1147
+ var tabnameDrpdwn = document.createElement("label");
1148
+ tabnameDrpdwn.className = "tabslabel";
1149
+ tabnameDrpdwn.innerHTML = title
1150
+ // Append new tab button to the dynamicTabs container
1151
+ document.getElementById("dynamicTabs").appendChild(newTab);
1152
+ document.getElementById("FramestabsDropdown").appendChild(tabnameDrpdwn);
1153
+ tabnameDrpdwn.addEventListener('click',function(){
1154
+ openTab('click',tabId)
1155
+ })
1156
+
1157
+ // Event listener for mouseover on dynamicTabs
1158
+ document.getElementById("dynamicTabs").addEventListener('mouseover', function() {
1159
+ // Check and log all the labels inside FramestabsDropdown
1160
+ const labels = document.getElementById("FramestabsDropdown").children;
1161
+ if (labels.length > 0) {
1162
+ document.getElementById("FramestabsDropdown").style.display = 'block';
1163
+ }
1164
+ });
1165
 
1166
+ document.getElementById("FramestabsDropdown").addEventListener('mouseover', function() {
1167
+ // Stay visible when hovering over the dropdown
1168
+ document.getElementById("FramestabsDropdown").style.display = 'block';
1169
+ });
1170
 
1171
+ document.addEventListener('click', function(event) {
1172
+ const dropdown = document.getElementById("FramestabsDropdown");
1173
 
1174
+ if (!dropdown.contains(event.target)) {
1175
+ dropdown.style.display = 'none';
1176
+ }
1177
+ });
1178
 
1179
+ // Handle clicks inside iframes
1180
+ document.querySelectorAll("iframe").forEach((iframe) => {
1181
+ iframe.contentWindow?.addEventListener("mousedown", function () {
1182
+ document.getElementById("FramestabsDropdown").style.display = "none";
1183
+ });
1184
+ });
1185
+
1186
+
1187
+
1188
+ //FramestabsDropdown
1189
+ // Create a corresponding iframe container in the console
1190
+ var iframeContainer = document.createElement("div");
1191
+ iframeContainer.id = tabId;
1192
+ iframeContainer.className = "tabcontent";
1193
+ iframeContainer.style.display = "none"; // Initially hidden
1194
+
1195
+ // Create the iframe and set its source
1196
+ var iframe = document.createElement("iframe");
1197
+ iframe.src = url;
1198
+ iframe.style.width = "100%";
1199
+ iframe.style.height = "100vh";
1200
+
1201
+ iframeContainer.appendChild(iframe);
1202
+
1203
+ // Append the iframe container to the consoleContent area
1204
+ document.getElementById("consoleContent").appendChild(iframeContainer);
1205
+
1206
+ // Open the new tab after the content is added
1207
+ setTimeout(function() {
1208
+ newTab.click();
1209
+ }, 10); // Short delay before clicking the new tab
1210
+ }
1211
+
1212
+ // Function to remove a tab
1213
+ function removeTab(event, tabId) {
1214
+ event.stopPropagation(); // Prevent tab click event
1215
+
1216
+ var tabButton = event.target.parentElement;
1217
+ var tabContent = document.getElementById(tabId);
1218
+
1219
+ if (tabButton) tabButton.remove();
1220
+ if (tabContent) tabContent.remove();
1221
+
1222
+ // Switch to the home tab if the removed tab was active
1223
+ document.getElementById("pagetitle").click();
1224
+ }
1225
+ function downloadPdf(pdfname,downloadPDFName) {
1226
  console.log('pdfname===',pdfname)
1227
  fetch('/get-pdf/'+JSON.stringify(pdfname))
1228
  .then(response => response.blob())
 
1230
  const url = URL.createObjectURL(blob);
1231
  var link = document.createElement('a');
1232
  link.href = url;
1233
+ link.download = downloadPDFName;
1234
  link.dispatchEvent(new MouseEvent('click'));
1235
  })
1236
  .catch(error => console.error('Error fetching PDF:', error));
 
1486
  //___________________________________________________________________________________________________________
1487
 
1488
  //Retrieves list of projects
1489
+ var doorSchedulePDF;
1490
  function getproj(){
1491
  getALLMCTNAMES();
1492
 
 
1498
 
1499
  var sections = document.getElementsByClassName("selectionsProjs")[0];
1500
  chooseFirstdrpdwn();
1501
+ var eventSource = new EventSource('/getmethod/' + JSON.stringify(projectVal));
1502
+ document.getElementById('progressBar').removeAttribute('hidden')
1503
+ document.getElementById('progressBar').style.display='block';
1504
+ eventSource.onmessage = function (event) {
1505
+ var progress = parseInt(event.data); // Progress value from Flask
1506
+ if (progress <= 100) {
1507
+ console.log(progress); // Log progress for debugging
1508
+ document.getElementById('progress').style.width = progress + '%';
1509
+ document.getElementById('progress').textContent = progress + '%';
1510
+ } else {
1511
+ // Final data handling when progress reaches 100%
1512
+ console.log('Process completed!');
1513
+
1514
+ // Parse and handle the final response data (documentsToMeasure, RelevantDocuments, extracted_path)
1515
+ var data = JSON.parse(event.data); // Assuming the result is a JSON array
1516
+ console.log('Final result:', data);
1517
+ // You can use this data to update your page or handle it accordingly
1518
+
1519
+ eventSource.close(); // Close the connection when finished
1520
+ document.getElementById('progressBar').setAttribute('hidden',true)
1521
+ document.getElementById('progressBar').style.display='none';
1522
+ document.getElementById('progress').style.width = '0%'; // Reset progress for the next process
1523
+ document.getElementById('progress').textContent = '0%';
1524
+
1525
+
1526
+ document.getElementById('refreshDropboxButtonID').style.display = "block";
1527
+ document.getElementById("all").style.display = "none";
1528
+ if (sections.value.startsWith('3.2') || sections.value.startsWith('3.3') || sections.value.startsWith('2.7') ){
1529
+ document.getElementById('dxfdiv').removeAttribute('hidden');
1530
+ document.getElementById('pdftodxfFile').setAttribute('required',true)
1531
+ }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1532
 
1533
+ else{
1534
+ document.getElementById('dxfdiv').setAttribute('hidden',true)
1535
+ }
 
 
 
 
 
 
 
1536
 
1537
+ extracted_path=data[2]
1538
+ var docsToMeasure=data[0]; //
1539
+ var relvDocs=data[1]
1540
+ var projname = document.getElementsByClassName("selectionsProj")[0];
1541
+ var projpart = document.getElementsByClassName("selectionsProjp")[0];
1542
+ var projsec = document.getElementsByClassName("selectionsProjs")[0];
1543
 
1544
+ var meas = document.getElementById("measureCheckbox") ;
1545
+ var relv = document.getElementById("relvdiv") ;
1546
+ const measids=[];
1547
+ const relvids=[];
1548
+ const measoptns=[];
1549
 
1550
+ // var measSelect = document.getElementById("measureselectid");
1551
+ var measSelect = document.getElementById("measureContainer");
1552
+
1553
+ var relvSelect = document.getElementById("relvselectid");
1554
+ var levelcheckbox= document.getElementById("levelcheckbox");
1555
+
1556
+
1557
+ measSelect.removeAttribute("hidden");
1558
+ relvSelect.removeAttribute("hidden");
1559
+ if (measSelect && measSelect.hasChildNodes()) {
1560
+ while (measSelect.firstChild) {
1561
+ measSelect.removeChild(measSelect.firstChild);
1562
+ }
1563
+ }
1564
+
1565
+ var optn2 = document.createElement("div"); // Use a <div> instead of <option>
1566
+ optn2.textContent = 'Select project to measure'; // Set text content
1567
+ optn2.hidden = true; // Keep it hidden
1568
+ optn2.id = 'hidden';
1569
+
1570
+ measSelect.appendChild(optn2); // Append to div instead of .add()
1571
+ document.getElementById("hidden").required = true;
1572
+
1573
+
1574
+ if (relvSelect && relvSelect.hasChildNodes()) {
1575
+ while (relvSelect.firstChild) {
1576
+ relvSelect.removeChild(relvSelect.firstChild);
1577
+ }
1578
+ }
1579
+ const nameSet = new Set(); // To track unique names
1580
+ const nameSetRelv = new Set(); // To track unique names
1581
+
1582
+ // Action foconst nameSet = new Set(); // To track unique names
1583
+
1584
+ // Action for when the checkbox is clicked
1585
+ function handleCheckboxChange(event) {
1586
+ // Uncheck all checkboxes before checking the current one
1587
+ document.querySelectorAll('input[name="measureCheckbox"]').forEach(checkbox => {
1588
+ checkbox.checked = false;
1589
+ });
1590
 
1591
+ // Check the current checkbox
1592
+ event.target.checked = true;
1593
 
1594
+ // Action when checkbox is clicked (e.g., log the selected project)
1595
+ let selectedValue = event.target.value;
1596
+ console.log("Selected project:", selectedValue);
1597
+
1598
+ // Highlight the selected item
1599
+ document.querySelectorAll(".measure-item").forEach(item => {
1600
+ item.style.backgroundColor = ''; // Reset background color for all items
1601
+ });
1602
+ event.target.closest(".measure-item").style.backgroundColor = '#d3f8d3'; // Highlight the selected item
1603
+
1604
+
1605
+
1606
+ // Show alert immediately to prompt the user
1607
  if (projsec.value.startsWith('3.2') || projsec.value.startsWith('3.3') || projsec.value.startsWith('2.7')) {
1608
+ // downloadPdf(selectedValue);
1609
+ downloadPdf(selectedValue,'DXF_File_:'+selectedValue)
1610
+ // 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.");
 
 
1611
  }
1612
+ // else{
1613
+ // 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.");
1614
+ // }
1615
  canvasimg='';
1616
  ry=[[]];
1617
  levelcheckbox.checked=false;
1618
+ pdfname=selectedValue;
1619
  measSelect.style.boxShadow='none';
1620
 
1621
 
1622
  document.getElementById("all").style.display = "block";
1623
 
1624
  pixelArr=[projname.value, projpart.value,projsec.value, pdfname]
1625
+ // Open popup immediately before initiating the PDF download
1626
+ var eventSource = new EventSource('/pixelimg/' + JSON.stringify(pixelArr));
1627
+ document.getElementById('progressBar').removeAttribute('hidden')
1628
+ document.getElementById('progressBar').style.display='block';
1629
+ eventSource.onmessage = function (event) {
1630
+ var progress = parseInt(event.data); // Progress value from Flask
1631
+ if (progress <= 100) {
1632
+ console.log(progress); // Log progress for debugging
1633
+ document.getElementById('progress').style.width = progress + '%';
1634
+ document.getElementById('progress').textContent = progress + '%';
1635
+ } else {
1636
+ // Final data handling when progress reaches 100%
1637
+ console.log('Process completed!');
1638
+
1639
+ // Parse and handle the final response data (documentsToMeasure, RelevantDocuments, extracted_path)
1640
+ var data = JSON.parse(event.data); // Assuming the result is a JSON array
1641
+ console.log('Final result:', data);
1642
+ // You can use this data to update your page or handle it accordingly
1643
+
1644
+ eventSource.close(); // Close the connection when finished
1645
+
1646
+ document.getElementById('progressBar').setAttribute('hidden',true)
1647
+ document.getElementById('progressBar').style.display='none';
1648
+ document.getElementById('progress').style.width = '0%'; // Reset progress for the next process
1649
+ document.getElementById('progress').textContent = '0%';
1650
+ document.getElementById("all").style.display = "none";
1651
+ // Display link or any additional data if needed
1652
+ window.open(data[2]);
1653
+ downloadPdf(pdfname,'Pixel_Conversion_File_:'+pdfname)
1654
+ document.getElementById("all").style.display = "none";
1655
+
1656
+ document.getElementById('measureADRbutton').onclick= function()
1657
+ {
1658
+ if (!areaRatio.value){
1659
+ if (!(projsec.value.startsWith('3.2')) & !(projsec.value.startsWith('2.8')) & !(projsec.value.startsWith('3.3')) & !(projsec.value.startsWith('2.7')) )
1660
+ areaRatio.style.boxShadow='0 0 8px 2px rgb(255, 0, 0)';
1661
+ }
1662
+ if (!prmRatio.value)
1663
+ {
1664
+ if (!(projsec.value.startsWith('2.8')))
1665
+ prmRatio.style.boxShadow='0 0 8px 2px rgb(255, 0, 0)';
1666
+ }
1667
+
1668
+ }
1669
+ document.getElementById('radiosColors').removeAttribute('hidden');
1670
+ var scalelbl= document.createElement("label");
1671
+ scalelbl.innerText='Scale Document';
1672
+ scalelbl.id='measureLabel';
1673
+ var br1= document.createElement("br");
1674
+ var areadiv=document.createElement("div");
1675
+ areadiv.id='areadiv'
1676
+ var areaRatiolbl= document.createElement("label");
1677
+ areaRatiolbl.innerText='Area:'
1678
+ areaRatiolbl.id='radiolbl';
1679
+
1680
+ var areaRatio= document.createElement("input");
1681
+ areaRatio.type='number';
1682
+ areaRatio.id='arealvlinput';
1683
+ areaRatio.className='lvlinput';
1684
+ areaRatio.name='areaRatio';
1685
+ areaRatio.style.marginLeft='78px';
1686
+ areaRatio.style.textAlign='right';
1687
+ areaRatio.step=".0000001";
1688
+ areaRatio.min = "0"; // Allow only positive numbers (>= 0)
1689
+ if( projsec.value.startsWith('3.2') || projsec.value.startsWith('3.3') || projsec.value.startsWith('2.1') || projsec.value.startsWith('2.7')){
1690
+ areaRatio.setAttribute('disabled',true)
1691
+ areaRatio.style.cursor='not-allowed';
1692
+ areaRatio.style.backgroundColor='rgba(101, 101, 101, 0.27)'
1693
+ document.getElementById('selectunitA').setAttribute('disabled',true)
1694
+ document.getElementById('selectunitA').style.cursor='not-allowed';
1695
+ document.getElementById('selectunitA').style.backgroundColor='rgba(101, 101, 101, 0.27)'
1696
+ }
1697
+
1698
+ else{ // section 1.0
1699
+ areaRatio.removeAttribute('disabled')
1700
+ areaRatio.style.cursor='pointer';
1701
+ document.getElementById('selectunitA').removeAttribute('disabled')
1702
+ document.getElementById('selectunitA').style.cursor='pointer';
1703
+ }
1704
+ areaRatio.addEventListener('change',function(){
1705
+ areaRatio.value=(Number(areaRatio.value)).toFixed(7)
1706
+ areaRatio.style.boxShadow='none';
1707
+ })
1708
+ areaRatio.required=true;
1709
+ selectunitA=document.getElementById('selectunitA')
1710
+ selectunitA.removeAttribute('hidden')
1711
+
1712
+ areadiv.append(areaRatiolbl,areaRatio,selectunitA)
1713
+ var br2= document.createElement("br");
1714
+ var br3= document.createElement("br");
1715
+ var prmdiv=document.createElement("div");
1716
+ prmdiv.id='prmdiv'
1717
+ var prmRatiolbl= document.createElement("label");
1718
+ prmRatiolbl.innerText='Perimeter:'
1719
+ prmRatiolbl.id='radiolbl';
1720
+
1721
+ var prmRatio= document.createElement("input");
1722
+ prmRatio.type='number';
1723
+ prmRatio.id='perimlvlinput';
1724
+ prmRatio.className='lvlinput';
1725
+ prmRatio.name='prmRatio';
1726
+ prmRatio.style.textAlign='right';
1727
+ prmRatio.style.marginLeft='49px';
1728
+ prmRatio.step=".0000001";
1729
+ prmRatio.min = "0"; // Allow only positive numbers (>= 0)
1730
+ prmRatio.addEventListener('change',function(){
1731
+ prmRatio.value=(Number(prmRatio.value)).toFixed(7)
1732
+ prmRatio.style.boxShadow='none';
1733
+ })
1734
+ prmRatio.required=true;
1735
+ selectunitP=document.getElementById('selectunitP')
1736
+ selectunitP.removeAttribute('hidden')
1737
+
1738
+ prmdiv.append(prmRatiolbl, prmRatio,selectunitP)
1739
+ var ratiosdiv= document.getElementById("ratios");
1740
+ ratiosdiv.innerHTML='';
1741
+ ratiosdiv.append(scalelbl);
1742
+ ratiosdiv.append(br1);
1743
+ ratiosdiv.append(areadiv)
1744
+ ratiosdiv.append(prmdiv)
1745
+ areainpixels=data[0];
1746
+ prminpixels=data[1];
1747
+
1748
+
1749
+ if( projsec.value.startsWith('2.8')) {
1750
+ areaRatio.setAttribute('disabled',true)
1751
+ areaRatio.style.cursor='not-allowed';
1752
+ areaRatio.style.backgroundColor='rgba(101, 101, 101, 0.27)'
1753
+ document.getElementById('selectunitA').setAttribute('disabled',true)
1754
+ document.getElementById('selectunitA').style.cursor='not-allowed';
1755
+ document.getElementById('selectunitA').style.backgroundColor='rgba(101, 101, 101, 0.27)'
1756
+
1757
+ prmRatio.setAttribute('disabled',true)
1758
+ prmRatio.style.cursor='not-allowed';
1759
+ prmRatio.style.backgroundColor='rgba(101, 101, 101, 0.27)'
1760
+ document.getElementById('selectunitP').setAttribute('disabled',true)
1761
+ document.getElementById('selectunitP').style.cursor='not-allowed';
1762
+ document.getElementById('selectunitP').style.backgroundColor='rgba(101, 101, 101, 0.27)'
1763
+ }
1764
+ };
1765
+ }
1766
 
1767
 
1768
+ eventSource.onerror = function (error) {
1769
+ console.error('Error occurred:', error);
1770
+ eventSource.close(); // Close on error
1771
+ 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. ';
1772
+ ShowPopUp();
1773
+ };
1774
+
1775
+ selectunitA.addEventListener('change',function(){
1776
+ value=document.getElementById('selectunitA').value
1777
+ if (value=='mm2')
1778
+ ratioAunit=1000000;
1779
+ else
1780
+ ratioAunit=1;
1781
+ })
1782
+ selectunitP.addEventListener('change',function(){
1783
+ value=document.getElementById('selectunitP').value
1784
+ if (value=='mm'){
1785
+ ratioPunit=1000;
1786
+ }
1787
+ else
1788
+ ratioPunit=1;
1789
+
1790
+ })
1791
+ // }
1792
+ // for 2.8 multiple pdfs
1793
+ // else{
1794
+ // pdfnames=getSelectValues(elem)
1795
+ // }
1796
+ }
1797
+
1798
+ // Action for when the label is clicked (no checkbox change)
1799
+ function handleLabelClick(event) {
1800
+ // Action when label is clicked (e.g., log the selected project via the label)
1801
+ let selectedLabel = event.target.textContent;
1802
+ console.log("Label clicked: ", selectedLabel);
1803
+ // Optional: Highlight the selected item
1804
+ document.querySelectorAll(".measure-item").forEach(item => {
1805
+ item.style.backgroundColor = ''; // Reset background color for all items
1806
+ });
1807
+ // event.target.closest(".measure-item").style.backgroundColor = '#919592'; // Highlight the selected item
1808
+ // Show loading indicator
1809
+ document.getElementById("all").style.display = "block";
1810
+ fetch('/getdropboxurl/'+ JSON.stringify(selectedLabel), {
1811
+
1812
+ method: 'POST',
1813
+ headers: { 'Content-Type': 'application/json' },
1814
+ body: JSON.stringify({ filename: "your_pdf_filename_here.pdf" })
1815
+ })
1816
+ .then(response => response.blob())
1817
+ .then(blob => {
1818
+ document.getElementById("all").style.display = "none";
1819
+ const url = URL.createObjectURL(blob);
1820
+ // Set the URL to the iframe's src to load the content inside the page
1821
+ addIframeTab(selectedLabel,url);
1822
+ // addIframeTab("Google", "https://www.google.com");
1823
+ })
1824
+ .catch(function(jqXHR, textStatus, errorThrown) {
1825
+ // Handle error
1826
+ 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.';
1827
+ ShowPopUp();
1828
+ });
1829
+ }
1830
 
1831
+ for (let i = 0; i < docsToMeasure.length; i++) {
1832
+ let name = docsToMeasure[i][0];
1833
+
1834
+ // Create div for the measure item
1835
+ let div = document.createElement("div");
1836
+ div.className = "measure-item";
1837
+
1838
+ // Create the checkbox
1839
+ let checkbox = document.createElement("input");
1840
+ checkbox.type = "checkbox";
1841
+ checkbox.name = "measureCheckbox";
1842
+ checkbox.value = name;
1843
+ checkbox.onclick = handleCheckboxChange; // Handle checkbox click
1844
+
1845
+ // Create the label
1846
+ let label = document.createElement("label");
1847
+ label.textContent = name;
1848
+ label.onclick = handleLabelClick; // Handle label click
1849
+
1850
+ // Append checkbox and label to the div
1851
+ div.appendChild(checkbox);
1852
+ div.appendChild(label);
1853
+
1854
+ // Append the item to the select container
1855
+ measSelect.appendChild(div);
1856
+ // Check for duplicates
1857
+ if (nameSet.has(name)) {
1858
+ label.style.color = "red"; // Highlight duplicate (optional)
1859
 
1860
+ document.getElementById("TopTextModal").textContent='Error: Duplicates Error'
1861
+ 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.';
1862
+ ShowPopUp();
1863
+ } else {
1864
+ nameSet.add(name); // Add unique name to the set
1865
+ }
1866
+ }
1867
+
1868
+
1869
+
1870
+ for (let i = 0; i < relvDocs.length; i++) {
1871
+ let name = relvDocs[i][0];
1872
+
1873
+ // Create div for the measure item
1874
+ let div = document.createElement("div");
1875
+ div.className = "relv-item"; //relvselectid .relv-item
1876
+ // Create the label
1877
+ let label = document.createElement("label");
1878
+ label.textContent = name;
1879
+ label.onclick= function(event)
1880
+ {
1881
+ // Action when label is clicked (e.g., log the selected project via the label)
1882
+ let relevantDocumentName = event.target.textContent;
1883
+ console.log("Label clicked: ", relevantDocumentName);
1884
+ if (projsec.value.startsWith('2.8')){
1885
+ doorSchedulePDF=relevantDocumentName
1886
+ console.log(doorSchedulePDF)
1887
  }
1888
+ // Optional: Highlight the selected item
1889
+ document.querySelectorAll(".relv-item").forEach(item => {
1890
+ item.style.backgroundColor = ''; // Reset background color for all items
1891
+
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1892
  });
1893
+ event.target.closest(".relv-item").style.backgroundColor ='#d3f8d3'; // Highlight the selected item
1894
+ document.getElementById('relvselectid').style.boxShadow='';
1895
+ };
1896
+
1897
+
1898
+ div.appendChild(label);
1899
+
1900
+ // Append the item to the select container
1901
+ relvSelect.appendChild(div);
1902
+ // Handle duplicate names
1903
+ if (nameSetRelv.has(name)) {
1904
+ label.style.color = "red"; // Highlight duplicate (optional)
1905
+ } else {
1906
+ nameSetRelv.add(name);
1907
+ }
1908
+ }
1909
+
1910
+ relvids.push(relvSelect) ;
1911
+ measids.push(measSelect);
1912
+
1913
+ document.addEventListener("click", function(event) {
1914
+ const iframe = document.getElementById("pdfFrame");
1915
+ if (!iframe.contains(event.target)) {
1916
+ const iframe = document.getElementById("pdfFrame");
1917
+ iframe.style.display = "none";
1918
+ }
1919
+ });
1920
+ document.getElementById('measureADRbutton').onclick= function()
1921
+ {
1922
+ if (!measSelect.value) {
1923
+ measSelect.style.boxShadow = '0 0 8px 2px rgb(255, 0, 0)';
1924
+ measSelect.setAttribute("required", "")
1925
  }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1926
 
1927
+ if (!relvSelect.value) {
1928
+ if (sectionNumber.startsWith('2.8')) {
1929
+ relvSelect.style.boxShadow = '0 0 8px 2px rgb(255, 0, 0)';
1930
+ relvSelect.setAttribute("required", "")
1931
+ }
1932
+ }
1933
+
1934
+
1935
+ }
1936
+
1937
+ }
1938
+
1939
+
1940
+ if (document.getElementById('arealvlinput')){
1941
+ if( projsec.value.startsWith('3.2') || projsec.value.startsWith('2.8') || projsec.value.startsWith('3.3') || projsec.value.startsWith('2.1') || projsec.value.startsWith('2.7')){
1942
+ document.getElementById('arealvlinput').setAttribute('disabled',true)
1943
+ document.getElementById('selectunitA').setAttribute('disabled',true)
1944
+ }
1945
+ else{ // section 1.0
1946
+ document.getElementById('arealvlinput').removeAttribute('disabled')
1947
+ document.getElementById('selectunitA').removeAttribute('disabled')
1948
+ }
1949
+ }
1950
+
1951
+ };
1952
+
1953
+ eventSource.onerror = function (error) {
1954
+ console.error('Error occurred:', error);
1955
+ eventSource.close(); // Close on error
1956
  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. ';
1957
  ShowPopUp();
1958
+ };
1959
+
 
 
 
 
 
 
 
 
 
1960
  }
1961
  //___________________________________________________________________________________________________________
1962
  //___________________________________________________________________________________________________________
 
2038
  legendbutton.style.boxShadow = 'none';
2039
  });
2040
 
2041
+
2042
+ if (sectionNumber.startsWith('2.8')){
2043
+ legendbutton.setAttribute('disabled',true);
2044
+ legendbutton.style.cursor='not-allowed';
2045
+ }
2046
+ else{
2047
+ legendbutton.addEventListener('click', function () {
2048
  window.open(spreadsheetLink);
2049
  });
2050
+ }
2051
  //////////////////////////////////////////////////////////////
2052
  var imgbutton = document.createElement("button");
2053
  imgbutton.className = 'measureADRbutton2';
 
2187
 
2188
  console.log(formData,formvalues)
2189
  // iterate through entries...
2190
+ tomeasureproj=formvalues['measureCheckbox']; //proj name
 
2191
 
2192
 
2193
  if( formvalues['selectprojs'].startsWith('3.2') || formvalues['selectprojs'].startsWith('3.3') || formvalues['selectprojs'].startsWith('2.7') ){
 
2241
  answers.push(tomeasureproj, 0,[] , ratio1, ratio2 ,pdfpath);
2242
  formData.append('answers',JSON.stringify(answers))
2243
  }
2244
+ else if (formvalues['selectprojs'].startsWith('2.1'))
2245
  {
2246
  answers.push(tomeasureproj, 0,[] , ratio1, ratio2 ,pdfpath);
2247
  formData.append('answers',JSON.stringify(answers))
2248
  }
2249
+ else if (formvalues['selectprojs'].startsWith('2.8') )
2250
+ {
2251
+ answers.push(tomeasureproj, 0,[] , 0,0,pdfpath , doorSchedulePDF);
2252
+ formData.append('answers',JSON.stringify(answers))
2253
+ }
2254
  }
2255
 
2256
  if (formvalues['selectprojs'].startsWith('1.0') || formvalues['selectprojs'].startsWith('3.2') || formvalues['selectprojs'].startsWith('2.8') || formvalues['selectprojs'].startsWith('3.3') || formvalues['selectprojs'].startsWith('2.7') ) //formvalues['selectprojs'].startsWith('2.1')
 
2258
  // console.log(formData)
2259
  $.ajax({
2260
  type: "POST",
 
2261
  url: "/savebase64Img/",
2262
+ contentType: "application/json", // set content type header to use Flask response.get_json()
2263
+ data: formData,// convert data/object to JSON to send
 
 
 
 
2264
  processData: false, // Prevent jQuery from automatically processing the data
2265
  contentType: false,
 
 
 
 
 
 
2266
  success: function(response) {
2267
  console.log(response);
2268
  },
2269
  error: function(err) {
2270
+ var TopTextModal = document.getElementById("TopTextModalWarning");
2271
+ TopTextModal.textContent='Error'
2272
  PopupElement.textContent='Error occured. Refresh and try again. If the error continues, please contact the ADR team to fix it. ';
2273
  ShowPopUp();
2274
 
 
2278
  // var mp3_url = 'https://media.geeksforgeeks.org/wp-content/uploads/20190531135120/beep.mp3';
2279
  // (new Audio(mp3_url)).play()
2280
  // retrieveLinks()
2281
+ if (!(formvalues['selectprojs'].startsWith('2.8')) )
2282
+ startDropdownUpdates(); // Start the dropdown updates
2283
 
2284
 
2285
  document.getElementById("loading").hidden = true;
 
2333
 
2334
  }
2335
  if (formvalues['selectprojs'].startsWith('2.8'))
2336
+ { //base64.b64encode(buffer).decode('utf-8') ,pdflink,list1.to_dict(), repeated_labels , not_found]
2337
+ // /* data[0]--> img , data[1]-->dataframe (goes to legend lsa ) , data [2] -->pdf dropbox shareable link ,data[3]-> spreadsheetId, data[4],spreadsheeturl */
2338
  // SimilarAreaDictionary=data[1];
2339
  // listofimages=data[0];
2340
  dropboxLink=data[1];
2341
+ list1= data[2] // list of pdf markups
2342
+ Repeated_Labels2_8=data[3]
2343
+ Not_Found2_8=data[4]
 
 
2344
  }
2345
  if (formvalues['selectprojs'].startsWith('2.2'))
2346
  {
 
2377
  // if (!(formvalues['selectprojs'].startsWith('2.8')))
2378
  // {
2379
  ImgSide(data[0],spreadsheetURL,dropboxLink)
2380
+ if (formvalues['selectprojs'].startsWith('2.8')) {
2381
+ let messages = [];
2382
+
2383
+ if (Repeated_Labels2_8.length > 0) {
2384
+ messages.push('The following label(s) are represented on multiple doors: ' + Repeated_Labels2_8);
2385
+ }
2386
+
2387
+ if (Not_Found2_8.length > 0) {
2388
+ messages.push('The following label(s) not found on the plan: ' + Not_Found2_8);
2389
+ }
2390
+
2391
+ if (messages.length > 0) {
2392
+ var TopTextModal = document.getElementById("TopTextModalWarning");
2393
+ TopTextModal.textContent = 'Warning';
2394
+
2395
+ PopupElement.textContent = messages.join('\n'); // Show both messages if both conditions are met
2396
+ ShowPopUp();
2397
+ }
2398
+ }
2399
+
2400
  // }
2401
 
2402
  // else{
 
2435
  dict1: JSON.stringify(list1),
2436
  spreadsheetId: spreadsheetId,
2437
  pdfpathpath: JSON.stringify(pdfpath),
2438
+ path: Object.fromEntries(formData)['measureCheckbox']
2439
  }),
2440
  dataType: "json",
2441
  success: function (data1) {
 
2444
  },
2445
  error: function (err) {
2446
  console.error('Error occurred during first AJAX call:', err);
2447
+ var TopTextModal = document.getElementById("TopTextModalWarning");
2448
+ TopTextModal.textContent='Error'
2449
  PopupElement.textContent = 'Error occurred. Refresh and try again. If the error continues, please contact the ADR team to fix it.';
2450
  ShowPopUp();
2451
  }
 
2465
  dict1: JSON.stringify(list1),
2466
  spreadsheetId: spreadsheetId,
2467
  pdfpathpath: JSON.stringify(pdfpath),
2468
+ path: Object.fromEntries(formData)['measureCheckbox']
2469
  }),
2470
  dataType: "json"
2471
  });
 
2484
  document.getElementById("loading").style.marginTop = '20%';
2485
  document.getElementById("loading").style.marginLeft = '65%';
2486
 
2487
+ updatepreview([pdfpath, Object.fromEntries(formData)['measureCheckbox']]);
2488
 
2489
  await $.ajax({
2490
  type: "POST",
 
2493
  data: JSON.stringify({
2494
  dict: JSON.stringify(SimilarAreaDictionary),
2495
  deletedrows: delrows2,
2496
+ path: Object.fromEntries(formData)['measureCheckbox'],
2497
  spreadsheetId: spreadsheetId,
2498
  areaPermArr: JSON.stringify(data[7]),
2499
  section: Object.fromEntries(formData)['selectprojs'],
 
2507
  }
2508
 
2509
  } catch (err) {
2510
+ var TopTextModal = document.getElementById("TopTextModalWarning");
2511
+ TopTextModal.textContent='Error'
2512
  console.error('Error occurred during fetchAndCompareData:', err);
2513
  PopupElement.textContent = 'Error occurred. Refresh and try again. If the error continues, please contact the ADR team to fix it.';
2514
  ShowPopUp();
 
2534
  /////////////////////////
2535
  });
2536
  }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2537
 
2538
  }
2539
  //___________________________________________________________________________________________________________
2540
  //___________________________________________________________________________________________________________
2541
  document.getElementById("myForm").addEventListener("submit", function (e) {
2542
+ let isChecked = document.querySelector('input[name="measureCheckbox"]:checked') !== null;
2543
+ let sectionNumber = projsec.value; // Ensure projsec is defined
2544
+ let isRelvClicked = document.querySelector(".relv-item[style*='background-color']") !== null;
2545
+
2546
+ let TopTextModal = document.getElementById("TopTextModal");
2547
+ TopTextModal.textContent = "Warning: Missing Inputs";
2548
+ if (sectionNumber.startsWith('2.8')) {
2549
+
2550
+ // If section starts with '2.8', both measureCheckbox and relv-item must be selected
2551
+ if (!isChecked & !isRelvClicked) {
2552
+ document.getElementById('relvselectid').style.boxShadow='0 0 8px 2px rgb(255, 0, 0)';
2553
+ e.preventDefault(); // Prevent form submission
2554
+ PopupElement.textContent = "Please select at least one project from 'Documents to Measure' and one relevant item rom 'Other Relevant Documents' before proceeding!";
2555
+ ShowPopUp();
2556
+ return;
2557
+ }
2558
+ else if (!isChecked){
2559
+
2560
+ e.preventDefault(); // Prevent form submission
2561
+ PopupElement.textContent = "Please select at least one project from 'Documents to Measure' before proceeding!";
2562
+ ShowPopUp();
2563
+ return;
2564
+ }
2565
+ else if (!isRelvClicked){
2566
+ document.getElementById('relvselectid').style.boxShadow='0 0 8px 2px rgb(255, 0, 0)';
2567
+ e.preventDefault(); // Prevent form submission
2568
+ PopupElement.textContent = "Please select at least one relevant item from 'Other Relevant Documents' before proceeding!";
2569
+ ShowPopUp();
2570
+ return;
2571
+ }
2572
+ } else {
2573
+ // If section is not '2.8', only measureCheckbox is required
2574
+ if (!isChecked) {
2575
+ e.preventDefault(); // Prevent form submission
2576
+ PopupElement.textContent = "Please select at least one project before proceeding from 'Documents to Measure' section!";
2577
+ ShowPopUp();
2578
+ return;
2579
+ }
2580
+ }
2581
+
2582
+ // If validation passes, proceed with form submission
2583
+ getData(e.target);
2584
  });
2585
+
2586
  ////////////////////////////////////////////
2587
  var measitemVal='';
2588
 
 
3226
  if (sectionNumber.startsWith('2.7'))
3227
  {
3228
  textextra= cloneExtra.children[0]
3229
+ textextra.style.backgroundColor = "rgba(101, 101, 101, 0.27)";
3230
  textextra.style.cursor='not-allowed';
3231
  textextra.disabled="disabled";
3232
 
 
3234
  if (sectionNumber.startsWith('2.8'))
3235
  {
3236
  text2extra= cloneExtra.children[3]
3237
+ text2extra.style.backgroundColor ="rgba(101, 101, 101, 0.27)";
3238
  text2extra.style.cursor='not-allowed';
3239
  text2extra.disabled="disabled";
3240
  }
 
3671
  input = document.getElementById(id);
3672
  filter = input.value.toUpperCase();
3673
  if (id.toString().startsWith('tomeasure'))
3674
+ a = document.querySelectorAll("#measureContainer .measure-item");
3675
+
3676
+ // a = document.getElementById("measureselectid").children;
3677
  else
3678
+ // a = document.getElementById("relvselectid").children;
3679
+ a = document.querySelectorAll("#relvselectid .relv-item");
3680
  // a = div.getElementsByTagName("option");
3681
  for (i = 0; i < a.length; i++) {
3682
  txtValue = a[i].textContent || a[i].innerText;
 
3700
 
3701
  document.getElementById("refreshDropboxButtonID").onclick = function()
3702
  {
3703
+ TopTextModal.textContent='Warning: Dropbox Refresh';
3704
  if (document.getElementById("refreshDropboxButtonID").disabled==false)
3705
  overlayme.style.display = "block";
3706
  overlaymeText.textContent='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.';
 
3714
  document.getElementById("refreshAPIbutton").disabled=false;
3715
  document.getElementById("refreshAPIbutton").onclick = function()
3716
  {
3717
+ TopTextModal.textContent='Warning: MC Refresh';
3718
  if (document.getElementById("refreshAPIbutton").disabled==false)
3719
  {
3720
  console.log(overlaymeText.textContent)
 
3731
  if (sectionNumber.startsWith('2.7'))
3732
  {
3733
  textextra= document.getElementById("textextra")
3734
+ textextra.style.backgroundColor = "rgba(101, 101, 101, 0.27)";
3735
+ // textextra.style.border='2px solid #2f83c6'
3736
  textextra.style.cursor='not-allowed';
3737
  textextra.disabled="disabled";
3738
 
 
3740
  if (sectionNumber.startsWith('2.8'))
3741
  {
3742
  text2extra= document.getElementById("text2extra")
3743
+ text2extra.style.backgroundColor = "rgba(101, 101, 101, 0.27)";
3744
  text2extra.style.cursor='not-allowed';
3745
  text2extra.disabled="disabled";
3746
  }
 
3760
  /* code executed if confirm is clicked */
3761
  overlayme.style.display = "none";
3762
  console.log(document.getElementById("confirm").parentElement.parentElement.children[0].textContent)
3763
+ if (document.getElementById("confirm").parentElement.parentElement.children[0].textContent.startsWith('The'))
3764
  {
3765
  console.log('hereeeeeeeee')
3766
  callrefreshDropbox();