chore(utils): parse-date supports relative time & fix routes (#7530)

This commit is contained in:
Queensferry
2021-05-15 11:08:33 +08:00
committed by GitHub
parent 2bc0d12019
commit 65e74a1c5e
13 changed files with 66 additions and 18 deletions

View File

@@ -21,11 +21,19 @@
具体解析参数请参考dayjs github说明
```javascript
const parseDate = require('@/utils/parse-date');
const { parseDate } = require('@/utils/parse-date');
const pubDate = parseDate('2020/12/30', 'YYYY/MM/DD')
const pubDate = parseDate('2020/12/30', 'YYYY/MM/DD');
```
如果你需要解析相对日期,请使用 `parseRelativeDate`
```javascript
const { parseRelativeDate } = require('@/utils/parse-date');
const pubDate = parseRelativeDate('2天前');
const pubDate = parseRelativeDate('前天 15:36');
```
### Timezone

View File

@@ -1,6 +1,6 @@
const got = require('@/utils/got');
const cheerio = require('cheerio');
const parseDate = require('@/utils/parse-date');
const { parseDate } = require('@/utils/parse-date');
module.exports = async (ctx) => {
const response = await got({

View File

@@ -1,4 +1,4 @@
const parseDate = require('@/utils/parse-date');
const { parseDate } = require('@/utils/parse-date');
const got = require('@/utils/got');
const cheerio = require('cheerio');

View File

@@ -1,7 +1,7 @@
const got = require('@/utils/got');
const cheerio = require('cheerio');
const iconv = require('iconv-lite');
const parseDate = require('@/utils/parse-date');
const { parseDate } = require('@/utils/parse-date');
module.exports = async (ctx) => {
const { bo_table } = ctx.params;

View File

@@ -2,7 +2,7 @@ const url = require('url');
const got = require('@/utils/got');
const cheerio = require('cheerio');
const timezone = require('@/utils/timezone');
const parseDate = require('@/utils/parse-date');
const { parseDate } = require('@/utils/parse-date');
const rootUrl = 'http://eea.gd.gov.cn/';
const config = {

View File

@@ -1,7 +1,7 @@
const got = require('@/utils/got');
const util = require('./utils');
const timezone = require('@/utils/timezone');
const parseDate = require('@/utils/parse-date');
const { parseDate } = require('@/utils/parse-date');
module.exports = async (ctx) => {
const tag_id = ctx.params.tag;

View File

@@ -1,6 +1,6 @@
const got = require('@/utils/got');
const cheerio = require('cheerio');
const parseDate = require('@/utils/parse-date');
const { parseDate } = require('@/utils/parse-date');
const timezone = require('@/utils/timezone');
module.exports = async (ctx) => {

View File

@@ -1,6 +1,6 @@
const got = require('@/utils/got');
const cheerio = require('cheerio');
const parseDate = require('@/utils/parse-date');
const { parseDate } = require('@/utils/parse-date');
const timezone = require('@/utils/timezone');
module.exports = async (ctx) => {

View File

@@ -1,7 +1,7 @@
const got = require('@/utils/got');
const cheerio = require('cheerio');
const timezone = require('@/utils/timezone');
const parseDate = require('@/utils/parse-date');
const { parseDate } = require('@/utils/parse-date');
module.exports = async (ctx) => {
const name = ctx.params.name;
const sort = ctx.params.sort || '0';

View File

@@ -1,6 +1,6 @@
const got = require('@/utils/got');
const cheerio = require('cheerio');
const parseDate = require('@/utils/parse-date');
const { parseDate } = require('@/utils/parse-date');
const timezone = require('@/utils/timezone');
module.exports = async (ctx) => {

View File

@@ -1,6 +1,7 @@
const got = require('@/utils/got');
const cheerio = require('cheerio');
const date_util = require('@/utils/date');
const { parseRelativeDate } = require('@/utils/parse-date');
const timezone = require('@/utils/timezone');
module.exports = async (ctx) => {
const link = `http://www.myzaker.com/?pos=selected_article`;
@@ -48,7 +49,7 @@ module.exports = async (ctx) => {
title: title,
link: itemUrl,
description: description,
pubDate: date_util(date, 8),
pubDate: timezone(parseRelativeDate(date), +8),
};
ctx.cache.set(itemUrl, JSON.stringify(single));
return Promise.resolve(single);

View File

@@ -1,6 +1,7 @@
const got = require('@/utils/got');
const cheerio = require('cheerio');
const date_util = require('@/utils/date');
const { parseRelativeDate } = require('@/utils/parse-date');
const timezone = require('@/utils/timezone');
module.exports = async (ctx) => {
const type = ctx.params.type || 'source';
@@ -50,7 +51,7 @@ module.exports = async (ctx) => {
title: title,
link: itemUrl,
description: description,
pubDate: date_util(date, 8),
pubDate: timezone(parseRelativeDate(date), +8),
};
ctx.cache.set(itemUrl, JSON.stringify(single));
return Promise.resolve(single);

View File

@@ -1,4 +1,42 @@
const dayjs = require('dayjs');
dayjs.extend(require('dayjs/plugin/customParseFormat'));
module.exports = (date, ...options) => dayjs(date, ...options).toDate();
const patterns = [
{
regexp: /^(\d+)分钟前$/,
handler: (minute) => dayjs().subtract(minute, 'minutes'),
},
{
regexp: /^(\d+)小时前$/,
handler: (hour) => dayjs().subtract(hour, 'hours'),
},
{
regexp: /^(\d+)天前$/,
handler: (day) => dayjs().subtract(day, 'days'),
},
{
regexp: /^今天\s*((\d+:\d+)?)$/,
handler: (hm) => dayjs(hm || '0:0', ['HH:m', 'HH:mm', 'H:m', 'H:mm']),
},
{
regexp: /^昨天\s*((\d+:\d+)?)$/,
handler: (hm) => dayjs(hm || '0:0', ['HH:m', 'HH:mm', 'H:m', 'H:mm']).subtract(1, 'day'),
},
{
regexp: /^前天\s*((\d+:\d+)?)$/,
handler: (hm) => dayjs(hm || '0:0', ['HH:m', 'HH:mm', 'H:m', 'H:mm']).subtract(2, 'day'),
},
];
module.exports = {
parseDate: (date, ...options) => dayjs(date, ...options).toDate(),
parseRelativeDate: (date) => {
for (const pattern of patterns) {
const match = pattern.regexp.exec(date);
if (match !== null) {
return pattern.handler(match[1]).toDate();
}
}
return null;
},
};