Menu.php 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. <?php namespace Manage\Lib;
  2. use Dever;
  3. use Dever\Project;
  4. class Menu
  5. {
  6. # 初始化菜单
  7. public function init($name = '')
  8. {
  9. if ($name) {
  10. $app = array($name => Project::load($name));
  11. } else {
  12. $app = Project::read();
  13. }
  14. foreach ($app as $k => $v) {
  15. $base = $v['path'] . 'table/manage/core.php';
  16. if (is_file($base)) {
  17. $core = include $base;
  18. if ($core) {
  19. $this->add($k, $core);
  20. }
  21. }
  22. }
  23. return 'ok';
  24. }
  25. private function add($app, $core)
  26. {
  27. if (isset($core['system'])) {
  28. foreach ($core['system'] as $k => $v) {
  29. $where = array();
  30. $where['key'] = $k;
  31. $data = $where;
  32. $data['name'] = $v['name'];
  33. $data['sort'] = $v['sort'];
  34. $data['partition'] = $v['partition'] ?? 'no';
  35. $data['info_table'] = $v['info_table'];
  36. $data['user_table'] = $v['user_table'];
  37. $data['role_table'] = $v['role_table'];
  38. Dever::db('system', 'manage')->up($where, $data);
  39. }
  40. }
  41. if (isset($core['module'])) {
  42. foreach ($core['module'] as $k => $v) {
  43. $where = array();
  44. $where['key'] = $k;
  45. $data = $where;
  46. $data['name'] = $v['name'];
  47. $data['sort'] = $v['sort'];
  48. $data['system'] = $v['system'];
  49. $data['data_table'] = $v['data_table'];
  50. Dever::db('system_module', 'manage')->up($where, $data);
  51. }
  52. }
  53. if (isset($core['menu'])) {
  54. foreach ($core['menu'] as $k => $v) {
  55. $where = array();
  56. if (isset($v['app'])) {
  57. $app = $v['app'];
  58. }
  59. $where['app'] = $app;
  60. $where['key'] = $k;
  61. if (isset($v['parent'])) {
  62. $parent = Dever::db('menu', 'manage')->find(array('key' => $v['parent']));
  63. if ($parent) {
  64. $where['parent_id'] = $parent['id'];
  65. $where['module_id'] = $parent['module_id'];
  66. $where['level'] = 2;
  67. if ($parent['parent_id']) {
  68. $where['level'] = 3;
  69. }
  70. }
  71. } else {
  72. $where['level'] = 1;
  73. }
  74. if (isset($v['module'])) {
  75. $module = Dever::db('system_module', 'manage')->find(array('key' => $v['module']));
  76. if ($module) {
  77. $where['module_id'] = $module['id'];
  78. }
  79. }
  80. $data = $where;
  81. $data['name'] = $v['name'];
  82. $data['icon'] = $v['icon'];
  83. $data['sort'] = $v['sort'];
  84. if (isset($v['show'])) {
  85. $data['show'] = $v['show'];
  86. }
  87. if (isset($v['badge'])) {
  88. $data['badge'] = $v['badge'];
  89. }
  90. if (isset($v['path'])) {
  91. $data['path'] = $v['path'];
  92. } else {
  93. $data['path'] = 'main';
  94. }
  95. if (isset($v['link'])) {
  96. $data['link'] = $v['link'];
  97. }
  98. Dever::db('menu', 'manage')->up($where, $data);
  99. }
  100. }
  101. }
  102. public function getAll()
  103. {
  104. $data = Dever::db('menu', 'manage')->select(array('parent_id' => '0'));
  105. return $data;
  106. }
  107. }