diff --git a/.github/workflows/issue-schedule.yml b/.github/workflows/issue-schedule.yml new file mode 100644 index 0000000000..7f78cb7180 --- /dev/null +++ b/.github/workflows/issue-schedule.yml @@ -0,0 +1,97 @@ +name: Issue Schedule +on: + workflow_dispatch: + schedule: + - cron: '30 1 * * *' + +jobs: + send-message: + runs-on: ubuntu-latest + steps: + - name: Send Unconfirmed Issues to DingTalk + uses: actions/github-script@v7 + env: + DINGDING_BOT_TOKEN: ${{ secrets.DINGDING_BOT_TOKEN }} + actionTitle: '近 7 天未确认的 issue' + with: + script: | + const dingdingTokenKey = process.env.DINGDING_BOT_TOKEN; + + const fromNow = (data) => { + const relativeTimeFormat = new Intl.RelativeTimeFormat('zh-CN'); + const date = new Date(data); + const now = new Date(); + + const diffInSeconds = Math.floor((now - date) / 1000); + const diffInMinutes = Math.floor(diffInSeconds / 60); + const diffInHours = Math.floor(diffInMinutes / 60); + const diffInDays = Math.floor(diffInHours / 24); + + if (diffInDays > 0) { + return relativeTimeFormat.format(-diffInDays, 'day'); + } else if (diffInHours > 0) { + return relativeTimeFormat.format(-diffInHours, 'hour'); + } else if (diffInMinutes > 0) { + return relativeTimeFormat.format(-diffInMinutes, 'minute'); + } else { + return relativeTimeFormat.format(-diffInSeconds, 'second'); + } + }; + + const response = await fetch('https://api.github.com/search/issues?q=repo:ant-design/ant-design&is:open+is:issue+label:unconfirmed&per_page=100'); + const data = await response.json(); + const issueList = []; + for (const item of data.items) { + const { created_at, html_url, pull_request, state, title, labels } = item; + const createdAt = new Date(created_at); + const now = new Date(); + const diffTime = Math.abs(now - createdAt); + const diffDays = Math.ceil(diffTime / (1000 * 60 * 60 * 24)); + + const isUnconfirmed = labels.some(label => label.name === 'unconfirmed'); + + if (!isUnconfirmed) { + continue; + } + + if (diffDays > 7) { + break; + } + + if (!pull_request && !html_url.includes('pull') && state === 'open') { + issueList.push({ + html_url, + created_at, + title + }) + } + } + + const actionTitle = process.env.actionTitle + `(${issueList.length})`; + + const markdownList = `