<?php
/**
 * Plugin Name: FFP Sales Commission Tracker
 * Description: Ultimate sales tracking with gamification, achievements, TV mode, and more
 * Version: 2.0.0
 * Author: Function Factory Performance
 */
if (!defined('ABSPATH')) exit;

class FFP_Sales_Commission_Tracker {
    
    private $associates = [
        'charles' => ['name' => 'Charles', 'commission' => false, 'role' => 'Owner', 'rate' => 0],
        'evan' => ['name' => 'Evan', 'commission' => true, 'role' => 'Customer Service', 'rate' => 0.05],
        'reggie' => ['name' => 'Reggie', 'commission' => true, 'role' => 'Sales', 'rate' => 0.07],
        'will' => ['name' => 'Will', 'commission' => false, 'role' => 'Owner', 'rate' => 0],
        'ethan' => ['name' => 'Ethan', 'commission' => true, 'role' => 'Product Catalog Coordinator', 'rate' => 0.07],
        'isaiah' => ['name' => 'Isaiah', 'commission' => true, 'role' => 'Sales', 'rate' => 0.07],
    ];
    
    private $commission_rate = 0.07;
    
    private $achievements = [
        'first_blood' => ['name' => 'First Blood', 'icon' => '🩸', 'desc' => 'First sale of the month'],
        'ten_k_club' => ['name' => '10K Club', 'icon' => '💎', 'desc' => 'Hit $10k in a month'],
        'twenty_five_k' => ['name' => '25K Legend', 'icon' => '👑', 'desc' => 'Hit $25k in a month'],
        'hat_trick' => ['name' => 'Hat Trick', 'icon' => '🎩', 'desc' => '3 sales in one day'],
        'closer' => ['name' => 'The Closer', 'icon' => '🎯', 'desc' => 'Highest single order of month'],
        'streak_3' => ['name' => 'On A Roll', 'icon' => '🔥', 'desc' => 'Sales 3 days in a row'],
        'streak_5' => ['name' => 'Streak Master', 'icon' => '⚡', 'desc' => 'Sales 5 days in a row'],
        'century' => ['name' => 'Century Club', 'icon' => '💯', 'desc' => '100 orders lifetime'],
        'early_bird' => ['name' => 'Early Bird', 'icon' => '🌅', 'desc' => 'Sale before 9am'],
        'night_owl' => ['name' => 'Night Owl', 'icon' => '🦉', 'desc' => 'Sale after 8pm'],
        'weekend_warrior' => ['name' => 'Weekend Warrior', 'icon' => '⚔️', 'desc' => 'Sale on weekend'],
        'big_ticket' => ['name' => 'Big Ticket', 'icon' => '🎟️', 'desc' => 'Single order over $2,000'],
        'whale' => ['name' => 'Whale Hunter', 'icon' => '🐋', 'desc' => 'Single order over $5,000'],
    ];
    
    public function __construct() {
        register_activation_hook(__FILE__, [$this, 'activate']);
        add_action('woocommerce_after_checkout_billing_form', [$this, 'add_sales_associate_field']);
        add_action('woocommerce_checkout_update_order_meta', [$this, 'save_sales_associate_field']);
        add_action('woocommerce_admin_order_data_after_billing_address', [$this, 'display_sales_associate_admin']);
        add_action('wfacp_after_phone_field', [$this, 'add_sales_associate_field']);
        add_filter('wfacp_checkout_fields', [$this, 'add_funnelkit_field'], 10, 2);
        add_action('admin_menu', [$this, 'add_admin_menu']);
        add_action('wp_ajax_ffp_get_commission_data', [$this, 'ajax_get_commission_data']);
        add_action('wp_ajax_ffp_get_live_feed', [$this, 'ajax_get_live_feed']);
        add_action('wp_ajax_ffp_export_commission', [$this, 'ajax_export_commission']);
        add_action('wp_ajax_ffp_get_analytics', [$this, 'ajax_get_analytics']);
        add_action('wp_ajax_ffp_get_head_to_head', [$this, 'ajax_get_head_to_head']);
        add_filter('manage_edit-shop_order_columns', [$this, 'add_order_column']);
        add_action('manage_shop_order_posts_custom_column', [$this, 'render_order_column'], 10, 2);
        add_filter('manage_woocommerce_page_wc-orders_columns', [$this, 'add_order_column']);
        add_action('manage_woocommerce_page_wc-orders_custom_column', [$this, 'render_order_column_hpos'], 10, 2);
        add_action('woocommerce_order_status_completed', [$this, 'process_achievements']);
        add_action('woocommerce_order_status_processing', [$this, 'process_achievements']);
    }
    
