Spaces:
Sleeping
Sleeping
| <html lang="en" dir="ltr"> | |
| <head> | |
| <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> | |
| <link href="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.3/css/select2.min.css" rel="stylesheet"/> | |
| <script src="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.3/js/select2.min.js"></script> | |
| <link rel="stylesheet" href="https://use.typekit.net/zos0ars.css"> | |
| <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css"> | |
| <link rel="stylesheet" href="static/style.css"> | |
| <link rel="stylesheet" href="static/MenuStyle.css"> | |
| <link rel="stylesheet" href="static/LegendPageStyle.css"> | |
| <link rel="stylesheet" href="static/popups.css"> | |
| <link rel="stylesheet" href="static/IMG-Larger.css"> | |
| <link rel="stylesheet" href="static/searchButton.css"> | |
| <meta charset="utf-8"> | |
| <title>ADR Console</title> | |
| <link rel = "icon" type = "image/png" sizes = "180x154" href = "static/images/TSAlogoCropped180x154.png"> | |
| <link rel = "icon" type = "image/png" sizes = "32x27" href = "static/images/TSAlogoCropped32x27.png"> | |
| <link rel = "icon" type = "image/png" sizes = "16x14" href = "static/images/TSAlogoCropped16x14.png"> | |
| <link rel = "mask-icon" href = "static/images/TSAlogoCropped180x154.png"> | |
| <link rel = "shortcut icon" href = "static/images/TSAlogoCropped180x154.png"> | |
| </head> | |
| <body > | |
| <div id="pdf-container"></div> | |
| <div id="all"> | |
| <!-- {% include 'loading.html' %} --> | |
| {% include 'loading.html' %} | |
| </div> | |
| <!--Main tab links--> | |
| <div class="tab" > | |
| <div class="container" id="toggle"> | |
| <div class="bar1"></div> | |
| <div class="bar2"></div> | |
| <div class="bar3"></div> | |
| </div> | |
| <button class="tablinks" id="pagetitle" onclick="openTab(event, 'home')">ADR Console <i class="fa fa-home" > </i></button> | |
| <!-- <button class="tablinks" id="LegendHist" onclick="openTab(event, 'legends')">Legends History <i class="fa fa-caret-down"></i></button> --> | |
| <a class="tablinks" id="LegendHist" href="{{ url_for('legendDirectory') }}"> | |
| Legends History <i class="fa fa-caret-down"></i> | |
| </a> | |
| <!-- Container for dynamic tabs --> | |
| <div id="dynamicTabs" class="dynamicdropdownclass"> | |
| <!-- This will be the dropdown content (FramestabsDropdown) --> | |
| <!-- <div id="FramestabsDropdown"></div> --> | |
| </div> | |
| <button class="dropbtn" onclick="userguideclick()"><img id="infoImg" src=""></button> | |
| </div> | |
| <div id="FramestabsDropdown"> </div> | |
| <div id="mySidebar" class="slide-out"> | |
| <div id="menuOptions"> | |
| <li onclick="openTab(event, 'home')" >Measure Plans </li> | |
| <li><a href="{{ url_for('searchDocument') }}">Search in Documents</a></li> | |
| </div> | |
| </div> | |
| <div id="home" class="tabcontent" > | |
| <div id="loading" hidden> </div> | |
| <div id="canvaswindow" hidden="until-found"> | |
| <canvas id="myCanvas"></canvas> | |
| <br> | |
| <input type="button" value="Draw New Shape" id="NewShapeButtonId" /> | |
| <input type="button" value="Undo" id="undoButtonId" /> | |
| <div id="colorpickers"> | |
| <input type="color" id="color" value="#2FFFFF" > | |
| </div> | |
| <input type="button" value="Save" id="savecanvas" /> | |
| </div> | |
| <div id="rightside" hidden="until-found"> | |
| <div id="backgroundimg" > | |
| <div id="imgs"> | |
| <!-- image here --> | |
| </div> | |
| <div id="underimgbuttons"> | |
| <!-- buttons here --> | |
| </div> | |
| </div> | |
| </div> | |
| <div id="myModal" class="modal" > | |
| <span class="close">×</span> | |
| <img class="modal-content" id="img01"> | |
| <div id="caption"></div> | |
| </div> | |
| <form method="post" id="myForm" enctype="multipart/form-data"> | |
| <!-- <div class="projnamedp"> | |
| <input type="text" placeholder="Project" name="selectproj" class="selectionsProj" id="selectionsProjid" oninput="filterFunction(this,event)" > | |
| <ul> | |
| </ul> | |
| </div> --> | |
| <input type="button" id="refreshAPIbutton" title="Refresh data retrieved from MC" value="Refresh data retrieved from MC "> | |
| <div id =""> | |
| <select name="selectproj" class="selectionsProj" id="selectionsProjid" required > </select> | |
| </div> | |
| <div id ="projectpart"> | |
| <select name="selectprojp" class="selectionsProjp" id="selectionsProjpid" required> </select> | |
| </div> | |
| <div id ="projectsection"> | |
| <select name="selectprojs" class="selectionsProjs" onchange=getproj() required> </select> | |
| </div> | |
| <div id ="tomeasurediv"> | |
| <div> | |
| <label id="measureLabel">Document To Measure</label> | |
| <input type="search" onkeyup=filterFunction(this.id) id="tomeasureSearchInput"> | |
| <!-- <button id="refreshDropboxButtonID"></button> --> | |
| <i hidden class="fa fa-dropbox fa-lg" id="refreshDropboxButtonID"> | |
| <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> | |
| </div> | |
| <div id="measureCheckbox"> | |
| <!-- <select style="margin-left: -1%;" hidden name="measureselectname" id="measureselectid" multiple size="5"></select> --> | |
| <div id="measureContainer" hidden required></div> | |
| <div id="dxfdiv" hidden="until-found"> | |
| <input type="button" id="pdftodxfFileButton" onclick="document.getElementById('pdftodxfFile').click();" value="Upload DXF File" > | |
| <input type="file" id="pdftodxfFile" name="pdftodxfFilename" > | |
| </div> | |
| <select id='selectunitA' hidden> | |
| <option id="m2" value="m2" >m² </option> | |
| <option id="mm2" value="mm2" >mm² </option> | |
| </select> | |
| <select id='selectunitP' hidden> | |
| <option id="m" value="m" >m </option> | |
| <option id="mm"value="mm" >mm </option> | |
| </select> | |
| </div> | |
| </div> | |
| <div id ="relvDocdiv"> | |
| <label id="relvDocLabel">Other Relevant Documents</label> | |
| <input type="search" onkeyup=filterFunction(this.id) id="relevantSearchInput"> | |
| <br> | |
| <div id ="relvdiv"> | |
| <div id="relvselectid" hidden></div> | |
| <!-- <select style="margin-left: -1%;" hidden name="relvselectname" id="relvselectid" multiple size="5"> </select> --> | |
| <iframe id="pdfFrame" hidden></iframe> | |
| </div> | |
| </div> | |
| <div id="ratios"> </div> | |
| <div id="radiosColors" hidden="until-found"> | |
| <div id="checkboxLine"> | |
| <input type="checkbox" id="levelcheckbox"> | |
| <label id="nLevels" name="levelsnamelabel">Leveled Plan</label> | |
| <i class="fa fa-info-circle" id="infotool"> | |
| <span class="tooltiptext"> | |
| Choose whether this project contains levels or not. Leave the checkbox unchecked if you want to measure the entirety of the plan. | |
| <br> Please check the box on this line if you want to measure certain areas of the plan or have the plan divided into levels. Once the checkbox is ticked, a window will appear that will allow you to draw on the PDF. Click the save button at the bottom of the page when you are done. | |
| </span> | |
| </i> | |
| </div> | |
| <div class="button-container"> | |
| <input type="button" id="popupforextratext" title="Add Key Information" value="Add Key Information"> | |
| </div> | |
| <!-- <br> | |
| <input type="checkbox" id="levelcheckbox" > | |
| <label id=nLevels name="levelsnamelabel" >Leveled Plan </label> | |
| <i class="fa fa-info-circle" id="infotool" > <span class="tooltiptext">Choose whether this project contains levels or not. Leave the checkbox unchecked if you want to measure the entirety of the plan. <br> Please check the box on this line if you want to measure certain areas of the plan or have the plan divided into levels. Once the checkbox is ticked, a window will apear that will allow you to draw on the PDF. Click the save button at the bottom of the page when you are done. </span> </i> --> | |
| </div> | |
| <div id ="saveOPdiv"> | |
| <button id="measureADRbutton">Measure using ADR</button> | |
| <script src="https://cdn.lordicon.com/bhenfmcm.js"></script> | |
| <lord-icon | |
| src="https://cdn.lordicon.com/ynwbvguu.json" | |
| trigger="hover" colors="primary:black" id="addicon" style="display: none;" onclick="duplicate()" > | |
| </lord-icon> | |
| </div> | |
| <audio id="myAudio" autoplay></audio> | |
| </form> | |
| <div id="progressBar" hidden> | |
| <div id="progress">0%</div> | |
| </div> | |
| <div id ="duplicater" class="duplicaterclass" hidden="until-found"> | |
| <label id="labelArrayId" hidden="until-found"> </label> | |
| <select name="measurementscripts" class="measurementselections" id="measurementselectionsid" > </select> | |
| <select name="select" class="selections" id="selectionsid" > | |
| </select> | |
| <select name="measureitem" class="measureitems" id="measureitemsid"> </select> | |
| <br> | |
| <div id="repeatforloop" class="repeatforloopclass00" name="repeatforloopname " > | |
| <select type="text" id="text0" name="text1name" placeholder="GB-1" class=gb> </select> | |
| <input type="text" id="text1" name="text2name" placeholder="A" class=a> | |
| <input type="text" id="text2" name="text3name" placeholder="Depth" class=depth> | |
| <script src="https://cdn.lordicon.com/bhenfmcm.js" ></script> | |
| <lord-icon | |
| onclick="addmctnameicon()" | |
| src="https://cdn.lordicon.com/mecwbjnp.json" | |
| trigger="hover" | |
| class="addmctnameclass" | |
| id="addmctnameid" | |
| colors="primary:black,secondary:black"> | |
| </lord-icon> | |
| </div> | |
| </div> | |
| <button hidden id="doneebackground" onclick="getSecondData()" > Export Summary </button> | |
| <button hidden id="summarytoXML" onclick=summary_to_XML() > Summary to XML</button> | |
| <div hidden id ="duplicaterhidden" class="duplicaterclasshidden"> | |
| <label id="labelArrayId" hidden="until-found"> </label> | |
| <select name="measurementscripts" class="measurementselections" id="measurementselectionsid" > | |
| <option value="" disabled selected hidden>Select</option> | |
| </select> | |
| <select name="select" class="selections" id="selectionsid"> </select> | |
| <select type="text" name="measureitem" class="measureitems" id="measureitemsid"> </select> | |
| <!-- <select name="select" class="selections" id="selectionsM-M2" > </select> --> | |
| <br> | |
| <div id="repeatforloophidden" class="repeatforloopclasshidden" name="repeatforloopnamehidden " > <!-- onchange="getmctName()" --> | |
| <select type="text" id="text0" name="text1name" placeholder="GB-1" class=gb> </select> | |
| <input type="text" id="text1" name="text2name" placeholder="A" class=a> | |
| <input type="text" id="text2" name="text3name" placeholder="Depth" class=depth> | |
| <script src="https://cdn.lordicon.com/bhenfmcm.js" ></script> | |
| <lord-icon | |
| onclick="addmctnameicon()" | |
| src="https://cdn.lordicon.com/mecwbjnp.json" | |
| trigger="hover" | |
| class="addmctnameclass" | |
| id="addmctnameid" | |
| colors="primary:black,secondary:black"> | |
| </lord-icon> | |
| <script src="https://cdn.lordicon.com/bhenfmcm.js"></script> | |
| <lord-icon | |
| onclick="deletemctnameicon()" | |
| src="https://cdn.lordicon.com/rivoakkk.json" | |
| trigger="hover" | |
| class="deletemctnameclass" | |
| id="deletemctnameid" | |
| colors="primary:black,secondary:black"> | |
| </lord-icon> | |
| </div> | |
| </div> | |
| </div> | |
| <div id="legends" class="tabcontent"> | |
| <ul class="graynavbarLegend" > | |
| <label class="label1">Project Name / Project Part / NRM Section /</label> <label class="label2">Legend</label> | |
| <div class="legendtime"> | |
| <div style="display: inline-flex;"> | |
| <label class="CreatedTime"> Created Time </label> | |
| <button id="sortBtnCreateDesc" class="sortbutton" onclick="sortlegends(this.id)"><i id="CreatesortDesc" class="fa fa-sort-amount-desc" aria-hidden="true" ></i> </button> | |
| <button id="sortBtnCreateAsc" class="sortbutton" onclick="sortlegends(this.id)"><i id="CreatesortAsc" class="fa fa-sort-amount-asc" aria-hidden="true" ></i></button> | |
| </div> | |
| <div style="display: inline-flex;"> | |
| <label class="EditTime"> Last Edited Time </label> | |
| <button id="sortBtnEditDesc" class="sortbutton" onclick="sortlegends(this.id)"><i id="EditsortDesc" class="fa fa-sort-amount-desc" aria-hidden="true" ></i></button> | |
| <button id="sortBtnEditAsc"class="sortbutton" onclick="sortlegends(this.id)"><i id="EditsortAsc" class="fa fa-sort-amount-asc" aria-hidden="true" ></i> </button> | |
| </div> | |
| </div> | |
| </ul> | |
| </div> | |
| <div id="consoleContent"></div> | |
| <div class="dropdown-content" id="dropdown-contentUserguideId" name="tobeclosed"> | |
| <div id="userguidetext" > | |
| <div id="UserguideRibbon"> | |
| <label id="UserGuideHeader"> User Guide Text: Before using this tool, kindly read the following carefully. </label> | |
| <button id="homeguidebutton" style="background-color: transparent; border: none;" onclick="ShowSectionUserguide(this)"> | |
| <i class="fa fa-home fa-lg" id="userguideHome"></i> | |
| </button> | |
| <div class="Userguidecontainer" id="UserGuidetoggle" onclick="userguidetoggleFunction()"> | |
| <div class="UserGuidebar1"></div> | |
| <div class="UserGuidebar2"></div> | |
| <div class="UserGuidebar3"></div> | |
| </div> | |
| <button type="button" class="closeModal" id="userguideClose" data-dismiss="modal">×</button> | |
| <button style="background-color: transparent; border: none;" id="userguideTableMaya" onclick="userguideMayaTableClick()"> | |
| <i class="fa fa-th fa-lg" aria-hidden="true"></i> | |
| </button> | |
| <div id="UserGuideSideBar"> | |
| <div id="UserGuidemenuOptions"> | |
| <li onclick="ShowSectionUserguide(this)">1.0 Substructure</li> | |
| <li onclick="ShowSectionUserguide(this)">2.1 Frames</li> | |
| <li onclick="ShowSectionUserguide(this)">2.2 Upper Floor</li> | |
| <li onclick="ShowSectionUserguide(this)">2.3 Roof</li> | |
| <li onclick="ShowSectionUserguide(this)">2.4 Stairs</li> | |
| <li onclick="ShowSectionUserguide(this)">2.5 External Walls</li> | |
| <li onclick="ShowSectionUserguide(this)">2.6 External Openings</li> | |
| <li onclick="ShowSectionUserguide(this)">2.7 Internal Walls</li> | |
| <li onclick="ShowSectionUserguide(this)">2.8 Internal Openings</li> | |
| <li onclick="ShowSectionUserguide(this)">3.1 Wall Finishes</li> | |
| <li onclick="ShowSectionUserguide(this)">3.2 Floor Finishes</li> | |
| <li onclick="ShowSectionUserguide(this)">3.3 Ceiling Finishes</li> | |
| <li onclick="ShowSectionUserguide(this)">4.0 Fittings, Furnishings and Equipments</li> | |
| <li onclick="ShowSectionUserguide(this)">5.0 Services</li> | |
| <li onclick="ShowSectionUserguide(this)">5.1 Sanitary</li> | |
| <li onclick="ShowSectionUserguide(this)">7.0 Works to existing buildings</li> | |
| <li onclick="ShowSectionUserguide(this)">8.1 Site Preparation Works</li> | |
| <li onclick="ShowSectionUserguide(this)">8.2 Roads, Paths, Pavings</li> | |
| <li onclick="ShowSectionUserguide(this)">8.3 Soft Landscaping</li> | |
| <li onclick="ShowSectionUserguide(this)">8.4 Fencing, Railing, Walls</li> | |
| <li onclick="ShowSectionUserguide(this)">8.5 External Fixtures</li> | |
| <li onclick="ShowSectionUserguide(this)">8.6 External Drainage</li> | |
| <li onclick="ShowSectionUserguide(this)">8.7 External Services</li> | |
| <li onclick="ShowSectionUserguide(this)">8.8 Minor Buildings</li> | |
| </div> | |
| </div> | |
| </div> | |
| <div id="textfirstpage"> | |
| <label style="font-weight: bold;"> | |
| After reading this user guide, if you still encounter any issues or have suggestions for improving the system, please don't hesitate to contact the ADR team. | |
| </label> | |
| <br> | |
| <label style="font-style: italic;"> | |
| This page provides general guidance on using the console. For details on a specific section, refer to the menu and select the desired section by clicking the '<i class="fa fa-bars" aria-hidden="true"></i>' icon. | |
| <br> | |
| In the top right corner, you will find this icon '<i class="fa fa-th fa-lg" aria-hidden="true"></i>', which, when clicked, takes you to a Google Spreadsheet containing a summarized table of the main AI features implemented and | |
| planned for the ADR console, along with the sections where they are applied. | |
| </label> | |
| <br> | |
| The tool is divided into two main parts: | |
| <br><br> | |
| <i class="fa fa-circle" aria-hidden="true"> </i> <label id="userguideheadings"> First Part </label> | |
| <br> | |
| <div style="margin-left: 40px;"> | |
| The system automatically refreshes all data retrieved every 5 minutes from the MC including project names, parts, sections, and MC-T names every. However, if you notice missing information, click this button | |
| <span style="background-color: blue; color: white; padding: 2px 8px; border-radius: 4px; font-style: italic; margin-top: 5px;">Refresh data received from MC</span> to retrieve the latest MC updates. | |
| <br> | |
| <label id="underlinedLables">Inputs: </label> | |
| <br> | |
| <li> | |
| Use the three dropdown menus to select the project name, part, and section to measure. | |
| <br> | |
| <img src="static/images/Dropdowns_3.png" alt="Dropdown menus example" style="margin-top: 10px; width:240px;"> | |
| <label style="font-style: italic; margin-left: -10px; margin-top: 50px;color: #2e83c7;"> Ensure the correct 'Project Section' is selected, as it affects the applied code. </label> | |
| <br> | |
| </li> | |
| <li> | |
| <label style="font-size: 15px;"> Document To Measure: </label> | |
| <br> | |
| Clicking a document's name opens a PDF preview in a separate tab attached to the black ribbon inside the console. Checking the box next to the document selects it as the document to measure. | |
| <br> | |
| <li> | |
| When retrieving documents for measurement, if multiple files share the same name on Dropbox, a popup may appear. In such cases, please rename the files in Dropbox, then return to the console and click the following icon: | |
| <i hidden class="fa fa-dropbox" style="color:white; background-color: #2e83c7; border-radius: 4px;"></i> to retrieve the updated documents. You can then select the desired document for measurement. Please note that this process will refresh all documents in the selected project folder. | |
| </li> | |
| <br> | |
| <label style="font-style: italic;"> Pixel-to-Metric conversion important notes:</label> | |
| <br> | |
| Upon selecting a plan, the console automatically downloads the PDF with a colored rectangle. Open it in Foxit Reader, Adobe, or Bluebeam to measure its area and perimeter in the desired metric unit. | |
| Enter these values in the provided textboxes. A dropdown next to each textbox lets you choose between meters (m) or millimeters (mm) for accurate scaling. | |
| <br> | |
| This rectangle serves as a scale check for Bluebeam. Refer to the relevant section for further details. | |
| <br> | |
| <li> | |
| Click <span style="background-color: #b216c7; color: white; padding: 2px 8px; border-radius: 4px; font-style: italic;">Add Key Information</span> button to open a popup where you can input additional details to assist in the detection process. | |
| </li> | |
| </li> | |
| <label id="underlinedLables">Outputs: </label> <br> | |
| The right panel displays results in three sections: | |
| <li>A preview of the measured plan, which you can click to expand.</li> | |
| <li>Three buttons: | |
| <li> <label style="font-weight: bold;" >"Legend and Data Created" </label> – Access the Google Sheet legend.</li> | |
| <li> <label style="font-weight: bold;" >"Click to View as PDF" </label>– Opens the marked-up PDF in Dropbox. <label>(Do not download for this feature.) </label></li> | |
| <li> This icon <i class='fa fa-refresh' style="color:white; padding: 3px 3px;background-color: rgb(255,0,255); border-radius: 4px;"></i> button allows you to get the deleted markups (in case you deleted any from the pdf on dropbox).</li> | |
| </li> | |
| <br> | |
| <label style="font-weight: bold;" > ONLY IN DROPBOX VIEW. DO NOT DOWNLOAD THE PDF FOR THIS FEATURE. </label> | |
| <br> | |
| <label style="font-style: oblique;" > | |
| Note : The algorithm is based on detecting shapes and colors from the plan. Some shapes such as tables and textboxes carrying plan-related information, may also be viewed as shapes and so added to the algorithm. | |
| </label> | |
| Any markup that you deem unnecessary in the pdf can be removed. After deleting any markup, the console will notify you with a message asking whether you would like to delete it from legend or not and the legend will be updated accordingly. | |
| </div> | |
| <br> | |
| <i class="fa fa-circle" aria-hidden="true"> </i> <label id="userguideheadings"> Second Part </label> | |
| <br><br> | |
| <div style="margin-left: 40px;"> | |
| To open the Google sheet with the created legend, first click the button labeled "Legend and Data created." Names of each shape should go in the first column of the sheet labeled ‘Guess’. | |
| <br>Ex. GB-1. | |
| <br> Then, return to this page, the ADR Console, to finish entering the remaining data after you have finished entering the guessed names in the legend. | |
| <br> Three dropdown menus and three text boxes are present. | |
| <li style="list-style-type:square;"> You can select the type of the shape from the first dropdown: <!--by selecting either: --> | |
| <br>    e.g. (1.0 Substructure) Ground Beam or Pile Cap. Refer to the relevant section for more details. | |
| <!-- <br>    b. (3.2 Floor Finishes) Floor or Wall --> | |
| </li> | |
| <li style="list-style-type:square;"> In the second dropdown, you will find a list of MC-T Names. Choose Accordingly.</li> | |
| <li style="list-style-type:square;"> The third dropdown menu has the unit of the MC-T Name you have chosen.</li> | |
| <br> Note: If the unit was (m), choose whether you wish to extract perimeter or length data from the third selection. | |
| <br><br><label style="font-style: italic;"> Regarding the MC-T naming process: </label> | |
| Then add the relevant detail and depth to the rows underneath the dropdowns. | |
| You can add/ subtract rows by using the + and - button. | |
| <br> | |
| You can add another block and repeat the process for another item by clicking the button next to "Measure using ADR". | |
| </div> | |
| </div> | |
| <div id="1_0textUserGuide" hidden class="othesectionsuserguide"> | |
| User guide in progress... | |
| </div> | |
| <div id="2_1textUserGuide" hidden class="othesectionsuserguide"> | |
| User guide in progress... | |
| </div> | |
| <div id="2_7textUserGuide" hidden class="othesectionsuserguide"> | |
| User guide in progress... | |
| </div> | |
| <div id="2_8textUserGuide" hidden class="othesectionsuserguide"> | |
| User guide in progress... | |
| </div> | |
| <div id="3_2textUserGuide" hidden class="othesectionsuserguide"> | |
| User guide in progress... | |
| </div> | |
| <div id="3_3textUserGuide" hidden class="othesectionsuserguide"> | |
| User guide in progress... | |
| </div> | |
| </div> | |
| </div> | |
| <!-- POP-UP code -- to handle errors --> | |
| <!-- Link to trigger modal --> | |
| <!-- Modal popup box --> | |
| <div id="mpopupBox" class="mpopup" name="tobeclosed"> | |
| <!-- Modal content --> | |
| <div class="modal-content"> | |
| <div class="modal-header"> | |
| <button type="button" class="closeModal" data-dismiss="modal">×</button> | |
| <h2 id="TopTextModal">Error</h2> | |
| </div> | |
| <div class="modal-body"> | |
| <p id="modal-bodyText"> | |
| </p> | |
| <br> | |
| </div> | |
| </div> | |
| </div> | |
| <div id="dialog-container" class="overlay" name="tobeclosed"> | |
| <!-- Modal content --> | |
| <div class="modal-content"> | |
| <div class="modal-header"> | |
| <button type="button" class="closeModal" >×</button> | |
| <h2 id="TopTextModalWarning">Warning!</h2> | |
| </div> | |
| <div class="modal-body"> | |
| <p id="modal-bodyTextp">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. | |
| </p> | |
| <div id="duplicaterExtra" hidden="until-found"> | |
| <div id="repeatforloopExtra" class="repeatforloopclassExtra0" name="repeatforloopExtraname " > | |
| <label id="modalColIndex">Index</label> | |
| <i class="fa fa-info-circle smallFaIcon" id="infotoolModal"> | |
| <span class="tooltiptext" id="modaltooltips"> | |
| Index of column. (Optional) | |
| </span> | |
| </i> | |
| <label id="modalColumn">Type</label> <label id="modalGray">(from drawing)</label> | |
| <i class="fa fa-info-circle smallFaIcon" id="infotoolModal"> | |
| <span class="tooltiptext" id="modaltooltips"> | |
| Enter the title for the column as it will be shown in Bluebeam columns. This helps organize and categorize extracted information. | |
| </span> | |
| </i> | |
| <label id="modalKeyword">Specification</label> <label id="modalGray">(from drawing)</label> | |
| <i class="fa fa-info-circle smallFaIcon" id="infotoolModal"> | |
| <span class="tooltiptext" id="modaltooltips"> | |
| Provide a word or phrase from the data you want to help detect relevant information in the drawing. | |
| </span> | |
| </i> | |
| <label id="modalCharacter">Count</label> | |
| <i class="fa fa-info-circle smallFaIcon" id="infotoolModal"> | |
| <span class="tooltiptext" id="modaltooltips"> | |
| Set the number of characters that is expected to be captured. This helps refine the extraction by limiting or expanding the detected text. | |
| </span> | |
| </i> | |
| <br> | |
| <input type="number" id="textextra" name="text0name" placeholder="Eg: 1" > | |
| <input type="text" id="text0extra" name="text1name" placeholder="Eg: Wall Type" > | |
| <input type="text" id="text1extra" name="text2name" placeholder="Eg:NBS K10/" > | |
| <input type="number" id="text2extra" name="text3name" placeholder="Eg: 3" min="0"> | |
| <script src="https://cdn.lordicon.com/bhenfmcm.js" ></script> | |
| <lord-icon | |
| onclick="addmctnameiconPopup()" | |
| src="https://cdn.lordicon.com/mecwbjnp.json" | |
| trigger="hover" | |
| class="addmctnameclassExtra" | |
| id="addmctnameidExtra" | |
| colors="primary:black,secondary:black"> | |
| </lord-icon> | |
| </div> | |
| </div> | |
| <div hidden="until-found" id="duplicaterExtraHidden" > | |
| <div id="repeatforloopExtrahidden" class="repeatforloopclassExtrahidden" name="repeatforloopnameExtrahidden " > <!-- onchange="getmctName()" --> | |
| <input type="number" id="textextra" name="text0name" placeholder="Eg: 1" > | |
| <input type="text" id="text0extra" name="text1name" placeholder="Eg:Specification" > | |
| <input type="text" id="text1extra" name="text2name" placeholder="Eg:NBS K10/" > | |
| <input type="number" id="text2extra" name="text3name" placeholder="Eg: 3" > | |
| <script src="https://cdn.lordicon.com/bhenfmcm.js" ></script> | |
| <lord-icon | |
| onclick="addmctnameiconPopup()" | |
| src="https://cdn.lordicon.com/mecwbjnp.json" | |
| trigger="hover" | |
| class="addmctnameclassExtra" | |
| id="addmctnameidExtra" | |
| colors="primary:black,secondary:black"> | |
| </lord-icon> | |
| <script src="https://cdn.lordicon.com/bhenfmcm.js"></script> | |
| <lord-icon | |
| onclick="deletemctnameiconPopup()" | |
| src="https://cdn.lordicon.com/rivoakkk.json" | |
| trigger="hover" | |
| class="deletemctnameclassExtra" | |
| id="deletemctnameidExtra" | |
| colors="primary:black,secondary:black"> | |
| </lord-icon> | |
| </div> | |
| </div> | |
| <br> | |
| <div class="text-right"> | |
| <button class="dialog-btn btn-primary" id="confirm">Ok</button> | |
| <button class="dialog-btn btn-cancel" id="cancel">Cancel</button> | |
| </div> | |
| <br> | |
| </div> | |
| </div> | |
| </div> | |
| </body> | |
| </html> | |
| <script src="https://cdnjs.cloudflare.com/ajax/libs/pdf.js/2.14.305/pdf.min.js"></script> | |
| <script > | |
| ///////////////////////////////////////////////BEGIN JS CODE////////////////////////////////////////////////// | |
| var ActiveSections=['1.0','2.1','2.7','2.8','3.2','3.3'] | |
| var menuItems = document.querySelectorAll("#UserGuidemenuOptions li"); | |
| menuItems.forEach(function (item) { | |
| // Extract the section number (first part of the text) | |
| var sectionNumber = item.textContent.trim().split(" ")[0]; | |
| // If the section is not in ActiveSections, disable it | |
| if (!ActiveSections.includes(sectionNumber)) { | |
| item.id = "disabledSection"; // Assign ID | |
| item.style.color = "#bdbcbc"; // Greyed-out text | |
| item.style.cursor = "not-allowed"; // Change cursor | |
| item.onclick = null; // Disable clicking | |
| } | |
| }); | |
| function updateProgressBar(value) { | |
| const progressBar = document.getElementById('progress'); | |
| progressBar.style.width = value + '%'; | |
| progressBar.innerText = Math.round(value) + '%'; | |
| } | |
| // Function to send the Dropbox link and keyword to the server | |
| function getURLParams() { | |
| const urlParams = new URLSearchParams(window.location.search); | |
| return { | |
| pdfLink: urlParams.get('pdfLink'), | |
| keyword: JSON.parse(decodeURIComponent(urlParams.get('keyword') || "[]")), // Decode and parse | |
| pageNumber: parseInt(urlParams.get('page')) || 1, | |
| zoomRect: urlParams.get('zoom') // Expecting format: "x,y,width,height" | |
| }; | |
| } | |
| function processPdf() { | |
| // const pdfLink = 'https://www.dropbox.com/scl/fi/hnp4mqigb51a5kp89kgfa/00801-ARC-20-ZZ-S-A-0002.pdf?rlkey=45abeoebzqw4qwnslnei6dkd6&st=m4yrcjm2&dl=1'; // Dropbox link | |
| // const keyword = ['115 INTEGRATED MRI ROOM LININGS','710 TRANSPORTATION'] ; // Example keyword | |
| const { pdfLink, keyword, pageNumber, zoomRect } = getURLParams(); | |
| // Create a new FormData object to send the data as form data | |
| const formData = new FormData(); | |
| formData.append('pdf_link', pdfLink); | |
| formData.append('keyword', JSON.stringify(keyword)); | |
| // Send the data to the Flask server | |
| fetch('/api/process-data', { | |
| method: 'POST', | |
| body: formData, | |
| }) | |
| .then(response => response.json()) | |
| .then(data => { | |
| if (data.download_link) { | |
| //window.location.href = data.download_link; // This will use the rect info from Flask | |
| console.log('Done!') | |
| } else { | |
| alert('Error: ' + data.error); | |
| } | |
| }) | |
| .catch(error => { | |
| console.error('Error:', error); | |
| }); | |
| } | |
| // Call the function to process the PDF | |
| // processPdf(); | |
| //////////////////////////////////////////////////////////////////// | |
| PopupElement=document.getElementById('modal-bodyText'); | |
| sectionSelect=document.getElementById('section-select'); | |
| $(sectionSelect).select2({ | |
| closeOnSelect: true, | |
| width:'20ch' | |
| }); | |
| // add project names to first dropdown from google sheet | |
| firstdropdown=document.getElementsByClassName('selectionsProj')[0]; | |
| seconddropdown=document.getElementsByClassName('selectionsProjp')[0]; | |
| thirddropdown=document.getElementsByClassName('selectionsProjs')[0]; | |
| $(firstdropdown).select2({ | |
| placeholder:'Projects', | |
| closeOnSelect: true, | |
| width:'51ch' | |
| }); | |
| $(seconddropdown).select2({ | |
| placeholder:'Project Parts', | |
| closeOnSelect: true, | |
| width:'51ch' | |
| }); | |
| $(thirddropdown).select2({ | |
| placeholder:'Sections', | |
| closeOnSelect: true, | |
| width:'51ch' | |
| }); | |
| var measSelect = document.getElementById("measureselectid"); | |
| var relvSelect = document.getElementById("relvselectid"); | |
| document.getElementById("all").style.display = "block"; | |
| PrjNamesArray=[]; | |
| PrjPartsArray=[]; | |
| PrjSectionsArray=[]; | |
| var partsArrwithID=[]; | |
| var firstDpwnValue; | |
| var prjids=[] | |
| displayprjnames() | |
| function displayprjnames(){ | |
| var eventSource = new EventSource('/getprojectnames/'); | |
| document.getElementById('progressBar').removeAttribute('hidden') | |
| document.getElementById('progressBar').style.display='block'; | |
| eventSource.onmessage = function (event) { | |
| var progress = parseInt(event.data); // Progress value from Flask | |
| if (progress <= 100) { | |
| console.log(progress); // Log progress for debugging | |
| document.getElementById('progress').style.width = progress + '%'; | |
| document.getElementById('progress').textContent = progress + '%'; | |
| } else { | |
| // Final data handling when progress reaches 100% | |
| console.log('Process completed!'); | |
| // Parse and handle the final response data (documentsToMeasure, RelevantDocuments, extracted_path) | |
| var data = JSON.parse(event.data); // Assuming the result is a JSON array | |
| console.log('Final result:', data); | |
| // You can use this data to update your page or handle it accordingly | |
| eventSource.close(); // Close the connection when finished | |
| document.getElementById('progressBar').setAttribute('hidden',true) | |
| document.getElementById('progressBar').style.display='none'; | |
| document.getElementById('progress').style.width = '0%'; // Reset progress for the next process | |
| document.getElementById('progress').textContent = '0%'; | |
| document.getElementById("all").style.display = "none"; | |
| prjids=data[1]; | |
| var op0 = document.createElement("OPTION") ; | |
| op0.text= 'Projects' | |
| op0.value= ""; | |
| op0.hidden=true; | |
| firstdropdown.add(op0); | |
| for (let i=0;i<data[0].length;i++) | |
| { | |
| opt=document.createElement("option"); | |
| opt.textContent=data[0][i]; | |
| opt.text=data[0][i]; | |
| firstdropdown.append(opt); | |
| PrjNamesArray.push(data[0][i]); | |
| } | |
| } | |
| } | |
| eventSource.onerror = function (error) { | |
| console.error('Error occurred:', error); | |
| eventSource.close(); // Close on error | |
| 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. '; | |
| ShowPopUp(); | |
| }; | |
| } | |
| /*Get chosen value and send to flask to get project parts*/ | |
| $(firstdropdown).on("change", function (e) { | |
| console.log('clickeds') | |
| firstDpwnValue=firstdropdown.value; | |
| seconddropdown.innerHTML=''; | |
| var op0 = document.createElement("OPTION") ; | |
| op0.text= 'Project Part' | |
| op0.value= ""; | |
| op0.hidden=true; | |
| seconddropdown.add(op0); | |
| var ii, L = seconddropdown.options.length - 1; | |
| for(ii = L; ii >= 0; ii--) { | |
| if (seconddropdown.options[ii].value) | |
| seconddropdown.remove(ii); | |
| } | |
| displayprojparts(prjids[(firstdropdown.selectedIndex)-1]); | |
| }) | |
| var partsArrIDsonly=[] | |
| function displayprojparts(val){ | |
| document.getElementById("all").style.display = "block"; | |
| console.log(val) | |
| $.get('/getprojectparts/'+JSON.stringify(val)) | |
| .success(function(data){ | |
| document.getElementById("all").style.display = "none"; | |
| partsArrwithID= data[0]; | |
| partsArrIDsonly= data[1]; | |
| for (let i=0;i<data[0].length;i++) | |
| { | |
| opt=document.createElement("option"); | |
| opt.value=data[0][i]; | |
| opt.text=data[0][i]; | |
| seconddropdown.append(opt); | |
| PrjPartsArray.push(data[0][i]); | |
| } | |
| }) | |
| .error(function(jqXHR, textStatus, errorThrown) { | |
| 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. '; | |
| ShowPopUp(); | |
| }); | |
| } | |
| $(seconddropdown).on("change", function (e) { | |
| thirddropdown.innerHTML=''; | |
| var op0 = document.createElement("OPTION") ; | |
| op0.text= 'Section' | |
| op0.value= ""; | |
| op0.hidden=true; | |
| thirddropdown.add(op0); | |
| displayprojsections(prjids[(firstdropdown.selectedIndex)-1],partsArrIDsonly[(seconddropdown.selectedIndex)-1]); | |
| }) | |
| function isValueNotInDropdown(dropdown, value) { | |
| // const dropdown = document.getElementById(dropdownId); | |
| const values = Array.from(dropdown.options).map(option => option.value); | |
| return !values.includes(value); // Check if the value is not in dropdown values | |
| } | |
| function displayprojsections(projectid,Partid){ | |
| console.log(seconddropdown.selectedIndex) | |
| document.getElementById("all").style.display = "block"; | |
| if (measSelect && measSelect.hasChildNodes()) { | |
| while (measSelect.firstChild) { | |
| measSelect.removeChild(measSelect.firstChild); | |
| } | |
| } | |
| if (relvSelect && relvSelect.hasChildNodes()) { | |
| while (relvSelect.firstChild) { | |
| relvSelect.removeChild(relvSelect.firstChild); | |
| } | |
| } | |
| $.get('/getprojectsections/' + JSON.stringify([projectid, Partid])) | |
| .done(function(data) { | |
| document.getElementById("all").style.display = "none"; | |
| for (let i = 0; i < data.length; i++) { | |
| let valueDoesNotExist = isValueNotInDropdown(thirddropdown, data[i]); | |
| if (valueDoesNotExist) { | |
| let opt = document.createElement("option"); | |
| opt.value = data[i]; | |
| opt.text = data[i]; | |
| let isActive = false; | |
| for (let d = 0; d < ActiveSections.length; d++) { | |
| if (data[i].startsWith(ActiveSections[d])) { | |
| isActive = true; | |
| break; // Exit loop early if active | |
| } | |
| } | |
| if (!isActive) { | |
| opt.style.color = '#bdbcbc'; | |
| opt.style.cursor = 'not-allowed'; | |
| opt.setAttribute('disabled', true); | |
| } | |
| thirddropdown.append(opt); | |
| PrjSectionsArray.push(data[i]); | |
| } | |
| } | |
| }) | |
| .fail(function(jqXHR, textStatus, errorThrown) { | |
| 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. '; | |
| ShowPopUp(); | |
| }); | |
| } | |
| /*Menu bar icon mySidebar and Toggle*/ | |
| var $mySidebar = document.getElementById('mySidebar'); | |
| var $toggle = document.getElementById('toggle'); | |
| $toggle.addEventListener('click', function() { | |
| var isOpen = $mySidebar.classList.contains('slide-in'); | |
| w3_open(); | |
| $mySidebar.setAttribute('class', isOpen ? 'slide-out' : 'slide-in'); | |
| $toggle.classList.toggle("change"); | |
| if ($mySidebar.classList.contains('slide-out')){ | |
| w3_close() | |
| } | |
| }); | |
| // if (thirddropdown.value){ | |
| MCTNames={} | |
| var workerMCT = new Worker('../static/MC_T_API_Worker.js'); | |
| // workerMCT.postMessage(thirddropdown.value) | |
| workerMCT.onmessage= function(event){ | |
| console.log('refreshed') | |
| if (thirddropdown.value){ | |
| sectionNumber=thirddropdown.value; | |
| MCTNames=event.data; | |
| MCTNames=MCTNames[sectionNumber.toString().toLowerCase()] | |
| } | |
| console.log('MCtname::',MCTNames) | |
| } | |
| // } | |
| var val='' | |
| var worker = new Worker('../static/API_Refresh_workerJS.js'); | |
| postAPIrefreshData() | |
| function postAPIrefreshData() | |
| { | |
| worker.onmessage= function(event){ | |
| if (firstdropdown.value) | |
| { | |
| val='firstonly' | |
| console.log(val) | |
| } | |
| if ((firstdropdown.value) && (seconddropdown.value)) | |
| { | |
| val='firstSecond' | |
| console.log(val) | |
| } | |
| if (val=='firstonly') | |
| worker.postMessage(firstdropdown.value) | |
| else if (val=='firstSecond') | |
| { | |
| worker.postMessage([firstdropdown.value,seconddropdown.value,partsArrIDsonly[seconddropdown.selectedIndex-1]]) | |
| } | |
| var data=JSON.parse(event.data); | |
| console.log(data) | |
| if (data) | |
| { | |
| if (confirm(data[0]+"\n")){ | |
| document.getElementById('all').style.display='block'; | |
| $.get('/refreshAPIAppendNewTables') | |
| .success(function(successData){ | |
| if (data[1]==='project') | |
| { | |
| // console.log('projjjj') | |
| // displayprjnames(); | |
| console.log(data[2]) | |
| for (let d=0;d<data[2].length;d++) | |
| { | |
| console.log(data[2][d]) | |
| opt=document.createElement("option"); | |
| opt.textContent=data[2][d]; | |
| opt.text=data[2][d]; | |
| firstdropdown.append(opt); | |
| PrjNamesArray.push(data[2][d]); | |
| } | |
| } | |
| else if (data[1]==='part') | |
| { if (firstdropdown.value) | |
| { | |
| console.log(data[2]) | |
| for (let d=0;d<data[2].length;d++) | |
| { | |
| console.log(data[2][d]) | |
| opt=document.createElement("option"); | |
| opt.textContent=data[2][d]; | |
| opt.text=data[2][d]; | |
| seconddropdown.append(opt); | |
| // PrjPartsArray.push(data[2][d]); | |
| } | |
| } | |
| } | |
| else if (data[1]==='section') | |
| { | |
| if ((firstdropdown.value) && (seconddropdown.value)) | |
| { | |
| console.log(data[2]) | |
| for (let d=0;d<data[2].length;d++) | |
| { | |
| console.log(data[2][d]) | |
| opt=document.createElement("option"); | |
| opt.textContent=data[2][d]; | |
| opt.text=data[2][d]; | |
| if(!(data[2][d].startsWith('1.0') ) && !(data[2][d].startsWith('3.2') ) && !(data[2][d].startsWith('2.8')) && !(data[2][d].startsWith('3.3')) && !(data[2][d].startsWith('2.1')) && !(data[i].startsWith('2.7'))) //||data[i].startsWith('2.2'))) | |
| { | |
| opt.style.color='#bdbcbc'; | |
| opt.style.cursor='not-allowed'; | |
| opt.setAttribute('disabled',true) | |
| } | |
| thirddropdown.append(opt); | |
| // PrjPartsArray.push(data[2][d]); | |
| } | |
| } | |
| } | |
| document.getElementById('all').style.display='none'; | |
| }) | |
| .error(function(jqXHR, textStatus, errorThrown) { | |
| PopupElement.textContent='Error occured while retrieving projects. Refresh and try again. If the error continues, please contact the ADR team to fix it. '; | |
| ShowPopUp(); | |
| }); | |
| } | |
| else{ | |
| worker.terminate() | |
| } | |
| } | |
| // } | |
| } | |
| } | |
| /*worker.onmessage= function(event){ | |
| } | |
| */ | |
| // var workerDropbox = new Worker('../static/DropboxWorker.js'); | |
| // workerDropbox.onmessage= function(event) | |
| // { | |
| // var dataDropbox=JSON.parse(event.data); | |
| // } | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| // /*Retrieve MCTNAMES Dictionary from API - Flask*/ | |
| var mctnameEmpty=false; | |
| var sectionNumber; | |
| function getALLMCTNAMES(){ | |
| MCTNames={} | |
| document.getElementById("all").style.display = "block"; | |
| $.get( '/RetrieveMCTNames/') | |
| .success (function(data){ | |
| // document.getElementById("all").style.display = "none"; | |
| console.log(data) | |
| MCTNames=data; | |
| sectionNumber = projsec.value.split(" ")[0]; // Get first item after splitting by space | |
| console.log(sectionNumber); | |
| // Find the first key in MCTNames that starts with sectionNumber | |
| let matchedKey = Object.keys(MCTNames).find(key => key.toLowerCase().startsWith(sectionNumber.toLowerCase())); | |
| if (matchedKey) { | |
| console.log(matchedKey); // Found matching key | |
| let matchedValue = MCTNames[matchedKey]; // Store matched value without overwriting MCTNames | |
| console.log('MCTname::', matchedValue); | |
| if (matchedValue && matchedValue.length ==0) { // Ensure matchedValue exists and has length | |
| mctnameEmpty = true; | |
| } else { | |
| mctnameEmpty = false; | |
| } | |
| } else { | |
| console.log("No matching key found in MCTNames"); | |
| mctnameEmpty = false; // Handle case where no key is found | |
| } | |
| }) | |
| .error(function(jqXHR, textStatus, errorThrown) { | |
| PopupElement.textContent='Error occured while retrieving the MC-T Names. Refresh and try again. If the error continues, please contact the ADR team to fix it. '; | |
| ShowPopUp(); | |
| }); | |
| // return MCTNames | |
| } | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| /****Values of MCTname rows at the end of the conssole( grouping shapes) --> legend summary ****/ | |
| document.getElementById('duplicater').childNodes[1].value=[0,0] | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| /*Tab View of User Guide*/ | |
| // document.getElementById('secondpage').addEventListener('click',function(){ | |
| // document.getElementById('textsecondpage').removeAttribute('hidden'); | |
| // document.getElementById('textfirstpage').setAttribute('hidden',true) | |
| // }); | |
| // document.getElementById('firstpage').addEventListener('click',function(){ | |
| // document.getElementById('textfirstpage').removeAttribute('hidden'); | |
| // document.getElementById('textsecondpage').setAttribute('hidden',true) | |
| // }); | |
| function w3_open() { | |
| document.getElementById("home").style.marginLeft = "25%"; | |
| document.getElementById("legends").style.marginLeft = "25%"; | |
| document.getElementById("home").style.transition= '0.8s'; | |
| document.getElementById("legends").style.transition= '0.8s'; | |
| document.getElementById("mySidebar").style.width = "25%"; | |
| document.getElementById("mySidebar").style.display = "block"; | |
| } | |
| function w3_close() { | |
| document.getElementById("home").style.marginLeft = "0%"; | |
| document.getElementById("legends").style.marginLeft = "0%"; | |
| document.getElementById("home").style.transition= '1.5s' | |
| document.getElementById("legends").style.transition= '1.5s' | |
| document.getElementById("mySidebar").style.display = "none"; | |
| } | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| /*Red Alert to fill in the first 3 dropdowns: prj name, part, section*/ | |
| document.getElementById('measureADRbutton').addEventListener('click',function(){ | |
| if (!document.getElementsByClassName('selectionsProj')[0].value) | |
| document.getElementsByClassName('selectionsProj')[0].style.boxShadow='0 0 8px 2px rgb(255, 0, 0)'; | |
| if (!document.getElementsByClassName('selectionsProjp')[0].value) | |
| document.getElementsByClassName('selectionsProjp')[0].style.boxShadow='0 0 8px 2px rgb(255, 0, 0)'; | |
| if (!document.getElementsByClassName('selectionsProjs')[0].value) | |
| document.getElementsByClassName('selectionsProjs')[0].style.boxShadow='0 0 8px 2px rgb(255, 0, 0)'; | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| if (document.getElementById('imgContainer')) { | |
| document.getElementById('imgContainer').innerHTML = ''; | |
| } | |
| }); | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| /*Toggle Tab View of Home and Legend along with the Menu bar icon*/ | |
| function openTab(evt, tabname) { | |
| var i, tabcontent, tablinks; | |
| // Hide all tab contents | |
| tabcontent = document.getElementsByClassName("tabcontent"); | |
| for (i = 0; i < tabcontent.length; i++) { | |
| tabcontent[i].style.display = "none"; | |
| } | |
| // Remove "active" class from all tab buttons | |
| tablinks = document.getElementsByClassName("tablinks"); | |
| for (i = 0; i < tablinks.length; i++) { | |
| tablinks[i].className = tablinks[i].className.replace(" active", ""); | |
| } | |
| // Show selected tab content and mark button as active | |
| var tab = document.getElementById(tabname); | |
| if (tab) { | |
| tab.style.display = "block"; | |
| tab.className += " active"; | |
| // evt.currentTarget.className += " active"; | |
| } else { | |
| console.error('Tab content with ID ' + tabname + ' not found.'); | |
| } | |
| } | |
| // Start with the first tab open | |
| document.getElementById("pagetitle").click(); | |
| // Function to add a new tab dynamically | |
| function addIframeTab(title, url) { | |
| var tabId = "tab_" + Date.now(); // Unique ID for each tab | |
| // Create a new button in the ribbon | |
| var newTab = document.createElement("button"); | |
| newTab.className = "tablinks"; | |
| newTab.innerHTML = title + ' <i class="fa fa-times" onclick="removeTab(event, \'' + tabId + '\')"></i>'; | |
| newTab.onclick = function (event) { | |
| // Delay opening the tab to ensure it has been added to the DOM | |
| setTimeout(function() { | |
| openTab(event, tabId); | |
| }, 10); // 10ms delay to allow DOM rendering | |
| }; | |
| // Dynamically create tab labels and append them to FramestabsDropdown | |
| var tabnameDrpdwn = document.createElement("label"); | |
| tabnameDrpdwn.className = "tabslabel"; | |
| tabnameDrpdwn.innerHTML = title | |
| // Append new tab button to the dynamicTabs container | |
| document.getElementById("dynamicTabs").appendChild(newTab); | |
| document.getElementById("FramestabsDropdown").appendChild(tabnameDrpdwn); | |
| tabnameDrpdwn.addEventListener('click',function(){ | |
| openTab('click',tabId) | |
| }) | |
| // Event listener for mouseover on dynamicTabs | |
| document.getElementById("dynamicTabs").addEventListener('mouseover', function() { | |
| // Check and log all the labels inside FramestabsDropdown | |
| const labels = document.getElementById("FramestabsDropdown").children; | |
| if (labels.length > 0) { | |
| document.getElementById("FramestabsDropdown").style.display = 'block'; | |
| } | |
| }); | |
| document.getElementById("FramestabsDropdown").addEventListener('mouseover', function() { | |
| // Stay visible when hovering over the dropdown | |
| document.getElementById("FramestabsDropdown").style.display = 'block'; | |
| }); | |
| document.addEventListener('click', function(event) { | |
| const dropdown = document.getElementById("FramestabsDropdown"); | |
| if (!dropdown.contains(event.target)) { | |
| dropdown.style.display = 'none'; | |
| } | |
| }); | |
| // Handle clicks inside iframes | |
| document.querySelectorAll("iframe").forEach((iframe) => { | |
| iframe.contentWindow?.addEventListener("mousedown", function () { | |
| document.getElementById("FramestabsDropdown").style.display = "none"; | |
| }); | |
| }); | |
| //FramestabsDropdown | |
| // Create a corresponding iframe container in the console | |
| var iframeContainer = document.createElement("div"); | |
| iframeContainer.id = tabId; | |
| iframeContainer.className = "tabcontent"; | |
| iframeContainer.style.display = "none"; // Initially hidden | |
| // Create the iframe and set its source | |
| var iframe = document.createElement("iframe"); | |
| iframe.src = url; | |
| iframe.style.width = "100%"; | |
| iframe.style.height = "100vh"; | |
| iframeContainer.appendChild(iframe); | |
| // Append the iframe container to the consoleContent area | |
| document.getElementById("consoleContent").appendChild(iframeContainer); | |
| // Open the new tab after the content is added | |
| setTimeout(function() { | |
| newTab.click(); | |
| }, 10); // Short delay before clicking the new tab | |
| } | |
| // Function to remove a tab | |
| function removeTab(event, tabId) { | |
| event.stopPropagation(); // Prevent tab click event | |
| var tabButton = event.target.parentElement; | |
| var tabContent = document.getElementById(tabId); | |
| if (tabButton) tabButton.remove(); | |
| if (tabContent) tabContent.remove(); | |
| // Switch to the home tab if the removed tab was active | |
| document.getElementById("pagetitle").click(); | |
| } | |
| function downloadPdf(pdfname,downloadPDFName) { | |
| console.log('pdfname===',pdfname) | |
| fetch('/get-pdf/'+JSON.stringify(pdfname)) | |
| .then(response => response.blob()) | |
| .then(blob => { | |
| const url = URL.createObjectURL(blob); | |
| var link = document.createElement('a'); | |
| link.href = url; | |
| link.download = downloadPDFName; | |
| link.dispatchEvent(new MouseEvent('click')); | |
| }) | |
| .catch(error => console.error('Error fetching PDF:', error)); | |
| } | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| /*Add icon to duplicate 'duplicater' div (big section that includes 3 dropdowns,3 textboxes, 2 buttons(add,delete)*/ | |
| var dupliateiExtra = 0; // i | |
| var clonedDivIdExtra=0; | |
| var originalExtra = document.getElementById('duplicaterhidden'); | |
| var addciconvalExtra=0; //div duplicate | |
| var jjExtra=0; | |
| var dupliatei = 0; // i | |
| var clonedDivId=0; | |
| var original = document.getElementById('duplicaterhidden'); | |
| var addciconval=0; //div duplicate | |
| var jj=0; | |
| const vals = []; | |
| var canvasimg; | |
| var ry = [[]]; | |
| var section = document.getElementsByClassName("selectionsProjs")[0] | |
| function duplicate() { | |
| /*Create array of addciconval w jj */ | |
| addciconval+=1; | |
| jj=0; | |
| var clone = original.cloneNode(true); // "deep" clone | |
| console.log('clonee',clone.children) | |
| clone.id = 'duplicater' + ++dupliatei; | |
| clonedDivId=clone.id; | |
| clone.children[0].value=[addciconval,jj] | |
| clone.children[5].style.marginLeft='5px'; | |
| // clone.children[1].style.marginBottom='10px'; | |
| clone.children[5].children[4].id='addmctnameid'+dupliatei | |
| clone.children[5].children[6].style.display='none' | |
| clone.children[5].style.marginTop='8px'; | |
| console.log('ayhaga', clone.children[5]) | |
| clone.removeAttribute("hidden"); | |
| clone.setAttribute('class','duplicaterclass'+dupliatei); | |
| clone.getElementsByClassName('measurementselections')[0].setAttribute('name', 'measurementscripts'+dupliatei); | |
| clone.getElementsByClassName('measurementselections')[0].setAttribute('class', 'measurementselections'+dupliatei); | |
| clone.getElementsByClassName('measureitems')[0].setAttribute('name', 'measureitem'+dupliatei); | |
| clone.getElementsByClassName('measureitems')[0].setAttribute('class', 'measureitems'+dupliatei); | |
| clone.getElementsByClassName('selections')[0].setAttribute('name', 'select'+dupliatei); | |
| clone.getElementsByClassName('selections')[0].setAttribute('class', 'selections'+dupliatei); | |
| clone.getElementsByClassName('repeatforloopclasshidden')[0].setAttribute('id', 'repeatforloop'+addciconval+'0'); | |
| clone.getElementsByClassName('repeatforloopclasshidden')[0].setAttribute('name', 'repeatforloopname'+addciconval+'0'); | |
| clone.getElementsByClassName('repeatforloopclasshidden')[0].setAttribute('class', 'repeatforloopclass'+addciconval+'0'); | |
| if (thirddropdown.value.startsWith('3.2') || thirddropdown.value.startsWith('3.3')) | |
| { | |
| clone.children[5].children[1].setAttribute('disabled','True') | |
| clone.children[5].children[2].setAttribute('disabled','True') | |
| clone.children[5].children [1].style.cursor='not-allowed'; | |
| clone.children[5].children[2].style.cursor='not-allowed'; | |
| // document.getElementById('duplicater' + dupliatei).children[8].children[1].style.cursor='not-allowed'; | |
| // document.getElementById('duplicater' + dupliatei).children[8].children[2].style.cursor='not-allowed'; | |
| } | |
| original.parentNode.appendChild(clone); | |
| clone.parentElement.insertBefore(clone, document.getElementById('doneebackground')); | |
| /*Based on the NRM section , populate the second part of the interface*/ | |
| if (addciconval>0){ | |
| var inputs1 = document.getElementsByClassName("measurementselections"+dupliatei)[0]; //1sr dpdwn | |
| var selections1 = document.getElementsByClassName("selections"+dupliatei)[0]; //2nd dropdown | |
| var measitem1 = document.getElementsByClassName("measureitems"+dupliatei)[0]; //3rd dpdwn | |
| $(inputs1).select2({ | |
| placeholder:'Select', | |
| closeOnSelect: true, | |
| width:'15ch' | |
| }); | |
| $(selections1).select2({ | |
| placeholder:'Select MC-T Name', | |
| closeOnSelect: true, | |
| width:'23ch' | |
| }); | |
| $(measitem1).select2({ | |
| placeholder:'Select unit', | |
| closeOnSelect: true, | |
| width:'11ch' | |
| }); | |
| $(inputs1).on("change", function (e) { | |
| get3rddropdown(); | |
| }); | |
| $(selections1).on("change", function (e) { | |
| get3rddropdown(); | |
| }) | |
| if (section.value.startsWith('1.0')) | |
| { | |
| var opt = document.createElement("OPTION"); | |
| opt.text= 'Select'; | |
| opt.value= ""; | |
| opt.hidden=true; | |
| inputs1.add(opt); | |
| var optn = document.createElement("OPTION"); | |
| optn.text= 'Ground Beams'; | |
| optn.value= "ground beams"; | |
| inputs1.add(optn); | |
| var optn1 = document.createElement("OPTION"); | |
| optn1.text= 'Pile Caps'; | |
| optn1.value= "pile caps"; | |
| inputs1.add(optn1); | |
| } | |
| if (section.value.startsWith('3.2')) | |
| { | |
| var opt = document.createElement("OPTION"); | |
| opt.text= 'Select'; | |
| opt.value= ""; | |
| opt.hidden=true; | |
| inputs1.add(opt); | |
| var optn = document.createElement("OPTION"); | |
| optn.text= 'Floor'; | |
| optn.value= "Floor"; | |
| inputs1.add(optn); | |
| var optn1 = document.createElement("OPTION"); | |
| optn1.text= 'Wall'; | |
| optn1.value= "Wall"; | |
| inputs1.add(optn1); | |
| var optn2 = document.createElement("OPTION"); | |
| optn2.text= 'Internal Doors'; | |
| optn2.value= "Internal Doors"; | |
| inputs1.add(optn2); | |
| } | |
| if (section.value.startsWith('2.7')) | |
| { | |
| var opt = document.createElement("OPTION"); | |
| opt.text= 'Select'; | |
| opt.value= ""; | |
| opt.hidden=true; | |
| inputs1.add(opt); | |
| var optn = document.createElement("OPTION"); | |
| optn.text= 'Internal Walls'; | |
| optn.value= "Internal Walls"; | |
| inputs1.add(optn); | |
| } | |
| if (section.value.startsWith('2.8')) | |
| { | |
| var opt = document.createElement("OPTION"); | |
| opt.text= 'Select'; | |
| opt.value= ""; | |
| opt.hidden=true; | |
| inputs1.add(opt); | |
| var optn = document.createElement("OPTION"); | |
| optn.text= 'Single Door'; | |
| optn.value= "Single Door"; | |
| inputs1.add(optn); | |
| var optn1 = document.createElement("OPTION"); | |
| optn1.text= 'Double Door'; | |
| optn1.value= "Double Door"; | |
| inputs1.add(optn1); | |
| } | |
| if (section.value.startsWith('2.1')) | |
| { | |
| var opt = document.createElement("OPTION"); | |
| opt.text= 'Select'; | |
| opt.value= ""; | |
| opt.hidden=true; | |
| inputs1.add(opt); | |
| var optn = document.createElement("OPTION"); | |
| optn.text= 'Column'; | |
| optn.value= "Column"; | |
| inputs1.add(optn); | |
| var optn1 = document.createElement("OPTION"); | |
| optn1.text= 'Wall'; | |
| optn1.value= "Wall"; | |
| inputs1.add(optn1); | |
| } | |
| } | |
| } | |
| function userguidetoggleFunction() { | |
| var dropdownContentUserguideId = document.getElementById("dropdown-contentUserguideId"); | |
| var UserGuideSideBar = document.getElementById('UserGuideSideBar'); | |
| var UserGuidetoggle = document.getElementById('UserGuidetoggle'); | |
| var isOpen = UserGuideSideBar.style.display === "block"; | |
| // **Close the dropdown when opening User Guide** | |
| dropdownContentUserguideId.classList.remove("active"); | |
| // **Toggle the sidebar visibility properly** | |
| if (isOpen) { | |
| UserGuideSideBar.style.display = "none"; | |
| UserGuideSideBar.classList.remove('UserGuideslide-in'); | |
| UserGuideSideBar.classList.add('UserGuideslide-out'); | |
| UserGuidetoggle.classList.remove("change"); | |
| } else { | |
| UserGuideSideBar.style.display = "block"; | |
| UserGuideSideBar.style.width = "25%"; | |
| UserGuideSideBar.classList.add('UserGuideslide-in'); | |
| UserGuideSideBar.classList.remove('UserGuideslide-out'); | |
| UserGuidetoggle.classList.add("change"); | |
| } | |
| } | |
| function ShowSectionUserguide(element) { | |
| var textFirstPage = document.getElementById('textfirstpage'); | |
| var UserGuideSideBar = document.getElementById('UserGuideSideBar'); | |
| var UserGuidetoggle = document.getElementById('UserGuidetoggle'); | |
| var isOpen = UserGuideSideBar.style.display === "block"; | |
| // **If clicking home and already on home, only toggle icon** | |
| if (element.id === 'homeguidebutton' || element.parentElement?.id === 'homeguidebutton') { | |
| if (textFirstPage.style.display === 'block') { | |
| return; // Exit function to prevent further toggling | |
| } | |
| hideAllSections(); | |
| textFirstPage.style.display = 'block'; | |
| return; | |
| } | |
| // **If clicking a section, hide sidebar and update content** | |
| if (element.tagName === 'LI') { | |
| hideAllSections(); | |
| // **Toggle the sidebar visibility properly** | |
| if (isOpen) { | |
| UserGuideSideBar.style.display = "none"; | |
| UserGuideSideBar.classList.remove('UserGuideslide-in'); | |
| UserGuideSideBar.classList.add('UserGuideslide-out'); | |
| UserGuidetoggle.classList.remove("change"); | |
| } else { | |
| UserGuideSideBar.style.display = "block"; | |
| UserGuideSideBar.style.width = "25%"; | |
| UserGuideSideBar.classList.add('UserGuideslide-in'); | |
| UserGuideSideBar.classList.remove('UserGuideslide-out'); | |
| UserGuidetoggle.classList.add("change"); | |
| } | |
| if (element.textContent.startsWith('1.0')) { | |
| document.getElementById('1_0textUserGuide').style.display = 'block'; | |
| document.getElementById('1_0textUserGuide').removeAttribute('hidden'); | |
| } | |
| else if (element.textContent.startsWith('2.1')) { | |
| document.getElementById('2_1textUserGuide').style.display = 'block'; | |
| document.getElementById('2_1textUserGuide').removeAttribute('hidden'); | |
| } | |
| else if (element.textContent.startsWith('2.7')) { | |
| document.getElementById('2_7textUserGuide').style.display = 'block'; | |
| document.getElementById('2_7textUserGuide').removeAttribute('hidden'); | |
| } | |
| else if (element.textContent.startsWith('2.8')) { | |
| document.getElementById('2_8textUserGuide').style.display = 'block'; | |
| document.getElementById('2_8textUserGuide').removeAttribute('hidden'); | |
| } | |
| else if (element.textContent.startsWith('3.2')) { | |
| document.getElementById('3_2textUserGuide').style.display = 'block'; | |
| document.getElementById('3_2textUserGuide').removeAttribute('hidden'); | |
| } | |
| else if (element.textContent.startsWith('3.3')) { | |
| document.getElementById('3_3textUserGuide').style.display = 'block'; | |
| document.getElementById('3_3textUserGuide').removeAttribute('hidden'); | |
| } | |
| } | |
| } | |
| // Function to hide all sections before showing the selected one | |
| function hideAllSections() { | |
| document.getElementById('textfirstpage').style.display = 'none'; | |
| document.getElementById('1_0textUserGuide').style.display = 'none'; | |
| document.getElementById('2_1textUserGuide').style.display = 'none'; | |
| document.getElementById('2_7textUserGuide').style.display = 'none'; | |
| document.getElementById('2_8textUserGuide').style.display = 'none'; | |
| document.getElementById('3_2textUserGuide').style.display = 'none'; | |
| document.getElementById('3_3textUserGuide').style.display = 'none'; | |
| } | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| /*User Guide button toggle*/ | |
| function userguideclick(){ | |
| document.getElementById('textfirstpage').style.display='block' | |
| var acc = document.getElementsByClassName("dropdown-content")[0]; | |
| var userguideClose=document.getElementById("userguideClose") | |
| var i; | |
| acc.classList.toggle("active"); | |
| /* Toggle between hiding and showing the active panel */ | |
| if (acc.style.display === "block") { | |
| acc.style.display = "none"; | |
| } else { | |
| acc.style.display = "block"; | |
| acc.style.backgroundColor=(0, 153, 255); | |
| } | |
| close.onclick = function() { | |
| acc.style.display = "none"; | |
| }; | |
| } | |
| function userguideMayaTableClick(){ | |
| var userguideTableMaya=document.getElementById('userguideTableMaya') | |
| window.open('https://docs.google.com/spreadsheets/d/10TjB8EbSiDHybo9YsDDzekxi8iQECpprXdqptHCZzec/edit?gid=875423041#gid=875423041'); | |
| } | |
| //to be retrieved from python code | |
| var areainpixels=0; | |
| var prminpixels=0; | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| /*Populate dropdowns*/ | |
| //get the 3 dropdown elements | |
| var proj = document.getElementsByClassName("selectionsProj")[0]; | |
| var proj1 = document.getElementsByClassName("selectionsProjp")[0]; | |
| var projsec = document.getElementsByClassName("selectionsProjs")[0]; | |
| var pdfname; | |
| projsec.addEventListener('input',function(){ | |
| projsec.style.boxShadow=( '2px 2px 2px gray') | |
| }) | |
| var ratioAunit=1; | |
| var ratioPunit=1; | |
| var pdfnames=''; | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| function getSelectValues(select) { | |
| var result = []; | |
| var options = select && select.options; | |
| var opt; | |
| for (var i=0, iLen=options.length; i<iLen; i++) { | |
| opt = options[i]; | |
| if (opt.selected) { | |
| result.push(opt.value || opt.text); | |
| } | |
| } | |
| console.log('selectedddddd',result) | |
| return result; | |
| } | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| //Retrieves list of projects | |
| var doorSchedulePDF; | |
| function getproj(){ | |
| getALLMCTNAMES(); | |
| var proj = document.getElementsByClassName("selectionsProj")[0]; | |
| var projectVal=proj.value.toString() //selected project | |
| var inputs = document.getElementsByTagName("select")[1]; //second dropdown(project part) | |
| var p=document.getElementById("selectionsProjpid") //project part | |
| var sections = document.getElementsByClassName("selectionsProjs")[0]; | |
| chooseFirstdrpdwn(); | |
| var eventSource = new EventSource('/getmethod/' + JSON.stringify(projectVal)); | |
| document.getElementById('progressBar').removeAttribute('hidden') | |
| document.getElementById('progressBar').style.display='block'; | |
| eventSource.onmessage = function (event) { | |
| var progress = parseInt(event.data); // Progress value from Flask | |
| if (progress <= 100) { | |
| console.log(progress); // Log progress for debugging | |
| document.getElementById('progress').style.width = progress + '%'; | |
| document.getElementById('progress').textContent = progress + '%'; | |
| } else { | |
| // Final data handling when progress reaches 100% | |
| console.log('Process completed!'); | |
| // Parse and handle the final response data (documentsToMeasure, RelevantDocuments, extracted_path) | |
| var data = JSON.parse(event.data); // Assuming the result is a JSON array | |
| console.log('Final result:', data); | |
| // You can use this data to update your page or handle it accordingly | |
| eventSource.close(); // Close the connection when finished | |
| document.getElementById('progressBar').setAttribute('hidden',true) | |
| document.getElementById('progressBar').style.display='none'; | |
| document.getElementById('progress').style.width = '0%'; // Reset progress for the next process | |
| document.getElementById('progress').textContent = '0%'; | |
| document.getElementById('refreshDropboxButtonID').style.display = "block"; | |
| document.getElementById("all").style.display = "none"; | |
| if (sections.value.startsWith('3.2') || sections.value.startsWith('3.3') || sections.value.startsWith('2.7') ){ | |
| document.getElementById('dxfdiv').removeAttribute('hidden'); | |
| document.getElementById('pdftodxfFile').setAttribute('required',true) | |
| } | |
| else{ | |
| document.getElementById('dxfdiv').setAttribute('hidden',true) | |
| } | |
| extracted_path=data[2] | |
| var docsToMeasure=data[0]; // | |
| var relvDocs=data[1] | |
| var projname = document.getElementsByClassName("selectionsProj")[0]; | |
| var projpart = document.getElementsByClassName("selectionsProjp")[0]; | |
| var projsec = document.getElementsByClassName("selectionsProjs")[0]; | |
| var meas = document.getElementById("measureCheckbox") ; | |
| var relv = document.getElementById("relvdiv") ; | |
| const measids=[]; | |
| const relvids=[]; | |
| const measoptns=[]; | |
| // var measSelect = document.getElementById("measureselectid"); | |
| var measSelect = document.getElementById("measureContainer"); | |
| var relvSelect = document.getElementById("relvselectid"); | |
| var levelcheckbox= document.getElementById("levelcheckbox"); | |
| measSelect.removeAttribute("hidden"); | |
| relvSelect.removeAttribute("hidden"); | |
| if (measSelect && measSelect.hasChildNodes()) { | |
| while (measSelect.firstChild) { | |
| measSelect.removeChild(measSelect.firstChild); | |
| } | |
| } | |
| var optn2 = document.createElement("div"); // Use a <div> instead of <option> | |
| optn2.textContent = 'Select project to measure'; // Set text content | |
| optn2.hidden = true; // Keep it hidden | |
| optn2.id = 'hidden'; | |
| measSelect.appendChild(optn2); // Append to div instead of .add() | |
| document.getElementById("hidden").required = true; | |
| if (relvSelect && relvSelect.hasChildNodes()) { | |
| while (relvSelect.firstChild) { | |
| relvSelect.removeChild(relvSelect.firstChild); | |
| } | |
| } | |
| const nameSet = new Set(); // To track unique names | |
| const nameSetRelv = new Set(); // To track unique names | |
| // Action foconst nameSet = new Set(); // To track unique names | |
| // Action for when the checkbox is clicked | |
| function handleCheckboxChange(event) { | |
| // Uncheck all checkboxes before checking the current one | |
| document.querySelectorAll('input[name="measureCheckbox"]').forEach(checkbox => { | |
| checkbox.checked = false; | |
| }); | |
| // Check the current checkbox | |
| event.target.checked = true; | |
| // Action when checkbox is clicked (e.g., log the selected project) | |
| let selectedValue = event.target.value; | |
| console.log("Selected project:", selectedValue); | |
| // Highlight the selected item | |
| document.querySelectorAll(".measure-item").forEach(item => { | |
| item.style.backgroundColor = ''; // Reset background color for all items | |
| }); | |
| event.target.closest(".measure-item").style.backgroundColor = '#d3f8d3'; // Highlight the selected item | |
| // Show alert immediately to prompt the user | |
| if (projsec.value.startsWith('3.2') || projsec.value.startsWith('3.3') || projsec.value.startsWith('2.7')) { | |
| // downloadPdf(selectedValue); | |
| downloadPdf(selectedValue,'DXF_File_:'+selectedValue) | |
| // 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."); | |
| } | |
| // else{ | |
| // 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."); | |
| // } | |
| canvasimg=''; | |
| ry=[[]]; | |
| levelcheckbox.checked=false; | |
| pdfname=selectedValue; | |
| measSelect.style.boxShadow='none'; | |
| document.getElementById("all").style.display = "block"; | |
| pixelArr=[projname.value, projpart.value,projsec.value, pdfname] | |
| // Open popup immediately before initiating the PDF download | |
| var eventSource = new EventSource('/pixelimg/' + JSON.stringify(pixelArr)); | |
| document.getElementById('progressBar').removeAttribute('hidden') | |
| document.getElementById('progressBar').style.display='block'; | |
| eventSource.onmessage = function (event) { | |
| var progress = parseInt(event.data); // Progress value from Flask | |
| if (progress <= 100) { | |
| console.log(progress); // Log progress for debugging | |
| document.getElementById('progress').style.width = progress + '%'; | |
| document.getElementById('progress').textContent = progress + '%'; | |
| } else { | |
| // Final data handling when progress reaches 100% | |
| console.log('Process completed!'); | |
| // Parse and handle the final response data (documentsToMeasure, RelevantDocuments, extracted_path) | |
| var data = JSON.parse(event.data); // Assuming the result is a JSON array | |
| console.log('Final result:', data); | |
| // You can use this data to update your page or handle it accordingly | |
| eventSource.close(); // Close the connection when finished | |
| document.getElementById('progressBar').setAttribute('hidden',true) | |
| document.getElementById('progressBar').style.display='none'; | |
| document.getElementById('progress').style.width = '0%'; // Reset progress for the next process | |
| document.getElementById('progress').textContent = '0%'; | |
| document.getElementById("all").style.display = "none"; | |
| // Display link or any additional data if needed | |
| window.open(data[2]); | |
| downloadPdf(pdfname,'Pixel_Conversion_File_:'+pdfname) | |
| document.getElementById("all").style.display = "none"; | |
| document.getElementById('measureADRbutton').onclick= function() | |
| { | |
| if (!areaRatio.value){ | |
| if (!(projsec.value.startsWith('3.2')) & !(projsec.value.startsWith('2.8')) & !(projsec.value.startsWith('3.3')) & !(projsec.value.startsWith('2.7')) ) | |
| areaRatio.style.boxShadow='0 0 8px 2px rgb(255, 0, 0)'; | |
| } | |
| if (!prmRatio.value) | |
| { | |
| if (!(projsec.value.startsWith('2.8'))) | |
| prmRatio.style.boxShadow='0 0 8px 2px rgb(255, 0, 0)'; | |
| } | |
| } | |
| document.getElementById('radiosColors').removeAttribute('hidden'); | |
| var scalelbl= document.createElement("label"); | |
| scalelbl.innerText='Scale Document'; | |
| scalelbl.id='measureLabel'; | |
| var br1= document.createElement("br"); | |
| var areadiv=document.createElement("div"); | |
| areadiv.id='areadiv' | |
| var areaRatiolbl= document.createElement("label"); | |
| areaRatiolbl.innerText='Area:' | |
| areaRatiolbl.id='radiolbl'; | |
| var areaRatio= document.createElement("input"); | |
| areaRatio.type='number'; | |
| areaRatio.id='arealvlinput'; | |
| areaRatio.className='lvlinput'; | |
| areaRatio.name='areaRatio'; | |
| areaRatio.style.marginLeft='78px'; | |
| areaRatio.style.textAlign='right'; | |
| areaRatio.step=".0000001"; | |
| areaRatio.min = "0"; // Allow only positive numbers (>= 0) | |
| if( projsec.value.startsWith('3.2') || projsec.value.startsWith('3.3') || projsec.value.startsWith('2.1') || projsec.value.startsWith('2.7')){ | |
| areaRatio.setAttribute('disabled',true) | |
| areaRatio.style.cursor='not-allowed'; | |
| areaRatio.style.backgroundColor='rgba(101, 101, 101, 0.27)' | |
| document.getElementById('selectunitA').setAttribute('disabled',true) | |
| document.getElementById('selectunitA').style.cursor='not-allowed'; | |
| document.getElementById('selectunitA').style.backgroundColor='rgba(101, 101, 101, 0.27)' | |
| } | |
| else{ // section 1.0 | |
| areaRatio.removeAttribute('disabled') | |
| areaRatio.style.cursor='pointer'; | |
| document.getElementById('selectunitA').removeAttribute('disabled') | |
| document.getElementById('selectunitA').style.cursor='pointer'; | |
| } | |
| areaRatio.addEventListener('change',function(){ | |
| areaRatio.value=(Number(areaRatio.value)).toFixed(7) | |
| areaRatio.style.boxShadow='none'; | |
| }) | |
| areaRatio.required=true; | |
| selectunitA=document.getElementById('selectunitA') | |
| selectunitA.removeAttribute('hidden') | |
| areadiv.append(areaRatiolbl,areaRatio,selectunitA) | |
| var br2= document.createElement("br"); | |
| var br3= document.createElement("br"); | |
| var prmdiv=document.createElement("div"); | |
| prmdiv.id='prmdiv' | |
| var prmRatiolbl= document.createElement("label"); | |
| prmRatiolbl.innerText='Perimeter:' | |
| prmRatiolbl.id='radiolbl'; | |
| var prmRatio= document.createElement("input"); | |
| prmRatio.type='number'; | |
| prmRatio.id='perimlvlinput'; | |
| prmRatio.className='lvlinput'; | |
| prmRatio.name='prmRatio'; | |
| prmRatio.style.textAlign='right'; | |
| prmRatio.style.marginLeft='49px'; | |
| prmRatio.step=".0000001"; | |
| prmRatio.min = "0"; // Allow only positive numbers (>= 0) | |
| prmRatio.addEventListener('change',function(){ | |
| prmRatio.value=(Number(prmRatio.value)).toFixed(7) | |
| prmRatio.style.boxShadow='none'; | |
| }) | |
| prmRatio.required=true; | |
| selectunitP=document.getElementById('selectunitP') | |
| selectunitP.removeAttribute('hidden') | |
| prmdiv.append(prmRatiolbl, prmRatio,selectunitP) | |
| var ratiosdiv= document.getElementById("ratios"); | |
| ratiosdiv.innerHTML=''; | |
| ratiosdiv.append(scalelbl); | |
| ratiosdiv.append(br1); | |
| ratiosdiv.append(areadiv) | |
| ratiosdiv.append(prmdiv) | |
| areainpixels=data[0]; | |
| prminpixels=data[1]; | |
| if( projsec.value.startsWith('2.8')) { | |
| areaRatio.setAttribute('disabled',true) | |
| areaRatio.style.cursor='not-allowed'; | |
| areaRatio.style.backgroundColor='rgba(101, 101, 101, 0.27)' | |
| document.getElementById('selectunitA').setAttribute('disabled',true) | |
| document.getElementById('selectunitA').style.cursor='not-allowed'; | |
| document.getElementById('selectunitA').style.backgroundColor='rgba(101, 101, 101, 0.27)' | |
| prmRatio.setAttribute('disabled',true) | |
| prmRatio.style.cursor='not-allowed'; | |
| prmRatio.style.backgroundColor='rgba(101, 101, 101, 0.27)' | |
| document.getElementById('selectunitP').setAttribute('disabled',true) | |
| document.getElementById('selectunitP').style.cursor='not-allowed'; | |
| document.getElementById('selectunitP').style.backgroundColor='rgba(101, 101, 101, 0.27)' | |
| } | |
| }; | |
| } | |
| eventSource.onerror = function (error) { | |
| console.error('Error occurred:', error); | |
| eventSource.close(); // Close on error | |
| 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. '; | |
| ShowPopUp(); | |
| }; | |
| selectunitA.addEventListener('change',function(){ | |
| value=document.getElementById('selectunitA').value | |
| if (value=='mm2') | |
| ratioAunit=1000000; | |
| else | |
| ratioAunit=1; | |
| }) | |
| selectunitP.addEventListener('change',function(){ | |
| value=document.getElementById('selectunitP').value | |
| if (value=='mm'){ | |
| ratioPunit=1000; | |
| } | |
| else | |
| ratioPunit=1; | |
| }) | |
| // } | |
| // for 2.8 multiple pdfs | |
| // else{ | |
| // pdfnames=getSelectValues(elem) | |
| // } | |
| } | |
| // Action for when the label is clicked (no checkbox change) | |
| function handleLabelClick(event) { | |
| // Action when label is clicked (e.g., log the selected project via the label) | |
| let selectedLabel = event.target.textContent; | |
| console.log("Label clicked: ", selectedLabel); | |
| // Optional: Highlight the selected item | |
| document.querySelectorAll(".measure-item").forEach(item => { | |
| item.style.backgroundColor = ''; // Reset background color for all items | |
| }); | |
| // event.target.closest(".measure-item").style.backgroundColor = '#919592'; // Highlight the selected item | |
| // Show loading indicator | |
| document.getElementById("all").style.display = "block"; | |
| fetch('/getdropboxurl/'+ JSON.stringify(selectedLabel), { | |
| method: 'POST', | |
| headers: { 'Content-Type': 'application/json' }, | |
| body: JSON.stringify({ filename: "your_pdf_filename_here.pdf" }) | |
| }) | |
| .then(response => response.blob()) | |
| .then(blob => { | |
| document.getElementById("all").style.display = "none"; | |
| const url = URL.createObjectURL(blob); | |
| // Set the URL to the iframe's src to load the content inside the page | |
| addIframeTab(selectedLabel,url); | |
| // addIframeTab("Google", "https://www.google.com"); | |
| }) | |
| .catch(function(jqXHR, textStatus, errorThrown) { | |
| // Handle error | |
| 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.'; | |
| ShowPopUp(); | |
| }); | |
| } | |
| for (let i = 0; i < docsToMeasure.length; i++) { | |
| let name = docsToMeasure[i][0]; | |
| // Create div for the measure item | |
| let div = document.createElement("div"); | |
| div.className = "measure-item"; | |
| // Create the checkbox | |
| let checkbox = document.createElement("input"); | |
| checkbox.type = "checkbox"; | |
| checkbox.name = "measureCheckbox"; | |
| checkbox.value = name; | |
| checkbox.onclick = handleCheckboxChange; // Handle checkbox click | |
| // Create the label | |
| let label = document.createElement("label"); | |
| label.textContent = name; | |
| label.onclick = handleLabelClick; // Handle label click | |
| // Append checkbox and label to the div | |
| div.appendChild(checkbox); | |
| div.appendChild(label); | |
| // Append the item to the select container | |
| measSelect.appendChild(div); | |
| // Check for duplicates | |
| if (nameSet.has(name)) { | |
| label.style.color = "red"; // Highlight duplicate (optional) | |
| document.getElementById("TopTextModal").textContent='Error: Duplicates Error' | |
| 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.'; | |
| ShowPopUp(); | |
| } else { | |
| nameSet.add(name); // Add unique name to the set | |
| } | |
| } | |
| for (let i = 0; i < relvDocs.length; i++) { | |
| let name = relvDocs[i][0]; | |
| // Create div for the measure item | |
| let div = document.createElement("div"); | |
| div.className = "relv-item"; //relvselectid .relv-item | |
| // Create the label | |
| let label = document.createElement("label"); | |
| label.textContent = name; | |
| label.onclick= function(event) | |
| { | |
| // Action when label is clicked (e.g., log the selected project via the label) | |
| let relevantDocumentName = event.target.textContent; | |
| console.log("Label clicked: ", relevantDocumentName); | |
| if (projsec.value.startsWith('2.8')){ | |
| doorSchedulePDF=relevantDocumentName | |
| console.log(doorSchedulePDF) | |
| } | |
| // Optional: Highlight the selected item | |
| document.querySelectorAll(".relv-item").forEach(item => { | |
| item.style.backgroundColor = ''; // Reset background color for all items | |
| }); | |
| event.target.closest(".relv-item").style.backgroundColor ='#d3f8d3'; // Highlight the selected item | |
| document.getElementById('relvselectid').style.boxShadow=''; | |
| }; | |
| div.appendChild(label); | |
| // Append the item to the select container | |
| relvSelect.appendChild(div); | |
| // Handle duplicate names | |
| if (nameSetRelv.has(name)) { | |
| label.style.color = "red"; // Highlight duplicate (optional) | |
| } else { | |
| nameSetRelv.add(name); | |
| } | |
| } | |
| relvids.push(relvSelect) ; | |
| measids.push(measSelect); | |
| document.addEventListener("click", function(event) { | |
| const iframe = document.getElementById("pdfFrame"); | |
| if (!iframe.contains(event.target)) { | |
| const iframe = document.getElementById("pdfFrame"); | |
| iframe.style.display = "none"; | |
| } | |
| }); | |
| document.getElementById('measureADRbutton').onclick= function() | |
| { | |
| if (!measSelect.value) { | |
| measSelect.style.boxShadow = '0 0 8px 2px rgb(255, 0, 0)'; | |
| measSelect.setAttribute("required", "") | |
| } | |
| if (!relvSelect.value) { | |
| if (sectionNumber.startsWith('2.8')) { | |
| relvSelect.style.boxShadow = '0 0 8px 2px rgb(255, 0, 0)'; | |
| relvSelect.setAttribute("required", "") | |
| } | |
| } | |
| } | |
| } | |
| if (document.getElementById('arealvlinput')){ | |
| 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')){ | |
| document.getElementById('arealvlinput').setAttribute('disabled',true) | |
| document.getElementById('selectunitA').setAttribute('disabled',true) | |
| } | |
| else{ // section 1.0 | |
| document.getElementById('arealvlinput').removeAttribute('disabled') | |
| document.getElementById('selectunitA').removeAttribute('disabled') | |
| } | |
| } | |
| }; | |
| eventSource.onerror = function (error) { | |
| console.error('Error occurred:', error); | |
| eventSource.close(); // Close on error | |
| 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. '; | |
| ShowPopUp(); | |
| }; | |
| } | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| function ImgLarger(id, src){ | |
| // Get the modal | |
| var modal = document.getElementById('myModal'); | |
| // Get the image and insert it inside the modal - use its "alt" text as a caption | |
| var img = document.getElementById(id); | |
| var modalImg = document.getElementById('img01'); | |
| var captionText = document.getElementById("caption"); | |
| modal.style.display = "block"; | |
| modalImg.src = src; | |
| captionText.innerHTML = 'Preview'; | |
| // Get the <span> element that closes the modal | |
| var span = document.getElementsByClassName("close")[0]; | |
| // When the user clicks on <span> (x), close the modal | |
| span.onclick = function() { | |
| modal.style.display = "none"; | |
| } | |
| } | |
| var spreadsheetId=''; | |
| var spreadsheetURL=''; | |
| var colorsUsed=''; | |
| var list1=''; | |
| var SimilarAreaDictionary=''; | |
| var tomeasureproj='' | |
| var pdfpath=[]; | |
| var interval = null; | |
| var namepathArr='' | |
| var allcolors=['#2FFFFF']; | |
| // Main Function - form submit | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| document.getElementById('pdftodxfFile').addEventListener('input',function(){ | |
| console.log('hghjk') | |
| const files = document.getElementById("pdftodxfFile"); | |
| dxffile=files.files[0]; | |
| console.log(dxffile) | |
| }); | |
| function ImgSide(imgdata, spreadsheetLink, pdfLink) { | |
| var backimg = document.getElementById('backgroundimg'); | |
| backimg.innerHTML='' | |
| // Create a container for the image and buttons | |
| var imgContainer = document.createElement('div'); | |
| imgContainer.className = 'imgContainer'; | |
| var imgcanvas = document.createElement("img"); | |
| imgcanvas.src = 'data:image/gif;base64,' + imgdata; | |
| imgcanvas.height = 600; | |
| imgcanvas.id = 'imgcanvas'; | |
| imgcanvas.alt = "Larry"; | |
| imgcanvas.style.zIndex = 999; | |
| imgcanvas.addEventListener('click', function () { | |
| ImgLarger(imgcanvas.id, imgcanvas.src); | |
| }); | |
| var buttonContainer = document.createElement('div'); | |
| buttonContainer.style.display = 'flex'; | |
| buttonContainer.style.marginTop = '10px'; | |
| /////////////////////////////////////////////////////////////// | |
| var legendbutton = document.createElement("button"); | |
| legendbutton.className = 'measureADRbutton2'; | |
| legendbutton.innerText = 'Legend and Data created'; | |
| legendbutton.style.backgroundColor = 'rgb(5, 43, 235)'; | |
| if ( projsec.value.startsWith('2.8')){ | |
| legendbutton.setAttribute('disabled',true); | |
| legendbutton.style.cursor='not-allowed'; | |
| legendbutton.style.boxShadow = 'none'; | |
| legendbutton.style.color = 'white'; | |
| legendbutton.style.backgroundColor="rgb(154,152,152)"; | |
| } | |
| else{ | |
| legendbutton.addEventListener('mouseover', function () { | |
| legendbutton.style.boxShadow = '0 0 8px 2px rgb(5, 43, 235)'; | |
| }); | |
| legendbutton.addEventListener('mouseout', function () { | |
| legendbutton.style.boxShadow = 'none'; | |
| }); | |
| legendbutton.addEventListener('click', function () { | |
| window.open(spreadsheetLink); | |
| }); | |
| } | |
| ////////////////////////////////////////////////////////////// | |
| var imgbutton = document.createElement("button"); | |
| imgbutton.className = 'measureADRbutton2'; | |
| imgbutton.innerText = 'Click to view as PDF'; | |
| imgbutton.id='clickpdfurldp' | |
| imgbutton.style.backgroundColor = 'rgb(255,0,255)'; | |
| imgbutton.addEventListener('mouseover', function () { | |
| imgbutton.style.boxShadow = '0 0 8px 2px rgb(255,0,255)'; | |
| }); | |
| imgbutton.addEventListener('mouseout', function () { | |
| imgbutton.style.boxShadow = 'none'; | |
| }); | |
| imgbutton.addEventListener('click', function () { | |
| window.open(pdfLink); | |
| }); | |
| ///////////////////////////////////////////////////////////// | |
| var refreshpdfmarkups = document.createElement("button"); | |
| refreshpdfmarkups.className = 'measureADRbutton2'; | |
| refreshpdfmarkups.id='refreshpdfmarkups' | |
| refreshpdfmarkups.style.backgroundColor = 'rgb(255,80,255)'; | |
| refreshpdfmarkups.style.padding = '10px 20px'; | |
| // Create the icon element | |
| const icon = document.createElement('i'); | |
| icon.className = 'fa fa-refresh'; // Add Font Awesome classes | |
| icon.setAttribute('aria-hidden', 'true'); // Add accessibility attribute | |
| // Set button text and append the icon | |
| // refreshpdfmarkups.textContent = ' Refresh'; | |
| refreshpdfmarkups.prepend(icon); // Add icon before the text | |
| refreshpdfmarkups.addEventListener('mouseover', function () { | |
| refreshpdfmarkups.style.boxShadow = '0 0 8px 2px rgb(255,80,255)'; | |
| }); | |
| refreshpdfmarkups.addEventListener('mouseout', function () { | |
| refreshpdfmarkups.style.boxShadow = 'none'; | |
| }); | |
| //////////////////////////////////////////////////////////// | |
| buttonContainer.appendChild(legendbutton); | |
| buttonContainer.appendChild(imgbutton); | |
| buttonContainer.appendChild(refreshpdfmarkups); | |
| imgContainer.appendChild(imgcanvas); | |
| imgContainer.appendChild(buttonContainer); | |
| backimg.appendChild(imgContainer); | |
| } | |
| function updatepreview(pdfname){ | |
| console.log('pdfpath',pdfname) | |
| $.get( '/updatepreviewimg/'+ JSON.stringify(pdfname)) | |
| .success( function(data) { | |
| document.getElementById("loading").hidden = true; | |
| ImgSide(data,spreadsheetURL,dropboxLink) | |
| }) | |
| } | |
| // Function to update dropdown options | |
| function updateDropdown(options) { | |
| const dropdowns = document.getElementsByName('text1name'); | |
| dropdowns.forEach((dropdown) => { | |
| // Save the currently selected value | |
| const selectedValue = dropdown.value; | |
| // Clear the dropdown | |
| dropdown.innerHTML = ''; | |
| // Repopulate with new options | |
| options.forEach((value) => { | |
| const option = document.createElement('option'); | |
| option.value = value; | |
| option.textContent = value; | |
| dropdown.appendChild(option); | |
| }); | |
| // Restore the previously selected value if it still exists | |
| if (options.includes(selectedValue)) { | |
| dropdown.value = selectedValue; | |
| } | |
| }); | |
| } | |
| // Function to start the worker and periodic updates | |
| function startDropdownUpdates() { | |
| const guessedNamesWorker = new Worker('../static/guessedNamesWorker.js'); | |
| // Handle messages from the worker | |
| guessedNamesWorker.onmessage = function (event) { | |
| if (event.data.status === 'success') { | |
| console.log('Updating dropdown with new data:', event.data.data); | |
| updateDropdown(event.data.data); // Update the dropdown | |
| } else { | |
| console.error('Error from worker:', event.data.error); | |
| } | |
| }; | |
| // Send an initial fetch message to the worker | |
| guessedNamesWorker.postMessage('fetch'); | |
| // Periodically fetch data every 3 seconds | |
| setInterval(() => { | |
| guessedNamesWorker.postMessage('fetch'); | |
| }, 3000); | |
| } | |
| function getData(form) { | |
| document.getElementById("loading").hidden = false; | |
| document.getElementById('measureADRbutton').setAttribute('disabled',true); | |
| document.getElementById('measureADRbutton').style.cursor='not-allowed'; | |
| document.getElementById('measureADRbutton').style.boxShadow = 'none'; | |
| document.getElementById('measureADRbutton').style.color = 'white'; | |
| document.getElementById('measureADRbutton').style.backgroundColor="rgb(154,152,152)"; | |
| var formData = new FormData(form); | |
| clearInterval(interval) | |
| val=0; | |
| answers=[]; | |
| var ratio1=0; | |
| var ratio2=0; | |
| tomeasureproj=''; | |
| pdfpath=[]; | |
| formvalues=Object.fromEntries(formData); | |
| console.log(formData,formvalues) | |
| // iterate through entries... | |
| tomeasureproj=formvalues['measureCheckbox']; //proj name | |
| if( formvalues['selectprojs'].startsWith('3.2') || formvalues['selectprojs'].startsWith('3.3') || formvalues['selectprojs'].startsWith('2.7') ){ | |
| ratio1=1 | |
| ratio2=prminpixels/(formvalues['prmRatio']/ratioPunit); | |
| console.log(ratio2, prminpixels,formvalues['prmRatio'],ratioPunit) | |
| } | |
| else if (formvalues['selectprojs'].startsWith('1.0') ){ | |
| ratio1=(formvalues['areaRatio']/ratioAunit)/areainpixels; | |
| ratio2=(formvalues['prmRatio']/ratioPunit)/prminpixels; | |
| console.log('ratioss',ratio1,ratio2) | |
| } | |
| else if (formvalues['selectprojs'].startsWith('2.8') || formvalues['selectprojs'].startsWith('2.1') ){ | |
| ratio1=1; | |
| ratio2=(formvalues['prmRatio']/ratioPunit)/prminpixels; | |
| console.log('ratioss',ratio1,ratio2) | |
| } | |
| pdfpath.push(formvalues['selectproj'],formvalues['selectprojp'] ,formvalues['selectprojs']) //project name - part - section | |
| if (canvasimg){ | |
| console.log('canvasimg') | |
| buf=canvasimg.split("data:image/png;base64,") | |
| answers.push(tomeasureproj, 220,allcolors , ratio1, ratio2 ,pdfpath,buf[1]); | |
| formData.append('answers',JSON.stringify(answers)) | |
| } | |
| else{ | |
| console.log('else') | |
| if ( formvalues['selectprojs'].startsWith('3.2') || formvalues['selectprojs'].startsWith('3.3') ) | |
| { | |
| console.log('elseif') | |
| answers.push(tomeasureproj, 0,[], ratio1, ratio2 ,pdfpath); | |
| formData.append('file',dxffile) | |
| formData.append('answers',JSON.stringify(answers)) | |
| } | |
| else if ( formvalues['selectprojs'].startsWith('2.7')) | |
| { | |
| console.log('elseif') | |
| console.log(groupedValues) | |
| answers.push(tomeasureproj, 0,[], ratio1, ratio2 ,pdfpath,groupedValues); | |
| formData.append('file',dxffile) | |
| formData.append('answers',JSON.stringify(answers)) | |
| } | |
| else if (formvalues['selectprojs'].startsWith('1.0')) | |
| { | |
| console.log('whyyyy hereeee') | |
| file='' | |
| answers.push(tomeasureproj, 0,[] , ratio1, ratio2 ,pdfpath); | |
| formData.append('answers',JSON.stringify(answers)) | |
| } | |
| else if (formvalues['selectprojs'].startsWith('2.1')) | |
| { | |
| answers.push(tomeasureproj, 0,[] , ratio1, ratio2 ,pdfpath); | |
| formData.append('answers',JSON.stringify(answers)) | |
| } | |
| else if (formvalues['selectprojs'].startsWith('2.8') ) | |
| { | |
| answers.push(tomeasureproj, 0,[] , 0,0,pdfpath , doorSchedulePDF); | |
| formData.append('answers',JSON.stringify(answers)) | |
| } | |
| } | |
| 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') | |
| { | |
| // console.log(formData) | |
| $.ajax({ | |
| type: "POST", | |
| url: "/savebase64Img/", | |
| contentType: "application/json", // set content type header to use Flask response.get_json() | |
| data: formData,// convert data/object to JSON to send | |
| processData: false, // Prevent jQuery from automatically processing the data | |
| contentType: false, | |
| success: function(response) { | |
| console.log(response); | |
| }, | |
| error: function(err) { | |
| var TopTextModal = document.getElementById("TopTextModalWarning"); | |
| TopTextModal.textContent='Error' | |
| PopupElement.textContent='Error occured. Refresh and try again. If the error continues, please contact the ADR team to fix it. '; | |
| ShowPopUp(); | |
| } | |
| }) | |
| .done(function(data){ | |
| // var mp3_url = 'https://media.geeksforgeeks.org/wp-content/uploads/20190531135120/beep.mp3'; | |
| // (new Audio(mp3_url)).play() | |
| // retrieveLinks() | |
| if (!(formvalues['selectprojs'].startsWith('2.8')) ) | |
| startDropdownUpdates(); // Start the dropdown updates | |
| document.getElementById("loading").hidden = true; | |
| document.getElementById("rightside").hidden = false; | |
| document.getElementById('duplicater').removeAttribute('hidden'); | |
| if (formvalues['selectprojs'].startsWith('3.2') || formvalues['selectprojs'].startsWith('3.3') ) | |
| { | |
| document.getElementById('duplicater').children[8].children[1].setAttribute('disabled','True') | |
| document.getElementById('duplicater').children[8].children[2].setAttribute('disabled','True') | |
| document.getElementById('duplicater').children[8].children[1].style.cursor='not-allowed'; | |
| document.getElementById('duplicater').children[8].children[2].style.cursor='not-allowed'; | |
| } | |
| document.getElementById('addicon').style.display='inline-block'; | |
| document.getElementById('doneebackground').removeAttribute('hidden'); | |
| document.getElementById('summarytoXML').removeAttribute('hidden'); | |
| if (mctnameEmpty){ | |
| document.getElementById('doneebackground').setAttribute('disabled','True') | |
| document.getElementById('doneebackground').style.cursor='not-allowed'; | |
| document.getElementById('doneebackground').style.boxShadow = 'none'; | |
| document.getElementById('doneebackground').style.color = 'white'; | |
| document.getElementById('doneebackground').style.backgroundColor="rgb(154,152,152)"; | |
| document.getElementById('summarytoXML').setAttribute('disabled','True') | |
| document.getElementById('summarytoXML').style.cursor='not-allowed'; | |
| document.getElementById('summarytoXML').style.boxShadow = 'none'; | |
| document.getElementById('summarytoXML').style.color = 'white'; | |
| document.getElementById('summarytoXML').style.backgroundColor="rgb(154,152,152)"; | |
| } | |
| // clearInterval() | |
| document.getElementById('measureADRbutton').removeAttribute('disabled'); | |
| document.getElementById('measureADRbutton').style.cursor='pointer'; | |
| document.getElementById('measureADRbutton').style.color = 'white'; | |
| document.getElementById('measureADRbutton').style.backgroundColor="#16c72e"; | |
| document.getElementById('measureADRbutton').style.padding='10px 102px'; | |
| document.getElementById('measureADRbutton').addEventListener('mouseover',function(){ | |
| document.getElementById('measureADRbutton').style.color='black'; | |
| document.getElementById('measureADRbutton').style.boxShadow=' 0 0 8px 2px #16c72e'; | |
| }) | |
| document.getElementById('measureADRbutton').addEventListener('mouseout',function(){ | |
| document.getElementById('measureADRbutton').style.color='white'; | |
| document.getElementById('measureADRbutton').style.boxShadow='none'; | |
| }); | |
| if (formvalues['selectprojs'].startsWith('3.2') || formvalues['selectprojs'].startsWith('3.3') || formvalues['selectprojs'].startsWith('2.7') ) | |
| { // | |
| // /* data[0]--> img , SimilarAreaDictionary.to_dict(), spreadsheet_url,spreadsheetId,[],list1.to_dict(),pdflink,hatched_areas,namepathArr]# , spreadsheetId, spreadsheet_url , list1.to_dict()] | |
| SimilarAreaDictionary=data[1]; | |
| spreadsheetURL=data[2]; | |
| spreadsheetId=data[3]; | |
| // spreadsheetURL=data[4]; | |
| list1= data[5]; | |
| dropboxLink=data[6]; | |
| console.log(data[7]) | |
| // console.log(dropboxLink) | |
| } | |
| if (formvalues['selectprojs'].startsWith('2.8')) | |
| { //base64.b64encode(buffer).decode('utf-8') ,pdflink,list1.to_dict(), repeated_labels , not_found] | |
| // /* data[0]--> img , data[1]-->dataframe (goes to legend lsa ) , data [2] -->pdf dropbox shareable link ,data[3]-> spreadsheetId, data[4],spreadsheeturl */ | |
| // SimilarAreaDictionary=data[1]; | |
| // listofimages=data[0]; | |
| console.log('2.8Daata',data) | |
| dropboxLink=data[1]; | |
| list1= data[2] // list of pdf markups | |
| Repeated_Labels2_8=data[3] | |
| Not_Found2_8=data[4] | |
| console.log(Repeated_Labels2_8,Not_Found2_8) | |
| } | |
| if (formvalues['selectprojs'].startsWith('2.2')) | |
| { | |
| //ignore data[0] --> img passed directly | |
| //dropboxLink=data[1] | |
| //spreadsheetId=data[2] | |
| //spreadsheetURL=data[3] | |
| } | |
| if (formvalues['selectprojs'].startsWith('2.1')) | |
| { | |
| //ignore data[0] --> img passed directly | |
| //dropboxLink=data[1] | |
| //spreadsheetId=data[2] | |
| //spreadsheetURL=data[3] | |
| spreadsheetURL=data[0] | |
| } | |
| if (formvalues['selectprojs'].startsWith('1.0')) | |
| {// section 1.0 | |
| console.log('?') | |
| SimilarAreaDictionary=data[1]; | |
| spreadsheetURL= data[2]; | |
| spreadsheetId= data[3]; | |
| colorsUsed = data[4]; | |
| list1 = data[5]; //list of pdf markups | |
| dropboxLink=data[6]; | |
| namepathArr=data[8]; | |
| } | |
| // if (!(formvalues['selectprojs'].startsWith('2.8'))) | |
| // { | |
| ImgSide(data[0],spreadsheetURL,dropboxLink) | |
| if (formvalues['selectprojs'].startsWith('2.8')) { | |
| let messages = []; | |
| if (Repeated_Labels2_8) | |
| if (Repeated_Labels2_8.length > 0) { | |
| messages.push('The following label(s) are represented on multiple doors: ' + Repeated_Labels2_8); | |
| } | |
| if (Not_Found2_8.length > 0) { | |
| messages.push('The following label(s) not found on the plan: ' + Not_Found2_8); | |
| } | |
| if (messages.length > 0) { | |
| var TopTextModal = document.getElementById("TopTextModal"); | |
| TopTextModal.textContent = 'Warning'; | |
| PopupElement.textContent = messages.join('\n'); // Show both messages if both conditions are met | |
| ShowPopUp(); | |
| } | |
| } | |
| // } | |
| // else{ | |
| // console.log(listofimages.length) | |
| // for(var p=0;p<listofimages.length;p++) | |
| // { | |
| // ImgSide(listofimages[p],spreadsheetURLs[p],dropboxLinks[p]) | |
| // } | |
| // } | |
| // getlegendstoDirectory() | |
| ////////////////////////////////////////////////////////////////////////////////////////// | |
| let delrows2 = { | |
| content : {}, | |
| id : {}, | |
| subject :{}, | |
| color:{} | |
| }; | |
| var delrows1=''; | |
| var flag=0; | |
| pdfpath=[]; | |
| pdfpath.push(formvalues['selectproj'],formvalues['selectprojp'] ,formvalues['selectprojs']) | |
| if (formvalues['selectprojs'].startsWith('1.0') || formvalues['selectprojs'].startsWith('3.2') || formvalues['selectprojs'].startsWith('3.3')|| formvalues['selectprojs'].startsWith('2.7')) { // || formvalues['selectprojs'].startsWith('2.8') | |
| const interval = 6000; // Interval in milliseconds | |
| let delrows1 = ''; // Initial data storage | |
| let delrows2 = ''; // Updated data storage | |
| console.log('Starting first AJAX request...'); | |
| // First AJAX request | |
| $.ajax({ | |
| type: "POST", | |
| url: "/_submission", | |
| contentType: "application/json", | |
| data: JSON.stringify({ | |
| dict1: JSON.stringify(list1), | |
| spreadsheetId: spreadsheetId, | |
| pdfpathpath: JSON.stringify(pdfpath), | |
| path: Object.fromEntries(formData)['measureCheckbox'] | |
| }), | |
| dataType: "json", | |
| success: function (data1) { | |
| delrows1 = data1[0]; | |
| console.log('First AJAX response received:', JSON.stringify(delrows1)); | |
| }, | |
| error: function (err) { | |
| console.error('Error occurred during first AJAX call:', err); | |
| var TopTextModal = document.getElementById("TopTextModalWarning"); | |
| TopTextModal.textContent='Error' | |
| PopupElement.textContent = 'Error occurred. Refresh and try again. If the error continues, please contact the ADR team to fix it.'; | |
| ShowPopUp(); | |
| } | |
| }); | |
| // Function to perform AJAX requests and compare data | |
| async function fetchAndCompareData() { | |
| try { | |
| console.log('Fetching data...'); | |
| // Second AJAX request | |
| const data11 = await $.ajax({ | |
| type: "POST", | |
| url: "/_submission", | |
| contentType: "application/json", | |
| data: JSON.stringify({ | |
| dict1: JSON.stringify(list1), | |
| spreadsheetId: spreadsheetId, | |
| pdfpathpath: JSON.stringify(pdfpath), | |
| path: Object.fromEntries(formData)['measureCheckbox'] | |
| }), | |
| dataType: "json" | |
| }); | |
| delrows2 = data11[0]; | |
| console.log('Second AJAX response received:', JSON.stringify(delrows2)); | |
| // Compare data | |
| if (JSON.stringify(delrows1) === JSON.stringify(delrows2)) { | |
| console.log('Data is the same'); | |
| } else { | |
| console.log('Differences found:', delrows1, delrows2); | |
| if (confirm("Changes have been made in the markups. Would you like to save and view them in the legend?")) { | |
| delrows1 = delrows2; | |
| document.getElementById("loading").hidden = false; | |
| document.getElementById("loading").style.marginTop = '20%'; | |
| document.getElementById("loading").style.marginLeft = '65%'; | |
| updatepreview([pdfpath, Object.fromEntries(formData)['measureCheckbox']]); | |
| await $.ajax({ | |
| type: "POST", | |
| url: "/deletemarkupsroute", | |
| contentType: "application/json", | |
| data: JSON.stringify({ | |
| dict: JSON.stringify(SimilarAreaDictionary), | |
| deletedrows: delrows2, | |
| path: Object.fromEntries(formData)['measureCheckbox'], | |
| spreadsheetId: spreadsheetId, | |
| areaPermArr: JSON.stringify(data[7]), | |
| section: Object.fromEntries(formData)['selectprojs'], | |
| pdfpathpath: JSON.stringify(pdfpath) | |
| }), | |
| dataType: "json" | |
| }); | |
| console.log('Markups updated'); | |
| } | |
| } | |
| } catch (err) { | |
| var TopTextModal = document.getElementById("TopTextModalWarning"); | |
| TopTextModal.textContent='Error' | |
| console.error('Error occurred during fetchAndCompareData:', err); | |
| PopupElement.textContent = 'Error occurred. Refresh and try again. If the error continues, please contact the ADR team to fix it.'; | |
| ShowPopUp(); | |
| } finally { | |
| // Always continue fetching data every 6 seconds | |
| console.log(`Waiting for ${interval} ms before next fetch...`); | |
| setTimeout(fetchAndCompareData, interval); // Continue the interval | |
| } | |
| } | |
| // Initial interval-based call | |
| setTimeout(fetchAndCompareData, interval); | |
| // Button click event listener | |
| document.addEventListener("click", function (event) { | |
| if (event.target && event.target.id === "refreshpdfmarkups") { | |
| console.log('Button clicked. Fetching data immediately...'); | |
| fetchAndCompareData(); | |
| } | |
| }); | |
| } | |
| ///////////////////////// | |
| }); | |
| } | |
| } | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| document.getElementById("myForm").addEventListener("submit", function (e) { | |
| e.preventDefault(); // Prevent form submission | |
| let isChecked = document.querySelector('input[name="measureCheckbox"]:checked') !== null; | |
| let sectionNumber = projsec.value; // Ensure projsec is defined | |
| let isRelvClicked = document.querySelector(".relv-item[style*='background-color']") !== null; | |
| let TopTextModal = document.getElementById("TopTextModal"); | |
| TopTextModal.textContent = "Warning: Missing Inputs"; | |
| if (sectionNumber.startsWith('2.8')) { | |
| // If section starts with '2.8', both measureCheckbox and relv-item must be selected | |
| if (!isChecked & !isRelvClicked) { | |
| document.getElementById('relvselectid').style.boxShadow='0 0 8px 2px rgb(255, 0, 0)'; | |
| PopupElement.textContent = "Please select at least one project from 'Documents to Measure' and one relevant item rom 'Other Relevant Documents' before proceeding!"; | |
| ShowPopUp(); | |
| return; | |
| } | |
| else if (!isChecked){ | |
| PopupElement.textContent = "Please select at least one project from 'Documents to Measure' before proceeding!"; | |
| ShowPopUp(); | |
| return; | |
| } | |
| else if (!isRelvClicked){ | |
| document.getElementById('relvselectid').style.boxShadow='0 0 8px 2px rgb(255, 0, 0)'; | |
| PopupElement.textContent = "Please select at least one relevant item from 'Other Relevant Documents' before proceeding!"; | |
| ShowPopUp(); | |
| return; | |
| } | |
| } else { | |
| // If section is not '2.8', only measureCheckbox is required | |
| if (!isChecked) { | |
| PopupElement.textContent = "Please select at least one project before proceeding from 'Documents to Measure' section!"; | |
| ShowPopUp(); | |
| return; | |
| } | |
| } | |
| // If validation passes, proceed with form submission | |
| getData(e.target); | |
| }); | |
| //////////////////////////////////////////// | |
| var measitemVal=''; | |
| function get3rddropdown(){ | |
| console.log('ayhagaaaaaaaaaaaaaaaaa') | |
| // selections=measitem.value.toString() //3rd dpdwn value | |
| var unit; | |
| if (addciconval>0){ | |
| for (let i =1 ; i <=addciconval ; i++){ | |
| var inputs1 = document.getElementsByClassName("measurementselections"+i)[0]; //1sr dpdwn | |
| var selections1 = document.getElementsByClassName("selections"+i)[0]; //2nd dropdown | |
| var measitem1 = document.getElementsByClassName("measureitems"+i)[0]; //3rd dpdwn | |
| measitemVal1=measitem1.value.toString() //3rd dpdwn value | |
| if(( (inputs1.value=='ground beams' ) || (inputs1.value=='pile caps' ) ) & (!selections1.value))//& (selections.value.startsWith('Pile') || !selections.value )) || (inputs.children[0].value=='pile caps' & (selections.value.startsWith('Ground') || !selections.value ))) | |
| { //1.0 | |
| selections1.innerHTML=''; | |
| for (let m=0;m<MCTNames.length;m++) | |
| { | |
| var opt0 = document.createElement("OPTION") ; | |
| opt0.text= MCTNames[m][0]; | |
| opt0.textContent= MCTNames[m][0]; | |
| opt0.value= MCTNames[m][0]; | |
| selections1.add(opt0); | |
| } | |
| console.log(section.value.toString()) | |
| } | |
| else if(( (inputs1.value=='Wall' ) || (inputs1.value=='Column' ) ) & (!selections1.value))//& (selections.value.startsWith('Pile') || !selections.value )) || (inputs.children[0].value=='pile caps' & (selections.value.startsWith('Ground') || !selections.value ))) | |
| { //1.0 | |
| selections1.innerHTML=''; | |
| for (let m=0;m<MCTNames.length;m++) | |
| { | |
| var opt0 = document.createElement("OPTION") ; | |
| opt0.text= MCTNames[m][0]; | |
| opt0.textContent= MCTNames[m][0]; | |
| opt0.value= MCTNames[m][0]; | |
| selections1.add(opt0); | |
| } | |
| console.log(section.value.toString()) | |
| } | |
| else if(( (inputs1.value=='Floor' ) || (inputs1.value=='Wall' ) ) & (!selections1.value))//& (selections.value.startsWith('Pile') || !selections.value )) || (inputs.children[0].value=='pile caps' & (selections.value.startsWith('Ground') || !selections.value ))) | |
| { //3.2 | |
| selections1.innerHTML=''; | |
| for (let m=0;m<MCTNames.length;m++) | |
| { | |
| var opt0 = document.createElement("OPTION") ; | |
| opt0.text= MCTNames[m][0]; | |
| opt0.textContent= MCTNames[m][0]; | |
| opt0.value= MCTNames[m][0]; | |
| selections1.add(opt0); | |
| } | |
| console.log(section.value.toString()) | |
| } | |
| else if(( (inputs1.value=='Ceiling' ) ) & (!selections1.value))//& (selections.value.startsWith('Pile') || !selections.value )) || (inputs.children[0].value=='pile caps' & (selections.value.startsWith('Ground') || !selections.value ))) | |
| { //3.3 | |
| selections1.innerHTML=''; | |
| for (let m=0;m<MCTNames.length;m++) | |
| { | |
| var opt0 = document.createElement("OPTION") ; | |
| opt0.text= MCTNames[m][0]; | |
| opt0.textContent= MCTNames[m][0]; | |
| opt0.value= MCTNames[m][0]; | |
| selections1.add(opt0); | |
| } | |
| console.log(section.value.toString()) | |
| } | |
| else if(( (inputs1.value=='Internal Walls' ) ) & (!selections1.value))//& (selections.value.startsWith('Pile') || !selections.value )) || (inputs.children[0].value=='pile caps' & (selections.value.startsWith('Ground') || !selections.value ))) | |
| { //3.3 | |
| selections1.innerHTML=''; | |
| for (let m=0;m<MCTNames.length;m++) | |
| { | |
| var opt0 = document.createElement("OPTION") ; | |
| opt0.text= MCTNames[m][0]; | |
| opt0.textContent= MCTNames[m][0]; | |
| opt0.value= MCTNames[m][0]; | |
| selections1.add(opt0); | |
| } | |
| console.log(section.value.toString()) | |
| } | |
| // if (inputs1.value.startsWith('Floor') & (selections1.value.startsWith('Wall') || !selections1.value )){ | |
| // selections1.innerHTML=''; | |
| // var opt2 = document.createElement("OPTION") ; | |
| // opt2.text= 'Floor:m2'; | |
| // opt2.value= 'Floor:m2'; | |
| // opt2.id='floorA' ; | |
| // selections1.add(opt2); | |
| // } | |
| // if (inputs1.value.startsWith('Wall') & (selections1.value.startsWith('Floor') || !selections1.value ) ){ | |
| // selections1.innerHTML=''; | |
| // var opt3 = document.createElement("OPTION") ; | |
| // opt3.text= 'Wall:m'; | |
| // opt3.value= 'Wall:m'; | |
| // opt3.id='WallP'; | |
| // selections1.add(opt3); | |
| // } | |
| // measitem1.innerHTML=''; | |
| // var ii, L = measitem1.options.length - 1; | |
| // for(ii = L; ii >= 0; ii--) { | |
| // if (measitem1.options[ii].value=='Area') | |
| // measitem1.remove(ii); | |
| // } | |
| // }); | |
| if (selections1.value ) | |
| { | |
| for(var l in MCTNames){ | |
| if(MCTNames[l][0] == selections1.value){ | |
| // Add an element to the dictionary | |
| unit=MCTNames[l][1] | |
| break; // If you want to break out of the loop once you've found a match | |
| } | |
| } | |
| if (unit=='m2' ) | |
| { measitem1.innerHTML=''; | |
| var opt10 = document.createElement("OPTION") ; | |
| opt10.text= 'Area:m2'; | |
| opt10.value= 'Area:m2'; | |
| opt10.id='Area:m2'; | |
| measitem1.add(opt10); | |
| } | |
| if (unit=='m' & !(measitem1.value=='Perimeter:m')) | |
| { measitem1.innerHTML=''; | |
| var opt11 = document.createElement("OPTION") ; | |
| opt11.text= 'Length:m'; | |
| opt11.value= 'Length:m'; | |
| opt11.id='Length:m'; | |
| measitem1.add(opt11); | |
| var opt12 = document.createElement("OPTION") ; | |
| opt12.text= 'Perimeter:m'; | |
| opt12.value= 'Perimeter:m'; | |
| opt12.id='Perimeter:m'; | |
| measitem1.add(opt12); | |
| } | |
| if (unit=='nr') | |
| { measitem1.innerHTML=''; | |
| var opt13 = document.createElement("OPTION") ; | |
| opt13.text= 'Count:Nr'; | |
| opt13.value= 'Count:Nr'; | |
| opt13.id='Count:Nr'; | |
| measitem1.add(opt13); | |
| } | |
| } | |
| } | |
| } | |
| // $(inputs).on("change", function (e) { | |
| if(( (inputs.value=='ground beams' ) || (inputs.value=='pile caps' ) ) & (!selections.value))//& (selections.value.startsWith('Pile') || !selections.value )) || (inputs.children[0].value=='pile caps' & (selections.value.startsWith('Ground') || !selections.value ))) | |
| { | |
| selections.innerHTML=''; | |
| for (let m=0;m<MCTNames.length;m++) | |
| { | |
| var opt0 = document.createElement("OPTION") ; | |
| opt0.text= MCTNames[m][0]; | |
| opt0.textContent= MCTNames[m][0]; | |
| opt0.value= MCTNames[m][0]; | |
| selections.add(opt0); | |
| } | |
| } | |
| if(( (inputs.value=='Wall' ) || (inputs.value=='Column' ) ) & (!selections.value))//& (selections.value.startsWith('Pile') || !selections.value )) || (inputs.children[0].value=='pile caps' & (selections.value.startsWith('Ground') || !selections.value ))) | |
| { | |
| selections.innerHTML=''; | |
| for (let m=0;m<MCTNames.length;m++) | |
| { | |
| var opt0 = document.createElement("OPTION") ; | |
| opt0.text= MCTNames[m][0]; | |
| opt0.textContent= MCTNames[m][0]; | |
| opt0.value= MCTNames[m][0]; | |
| selections.add(opt0); | |
| } | |
| } | |
| else if(( (inputs.value=='Floor' ) || (inputs.value=='Wall' ) ) & (!selections.value))//& (selections.value.startsWith('Pile') || !selections.value )) || (inputs.children[0].value=='pile caps' & (selections.value.startsWith('Ground') || !selections.value ))) | |
| { | |
| selections.innerHTML=''; | |
| for (let m=0;m<MCTNames.length;m++) | |
| { | |
| var opt0 = document.createElement("OPTION") ; | |
| opt0.text= MCTNames[m][0]; | |
| opt0.textContent= MCTNames[m][0]; | |
| opt0.value= MCTNames[m][0]; | |
| selections.add(opt0); | |
| } | |
| } | |
| else if(( (inputs.value=='Ceiling' ) ) & (!selections.value))//& (selections.value.startsWith('Pile') || !selections.value )) || (inputs.children[0].value=='pile caps' & (selections.value.startsWith('Ground') || !selections.value ))) | |
| { | |
| selections.innerHTML=''; | |
| for (let m=0;m<MCTNames.length;m++) | |
| { | |
| var opt0 = document.createElement("OPTION") ; | |
| opt0.text= MCTNames[m][0]; | |
| opt0.textContent= MCTNames[m][0]; | |
| opt0.value= MCTNames[m][0]; | |
| selections.add(opt0); | |
| } | |
| } | |
| // if (inputs.value=='Floor' & (selections.value.startsWith('Wall') || !selections.value )){ | |
| // selections.innerHTML=''; | |
| // var optn = document.createElement("OPTION") ; | |
| // optn.text= 'Floor:m2'; | |
| // optn.value= 'Floor:m2'; | |
| // optn.id='floorA' ; | |
| // selections.add(optn); | |
| // } | |
| // if (inputs.value=='Wall' & (selections.value.startsWith('Floor') || !selections.value ) ){ | |
| // selections.innerHTML=''; | |
| // var opt = document.createElement("OPTION") ; | |
| // opt.text= 'Wall:m'; | |
| // opt.value= 'Wall:m'; | |
| // opt.id='WallP'; | |
| // selections.add(opt); | |
| // } | |
| // }) | |
| console.log(selections.value) | |
| if (selections.value) | |
| { | |
| for(var l in MCTNames){ | |
| if(MCTNames[l][0] == selections.value){ | |
| // Add an element to the dictionary | |
| unit=MCTNames[l][1] | |
| break; // If you want to break out of the loop once you've found a match | |
| } | |
| } | |
| if (unit=='m2' ) | |
| { measitem.innerHTML=''; | |
| var opt10 = document.createElement("OPTION") ; | |
| opt10.text= 'Area:m2'; | |
| opt10.value= 'Area:m2'; | |
| opt10.id='Area:m2'; | |
| measitem.add(opt10); | |
| } | |
| if (unit=='m' & !(measitem.value=='Perimeter:m')) | |
| { | |
| measitem.innerHTML=''; | |
| var opt11 = document.createElement("OPTION") ; | |
| opt11.text= 'Length:m'; | |
| opt11.value= 'Length:m'; | |
| opt11.id='Length:m'; | |
| measitem.add(opt11); | |
| var opt12 = document.createElement("OPTION") ; | |
| opt12.text= 'Perimeter:m'; | |
| opt12.value= 'Perimeter:m'; | |
| opt12.id='Perimeter:m'; | |
| measitem.add(opt12); | |
| } | |
| if (unit=='nr' ) | |
| { measitem.innerHTML=''; | |
| var opt13 = document.createElement("OPTION") ; | |
| opt13.text= 'Count:Nr'; | |
| opt13.value= 'Count:Nr'; | |
| opt13.id='Count:Nr'; | |
| measitem.add(opt13); | |
| } | |
| } | |
| } | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| var repeatforloopI=0; | |
| var repeatforloopIextra=0; | |
| function getmctName(){ | |
| var listofnames=[]; | |
| var flag=0; | |
| arrallvalues=[]; | |
| arrmctNames=[]; | |
| arrFinalMCNames=[]; | |
| var allmcnamestext= document.querySelectorAll('input[name="text1name"]'); | |
| allmcnamestext.forEach(function(elem){ | |
| if (elem.value) | |
| arrallvalues.push(elem.value); | |
| }) | |
| for (ii=0 ; ii<=addciconval; ii++){ | |
| if (ii==0){ | |
| //first one -- not duplicated yet --first row onlyy | |
| var divduplicater= document.getElementsByClassName('duplicaterclass')[0].children; | |
| var selections = divduplicater[3];//ex: Gb:m | |
| measitemVal=divduplicater[5].value; // ex:area | |
| var div=divduplicater[8].children;// first repeatforloopclass | |
| var divValues=['text1'+div[0].value, div[1].value , div[2].value]; | |
| mctname=[selections.value ,divValues , measitemVal ]; | |
| ////////////////////////////////////////// | |
| count=0; | |
| var ii0selections=''; | |
| for (let child =1;child <divduplicater.length;child++) | |
| { | |
| console.log('here3') | |
| if( divduplicater[child] instanceof(HTMLDivElement) ) | |
| count++; | |
| console.log(divduplicater) | |
| ii0selections=divduplicater[3].value; | |
| measitemVal=divduplicater[5].value; | |
| console.log('gfd ',ii0selections,measitemVal) | |
| if (divduplicater[child].className.startsWith('repeatforloopclass') && child !=5) | |
| { | |
| console.log('c',divduplicater[child].children) | |
| var divValues2=['text1'+divduplicater[child].children[0].value, divduplicater[child].children[1].value , divduplicater[child].children[2].value]; | |
| mctname1=[ii0selections ,divValues2 , measitemVal]; | |
| console.log('divValues2',mctname1) | |
| if(divduplicater[child].children[0].value && divduplicater[child].children[1].value && divduplicater[child].children[2].value) | |
| { | |
| // console.log(mctname1); | |
| flag=1; | |
| arrmctNames.push(mctname1); | |
| } | |
| else if(divduplicater[child].children[0].value && !divduplicater[child].children[1].value && !divduplicater[child].children[2].value) { | |
| mctname1=[ii0selections ,[ 'text1'+divduplicater[child].children[0].value ], measitemVal ]; | |
| flag=1; | |
| arrmctNames.push( mctname1); | |
| } | |
| else if(divduplicater[child].children[0].value && divduplicater[child].children[1].value && !divduplicater[child].children[2].value) { | |
| mctname1=[ii0selections ,['text1'+divduplicater[child].children[0].value , divduplicater[child].children[1].value] , measitemVal]; | |
| flag=1; | |
| arrmctNames.push( mctname1); | |
| } | |
| } | |
| } | |
| } | |
| // else if (ii>0){ | |
| // var divduplicater= document.getElementsByClassName('duplicaterclass'+ii)[0].children; | |
| // console.log(divduplicater) | |
| // selections = divduplicater[3];//document.getElementsByClassName("selections")[0]; | |
| // measitemVal=divduplicater[5].value; | |
| // div=divduplicater[8].children; | |
| // var divValues=['text1'+div[0].value, div[1].value , div[2].value]; | |
| // mctname=[selections.value ,divValues , measitemVal ]; | |
| // if(div[0].value && div[1].value && div[2].value) | |
| // { | |
| // flag=1; | |
| // arrmctNames.push( mctname); | |
| // } | |
| // else if (div[0].value && !div[1].value && !div[2].value) { | |
| // mctname=[selections.value ,['text1'+div[0].value ], measitemVal ]; | |
| // flag=1; | |
| // arrmctNames.push( mctname); | |
| // } | |
| // else if (div[0].value && div[1].value && !div[2].value) { | |
| // mctname=[selections.value ,['text1'+div[0].value, div[1].value ] , measitemVal ]; | |
| // flag=1; | |
| // arrmctNames.push( mctname); | |
| // } | |
| // } | |
| if (ii>0 )//&& addciconval >0 && jj>0) | |
| { | |
| count=0; | |
| var ii0selections=''; | |
| var replicatedDivChildren=document.getElementsByClassName('duplicaterclass'+ii)[0].children; | |
| for (let o =0;o <=replicatedDivChildren.length;o++) | |
| { | |
| if( replicatedDivChildren[o] instanceof(HTMLDivElement) ) | |
| { count++; | |
| ii0selections=replicatedDivChildren[3].value; | |
| measitemVal=replicatedDivChildren[5].value; | |
| console.log('lkjhgf',replicatedDivChildren) | |
| } | |
| } | |
| for (child=0;child<replicatedDivChildren.length;child++) | |
| { | |
| if (replicatedDivChildren[child].className.startsWith('repeatforloopclass') && child !=5) | |
| { | |
| var divValues2=['text1'+replicatedDivChildren[child].children[0].value, replicatedDivChildren[child].children[1].value , replicatedDivChildren[child].children[2].value]; | |
| mctname1=[ii0selections ,divValues2 , measitemVal]; | |
| if(replicatedDivChildren[child].children[0].value && replicatedDivChildren[child].children[1].value && replicatedDivChildren[child].children[2].value) | |
| { | |
| arrmctNames.push(mctname1); | |
| flag=1; | |
| } | |
| else if(replicatedDivChildren[child].children[0].value && !replicatedDivChildren[child].children[1].value && !replicatedDivChildren[child].children[2].value) | |
| { | |
| mctname1=[ii0selections ,['text1'+replicatedDivChildren[child].children[0].value] , measitemVal]; | |
| arrmctNames.push(mctname1); | |
| flag=1; | |
| } | |
| else if(replicatedDivChildren[child].children[0].value && replicatedDivChildren[child].children[1].value && !replicatedDivChildren[child].children[2].value) | |
| { | |
| mctname1=[ii0selections ,['text1'+replicatedDivChildren[child].children[0].value, replicatedDivChildren[child].children[1].value] , measitemVal]; | |
| arrmctNames.push(mctname1); | |
| flag=1; | |
| } | |
| } | |
| } | |
| } | |
| arrFinalMCNames= arrmctNames.slice(); | |
| if(arrmctNames.length >1){ | |
| var name=[]; | |
| allnames=[]; | |
| arrFinalMCNames = arrmctNames.slice(); | |
| var newarr=[]; | |
| for (let i=0;i<arrmctNames.length; i++) | |
| { str=''; | |
| newarr=[]; | |
| for (let j=i+1; j<arrmctNames.length; j++) | |
| { | |
| if (arrmctNames[i][0] == arrmctNames[j][0] && arrmctNames[i][2] == arrmctNames[j][2] &&arrmctNames[i][1][1] == arrmctNames[j][1][1] && arrmctNames[i][1][2] == arrmctNames[j][1][2]) | |
| { var selectionsname=arrmctNames[i][0] ; | |
| measitemVal=arrmctNames[i][2]; | |
| flag=1; | |
| console.log('foorrr',arrmctNames[i][0],arrmctNames[i]); | |
| if (allnames.includes(arrmctNames[i][1][0]) ) | |
| { | |
| var index = allnames.indexOf(allnames[i] ); | |
| if (index !== -1) { | |
| allnames.splice(index, 1); | |
| } | |
| } | |
| if (!name.includes(arrmctNames[i][1][0] ) ){ | |
| // console.log('msh mwgod'); | |
| name.push(arrmctNames[i][1][0]); | |
| newarr.push(arrmctNames[i][1][0]); | |
| var index = arrFinalMCNames.indexOf(arrmctNames[i] ); | |
| if (index !== -1) { | |
| arrFinalMCNames.splice(index, 1); | |
| } | |
| } | |
| if (!name.includes(arrmctNames[j][1][0] ) ){ | |
| // console.log('msh mwgodj') | |
| name.push(arrmctNames[j][1][0]); | |
| newarr.push(arrmctNames[j][1][0]); | |
| var index1 = arrFinalMCNames.indexOf(arrmctNames[j] ); | |
| if (index1 !== -1) { | |
| arrFinalMCNames.splice(index1, 1); | |
| } | |
| } | |
| if (!name.includes(arrmctNames[i][1][1] ) ||!name.includes(arrmctNames[i][1][2] ) ){ | |
| name.push( arrmctNames[i][1][1] , arrmctNames[i][1][2] ); | |
| newarr.push(arrmctNames[i][1][1] , arrmctNames[i][1][2] ); | |
| } | |
| } | |
| } | |
| if (newarr.length >0){ | |
| flag=1; | |
| arrFinalMCNames.push([selectionsname , newarr, measitemVal ]); | |
| } | |
| } | |
| } | |
| arrFinalMCNames.push([spreadsheetId , pdfpath[2]]); | |
| console.log(arrFinalMCNames) | |
| } | |
| if (flag==1){ | |
| $.get( '/mctnametoGoogleSheet/'+ JSON.stringify(arrFinalMCNames)) | |
| .success( function(data) { | |
| console.log('dataaaaa',data) | |
| spreadsheetURL=spreadsheetURL+ '/edit#gid='+data[0].toString() | |
| console.log('spreadsheetURL',spreadsheetURL) | |
| document.getElementById('all').style.display='none'; | |
| window.open(spreadsheetURL.toString()) //sheetid | |
| }) | |
| .error(function(jqXHR, textStatus, errorThrown) { | |
| PopupElement.textContent='Error occured while exporting the summary. Check your connection, refresh and try again. If the error continues, please contact the ADR team to fix it. '; | |
| ShowPopUp(); | |
| }); | |
| } | |
| } | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| function addmctnameicon(){ | |
| // guessednamesDropdown() | |
| repeatforloopI+=1 | |
| var dupDiv; | |
| if (clonedDivId==0){ | |
| var dupDiv=document.getElementById('duplicater'); //pass kol div hna | |
| } | |
| else{ | |
| var dupDiv=document.getElementById(clonedDivId); //pass kol div hna //akher div et3mlt | |
| } | |
| var div=document.getElementById('repeatforloophidden') | |
| var clone = div.cloneNode(true); // "deep" clone | |
| jj++; | |
| if (clonedDivId==0) | |
| clone.style.marginLeft='5px'; | |
| else | |
| clone.style.marginLeft='5px'; | |
| window.onclick = elem => { | |
| if (elem.target.tagName.startsWith('LORD-ICON') && elem.target.id.startsWith('addmctnameid')){ | |
| clone.id = 'repeatforloop'+ elem.target.parentElement.parentElement.childNodes[1].value[0] + ++elem.target.parentElement.parentElement.childNodes[1].value[1]; | |
| clone.setAttribute('class','repeatforloopclass'+elem.target.parentElement.parentElement.childNodes[1].value[0] + elem.target.parentElement.parentElement.childNodes[1].value[1]); | |
| clone.setAttribute('name','repeatforloopname'+elem.target.parentElement.parentElement.childNodes[1].value[0] + elem.target.parentElement.parentElement.childNodes[1].value[1]); | |
| clone.childNodes[11].id='addmctnameid'+elem.target.parentElement.parentElement.childNodes[1].value[0] + elem.target.parentElement.parentElement.childNodes[1].value[1]; | |
| clone.childNodes[15].id='deletemctnameid'+elem.target.parentElement.parentElement.childNodes[1].value[0] + elem.target.parentElement.parentElement.childNodes[1].value[1]; | |
| if (elem.target.parentElement.nextElementSibling) | |
| { | |
| $("#"+elem.target.parentElement.parentElement.id).append(clone); | |
| } | |
| else | |
| { | |
| $("#"+elem.target.parentElement.parentElement.id).append(clone); | |
| $("#"+elem.target.parentElement.id).insertBefore(clone,document.getElementById('doneebackground')); | |
| } | |
| if (thirddropdown.value.startsWith('3.2') || thirddropdown.value.startsWith('3.3')) | |
| { | |
| document.getElementById( 'repeatforloop'+ elem.target.parentElement.parentElement.childNodes[1].value[0] +elem.target.parentElement.parentElement.childNodes[1].value[1]).children[1].setAttribute('disabled','True') | |
| document.getElementById( 'repeatforloop'+ elem.target.parentElement.parentElement.childNodes[1].value[0] +elem.target.parentElement.parentElement.childNodes[1].value[1]).children[2].setAttribute('disabled','True') | |
| document.getElementById( 'repeatforloop'+ elem.target.parentElement.parentElement.childNodes[1].value[0] +elem.target.parentElement.parentElement.childNodes[1].value[1]).children[1].style.cursor='not-allowed'; | |
| document.getElementById( 'repeatforloop'+ elem.target.parentElement.parentElement.childNodes[1].value[0] +elem.target.parentElement.parentElement.childNodes[1].value[1]).children[2].style.cursor='not-allowed'; | |
| } | |
| } | |
| } | |
| } | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| function deletemctnameicon(){ | |
| window.onclick = elem => { | |
| if (elem.target.tagName.startsWith('LORD-ICON') && elem.target.id.startsWith('deletemctnameid')) | |
| { | |
| var numb = elem.target.parentElement.id.match(/\d/g); | |
| if (numb==null) | |
| numb=''; | |
| else | |
| numb = numb.join(""); | |
| var deletethisdiv= document.getElementById('repeatforloop'+ numb); | |
| deletethisdiv.parentNode.removeChild(deletethisdiv); | |
| } | |
| } | |
| } | |
| function addmctnameiconPopup(){ | |
| // guessednamesDropdown() | |
| repeatforloopIextra+=1 | |
| var dupDivExtra; | |
| if (clonedDivIdExtra==0){ | |
| var dupDivExtra=document.getElementById('duplicaterExtra'); //pass kol div hna | |
| } | |
| else{ | |
| var dupDivExtra=document.getElementById(clonedDivIdExtra); //pass kol div hna //akher div et3mlt | |
| } | |
| var divExtra=document.getElementById('repeatforloopExtrahidden') | |
| var cloneExtra = divExtra.cloneNode(true); // "deep" clone | |
| jjExtra++; | |
| // if (clonedDivIdExtra==0) | |
| // clone.style.marginLeft='5px'; | |
| // else | |
| // clone.style.marginLeft='5px'; | |
| window.onclick = elem => { | |
| if (elem.target.tagName.startsWith('LORD-ICON') && elem.target.id.startsWith('addmctnameidExtra')){ | |
| // console.log('repeatforloopExtraaa', elem.target.parentElement.parentElement.childNodes[1].value ) | |
| cloneExtra.id = 'repeatforloopExtra'+ jjExtra; | |
| cloneExtra.setAttribute('class','repeatforloopclassExtra'+jjExtra); | |
| cloneExtra.setAttribute('name','repeatforloopnameExtra'+jjExtra); | |
| cloneExtra.childNodes[11].id='addmctnameidExtra'+jjExtra; | |
| cloneExtra.childNodes[15].id='deletemctnameidExtra'+jjExtra; | |
| if (elem.target.parentElement.nextElementSibling) | |
| { | |
| $("#"+elem.target.parentElement.parentElement.id).append(cloneExtra); | |
| } | |
| else | |
| { | |
| $("#"+elem.target.parentElement.parentElement.id).append(cloneExtra); | |
| $("#"+elem.target.parentElement.id).insertBefore(cloneExtra,document.getElementById('doneebackground')); | |
| } | |
| } | |
| } | |
| console.log() | |
| if (sectionNumber.startsWith('2.7')) | |
| { | |
| textextra= cloneExtra.children[0] | |
| textextra.style.backgroundColor = "rgba(101, 101, 101, 0.27)"; | |
| textextra.style.cursor='not-allowed'; | |
| textextra.disabled="disabled"; | |
| } | |
| if (sectionNumber.startsWith('2.8')) | |
| { | |
| text2extra= cloneExtra.children[3] | |
| text2extra.style.backgroundColor ="rgba(101, 101, 101, 0.27)"; | |
| text2extra.style.cursor='not-allowed'; | |
| text2extra.disabled="disabled"; | |
| } | |
| } | |
| function deletemctnameiconPopup(){ | |
| window.onclick = elem => { | |
| if (elem.target.tagName.startsWith('LORD-ICON') && elem.target.id.startsWith('deletemctnameidExtra')) | |
| { | |
| var numb = elem.target.parentElement.id.match(/\d/g); | |
| if (numb==null) | |
| numb=''; | |
| else | |
| numb = numb.join(""); | |
| var deletethisdivExtra= document.getElementById('repeatforloopExtra'+ numb); | |
| deletethisdivExtra.parentNode.removeChild(deletethisdivExtra); | |
| } | |
| } | |
| } | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| function colors(){ | |
| var ele = document.getElementsByName('fullimage'); | |
| var levels = document.getElementsByName('levelsnamelabel')[0]; | |
| var levelsin = document.getElementsByName('levelsnameinput')[0]; //number of colors -- color pickers | |
| var drp = document.getElementById("colorpickers"); | |
| for (i = 0; i < ele.length; i++) { | |
| if (ele[i].checked) | |
| if (ele[i].value==220){ | |
| console.log(ele[i].value); | |
| levels.style.visibility='visible'; | |
| levelsin.style.visibility='visible'; | |
| } | |
| else | |
| { | |
| levels.style.visibility='hidden'; | |
| levelsin.style.visibility='hidden'; | |
| drp.innerHTML=''; | |
| } | |
| } | |
| } | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| var canvas = document.querySelector("#myCanvas"); | |
| var ctx = canvas.getContext("2d"); | |
| var drp; | |
| var color = 'rgb(47,255,255)'; | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| function change(e){ | |
| color = this.value; | |
| allcolors.push( color); | |
| } | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| let hex2rgb= c=> `rgb(${c.match(/\w\w/g).map(x=>+`0x${x}`)})`; | |
| myCanvas.addEventListener("click", e => { | |
| var offset = canvas.getBoundingClientRect(); | |
| var x = e.clientX - offset.left; | |
| var y = e.clientY - offset.top; | |
| //a new point is pushed on the last array of ry | |
| ry[ry.length - 1].push({ x: x, y: y, color:hex2rgb(color) }); | |
| drawChart(); | |
| }); | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| // function guessednamesDropdown(){ | |
| // // | |
| // $.get('/getguessednamepath/') | |
| // .success(function(arrayofvalues) { | |
| // console.log('arrayofvalues',arrayofvalues) | |
| // var text1name= document.getElementsByName('text1name') | |
| // // Loop through each dropdown | |
| // text1name.forEach((dropdown, index) => { | |
| // // Clear existing options | |
| // dropdown.innerHTML = ''; | |
| // // Populate with arrayofvalues | |
| // arrayofvalues.forEach(value => { | |
| // let option = document.createElement('option'); | |
| // option.value = value; | |
| // option.text = value; | |
| // dropdown.appendChild(option); | |
| // }); | |
| // }); | |
| // }) | |
| // .error(function(jqXHR, textStatus, errorThrown) { | |
| // PopupElement.textContent='Error occured while retrieving the Legend Guessed Names. Refresh and try again. If the error continues, please contact the ADR team to fix it. '; | |
| // ShowPopUp(); | |
| // }); | |
| // } | |
| function drawChart() { | |
| ctx.lineWidth = 5; | |
| // for every array in the ry array | |
| for (let index = 0; index < ry.length; index++) { | |
| // for every point in the ry[index] | |
| for (let i = 0; i < ry[index].length; i++) { | |
| firstcircle=[] | |
| let l = ry[index][i]; | |
| // draw the circle | |
| if (i==0){ | |
| drawCircle(l.x, l.y); | |
| firstcircle=[l.x,l.y] | |
| } | |
| // draw the line | |
| if (i > 0) { | |
| let last = ry[index][i - 1]; | |
| ctx.beginPath(); | |
| ctx.moveTo(last.x, last.y); | |
| ctx.lineTo(l.x, l.y); | |
| ctx.strokeStyle = l.color; | |
| ctx.stroke(); | |
| } | |
| } | |
| } | |
| } | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| function drawCircle(x, y) { | |
| ctx.beginPath(); | |
| ctx.arc(x, y,1, 0, Math.PI *2); | |
| ctx.strokeStyle = 'rgb(47,255,255)'; | |
| ctx.stroke(); | |
| } | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| /*If the plan contains levels, open canvas window*/ | |
| /*Set canvas code to be visible on the new window with the pdftoimg as the background*/ | |
| var levelsin = document.getElementById('levelcheckbox'); | |
| var canvaswindow= document.getElementById('canvaswindow'); | |
| var undoButtonId=document.getElementById('undoButtonId'); | |
| NewShapeButtonId=document.getElementById('NewShapeButtonId'); | |
| var savecanvas=document.getElementById('savecanvas'); | |
| levelsin.addEventListener('click',function(){ | |
| if (document.getElementsByClassName("selectionsProjs")[0].value.startsWith('1.0')) | |
| { | |
| document.getElementById("all").style.display = "block"; | |
| if( document.getElementById('levelcheckbox').checked) | |
| { | |
| $.get( '/canvaspdftoimgBackground/'+pdfname) | |
| .success (function(data){ | |
| document.getElementById("all").style.display = "none"; | |
| var popup = window.open(''); | |
| console.log(popup) | |
| popup.document.write('<html><head><title>ADR Console:Draw on PDF tool</title><link rel="stylesheet" href="static/style.css"></head><body>'); | |
| var element = popup.document.createElement('div'); | |
| element.setAttribute('id', 'mydiv'); | |
| canvaswindow.childNodes[1].height=data[1]; //canvas -->child 3 | |
| canvaswindow.childNodes[1].width=data[2]; | |
| canvaswindow.childNodes[1].style.width= 0.5*screen.width +'px' | |
| HeightStyleratio= canvaswindow.childNodes[1].height * 0.5*screen.width / canvaswindow.childNodes[1].width ; | |
| canvaswindow.childNodes[1].style.height= HeightStyleratio.toString() + 'px'; | |
| element.append(canvaswindow); | |
| console.log(canvaswindow.childNodes) | |
| canvaswindow.removeAttribute('hidden'); | |
| var imgDrawon =document.createElement("img"); | |
| imgDrawon.src = 'data:image/gif;base64,' +data[0]; | |
| console.log('srcc'+imgDrawon.src) | |
| imgDrawon.width=data[2]; | |
| imgDrawon.style.width='700px'; | |
| imgDrawon.id='imgcanvas'; | |
| imgDrawon.alt="Larry"; | |
| imgDrawon.onload = function(){ | |
| ctx.drawImage(imgDrawon,0,0); | |
| var scale = data[2] / canvaswindow.childNodes[1].style.width.slice(0,-2) ; // get the scale that matches display size | |
| ctx.setTransform(scale,0,0,scale,0,0); | |
| } | |
| undoButtonId.addEventListener("click", e => { | |
| //when undoButtonId is clicked the last point from the last array is deleted | |
| if (ry[ry.length - 1].length > 0) | |
| { | |
| ry[ry.length - 1].pop(); | |
| } | |
| else { | |
| //if the last array is empty I delete this array | |
| ry.pop(); | |
| //and then I delete the last point from the last array | |
| ry[ry.length - 1].pop(); | |
| } | |
| // delete everything | |
| ctx.clearRect(0,0, canvas.width, canvas.height); | |
| //redraw background to draw lines over again | |
| ctx.drawImage(imgDrawon,0,0,canvaswindow.childNodes[1].style.width.slice(0, -2),canvaswindow.childNodes[1].style.height.slice(0, -2)); | |
| drawChart(); | |
| }); | |
| var win = popup.document.body; | |
| win.appendChild(element); | |
| var drp=popup.document.body.childNodes[0].childNodes[0].childNodes[9];//color picker div | |
| NewShapeButtonId.addEventListener('click',function(){ | |
| ry.push([]); | |
| }); | |
| drp.childNodes[1].addEventListener('click',function(){ //color picker | |
| drp.childNodes[1].onchange=change; | |
| }) | |
| }) | |
| .error(function(jqXHR, textStatus, errorThrown) { | |
| PopupElement.textContent='Levels are not supported in this Section. '; | |
| ShowPopUp(); | |
| document.getElementById('levelcheckbox').checked=false; | |
| }); | |
| savecanvas.addEventListener('click',function(){ | |
| var image = new Image(); | |
| image.id = "pic"; | |
| image.src = canvas.toDataURL("image/png"); | |
| canvasimg=image.src; | |
| }) | |
| } | |
| } | |
| else{ | |
| PopupElement.textContent='Levels are not supported in this Section. '; | |
| ShowPopUp(); | |
| document.getElementById('levelcheckbox').checked=false; | |
| } | |
| }) | |
| //___________________________________________________________________________________________________________ | |
| function getSecondData(){ | |
| document.getElementById('all').style.display='block'; | |
| getmctName() | |
| } | |
| //___________________________________________________________________________________________________________ | |
| var section = document.getElementsByClassName("selectionsProjs")[0] | |
| var inputs= document.getElementById('measurementselectionsid'); | |
| var selections= document.getElementById('selectionsid'); | |
| var measitem= document.getElementById('measureitemsid'); | |
| function chooseFirstdrpdwn() | |
| { | |
| inputs.innerHTML=''; | |
| selections.innerHTML=''; | |
| measitem.innerHTML=''; | |
| if (section.value.startsWith('1.0')) | |
| { | |
| var opt = document.createElement("OPTION"); | |
| opt.text= 'Select'; | |
| opt.value= ""; | |
| opt.hidden=true; | |
| inputs.add(opt); | |
| var optn = document.createElement("OPTION"); | |
| optn.text= 'Ground Beams'; | |
| optn.value= "ground beams"; | |
| inputs.add(optn); | |
| var optn1 = document.createElement("OPTION"); | |
| optn1.text= 'Pile Caps'; | |
| optn1.value= "pile caps"; | |
| inputs.add(optn1); | |
| } | |
| if (section.value.startsWith('3.2')) | |
| { | |
| var opt = document.createElement("OPTION"); | |
| opt.text= 'Select'; | |
| opt.value= ""; | |
| opt.hidden=true; | |
| inputs.add(opt); | |
| var optn = document.createElement("OPTION"); | |
| optn.text= 'Floor'; | |
| optn.value= "Floor"; | |
| inputs.add(optn); | |
| var optn1 = document.createElement("OPTION"); | |
| optn1.text= 'Wall'; | |
| optn1.value= "Wall"; | |
| inputs.add(optn1); | |
| var optn2 = document.createElement("OPTION"); | |
| optn2.text= 'Internal Doors'; | |
| optn2.value= "Internal Doors"; | |
| inputs.add(optn2); | |
| } | |
| if (section.value.startsWith('3.3')) | |
| { | |
| var opt = document.createElement("OPTION"); | |
| opt.text= 'Select'; | |
| opt.value= ""; | |
| opt.hidden=true; | |
| inputs.add(opt); | |
| var optn = document.createElement("OPTION"); | |
| optn.text= 'Ceiling'; | |
| optn.value= "Ceiling"; | |
| inputs.add(optn); | |
| } | |
| if (section.value.startsWith('2.7')) | |
| { | |
| var opt = document.createElement("OPTION"); | |
| opt.text= 'Select'; | |
| opt.value= ""; | |
| opt.hidden=true; | |
| inputs.add(opt); | |
| var optn = document.createElement("OPTION"); | |
| optn.text= 'Internal Walls'; | |
| optn.value= "Internal Walls"; | |
| inputs.add(optn); | |
| } | |
| if (section.value.startsWith('2.8')) | |
| { | |
| var opt = document.createElement("OPTION"); | |
| opt.text= 'Select'; | |
| opt.value= ""; | |
| opt.hidden=true; | |
| inputs.add(opt); | |
| var optn = document.createElement("OPTION"); | |
| optn.text= 'Single Door'; | |
| optn.value= "Single Door"; | |
| inputs.add(optn); | |
| var optn1 = document.createElement("OPTION"); | |
| optn1.text= 'Double Door'; | |
| optn1.value= "Double Door"; | |
| inputs.add(optn1); | |
| } | |
| if (section.value.startsWith('2.1')) | |
| { | |
| var opt = document.createElement("OPTION"); | |
| opt.text= 'Select'; | |
| opt.value= ""; | |
| opt.hidden=true; | |
| inputs.add(opt); | |
| var optn = document.createElement("OPTION"); | |
| optn.text= 'Column'; | |
| optn.value= "Column"; | |
| inputs.add(optn); | |
| var optn1 = document.createElement("OPTION"); | |
| optn1.text= 'Wall'; | |
| optn1.value= "Wall"; | |
| inputs.add(optn1); | |
| } | |
| $(inputs).select2({ | |
| placeholder:'Select', | |
| closeOnSelect: true, | |
| width:'15ch' | |
| }); | |
| $(selections).select2({ | |
| placeholder:'Select MC-T Name', | |
| closeOnSelect: true, | |
| width:'23ch' | |
| }); | |
| $(measitem).select2({ | |
| placeholder:'Select unit', | |
| closeOnSelect: true, | |
| width:'11ch' | |
| }); | |
| } | |
| $(inputs).on("change", function (e) { | |
| get3rddropdown(); | |
| }) | |
| $(selections).on("change", function (e) { | |
| get3rddropdown(); | |
| }) | |
| $(inputs).css('width', '50px'); | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| function summary_to_XML(){ | |
| console.log(pdfpath) | |
| $.get('/summarytoXML/'+JSON.stringify([pdfpath,tomeasureproj])) | |
| .success(function(xmllink){ | |
| console.log(xmllink) | |
| window.open(xmllink) | |
| }) | |
| .error(function(jqXHR, textStatus, errorThrown) { | |
| PopupElement.textContent='Error occured while exporting summary to XML. Refresh and try again. If the error continues, please contact the ADR team to fix it. '; | |
| ShowPopUp(); | |
| }); | |
| } | |
| var closeButtons = document.querySelectorAll(".closeModal"); | |
| var allCloseDivs = document.getElementsByName("tobeclosed"); | |
| closeButtons.forEach(function(button) { | |
| button.addEventListener("click", function() { | |
| allCloseDivs.forEach(function(div) { | |
| div.style.display = "none"; | |
| }); | |
| }); | |
| }); | |
| //___________________________________________________________________________________________________________ | |
| //___________________________________________________________________________________________________________ | |
| /* POP-UP code JS*/ | |
| // Select modal | |
| var mpopup = document.getElementById('mpopupBox'); | |
| // Select close action element | |
| // var close = document.getElementsByClassName("closeModal")[0]; | |
| function ShowPopUp(){ | |
| // Open modal | |
| mpopup.style.display = "block"; | |
| } | |
| // Close modal once close element is clicked | |
| // close.onclick = function() { | |
| // mpopup.style.display = "none"; | |
| // }; | |
| // Close modal when user clicks outside of the modal box | |
| window.onclick = function(event) { | |
| if (event.target == mpopup) { | |
| mpopup.style.display = "none"; | |
| } | |
| }; | |
| // closeDialog.onclick = function() { | |
| // dialog_container.style.display = "none"; | |
| // }; | |
| var dialog_container = document.getElementById('dialog-container'); | |
| // Select close action element | |
| // var closeDialog = document.getElementsByClassName("closeModal")[0]; | |
| function ShowPopUpWarning(){ | |
| // Open modal | |
| dialog_container.style.display = "block"; | |
| } | |
| // Close modal once close element is clicked | |
| // closeDialog.onclick = function() { | |
| // console.log() | |
| // dialog_container.style.display = "none"; | |
| // }; | |
| // Close modal when user clicks outside of the modal box | |
| window.onclick = function(event) { | |
| if (event.target == dialog_container) { | |
| dialog_container.style.display = "none"; | |
| } | |
| }; | |
| function filterFunction(id) { | |
| var input, filter, ul, li, a, i; | |
| input = document.getElementById(id); | |
| filter = input.value.toUpperCase(); | |
| if (id.toString().startsWith('tomeasure')) | |
| a = document.querySelectorAll("#measureContainer .measure-item"); | |
| // a = document.getElementById("measureselectid").children; | |
| else | |
| // a = document.getElementById("relvselectid").children; | |
| a = document.querySelectorAll("#relvselectid .relv-item"); | |
| // a = div.getElementsByTagName("option"); | |
| for (i = 0; i < a.length; i++) { | |
| txtValue = a[i].textContent || a[i].innerText; | |
| if (txtValue.toUpperCase().indexOf(filter) > -1) { | |
| a[i].style.display = ""; | |
| } else { | |
| a[i].style.display = "none"; | |
| } | |
| } | |
| } | |
| // Call function when show dialog btn is clicked | |
| var duplicaterExtra = document.getElementById("duplicaterExtra"); | |
| var overlaymeText = document.getElementById("modal-bodyTextp"); | |
| var overlayme = document.getElementById("dialog-container"); | |
| document.getElementById("refreshDropboxButtonID").disabled=false; | |
| // if (document.getElementById("refreshDropboxButtonID").disabled==false){ | |
| document.getElementById("refreshDropboxButtonID").onclick = function() | |
| { | |
| TopTextModal.textContent='Warning: Dropbox Refresh'; | |
| if (document.getElementById("refreshDropboxButtonID").disabled==false) | |
| overlayme.style.display = "block"; | |
| 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.'; | |
| duplicaterExtra.setAttribute('hidden',true) | |
| }; | |
| // Call function when show dialog btn is clicked | |
| var TopTextModal = document.getElementById("TopTextModalWarning"); | |
| document.getElementById("refreshAPIbutton").disabled=false; | |
| document.getElementById("refreshAPIbutton").onclick = function() | |
| { | |
| TopTextModal.textContent='Warning: MC Refresh'; | |
| if (document.getElementById("refreshAPIbutton").disabled==false) | |
| { | |
| console.log(overlaymeText.textContent) | |
| overlaymeText.textContent='This is not a mandatory button. The system already runs at half-hour intervals to update the dropdowns and MC-Templates from the MC. Using this would manually refresh the data retrieved, disregarding the 30-minute interval.'; | |
| overlayme.style.display = "block"; | |
| duplicaterExtra.setAttribute('hidden',true) | |
| } | |
| }; | |
| document.getElementById("popupforextratext").disabled=false; | |
| document.getElementById("popupforextratext").onclick = function(){ | |
| if (sectionNumber.startsWith('2.7')) | |
| { | |
| textextra= document.getElementById("textextra") | |
| textextra.style.backgroundColor = "rgba(101, 101, 101, 0.27)"; | |
| // textextra.style.border='2px solid #2f83c6' | |
| textextra.style.cursor='not-allowed'; | |
| textextra.disabled="disabled"; | |
| } | |
| if (sectionNumber.startsWith('2.8')) | |
| { | |
| text2extra= document.getElementById("text2extra") | |
| text2extra.style.backgroundColor = "rgba(101, 101, 101, 0.27)"; | |
| text2extra.style.cursor='not-allowed'; | |
| text2extra.disabled="disabled"; | |
| } | |
| duplicaterExtra.removeAttribute('hidden'); | |
| TopTextModal.textContent='Define Information to Extract from Drawing' | |
| if (document.getElementById("popupforextratext").disabled==false) | |
| { | |
| overlaymeText.textContent=''; | |
| overlayme.style.display = "block"; | |
| } | |
| }; | |
| // } | |
| document.getElementById("confirm").onclick = function(){confirmDialogR()}; | |
| function confirmDialogR() { | |
| /* code executed if confirm is clicked */ | |
| overlayme.style.display = "none"; | |
| console.log(document.getElementById("confirm").parentElement.parentElement.children[0].textContent) | |
| if (document.getElementById("confirm").parentElement.parentElement.children[0].textContent.startsWith('The')) | |
| { | |
| console.log('hereeeeeeeee') | |
| callrefreshDropbox(); | |
| } | |
| else if(document.getElementById("confirm").parentElement.parentElement.children[0].textContent.startsWith('This')){ | |
| callrefreshAPI(); | |
| } | |
| else{ | |
| getpopuptext(); | |
| } | |
| } | |
| // If cancel btn is clicked , the function cancel() is executed | |
| document.getElementById("cancel").onclick = function(){cancelDialog()}; | |
| function cancelDialog() { | |
| overlayme.style.display = "none"; | |
| } | |
| var extracted_path; | |
| function callrefreshDropbox(){ | |
| console.log('ldropboxx' , extracted_path) | |
| document.getElementById("refreshDropboxButtonID").style.backgroundColor = "gray"; | |
| document.getElementById("refreshDropboxButtonID").style.cursor='not-allowed'; | |
| document.getElementById("refreshDropboxButtonID").disabled="disabled"; | |
| TopTextModal=document.getElementById("TopTextModal"); | |
| $.get('/postdropboxprojects/' + encodeURIComponent(JSON.stringify(extracted_path))) | |
| .success(function(stringReturned) { | |
| if (stringReturned.startsWith('Updated')) | |
| { | |
| console.log('DONEEEE') | |
| TopTextModal.textContent= "Success!"; | |
| TopTextModal.style.color='green'; | |
| PopupElement.textContent=stringReturned; | |
| } | |
| else{ | |
| PopupElement.textContent=stringReturned; | |
| } | |
| ShowPopUp(); | |
| document.getElementById("refreshDropboxButtonID").style.cursor='pointer'; | |
| document.getElementById("refreshDropboxButtonID").style.backgroundColor = "#1680c7"; | |
| document.getElementById("refreshDropboxButtonID").disabled = false; | |
| }) | |
| .error(function(jqXHR, textStatus, errorThrown) { | |
| PopupElement.textContent='Error occured while retrieving projects from the dropbox. Refresh and try again. If the error continues, please contact the ADR team to fix it. '; | |
| ShowPopUp(); | |
| }); | |
| } | |
| function refreshAPIbuutton(dataa){ | |
| $.get('/refreshAPIAppendNewTables') | |
| .success(function(successData){ | |
| if (dataa[1]==='project') | |
| { | |
| // console.log('projjjj') | |
| // displayprjnames(); | |
| console.log(dataa[2]) | |
| for (let d=0;d<dataa[2].length;d++) | |
| { | |
| console.log(dataa[2][d]) | |
| opt=document.createElement("option"); | |
| opt.textContent=dataa[2][d]; | |
| opt.text=dataa[2][d]; | |
| firstdropdown.append(opt); | |
| PrjNamesArray.push(dataa[2][d]); | |
| } | |
| } | |
| else if (dataa[1]==='part') | |
| { if (firstdropdown.value) | |
| { | |
| console.log(dataa[2]) | |
| for (let d=0;d<dataa[2].length;d++) | |
| { | |
| console.log(dataa[2][d]) | |
| opt=document.createElement("option"); | |
| opt.textContent=dataa[2][d]; | |
| opt.text=dataa[2][d]; | |
| seconddropdown.append(opt); | |
| // PrjPartsArray.push(data[2][d]); | |
| } | |
| } | |
| } | |
| else if (dataa[1]==='section') | |
| { | |
| if ((firstdropdown.value) && (seconddropdown.value)) | |
| { | |
| console.log(dataa[2]) | |
| for (let d=0;d<dataa[2].length;d++) | |
| { | |
| console.log(dataa[2][d]) | |
| opt=document.createElement("option"); | |
| opt.textContent=dataa[2][d]; | |
| opt.text=dataa[2][d]; | |
| if(!(dataa[2][d].startsWith('1.0') ) || (data[i].startsWith('3.2') ) || (data[i].startsWith('2.8')) || (data[i].startsWith('3.3')) || (data[i].startsWith('2.1')) || (data[i].startsWith('2.7')) )//||data[i].startsWith('2.2'))) | |
| { | |
| opt.style.color='#bdbcbc'; | |
| opt.style.cursor='not-allowed'; | |
| opt.setAttribute('disabled',true) | |
| } | |
| thirddropdown.append(opt); | |
| // PrjPartsArray.push(data[2][d]); | |
| } | |
| } | |
| } | |
| TopTextModal=document.getElementById("TopTextModalWarning"); | |
| TopTextModal.textContent= "Success!"; | |
| TopTextModal.style.color='green'; | |
| PopupElement.textContent='Console is up to date!'; | |
| ShowPopUp(); | |
| document.getElementById("refreshAPIbutton").style.cursor='pointer'; | |
| document.getElementById("refreshAPIbutton").style.backgroundColor = "#003CFF"; | |
| document.getElementById("refreshAPIbutton").disabled = false; | |
| document.getElementById('all').style.display='none'; | |
| }) | |
| .error(function(jqXHR, textStatus, errorThrown) { | |
| PopupElement.textContent='Error occured while retrieving projects. Refresh and try again. If the error continues, please contact the ADR team to fix it. '; | |
| ShowPopUp(); | |
| }); | |
| } | |
| function callrefreshAPI(){ | |
| console.log('l') | |
| document.getElementById("refreshAPIbutton").style.backgroundColor = "gray"; | |
| document.getElementById("refreshAPIbutton").style.cursor='not-allowed'; | |
| document.getElementById("refreshAPIbutton").disabled="disabled"; | |
| if (thirddropdown.value){ | |
| console.log('yes') | |
| $.get( '/RetrieveMCTNames/') | |
| .success (function(data){ | |
| console.log(data) | |
| MCTNames=data; | |
| // console.log('jjw') | |
| sectionNumber=thirddropdown.value; | |
| MCTNames=MCTNames[sectionNumber.toString().toLowerCase()] | |
| // console.log('pn') | |
| console.log(MCTNames) | |
| }) | |
| .error(function(jqXHR, textStatus, errorThrown) { | |
| PopupElement.textContent='Error occured while retrieving the MC-T Names. Refresh and try again. If the error continues, please contact the ADR team to fix it. '; | |
| ShowPopUp(); | |
| }); | |
| // return MCTNames | |
| } | |
| if ((firstdropdown.value) && (seconddropdown.value)) | |
| { | |
| $.getJSON('/refreshAPI', {prjname: firstdropdown.value, prjpart: seconddropdown.value,prjpartid:partsArrIDsonly[seconddropdown.selectedIndex-1],},function(data11){ | |
| refreshAPIbuutton(data11) | |
| }) | |
| } | |
| else if (firstdropdown.value) | |
| { | |
| $.getJSON('/refreshAPI', {prjname: firstdropdown.value, } | |
| ,function(data11){ | |
| refreshAPIbuutton(data11) | |
| }) | |
| } | |
| else if (!firstdropdown.value){ | |
| $.getJSON('/refreshAPI',function(data11){ | |
| refreshAPIbuutton(data11) | |
| }) | |
| } | |
| } | |
| var groupedValues = []; | |
| function getpopuptext(){ | |
| // Select all text input fields inside the modal | |
| const inputs = document.querySelectorAll('.modal-body input[type="text"], .modal-body input[type="number"]'); | |
| const values = []; | |
| // Loop through the inputs and add their values to the array | |
| inputs.forEach(input => { | |
| values.push(input.value); | |
| }); | |
| console.log("Collected input values:", values); | |
| // Group the values into subarrays of 4 | |
| // const groupedValues = []; | |
| for (let i = 0; i < values.length; i += 4) { | |
| groupedValues.push(values.slice(i, i + 4)); | |
| } | |
| console.log("Grouped input values:", groupedValues); | |
| return groupedValues; | |
| } | |
| </script> | |