wenlele 2 years ago
parent
commit
a9133e3220
  1. BIN
      web/client/assets/images/weather/baoxue.png
  2. BIN
      web/client/assets/images/weather/dayu.png
  3. BIN
      web/client/assets/images/weather/duoyun.png
  4. BIN
      web/client/assets/images/weather/fucheng.png
  5. BIN
      web/client/assets/images/weather/leizhengyu.png
  6. BIN
      web/client/assets/images/weather/mai.png
  7. BIN
      web/client/assets/images/weather/qiangshachengbao.png
  8. BIN
      web/client/assets/images/weather/qing.png
  9. BIN
      web/client/assets/images/weather/shachengbao.png
  10. BIN
      web/client/assets/images/weather/tedabaoyu.png
  11. BIN
      web/client/assets/images/weather/weizhi.png
  12. BIN
      web/client/assets/images/weather/wu.png
  13. BIN
      web/client/assets/images/weather/xiaoxue.png
  14. BIN
      web/client/assets/images/weather/xiaoyu.png
  15. BIN
      web/client/assets/images/weather/yangsha.png
  16. BIN
      web/client/assets/images/weather/yingtian.png
  17. BIN
      web/client/assets/images/weather/yujiaxue.png
  18. BIN
      web/client/assets/images/weather/zhenyu.png
  19. BIN
      web/client/assets/images/weather/zhongxue.png
  20. BIN
      web/client/assets/images/weather/zhongyu.png
  21. 3
      web/client/src/sections/bigScreen/components/header.js
  22. 165
      web/client/src/sections/bigScreen/components/public/weather.js
  23. 4
      web/config.js
  24. 55
      web/routes/weather/index.js

BIN
web/client/assets/images/weather/baoxue.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

BIN
web/client/assets/images/weather/dayu.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

BIN
web/client/assets/images/weather/duoyun.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.8 KiB

BIN
web/client/assets/images/weather/fucheng.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.8 KiB

BIN
web/client/assets/images/weather/leizhengyu.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

BIN
web/client/assets/images/weather/mai.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 KiB

BIN
web/client/assets/images/weather/qiangshachengbao.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

BIN
web/client/assets/images/weather/qing.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

BIN
web/client/assets/images/weather/shachengbao.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

BIN
web/client/assets/images/weather/tedabaoyu.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

BIN
web/client/assets/images/weather/weizhi.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
web/client/assets/images/weather/wu.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 665 B

BIN
web/client/assets/images/weather/xiaoxue.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

BIN
web/client/assets/images/weather/xiaoyu.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
web/client/assets/images/weather/yangsha.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

BIN
web/client/assets/images/weather/yingtian.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 KiB

BIN
web/client/assets/images/weather/yujiaxue.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

BIN
web/client/assets/images/weather/zhenyu.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

BIN
web/client/assets/images/weather/zhongxue.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

BIN
web/client/assets/images/weather/zhongyu.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

3
web/client/src/sections/bigScreen/components/header.js

