news 2026/4/16 12:36:57

开源鸿蒙跨平台开发训练营--AtomGit(GitCode)口袋工具(六)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
开源鸿蒙跨平台开发训练营--AtomGit(GitCode)口袋工具(六)

获取代码仓库文件列表

如下图所示:我们先实现从网络获取文件列表的接口

该接口会返回文件列表集合。实例数据如下所示:

[ .gitignore, ArkTSCangjieHybridApp/.gitignore, ArkTSCangjieHybridApp/AppScope/resources/base/element/string.json, ArkTSCangjieHybridApp/AppScope/resources/base/media/app_icon.png, ArkTSCangjieHybridApp/README.md, ArkTSCangjieHybridApp/arkts_modules/shortvideoarkts/.gitignore, ArkTSCangjieHybridApp/arkts_modules/shortvideoarkts/Index.ets, ArkTSCangjieHybridApp/arkts_modules/shortvideoarkts/oh-package.json5, ]

1. 数据处理

首先我们需要创建一个GitCodeCodeRepo实体类,用来表示文件或者文件夹。根据上述返回的是数据列表,我们需要将每个文件、文件夹转换成对应的GitCodeCodeRepo实体类。所以我们需要做数据转换,将对应的字符串列表,转换成List<GitCodeCodeRepo>

GitCodeCodeRepo我们先设计三个属性,如下所示:

  • name:文件名/文件夹名。
  • path:文件夹/文件的完整路径。
  • isDir: 是否是文件夹。
