123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343 |
- <?php
- // +----------------------------------------------------------------------
- // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
- // +----------------------------------------------------------------------
- // | Copyright (c) 2016~2022 https://www.crmeb.com All rights reserved.
- // +----------------------------------------------------------------------
- // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
- // +----------------------------------------------------------------------
- // | Author: CRMEB Team <admin@crmeb.com>
- // +----------------------------------------------------------------------
- // +----------------------------------------------------------------------
- // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
- // +----------------------------------------------------------------------
- // | Copyright (c) 2016~2022 https://www.crmeb.com All rights reserved.
- // +----------------------------------------------------------------------
- // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
- // +----------------------------------------------------------------------
- // | Author: CRMEB Team <admin@crmeb.com>
- // +----------------------------------------------------------------------
- namespace app\common\repositories\system\auth;
- //附件
- use app\common\dao\BaseDao;
- use app\common\dao\system\menu\MenuDao;
- use app\common\repositories\BaseRepository;
- use FormBuilder\Exception\FormBuilderException;
- use FormBuilder\Factory\Elm;
- use FormBuilder\Form;
- use think\db\exception\DataNotFoundException;
- use think\db\exception\DbException;
- use think\db\exception\ModelNotFoundException;
- use think\Exception;
- use think\facade\Db;
- use think\facade\Route;
- use think\Model;
- /**
- * Class BaseRepository
- * @package common\repositories
- * @mixin MenuDao
- */
- class MenuRepository extends BaseRepository
- {
- /**
- * MenuRepository constructor.
- * @param MenuDao $dao
- */
- protected $styles = array(
- 'success' => "\033[0;32m%s\033[0m",
- 'error' => "\033[31;31m%s\033[0m",
- 'info' => "\033[33;33m%s\033[0m"
- );
- public $prompt = 'all';
- public function __construct(MenuDao $dao)
- {
- /**
- * @var MenuDao
- */
- $this->dao = $dao;
- }
- /**
- * @param array $where
- * @param int $merId
- * @return array
- * @throws DataNotFoundException
- * @throws DbException
- * @throws ModelNotFoundException
- * @author xaboy
- * @day 2020-04-16
- */
- public function getList(array $where, $merId = 0)
- {
- $query = $this->dao->search($where, $merId);
- $count = $query->count();
- $list = $query->hidden(['update_time', 'path'])->select()->toArray();
- return compact('count', 'list');
- }
- /**
- * @param array $data
- * @return BaseDao|Model
- * @author xaboy
- * @day 2020-04-09
- */
- public function create(array $data)
- {
- $data['path'] = '/';
- if ($data['pid']) {
- $data['path'] = $this->getPath($data['pid']) . $data['pid'] . '/';
- }
- return $this->dao->create($data);
- }
- /**
- * @param int $id
- * @param array $data
- * @return int
- * @throws DbException
- * @author xaboy
- * @day 2020-04-09
- */
- public function update(int $id, array $data)
- {
- $menu = $this->dao->get($id);
- if ($menu->pid != $data['pid']) {
- Db::transaction(function () use ($menu, $data) {
- $data['path'] = '/';
- if ($data['pid']) {
- $data['path'] = $this->getPath($data['pid']) . $data['pid'] . '/';
- }
- $this->dao->updatePath($menu->path . $menu->menu_id . '/', $data['path'] . $menu->menu_id . '/');
- $menu->save($data);
- });
- } else {
- unset($data['path']);
- $this->dao->update($id, $data);
- }
- }
- /**
- * @param bool $is_mer
- * @return array
- * @author xaboy
- * @day 2020-04-18
- */
- public function getTree($merType = 0)
- {
- if (!$merType) {
- $options = $this->dao->getAllOptions();
- } else {
- $options = $this->dao->merchantTypeByOptions($merType);
- }
- return formatTree($options, 'menu_name');
- }
- /**
- * @param int $isMer
- * @param int|null $id
- * @param array $formData
- * @return Form
- * @throws FormBuilderException
- * @author xaboy
- * @day 2020-04-16
- */
- public function menuForm(int $isMer = 0, ?int $id = null, array $formData = []): Form
- {
- $action = $isMer == 0 ? (is_null($id) ? Route::buildUrl('systemMenuCreate')->build() : Route::buildUrl('systemMenuUpdate', ['id' => $id])->build())
- : (is_null($id) ? Route::buildUrl('systemMerchantMenuCreate')->build() : Route::buildUrl('systemMerchantMenuUpdate', ['id' => $id])->build());
- $form = Elm::createForm($action);
- $form->setRule([
- Elm::cascader('pid', '父级分类')->options(function () use ($id, $isMer) {
- $menus = $this->dao->getAllOptions($isMer, true);
- if ($id && isset($menus[$id])) unset($menus[$id]);
- $menus = formatCascaderData($menus, 'menu_name');
- array_unshift($menus, ['label' => '顶级分类', 'value' => 0]);
- return $menus;
- })->props(['props' => ['checkStrictly' => true, 'emitPath' => false]]),
- Elm::select('is_menu', '权限类型', 1)->options([
- ['value' => 1, 'label' => '菜单'],
- ['value' => 0, 'label' => '权限'],
- ])->control([
- [
- 'value' => 0,
- 'rule' => [
- Elm::input('menu_name', '路由名称')->required(),
- Elm::textarea('params', '参数')->placeholder("路由参数:\r\nkey1:value1\r\nkey2:value2"),
- ]
- ], [
- 'value' => 1,
- 'rule' => [
- Elm::switches('is_show', '是否显示', 1)->inactiveValue(0)->activeValue(1)->inactiveText('关')->activeText('开'),
- Elm::frameInput('icon', '菜单图标', '/' . config('admin.admin_prefix') . '/setting/icons?field=icon')->icon('el-icon-circle-plus-outline')->height('338px')->width('700px')->modal(['modal' => false]),
- Elm::input('menu_name', '菜单名称')->required(),
- ]
- ]
- ]),
- Elm::input('route', '路由'),
- Elm::number('sort', '排序', 0)->precision(0)->max(99999)
- ]);
- return $form->setTitle(is_null($id) ? '添加菜单' : '编辑菜单')->formData($formData);
- }
- /**
- * @param int $id
- * @param int $merId
- * @return Form
- * @throws DataNotFoundException
- * @throws DbException
- * @throws FormBuilderException
- * @throws ModelNotFoundException
- * @author xaboy
- * @day 2020-04-16
- */
- public function updateMenuForm(int $id, $merId = 0)
- {
- return $this->menuForm($merId, $id, $this->dao->get($id)->toArray());
- }
- /**
- * @param string $params
- * @return array
- * @author xaboy
- * @day 2020-04-22
- */
- public function tidyParams(?string $params)
- {
- return $params ? array_reduce(explode('|', $params), function ($initial, $val) {
- $data = explode(':', $val, 2);
- if (count($data) != 2) return $initial;
- $initial[$data[0]] = $data[1];
- return $initial;
- }, []) : [];
- }
- /**
- * @param array $params
- * @param array $routeParams
- * @return bool
- * @author xaboy
- * @day 2020-04-23
- */
- public function checkParams(array $params, array $routeParams)
- {
- foreach ($routeParams as $k => $param) {
- if (isset($params[$k]) && $params[$k] != $param)
- return false;
- }
- return true;
- }
- public function formatPath($is_mer = 0)
- {
- $options = $this->getAll($is_mer);
- $options = formatCategory($options, 'menu_id');
- Db::transaction(function () use ($options) {
- foreach ($options as $option) {
- $this->_formatPath($option);
- }
- });
- }
- protected function _formatPath($parent, $path = '/')
- {
- $this->dao->update($parent['menu_id'], ['path' => $path]);
- foreach ($parent['children'] ?? [] as $item) {
- $itemPath = $path . $item['pid'] . '/';
- $this->_formatPath($item, $itemPath);
- }
- }
- public function commandMenu($type, $data, $prompt)
- {
- $res = [];
- if ($prompt) $this->prompt = $prompt;
- $isMer = ($type == 'sys') ? 0 : 1;
- foreach ($data as $key => $value) {
- try{
- $result = $this->dao->getMenuPid($key, $isMer, 0);
- if (!$result) {
- $route = $key;
- $isAppend =0;
- if (substr($key,0,7) === 'append_') {
- $isAppend = 1;
- $route = substr($key,7);
- }
- $result = $this->dao->getMenuPid($route, $isMer, 1);
- if (!$result && $key !== 'self') {
- printf($this->styles['info'], '未找到菜单: '. $key);
- echo PHP_EOL;
- continue;
- } else {
- $result = $this->dao->create([
- 'pid' => $key == 'self' ? 0 : $result['menu_id'],
- 'path' => $key == 'self' ? '/' : $result['path'] . $result['menu_id'] . '/',
- 'menu_name' => $isAppend ? '附加权限' : '权限' ,
- 'route' => $key,
- 'is_mer' => $isMer,
- 'is_menu' => 0
- ]);
- }
- }
- $res = array_merge($res, $this->createSlit($isMer, $result['menu_id'], $result['path'], $value));
- }catch (\Exception $exception) {
- throw new Exception($key);
- }
- }
- $count = count($res);
- if (!empty($res)) $this->dao->insertAll($res);
- return $count;
- }
- /**
- * TODO 新增权限数据整理
- * @param int $isMer
- * @param int $menuId
- * @param string $path
- * @param array $data
- * @return array
- * @author Qinii
- * @day 3/18/22
- */
- public function createSlit(int $isMer,int $menuId, string $path,array $data)
- {
- $arr = [];
- try {
- foreach ($data as $k => $v) {
- $result = $this->dao->getWhere(['route' => $v['route'], 'pid' => $menuId]);
- if (!$result) {
- $arr[] = [
- 'pid' => $menuId,
- 'path' => $path . $menuId . '/',
- 'menu_name' => $v['menu_name'],
- 'route' => $v['route'],
- 'is_mer' => $isMer,
- 'is_menu' => 0,
- 'params' => $v['params'] ?? [],
- ];
- if ($this->prompt == 's') {
- printf($this->styles['success'], '新增权限: ' . $v['menu_name'] . ' [' . $v['route'] . ']');
- echo PHP_EOL;
- }
- }
- }
- return $arr;
- }catch (\Exception $exception) {
- halt($isMer, $menuId, $path, $data);
- }
- }
- }
|