Module.php 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. <?php
  2. namespace common\modules\rbac;
  3. use Yii;
  4. use yii\helpers\Inflector;
  5. /**
  6. * GUI manager for RBAC.
  7. *
  8. * Use [[\yii\base\Module::$controllerMap]] to change property of controller.
  9. * To change listed menu, use property [[$menus]].
  10. *
  11. * ~~~
  12. * 'layout' => 'left-menu', // default to null mean use application layout.
  13. * 'controllerMap' => [
  14. * 'assignment' => [
  15. * 'class' => 'rbac\controllers\AssignmentController',
  16. * 'userClassName' => 'app\models\User',
  17. * 'idField' => 'id'
  18. * ]
  19. * ],
  20. * 'menus' => [
  21. * 'assignment' => [
  22. * 'label' => 'Grand Access' // change label
  23. * ],
  24. * 'route' => null, // disable menu
  25. * ],
  26. * ~~~
  27. *
  28. * @property string $mainLayout Main layout using for module. Default to layout of parent module.
  29. * Its used when `layout` set to 'left-menu', 'right-menu' or 'top-menu'.
  30. * @property array $menus List avalible menu of module.
  31. * It generated by module items .
  32. *
  33. * @author Misbahul D Munir <misbahuldmunir@gmail.com>
  34. *
  35. * @since 1.0
  36. */
  37. class Module extends \yii\base\Module
  38. {
  39. /**
  40. * {@inheritdoc}
  41. */
  42. public $defaultRoute = 'assignment';
  43. /**
  44. * @var array
  45. *
  46. * @see [[items]]
  47. */
  48. private $_menus = [];
  49. /**
  50. * @var array
  51. *
  52. * @see [[items]]
  53. */
  54. private $_coreItems = [
  55. 'assignment' => 'Assignments',
  56. 'role' => 'Roles',
  57. 'permission' => 'Permissions',
  58. 'route' => 'Routes',
  59. 'rule' => 'Rules',
  60. 'menu' => 'Menus',
  61. ];
  62. /**
  63. * @var array
  64. *
  65. * @see [[items]]
  66. */
  67. private $_normalizeMenus;
  68. /**
  69. * Nav bar items.
  70. *
  71. * @var array
  72. */
  73. public $navbar;
  74. /**
  75. * @var string Main layout using for module. Default to layout of parent module.
  76. * Its used when `layout` set to 'left-menu', 'right-menu' or 'top-menu'.
  77. */
  78. public $mainLayout = '@mdm/admin/views/layouts/main.php';
  79. /**
  80. * {@inheritdoc}
  81. */
  82. public function init()
  83. {
  84. parent::init();
  85. if (!isset(Yii::$app->i18n->translations['rbac'])) {
  86. Yii::$app->i18n->translations['rbac'] = [
  87. 'class' => 'yii\i18n\PhpMessageSource',
  88. 'sourceLanguage' => 'en',
  89. 'basePath' => '@rbac/messages',
  90. 'fileMap' => ['rbac' => 'rbac-admin.php']
  91. ];
  92. }
  93. //user did not define the Navbar?
  94. if ($this->navbar === null) {
  95. $this->navbar = [
  96. ['label' => Yii::t('rbac', 'Help'), 'url' => 'https://github.com/mdmsoft/yii2-admin/blob/master/docs/guide/basic-usage.md'],
  97. ['label' => Yii::t('rbac', 'Application'), 'url' => Yii::$app->homeUrl],
  98. ];
  99. }
  100. }
  101. /**
  102. * Get avalible menu.
  103. *
  104. * @return array
  105. */
  106. public function getMenus()
  107. {
  108. if ($this->_normalizeMenus === null) {
  109. $mid = '/'.$this->getUniqueId().'/';
  110. // resolve core menus
  111. $this->_normalizeMenus = [];
  112. $config = components\Configs::instance();
  113. foreach ($this->_coreItems as $id => $lable) {
  114. if ($id !== 'menu' || ($config->db !== null && $config->db->schema->getTableSchema($config->menuTable) !== null)) {
  115. $this->_normalizeMenus[$id] = ['label' => Yii::t('rbac', $lable), 'url' => [$mid.$id]];
  116. }
  117. }
  118. foreach (array_keys($this->controllerMap) as $id) {
  119. $this->_normalizeMenus[$id] = ['label' => Yii::t('rbac', Inflector::humanize($id)), 'url' => [$mid.$id]];
  120. }
  121. // user configure menus
  122. foreach ($this->_menus as $id => $value) {
  123. if (empty($value)) {
  124. unset($this->_normalizeMenus[$id]);
  125. } else {
  126. if (is_string($value)) {
  127. $value = [
  128. 'label' => $value,
  129. ];
  130. }
  131. $this->_normalizeMenus[$id] = isset($this->_normalizeMenus[$id]) ? array_merge($this->_normalizeMenus[$id], $value) : $value;
  132. if (!isset($this->_normalizeMenus[$id]['url'])) {
  133. $this->_normalizeMenus[$id]['url'] = [$mid.$id];
  134. }
  135. }
  136. }
  137. }
  138. return $this->_normalizeMenus;
  139. }
  140. /**
  141. * Set or add avalible menu.
  142. *
  143. * @param array $menus
  144. */
  145. public function setMenus($menus)
  146. {
  147. $this->_menus = array_merge($this->_menus, $menus);
  148. $this->_normalizeMenus = null;
  149. }
  150. }