海南旅游SAAS
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

102 lines
2.8 KiB

4 years ago
  1. <?php
  2. namespace App\AdminAgent\Controllers;
  3. use App\AdminAgent\Metrics\Examples\FinanceStatistics;
  4. use App\AdminAgent\Metrics\Examples\OrderStatistics;
  5. use App\AdminAgent\Metrics\Examples\ProductStatistics;
  6. use App\AdminAgent\Metrics\Examples\UserStatistics;
  7. use App\Common\OrderStatus;
  8. use App\Common\ProductStatus;
  9. use App\Models\AgentProduct;
  10. use App\Models\Order;
  11. use App\Models\OrderProductItem;
  12. use Dcat\Admin\Admin;
  13. use Dcat\Admin\Layout\Column;
  14. use Dcat\Admin\Layout\Content;
  15. use Dcat\Admin\Layout\Row;
  16. use Dcat\Admin\Http\Controllers\AdminController;
  17. use Dcat\Admin\Widgets\Card;
  18. use Illuminate\Support\Arr;
  19. class ProductStatisticsController extends AdminController
  20. {
  21. public function index(Content $content)
  22. {
  23. Admin::style(
  24. <<<CSS
  25. .col-sm-12.d-flex{
  26. display: inline-block !important;
  27. }
  28. CSS
  29. );
  30. //数据
  31. //订单
  32. return $content
  33. ->body(
  34. <<<HTML
  35. <div class="content-header">
  36. <section class="content-header breadcrumbs-top">
  37. <h1 class=" float-left">
  38. <span class="text-capitalize">商品统计</span>
  39. </h1>
  40. <div class="clearfix"></div>
  41. </section>
  42. </div>
  43. HTML
  44. )
  45. ->body(function (Row $row){
  46. $row->column(4, function (Column $column) {
  47. $column->row(Card::make('总数', function () {
  48. $count = AgentProduct::query()->where('agent_id',Admin::user()->id)->count();
  49. return <<<HTML
  50. <div class="d-flex justify-content-between align-items-center mt-1" style="margin-bottom: 2px">
  51. <h2 class="ml-1 font-large-1 text-primary">$count</h2>
  52. </div>
  53. HTML;
  54. }));
  55. });
  56. $row->column(4, function (Column $column) {
  57. $column->row(Card::make('上架', function () {
  58. $profit = AgentProduct::query()->where('agent_id',Admin::user()->id)->where('status',ProductStatus::ON_SALE)->count();
  59. return <<<HTML
  60. <div class="d-flex justify-content-between align-items-center mt-1" style="margin-bottom: 2px">
  61. <h2 class="ml-1 font-large-1 text-primary">$profit</h2>
  62. </div>
  63. HTML;
  64. }));
  65. });
  66. $row->column(4, function (Column $column) {
  67. $column->row(Card::make('下架', function () {
  68. $unSale = AgentProduct::query()
  69. ->where('agent_id',Admin::user()->id)
  70. ->where('status',ProductStatus::SOLD_OUT)
  71. ->count();
  72. return <<<HTML
  73. <div class="d-flex justify-content-between align-items-center mt-1" style="margin-bottom: 2px">
  74. <h2 class="ml-1 font-large-1 text-primary">$unSale</h2>
  75. </div>
  76. HTML;
  77. }));
  78. });
  79. })
  80. ->body(function (Row $row){
  81. $row->column(12,new ProductStatistics()
  82. );
  83. });
  84. }
  85. }