Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(circle,line): enable indeterminate mode #216

Merged
merged 8 commits into from
Mar 9, 2025

Conversation

SaidMarar
Copy link
Contributor

@SaidMarar SaidMarar commented Jan 1, 2023

This is an enhancement for the request #84 it enables the indeterminate mode when the user does not define the percent property for both components circle and line.

<Circle />
<Line />

indeterminate

Summary by CodeRabbit

  • 新功能

    • 为进度组件新增 “loading” 属性,支持启用不确定状态下的加载动画效果。
    • 新增 “Loading” 演示组件,展示圆形和线性进度条的加载状态。
  • 文档

    • 更新 API 文档,详细说明新属性的默认行为。
    • 添加加载状态的示例页面,方便用户参考使用方法。
  • 测试

    • 引入测试用例验证进度组件在加载状态下动画和样式的一致性。

@vercel
Copy link

vercel bot commented Jan 1, 2023

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Comments Updated (UTC)
progress ✅ Ready (Inspect) Visit Preview 💬 Add feedback Feb 11, 2025 1:32am

@codecov
Copy link

codecov bot commented Jan 1, 2023

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 99.41%. Comparing base (bfe42ea) to head (ef86c31).
Report is 1 commits behind head on master.

Additional details and impacted files
@@            Coverage Diff             @@
##           master     #216      +/-   ##
==========================================
+ Coverage   99.36%   99.41%   +0.05%     
==========================================
  Files           6        8       +2     
  Lines         157      172      +15     
  Branches       50       52       +2     
==========================================
+ Hits          156      171      +15     
  Misses          1        1              

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

🚀 New features to boost your workflow:
  • Test Analytics: Detect flaky tests, report on failures, and find test suite problems.
  • 📦 JS Bundle Analysis: Save yourself from yourself by tracking and limiting bundle sizes in JS merges.

@afc163
Copy link
Member

afc163 commented Jan 1, 2023

👍

@yoyo837
Copy link
Member

yoyo837 commented Jan 3, 2024

Rebase please

@SaidMarar
Copy link
Contributor Author

@yoyo837 Done 😄

@afc163
Copy link
Member

afc163 commented Jan 5, 2024

code coverage is down.

@sguergachi
Copy link

Hi, will this be merged anytime soon?

@afc163
Copy link
Member

afc163 commented Nov 29, 2024

图片

Copy link

coderabbitai bot commented Feb 10, 2025

"""

Walkthrough

此次变更为进度组件引入了新的 loading 属性。当 loadingtrue 时,组件将展示不确定进度状态,通过 CSS 样式和动画实现。相关文档、接口、默认值、组件实现及工具函数均做了相应更新,新添的 Demo 和测试用例用于展示并验证这一功能。

Changes

文件 变更摘要
README.md
docs/demo/loading.md
新增文档:更新 API 说明(新增 loading 属性)及添加 demo 文档
docs/examples/loading.tsx 新增示例组件 Loading,演示 CircleLine 组件的 loading 状态
src/Circle/index.tsx
src/Line.tsx
更新组件:为 CircleLine 组件添加 loading 属性及相关 indeterminate 样式和动画逻辑
src/common.ts
src/interface.ts
更新配置与接口:添加 loading 属性到默认配置和进度属性接口
src/utils/getIndeterminateCircle.tsx
src/utils/getIndeterminateLine.tsx
新增工具函数:返回 indeterminate 样式和动画,用于 loading 状态
tests/indeterminate.spec.tsx 新增测试:验证 CircleLine 组件在 loading 状态下的动画表现

Sequence Diagram(s)

sequenceDiagram
    participant U as 用户
    participant C as 进度组件 (Circle/Line)
    participant T as 工具函数 (getIndeterminate...)
    
    U->>C: 传入 loading=true 渲染组件
    C->>T: 调用工具函数获取样式和动画
    T-->>C: 返回 indeterminate 样式和动画
    C->>C: 合并样式并渲染包含动画的 SVG
    Note over C: 不确定加载状态激活
Loading

Poem

我是一只快乐的小兔,
代码新意映眼眸。
loading点亮动感幻彩,
挥动键盘如同跳跃,
感谢更新让心情飞舞!
🐰✨
"""