class GitCodeCodeRepo { final String name; // 文件名或文件夹名 final bool isDir; // 是否为文件夹 final String? path; // 完整路径 GitCodeCodeRepo({ required this.name, required this.isDir, this.path, }); }

然后我们在GitCodeCodeRepo中新建一个buildTreeFromPaths函数,专门用来解析数据,目的是将List<String>转换成List<GitCodeCodeRepo>。代码如下所示:

static List<GitCodeCodeRepo> buildTreeFromPaths(List<String> paths) { final List<GitCodeCodeRepo> rootNodes = []; // 遍历接口返回的所有文件路径 for (final path in paths) { // 将每个路径按照 "/" 进行分割。 final parts = path.split('/').where((part) => part.isNotEmpty).toList(); if (parts.isEmpty) continue; for (int i = 0; i < parts.length; i++) { // 获取文件名 String fileName = parts[i]; // 判断是不是文件夹 bool isDir = fileName.contains("."); GitCodeCodeRepo repo = GitCodeCodeRepo(name: fileName, isDir: isDir); rootNodes.add(repo); } } return rootNodes; }

文件和文件夹虽然显示出来了,但是我们发现数据有问题:所有的文件和文件夹都平铺在这个列表里,没有文件夹层次结构了。‘

因此我们继续修改,并且让当前列表只展示根目录下的文件或文件夹。

static List<GitCodeCodeRepo> buildTreeFromPathsTest(List<String> paths) { final Map<String, GitCodeCodeRepo> nodeMap = {}; final List<GitCodeCodeRepo> rootNodes = []; // 遍历接口返回的所有文件路径 for (final path in paths) { // 将每个路径按照 "/" 进行分割。 final parts = path.split('/').where((part) => part.isNotEmpty).toList(); if (parts.isEmpty) continue; String currentPath = ''; for (int i = 0; i < parts.length; i++) { final part = parts[i]; final isLastPart = i == parts.length - 1; // 这里修改了判断文件夹的逻辑 final isDir = isLastPart ? path.endsWith('/') : true; currentPath += '/$part'; // 对于文件夹,确保路径以斜杠结尾 final nodePath = isDir ? '$currentPath/' : currentPath; if (!nodeMap.containsKey(nodePath)) { final node = GitCodeCodeRepo( name: part, isDir: isDir, path: nodePath, ); nodeMap[nodePath] = node; // 如果是根节点(第一级),添加到根节点列表 if (i == 0) { rootNodes.add(node); } } } } return rootNodes; }

说明:为了提高用户体验,区分不同的 item。我们对每个 item 进行各行设置不同的背景色。

根目录显示成功,我们可以继续再优化一下。当前处理后的列表中,文件夹和文家是乱序的,我们需要将文件夹和文件进行排序,如果相同类型的文件或文件夹,则按照字母顺序排序。

// 在该函数中, return List 之前,先进行排序 rootNodes.sort((a, b) { // 文件夹排在前面 if (a.isDir && !b.isDir) return -1; if (!a.isDir && b.isDir) return 1; // 同类型按名称字母顺序排序 return a.name.compareTo(b.name); });

2. 界面跳转

当我们点击 item 后跳转到文件详情界面。目前先展示一些基本信息。文件具体的内容暂时先不展示。

// 点击跳转 Navigator.push( context, MaterialPageRoute( builder: (context) => ShowCodeDetailPage( repo: widget.repo, refName: refName, filePath: fullPath, node: node, fileTree: _fileTree, // 传递_fileTree数据 ), ), );

在文件详情界面我们展示一些基本信息,用于验证文件的正确性。如下图所示:仓库、分支正确,而且最重要的文件路径也显示正确。

3. 侧边栏实现

由于文件夹和文件列表以及文件具体内容展示区域都非常占用空间,所以我们将文件夹和文件列表使用侧边栏来展示,并且侧边栏是悬浮状态。而且由于我们将处理过后的文件列表数据传递过去了,也顺便在侧边栏中展示出来。

核心区域我们做一个判断,如果用户点击的 item 是文件夹进入当前页面,则核心区域不展示内容。如果用户点击的是 item 是文件,则展示当前文件内容(先不实现)。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 0:13:17

NAT应用

背景IDC机房的公网ip如果想映射到局域网的机器或者使用端口映射功能可以使用Nat转换静态NAT&#xff08;一对一映射&#xff09;映射所有端口NAT Server&#xff08;端口映射&#xff09;如果只想映射特定端口&#xff0c;而不是所有流量Easy IP&#xff08;如果只有一个公网IP…

作者头像 李华
网站建设 2026/4/3 11:58:36

河道防洪防汛监测设备的技术体系与实践应用

一&#xff0e;前言汛期来临之际&#xff0c;河道水位暴涨、暴雨突袭等突发情况直接威胁人民生命财产安全&#xff0c;水位、流量、雨量监测设备作为防洪防汛的“科技哨兵”&#xff0c;凭借精准的数据支撑为灾害预警与调度决策筑牢第一道防线。二&#xff0e;监测设备水位监测…

作者头像 李华
网站建设 2026/4/16 12:18:15

人类反馈强化学习(RLHF) 从强化学习架构到监督微调

人类反馈强化学习&#xff08;RLHF&#xff09; 从架构到监督微调 关于强化学习&#xff08;reinforcement learning from human feedback&#xff09;架构、演员-评论家架构、近端策略优化&#xff08;PPO&#xff09;及DeepSpeed Chat的RLHF三阶段训练流程&#xff0c;并附代…

作者头像 李华
网站建设 2026/4/16 10:45:37

Sigma规则转换后端实战:企业级深度优化与性能进阶

Sigma规则转换后端实战&#xff1a;企业级深度优化与性能进阶 【免费下载链接】sigma 项目地址: https://gitcode.com/gh_mirrors/sig/sigma 核心问题&#xff1a;为什么90%的Sigma规则转换会失败&#xff1f; 在实际企业部署中&#xff0c;Sigma规则的转换成功率往往…

作者头像 李华
网站建设 2026/4/16 12:14:49

告别数据孤岛:用Readest实现电子书无缝迁移的艺术

告别数据孤岛&#xff1a;用Readest实现电子书无缝迁移的艺术 【免费下载链接】readest Readest is a modern, feature-rich ebook reader designed for avid readers offering seamless cross-platform access, powerful tools, and an intuitive interface to elevate your r…

作者头像 李华