mirror of
https://gitee.com/zoujingli/ThinkAdmin.git
synced 2026-06-09 13:18:18 +08:00
将 v6 中直接放在本地 app 的后台与微信能力迁移为 v8 插件组件,并把运行时基础能力沉淀到独立插件包。 主要内容: - 新增 think-library、system、worker、static、install 等基础插件包。 - 新增 account、payment、wechat-client、wechat-service、wemall、wuma 等业务插件包。 - 移除 v6 的 app/admin 与 app/wechat 本地应用实现,改由插件分发接管。 - 将 Helper 能力彻底并入 System,统一为 plugin\system\helper\* 命名空间。 - 同步插件迁移发布清单与根 route 占位,保证安装发布流程可复现。
85 lines
3.3 KiB
PHP
85 lines
3.3 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
/**
|
|
* +----------------------------------------------------------------------
|
|
* | ThinkAdmin Plugin for ThinkAdminDeveloper
|
|
* +----------------------------------------------------------------------
|
|
* | Copyright (c) 2014~2026 ThinkAdmin [ thinkadmin.top ]
|
|
* +----------------------------------------------------------------------
|
|
* | Official Website: https://thinkadmin.top
|
|
* +----------------------------------------------------------------------
|
|
* | Licensed: https://mit-license.org
|
|
* | Disclaimer: https://thinkadmin.top/disclaimer
|
|
* | Vip Rights: https://thinkadmin.top/vip-introduce
|
|
* +----------------------------------------------------------------------
|
|
* | Gitee Repository: https://gitee.com/zoujingli/ThinkAdmin
|
|
* | Github Repository: https://github.com/zoujingli/ThinkAdmin
|
|
* +----------------------------------------------------------------------
|
|
*/
|
|
|
|
namespace think\admin\extend;
|
|
|
|
/**
|
|
* 标准树形数组工具。
|
|
*/
|
|
class ArrayTree
|
|
{
|
|
/**
|
|
* 二维数组转带层级标识的数据表。
|
|
* 这里继续输出历史字段 `spc/spt/spl/sps/spp`,避免影响后台树表展示。
|
|
*/
|
|
public static function arr2table(array $list, string $ckey = 'id', string $pkey = 'pid', string $path = 'path'): array
|
|
{
|
|
$build = static function (array $nodes, callable $build, array &$data = [], string $parent = '') use ($ckey, $path) {
|
|
foreach ($nodes as $node) {
|
|
$subs = $node['sub'] ?? [];
|
|
unset($node['sub']);
|
|
$node[$path] = "{$parent}-{$node[$ckey]}";
|
|
$node['spc'] = count($subs);
|
|
$node['spt'] = substr_count($parent, '-');
|
|
$node['spl'] = str_repeat('ㅤ├ㅤ', $node['spt']);
|
|
$node['sps'] = ",{$node[$ckey]},";
|
|
array_walk_recursive($subs, static function ($val, $key) use ($ckey, &$node) {
|
|
if ($key === $ckey) {
|
|
$node['sps'] .= "{$val},";
|
|
}
|
|
});
|
|
$node['spp'] = arr2str(str2arr(strtr($parent . $node['sps'], '-', ',')));
|
|
$data[] = $node;
|
|
if (!empty($subs)) {
|
|
$build($subs, $build, $data, $node[$path]);
|
|
}
|
|
}
|
|
return $data;
|
|
};
|
|
return $build(static::arr2tree($list, $ckey, $pkey), $build);
|
|
}
|
|
|
|
/**
|
|
* 二维数组转多维数据树。
|
|
*/
|
|
public static function arr2tree(array $list, string $ckey = 'id', string $pkey = 'pid', string $chil = 'sub'): array
|
|
{
|
|
[$tree, $list] = [[], array_column($list, null, $ckey)];
|
|
foreach ($list as $it) {
|
|
isset($list[$it[$pkey]]) ? $list[$it[$pkey]][$chil][] = &$list[$it[$ckey]] : $tree[] = &$list[$it[$ckey]];
|
|
}
|
|
return $tree;
|
|
}
|
|
|
|
/**
|
|
* 获取数据树子 ID 集合。
|
|
*/
|
|
public static function getArrSubIds(array $list, int|string $value = 0, string $ckey = 'id', string $pkey = 'pid'): array
|
|
{
|
|
$ids = [(int)$value];
|
|
foreach ($list as $vo) {
|
|
if ((int)$vo[$pkey] > 0 && (int)$vo[$pkey] === (int)$value) {
|
|
$ids = array_merge($ids, static::getArrSubIds($list, (int)$vo[$ckey], $ckey, $pkey));
|
|
}
|
|
}
|
|
return $ids;
|
|
}
|
|
}
|