浏览代码

fleat: warning

igb 2 周之前
父节点
当前提交
dcaadf2ce9
共有 2 个文件被更改,包括 497 次插入3 次删除
  1. 494 0
      customer_detail.php
  2. 3 3
      statistics_order_warnings.php

+ 494 - 0
customer_detail.php

@@ -0,0 +1,494 @@
+<?php
+require_once 'conn.php';
+checkLogin();
+
+$id = $_GET['id'] ?? '';
+$from_warning = isset($_GET['from_warning']) ? true : false;
+
+// Validate and fetch customer data
+if (!empty($id) && is_numeric($id)) {
+    // Fetch customer basic information
+    $sql = "SELECT c.*, e.em_user as employee_name FROM customer c 
+            JOIN employee e ON c.cs_belong = e.id
+            WHERE c.id = ?";
+    
+    $stmt = $conn->prepare($sql);
+    $stmt->bind_param("i", $id);
+    $stmt->execute();
+    $result = $stmt->get_result();
+    
+    if ($row = $result->fetch_assoc()) {
+        $customer = [
+            'id' => $row['id'],
+            'cs_code' => textUncode($row['cs_code']),
+            'cs_company' => textUncode($row['cs_company']),
+            'cs_address' => textUncode($row['cs_address']),
+            'cs_deal' => textUncode($row['cs_deal']),
+            'cs_addtime' => $row['cs_addtime'],
+            'cs_belongclient' => $row['cs_belongclient'],
+            'cs_updatetime' => $row['cs_updatetime'],
+            'cs_from' => $row['cs_from'],
+            'cs_country' => $row['cs_country'],
+            'cs_type' => $row['cs_type'],
+            'cs_note' => htmlUnCode($row['cs_note']),
+            'cs_claimFrom' => $row['cs_claimFrom'],
+            'cs_belong' => $row['cs_belong'],
+            'employee_name' => $row['employee_name']
+        ];
+        
+        // Fetch all contact records for this customer
+        $contactSql = "SELECT cc.* FROM customer_contact cc WHERE cc.customer_id = ?";
+        $contactStmt = $conn->prepare($contactSql);
+        $contactStmt->bind_param("i", $id);
+        $contactStmt->execute();
+        $contactResult = $contactStmt->get_result();
+        
+        $contacts = [];
+        while ($contactRow = $contactResult->fetch_assoc()) {
+            $contact = [
+                'id' => $contactRow['id'],
+                'contact_name' => textUncode($contactRow['contact_name']),
+                'created_at' => $contactRow['created_at'],
+                'updated_at' => $contactRow['updated_at']
+            ];
+            
+            // Process each contact method type (up to 3 entries each)
+            $methodTypes = ['tel', 'email', 'whatsapp', 'wechat', 'linkedin', 'facebook', 'alibaba'];
+            foreach ($methodTypes as $type) {
+                for ($i = 1; $i <= 3; $i++) {
+                    $fieldBase = $type . '_' . $i;
+                    $contact[$fieldBase] = textUncode($contactRow[$fieldBase]);
+                    if ($type == 'tel' || $type == 'whatsapp') {
+                        $contact[$fieldBase . '_format'] = textUncode($contactRow[$fieldBase . '_format']);
+                    }
+                }
+            }
+            
+            $contacts[] = $contact;
+        }
+        
+        // Get channel information
+        $channelSql = "SELECT ch_name FROM qudao WHERE id = ?";
+        $channelStmt = $conn->prepare($channelSql);
+        $channelStmt->bind_param("i", $customer['cs_from']);
+        $channelStmt->execute();
+        $channelResult = $channelStmt->get_result();
+        if ($channelRow = $channelResult->fetch_assoc()) {
+            $customer['cs_from_name'] = $channelRow['ch_name'];
+        } else {
+            $customer['cs_from_name'] = '未知';
+        }
+        
+        // Get country information
+        $countrySql = "SELECT countryName FROM country WHERE id = ?";
+        $countryStmt = $conn->prepare($countrySql);
+        $countryStmt->bind_param("i", $customer['cs_country']);
+        $countryStmt->execute();
+        $countryResult = $countryStmt->get_result();
+        if ($countryRow = $countryResult->fetch_assoc()) {
+            $customer['country_name'] = $countryRow['countryName'];
+        } else {
+            $customer['country_name'] = '未知';
+        }
+        
+        // Get client type information
+        $typeSql = "SELECT businessType FROM clienttype WHERE id = ?";
+        $typeStmt = $conn->prepare($typeSql);
+        $typeStmt->bind_param("i", $customer['cs_type']);
+        $typeStmt->execute();
+        $typeResult = $typeStmt->get_result();
+        if ($typeRow = $typeResult->fetch_assoc()) {
+            $customer['cs_type_name'] = $typeRow['businessType'];
+        } else {
+            $customer['cs_type_name'] = '未知';
+        }
+        
+        // Get customer tags
+        $tagSql = "SELECT tagName FROM tagtable WHERE customerId = ?";
+        $tagStmt = $conn->prepare($tagSql);
+        $tagStmt->bind_param("i", $id);
+        $tagStmt->execute();
+        $tagResult = $tagStmt->get_result();
+        $tags = [];
+        while ($tagRow = $tagResult->fetch_assoc()) {
+            $tags[] = textUncode($tagRow['tagName']);
+        }
+        
+        // Get order history
+        $orderSql = "SELECT o.*, e.em_user as sales_rep 
+                   FROM orders o 
+                   JOIN employee e ON o.employee_id = e.id 
+                   WHERE o.customer_id = ? 
+                   ORDER BY o.order_date DESC";
+        $orderStmt = $conn->prepare($orderSql);
+        $orderStmt->bind_param("i", $id);
+        $orderStmt->execute();
+        $orderResult = $orderStmt->get_result();
+        $orders = [];
+        while ($orderRow = $orderResult->fetch_assoc()) {
+            $orders[] = $orderRow;
+        }
+    } else {
+        echo "<script>alert('客户不存在!');history.back();</script>";
+        exit;
+    }
+} else {
+    echo "<script>alert('客户不存在!');history.back();</script>";
+    exit;
+}
+
+// Helper functions
+function getDealStageText($stage) {
+    $stages = [
+        '0' => '无响应',
+        '1' => '背景调查',
+        '2' => '明确需求',
+        '3' => '已成交'
+    ];
+    return $stages[$stage] ?? '未知';
+}
+
+function getOrderStatusText($status) {
+    $statuses = [
+        '0' => '已取消',
+        '1' => '待确认',
+        '2' => '已确认',
+        '3' => '生产中',
+        '4' => '已发货',
+        '5' => '已完成'
+    ];
+    return $statuses[$status] ?? '未知';
+}
+
+function getPaymentStatusText($status) {
+    $statuses = [
+        '0' => '未付款',
+        '1' => '部分付款',
+        '2' => '已付清'
+    ];
+    return $statuses[$status] ?? '未知';
+}
+?>
+<!DOCTYPE html>
+<html xmlns="http://www.w3.org/1999/xhtml">
+<head>
+    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
+    <title>客户详情</title>
+    <link rel="stylesheet" href="css/common.css" type="text/css" />
+    <script src="system/js/jquery-1.7.2.min.js"></script>
+    <script src="js/js.js"></script>
+    <style>
+        body {
+            margin: 0;
+            padding: 20px;
+            background: #fff;
+        }
+        #man_zone {
+            margin-left: 0;
+        }
+        .detail-container {
+            margin-bottom: 20px;
+            width: 100%;
+        }
+        .section-title {
+            font-size: 18px;
+            font-weight: bold;
+            margin: 15px 0 10px 0;
+            padding-bottom: 5px;
+            border-bottom: 1px solid #eee;
+        }
+        .data-table {
+            width: 100%;
+            border-collapse: collapse;
+            margin-bottom: 20px;
+        }
+        .data-table th {
+            background-color: #f5f5f5;
+            padding: 8px;
+            text-align: left;
+            font-weight: bold;
+            width: 150px;
+        }
+        .data-table td {
+            padding: 8px;
+            vertical-align: top;
+            border-bottom: 1px solid #eee;
+        }
+        .contact-card {
+            border: 1px solid #eee;
+            padding: 15px;
+            margin-bottom: 15px;
+            border-radius: 5px;
+            background-color: #fafafa;
+        }
+        .contact-card h3 {
+            margin-top: 0;
+            margin-bottom: 10px;
+            font-size: 16px;
+        }
+        .contact-method {
+            margin-bottom: 8px;
+        }
+        .contact-type {
+            font-weight: bold;
+            margin-right: 10px;
+            display: inline-block;
+            min-width: 80px;
+        }
+        .tag-container {
+            display: flex;
+            flex-wrap: wrap;
+            gap: 8px;
+        }
+        .tag {
+            background-color: #f1f1f1;
+            padding: 4px 8px;
+            border-radius: 4px;
+            font-size: 12px;
+        }
+        .orders-table {
+            width: 100%;
+            border-collapse: collapse;
+        }
+        .orders-table th, .orders-table td {
+            padding: 8px;
+            text-align: left;
+            border: 1px solid #ddd;
+        }
+        .orders-table th {
+            background-color: #f5f5f5;
+        }
+        .orders-table tr:nth-child(even) {
+            background-color: #fafafa;
+        }
+        .btn-container {
+            margin-top: 20px;
+            display: flex;
+            gap: 10px;
+        }
+        .btn {
+            padding: 8px 16px;
+            border-radius: 4px;
+            cursor: pointer;
+            text-decoration: none;
+            display: inline-block;
+            text-align: center;
+        }
+        .btn-primary {
+            background-color: #2196f3;
+            color: white;
+            border: none;
+        }
+        .btn-secondary {
+            background-color: #f5f5f5;
+            color: #333;
+            border: 1px solid #ddd;
+        }
+        .status-badge {
+            display: inline-block;
+            padding: 3px 8px;
+            border-radius: 12px;
+            font-size: 12px;
+            background-color: #e0e0e0;
+        }
+        .status-badge.success {
+            background-color: #4caf50;
+            color: white;
+        }
+        .status-badge.warning {
+            background-color: #ff9800;
+            color: white;
+        }
+        .status-badge.danger {
+            background-color: #f44336;
+            color: white;
+        }
+        .status-badge.info {
+            background-color: #2196f3;
+            color: white;
+        }
+    </style>
+</head>
+<body class="clear">
+<?php // require_once 'panel.php'; ?>
+<div id="man_zone">
+    <div class="detail-container">
+        <h1>客户详情</h1>
+        
+        <!-- 基本信息 -->
+        <div class="section-title">基本信息</div>
+        <table class="data-table">
+            <tr>
+                <th>客户编号</th>
+                <td><?php echo htmlspecialchars($customer['cs_code']); ?></td>
+            </tr>
+            <tr>
+                <th>公司名称</th>
+                <td><?php echo htmlspecialchars($customer['cs_company']); ?></td>
+            </tr>
+            <tr>
+                <th>地区</th>
+                <td><?php echo htmlspecialchars($customer['country_name']); ?></td>
+            </tr>
+            <tr>
+                <th>地址</th>
+                <td><?php echo htmlspecialchars($customer['cs_address']); ?></td>
+            </tr>
+            <tr>
+                <th>业务员</th>
+                <td><?php echo htmlspecialchars($customer['employee_name']); ?></td>
+            </tr>
+            <tr>
+                <th>客户来源</th>
+                <td><?php echo htmlspecialchars($customer['cs_from_name']); ?></td>
+            </tr>
+            <tr>
+                <th>业务类型</th>
+                <td><?php echo htmlspecialchars($customer['cs_type_name']); ?></td>
+            </tr>
+            <tr>
+                <th>跟进阶段</th>
+                <td>
+                    <?php 
+                    $dealStage = getDealStageText($customer['cs_deal']);
+                    $dealClass = $customer['cs_deal'] == 3 ? 'success' : ($customer['cs_deal'] == 0 ? 'danger' : 'info');
+                    echo '<span class="status-badge ' . $dealClass . '">' . htmlspecialchars($dealStage) . '</span>';
+                    ?>
+                </td>
+            </tr>
+            <tr>
+                <th>其他</th>
+                <td>
+                    <?php if ($customer['cs_belongclient'] == 1): ?>
+                    <span class="status-badge">客户的客户</span>
+                    <?php endif; ?>
+                </td>
+            </tr>
+            <tr>
+                <th>添加时间</th>
+                <td><?php echo $customer['cs_addtime']; ?></td>
+            </tr>
+            <tr>
+                <th>最后更新</th>
+                <td><?php echo $customer['cs_updatetime']; ?></td>
+            </tr>
+        </table>
+        
+        <!-- 联系人信息 -->
+        <div class="section-title">联系人信息</div>
+        <?php if (empty($contacts)): ?>
+            <p>没有联系人信息</p>
+        <?php else: ?>
+            <?php foreach ($contacts as $contact): ?>
+            <div class="contact-card">
+                <h3><?php echo htmlspecialchars($contact['contact_name']); ?></h3>
+                
+                <?php
+                $methodTypes = [
+                    'tel' => '电话',
+                    'wechat' => '微信',
+                    'whatsapp' => 'WhatsApp',
+                    'email' => '邮箱',
+                    'linkedin' => '领英',
+                    'facebook' => 'Facebook',
+                    'alibaba' => '阿里巴巴'
+                ];
+                
+                foreach ($methodTypes as $type => $label) {
+                    for ($i = 1; $i <= 3; $i++) {
+                        $fieldName = $type . '_' . $i;
+                        if (!empty($contact[$fieldName])) {
+                            echo '<div class="contact-method">';
+                            echo '<span class="contact-type">' . $label . ':</span>';
+                            echo '<span>' . htmlspecialchars($contact[$fieldName]) . '</span>';
+                            echo '</div>';
+                        }
+                    }
+                }
+                ?>
+            </div>
+            <?php endforeach; ?>
+        <?php endif; ?>
+        
+        <!-- 自定义标签 -->
+        <div class="section-title">自定义标签</div>
+        <div class="tag-container">
+            <?php if (empty($tags)): ?>
+                <p>没有自定义标签</p>
+            <?php else: ?>
+                <?php foreach ($tags as $tag): ?>
+                <span class="tag"><?php echo htmlspecialchars($tag); ?></span>
+                <?php endforeach; ?>
+            <?php endif; ?>
+        </div>
+        
+        <!-- 备注信息 -->
+        <div class="section-title">备注信息</div>
+        <div><?php echo empty($customer['cs_note']) ? '无备注' : $customer['cs_note']; ?></div>
+        
+        <!-- 订单历史 -->
+        <div class="section-title">订单历史</div>
+        <?php if (empty($orders)): ?>
+            <p>没有订单记录</p>
+        <?php else: ?>
+            <table class="orders-table">
+                <thead>
+                    <tr>
+                        <th>订单编号</th>
+                        <th>下单日期</th>
+                        <th>订单金额</th>
+                        <th>订单状态</th>
+                        <th>付款状态</th>
+                        <th>业务员</th>
+                    </tr>
+                </thead>
+                <tbody>
+                    <?php foreach ($orders as $order): ?>
+                    <tr>
+                        <td><?php echo htmlspecialchars($order['order_code']); ?></td>
+                        <td><?php echo date('Y-m-d', strtotime($order['order_date'])); ?></td>
+                        <td><?php echo htmlspecialchars($order['currency']) . ' ' . number_format($order['total_amount'], 2); ?></td>
+                        <td>
+                            <?php 
+                            $statusText = getOrderStatusText($order['order_status']);
+                            $statusClass = '';
+                            if ($order['order_status'] == 5) $statusClass = 'success';
+                            else if ($order['order_status'] == 0) $statusClass = 'danger';
+                            else if ($order['order_status'] >= 2) $statusClass = 'info';
+                            else $statusClass = 'warning';
+                            echo '<span class="status-badge ' . $statusClass . '">' . htmlspecialchars($statusText) . '</span>';
+                            ?>
+                        </td>
+                        <td>
+                            <?php 
+                            $paymentText = getPaymentStatusText($order['payment_status']);
+                            $paymentClass = '';
+                            if ($order['payment_status'] == 2) $paymentClass = 'success';
+                            else if ($order['payment_status'] == 1) $paymentClass = 'warning';
+                            else $paymentClass = 'danger';
+                            echo '<span class="status-badge ' . $paymentClass . '">' . htmlspecialchars($paymentText) . '</span>';
+                            ?>
+                        </td>
+                        <td><?php echo htmlspecialchars($order['sales_rep']); ?></td>
+                    </tr>
+                    <?php endforeach; ?>
+                </tbody>
+            </table>
+        <?php endif; ?>
+        
+        <!-- 按钮 -->
+        <div class="btn-container">
+            <?php if ($from_warning): ?>
+                <a href="statistics_order_warnings.php" class="btn btn-secondary">返回预警列表</a>
+            <?php else: ?>
+                <a href="javascript:history.back();" class="btn btn-secondary">返回</a>
+            <?php endif; ?>
+            
+            <?php if ($_SESSION['employee_id'] == $customer['cs_belong']): ?>
+                <a href="customerEdit.php?id=<?php echo $id; ?>" class="btn btn-primary">编辑客户</a>
+            <?php endif; ?>
+        </div>
+    </div>
+</div>
+</body>
+</html> 

