海南旅游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.

97 lines
2.7 KiB

4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
  1. <?php
  2. namespace App\AdminAgent\Controllers;
  3. use App\AdminAgent\Metrics\Examples\FinanceStatistics;
  4. use App\Common\OrderStatus;
  5. use App\Models\Order;
  6. use App\Models\OrderProductItem;
  7. use Dcat\Admin\Admin;
  8. use Dcat\Admin\Layout\Column;
  9. use Dcat\Admin\Layout\Content;
  10. use Dcat\Admin\Layout\Row;
  11. use Dcat\Admin\Http\Controllers\AdminController;
  12. use Dcat\Admin\Widgets\Card;
  13. class FinanceStatisticsController extends AdminController
  14. {
  15. public function index(Content $content)
  16. {
  17. Admin::style(
  18. <<<CSS
  19. .col-sm-12.d-flex{
  20. display: inline-block !important;
  21. }
  22. CSS
  23. );
  24. //数据
  25. //金额
  26. $price = Order::query()->where('agent_id',Admin::user()->id)->complete()->sum('price');
  27. //利润
  28. $costPrice = OrderProductItem::query()->where('agent_id',Admin::user()->id)->whereHas('order',function ($query) {
  29. $query->complete();
  30. })->sum('price');
  31. $profit = bcsub($price,$costPrice,2);
  32. //已完成订单
  33. $count = Order::query()->where('agent_id',Admin::user()->id)->complete()->count();
  34. return $content
  35. ->body(
  36. <<<HTML
  37. <div class="content-header">
  38. <section class="content-header breadcrumbs-top">
  39. <h1 class=" float-left">
  40. <span class="text-capitalize">财务统计</span>
  41. </h1>
  42. <div class="clearfix"></div>
  43. </section>
  44. </div>
  45. HTML
  46. )
  47. ->body(function (Row $row) use ($price, $profit, $count) {
  48. $row->column(4, function (Column $column) use ($price) {
  49. $column->row(Card::make('金额', function () use ($price) {
  50. return <<<HTML
  51. <div class="d-flex justify-content-between align-items-center mt-1" style="margin-bottom: 2px">
  52. <h2 class="ml-1 font-large-1 text-primary">$price</h2>
  53. </div>
  54. HTML;
  55. }));
  56. });
  57. $row->column(4, function (Column $column) use ($profit) {
  58. $column->row(Card::make('利润', function () use ($profit) {
  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) use ($count) {
  67. $column->row(Card::make('已完成订单', function () use ($count) {
  68. return <<<HTML
  69. <div class="d-flex justify-content-between align-items-center mt-1" style="margin-bottom: 2px">
  70. <h2 class="ml-1 font-large-1 text-primary">$count</h2>
  71. </div>
  72. HTML;
  73. }));
  74. });
  75. })
  76. ->body(function (Row $row){
  77. $row->column(12,new FinanceStatistics()
  78. );
  79. });
  80. }
  81. }