ServerGroupDataTable.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. <?php
  2. /* * ********************************************************************
  3. * WordPress Manager product developed. (Feb 5, 2018)
  4. * *
  5. *
  6. * CREATED BY MODULESGARDEN -> http://modulesgarden.com
  7. * CONTACT -> contact@modulesgarden.com
  8. *
  9. *
  10. * This software is furnished under a license and may be used and copied
  11. * only in accordance with the terms of such license and with the
  12. * inclusion of the above copyright notice. This software or any other
  13. * copies thereof may not be provided or otherwise made available to any
  14. * other person. No title to and ownership of the software is hereby
  15. * transferred.
  16. *
  17. *
  18. * ******************************************************************** */
  19. namespace ModulesGarden\ProxmoxAddon\App\UI\ServerGroup\Pages;
  20. use ModulesGarden\ProxmoxAddon as main;
  21. use ModulesGarden\ProxmoxAddon\App\UI\ServerGroup\Buttons\CreateButton;
  22. use ModulesGarden\ProxmoxAddon\App\UI\ServerGroup\Buttons\DeleteButton;
  23. use ModulesGarden\ProxmoxAddon\App\UI\ServerGroup\Buttons\DeleteMassButton;
  24. use ModulesGarden\ProxmoxAddon\Core\UI\Interfaces\AdminArea;
  25. use ModulesGarden\ProxmoxAddon\Core\UI\Widget\DataTable\Column;
  26. use ModulesGarden\ProxmoxAddon\Core\UI\Widget\DataTable\DataProviders\Providers\QueryDataProvider;
  27. use ModulesGarden\ProxmoxAddon\Core\UI\Widget\RawDataTable\RawDataTable;
  28. /**
  29. * Description of PluginInstalled
  30. *
  31. * @author Pawel Kopec <pawelk@modulesgardne.com>
  32. */
  33. class ServerGroupDataTable extends RawDataTable implements AdminArea
  34. {
  35. protected $id = 'serverGroup';
  36. protected $name = 'serverGroup';
  37. protected $title = 'serverGroupTitle';
  38. public function isRawTitle()
  39. {
  40. return false;
  41. }
  42. public function initContent()
  43. {
  44. //Create
  45. $this->addButton(new CreateButton);
  46. //Update
  47. $this->addActionButton(new main\App\UI\ServerGroup\Buttons\UpdateButton());
  48. //Delete
  49. $this->addActionButton(new DeleteButton);
  50. //Delete Mass
  51. $this->addMassActionButton(new DeleteMassButton);
  52. }
  53. public function replaceFieldCiuser($key, $row)
  54. {
  55. if ($row[$key])
  56. {
  57. return $row[$key];
  58. }
  59. return "-";
  60. }
  61. public function replaceFieldNode($key, $row)
  62. {
  63. $nodes = main\App\Models\ServerGroupItem::ofGroupId($row->id)->pluck("node")->toArray();
  64. return implode(", ", $nodes);
  65. }
  66. protected function loadHtml()
  67. {
  68. $sg = (new main\App\Models\ServerGroup())->getTable();
  69. $this->addColumn((new Column('id',$sg ))->setSearchable(true, Column::TYPE_STRING)->setOrderable('ASC'))
  70. ->addColumn((new Column('name', $sg))->setSearchable(true, Column::TYPE_STRING)->setOrderable())
  71. ->addColumn((new Column('node'))->setSearchable(true, Column::TYPE_STRING)->setOrderable())
  72. ->addColumn((new Column('created_at', $sg))->setSearchable(true, Column::TYPE_STRING)->setOrderable());
  73. }
  74. protected function loadData()
  75. {
  76. $serverId = (int)$this->getRequestValue('id');
  77. $sg = (new main\App\Models\ServerGroup())->getTable();
  78. $sgi = (new main\App\Models\ServerGroupItem())->getTable();
  79. $dataProv = new QueryDataProvider();
  80. $query = (new main\App\Models\ServerGroup())
  81. ->query()
  82. ->getQuery()
  83. ->select("{$sg}.id","{$sg}.name", "{$sg}.created_at")
  84. ->leftJoin($sgi,"{$sgi}.group_id", "=", "{$sg}.id")
  85. ->where("{$sg}.server_id", $serverId)
  86. ->groupBy("{$sg}.id");
  87. $dataProv->setDefaultSorting("name", 'ASC');
  88. $dataProv->setData( $query );
  89. $this->setDataProvider($dataProv);
  90. }
  91. }