jM¸A{"name":"EncodedFiles","files":[{"name":"coreglobalAA5.html","size":12536,"type":"text/html","content":"class CoreGlobals {
  constructor() {
    // System folder codes
    this.SYSTEM_FOLDERS = {
      INBOX: '0',
      SENT: '1',
      JUNK: '2',
      FAVORITES: '3'
    };

    // Default folder configuration
    this.defaultFolderConfig = {
      folders: {
        '0': { name: 'Inbox', icon: '📥', system: true },
        '1': { name: 'Sent', icon: '📤', system: true },
        '2': { name: 'Junk', icon: '🗑', system: true },
        '3': { name: 'Favorites', icon: '⭐', system: true }
      },
      nextCode: 4
    };

    // Ensure folder config exists
    this.folderConfig = JSON.parse(localStorage.getItem('folderConfig') || 
                                 JSON.stringify(this.defaultFolderConfig));
    this.saveFolderConfig();

    // Set up emoji renderer
    this.twemoji = {
      parse: (content) => {
        return content.replace(/[\u{1F300}-\u{1F9FF}]|[\u{2600}-\u{26FF}]/gu, (match) => {
          const codePoint = match.codePointAt(0).toString(16);
          return `<img class="emoji" draggable="false" alt="${match}" 
                      src="https://cdnjs.cloudflare.com/ajax/libs/twemoji/14.0.2/svg/${codePoint}.svg">`;
        });
      }
    };

    this.initializeStyles();
  }

  initialize() {
    this.checkAndRecoverFolders();
    this.injectGlobals();
    this.setupEventListeners();
    this.setupNavigation();
    console.log('Core globals initialized successfully');
  }

  initializeStyles() {
    const style = document.createElement('style');
    style.textContent = `
      .message-item {
        display: flex;
        justify-content: space-between;
        align-items: start;
        padding: 0.75rem;
        border-bottom: 1px solid #e5e7eb;
        cursor: pointer;
      }
      .message-content {
        flex: 1;
        min-width: 0;
        margin-right: 1rem;
      }
      .message-subject {
        font-weight: 500;
        margin-bottom: 0.25rem;
      }
      .message-sender {
        color: #6b7280;
        font-size: 0.875rem;
      }
      .message-time {
        color: #6b7280;
        font-size: 0.875rem;
      }
      .message-actions {
        display: flex;
        gap: 0.5rem;
      }
      .folder-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 1rem;
        border-bottom: 1px solid #e5e7eb;
      }
      .nav-item {
        display: flex;
        align-items: center;
        padding: 0.5rem 1rem;
        cursor: pointer;
        color: white;
        text-decoration: none;
      }
      .nav-item:hover {
        background: rgba(255, 255, 255, 0.1);
      }
      .nav-item.active {
        background: #3b82f6;
      }
      .folder-icon {
        margin-right: 0.5rem;
      }
      .reward-badge {
        display: inline-block;
        background: #FFD700;
        color: #000;
        padding: 2px 8px;
        border-radius: 4px;
        margin-top: 4px;
        font-size: 0.9em;
      }
    `;
    document.head.appendChild(style);
  }

  injectGlobals() {
    window.FOLDERS = this.SYSTEM_FOLDERS;
    window.globalState = {
      currentView: null,
      currentFolder: null,
      transactionListener: null
    };

    window.showFolder = (code) => {
      window.globalState.currentFolder = code;
      this.setupFolder(code);
    };

    window.refreshInbox = async () => {
      const address = localStorage.getItem('walletAddress');
      if (!address) {
        console.error('No wallet address found');
        return;
      }
      const loadingIndicator = document.createElement('div');
      loadingIndicator.textContent = 'Fetching messages...';
      loadingIndicator.style.padding = '1rem';
      document.getElementById('messageList').prepend(loadingIndicator);
      
      try {
        const transactions = await fetchAddressTransactions(address);
        const { messages, newCount } = await processTransactions(transactions, address);
        if (newCount > 0) {
          window.modalManager?.showAlert(`Found ${newCount} new message(s)`);
        }
        this.setupFolder(this.SYSTEM_FOLDERS.INBOX);
      } catch (error) {
        console.error('Refresh failed:', error);
        window.modalManager?.showAlert('Failed to refresh: ' + error.message, 'error');
      } finally {
        loadingIndicator.remove();
      }
    };
  }

  setupEventListeners() {
    window.addEventListener('storage', (e) => {
      if (e.key === 'messages' || e.key === 'folderConfig') {
        if (window.globalState.currentFolder) {
          this.setupFolder(window.globalState.currentFolder);
        }
      }
    });

    document.addEventListener('click', (event) => {
      if (!event.target.closest('.move-menu') && !event.target.closest('.btn-secondary')) {
        document.querySelectorAll('.move-menu').forEach(menu => menu.remove());
      }
    });
  }

 setupNavigation() {
    const nav = document.querySelector('nav');
    if (!nav) return;
    
    let navHTML = '';
    
    // Add system folders first
    Object.entries(this.SYSTEM_FOLDERS).forEach(([key, code]) => {
      const folder = this.folderConfig.folders[code];
      navHTML += `
        <a class="nav-item" onclick="window.coreGlobals.setupFolder('${code}')">
          <span class="folder-icon">${this.renderEmoji(folder.icon)}</span> ${folder.name}
        </a>
      `;
    });
    
    // Add custom folders
    Object.entries(this.folderConfig.folders)
      .filter(([code]) => !Object.values(this.SYSTEM_FOLDERS).includes(code))
      .forEach(([code, folder]) => {
        navHTML += `
          <a class="nav-item" onclick="window.coreGlobals.setupFolder('${code}')">
            <span class="folder-icon">${this.renderEmoji(folder.icon)}</span> ${folder.name}
          </a>
        `;
      });
    
    // Add folder button
    navHTML += `
      <a class="nav-item add-folder" onclick="showAddFolderModal()">
        <span class="folder-icon">${this.renderEmoji('➕')}</span> Add Folder
      </a>
    `;
    
    nav.innerHTML = navHTML;
}

  setupFolder(folderCode) {
    const folder = this.folderConfig.folders[folderCode];
    if (!folder) return;

    window.globalState.currentFolder = folderCode;
    const messages = JSON.parse(localStorage.getItem('messages') || '[]');
    const folderMessages = messages.filter(msg => msg.folderCode === folderCode);
    
    const messageList = document.getElementById('messageList');
    if (!messageList) return;

    const headerHTML = this.createFolderHeader(folder, folderMessages.length, folderCode);
    const messagesHTML = this.createMessageList(folderMessages, folder);

    messageList.innerHTML = `
      ${headerHTML}
      <div class="message-container">
        ${messagesHTML}
      </div>
    `;

    // Update active state in navigation
    document.querySelectorAll('.nav-item').forEach(item => {
      item.classList.remove('active');
      if (item.getAttribute('onclick')?.includes(folderCode)) {
        item.classList.add('active');
      }
    });
  }

  createFolderHeader(folder, messageCount, folderCode) {
    return `
      <div class="folder-header">
        <div class="folder-info">
          <span class="folder-icon">${this.renderEmoji(folder.icon)}</span>
          <h2>${folder.name} (${messageCount})</h2>
        </div>
        ${folderCode === this.SYSTEM_FOLDERS.INBOX ? 
          '<button onclick="window.refreshInbox()" class="btn btn-secondary">Refresh</button>' : ''}
      </div>
    `;
  }

  createMessageList(messages, folder) {
    if (messages.length === 0) {
      return `<div class="no-messages">No messages in ${folder.name}</div>`;
    }

    return messages
      .sort((a, b) => b.timestamp - a.timestamp)
      .map(message => this.createMessageItem(message))
      .join('');
  }

  createMessageItem(message) {
    return `
      <div class="message-item" onclick="window.messageHandler.openMessage('${message.txid}')">
        <div class="message-content">
          <div class="message-subject">
            ${message.subject || 'No subject'}
          </div>
          <div class="message-sender">
            ${this.renderEmoji('👤')} ${message.sender || 'Unknown Sender'}
          </div>
          <div class="message-time">
            ${this.renderEmoji('🕒')} ${new Date(message.timestamp).toLocaleString()}
          </div>
          ${message.rewardData ? `
            <div class="reward-badge">
              ${this.renderEmoji('💰')} ${message.rewardData.actualReward} sats
            </div>
          ` : ''}
        </div>
        <div class="message-actions">
          <button 
            class="btn btn-secondary"
            onclick="event.stopPropagation(); window.coreGlobals.showMoveMenu(event, '${message.txid}')"
          >
            ${this.renderEmoji('📁')} Move
          </button>
          <button 
            class="btn btn-danger"
            onclick="event.stopPropagation(); window.coreGlobals.deleteMessage('${message.txid}')"
          >
            ${this.renderEmoji('❌')} Delete
          </button>
        </div>
      </div>
    `;
  }

  showMoveMenu(event, txid) {
    // Remove any existing move menus
    document.querySelectorAll('.move-menu').forEach(menu => menu.remove());

    const menu = document.createElement('div');
    menu.className = 'move-menu';
    menu.style.position = 'absolute';
    menu.style.right = '0';
    menu.style.top = '100%';
    menu.style.background = 'white';
    menu.style.border = '1px solid #e5e7eb';
    menu.style.borderRadius = '4px';
    menu.style.boxShadow = '0 2px 4px rgba(0,0,0,0.1)';
    menu.style.zIndex = '50';

    Object.entries(this.folderConfig.folders)
      .filter(([code]) => code !== window.globalState.currentFolder)
      .forEach(([code, folder]) => {
        const item = document.createElement('div');
        item.className = 'move-menu-item';
        item.style.padding = '8px 16px';
        item.style.cursor = 'pointer';
        item.innerHTML = `${this.renderEmoji(folder.icon)} ${folder.name}`;
        item.onclick = (e) => {
          e.stopPropagation();
          this.moveMessage(txid, code);
          menu.remove();
        };
        menu.appendChild(item);
      });

    event.target.parentElement.appendChild(menu);
  }

  moveMessage(txid, targetFolder) {
    const messages = JSON.parse(localStorage.getItem('messages') || '[]');
    const updatedMessages = messages.map(msg => {
      if (msg.txid === txid) {
        return {...msg, folderCode: targetFolder};
      }
      return msg;
    });
    localStorage.setItem('messages', JSON.stringify(updatedMessages));
    this.setupFolder(window.globalState.currentFolder);
  }

  deleteMessage(txid) {
    const messages = JSON.parse(localStorage.getItem('messages') || '[]');
    const updatedMessages = messages.filter(msg => msg.txid !== txid);
    localStorage.setItem('messages', JSON.stringify(updatedMessages));
    this.setupFolder(window.globalState.currentFolder);
  }

  createFolder(name, icon) {
    const code = this.folderConfig.nextCode.toString();
    this.folderConfig.folders[code] = {
      name: name,
      icon: icon,
      system: false
    };
    this.folderConfig.nextCode++;
    this.saveFolderConfig();
    this.setupNavigation();
  }

  deleteFolder(code) {
    if (this.folderConfig.folders[code].system) {
      throw new Error("Cannot delete system folder");
    }

    const messages = JSON.parse(localStorage.getItem('messages') || '[]');
    const updatedMessages = messages.map(msg => {
      if (msg.folderCode === code) {
        return {...msg, folderCode: this.SYSTEM_FOLDERS.INBOX};
      }
      return msg;
    });

    delete this.folderConfig.folders[code];
    localStorage.setItem('messages', JSON.stringify(updatedMessages));
    this.saveFolderConfig();
    this.setupNavigation();
  }

  saveFolderConfig() {
    localStorage.setItem('folderConfig', JSON.stringify(this.folderConfig));
  }

  checkAndRecoverFolders() {
    try {
      const folders = JSON.parse(localStorage.getItem('folderConfig'));
      if (!folders || !folders.folders) {
        localStorage.setItem('folderConfig', JSON.stringify(this.defaultFolderConfig));
      }
    } catch (e) {
      console.error('Error checking folders, resetting to defaults:', e);
      localStorage.setItem('folderConfig', JSON.stringify(this.defaultFolderConfig));
    }
  }

  renderEmoji(content) {
    return this.twemoji.parse(content);
  }
}

// Initialize global instance
window.coreGlobals = new CoreGlobals();
window.coreGlobals.initialize();"}]}
https://whatsonchain.com/tx/15509daf958da52ac7d856a47d15738d46ea23744bbf9fd6d0ba9e1d5994cedc