@ -3,6 +3,7 @@ import { connect } from 'react-redux';
import { Spin, Card, Modal, TreeSelect, message } from 'antd'; import { Spin, Card, Modal, TreeSelect, message } from 'antd';
import ProForm, { ProFormText, ModalForm, ProFormSwitch, ProFormTreeSelect } from '@ant-design/pro-form'; import ProForm, { ProFormText, ModalForm, ProFormSwitch, ProFormTreeSelect } from '@ant-design/pro-form';
import Title from 'antd/lib/skeleton/Title'; import Title from 'antd/lib/skeleton/Title';
import Weather from './public/weather';
const Header = ({ dispatch, actions, user, module, setModule, history }) => { const Header = ({ dispatch, actions, user, module, setModule, history }) => {
@ -14,7 +15,7 @@ const Header = ({ dispatch, actions, user, module, setModule, history }) => {
justifyContent: 'space-between', justifyContent: 'space-between',
alignItems: 'center' alignItems: 'center'
}}> }}>
<div style={{ width: 200, color: 'white', }}>天气</div> <Weather />
<div style={{ width: 200, color: 'white', display: 'flex', alignItems: 'center' }}> <div style={{ width: 200, color: 'white', display: 'flex', alignItems: 'center' }}>
<div style={{ <div style={{
width: 130, height: 52, width: 130, height: 52,

165
web/client/src/sections/bigScreen/components/public/weather.js

@ -0,0 +1,165 @@
import { Col, Row } from 'antd';
import moment from 'moment';
import React, { useState, useEffect, useMemo } from 'react';
import { RouteRequest } from '@peace/utils';
const WEATHERMARGIN = 1 * 60 * 60 * 1000;
const WEATHERArr = [
{
lbl: '未知',
key: 'weizhi',
},
{
lbl: '暴雪',
key: 'baoxue',
},
{
lbl: '多云',
key: 'duoyun',
},
{
lbl: '浮沉',
key: 'fucheng',
},
{
lbl: '雷阵雨',
key: 'leizhengyu',
},
{
lbl: '霾',
key: 'mai',
},
{
lbl: '强沙尘暴',
key: 'qiangshachengbao',
},
{
lbl: '晴',
key: 'qing',
},
{
lbl: '沙尘暴',
key: 'shachengbao',
},
{
lbl: '特大暴雨',
key: 'tedabaoyu',
},
{
lbl: '雾',
key: 'wu',
},
{
lbl: '小雪',
key: 'xiaoxue',
},
{
lbl: '小雨',
key: 'xiaoyu',
},
{
lbl: '扬沙',
key: 'yangsha',
},
{
lbl: '阴天',
key: 'yingtian',
},
{
lbl: '雨夹雪',
key: 'yujiaxue',
},
{
lbl: '阵雨',
key: 'zhenyu',
},
{
lbl: '中雪',
key: 'zhongxue',
},
{
lbl: '中雨',
key: 'zhongyu',
},
{
lbl: '大雨',
key: 'dayu',
},
];
const ICONSMAP = {};
WEATHERArr.forEach(({ lbl, key }) => {
const icon = `/assets/images/weather/${key}.png`;
ICONSMAP[lbl] = icon;
});
function Weather() {
const [time, setTime] = useState(new Date().toLocaleTimeString());
const [weather, setWeather] = useState('');
const [temp, setTemp] = useState(0);
useEffect(() => {
const timeUpdate = setInterval(() => {
setTime(new Date().toLocaleTimeString());
}, 1000);
return () => {
clearInterval(timeUpdate);
};
}, []);
const queryWeather = () => {
RouteRequest.get(`/query/weather?cname=南昌市`).then((doc) => {
console.log(doc, 'weather');
const w = doc?.text || '未知';
const temp = doc?.temp || 0;
setWeather(w);
setTemp(temp);
});
};
useEffect(() => {
queryWeather();
const timeUpdate = setInterval(() => {
queryWeather();
}, WEATHERMARGIN);
return () => {
clearInterval(timeUpdate);
};
}, []);
const iconSrc = useMemo(() => {
const icon = ICONSMAP[weather];
if (icon) return icon;
const rgx = new RegExp(weather);
for (const k in ICONSMAP) {
if (rgx.test(k)) {
return ICONSMAP[k];
}
}
return '';
}, [weather]);
return (
<div style={{ color: '#C3E6FF', marginLeft: '37px', display: 'flex', justifyContent: 'space-between', alignItems: 'center' }}>
<div style={{ borderRight: '0.5px solid #C3E6FF', paddingRight: 10 }}>
<div style={{ fontSize: 16 }}>{time}</div>
<div style={{ marginLeft: '5px', fontSize: 12 }}>
{moment().format(
'YYYY-MM-DD'
)}
</div>
</div>
<div style={{ paddingLeft: 10, display: 'flex' }}>
<img src={iconSrc} alt="icon" style={{ width: 44, height: 40, marginRight: 5 }} />
<div>
<div>{weather}</div>
<div style={{ fontSize: 12 }}>{temp}</div>
</div>
</div>
</div>
);
}
export default Weather;

4
web/config.js

@ -21,7 +21,7 @@ args.option(['u', 'api-url'], 'webapi的URL');
const flags = args.parse(process.argv); const flags = args.parse(process.argv);
const FS_UNIAPP_API = process.env.FS_UNIAPP_API || flags.apiUrl; const FS_UNIAPP_API = process.env.FS_UNIAPP_API || flags.apiUrl;
const weatherUrl = process.env.ANXINCLOUD_WEATHERAPP_API || "https://weatherssj.anxinyun.cn/weatherApp/weather/getImmeData"
if ( if (
!FS_UNIAPP_API !FS_UNIAPP_API
@ -54,7 +54,7 @@ const product = {
}, { }, {
entry: require('./routes').entry, entry: require('./routes').entry,
opts: { opts: {
weatherUrl,
} }
}, { }, {
entry: require('./client').entry,// 静态信息 entry: require('./client').entry,// 静态信息

55
web/routes/weather/index.js

@ -0,0 +1,55 @@
const request = require('superagent');
let _weatherUrl = '';
module.exports.entry = function (app, router, opts) {
const { weatherUrl } = opts;
console.log(weatherUrl, '天气');
_weatherUrl = weatherUrl;
// _weatherUrl = "https://weatherssj.anxinyun.cn/weatherApp/weather/getImmeData"
router.get('/query/weather', weather);
};
async function weather(ctx) {
try {
const { cname } = ctx.query;
const reg = /.+?(省|市|自治区|自治州|县|区)/g;
const arr = cname.match(reg);
if (Array.isArray(arr)) {
let cityName = arr[0];
if (arr[1]) {
cityName = arr[1];
}
const weatherRes = await request.post(_weatherUrl).send({ cityName });
const { body } = weatherRes;
if (body && body.data) {
ctx.status = 200;
ctx.body = { ...body.data, cname, texta: _weatherUrl };
} else {
ctx.status = 400;
ctx.body = { msg: '获取天气错误' };
}
} else {
ctx.status = 400;
ctx.body = { msg: '地址解析错误' };
}
} catch (error) {
console.log('[*err]', error);
ctx.status = 400;
ctx.body = error;
}
}
// ip地址识别库
// 淘宝IP地址查询接口:http://ip.taobao.com/service/getIpInfo.php?ip=1.1.35.57
// 腾讯IP地址查询接口:http://fw.qq.com/ipaddress
// 新浪的IP地址查询接口:http://int.dpool.sina.com.cn/iplookup/iplookup.php?format=js
// 新浪多地域测试方法:http://int.dpool.sina.com.cn/iplookup/iplookup.php?format=js&ip=218.192.3.42
// 搜狐IP地址查询接口(默认GBK):http://pv.sohu.com/cityjson
// 搜狐IP地址查询接口(可设置编码):http://pv.sohu.com/cityjson?ie=utf-8
// 搜狐另外的IP地址查询接口:http://txt.go.sohu.com/ip/soip
// 谷歌IP地址查询接口:http://j.maxmind.com/app/geoip.js
// 1616 IP地址查询接口:http://w.1616.net/chaxun/iptolocal.php
// 126 http://ip.ws.126.net/ipquery hao123
// http://app.hao123.com/ipquery/getcity.php?rtype=2
// 太平洋电脑网 http://whois.pconline.com.cn/
Loading…
Cancel
Save