HEX
Server: Apache
System: Linux p3plzcpnl506847.prod.phx3.secureserver.net 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User: slfopp7cb1df (5698090)
PHP: 8.1.34
Disabled: NONE
Upload Files
File: /home/slfopp7cb1df/www/shaneconrad.me/wp-content/plugins/embedpress/assets/js/meetup-timezone.js
/**
 * EmbedPress Meetup Timezone Converter
 * 
 * Converts UTC timestamps to visitor's local timezone for Meetup embeds
 */
(function () {
    'use strict';

    /**
     * Format date according to the specified format string
     */
    function formatDate(date, format) {
        const months = ['January', 'February', 'March', 'April', 'May', 'June',
            'July', 'August', 'September', 'October', 'November', 'December'];
        const monthsShort = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun',
            'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];
        const days = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];
        const daysShort = ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'];

        const replacements = {
            // Year
            'Y': date.getFullYear(),
            'y': String(date.getFullYear()).slice(-2),

            // Month
            'F': months[date.getMonth()],
            'M': monthsShort[date.getMonth()],
            'm': String(date.getMonth() + 1).padStart(2, '0'),
            'n': date.getMonth() + 1,

            // Day
            'd': String(date.getDate()).padStart(2, '0'),
            'j': date.getDate(),
            'D': daysShort[date.getDay()],
            'l': days[date.getDay()],

            // Time
            'H': String(date.getHours()).padStart(2, '0'),
            'h': String(date.getHours() % 12 || 12).padStart(2, '0'),
            'G': date.getHours(),
            'g': date.getHours() % 12 || 12,
            'i': String(date.getMinutes()).padStart(2, '0'),
            's': String(date.getSeconds()).padStart(2, '0'),
            'A': date.getHours() >= 12 ? 'PM' : 'AM',
            'a': date.getHours() >= 12 ? 'pm' : 'am',
        };

        let formatted = format;

        // Use a unique placeholder pattern that won't conflict with date format characters
        // Using Unicode characters that are unlikely to appear in format strings
        const placeholderPrefix = '\u{1F4C5}'; // Calendar emoji as unique marker
        const placeholders = {};

        // First pass: replace format characters with unique placeholders
        for (const key in replacements) {
            const placeholder = placeholderPrefix + key + placeholderPrefix;
            placeholders[placeholder] = replacements[key];
            formatted = formatted.split(key).join(placeholder);
        }

        // Second pass: replace placeholders with actual values
        for (const placeholder in placeholders) {
            formatted = formatted.split(placeholder).join(placeholders[placeholder]);
        }

        return formatted;
    }

    /**
     * Format time according to the specified format string
     */
    function formatTime(date, format) {
        return formatDate(date, format);
    }

    /**
     * Convert UTC timestamps to visitor's local timezone
     */
    function convertTimezones() {
        // Find all elements with visitor timezone data attribute
        const elements = document.querySelectorAll('[data-visitor-timezone="true"]');

        console.log('EmbedPress Meetup Timezone: Found ' + elements.length + ' elements to convert');

        elements.forEach(function (element) {
            const utcTimestamp = parseInt(element.getAttribute('data-utc-timestamp'), 10);

            if (!utcTimestamp || isNaN(utcTimestamp)) {
                return;
            }

            // Create date object from UTC timestamp
            const date = new Date(utcTimestamp * 1000);

            console.log('Converting timestamp:', utcTimestamp, 'to local date:', date.toString());

            // Check if this is a date element or time element
            const isDateElement = element.classList.contains('ep-event-date');
            const isTimeElement = element.classList.contains('ep-event-end-time');

            // Get timezone abbreviation
            const timezoneAbbr = date.toLocaleTimeString('en-US', {
                timeZoneName: 'short'
            }).split(' ').pop();

            if (isDateElement) {
                // Format date and time
                const dateFormat = element.getAttribute('data-date-format') || 'F j, Y';
                const timeFormat = element.getAttribute('data-time-format') || 'g:i A';

                // Combine date and time format
                const formattedDate = formatDate(date, dateFormat);
                const formattedTime = formatTime(date, timeFormat);

                const newText = formattedDate + ', ' + formattedTime + ' ' + timezoneAbbr;
                console.log('Formatted date:', newText);
                element.textContent = newText;
            } else if (isTimeElement) {
                // Format time only (for end time)
                const timeFormat = element.getAttribute('data-time-format') || 'g:i A';
                element.textContent = formatTime(date, timeFormat) + ' ' + timezoneAbbr;
            }
        });
    }

    // Convert on page load
    if (document.readyState === 'loading') {
        document.addEventListener('DOMContentLoaded', convertTimezones);
    } else {
        convertTimezones();
    }

    // Convert after AJAX load more
    document.addEventListener('embedpress:meetup:loaded', convertTimezones);
})();