    public function activate() {
        global $wpdb;
        $charset_collate = $wpdb->get_charset_collate();
        $table_name = $wpdb->prefix . 'ffp_achievements';
        $sql = "CREATE TABLE IF NOT EXISTS $table_name (
            id bigint(20) NOT NULL AUTO_INCREMENT,
            associate_key varchar(50) NOT NULL,
            achievement_key varchar(50) NOT NULL,
            earned_at datetime DEFAULT CURRENT_TIMESTAMP,
            order_id bigint(20) DEFAULT NULL,
            PRIMARY KEY (id)
        ) $charset_collate;";
        require_once(ABSPATH . 'wp-admin/includes/upgrade.php');
        dbDelta($sql);
    }
    
    public function process_achievements($order_id) {
        global $wpdb;
        $order = wc_get_order($order_id);
        if (!$order) return;
        $associate_key = $order->get_meta('_sales_associate');
        if (!$associate_key || !isset($this->associates[$associate_key])) return;
        $subtotal = $order->get_subtotal();
        $order_date = $order->get_date_created();
        $month_year = $order_date->format('Y-m');
        
        if ($subtotal >= 2000) $this->award_achievement($associate_key, 'big_ticket', $order_id);
        if ($subtotal >= 5000) $this->award_achievement($associate_key, 'whale', $order_id);
        if ((int)$order_date->format('H') < 9) $this->award_achievement($associate_key, 'early_bird', $order_id);
        if ((int)$order_date->format('H') >= 20) $this->award_achievement($associate_key, 'night_owl', $order_id);
        if ($order_date->format('N') >= 6) $this->award_achievement($associate_key, 'weekend_warrior', $order_id);
        if ($this->is_first_sale_of_month($associate_key, $month_year)) $this->award_achievement($associate_key, 'first_blood', $order_id);
        
        $monthly_total = $this->get_monthly_total($associate_key, $month_year);
        if ($monthly_total >= 10000) $this->award_achievement($associate_key, 'ten_k_club', $order_id);
        if ($monthly_total >= 25000) $this->award_achievement($associate_key, 'twenty_five_k', $order_id);
        
        $streak = $this->get_sales_streak($associate_key);
        if ($streak >= 3) $this->award_achievement($associate_key, 'streak_3', $order_id);
        if ($streak >= 5) $this->award_achievement($associate_key, 'streak_5', $order_id);
        if ($this->get_daily_sales_count($associate_key, $order_date->format('Y-m-d')) >= 3) $this->award_achievement($associate_key, 'hat_trick', $order_id);
        if ($this->get_lifetime_order_count($associate_key) >= 100) $this->award_achievement($associate_key, 'century', $order_id);
    }
    
    private function award_achievement($associate_key, $achievement_key, $order_id) {
        global $wpdb;
        $table_name = $wpdb->prefix . 'ffp_achievements';
        $monthly = ['first_blood', 'ten_k_club', 'twenty_five_k', 'closer'];
        if (in_array($achievement_key, $monthly)) {
            $existing = $wpdb->get_var($wpdb->prepare("SELECT id FROM $table_name WHERE associate_key = %s AND achievement_key = %s AND earned_at >= %s", $associate_key, $achievement_key, date('Y-m-01 00:00:00')));
            if ($existing) return;
        }
        $wpdb->insert($table_name, ['associate_key' => $associate_key, 'achievement_key' => $achievement_key, 'order_id' => $order_id, 'earned_at' => current_time('mysql')]);
    }
    
    private function is_first_sale_of_month($associate_key, $month_year) {
        $orders = wc_get_orders(['limit' => 2, 'status' => ['completed', 'processing'], 'date_created' => $month_year . '-01...' . $month_year . '-31', 'meta_key' => '_sales_associate', 'meta_value' => $associate_key]);
        return count($orders) === 1;
    }
    
    private function get_monthly_total($associate_key, $month_year) {
        $orders = wc_get_orders(['limit' => -1, 'status' => ['completed', 'processing'], 'date_created' => $month_year . '-01...' . $month_year . '-31', 'meta_key' => '_sales_associate', 'meta_value' => $associate_key]);
        $total = 0;
        foreach ($orders as $order) $total += $order->get_subtotal();
        return $total;
    }
    
    private function get_sales_streak($associate_key) {
        $streak = 0;
        $check_date = new DateTime();
        for ($i = 0; $i < 30; $i++) {
            if ($this->get_daily_sales_count($associate_key, $check_date->format('Y-m-d')) > 0) $streak++;
            else break;
            $check_date->modify('-1 day');
        }
        return $streak;
    }
    
    private function get_daily_sales_count($associate_key, $date) {
        return count(wc_get_orders(['limit' => -1, 'status' => ['completed', 'processing'], 'date_created' => "$date...$date", 'meta_key' => '_sales_associate', 'meta_value' => $associate_key]));
    }
    
    private function get_lifetime_order_count($associate_key) {
        return count(wc_get_orders(['limit' => -1, 'status' => ['completed', 'processing'], 'meta_key' => '_sales_associate', 'meta_value' => $associate_key]));
    }
    
    public function add_sales_associate_field($checkout = null) {
        echo '<div id="ffp-sales-associate-field" class="ffp-sales-field">';
        woocommerce_form_field('sales_associate', ['type' => 'select', 'class' => ['ffp-sales-associate-select form-row-wide'], 'label' => 'Sales Representative', 'required' => false, 'options' => $this->get_associate_options()], WC()->checkout->get_value('sales_associate'));
        echo '<p class="ffp-sales-note">Working with one of our team? Select them so they get credit!</p></div>';
        echo '<style>#ffp-sales-associate-field{margin-top:20px;padding:15px;background:linear-gradient(135deg,rgba(0,200,83,0.05) 0%,rgba(0,180,216,0.05) 100%);border:1px solid rgba(0,200,83,0.2);border-radius:8px}#ffp-sales-associate-field label{color:#00a844!important;font-weight:600!important}.ffp-sales-note{font-size:12px;color:#888;margin-top:5px;font-style:italic}</style>';
    }
    
    public function add_funnelkit_field($fields, $key) {
        if ($key === 'billing') $fields['sales_associate'] = ['type' => 'select', 'label' => 'Sales Representative', 'required' => false, 'options' => $this->get_associate_options(), 'priority' => 120];
        return $fields;
    }
    
    private function get_associate_options() {
        $options = ['' => 'None / Online Order'];
        foreach ($this->associates as $key => $data) $options[$key] = $data['name'];
        return $options;
    }
    
    public function save_sales_associate_field($order_id) {
        if (!empty($_POST['sales_associate'])) {
            $associate = sanitize_text_field($_POST['sales_associate']);
            $order = wc_get_order($order_id);
            $order->update_meta_data('_sales_associate', $associate);
            if (isset($this->associates[$associate]) && $this->associates[$associate]['commission']) {
                $rate = $this->associates[$associate]['rate'] ?? $this->commission_rate;
                $order->update_meta_data('_sales_commission', $order->get_subtotal() * $rate);
            }
            $order->save();
        }
    }
    
    public function display_sales_associate_admin($order) {
        $key = $order->get_meta('_sales_associate');
        $comm = $order->get_meta('_sales_commission');
        if ($key && isset($this->associates[$key])) {
            echo '<p><strong>Sales Rep:</strong> ' . esc_html($this->associates[$key]['name']);
            if ($comm) echo ' <span style="color:#00c853;font-weight:bold;">($' . number_format($comm, 2) . ' commission)</span>';
            echo '</p>';
        }
    }
    
    public function add_order_column($columns) {
        $new = [];
        foreach ($columns as $k => $v) { $new[$k] = $v; if ($k === 'order_status') $new['sales_rep'] = 'Sales Rep'; }
        return $new;
    }
    
    public function render_order_column($column, $post_id) { if ($column === 'sales_rep') $this->render_rep_badge(wc_get_order($post_id)); }
    public function render_order_column_hpos($column, $order) { if ($column === 'sales_rep') $this->render_rep_badge($order); }
    
    private function render_rep_badge($order) {
        if (!$order) return;
        $key = $order->get_meta('_sales_associate');
        if ($key && isset($this->associates[$key])) {
            $color = $this->associates[$key]['commission'] ? '#00c853' : '#00b4d8';
            echo '<span style="background:' . $color . '22;color:' . $color . ';padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600;">' . esc_html($this->associates[$key]['name']) . '</span>';
        } else echo '<span style="color:#666;">—</span>';
    }
    
    public function add_admin_menu() {
        add_menu_page('Sales Commission', 'Sales Commission', 'read', 'ffp-commission', [$this, 'render_dashboard'], 'dashicons-chart-area', 56);
        add_submenu_page('ffp-commission', 'TV Display', '📺 TV Display', 'read', 'ffp-commission-tv', [$this, 'render_tv_mode']);
        add_submenu_page('ffp-commission', 'Head to Head', '⚔️ Head to Head', 'read', 'ffp-commission-h2h', [$this, 'render_head_to_head']);
        add_submenu_page('ffp-commission', 'Export', '📄 Export', 'manage_options', 'ffp-commission-export', [$this, 'render_export_page']);
    }
    
    public function ajax_get_commission_data() {
        check_ajax_referer('ffp_commission_nonce', 'nonce');
        $start = isset($_POST['start_date']) ? sanitize_text_field($_POST['start_date']) : date('Y-m-01');
        $end = isset($_POST['end_date']) ? sanitize_text_field($_POST['end_date']) : date('Y-m-d');
        $data = $this->get_commission_stats($start, $end);
        $data['achievements'] = $this->get_recent_achievements();
        $data['on_fire'] = $this->get_on_fire_reps();
        $data['monthly_champion'] = $this->get_monthly_champion();
        wp_send_json_success($data);
    }
    
    public function ajax_get_live_feed() {
        check_ajax_referer('ffp_commission_nonce', 'nonce');
        $orders = wc_get_orders(['limit' => 10, 'status' => ['completed', 'processing'], 'orderby' => 'date', 'order' => 'DESC']);
        $feed = [];
        foreach ($orders as $order) {
            $key = $order->get_meta('_sales_associate');
            $name = ($key && isset($this->associates[$key])) ? $this->associates[$key]['name'] : 'Online';
            $items = $order->get_items();
            $first = reset($items);
            $product = $first ? substr($first->get_name(), 0, 40) : 'Order';
            $feed[] = ['id' => $order->get_id(), 'rep' => $name, 'amount' => $order->get_subtotal(), 'product' => $product, 'time' => human_time_diff($order->get_date_created()->getTimestamp()) . ' ago'];
        }
        wp_send_json_success($feed);
    }
    
    public function ajax_get_analytics() {
        check_ajax_referer('ffp_commission_nonce', 'nonce');
        $start = isset($_POST['start_date']) ? sanitize_text_field($_POST['start_date']) : date('Y-m-01');
        $end = isset($_POST['end_date']) ? sanitize_text_field($_POST['end_date']) : date('Y-m-d');
        $sparklines = [];
        foreach ($this->associates as $key => $a) $sparklines[$key] = $this->get_sparkline_data($key);
        wp_send_json_success(['sparklines' => $sparklines, 'best_sellers' => $this->get_best_sellers($start, $end), 'heatmap' => $this->get_heatmap($start, $end)]);
    }
    
    private function get_sparkline_data($key) {
        $data = [];
        for ($i = 29; $i >= 0; $i--) {
            $date = date('Y-m-d', strtotime("-$i days"));
            $orders = wc_get_orders(['limit' => -1, 'status' => ['completed', 'processing'], 'date_created' => "$date...$date", 'meta_key' => '_sales_associate', 'meta_value' => $key]);
            $total = 0;
            foreach ($orders as $o) $total += $o->get_subtotal();
            $data[] = $total;
        }
        return $data;
    }
    
    private function get_best_sellers($start, $end) {
        $results = [];
        foreach ($this->associates as $key => $a) {
            $orders = wc_get_orders(['limit' => -1, 'status' => ['completed', 'processing'], 'date_created' => "$start...$end", 'meta_key' => '_sales_associate', 'meta_value' => $key]);
            $products = [];
            foreach ($orders as $order) {
                foreach ($order->get_items() as $item) {
                    $pid = $item->get_product_id();
                    if (!isset($products[$pid])) $products[$pid] = ['name' => $item->get_name(), 'total' => 0];
                    $products[$pid]['total'] += $item->get_total();
                }
            }
            uasort($products, fn($a, $b) => $b['total'] <=> $a['total']);
            $results[$key] = array_slice($products, 0, 3, true);
        }
        return $results;
    }
    
    private function get_heatmap($start, $end) {
        $heatmap = array_fill(0, 7, array_fill(0, 24, 0));
        $orders = wc_get_orders(['limit' => -1, 'status' => ['completed', 'processing'], 'date_created' => "$start...$end"]);
        foreach ($orders as $order) {
            $d = $order->get_date_created();
            $heatmap[(int)$d->format('N') - 1][(int)$d->format('G')] += $order->get_subtotal();
        }
        return $heatmap;
    }
    
    public function ajax_get_head_to_head() {
        check_ajax_referer('ffp_commission_nonce', 'nonce');
        $rep1 = sanitize_text_field($_POST['rep1']);
        $rep2 = sanitize_text_field($_POST['rep2']);
        $start = isset($_POST['start_date']) ? sanitize_text_field($_POST['start_date']) : date('Y-m-01');
        $end = isset($_POST['end_date']) ? sanitize_text_field($_POST['end_date']) : date('Y-m-d');
        wp_send_json_success(['rep1' => $this->get_rep_stats($rep1, $start, $end), 'rep2' => $this->get_rep_stats($rep2, $start, $end)]);
    }
    
    private function get_rep_stats($key, $start, $end) {
        if (!isset($this->associates[$key])) return null;
        $orders = wc_get_orders(['limit' => -1, 'status' => ['completed', 'processing'], 'date_created' => "$start...$end", 'meta_key' => '_sales_associate', 'meta_value' => $key]);
        $total = 0; $highest = 0;
        foreach ($orders as $o) { $s = $o->get_subtotal(); $total += $s; if ($s > $highest) $highest = $s; }
        $count = count($orders);
        return ['name' => $this->associates[$key]['name'], 'role' => $this->associates[$key]['role'], 'total' => $total, 'orders' => $count, 'aov' => $count > 0 ? $total / $count : 0, 'highest' => $highest, 'streak' => $this->get_sales_streak($key)];
    }
    
    private function get_recent_achievements() {
        global $wpdb;
        $table = $wpdb->prefix . 'ffp_achievements';
        $rows = $wpdb->get_results("SELECT * FROM $table ORDER BY earned_at DESC LIMIT 10");
        $achievements = [];
        foreach ($rows as $r) {
            if (isset($this->achievements[$r->achievement_key]) && isset($this->associates[$r->associate_key])) {
                $achievements[] = ['rep' => $this->associates[$r->associate_key]['name'], 'achievement' => $this->achievements[$r->achievement_key], 'time' => human_time_diff(strtotime($r->earned_at)) . ' ago'];
            }
        }
        return $achievements;
    }
    
    private function get_on_fire_reps() {
        $fire = [];
        foreach ($this->associates as $key => $a) { $streak = $this->get_sales_streak($key); if ($streak >= 3) $fire[$key] = $streak; }
        return $fire;
    }
    
    private function get_monthly_champion() {
        $last = date('Y-m', strtotime('-1 month'));
        $champ = null; $high = 0;
        foreach ($this->associates as $key => $a) { $t = $this->get_monthly_total($key, $last); if ($t > $high) { $high = $t; $champ = $key; } }
        return $champ;
    }
    
    private function get_commission_stats($start, $end) {
        $stats = [];
        foreach ($this->associates as $key => $a) $stats[$key] = ['name' => $a['name'], 'role' => $a['role'], 'earns_commission' => $a['commission'], 'rate' => $a['rate'], 'order_count' => 0, 'total_sales' => 0, 'commission_earned' => 0];
        $stats['online'] = ['name' => 'Online (No Rep)', 'role' => 'Direct', 'earns_commission' => false, 'rate' => 0, 'order_count' => 0, 'total_sales' => 0, 'commission_earned' => 0];
        
        $orders = wc_get_orders(['limit' => -1, 'status' => ['completed', 'processing'], 'date_created' => "$start...$end"]);
        $total_sales = 0; $total_commission = 0;
        
        foreach ($orders as $order) {
            $key = $order->get_meta('_sales_associate');
            $subtotal = $order->get_subtotal();
            if (empty($key) || !isset($stats[$key])) $key = 'online';
            $stats[$key]['order_count']++;
            $stats[$key]['total_sales'] += $subtotal;
            $total_sales += $subtotal;
            if (isset($this->associates[$key]) && $this->associates[$key]['commission']) {
                $comm = $subtotal * ($this->associates[$key]['rate'] ?? $this->commission_rate);
                $stats[$key]['commission_earned'] += $comm;
                $total_commission += $comm;
            }
        }
        
        uasort($stats, fn($a, $b) => $b['total_sales'] <=> $a['total_sales']);
        return ['associates' => $stats, 'total_sales' => $total_sales, 'total_commission' => $total_commission, 'order_count' => count($orders)];
    }
    
    public function ajax_export_commission() {
        check_ajax_referer('ffp_commission_nonce', 'nonce');
        if (!current_user_can('manage_options')) wp_die('Unauthorized');
        $data = $this->get_commission_stats(sanitize_text_field($_GET['start_date']), sanitize_text_field($_GET['end_date']));
        header('Content-Type: text/csv');
        header('Content-Disposition: attachment; filename="ffp-commission-' . $_GET['start_date'] . '-to-' . $_GET['end_date'] . '.csv"');
        $out = fopen('php://output', 'w');
        fputcsv($out, ['Name', 'Role', 'Orders', 'Total Sales', 'Commission Rate', 'Commission Earned']);
        foreach ($data['associates'] as $a) fputcsv($out, [$a['name'], $a['role'], $a['order_count'], '$' . number_format($a['total_sales'], 2), $a['earns_commission'] ? ($a['rate'] * 100) . '%' : 'N/A', $a['earns_commission'] ? '$' . number_format($a['commission_earned'], 2) : 'N/A']);
        fputcsv($out, []);
        fputcsv($out, ['TOTALS', '', $data['order_count'], '$' . number_format($data['total_sales'], 2), '', '$' . number_format($data['total_commission'], 2)]);
        fclose($out);
        exit;
    }
    
    public function render_export_page() {
        echo '<div class="wrap"><h1>📄 Export Commission Data</h1><div style="background:#fff;padding:30px;border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,0.1);max-width:500px;margin-top:20px;"><form method="get" action="' . admin_url('admin-ajax.php') . '"><input type="hidden" name="action" value="ffp_export_commission"><input type="hidden" name="nonce" value="' . wp_create_nonce('ffp_commission_nonce') . '"><p><label><strong>Start Date</strong></label><br><input type="date" name="start_date" value="' . date('Y-m-01') . '" style="width:100%;padding:10px;border-radius:8px;border:1px solid #ddd;"></p><p><label><strong>End Date</strong></label><br><input type="date" name="end_date" value="' . date('Y-m-d') . '" style="width:100%;padding:10px;border-radius:8px;border:1px solid #ddd;"></p><p><button type="submit" style="background:linear-gradient(135deg,#00c853,#00b4d8);color:#fff;border:none;padding:15px 30px;border-radius:10px;font-weight:700;cursor:pointer;width:100%;">⬇️ Download CSV</button></p></form></div></div>';
    }
    
    public function render_head_to_head() {
        $nonce = wp_create_nonce('ffp_commission_nonce');
        echo '<div class="wrap"><h1>⚔️ Head to Head</h1><div style="background:#fff;padding:30px;border-radius:16px;box-shadow:0 4px 20px rgba(0,0,0,0.1);margin-top:20px;"><div style="display:flex;gap:20px;margin-bottom:30px;flex-wrap:wrap;align-items:center;"><select id="h2h-rep1" style="padding:12px;border-radius:8px;border:2px solid #e0e0e0;font-size:16px;">';
        foreach ($this->associates as $k => $a) echo '<option value="' . $k . '">' . $a['name'] . '</option>';
        echo '</select><span style="font-size:32px;font-weight:800;color:#8b5cf6;">VS</span><select id="h2h-rep2" style="padding:12px;border-radius:8px;border:2px solid #e0e0e0;font-size:16px;">';
        $i = 0; foreach ($this->associates as $k => $a) { echo '<option value="' . $k . '"' . ($i === 1 ? ' selected' : '') . '>' . $a['name'] . '</option>'; $i++; }
        echo '</select><button id="h2h-compare" style="background:linear-gradient(135deg,#00c853,#00b4d8);color:#fff;border:none;padding:12px 30px;border-radius:10px;font-weight:700;cursor:pointer;">Compare</button></div><div id="h2h-results" style="display:grid;grid-template-columns:1fr 1fr;gap:30px;"><div style="text-align:center;padding:40px;background:#f8f9fa;border-radius:12px;">Select reps and click Compare</div><div></div></div></div></div>';
        echo '<script>jQuery(function($){$("#h2h-compare").on("click",function(){$.post(ajaxurl,{action:"ffp_get_head_to_head",nonce:"' . $nonce . '",rep1:$("#h2h-rep1").val(),rep2:$("#h2h-rep2").val()},function(r){if(r.success){const d=r.data;let html="";[d.rep1,d.rep2].forEach((rep,i)=>{const wins=[];if(i===0){if(d.rep1.total>d.rep2.total)wins.push("total");if(d.rep1.orders>d.rep2.orders)wins.push("orders");if(d.rep1.aov>d.rep2.aov)wins.push("aov");if(d.rep1.highest>d.rep2.highest)wins.push("highest");if(d.rep1.streak>d.rep2.streak)wins.push("streak");}else{if(d.rep2.total>d.rep1.total)wins.push("total");if(d.rep2.orders>d.rep1.orders)wins.push("orders");if(d.rep2.aov>d.rep1.aov)wins.push("aov");if(d.rep2.highest>d.rep1.highest)wins.push("highest");if(d.rep2.streak>d.rep1.streak)wins.push("streak");}html+=`<div style="background:linear-gradient(135deg,${wins.length>2?"rgba(0,200,83,0.1)":"#f8f9fa"},#fff);padding:30px;border-radius:16px;border:2px solid ${wins.length>2?"#00c853":"#e0e0e0"};"><h2 style="margin:0 0 5px 0;font-size:28px;">${rep.name}</h2><p style="color:#888;margin:0 0 20px 0;">${rep.role}</p><div style="font-size:36px;font-weight:800;color:#00c853;margin-bottom:20px;">$${rep.total.toLocaleString("en-US",{minimumFractionDigits:2})}</div><div style="display:grid;gap:10px;"><div style="display:flex;justify-content:space-between;padding:10px;background:${wins.includes("orders")?"rgba(0,200,83,0.1)":"#f8f9fa"};border-radius:8px;"><span>Orders</span><strong>${rep.orders}</strong></div><div style="display:flex;justify-content:space-between;padding:10px;background:${wins.includes("aov")?"rgba(0,200,83,0.1)":"#f8f9fa"};border-radius:8px;"><span>Avg Order</span><strong>$${rep.aov.toLocaleString("en-US",{minimumFractionDigits:2})}</strong></div><div style="display:flex;justify-content:space-between;padding:10px;background:${wins.includes("highest")?"rgba(0,200,83,0.1)":"#f8f9fa"};border-radius:8px;"><span>Highest</span><strong>$${rep.highest.toLocaleString("en-US",{minimumFractionDigits:2})}</strong></div><div style="display:flex;justify-content:space-between;padding:10px;background:${wins.includes("streak")?"rgba(0,200,83,0.1)":"#f8f9fa"};border-radius:8px;"><span>Streak</span><strong>${rep.streak} days</strong></div></div></div>`;});$("#h2h-results").html(html);}});});});</script>';
    }

    public function render_dashboard() {
        $default_start = date('Y-m-01');
        $default_end = date('Y-m-d');
        $initial_data = $this->get_commission_stats($default_start, $default_end);
        $initial_data['on_fire'] = $this->get_on_fire_reps();
        $initial_data['monthly_champion'] = $this->get_monthly_champion();
        $initial_data['achievements'] = $this->get_recent_achievements();
        include(plugin_dir_path(__FILE__) . 'templates/dashboard.php');
    }
    
    public function render_tv_mode() {
        $data = $this->get_commission_stats(date('Y-m-01'), date('Y-m-d'));
        $data['on_fire'] = $this->get_on_fire_reps();
        include(plugin_dir_path(__FILE__) . 'templates/tv-mode.php');
        exit;
    }
}

