commit f30d064c663d56abe864003092c2fed88627c8cf
Author: ffff:72.234.190.31 <ffff:72.234.190.31@hub.scroll.pub> Date: 2024-11-11 16:54:50 +0000 Subject: Updated claude.parsers diff --git a/claude.parsers b/claude.parsers index a17a733..95aa4b9 100644 --- a/claude.parsers +++ b/claude.parsers @@ -35,7 +35,6 @@ webCamParser margin-top: 10px; } ` - return ` ${containerStyle} <div class="webcamContainer"> @@ -55,7 +54,6 @@ webCamParser const retakeButton = document.getElementById('retake${id}'); const capturedImage = document.getElementById('capturedImage${id}'); const ctx = canvas.getContext('2d'); - try { const stream = await navigator.mediaDevices.getUserMedia({ video: { @@ -68,7 +66,6 @@ webCamParser console.error('Error accessing webcam:', err); return; } - captureButton.addEventListener('click', () => { ctx.drawImage(video, 0, 0, canvas.width, canvas.height); const imageData = canvas.toDataURL('image/png'); @@ -77,14 +74,12 @@ webCamParser capturedImage.style.display = 'block'; captureButton.style.display = 'none'; retakeButton.style.display = 'inline-block'; - // Create a custom event with the image data const event = new CustomEvent('imageCaptured', { detail: { imageData, timestamp: new Date().toISOString() } }); document.dispatchEvent(event); }); - retakeButton.addEventListener('click', () => { video.style.display = 'block'; capturedImage.style.display = 'none';
commit 4e6f65a0f1de1be42176265e7966cd300e4807a8
Author: ffff:72.234.190.31 <ffff:72.234.190.31@hub.scroll.pub> Date: 2024-11-11 16:54:17 +0000 Subject: Updated index.scroll diff --git a/index.scroll b/index.scroll index 4442ed6..62a61b8 100644 --- a/index.scroll +++ b/index.scroll @@ -1,4 +1,7 @@ buildHtml + theme roboto -Hello World my name is \ No newline at end of file +claude.parsers + +webCam
commit 0911585695064dee429147fbad39a8ce18e99f56
Author: ffff:72.234.190.31 <ffff:72.234.190.31@hub.scroll.pub> Date: 2024-11-11 16:54:07 +0000 Subject: Updated claude.parsers diff --git a/claude.parsers b/claude.parsers index e69de29..a17a733 100644 --- a/claude.parsers +++ b/claude.parsers @@ -0,0 +1,97 @@ +webCamParser + extends abstractScrollWithRequirementsParser + description Access the device webcam with optional controls for capturing images. + cueFromId + inScope widthParser heightParser + javascript + compileInstance() { + const id = "webcam" + this._getUid() + const width = this.get("width") || "640" + const height = this.get("height") || "480" + const containerStyle = ` + .webcamContainer { + position: relative; + width: ${width}px; + margin: 20px auto; + } + .webcamControls { + margin-top: 10px; + text-align: center; + } + .webcamButton { + background: #0066cc; + color: white; + border: none; + padding: 8px 16px; + border-radius: 4px; + margin: 0 5px; + cursor: pointer; + } + .webcamButton:hover { + background: #0052a3; + } + .capturedImage { + display: none; + margin-top: 10px; + } + ` + + return ` + ${containerStyle} + <div class="webcamContainer"> + <video id="video${id}" width="${width}" height="${height}" autoplay playsinline></video> + <canvas id="canvas${id}" width="${width}" height="${height}" style="display:none;"></canvas> + <img id="capturedImage${id}" class="capturedImage" width="${width}" height="${height}"> + <div class="webcamControls"> + <button id="capture${id}" class="webcamButton">Capture Image</button> + <button id="retake${id}" class="webcamButton" style="display:none;">Retake</button> + </div> + </div> + <script> + (async () => { + const video = document.getElementById('video${id}'); + const canvas = document.getElementById('canvas${id}'); + const captureButton = document.getElementById('capture${id}'); + const retakeButton = document.getElementById('retake${id}'); + const capturedImage = document.getElementById('capturedImage${id}'); + const ctx = canvas.getContext('2d'); + + try { + const stream = await navigator.mediaDevices.getUserMedia({ + video: { + width: { ideal: ${width} }, + height: { ideal: ${height} } + } + }); + video.srcObject = stream; + } catch (err) { + console.error('Error accessing webcam:', err); + return; + } + + captureButton.addEventListener('click', () => { + ctx.drawImage(video, 0, 0, canvas.width, canvas.height); + const imageData = canvas.toDataURL('image/png'); + capturedImage.src = imageData; + video.style.display = 'none'; + capturedImage.style.display = 'block'; + captureButton.style.display = 'none'; + retakeButton.style.display = 'inline-block'; + + // Create a custom event with the image data + const event = new CustomEvent('imageCaptured', { + detail: { imageData, timestamp: new Date().toISOString() } + }); + document.dispatchEvent(event); + }); + + retakeButton.addEventListener('click', () => { + video.style.display = 'block'; + capturedImage.style.display = 'none'; + captureButton.style.display = 'inline-block'; + retakeButton.style.display = 'none'; + }); + })(); + </script> + ` + }
commit 845dd40ce39100fd3728e22669fc0515fa5756a2
Author: ffff:72.234.190.31 <ffff:72.234.190.31@hub.scroll.pub> Date: 2024-11-11 16:54:04 +0000 Subject: Updated claude.parsers diff --git a/claude.parsers b/claude.parsers new file mode 100644 index 0000000..e69de29
commit 93e43037b7794c5d3de89eaf6afe3e3d561d8df3
Author: root <root@hub.scroll.pub> Date: 2024-11-10 20:12:15 +0000 Subject: initial blank_template template diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..bd1a52d --- /dev/null +++ b/.gitignore @@ -0,0 +1,8 @@ +.DS_Store +*.html +*.txt +*.xml +*.css +*.js +*.csv +requests.scroll \ No newline at end of file diff --git a/index.scroll b/index.scroll new file mode 100644 index 0000000..4442ed6 --- /dev/null +++ b/index.scroll @@ -0,0 +1,4 @@ +buildHtml +theme roboto + +Hello World my name is \ No newline at end of file