commit 981e1c0556c86b7031c7229016b72407e31a6cd0
Author: root <root@hub.scroll.pub> Date: 2025-01-06 01:06:21 +0000 Subject: Initial commit diff --git a/body.html b/body.html new file mode 100644 index 0000000..5bc13ca --- /dev/null +++ b/body.html @@ -0,0 +1,71 @@ +<header> + <nav> + <div class="logo">StockWise</div> + <div class="menu-toggle" aria-label="Toggle menu"> + <span></span><span></span><span></span> + </div> + <ul class="nav-links"> + <li><a href="#trending">Trending</a></li> + <li><a href="#watchlist">Watchlist</a></li> + <li><a href="#analysis">Analysis</a></li> + </ul> + </nav> +</header> + +<main> + <section class="hero"> + <h1>Smart Stock Investments in Real-Time</h1> + <p>Track market movements and discover investment opportunities as they happen</p> + </section> + + <section id="trending" class="stock-grid"> + <h2>Trending Stocks</h2> + <div class="stock-container" id="trending-stocks"></div> + </section> + + <section id="watchlist" class="watchlist"> + <h2>Your Watchlist</h2> + <div class="watchlist-container"> + <div class="add-stock"> + <input type="text" id="stock-search" placeholder="Add stock symbol..." aria-label="Search for a stock"> + <button id="add-stock-btn">Add</button> + </div> + <div id="watchlist-items"></div> + </div> + </section> + + <section id="analysis" class="market-analysis"> + <h2>Market Analysis</h2> + <div class="analysis-grid"> + <div class="market-card"> + <h3>Market Overview</h3> + <div id="market-overview"></div> + </div> + <div class="market-card"> + <h3>Top Gainers</h3> + <div id="top-gainers"></div> + </div> + <div class="market-card"> + <h3>Top Losers</h3> + <div id="top-losers"></div> + </div> + </div> + </section> +</main> + +<footer> + <div class="footer-content"> + <div class="footer-section"> + <h4>StockWise</h4> + <p>Making smart investments simple</p> + </div> + <div class="footer-section"> + <h4>Quick Links</h4> + <ul> + <li><a href="#trending">Trending</a></li> + <li><a href="#watchlist">Watchlist</a></li> + <li><a href="#analysis">Analysis</a></li> + </ul> + </div> + </div> +</footer> \ No newline at end of file diff --git a/index.scroll b/index.scroll new file mode 100644 index 0000000..4b5107b --- /dev/null +++ b/index.scroll @@ -0,0 +1,10 @@ +buildHtml +baseUrl https://stockwise.scroll.pub +metaTags + description "Real-time stock market insights and investment recommendations updated live" + keywords "stocks, investing, real-time stocks, stock market, investment recommendations" +editButton /edit.html +title StockWise - Real-Time Investment Insights +style.css +body.html +script.js \ No newline at end of file diff --git a/prompt.json b/prompt.json new file mode 100644 index 0000000..fe638dd --- /dev/null +++ b/prompt.json @@ -0,0 +1,20 @@ +{ + "id": "msg_01GAx6kEKsHzU8HpuGnjGBWw", + "type": "message", + "role": "assistant", + "model": "claude-3-5-sonnet-20241022", + "content": [ + { + "type": "text", + "text": "I'll create a real-time stock investment tracking website.\n\nSuggested domain: stockwise.scroll.pub\n\n---domain---\nstockwise.scroll.pub\n---index.scroll---\nbuildHtml\nbaseUrl https://stockwise.scroll.pub\nmetaTags\n description \"Real-time stock market insights and investment recommendations updated live\"\n keywords \"stocks, investing, real-time stocks, stock market, investment recommendations\"\neditButton /edit.html\ntitle StockWise - Real-Time Investment Insights\nstyle.css\nbody.html\nscript.js\n---body.html---\n<header>\n <nav>\n <div class=\"logo\">StockWise</div>\n <div class=\"menu-toggle\" aria-label=\"Toggle menu\">\n <span></span><span></span><span></span>\n </div>\n <ul class=\"nav-links\">\n <li><a href=\"#trending\">Trending</a></li>\n <li><a href=\"#watchlist\">Watchlist</a></li>\n <li><a href=\"#analysis\">Analysis</a></li>\n </ul>\n </nav>\n</header>\n\n<main>\n <section class=\"hero\">\n <h1>Smart Stock Investments in Real-Time</h1>\n <p>Track market movements and discover investment opportunities as they happen</p>\n </section>\n\n <section id=\"trending\" class=\"stock-grid\">\n <h2>Trending Stocks</h2>\n <div class=\"stock-container\" id=\"trending-stocks\"></div>\n </section>\n\n <section id=\"watchlist\" class=\"watchlist\">\n <h2>Your Watchlist</h2>\n <div class=\"watchlist-container\">\n <div class=\"add-stock\">\n <input type=\"text\" id=\"stock-search\" placeholder=\"Add stock symbol...\" aria-label=\"Search for a stock\">\n <button id=\"add-stock-btn\">Add</button>\n </div>\n <div id=\"watchlist-items\"></div>\n </div>\n </section>\n\n <section id=\"analysis\" class=\"market-analysis\">\n <h2>Market Analysis</h2>\n <div class=\"analysis-grid\">\n <div class=\"market-card\">\n <h3>Market Overview</h3>\n <div id=\"market-overview\"></div>\n </div>\n <div class=\"market-card\">\n <h3>Top Gainers</h3>\n <div id=\"top-gainers\"></div>\n </div>\n <div class=\"market-card\">\n <h3>Top Losers</h3>\n <div id=\"top-losers\"></div>\n </div>\n </div>\n </section>\n</main>\n\n<footer>\n <div class=\"footer-content\">\n <div class=\"footer-section\">\n <h4>StockWise</h4>\n <p>Making smart investments simple</p>\n </div>\n <div class=\"footer-section\">\n <h4>Quick Links</h4>\n <ul>\n <li><a href=\"#trending\">Trending</a></li>\n <li><a href=\"#watchlist\">Watchlist</a></li>\n <li><a href=\"#analysis\">Analysis</a></li>\n </ul>\n </div>\n </div>\n</footer>\n---style.css---\n:root {\n --primary-color: #2a6cff;\n --secondary-color: #1d1d1d;\n --accent-color: #00ff9d;\n --background-color: #f8f9fa;\n --text-color: #333;\n --card-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);\n}\n\n* {\n margin: 0;\n padding: 0;\n box-sizing: border-box;\n}\n\nbody {\n font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;\n line-height: 1.6;\n color: var(--text-color);\n background-color: var(--background-color);\n}\n\n/* Header & Navigation */\nheader {\n background: var(--secondary-color);\n padding: 1rem;\n position: fixed;\n width: 100%;\n top: 0;\n z-index: 1000;\n}\n\nnav {\n max-width: 1200px;\n margin: 0 auto;\n display: flex;\n justify-content: space-between;\n align-items: center;\n}\n\n.logo {\n color: white;\n font-size: 1.5rem;\n font-weight: bold;\n background: linear-gradient(45deg, var(--primary-color), var(--accent-color));\n -webkit-background-clip: text;\n -webkit-text-fill-color: transparent;\n}\n\n.nav-links {\n display: flex;\n list-style: none;\n}\n\n.nav-links li a {\n color: white;\n text-decoration: none;\n padding: 0.5rem 1rem;\n transition: color 0.3s ease;\n}\n\n.nav-links li a:hover {\n color: var(--accent-color);\n}\n\n/* Hero Section */\n.hero {\n margin-top: 4rem;\n padding: 4rem 2rem;\n text-align: center;\n background: linear-gradient(135deg, var(--secondary-color), var(--primary-color));\n color: white;\n}\n\n.hero h1 {\n font-size: 2.5rem;\n margin-bottom: 1rem;\n}\n\n/* Stock Grid */\n.stock-grid {\n padding: 2rem;\n max-width: 1200px;\n margin: 0 auto;\n}\n\n.stock-container {\n display: grid;\n grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));\n gap: 1.5rem;\n margin-top: 1.5rem;\n}\n\n/* Market Analysis */\n.market-analysis {\n padding: 2rem;\n max-width: 1200px;\n margin: 0 auto;\n}\n\n.analysis-grid {\n display: grid;\n grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));\n gap: 1.5rem;\n margin-top: 1.5rem;\n}\n\n.market-card {\n background: white;\n padding: 1.5rem;\n border-radius: 10px;\n box-shadow: var(--card-shadow);\n transition: transform 0.3s ease;\n}\n\n.market-card:hover {\n transform: translateY(-5px);\n}\n\n/* Watchlist */\n.watchlist {\n padding: 2rem;\n max-width: 1200px;\n margin: 0 auto;\n}\n\n.add-stock {\n display: flex;\n gap: 1rem;\n margin-bottom: 1.5rem;\n}\n\n.add-stock input {\n flex: 1;\n padding: 0.5rem;\n border: 2px solid #ddd;\n border-radius: 5px;\n font-size: 1rem;\n}\n\n.add-stock button {\n padding: 0.5rem 1rem;\n background: var(--primary-color);\n color: white;\n border: none;\n border-radius: 5px;\n cursor: pointer;\n transition: background-color 0.3s ease;\n}\n\n.add-stock button:hover {\n background: var(--accent-color);\n}\n\n/* Footer */\nfooter {\n background: var(--secondary-color);\n color: white;\n padding: 2rem;\n margin-top: 4rem;\n}\n\n.footer-content {\n max-width: 1200px;\n margin: 0 auto;\n display: grid;\n grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));\n gap: 2rem;\n}\n\n.footer-section h4 {\n margin-bottom: 1rem;\n color: var(--accent-color);\n}\n\n.footer-section ul {\n list-style: none;\n}\n\n.footer-section ul li a {\n color: white;\n text-decoration: none;\n transition: color 0.3s ease;\n}\n\n.footer-section ul li a:hover {\n color: var(--accent-color);\n}\n\n/* Mobile Responsiveness */\n.menu-toggle {\n display: none;\n flex-direction: column;\n gap: 4px;\n cursor: pointer;\n}\n\n.menu-toggle span {\n width: 25px;\n height: 3px;\n background: white;\n transition: 0.3s;\n}\n\n@media (max-width: 768px) {\n .menu-toggle {\n display: flex;\n }\n\n .nav-links {\n display: none;\n position: absolute;\n top: 100%;\n left: 0;\n right: 0;\n background: var(--secondary-color);\n flex-direction: column;\n padding: 1rem;\n }\n\n .nav-links.active {\n display: flex;\n }\n\n .nav-links li {\n margin: 0.5rem 0;\n }\n}\n---script.js---\n// Mock data for demonstration\nconst mockStocks = [\n { symbol: 'AAPL', name: 'Apple Inc.', price: 150.25, change: 2.5 },\n { symbol: 'GOOGL', name: 'Alphabet Inc.', price: 2750.80, change: -1.2 },\n { symbol: 'MSFT', name: 'Microsoft Corp.', price: 310.45, change: 1.8 },\n { symbol: 'AMZN', name: 'Amazon.com Inc.', price: 3300.15, change: 0.9 }\n];\n\n// DOM Elements\nconst trendingStocks = document.getElementById('trending-stocks');\nconst watchlistItems = document.getElementById('watchlist-items');\nconst stockSearch = document.getElementById('stock-search');\nconst addStockBtn = document.getElementById('add-stock-btn');\nconst menuToggle = document.querySelector('.menu-toggle');\nconst navLinks = document.querySelector('.nav-links');\n\n// Mobile menu toggle\nmenuToggle.addEventListener('click', () => {\n navLinks.classList.toggle('active');\n});\n\n// Initialize trending stocks\nfunction initializeTrendingStocks() {\n mockStocks.forEach(stock => {\n const stockCard = createStockCard(stock);\n trendingStocks.appendChild(stockCard);\n });\n}\n\n// Create stock card element\nfunction createStockCard(stock) {\n const card = document.createElement('div');\n card.className = 'market-card';\n \n const changeColor = stock.change >= 0 ? '#00ff9d' : '#ff4d4d';\n const changeSymbol = stock.change >= 0 ? '+' : '';\n \n card.innerHTML = `\n <h3>${stock.symbol}</h3>\n <p>${stock.name}</p>\n <p class=\"price\">$${stock.price.toFixed(2)}</p>\n <p class=\"change\" style=\"color: ${changeColor}\">\n ${changeSymbol}${stock.change}%\n </p>\n `;\n \n return card;\n}\n\n// Add stock to watchlist\nfunction addToWatchlist() {\n const symbol = stockSearch.value.toUpperCase();\n if (symbol) {\n const stock = mockStocks.find(s => s.symbol === symbol);\n if (stock) {\n const watchlistCard = createStockCard(stock);\n watchlistItems.appendChild(watchlistCard);\n stockSearch.value = '';\n }\n }\n}\n\n// Event listeners\naddStockBtn.addEventListener('click', addToWatchlist);\nstockSearch.addEventListener('keypress', (e) => {\n if (e.key === 'Enter') {\n addToWatchlist();\n }\n});\n\n// Real-time price updates simulation\nfunction updatePrices() {\n const cards = document.querySelectorAll('.market-card');\n cards.forEach(card => {\n const priceElement = card.querySelector('.price');\n const changeElement = card.querySelector('.change');\n if (priceElement && changeElement) {\n const currentPrice = parseFloat(priceElement.textContent.replace('$', ''));\n const change = (Math.random() - 0.5) * 2;\n const newPrice = currentPrice + change;\n \n priceElement.textContent = `$${newPrice.toFixed(2)}`;\n changeElement.textContent = `${change >= 0 ? '+' : ''}${change.toFixed(2)}%`;\n changeElement.style.color = change >= 0 ? '#00ff9d' : '#ff4d4d';\n }\n });\n}\n\n// Initialize\ndocument.addEventListener('DOMContentLoaded', () => {\n initializeTrendingStocks();\n setInterval(updatePrices, 5000); // Update prices every 5 seconds\n});\n---end---\n\nThis implementation creates a modern, responsive stock tracking website with real-time price updates (simulated), a watchlist feature, and market analysis sections. The design uses a clean, professional color scheme with smooth animations and transitions. Key features include:\n\n1. Fixed header with mobile-responsive navigation\n2. Hero section with gradient background\n3. Real-time stock price updates with color-coded changes\n4. Interactive watchlist with add functionality\n5. Market analysis cards with hover effects\n6. Fully responsive layout that works on all devices\n7. Accessible design with ARIA labels and semantic HTML\n8. Smooth animations and transitions\n9. Modern CSS using custom properties and flexbox/grid layouts\n\nThe mock data is used for demonstration, but the structure is ready to be connected to a real stock API for live data." + } + ], + "stop_reason": "end_turn", + "stop_sequence": null, + "usage": { + "input_tokens": 278, + "cache_creation_input_tokens": 0, + "cache_read_input_tokens": 0, + "output_tokens": 3537 + } +} \ No newline at end of file diff --git a/readme.scroll b/readme.scroll new file mode 100644 index 0000000..54f4d62 --- /dev/null +++ b/readme.scroll @@ -0,0 +1,2 @@ +# stockwise2.scroll.pub +Website generated by Claude from prompt: Best stocks to invest in in real time \ No newline at end of file diff --git a/script.js b/script.js new file mode 100644 index 0000000..c8f91c9 --- /dev/null +++ b/script.js @@ -0,0 +1,93 @@ +// Mock data for demonstration +const mockStocks = [ + { symbol: 'AAPL', name: 'Apple Inc.', price: 150.25, change: 2.5 }, + { symbol: 'GOOGL', name: 'Alphabet Inc.', price: 2750.80, change: -1.2 }, + { symbol: 'MSFT', name: 'Microsoft Corp.', price: 310.45, change: 1.8 }, + { symbol: 'AMZN', name: 'Amazon.com Inc.', price: 3300.15, change: 0.9 } +]; + +// DOM Elements +const trendingStocks = document.getElementById('trending-stocks'); +const watchlistItems = document.getElementById('watchlist-items'); +const stockSearch = document.getElementById('stock-search'); +const addStockBtn = document.getElementById('add-stock-btn'); +const menuToggle = document.querySelector('.menu-toggle'); +const navLinks = document.querySelector('.nav-links'); + +// Mobile menu toggle +menuToggle.addEventListener('click', () => { + navLinks.classList.toggle('active'); +}); + +// Initialize trending stocks +function initializeTrendingStocks() { + mockStocks.forEach(stock => { + const stockCard = createStockCard(stock); + trendingStocks.appendChild(stockCard); + }); +} + +// Create stock card element +function createStockCard(stock) { + const card = document.createElement('div'); + card.className = 'market-card'; + + const changeColor = stock.change >= 0 ? '#00ff9d' : '#ff4d4d'; + const changeSymbol = stock.change >= 0 ? '+' : ''; + + card.innerHTML = ` + <h3>${stock.symbol}</h3> + <p>${stock.name}</p> + <p class="price">$${stock.price.toFixed(2)}</p> + <p class="change" style="color: ${changeColor}"> + ${changeSymbol}${stock.change}% + </p> + `; + + return card; +} + +// Add stock to watchlist +function addToWatchlist() { + const symbol = stockSearch.value.toUpperCase(); + if (symbol) { + const stock = mockStocks.find(s => s.symbol === symbol); + if (stock) { + const watchlistCard = createStockCard(stock); + watchlistItems.appendChild(watchlistCard); + stockSearch.value = ''; + } + } +} + +// Event listeners +addStockBtn.addEventListener('click', addToWatchlist); +stockSearch.addEventListener('keypress', (e) => { + if (e.key === 'Enter') { + addToWatchlist(); + } +}); + +// Real-time price updates simulation +function updatePrices() { + const cards = document.querySelectorAll('.market-card'); + cards.forEach(card => { + const priceElement = card.querySelector('.price'); + const changeElement = card.querySelector('.change'); + if (priceElement && changeElement) { + const currentPrice = parseFloat(priceElement.textContent.replace('$', '')); + const change = (Math.random() - 0.5) * 2; + const newPrice = currentPrice + change; + + priceElement.textContent = `$${newPrice.toFixed(2)}`; + changeElement.textContent = `${change >= 0 ? '+' : ''}${change.toFixed(2)}%`; + changeElement.style.color = change >= 0 ? '#00ff9d' : '#ff4d4d'; + } + }); +} + +// Initialize +document.addEventListener('DOMContentLoaded', () => { + initializeTrendingStocks(); + setInterval(updatePrices, 5000); // Update prices every 5 seconds +}); \ No newline at end of file diff --git a/style.css b/style.css new file mode 100644 index 0000000..307469e --- /dev/null +++ b/style.css @@ -0,0 +1,228 @@ +:root { + --primary-color: #2a6cff; + --secondary-color: #1d1d1d; + --accent-color: #00ff9d; + --background-color: #f8f9fa; + --text-color: #333; + --card-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); +} + +* { + margin: 0; + padding: 0; + box-sizing: border-box; +} + +body { + font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif; + line-height: 1.6; + color: var(--text-color); + background-color: var(--background-color); +} + +/* Header & Navigation */ +header { + background: var(--secondary-color); + padding: 1rem; + position: fixed; + width: 100%; + top: 0; + z-index: 1000; +} + +nav { + max-width: 1200px; + margin: 0 auto; + display: flex; + justify-content: space-between; + align-items: center; +} + +.logo { + color: white; + font-size: 1.5rem; + font-weight: bold; + background: linear-gradient(45deg, var(--primary-color), var(--accent-color)); + -webkit-background-clip: text; + -webkit-text-fill-color: transparent; +} + +.nav-links { + display: flex; + list-style: none; +} + +.nav-links li a { + color: white; + text-decoration: none; + padding: 0.5rem 1rem; + transition: color 0.3s ease; +} + +.nav-links li a:hover { + color: var(--accent-color); +} + +/* Hero Section */ +.hero { + margin-top: 4rem; + padding: 4rem 2rem; + text-align: center; + background: linear-gradient(135deg, var(--secondary-color), var(--primary-color)); + color: white; +} + +.hero h1 { + font-size: 2.5rem; + margin-bottom: 1rem; +} + +/* Stock Grid */ +.stock-grid { + padding: 2rem; + max-width: 1200px; + margin: 0 auto; +} + +.stock-container { + display: grid; + grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); + gap: 1.5rem; + margin-top: 1.5rem; +} + +/* Market Analysis */ +.market-analysis { + padding: 2rem; + max-width: 1200px; + margin: 0 auto; +} + +.analysis-grid { + display: grid; + grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); + gap: 1.5rem; + margin-top: 1.5rem; +} + +.market-card { + background: white; + padding: 1.5rem; + border-radius: 10px; + box-shadow: var(--card-shadow); + transition: transform 0.3s ease; +} + +.market-card:hover { + transform: translateY(-5px); +} + +/* Watchlist */ +.watchlist { + padding: 2rem; + max-width: 1200px; + margin: 0 auto; +} + +.add-stock { + display: flex; + gap: 1rem; + margin-bottom: 1.5rem; +} + +.add-stock input { + flex: 1; + padding: 0.5rem; + border: 2px solid #ddd; + border-radius: 5px; + font-size: 1rem; +} + +.add-stock button { + padding: 0.5rem 1rem; + background: var(--primary-color); + color: white; + border: none; + border-radius: 5px; + cursor: pointer; + transition: background-color 0.3s ease; +} + +.add-stock button:hover { + background: var(--accent-color); +} + +/* Footer */ +footer { + background: var(--secondary-color); + color: white; + padding: 2rem; + margin-top: 4rem; +} + +.footer-content { + max-width: 1200px; + margin: 0 auto; + display: grid; + grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); + gap: 2rem; +} + +.footer-section h4 { + margin-bottom: 1rem; + color: var(--accent-color); +} + +.footer-section ul { + list-style: none; +} + +.footer-section ul li a { + color: white; + text-decoration: none; + transition: color 0.3s ease; +} + +.footer-section ul li a:hover { + color: var(--accent-color); +} + +/* Mobile Responsiveness */ +.menu-toggle { + display: none; + flex-direction: column; + gap: 4px; + cursor: pointer; +} + +.menu-toggle span { + width: 25px; + height: 3px; + background: white; + transition: 0.3s; +} + +@media (max-width: 768px) { + .menu-toggle { + display: flex; + } + + .nav-links { + display: none; + position: absolute; + top: 100%; + left: 0; + right: 0; + background: var(--secondary-color); + flex-direction: column; + padding: 1rem; + } + + .nav-links.active { + display: flex; + } + + .nav-links li { + margin: 0.5rem 0; + } +} \ No newline at end of file