new FFP_Sales_Commission_Tracker();
 RTR 2024-2025 Ford Mustang Chin Splitter | 11011.0004.12.A - Function Factory Performance
Our favorite time of the year. USE CODE: FULLSEND25 |  Call 805-267-9762 to connect with an expert.
🎉 New Year Sale Start 2026 with Free Shipping + Exclusive Deals FULLSEND25 📞 805-267-9762

RTR 2024-2025 Ford Mustang Chin Splitter

  • Fits 2024+ Mustang EcoBoost & GT
  • Modern aggressive design
  • Satin black finish
  • Made from durable, injection-molded ASA plastic
  • RTR Undertray Extension is not required but recommended
  • Straight forward installation – no cutting required
  • Due to package dimensions – this item has a $100 Handling Fee
$399.99

Available

Category: SKU: 11011.0004.12.A

The RTR Chin Splitter is now available for the 2024+ Mustang EcoBoost and GT models! Our modern, aggressive design will give your S650 Mustang an all-new look. It’s made from durable, injection-molded ASA plastic for durability and finished in an automotive-grade Satin Black paint for added resistance to the elements. Plus, you can choose to install the RTR Undertray Extension for further customization.

The optional RTR Undertray Extension smooths airflow between the RTR Chin Splitter and OEM Belly Pan to further enhance lift reduction and added stiffness.

