Transaction

8e00c339750cdbd70bc5c2dde1ebcd044a9f7bfe4e39a4d31305484de10b0e91
Timestamp (utc)
2025-07-22 13:32:58
Fee Paid
0.00000347 BSV
(
0.00002000 BSV
-
0.00001653 BSV
)
Fee Rate
9.981 sat/KB
Version
1
Confirmations
32,202
Size Stats
34,765 B

2 Outputs

Total Output:
0.00001653 BSV
  • jMý†{"name":"ChainDisk","timestamp":1753190226899,"files":[{"name":"GatewayScrollerGS1J.html","size":25814,"type":"text/html","content":"// ===== GATEWAY SCROLLER MODULE - UPDATED LINKS =====
// Electrostatic proximity-based app discovery scroller
// Reveals apps on hover with 360° infinite scrolling

(function() {
    'use strict';

    console.log('🎯 Loading Gateway Scroller Module (Updated Links)...');

    // Initialize Scroller namespace
    window.GatewayScroller = {
        isInitialized: false,
        currentScrollPosition: 0,
        currentApp: null,
        apps: [],
        electrostatic: null
    };

    // App data for the scroller - Only apps with existing HTML files
    const DEFAULT_APPS = [
        { icon: '💳', name: 'Gateway EFTPOS', description: 'Professional point-of-sale terminal that transforms any device into a complete payment system. Accept payments, generate receipts, track sales - all with zero monthly fees.', features: ['Transform any device into EFTPOS terminal', 'Zero monthly fees or equipment rentals', 'Professional payment processing', 'Instant receipt generation', 'Complete sales tracking and analytics', 'Works on phones, tablets, computers'] },
        { icon: '🏦', name: 'Gateway Wallet', description: 'Runs entirely from your phone. Comes pre-funded and ready to use. Even if mybsv.io shuts down, your wallet keeps working forever. Made for the unbanked and under banked people of the global majority in mind.', features: ['One member gets BSV from exchange (one-time setup)', 'Others trade $1-5 cash for BSV at group meetings', 'Turns phone into EFTPOS order manager cash terminal', 'Yellow Pages - businesses advertise, White Pages - user directory', 'Noticeboard for community announcements and events', 'Built-in messaging - senders pay you to message (no spam!)'] },
        { icon: '🏛️', name: 'Gateway DAO', description: 'Decentralized autonomous organization tools for community governance and decision making. Create proposals, vote on initiatives, and manage collective resources transparently on the blockchain.', features: ['Create and manage governance proposals', 'Transparent voting mechanisms', 'Resource allocation and budgeting', 'Member management and roles', 'Automated execution of decisions', 'Complete audit trail on blockchain'] },
        { icon: '💼', name: 'Document Authenticator', description: 'Stop deep fakes and photo manipulation. Only blockchain-authenticated images prove authenticity in the age of AI.', features: ['Photos without blockchain proof are easily faked', 'Deep fake technology makes any image suspicious', 'Your wallet signature proves image authenticity', 'GPS and timestamp prevent manipulation', 'Courts can verify blockchain evidence', 'Future-proof against advancing AI deception'] },
        { icon: '📧', name: 'BSV Messaging', description: 'Email that pays you to receive messages. Group messaging for community updates, notices, marketing - recipients get paid to read.', features: ['Get paid for every email you receive', 'Group updates - earn money for staying informed', 'Community notices - get paid for important info', 'Group marketing - compensated for reading ads', 'Direct wallet-to-wallet email communication', 'Messages stored permanently on blockchain'] },
        { icon: '🏌️', name: 'Golf Organizer', description: 'Complete tournament organizer and results management system. Run professional golf events from registration to prize distribution.', features: ['Player registration and payment processing', 'Live scoring and leaderboard updates', 'Automatic handicap calculations', 'Prize money distribution via blockchain', 'Tournament reporting and statistics', 'Professional event management on your phone'] },
        { icon: '📋', name: 'Noticeboard', description: 'Community bulletin board for announcements, events, and local information sharing. Post notices, advertise services, and stay connected with your community through blockchain-verified messages.', features: ['Post community announcements', 'Event scheduling and notifications', 'Local business advertising', 'Verified user communications', 'Permanent message storage', 'Community moderation tools'] }
    ];

    // Electrostatic field controller class
    class ElectrostaticField {
        constructor(triggerElement) {
            this.trigger = triggerElement;
            this.fieldRadius = 120;
            this.init();
        }
        
        init() {
            document.addEventListener('mousemove', (e) => {
                this.updateField(e.clientX, e.clientY);
            });
            
            document.addEventListener('mouseleave', () => {
                this.deactivateField();
            });
        }
        
        updateField(mouseX, mouseY) {
            const rect = this.trigger.getBoundingClientRect();
            const centerX = rect.left + rect.width / 2;
            const centerY = rect.top + rect.height / 2;
            
            const distance = Math.sqrt(
                Math.pow(mouseX - centerX, 2) + 
                Math.pow(mouseY - centerY, 2)
            );
            
            if (distance <= this.fieldRadius) {
                const strength = Math.max(0, (this.fieldRadius - distance) / this.fieldRadius);
                this.activateField(strength);
            } else {
                this.deactivateField();
            }
        }
        
        activateField(strength) {
            this.trigger.style.setProperty('--field-strength', strength.toFixed(3));
            this.trigger.classList.add('electrostatic-active');
        }
        
        deactivateField() {
            this.trigger.style.setProperty('--field-strength', '0');
            this.trigger.classList.remove('electrostatic-active');
        }
    }

    // Core scroller functions
    window.GatewayScroller.scrollApps = function(direction) {
        window.GatewayScroller.currentScrollPosition += direction;
        
        const totalStamps = window.GatewayScroller.apps.length * 3;
        if (window.GatewayScroller.currentScrollPosition >= totalStamps - window.GatewayScroller.apps.length) {
            window.GatewayScroller.currentScrollPosition = window.GatewayScroller.apps.length;
        } else if (window.GatewayScroller.currentScrollPosition < 0) {
            window.GatewayScroller.currentScrollPosition = window.GatewayScroller.apps.length * 2 - 1;
        }
        
        this.updateScrollPosition();
        this.updateCenterStamp();
    };

    window.GatewayScroller.updateScrollPosition = function() {
        const appScroller = document.getElementById('appScroller');
        if (!appScroller) return;
        
        const stampWidth = 81; // 75px + 6px margin (increased from 71px)
        const offset = window.GatewayScroller.currentScrollPosition * stampWidth;
        appScroller.style.transform = `translateX(-${offset - 100}px)`;
    };

    window.GatewayScroller.updateCenterStamp = function() {
        const stamps = document.querySelectorAll('.app-stamp');
        stamps.forEach((stamp, index) => {
            stamp.classList.remove('center');
            if (index === window.GatewayScroller.currentScrollPosition) {
                stamp.classList.add('center');
            }
        });
    };

    window.GatewayScroller.openModal = function(app) {
        window.GatewayScroller.currentApp = app;
        
        // Create modal if it doesn't exist
        let modal = document.getElementById('appModal');
        if (!modal) {
            modal = document.createElement('div');
            modal.id = 'appModal';
            modal.className = 'app-modal';
modal.innerHTML = `
    <div class="modal-content">
        <div class="modal-header">
            <div class="modal-icon" id="modalIcon"></div>
            <div class="modal-title" id="modalTitle"></div>
            <div class="modal-description" id="modalDescription"></div>
        </div>
        <div class="modal-features">
            <h4>Key Features:</h4>
            <ul id="modalFeatures"></ul>
        </div>
        <div class="modal-buttons">
            <button class="modal-button launch-button" onclick="GatewayScroller.launchApp()">Learn More</button>
            <button class="modal-button close-button" onclick="GatewayScroller.closeModal()">Close</button>
        </div>
    </div>
`;
            document.body.appendChild(modal);
            
            // Add modal event listener
            modal.addEventListener('click', (e) => {
                if (e.target === e.currentTarget) {
                    window.GatewayScroller.closeModal();
                }
            });
        }
        
        document.getElementById('modalIcon').textContent = app.icon;
        document.getElementById('modalTitle').textContent = app.name;
        document.getElementById('modalDescription').textContent = app.description;
        
        const featuresList = document.getElementById('modalFeatures');
        featuresList.innerHTML = '';
        app.features.forEach(feature => {
            const li = document.createElement('li');
            li.textContent = feature;
            featuresList.appendChild(li);
        });
        
        modal.style.display = 'flex';
        setTimeout(() => modal.classList.add('show'), 10);
    };

    window.GatewayScroller.closeModal = function() {
        const modal = document.getElementById('appModal');
        if (modal) {
            modal.classList.remove('show');
            setTimeout(() => {
                modal.style.display = 'none';
                window.GatewayScroller.currentApp = null;
            }, 300);
        }
    };

    window.GatewayScroller.launchApp = function() {
        if (window.GatewayScroller.currentApp) {
            const app = window.GatewayScroller.currentApp;
            console.log(`🚀 Launching ${app.name}...`);
            
            // Integration with existing modules and mybsv.io links
            switch(app.name) {
                case 'Gateway EFTPOS':
                    window.open('https://mybsv.io/blockchain/eftpos.html', '_blank');
                    break;
                    
                case 'Gateway Wallet':
                    window.open('https://mybsv.io/blockchain/gatewaywallet.html', '_blank');
                    break;
                    
                case 'Gateway DAO':
                    if (window.GatewayDAO && window.GatewayDAO.show) {
                        window.GatewayDAO.show();
                    } else {
                        window.open('https://mybsv.io/blockchain/dao.html', '_blank');
                    }
                    break;
                    
                case 'Document Authenticator':
                    window.open('https://mybsv.io/blockchain/authenticate.html', '_blank');
                    break;
                    
                case 'BSV Messaging':
                    if (window.GatewayMessaging && window.GatewayMessaging.openComposeMessage) {
                        window.GatewayMessaging.openComposeMessage();
                    } else {
                        window.open('https://mybsv.io/blockchain/message.html', '_blank');
                    }
                    break;
                    
                case 'Golf Organizer':
                    window.open('https://mybsv.io/blockchain/golf.html', '_blank');
                    break;
                    
                case 'Noticeboard':
                    window.open('https://mybsv.io/blockchain/noticeboard.html', '_blank');
                    break;
                    
                default:
                    alert(`${app.name} module not yet integrated`);
            }
            
            window.GatewayScroller.closeModal();
        }
    };

    // Initialize the scroller
    window.GatewayScroller.initialize = function() {
        if (window.GatewayScroller.isInitialized) {
            console.log('✅ Gateway Scroller already initialized');
            return;
        }

        console.log('🎯 Initializing Gateway Scroller...');
        
        // Set up apps
        window.GatewayScroller.apps = DEFAULT_APPS;
        
        // Add CSS styles
        this.addStyles();
        
        // Mark as initialized
        window.GatewayScroller.isInitialized = true;
        console.log('✅ Gateway Scroller initialized successfully');
    };

    // Add required CSS styles - FIXED ICON SIZES
    window.GatewayScroller.addStyles = function() {
        if (document.getElementById('gateway-scroller-styles')) return;

        const style = document.createElement('style');
        style.id = 'gateway-scroller-styles';
        style.textContent = `
            /* ========== GATEWAY SCROLLER STYLES - FIXED ICONS ========== */
            .app-scroller-trigger {
                position: relative;
                width: 100%;
                height: 100px;
                --field-strength: 0;
                --proximity-radius: 120px;
            }

            .app-scroller-container {
                width: 100%;
                height: 80px;
                background: rgba(255,255,255,0.95);
                backdrop-filter: blur(10px);
                border-radius: 12px;
                box-shadow: 0 4px 20px rgba(0,0,0,0.1);
                overflow: hidden;
                border: 1px solid rgba(52, 152, 219, 0.2);
                position: relative;
                opacity: 0;
                visibility: hidden;
                transform: translateY(-20px) scale(0.9);
                transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
            }

            .app-scroller-trigger.electrostatic-active .app-scroller-container {
                opacity: calc(var(--field-strength) * 1);
                visibility: visible;
                transform: translateY(calc((1 - var(--field-strength)) * -20px)) scale(calc(0.9 + var(--field-strength) * 0.1));
                filter: brightness(calc(0.8 + var(--field-strength) * 0.4));
                box-shadow: 
                    0 4px 20px rgba(0,0,0,0.1),
                    0 0 calc(var(--field-strength) * 30px) rgba(52, 152, 219, calc(var(--field-strength) * 0.4));
            }

            .app-scroller-container:hover {
                filter: brightness(1.2) !important;
                box-shadow: 
                    0 8px 30px rgba(0,0,0,0.2),
                    0 0 40px rgba(52, 152, 219, 0.6) !important;
                transform: translateY(0) scale(1) !important;
            }

            .app-scroller {
                display: flex;
                height: 100%;
                align-items: center;
                padding: 0 15px;
                transition: transform 0.3s ease;
                width: fit-content;
            }

            /* FIXED: Larger icons that work on all screen sizes */
            .app-stamp {
                width: 75px !important;
                height: 75px !important;
                margin: 0 3px;
                border-radius: 12px;
                cursor: pointer;
                transition: all 0.3s ease;
                position: relative;
                flex-shrink: 0;
                display: flex;
                align-items: center;
                justify-content: center;
                font-size: 48px !important;
                border: 2px solid #e9ecef;
                background: linear-gradient(135deg, #fff 0%, #f8f9fa 100%);
                box-shadow: 0 2px 8px rgba(0,0,0,0.1);
                text-shadow: 0 1px 2px rgba(0,0,0,0.1);
                filter: brightness(1.1) saturate(1.3);
                min-width: 75px !important;
                min-height: 75px !important;
                max-width: 75px !important;
                max-height: 75px !important;
                line-height: 1 !important;
            }

            .app-stamp:hover {
                transform: scale(1.15) translateY(-3px);
                box-shadow: 0 6px 16px rgba(0,0,0,0.2);
                border-color: #3498db;
                z-index: 10;
                filter: brightness(1.3);
            }

            .app-stamp.center {
                transform: scale(1.08);
                border-color: #3498db;
                box-shadow: 0 4px 12px rgba(52, 152, 219, 0.3);
            }

            .nav-arrow {
                position: absolute;
                top: 50%;
                transform: translateY(-50%);
                background: rgba(255,255,255,0.9);
                border: 1px solid #dee2e6;
                width: 24px;
                height: 24px;
                border-radius: 50%;
                cursor: pointer;
                font-size: 12px;
                color: #3498db;
                display: flex;
                align-items: center;
                justify-content: center;
                transition: all 0.2s ease;
                z-index: 20;
            }

            .nav-arrow:hover {
                background: white;
                box-shadow: 0 2px 8px rgba(0,0,0,0.15);
                border-color: #3498db;
                filter: brightness(1.2);
            }

            .nav-arrow.left {
                left: 3px;
            }

            .nav-arrow.right {
                right: 3px;
            }

            .app-modal {
                position: fixed;
                top: 0;
                left: 0;
                width: 100%;
                height: 100%;
                background: rgba(0,0,0,0.8);
                display: none;
                justify-content: center;
                align-items: center;
                z-index: 1000;
                backdrop-filter: blur(5px);
            }

            .modal-content {
                background: white;
                border-radius: 16px;
                padding: 25px;
                max-width: 480px;
                width: 90%;
                text-align: center;
                transform: scale(0.8);
                transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
            }

            .app-modal.show .modal-content {
                transform: scale(1);
            }

            .modal-header {
                margin-bottom: 20px;
            }

            .modal-icon {
                font-size: 50px !important;
                margin-bottom: 12px;
            }

            .modal-title {
                font-size: 20px;
                font-weight: bold;
                margin-bottom: 8px;
                color: #2c3e50;
            }

            .modal-description {
                color: #666;
                line-height: 1.5;
                margin-bottom: 20px;
                font-size: 14px;
            }

            .modal-features {
                text-align: left;
                margin-bottom: 20px;
            }

            .modal-features h4 {
                margin-bottom: 8px;
                color: #2c3e50;
                font-size: 14px;
            }

            .modal-features ul {
                list-style: none;
                padding: 0;
            }

            .modal-features li {
                padding: 3px 0;
                color: #555;
                font-size: 13px;
            }

            .modal-features li::before {
                content: "✓ ";
                color: #27ae60;
                font-weight: bold;
            }

            .modal-buttons {
                display: flex;
                gap: 12px;
            }

            .modal-button {
                flex: 1;
                padding: 10px;
                border: none;
                border-radius: 8px;
                font-weight: bold;
                cursor: pointer;
                transition: all 0.2s ease;
                font-size: 14px;
            }

            .launch-button {
                background: #27ae60;
                color: white;
            }

            .launch-button:hover {
                background: #229954;
            }

            .close-button {
                background: #95a5a6;
                color: white;
            }

            .close-button:hover {
                background: #7f8c8d;
            }

            /* REMOVED MOBILE OVERRIDE - Icons stay large on all devices */
            @media (max-width: 480px) {
                .app-scroller-trigger {
                    --proximity-radius: 80px;
                }
                
                /* Keep icons large even on mobile */
                .app-stamp {
                    width: 70px !important;
                    height: 70px !important;
                    font-size: 42px !important;
                    margin: 0 2px;
                }
                
                .app-scroller-container {
                    height: 75px;
                }
            }
        `;
        document.head.appendChild(style);
    };

    // Create scroller HTML element
    window.GatewayScroller.createScrollerElement = function() {
        const scroller = document.createElement('div');
        scroller.className = 'app-scroller-trigger';
        scroller.id = 'appScrollerTrigger';
        
        scroller.innerHTML = `
            <div class="app-scroller-container" id="appScrollerContainer">
                <button class="nav-arrow left" onclick="GatewayScroller.scrollApps(-1)">‹</button>
                <div class="app-scroller" id="appScroller">
                    <!-- Apps populated by JavaScript -->
                </div>
                <button class="nav-arrow right" onclick="GatewayScroller.scrollApps(1)">›</button>
            </div>
        `;
        
        return scroller;
    };

    // Initialize scroller with apps
    window.GatewayScroller.initializeScrollerApps = function() {
        const appScroller = document.getElementById('appScroller');
        if (!appScroller) {
            console.error('❌ App scroller element not found');
            return;
        }
        
        // Create infinite scroll by tripling the apps
        const tripleApps = [...window.GatewayScroller.apps, ...window.GatewayScroller.apps, ...window.GatewayScroller.apps];
        
        tripleApps.forEach((app, index) => {
            const stamp = document.createElement('div');
            stamp.className = 'app-stamp';
            stamp.innerHTML = app.icon;
            stamp.onclick = () => window.GatewayScroller.openModal(app);
            stamp.dataset.appIndex = index % window.GatewayScroller.apps.length;
            appScroller.appendChild(stamp);
        });

        // Start at the middle set (Gateway Wallet should be at position 4, which is center)
        window.GatewayScroller.currentScrollPosition = window.GatewayScroller.apps.length + 4;
        window.GatewayScroller.updateScrollPosition();
        window.GatewayScroller.updateCenterStamp();

        // Add wheel scroll support
        const container = document.getElementById('appScrollerContainer');
        if (container) {
            container.addEventListener('wheel', (e) => {
                e.preventDefault();
                if (e.deltaY > 0) {
                    window.GatewayScroller.scrollApps(1);
                } else {
                    window.GatewayScroller.scrollApps(-1);
                }
            });

            // Add touch swipe support
            let startX = 0;
            container.addEventListener('touchstart', (e) => {
                startX = e.touches[0].clientX;
            });

            container.addEventListener('touchmove', (e) => {
                if (!startX) return;
                
                const diffX = startX - e.touches[0].clientX;
                
                if (Math.abs(diffX) > 30) {
                    e.preventDefault();
                    if (diffX > 0) {
                        window.GatewayScroller.scrollApps(1);
                    } else {
                        window.GatewayScroller.scrollApps(-1);
                    }
                    startX = 0;
                }
            });
        }

        // Initialize electrostatic field
        const trigger = document.getElementById('appScrollerTrigger');
        if (trigger) {
            window.GatewayScroller.electrostatic = new ElectrostaticField(trigger);
        }

        console.log('✅ Scroller apps initialized with updated mybsv.io links');
    };

    // Public API for wallet integration
    window.GatewayScroller.insertIntoWallet = function(targetElement) {
        if (!window.GatewayScroller.isInitialized) {
            window.GatewayScroller.initialize();
        }

        const scrollerElement = window.GatewayScroller.createScrollerElement();
        
        if (typeof targetElement === 'string') {
            const target = document.getElementById(targetElement) || document.querySelector(targetElement);
            if (target) {
                target.appendChild(scrollerElement);
            } else {
                console.error('❌ Target element not found:', targetElement);
                return;
            }
        } else if (targetElement && targetElement.appendChild) {
            targetElement.appendChild(scrollerElement);
        } else {
            console.error('❌ Invalid target element for scroller insertion');
            return;
        }

        // Initialize apps after DOM insertion
        setTimeout(() => {
            window.GatewayScroller.initializeScrollerApps();
        }, 100);

        console.log('✅ Gateway Scroller inserted into wallet with updated links');
    };

    // Global functions for backward compatibility
    window.scrollApps = function(direction) {
        window.GatewayScroller.scrollApps(direction);
    };

    // Auto-initialize
    window.GatewayScroller.initialize();
    
    console.log('🎯 Gateway Scroller Module loaded successfully with updated mybsv.io links');

})();"}]}
    https://whatsonchain.com/tx/8e00c339750cdbd70bc5c2dde1ebcd044a9f7bfe4e39a4d31305484de10b0e91