📜 Recent review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 4239195 and ef86c31.

📒 Files selected for processing (2)
  • src/utils/getIndeterminateCircle.tsx (1 hunks)
  • tests/indeterminate.spec.tsx (1 hunks)
🚧 Files skipped from review as they are similar to previous changes (2)
  • src/utils/getIndeterminateCircle.tsx
  • tests/indeterminate.spec.tsx

Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai generate docstrings to generate docstrings for this PR. (Beta)
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

CodeRabbit Configuration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 3

🧹 Nitpick comments (6)
docs/examples/loading.tsx (1)

4-11: 建议完善示例组件

建议增加以下场景的演示:

  1. 不设置 percent 属性时的加载状态
  2. percent 为不同值时的加载效果
  3. 添加错误处理,验证 percent 的有效范围

建议按如下方式修改代码:

 const Loading = () => {
   return (
     <div style={{ margin: 10, width: 200 }}>
-      <Circle loading percent={10} />
-      <Line loading percent={50} />
+      <Circle loading />
+      <Circle loading percent={10} />
+      <Circle loading percent={50} />
+      <Line loading />
+      <Line loading percent={30} />
+      <Line loading percent={70} />
     </div>
   );
 };
src/utils/getIndeterminateCircle.tsx (1)

20-22: 建议将动画时间和缓动函数设置为可配置项

当前动画时间是硬编码的 1s,建议将其作为配置项,以支持不同的动画速度需求。同时建议添加缓动函数以使动画更流畅。

建议修改如下:

 indeterminateStyleProps: {
   transform: 'rotate(0deg)',
-  animation: `${animationName} 1s linear infinite`,
+  animation: `${animationName} ${duration}s ${easing} infinite`,
 },
src/utils/getIndeterminateLine.tsx (2)

20-20: 建议简化 strokeDashOffset 的计算逻辑

当前计算逻辑较为复杂,可以提取为一个独立的函数以提高可读性。

建议修改如下:

+ const calculateStrokeDashOffset = (
+   percent: number,
+   strokeLinecap: StrokeLinecapType,
+   strokeWidth: number,
+ ): number => {
+   const roundStrokeOffset = strokeLinecap === 'round' ? strokeWidth : 0;
+   return 100 - (percent + roundStrokeOffset);
+ };

- const strokeDashOffset = 100 - (percent + (strokeLinecap === 'round' ? strokeWidth : 0));
+ const strokeDashOffset = calculateStrokeDashOffset(percent, strokeLinecap, strokeWidth);

24-26: 建议将动画参数设置为可配置项

与圆形进度条类似,建议将动画时间和缓动函数设置为可配置项。

建议修改如下:

 indeterminateStyleProps: {
   strokeDasharray: `${percent} 100`,
-  animation: `${animationName} .6s linear alternate infinite`,
+  animation: `${animationName} ${duration}s ${easing} alternate infinite`,
   strokeDashoffset: 0,
 },
src/Circle/index.tsx (1)

103-103: 建议优化样式合并逻辑

当前的样式合并方式可能会在某些边缘情况下出现问题。建议使用更健壮的合并策略:

-style={{ ...circleStyleForStack, ...indeterminateStyleProps }}
+style={loading ? { ...circleStyleForStack, ...indeterminateStyleProps } : circleStyleForStack}
README.md (1)

139-144: 新增 loading 属性文档描述审核

在表格中增加的 loading 属性描述简洁明了,已正确标明类型(Boolean)、默认值(false)以及功能说明。不过建议可以稍微扩展描述,例如添加一句说明当 loading 为 true 时,组件将展示不确定进度状态的动画效果,从而帮助用户更直观地理解该属性的用途。

📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between bfe42ea and cc2fd04.