Installation is easy with no cutting required—all you need are basic hand tools to get the job done quickly. Upgrade your Mustang with the RTR Chin Splitter today.

FITMENT GUIDE

Year Model
2024+ Ford® Mustang EcoBoost, GT

First Class Customer Service & Satisfaction.

At Function Factory Performance, customer service is our top priority. We know that finding the right parts can be overwhelming, so we’re here to make the process smooth and enjoyable. We’re always ahead of the curve with our commitment to education and awareness. Let’s make this experience simple and awesome together! Don’t hesitate to call us at (480) 576-8606 or click here to reach us via email.

Make sure to follow us on Instagram: @FFPerformanceAZ and Youtube.

EMAIL A FACTORY SPECIALIST FOR HELP CALL A FACTORY SPECIALIST NOW

Reviews

There are no reviews yet

Be the first to review “RTR 2024-2025 Ford Mustang Chin Splitter”

Your email address will not be published. Required fields are marked *

💡 Quick Answers

FREQUENTLY ASKED QUESTIONS

📦 How long does it take for my parts to ship? +

If it's in stock and ready to roll, your order usually hits the road within 1–3 business days.

For made-to-order or specialty items (like carbon fiber parts or custom builds), the turnaround can take up to 8 weeks — perfection takes time.

Either way, we'll keep you updated so you know exactly when your parts are leaving the pit lane.

🚚 Do you send tracking with my order? +

Absolutely! Once your order ships, you'll receive an email with a tracking link so you can follow its journey from our shop to your doorstep.

If your order ships via freight, you'll get a separate email with a direct link to the carrier's tracking page — easy and stress-free.

🛡️ What if my parts get lost or damaged? +

Things happen on the road — even to boxes. If your order arrives damaged, snap a few clear photos of the box and product and send them our way right away.

If your shipment is lost, just email or call us — we'll help track it down and guide you through the next steps to make it right.

❤️ What can I do to help FFP? +

Simple — spread the horsepower! Follow us on Instagram, YouTube, and Facebook, and most importantly, drop us a review on Google or Yelp to let others know about your experience.

Your feedback helps us grow, create more content, and keep bringing performance-driven parts to the community. 🏁

🏎️
Ready to Order?

1ST CLASS SERVICE

805-267-9762

or email Support@FFPerformance.co

Car parts can be a maze — good thing we brought the map. Our team's here to keep things smooth, simple, and maybe even a little fun.

📞 Click To Call Now

Follow us for builds, tips & giveaways

@FFPerformanceAZ
👤
Customer Support Specialist
Product Guaranteed
🏁
Race Proven Knowledge
🔒
Payments Verified