Skip to content

fix(datepicker): 解决未传默认值时限制时间边界不准确问题#3265

Merged
xiaoyatong merged 19 commits intojdf2e:feat_v3.xfrom
irisSong:bugfix_datepicer
Jun 13, 2025
Merged

fix(datepicker): 解决未传默认值时限制时间边界不准确问题#3265
xiaoyatong merged 19 commits intojdf2e:feat_v3.xfrom
irisSong:bugfix_datepicer

Conversation

@irisSong
Copy link
Collaborator

@irisSong irisSong commented Jun 11, 2025

🤔 这个变动的性质是?

  • 新特性提交
  • 日常 bug 修复
  • 站点、文档改进
  • 演示代码改进
  • 组件样式/交互改进
  • TypeScript 定义更新
  • 包体积优化
  • 性能优化
  • 功能增强
  • 国际化改进
  • 重构
  • 代码风格优化
  • 测试用例
  • 分支合并
  • 其他改动(是关于什么的改动?)

🔗 相关 Issue

💡 需求背景和解决方案

☑️ 请求合并前的自查清单

⚠️ 请自检并全部勾选全部选项⚠️

  • 文档已补充或无须补充
  • 代码演示已提供或无须提供
  • TypeScript 定义已补充或无须补充
  • fork仓库代码是否为最新避免文件冲突
  • Files changed 没有 package.json lock 等无关文件

Summary by CodeRabbit

  • 修复问题
    • 修正了日期选择器在未选择日期时的默认日期处理逻辑,提升了日期范围生成的准确性。

@coderabbitai
Copy link

coderabbitai bot commented Jun 11, 2025

Walkthrough

本次更改调整了 generateDatePickerRanges 函数内部 selected 变量的初始化逻辑。现在,selected 会根据 selectedDate 是否存在来决定使用 selectedDate 还是 startDate 进行初始化,函数签名和外部接口未发生变化。

Changes

文件路径 变更摘要
src/packages/datepicker/utils.ts 修改了 generateDatePickerRanges 内部 selected 变量的初始化逻辑。

Poem

🐰
日期选择器代码轻轻改,
选中逻辑更灵活,兔儿心欢快。
若无选中用起始,
代码如春风拂面来。
新的一天,新的彩!

✨ Finishing Touches
  • 📝 Generate Docstrings

Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out.

❤️ 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.
    • Explain this complex logic.
    • 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 explain this code block.
    • @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 explain its main purpose.
    • @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.

Support

Need help? Create a ticket on our support page for assistance with any issues or questions.

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.
  • @coderabbitai generate sequence diagram to generate a sequence diagram of the changes in this PR.
  • @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.

@github-actions github-actions bot added action:review This PR needs more reviews (less than 2 approvals) 3.x Target branch 3.x labels Jun 11, 2025
@codecov
Copy link

codecov bot commented Jun 11, 2025

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 87.75%. Comparing base (c17af68) to head (9fba5ec).
Report is 2 commits behind head on feat_v3.x.

Additional details and impacted files
@@            Coverage Diff             @@
##           feat_v3.x    #3265   +/-   ##
==========================================
  Coverage      87.75%   87.75%           
==========================================
  Files            290      290           
  Lines          19111    19111           
  Branches        2938     2939    +1     
==========================================
  Hits           16771    16771           
  Misses          2335     2335           
  Partials           5        5           

☔ 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.

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: 1

📜 Review details

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

📥 Commits

Reviewing files that changed from the base of the PR and between c17af68 and 9fba5ec.

📒 Files selected for processing (1)
  • src/packages/datepicker/utils.ts (1 hunks)
⏰ Context from checks skipped due to timeout of 90000ms (2)
  • GitHub Check: test
  • GitHub Check: build

Comment on lines +76 to 78
const selected = selectedDate ? new Date(selectedDate) : new Date(startDate)
if (!selected) return []

Copy link

Choose a reason for hiding this comment

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

🛠️ Refactor suggestion

⚠️ Potential issue

selected 的有效性依旧得不到保证

Date 对象在 JS 中始终为 truthy 值,if (!selected) 无法判断其是否为 Invalid Date
selectedDate 为非法时间戳(如 NaN)或 undefined 时,selected 依旧通过检查,随后参与边界计算会产生 NaN 级联,导致组件异常。

建议同时校验 selected 的合法性,或直接复用已引入的 isDate 工具:

- const selected = selectedDate ? new Date(selectedDate) : new Date(startDate)
- if (!selected) return []
+ const selected = selectedDate
+   ? new Date(selectedDate)
+   : new Date(startDate.getTime()) // 避免引用同一实例
+
+ // 无效日期直接返回空数组,防止后续 NaN 传播
+ if (!isDate(selected)) return []

这样既能处理 selectedDate 缺省的场景,也能防止非法值进入后续逻辑。
另外,startDate 已是 Date 实例,如无必要可避免 new Date(startDate) 的重复包装。

📝 Committable suggestion

‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.

Suggested change
const selected = selectedDate ? new Date(selectedDate) : new Date(startDate)
if (!selected) return []
const selected = selectedDate
? new Date(selectedDate)
: new Date(startDate.getTime()) // 避免引用同一实例
// 无效日期直接返回空数组,防止后续 NaN 传播
if (!isDate(selected)) return []
🤖 Prompt for AI Agents
In src/packages/datepicker/utils.ts around lines 76 to 78, the check for
selected date validity is incorrect because a Date object is always truthy even
if invalid. Fix this by using the existing isDate utility to verify that
selected is a valid date instance. Also, avoid unnecessary new Date wrapping of
startDate since it is already a Date object. Update the code to validate
selected with isDate and handle invalid dates by returning an empty array early.

@xiaoyatong xiaoyatong merged commit 94333d4 into jdf2e:feat_v3.x Jun 13, 2025
8 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

3.x Target branch 3.x action:review This PR needs more reviews (less than 2 approvals) size/XS

Projects

None yet

Development

Successfully merging this pull request may close these issues.

DatePicker在type="year-month"下,startDate不能限制开始月份。

2 participants