⛔ Files ignored due to path filters (1)
  • tests/__snapshots__/index.spec.js.snap is excluded by !**/*.snap
📒 Files selected for processing (10)
  • README.md (1 hunks)
  • docs/demo/loading.md (1 hunks)
  • docs/examples/loading.tsx (1 hunks)
  • src/Circle/index.tsx (5 hunks)
  • src/Line.tsx (5 hunks)
  • src/common.ts (1 hunks)
  • src/interface.ts (1 hunks)
  • src/utils/getIndeterminateCircle.tsx (1 hunks)
  • src/utils/getIndeterminateLine.tsx (1 hunks)
  • tests/index.spec.js (1 hunks)
✅ Files skipped from review due to trivial changes (1)
  • docs/demo/loading.md
🔇 Additional comments (5)
src/interface.ts (1)

17-17: 接口定义符合规范

新增的 loading 属性定义清晰,类型正确,且保持了可选特性,符合 TypeScript 最佳实践。

src/common.ts (1)

13-13: 新增的 loading 属性设置合理!

默认值设置为 false 符合 React 布尔属性的最佳实践。

src/Line.tsx (2)

43-49: getIndeterminateLine 的使用恰当!

良好地将不确定状态的样式逻辑抽离到工具函数中。


86-86: 建议添加 loading 状态的单元测试用例

虽然已经添加了基本的测试,但建议增加以下场景的测试:

  • loading 状态切换时的动画效果
  • loading 和 percent 属性同时存在时的行为

Also applies to: 111-111

src/Circle/index.tsx (1)

56-59: 实现与 Line 组件保持一致,值得赞赏!

良好地保持了组件间的一致性,使用相同的模式处理 loading 状态。

Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Nitpick comments (4)
tests/indeterminate.spec.tsx (4)

1-4: 移除未使用的导入

waitFor 导入后未在测试中使用,建议移除以保持代码整洁。

应用以下修改:

import React from 'react';
import { Circle, Line } from '../src';
-import { render, waitFor } from '@testing-library/react';
+import { render } from '@testing-library/react';
🧰 Tools
🪛 ESLint

[error] 3-3: 'waitFor' is defined but never used.

(@typescript-eslint/no-unused-vars)


6-30: 建议增加边界测试用例

当前测试覆盖了基本场景,建议添加以下边界情况的测试:

  • 负数百分比
  • 大于100的百分比
  • loading 属性在组件生命周期中的动态变化

需要我帮您生成这些测试用例的代码吗?


32-57: 建议添加错误处理测试

建议添加以下错误场景的测试:

  • 在加载状态下组件卸载的情况
  • 动画相关的浏览器兼容性检查
  • 样式计算失败的容错处理

需要我帮您生成这些测试用例的代码吗?


5-57: 测试结构清晰,覆盖了主要功能

测试代码组织良好,验证了不确定模式的核心功能。建议考虑:

  1. 添加测试用例描述文档
  2. 提取常用的测试工具函数
  3. 添加性能相关的测试用例
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between cc2fd04 and 4239195.

📒 Files selected for processing (3)
  • src/utils/getIndeterminateCircle.tsx (1 hunks)
  • src/utils/getIndeterminateLine.tsx (1 hunks)
  • tests/indeterminate.spec.tsx (1 hunks)
🚧 Files skipped from review as they are similar to previous changes (2)
  • src/utils/getIndeterminateCircle.tsx
  • src/utils/getIndeterminateLine.tsx
🧰 Additional context used
🪛 ESLint
tests/indeterminate.spec.tsx

[error] 3-3: 'waitFor' is defined but never used.

(@typescript-eslint/no-unused-vars)

@SaidMarar
Copy link
Contributor Author

图片

@afc163 done please check

@SaidMarar
Copy link
Contributor Author

If you wonder why i updated the test snapshot, it is due to useId state (id is undefined at first render) and that's impact useTransitionDuration that executes to quickly which return 0s 0s

we already have the same behaviour on Circle snapshot which is already (0s, 0s)

At any case, we must update snapshot, even if we fix useId to have an initial value.

@afc163 afc163 merged commit 202afb8 into react-component:master Mar 9, 2025
9 checks passed
@afc163 afc163 mentioned this pull request Mar 9, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants