Manageredit.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437
  1. <?php
  2. /*
  3. * 存放 一些基本的非数据库数据 如 html
  4. * 都是数组
  5. */
  6. namespace fecadmin\block\role;
  7. use Yii;
  8. use fec\helpers\CRequest;
  9. use fec\helpers\CUrl;
  10. use fec\helpers\CModel;
  11. use fec\helpers\CConfig;
  12. use fecadmin\models\AdminRole;
  13. use fecadmin\models\AdminMenu;
  14. use fecadmin\models\AdminRoleMenu;
  15. use fecadmin\models\AdminUserRole;
  16. use fec\helpers\CDB;
  17. class Manageredit{
  18. public $_param;
  19. public $_paramKey;
  20. public $_one;
  21. public function __construct(){
  22. $this->_paramKey = 'role_id';
  23. }
  24. # 初始化数据
  25. public function initParam(){
  26. $val = $this->_param[$this->_paramKey];
  27. if($val){
  28. $this->_one = AdminRole::find()->where([$this->_paramKey => $val])->one();
  29. }else{
  30. $this->_one = new AdminRole;
  31. }
  32. //$obj = $this->_obj;
  33. }
  34. # 传递给前端的数据 显示编辑form
  35. public function getLastData(){
  36. $request_param = CRequest::param();
  37. $this->_param = $request_param;
  38. $this->initParam();
  39. $reuturn['menu'] = self::getMenuStr();
  40. return [
  41. 'editBar' => $this->getEditBar(),
  42. 'saveUrl' => CUrl::getUrl('fecadmin/role/managereditsave'),
  43. 'menu' => self::getMenuStr(),
  44. ];
  45. }
  46. public function getSelectedMenuId(){
  47. $role_name_id = $this->_id;
  48. $selected_men = Systemrole::find()->where(['role_name_id' => $role_name_id ])->all();
  49. $menu_ids = [];
  50. foreach($selected_men as $d){
  51. $menu_ids[] = $d['menu_id'];
  52. }
  53. $this->_menu_ids_str = implode(",",$menu_ids);
  54. return $menu_ids;
  55. }
  56. # 得到菜单内容
  57. public function getMenuStr(){
  58. //$menu_ids = $this->getSelectedMenuId();
  59. # 执行一下 让 文件menu.php 和 数据库 中的菜单数据 进行核对。
  60. //\backend\models\core\Menu::checkMenu();
  61. $roleId = $this->_param[$this->_paramKey];
  62. if($roleId){
  63. $selected_menu_ids = $this->getDbRoleMenuIds($roleId);
  64. }else{
  65. $selected_menu_ids = [];
  66. }
  67. $AdminMenu = new AdminMenu();
  68. $menuStr = $AdminMenu->getRoloEditMenuTreeHtml($selected_menu_ids);
  69. return $menuStr;
  70. }
  71. # 保存
  72. public function save(){
  73. $request_param = CRequest::param();
  74. $this->_param = $request_param['editFormData'];
  75. $this->initParam();
  76. //$model = $this->_one;
  77. $this->_one->attributes = $this->_param;
  78. if($this->_one[$this->_paramKey]){
  79. if(CConfig::param("is_demo")){
  80. if($this->_one[$this->_paramKey] == 4){
  81. echo json_encode(array(
  82. "statusCode"=>"300",
  83. "message"=>"demo版本,不允许编辑admin role",
  84. ));
  85. exit;
  86. }
  87. }
  88. if ($this->_one->validate()) {
  89. $this->saveMenuAndRole();
  90. //$this->_one->save();
  91. echo json_encode(array(
  92. "statusCode"=>"200",
  93. "message"=>"update",
  94. ));
  95. exit;
  96. }
  97. }else{
  98. if ($this->_one->validate()) {
  99. //$this->_one->save();
  100. $this->saveMenuAndRole();
  101. echo json_encode(array(
  102. "statusCode"=>"200",
  103. "message"=>"insert",
  104. ));
  105. exit;
  106. }
  107. }
  108. $errors = $this->_one->errors;
  109. echo json_encode(["statusCode"=>"300",
  110. "message" => CModel::getErrorStr($errors),
  111. ]);
  112. exit;
  113. }
  114. # 保存编辑后的Role内容 AdminRole
  115. # 以及role对应的菜单表 AdminRoleMenu
  116. public function saveMenuAndRole(){
  117. if($this->_one[$this->_paramKey]){
  118. $roleId = $this->_one[$this->_paramKey];
  119. $this->_one->save();
  120. }else{
  121. $this->_one->save();
  122. $roleId = Yii::$app->db->getLastInsertID();
  123. }
  124. $menu = CRequest::param("menu");
  125. $select_menus = isset($menu['select_menus']) ? $menu['select_menus'] : '';
  126. # 如果存在role_id 和选择的菜单
  127. if($roleId && $select_menus){
  128. # 得到当前选择的menu_id和相应的所有上级menu_id
  129. $select_menu_ids = $this->getAllParentMenuIds($select_menus);
  130. $select_menu_ids = array_unique($select_menu_ids);
  131. # AdminRole中role_id 对应的所有 menu_id
  132. $role_menu_ids = $this->getDbRoleMenuIds($roleId);
  133. # 需要插入的role_id - menu_id 数组差集
  134. $add_role_menu_ids = array_diff($select_menu_ids,$role_menu_ids);
  135. # 需要删除的role_id - menu_id 数组差集
  136. $remove_role_menu_ids = array_diff($role_menu_ids,$select_menu_ids);
  137. # 事务 插入 和 删除 role_menu 表中,当前role_id 对应的menu_id
  138. $table = \fecadmin\models\AdminRoleMenu::tableName();
  139. $columnsArr = ['menu_id','role_id','created_at','updated_at'];
  140. $valueArr = [];
  141. $now_date = date("Y-m-d H:i:s");
  142. if(!empty($add_role_menu_ids)){
  143. foreach($add_role_menu_ids as $menu_id){
  144. $valueArr[] = [$menu_id,$roleId,$now_date,$now_date];
  145. }
  146. }
  147. $innerTransaction = Yii::$app->db->beginTransaction();
  148. try {
  149. if(!empty($add_role_menu_ids)){
  150. \fec\helpers\CDB::batchInsert($table,$columnsArr,$valueArr);
  151. }
  152. if(!empty($remove_role_menu_ids)){
  153. $remove_role_menu_id_str = implode(',',$remove_role_menu_ids);
  154. //AdminRoleMenu::deleteAll(['in','menu_id',$remove_role_menu_ids]);
  155. $sql = "delete from $table where menu_id in ($remove_role_menu_id_str ) and role_id = :role_id ";
  156. $data = [ 'role_id'=> $roleId ];
  157. CDB::deleteBySql($sql,$data);
  158. //$roleId
  159. }
  160. $innerTransaction->commit();
  161. } catch (Exception $e) {
  162. $innerTransaction->rollBack();
  163. }
  164. }
  165. }
  166. # 得到当前数据库中role对应的所有的menu_id
  167. public function getDbRoleMenuIds($roleId){
  168. $role_menu_ids = [];
  169. $role_menus = AdminRoleMenu::find()->asArray()
  170. ->where(['role_id' => $roleId ])
  171. ->all();
  172. if(!empty($role_menus)){
  173. foreach($role_menus as $role_menu){
  174. $role_menu_ids[] = $role_menu['menu_id'];
  175. }
  176. }
  177. return $role_menu_ids;
  178. }
  179. # 得到菜单的所有上级菜单的id
  180. public function getAllParentMenuIds($select_menus,$last_arr=[]){
  181. $thisIds = [];
  182. if(!is_array($select_menus)){
  183. $ids = [];
  184. $select_menu_ids = explode(",",$select_menus);
  185. if(is_array($select_menu_ids) && !empty($select_menu_ids)){
  186. foreach($select_menu_ids as $menu_id){
  187. if($i = trim($menu_id)){
  188. $ids[] = $i;
  189. }
  190. }
  191. }
  192. }else{
  193. $ids = $select_menus;
  194. }
  195. $thisIds = $ids;
  196. if(empty($last_arr)){
  197. $last_arr = $ids;
  198. }
  199. if(!empty($ids)){
  200. $parentMenus = AdminMenu::find()->asArray()->where(['in','id',$ids])->all();
  201. $parentIds = [];
  202. foreach($parentMenus as $menu){
  203. $parent_id = $menu['parent_id'];
  204. if($parent_id){
  205. $parentIds[] = $parent_id;
  206. }
  207. }
  208. if(!empty($parentIds)){
  209. $last_arr = array_merge($last_arr,$parentIds);
  210. return $this->getAllParentMenuIds($parentIds,$last_arr);
  211. }else{
  212. return $last_arr;
  213. }
  214. }
  215. return $last_arr;
  216. }
  217. # 批量删除
  218. public function delete(){
  219. //$request_param = CRequest::param();
  220. //$this->_param = $request_param;
  221. //$this->initParam();
  222. if($role_id = CRequest::param($this->_paramKey)){
  223. $model = AdminRole::findOne([$this->_paramKey => $role_id]);
  224. if($model->role_id){
  225. # 不允许删除admin
  226. if(CConfig::param("is_demo")){
  227. if($model->role_id == 4){
  228. echo json_encode(["statusCode"=>"300",
  229. "message" => 'demo版本,不允许编辑admin',
  230. ]);
  231. exit;
  232. }
  233. }
  234. $innerTransaction = Yii::$app->db->beginTransaction();
  235. try {
  236. $model->delete();
  237. # 删除这个role 对应的所有关联的菜单
  238. AdminRoleMenu::deleteAll(['role_id' => $role_id]);
  239. AdminUserRole::deleteAll(['role_id' => $role_id]);
  240. $innerTransaction->commit();
  241. } catch (Exception $e) {
  242. $innerTransaction->rollBack();
  243. }
  244. echo json_encode(["statusCode"=>"200",
  245. "message" => 'Delete Success!',
  246. ]);
  247. exit;
  248. }else{
  249. echo json_encode(["statusCode"=>"300",
  250. "message" => "role_id => $role_id , is not exist",
  251. ]);
  252. exit;
  253. }
  254. }else if($ids = CRequest::param($this->_paramKey.'s')){
  255. $id_arr = explode(",",$ids);
  256. $innerTransaction = Yii::$app->db->beginTransaction();
  257. try {
  258. # 不允许删除admin
  259. if(CConfig::param("is_demo")){
  260. if(in_array(4,$id_arr)){
  261. echo json_encode(["statusCode"=>"300",
  262. "message" => 'demo版本,不允许删除admin',
  263. ]);
  264. $innerTransaction->rollBack();
  265. exit;
  266. }
  267. }
  268. AdminRole::deleteAll(['in','role_id',$id_arr]);
  269. # 删除这个role 对应的所有关联的菜单
  270. AdminUserRole::deleteAll(['in','role_id',$id_arr]);
  271. $innerTransaction->commit();
  272. } catch (Exception $e) {
  273. $innerTransaction->rollBack();
  274. }
  275. echo json_encode(["statusCode"=>"200",
  276. "message" => "$ids Delete Success!",
  277. ]);
  278. exit;
  279. }
  280. echo json_encode(["statusCode"=>"300",
  281. "message" => "role_id or ids Param is not Exist!",
  282. ]);
  283. exit;
  284. }
  285. public function getEditArr(){
  286. return [
  287. [
  288. 'label'=>'权限名称',
  289. 'name'=>'role_name',
  290. 'display'=>[
  291. 'type' => 'inputString',
  292. ],
  293. 'require' => 1,
  294. ],
  295. [
  296. 'label'=>'权限描述',
  297. 'name'=>'role_description',
  298. 'display'=>[
  299. 'type' => 'inputString',
  300. ],
  301. 'require' => 1,
  302. ],
  303. ];
  304. }
  305. public function getEditBar(){
  306. $editArr = $this->getEditArr();
  307. $str = '';
  308. if($this->_param[$this->_paramKey]){
  309. $str = '<input type="hidden" value="'.$this->_param[$this->_paramKey].'" size="30" name="editFormData['.$this->_paramKey.']" class="textInput ">';
  310. }
  311. foreach($editArr as $column){
  312. $name = $column['name'];
  313. $require = $column['require'] ? 'required' : '';
  314. $label = $column['label'] ? $column['label'] : $this->_one->getAttributeLabel($name);
  315. $display = isset($column['display']) ? $column['display'] : '';
  316. if(empty($display)){
  317. $display = ['type' => 'inputString'];
  318. }
  319. //var_dump($this->_one['id']);
  320. $value = $this->_one[$name] ? $this->_one[$name] : $column['default'];
  321. $display_type = isset($display['type']) ? $display['type'] : 'inputString';
  322. if($display_type == 'inputString'){
  323. $str .='<p>
  324. <label>'.$label.':</label>
  325. <input type="text" value="'.$value.'" size="30" name="editFormData['.$name.']" class="textInput '.$require.' ">
  326. </p>';
  327. }else if($display_type == 'inputDate'){
  328. $str .='<p>
  329. <label>'.$label.':</label>
  330. <input type="text" value="'.($value ? date("Y-m-d",strtotime($value)) : '').'" size="30" name="editFormData['.$name.']" class="date textInput '.$require.' ">
  331. </p>';
  332. }else if($display_type == 'inputEmail'){
  333. $str .='<p>
  334. <label>'.$label.':</label>
  335. <input type="text" value="'.$value.'" size="30" name="editFormData['.$name.']" class="email textInput '.$require.' ">
  336. </p>';
  337. }else if($display_type == 'inputPassword'){
  338. $str .='<p>
  339. <label>'.$label.':</label>
  340. <input type="password" value="" size="30" name="editFormData['.$name.']" class=" textInput '.$require.' ">
  341. </p>';
  342. }else if($display_type == 'select'){
  343. $data = isset($display['data']) ? $display['data'] : '';
  344. //var_dump($data);
  345. //echo $value;
  346. $select_str = '';
  347. if(is_array($data)){
  348. $select_str .= '<select class="combox '.$require.'" name="editFormData['.$name.']" >';
  349. $select_str .='<option value="">'.$label.'</option>';
  350. foreach($data as $k => $v){
  351. if($value == $k){
  352. //echo $value."#".$k;
  353. $select_str .='<option selected="selected" value="'.$k.'">'.$v.'</option>';
  354. }else{
  355. $select_str .='<option value="'.$k.'">'.$v.'</option>';
  356. }
  357. }
  358. $select_str .= '</select>';
  359. }
  360. $str .='<p>
  361. <label>'.$label.':</label>
  362. '.$select_str.'
  363. </p>';
  364. }
  365. }
  366. return $str;
  367. }
  368. }