+ 3 - 3
statistics_order_warnings.php

@@ -209,7 +209,7 @@ include('statistics_header.php');
                     echo "<td class='{$change_class}'>" . $change_percent . "%</td>";
                     echo "<td>" . $customer['last_order_date'] . "</td>";
                     echo "<td>" . htmlspecialchars($customer['em_user']) . "</td>";
-                    echo "<td><a href='customer_detail.php?id=" . $customer['id'] . "' class='action-btn action-btn-view'>查看</a></td>";
+                    echo "<td><a href='customer_detail.php?id=" . $customer['id'] . "&from_warning=1' class='action-btn action-btn-view'>查看</a></td>";
                     echo "</tr>";
                 }
                 
@@ -267,7 +267,7 @@ include('statistics_header.php');
                     echo "<td>" . $customer['last_order_date'] . "</td>";
                     echo "<td>" . $customer['order_count'] . "</td>";
                     echo "<td>" . htmlspecialchars($customer['em_user']) . "</td>";
-                    echo "<td><a href='customer_detail.php?id=" . $customer['id'] . "' class='action-btn action-btn-view'>查看</a></td>";
+                    echo "<td><a href='customer_detail.php?id=" . $customer['id'] . "&from_warning=1' class='action-btn action-btn-view'>查看</a></td>";
                     echo "</tr>";
                 }
                 
@@ -330,7 +330,7 @@ include('statistics_header.php');
                     echo "<td>" . $customer['order_count'] . "</td>";
                     echo "<td>¥" . number_format($customer['total_amount'], 2) . "</td>";
                     echo "<td>" . htmlspecialchars($customer['em_user']) . "</td>";
-                    echo "<td><a href='customer_detail.php?id=" . $customer['id'] . "' class='action-btn action-btn-view'>查看</a></td>";
+                    echo "<td><a href='customer_detail.php?id=" . $customer['id'] . "&from_warning=1' class='action-btn action-btn-view'>查看</a></td>";
                     echo "</tr>";
                 }