diff --git a/app/Http/Controllers/Admin/PlatformOrderController.php b/app/Http/Controllers/Admin/PlatformOrderController.php index 906f949..ec067c3 100644 --- a/app/Http/Controllers/Admin/PlatformOrderController.php +++ b/app/Http/Controllers/Admin/PlatformOrderController.php @@ -40,6 +40,8 @@ class PlatformOrderController extends Controller 'remark' => (string) $request->query('remark', ''), // back:用于创建成功后回到来源页(例如订阅详情) 'back' => (string) $request->query('back', ''), + // 线索联动:用于从开通线索进入下单页,需透传到 form hidden input + 'lead_id' => (int) $request->query('lead_id', 0), ]; // back 安全阀:必须为站内相对路径,并拒绝引号/尖括号。 diff --git a/resources/views/admin/platform_orders/form.blade.php b/resources/views/admin/platform_orders/form.blade.php index 1f32fcd..89d2fad 100644 --- a/resources/views/admin/platform_orders/form.blade.php +++ b/resources/views/admin/platform_orders/form.blade.php @@ -30,6 +30,8 @@ + + @php $backVal = (string) old('back', $defaults['back'] ?? ''); @endphp diff --git a/tests/Feature/AdminPlatformOrderCreateShouldKeepLeadIdTest.php b/tests/Feature/AdminPlatformOrderCreateShouldKeepLeadIdTest.php new file mode 100644 index 0000000..e91413d --- /dev/null +++ b/tests/Feature/AdminPlatformOrderCreateShouldKeepLeadIdTest.php @@ -0,0 +1,67 @@ +seed(); + + $this->post('/admin/login', [ + 'email' => 'platform.admin@demo.local', + 'password' => 'Platform@123456', + ])->assertRedirect('/admin'); + } + + public function test_create_should_render_hidden_lead_id_input_when_present_in_query(): void + { + $this->loginAsPlatformAdmin(); + + $merchant = Merchant::query()->firstOrFail(); + + $plan = Plan::query()->create([ + 'code' => 'lead_id_create_order_plan', + 'name' => '下单页lead_id透传测试套餐', + 'billing_cycle' => 'monthly', + 'price' => 10, + 'list_price' => 10, + 'status' => 'active', + 'sort' => 10, + 'published_at' => now(), + ]); + + $lead = PlatformLead::query()->create([ + 'name' => 'lead_id线索', + 'mobile' => '13800000005', + 'email' => 'lead5@example.com', + 'company' => 'lead_id公司', + 'source' => 'test', + 'status' => 'new', + 'plan_id' => $plan->id, + 'meta' => ['merchant_id' => $merchant->id], + ]); + + $url = '/admin/platform-orders/create?' . Arr::query([ + 'merchant_id' => $merchant->id, + 'plan_id' => $plan->id, + 'lead_id' => $lead->id, + 'back' => '/admin/platform-leads', + ]); + + $res = $this->get($url); + $res->assertOk(); + + $res->assertSee('name="lead_id"', false); + $res->assertSee('value="' . $lead->id . '"', false); + } +}