commit c3c10d0807791f7c41e417869b8be6d4eb251921
Author: ffff:72.234.190.31 <ffff:72.234.190.31@ratemyfocus.breckyunits.com> Date: 2024-11-11 23:07:36 +0000 Subject: Updated basic.html diff --git a/basic.html b/basic.html index edad704..edceb18 100644 --- a/basic.html +++ b/basic.html @@ -357,7 +357,7 @@ } async function analyzeTextPro() { - window.location = "https://buy.stripe.com/9AQ3fYgzfgHbguY5kP"; + window.location = "https://buy.stripe.com/bIYdUC1El4Yt1A45kQ"; } // Add the spin animation to the existing style section
commit a83225f418cf9be7ea64808bd4fb9fef2e3890ce
Author: ffff:72.234.190.31 <ffff:72.234.190.31@ratemyfocus.breckyunits.com> Date: 2024-11-11 23:04:16 +0000 Subject: Updated basic.html diff --git a/basic.html b/basic.html index 6128863..edad704 100644 --- a/basic.html +++ b/basic.html @@ -7,7 +7,6 @@ content="https://ratemyfocus.breckyunits.com/og.png" /> <title>RateMyFocus - Measure The Focus Of Your Published Thoughts</title> - <script src="tf.min.js"></script> <script src="chart.umd.min.js"></script> <style> body { @@ -95,6 +94,18 @@ .sample-link:hover { color: #0052a3; } + .loading { + position: fixed; + top: 0; + left: 0; + width: 100%; + height: 100%; + background: rgba(255, 255, 255, 0.8); + display: flex; + justify-content: center; + align-items: center; + z-index: 1000; + } </style> </head> <body> @@ -119,9 +130,7 @@ <textarea id="textInput" placeholder="Paste your text here..."></textarea> <div> - <button onclick="analyzeText(); calculateFocusArea();"> - Calculate FocusRating (Basic) - </button> + <button onclick="analyzeText()">Calculate FocusRating (Basic)</button> <button onclick="analyzeTextPro()" class="pro-button"> Calculate FocusRating (Pro) </button> @@ -136,8 +145,6 @@ </div> <script> - let embeddings = []; - let projectedPoints = []; let chart = null; function loadSampleData() { @@ -167,12 +174,9 @@ document.getElementById("focusThought").value = "football"; document.getElementById("textInput").value = sampleMessages; - // Automatically trigger analysis analyzeText(); - calculateFocusArea(); } - // Rest of the JavaScript remains the same function basicEmbedding(text) { const words = text .toLowerCase() @@ -220,38 +224,48 @@ ]); } - function analyzeText() { - const text = document.getElementById("textInput").value; - embeddings = basicEmbedding(text); - projectedPoints = simplePCA(embeddings); - updateVisualization(); - } - - function analyzeTextPro() { - window.location = "https://buy.stripe.com/9AQ3fYgzfgHbguY5kP"; - } - - function updateVisualization() { + function updateVisualization( + projectedPoints, + messages, + focusEmbedding = null, + ) { const ctx = document.getElementById("plotCanvas").getContext("2d"); if (chart) { chart.destroy(); } - chart = new Chart(ctx, { - type: "scatter", - data: { - datasets: [ + const datasets = [ + { + label: "Thoughts", + data: projectedPoints.map((point, index) => ({ + x: point[0], + y: point[1], + message: messages[index], + })), + backgroundColor: "rgba(0, 102, 204, 0.5)", + }, + ]; + + // Add focus point if provided + if (focusEmbedding) { + datasets.push({ + label: "Target", + data: [ { - label: "Thought Embeddings", - data: projectedPoints.map((point) => ({ - x: point[0], - y: point[1], - })), - backgroundColor: "rgba(0, 102, 204, 0.5)", + x: focusEmbedding[0], + y: focusEmbedding[1], + message: document.getElementById("focusThought").value, }, ], - }, + backgroundColor: "rgba(255, 0, 0, 0.8)", + pointRadius: 8, + }); + } + + chart = new Chart(ctx, { + type: "scatter", + data: { datasets }, options: { responsive: true, maintainAspectRatio: false, @@ -261,30 +275,102 @@ position: "bottom", }, }, + plugins: { + tooltip: { + callbacks: { + label: function (context) { + return context.raw.message; + }, + }, + }, + legend: { + display: true, + }, + }, }, }); } - function calculateFocusArea() { - const focusThought = document - .getElementById("focusThought") - .value.toLowerCase(); - const text = document.getElementById("textInput").value; - const lines = text - .toLowerCase() - .split(/\n+/) - .filter((w) => w.length > 0); + function showLoading() { + const loadingDiv = document.createElement("div"); + loadingDiv.className = "loading"; + loadingDiv.id = "loadingIndicator"; + + const spinnerHTML = ` + <div style="text-align: center;"> + <div style="border: 4px solid #f3f3f3; + border-top: 4px solid #0066cc; + border-radius: 50%; + width: 40px; + height: 40px; + animation: spin 1s linear infinite; + margin: 0 auto; + margin-bottom: 10px;"> + </div> + <div style="color: #0066cc; font-weight: 500;">Analyzing...</div> + </div> + `; - const totalLines = lines.length; - const hits = lines.filter((line) => line.includes(focusThought)).length; - const focusRating = (100 * hits) / totalLines; + loadingDiv.innerHTML = spinnerHTML; + document.body.appendChild(loadingDiv); + } - document.getElementById("results").innerHTML = ` - <h3>RateMyFocus Results</h3> - <p>Total Thoughts: ${totalLines}</p> - <p>FocusRating for <b>${focusThought}</b>: ${focusRating.toFixed(0)}% 🔍</p> - `; + function hideLoading() { + const loadingDiv = document.getElementById("loadingIndicator"); + if (loadingDiv) { + loadingDiv.remove(); + } } + + function analyzeText() { + showLoading(); + + setTimeout(() => { + const text = document.getElementById("textInput").value; + const focusThought = document.getElementById("focusThought").value; + const lines = text.split(/\n+/).filter((line) => line.length > 0); + + const totalLines = lines.length; + const hits = lines.filter((line) => + line.toLowerCase().includes(focusThought.toLowerCase()), + ).length; + + const focusRating = (100 * hits) / totalLines; + + const embeddings = basicEmbedding(text); + const focusEmbedding = basicEmbedding(focusThought)[0]; + const projectedPoints = simplePCA(embeddings); + + const focusProjected = simplePCA([focusEmbedding])[0]; + + updateVisualization(projectedPoints, lines, focusProjected); + + document.getElementById("results").innerHTML = ` + <h3>RateMyFocus Results</h3> + <p>Total Thoughts: ${totalLines}</p> + <p>FocusRating for <b>${focusThought}</b>: ${focusRating.toFixed(1)}% 🔍</p> + <p><small>Using basic word matching</small></p> + `; + + hideLoading(); + }, 100); // Small delay to ensure loading indicator shows even for quick operations + } + + async function analyzeTextPro() { + window.location = "https://buy.stripe.com/9AQ3fYgzfgHbguY5kP"; + } + + // Add the spin animation to the existing style section + const styleSheet = document.styleSheets[0]; + styleSheet.insertRule( + ` + @keyframes spin { + 0% { transform: rotate(0deg); } + 100% { transform: rotate(360deg); } + } +`, + styleSheet.cssRules.length, + ); </script> </body> </html>
commit 3604265a708db0b3051d54397f99a30ffcde4f4c
Author: ffff:72.234.190.31 <ffff:72.234.190.31@thoughtfocus.breckyunits.com> Date: 2024-11-11 15:55:05 +0000 Subject: Updated basic.html diff --git a/basic.html b/basic.html index 451449c..6128863 100644 --- a/basic.html +++ b/basic.html @@ -113,17 +113,17 @@ </div> <p> Paste everything you published today, each message or document on its - own line. Emails, tweets, texts, etc, to calculate your RateMyFocus. + own line. Emails, tweets, texts, etc, to calculate your FocusRating. </p> <textarea id="textInput" placeholder="Paste your text here..."></textarea> <div> <button onclick="analyzeText(); calculateFocusArea();"> - Calculate RateMyFocus (Basic) + Calculate FocusRating (Basic) </button> <button onclick="analyzeTextPro()" class="pro-button"> - Calculate RateMyFocus (Pro) + Calculate FocusRating (Pro) </button> </div>
commit 9a89c458d78de1ec68d72205239eaa4d67a3ede4
Author: ffff:72.234.190.31 <ffff:72.234.190.31@thoughtfocus.breckyunits.com> Date: 2024-11-11 15:54:19 +0000 Subject: Updated basic.html diff --git a/basic.html b/basic.html index 816c733..451449c 100644 --- a/basic.html +++ b/basic.html @@ -4,9 +4,9 @@ <meta charset="UTF-8" /> <meta property="og:image" - content="https://thoughtfocus.breckyunits.com/og.png" + content="https://ratemyfocus.breckyunits.com/og.png" /> - <title>ThoughtFocus - Measure Your Focus By Your Words</title> + <title>RateMyFocus - Measure The Focus Of Your Published Thoughts</title> <script src="tf.min.js"></script> <script src="chart.umd.min.js"></script> <style> @@ -99,7 +99,9 @@ </head> <body> <div class="container"> - <h1>ThoughtFocus · Measure Your Focus by Your Words · TF = FT/T</h1> + <h1> + RateMyFocus · Measure The Focus of Your Published Thoughts · FR = FT/T + </h1> <div class="input-container"> <input @@ -110,18 +112,18 @@ <a class="sample-link" onclick="loadSampleData()">Sample</a> </div> <p> - Paste everything you wrote today, each message or document on its own - line. Emails, tweets, texts, etc, to calculate your ThoughtFocus. + Paste everything you published today, each message or document on its + own line. Emails, tweets, texts, etc, to calculate your RateMyFocus. </p> <textarea id="textInput" placeholder="Paste your text here..."></textarea> <div> <button onclick="analyzeText(); calculateFocusArea();"> - Calculate ThoughtFocus (Basic) + Calculate RateMyFocus (Basic) </button> <button onclick="analyzeTextPro()" class="pro-button"> - Calculate ThoughtFocus (Pro) + Calculate RateMyFocus (Pro) </button> </div> @@ -275,12 +277,12 @@ const totalLines = lines.length; const hits = lines.filter((line) => line.includes(focusThought)).length; - const focusScore = (100 * hits) / totalLines; + const focusRating = (100 * hits) / totalLines; document.getElementById("results").innerHTML = ` - <h3>ThoughtFocus Results</h3> + <h3>RateMyFocus Results</h3> <p>Total Thoughts: ${totalLines}</p> - <p>ThoughtFocus for <b>${focusThought}</b>: ${focusScore.toFixed(0)}% 🔍</p> + <p>FocusRating for <b>${focusThought}</b>: ${focusRating.toFixed(0)}% 🔍</p> `; } </script>
commit 92d15108e761eab5273f083b065ab07d5faeea9b
Author: ffff:24.165.26.201 <ffff:24.165.26.201@hub.scroll.pub> Date: 2024-11-11 01:45:34 +0000 Subject: Updated basic.html diff --git a/basic.html b/basic.html index 9918db8..816c733 100644 --- a/basic.html +++ b/basic.html @@ -23,7 +23,7 @@ color: black; } .pro-button:hover { - box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); + box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3); background: gold; color: black; }
commit e300a992a72b782683915b68519744806a3d3e06
Author: ffff:24.165.26.201 <ffff:24.165.26.201@hub.scroll.pub> Date: 2024-11-11 01:45:20 +0000 Subject: Updated basic.html diff --git a/basic.html b/basic.html index 0350212..9918db8 100644 --- a/basic.html +++ b/basic.html @@ -23,7 +23,7 @@ color: black; } .pro-button:hover { - opacity: 0.5; + box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); background: gold; color: black; }
commit 9513cc512666c859f121bcebb4972ea0e07a0bea
Author: ffff:24.165.26.201 <ffff:24.165.26.201@hub.scroll.pub> Date: 2024-11-11 01:45:08 +0000 Subject: Updated basic.html diff --git a/basic.html b/basic.html index 3a9931b..0350212 100644 --- a/basic.html +++ b/basic.html @@ -23,7 +23,7 @@ color: black; } .pro-button:hover { - opacity: 0.9; + opacity: 0.5; background: gold; color: black; }
commit 062433255586953d54609c4ca976d328902bc763
Author: ffff:24.165.26.201 <ffff:24.165.26.201@hub.scroll.pub> Date: 2024-11-11 01:44:49 +0000 Subject: Updated basic.html diff --git a/basic.html b/basic.html index 0f10772..3a9931b 100644 --- a/basic.html +++ b/basic.html @@ -24,6 +24,7 @@ } .pro-button:hover { opacity: 0.9; + background: gold; color: black; } .container {
commit c2a6b7d6dd7b51703ec77b3d5938270e8ee2a3f5
Author: ffff:24.165.26.201 <ffff:24.165.26.201@hub.scroll.pub> Date: 2024-11-11 01:44:42 +0000 Subject: Updated basic.html diff --git a/basic.html b/basic.html index 0403701..0f10772 100644 --- a/basic.html +++ b/basic.html @@ -22,6 +22,10 @@ background: gold; color: black; } + .pro-button:hover { + opacity: 0.9; + color: black; + } .container { background: white; padding: 20px;
commit 86009c2b6b26d52788593bfe3faeb11df6dceefe
Author: ffff:24.165.26.201 <ffff:24.165.26.201@hub.scroll.pub> Date: 2024-11-11 01:43:54 +0000 Subject: Updated basic.html diff --git a/basic.html b/basic.html index 806ef1d..0403701 100644 --- a/basic.html +++ b/basic.html @@ -20,6 +20,7 @@ } .pro-button { background: gold; + color: black; } .container { background: white;