Department.php 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. <?php
  2. namespace addons\department;
  3. use app\common\library\Menu;
  4. use think\Addons;
  5. use think\Db;
  6. use think\Lang;
  7. use think\Loader;
  8. /**
  9. * 插件
  10. */
  11. class Department extends Addons
  12. {
  13. /**
  14. * 插件安装方法
  15. * @return bool
  16. */
  17. public function install()
  18. {
  19. $menu = [];
  20. $config_file = ADDON_PATH . "department" . DS . 'config' . DS . "menu.php";
  21. if (is_file($config_file)) {
  22. $menu = include $config_file;
  23. }
  24. if ($menu) {
  25. Menu::create($menu);
  26. }
  27. $this->addField();
  28. return true;
  29. }
  30. /**
  31. * 插件卸载方法
  32. * @return bool
  33. */
  34. public function uninstall()
  35. {
  36. $info = get_addon_info('department');
  37. Menu::delete(isset($info['first_menu']) ? $info['first_menu'] : 'department');
  38. return true;
  39. }
  40. /**
  41. * 插件启用方法
  42. */
  43. public function enable()
  44. {
  45. $info = get_addon_info('department');
  46. Menu::enable(isset($info['first_menu']) ? $info['first_menu'] : 'department');
  47. }
  48. /**
  49. * 插件禁用方法
  50. */
  51. public function disable()
  52. {
  53. $info = get_addon_info('department');
  54. Menu::disable(isset($info['first_menu']) ? $info['first_menu'] : 'department');
  55. }
  56. /**
  57. * 插件升级方法
  58. */
  59. public function upgrade()
  60. {
  61. $this->addField();
  62. }
  63. /**
  64. * 添加语言包
  65. */
  66. public function appBegin()
  67. {
  68. $lang = \request()->langset();
  69. $lang = preg_match("/^([a-zA-Z\-_]{2,10})\$/i", $lang) ? $lang : 'zh-cn';
  70. //添加语言包
  71. Lang::load(ADDON_PATH . '/department/lang/' . $lang . '/' . $lang . '.php');
  72. }
  73. /**
  74. * 增加数据权限范围字段
  75. */
  76. private function addField()
  77. {
  78. $database = config('database');
  79. $isexits = Db::query("SELECT 1 FROM information_schema.COLUMNS WHERE table_name='{$database['prefix']}admin' AND COLUMN_NAME='data_scope' limit 1");
  80. if (!$isexits) {
  81. Db::query("ALTER TABLE {$database['prefix']}admin ADD `data_scope` tinyint(4) NULL COMMENT '0默认1全部'");
  82. }
  83. }
  84. }