HTML-Table Visualization
data:image/s3,"s3://crabby-images/efea3/efea3e2e2a424ceabf2c0721c5ceb98da8cd7da5" alt="introapp.png"
The next step is to extend the app from the last instructables with a HTML-Table that shows the whole calculation directly on page with pointing horizontal, vertical bars and the info of the binary operation (e.g. 9x13=117).
CSS + Additional HTML Lines
data:image/s3,"s3://crabby-images/304e5/304e50bb71c14bd9082c286231c8b6a23e3db5eb" alt="css.png"
data:image/s3,"s3://crabby-images/fca37/fca376a9ca30786ece31d94169236e339144b0b1" alt="htmledit.png"
The most important lines of the css (autoCalcGUI.html) part is the table that gets once framed when the first row and column is appearing. tr: hover is when you mark horizontally the pointing row with the cursor. The odd thing is that the pointing vertical bar with col tag does not work with CSS, so I solved with a workaround in JS. (is shown later) Probably there is a better solution in the web.
In the html file there are also few lines added, a checkbox to enable, disable html table output and avoid clearing input text when pushing enter.
Diagramm With Additional Entities
data:image/s3,"s3://crabby-images/396e7/396e7a9b2b8bee62c4a04c21670a258027ff8a55" alt="draft123.png"
We create an additional worker that is responsible for the HTML Table output. Some changes in the code are also necessary.
Seperate Scriptfiles
data:image/s3,"s3://crabby-images/5320a/5320a450230486a4ece00237717bb9c59f77848a" alt="seperate.png"
The 2 workers have similar functions that we have to avoid code duplication. The swap and mode selection methods are saved now in seperate scriptfiles, so that these 2 workers can use them simultaneously. Rename workerCalc to workerCSV.js
Import New Scriptfiles
data:image/s3,"s3://crabby-images/7e03b/7e03b167609d276cd32d0c64bfd66d5916274268" alt="changesCSV.png"
Like mentioned before, some methods are in seperate files like shown in image. So importScripts contains these necessary methods.
Changes in Controller.js: Selected Workers
data:image/s3,"s3://crabby-images/b02f1/b02f17e6ed5f297d8468c0687049e35ee79a7857" alt="wSel.png"
If the HTML-Table checkbox is checked both workers will be enabled, otherwise only one that generates the csv spreadsheet.
Changes in Controller.js: Use Workers Simultaneously
data:image/s3,"s3://crabby-images/e0606/e0606e96788d84a9885091f3531f8899d1322145" alt="generate.png"
Start up to 2 workers for generating the csv file and creating the HTML-Table.
Changes in Controller.js: Vertical Pointing Bar
data:image/s3,"s3://crabby-images/1df58/1df58bb0b5d22a4728806ab6af80b10909f56e8f" alt="markervert.png"
This method is for the vertical marking bar of columns, it's a workaround, because I didn't get it work only with CSS.
New Workerfile
data:image/s3,"s3://crabby-images/d4f2b/d4f2bc478463bbf6615a5763215ad81967424717" alt="newWorker.png"
This worker creates a string containing the whole html code + calculations for table, rows and columns. It's similar to the another worker, it contains the necessary tags with appended values and results. If you point on a result you will get the calculation as info it's embedded in the td title="" tag.
The Finished App
I realized that the app blocks when using huge values, because of the DOM Access for the table output. Probably there is a better solution for that. But I think it's inevitable, somehow you have to access to DOM if you create a HTML-Table.
App is provided as zip.