Skip to content

Commit d4a46fc

Browse files
committed
Update moji.js
1 parent e70f0fc commit d4a46fc

File tree

1 file changed

+81
-49
lines changed

1 file changed

+81
-49
lines changed

Task/moji.js

Lines changed: 81 additions & 49 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
/*
22
支持boxjs手动修改位置,可直接输入中文地区名
3-
更新时间 2020-12-10 20:13
3+
更新时间 2020-12-14 21:13
44
*/
55
const $ = new Env('墨迹天气')
66
const City = encodeURIComponent($.getdata('city')||"北京")
@@ -13,13 +13,12 @@ let daylys = $.getdata('day_desc') || true, //每日天气
1313
!(async() => {
1414
await SearchCity();
1515
await Weather();
16-
await Indexs();
16+
await TodayReport();
1717
await showmsg()
1818
})()
1919
.catch((e) => $.logErr(e))
2020
.finally(() => $.done())
2121

22-
2322
function Weather() {
2423
return new Promise((resolve, reject) =>{
2524
let weatherurl = {
@@ -56,8 +55,6 @@ try {
5655
})
5756
}
5857

59-
60-
6158
function SearchCity() {
6259
return new Promise((resolve) =>{
6360
let cityurl = {
@@ -85,6 +82,7 @@ function SearchCity() {
8582
})
8683
})
8784
}
85+
8886
function mapSkycon(skycon) {
8987
const map = {
9088
"晴": [
@@ -155,58 +153,62 @@ function mapSkycon(skycon) {
155153
return map[skycon];
156154
}
157155

156+
function windSpeed(speed) {
157+
const map = {
158+
0: "无风",
159+
1: "软风",
160+
2: "轻风",
161+
3: "微风",
162+
4: "和风",
163+
5: "劲风",
164+
6: "强风",
165+
7: "疾风",
166+
8: "大风",
167+
9: "烈风",
168+
10: "狂风",
169+
11: "暴风",
170+
12: "飓风"
171+
}
172+
const wind_desc = $.weather.data.wind_desc.value
173+
return `${map[wind_desc[0]]}`
174+
}
158175

159-
function showmsg() {
160-
let icon = "❓"
161-
console.log("\n您的地区为〈"+$.weather.data.city+"〉")
162-
nowweather = $.weather.data.weather_desc //当前天气
163-
nowtemp = $.weather.data.temp.value+$.weather.data.temp.unit //当前温度
164-
nowwindval = $.weather.data.wind_desc.winddir+$.weather.data.wind_desc.value+$.weather.data.wind_desc.unit //当前风速
165-
nowhum = $.weather.data.humidity //当前湿度
166-
aqidesc = $.weather.data.aqi_desc //空气质量
167-
sunrise = $.weather.data.sunset.sunrise
168-
sundown = $.weather.data.sunset.sundown
169-
daytemp = $.weather.data.forecast_day[0].temp_low.value+"℃"+"-"+$.weather.data.forecast_day[0].temp_high.value+"℃"
170-
$.desc = " 当天温度: "+daytemp+" 实时温度🌡:"+nowtemp+"\n " +` 天气: ${mapSkycon(nowweather)[0]}`+" 风速🌪:"+ nowwindval + "\n 空气质量🌬:"+aqidesc+" 湿度☔️:"+nowhum+"\n"
171-
if(daylys== 'true'){
172-
$.desc += "【每周天气】\n"
173-
}
174-
for ( Dayweather of $.weather.data.forecast_day){
175-
week = Dayweather.predict_week // 日期
176-
date = Dayweather.predict_date
177-
178-
Daysweather = Dayweather.weather_desc_day //当日天气
179-
Winds = Dayweather.wind_desc_day.winddir+Dayweather.wind_desc_day.value+ Dayweather.wind_desc_day.unit //当日风速
180-
temps = Dayweather.temp_low.value+Dayweather.temp_low.unit+"至"+Dayweather.temp_high.value+Dayweather.temp_high.unit //当日温度
181-
if(reduction== 'true') {$.log(" "+ date+" "+Daysweather+" "+ temps+" "+Winds)
182-
}
183-
if(daylys== 'true'){
184-
$.desc += " "+week+" "+mapSkycon(Daysweather)[0]+" "+ temps+" "+Winds+"\n"
185-
}
186-
};
187-
if(hourlys == 'true'){
188-
$.desc += "【未来6小时变化预报】\n"
189-
}
190-
for ( i=0;i <6 ;i++){
191-
Hourlyweather = $.weather.data.hourly
176+
function HourlyReport() {
177+
const Hourlyweather = $.weather.data.hourly
178+
for ( i=0;i < 6 ;i++){
192179
hours = Hourlyweather[i].temperature.hour
193180
hourweather = Hourlyweather[i].temperature.condition
194-
hourWinds = Hourlyweather[i].wind.wind_desc.winddir+Hourlyweather[i].wind.wind_desc.value+ Hourlyweather[i].wind.wind_desc.unit
181+
hourly_Skycon = mapSkycon(hourweather) ? mapSkycon(hourweather)[0]:" "+hourweather
182+
hourWinds = Hourlyweather[i].wind.wind_desc.winddir+Hourlyweather[i].wind.wind_desc.value+Hourlyweather[i].wind.wind_desc.unit
195183
hourtemps = Hourlyweather[i].temperature.temp.value+Hourlyweather[i].temperature.temp.unit
196184
if(hourlys == 'true'&& i==0 ){
197-
$.desc += " "+hours+":00 "+mapSkycon(Hourlyweather[i].temperature.condition)[0]+" "+ hourtemps+" "+hourWinds +"\n"
185+
$.desc += " "+hours+":00 "+hourly_Skycon+" "+ hourtemps+" "+hourWinds +"\n"
198186
} else if(hourlys == 'true'&& (hourweather != Hourlyweather[i-1].temperature.condition || hourtemps != Hourlyweather[i-1].temperature.temp.value+"℃")){
199-
$.desc += " "+hours+":00 "+mapSkycon(Hourlyweather[i].temperature.condition)[0]+" "+ hourtemps+" "+hourWinds +"\n"
187+
$.desc += " "+hours+":00 "+hourly_Skycon+" "+ hourtemps+" "+hourWinds +"\n"
200188
}
201189
if(reduction == 'true') {
202190
$.log(" "+hours+":00 "+hourweather+" "+ hourtemps+" "+hourWinds)
203191
}
192+
}
193+
}
194+
195+
function WeekReport() {
196+
for (Dayweather of $.weather.data.forecast_day){
197+
week = Dayweather.predict_week // 日期
198+
date = Dayweather.predict_date
199+
200+
Daysweather = Dayweather.weather_desc_day //当日天气
201+
Days_Skycon = mapSkycon(Daysweather) ? mapSkycon(Daysweather)[0]:" "+Daysweather
202+
Winds = Dayweather.wind_desc_day.winddir+Dayweather.wind_desc_day.value+ Dayweather.wind_desc_day.unit //当日风速
203+
temps = Dayweather.temp_low.value+Dayweather.temp_low.unit+"至"+Dayweather.temp_high.value+Dayweather.temp_high.unit //当日温度
204+
if(reduction== 'true') {$.log(" "+ date+" "+Daysweather+" "+ temps+" "+Winds)
205+
}
206+
$.desc += " "+week+" "+Days_Skycon+" "+ temps+" "+Winds+"\n"
204207
}
205-
if ($.index.code == 0){
206-
if(indexs== 'true'){
207-
$.desc += "【生活指数】\n"
208-
}
209-
for (indexdata of $.index.indexs){
208+
}
209+
210+
function IndexReport() {
211+
for (indexdata of $.index.indexs){
210212
indexType = indexdata.indexType
211213
indexLevel = indexdata.indexLevel
212214
indexLevelDesc =indexdata.indexLevelDesc
@@ -216,11 +218,41 @@ function showmsg() {
216218
}
217219
if(reduction == 'true'){ console.log("\n "+indexType+" "+indexLevel+"级 "+ indexLevelDesc+"\n"+indexDesc )
218220
}
219-
}
220-
}
221+
}
222+
}
223+
224+
function TodayReport() {
225+
console.log("您的地区为〈"+$.weather.data.city+"〉")
226+
nowweather = $.weather.data.weather_desc //当前天气
227+
today_Skycon = mapSkycon(nowweather)? mapSkycon(nowweather)[0]:" "+nowweather
228+
nowtemp = $.weather.data.temp.value+$.weather.data.temp.unit //当前温度
229+
windDirection = $.weather.data.wind_desc.winddir
230+
nowwindval = $.weather.data.wind_desc.value //当前风速
231+
nowhum = $.weather.data.humidity //当前湿度
232+
aqidesc = $.weather.data.aqi_desc //空气质量
233+
sunrise = $.weather.data.sunset.sunrise
234+
sundown = $.weather.data.sunset.sundown
235+
daytemp = $.weather.data.forecast_day[0].temp_low.value+"℃"+"-"+$.weather.data.forecast_day[0].temp_high.value+"℃"
236+
$.desc = " 当天温度: "+daytemp+" 实时温度🌡:"+nowtemp+"\n " +` 实时天气: ${today_Skycon}`+" 风速🌪: "+ windDirection + nowwindval +"级" + windSpeed(nowwindval)+ "\n 空气质量🌬: "+aqidesc+" 湿度☔️: "+nowhum+"\n"
237+
}
238+
239+
async function showmsg() {
240+
if(daylys== 'true'){
241+
$.desc += "【每周天气】\n"
242+
await WeekReport()
243+
}
244+
if(hourlys == 'true'){
245+
$.desc += "【未来6小时变化预报】\n"
246+
await HourlyReport()
247+
}
248+
if (indexs== 'true'){
249+
$.desc += "【生活指数】\n"
250+
await Indexs();
251+
await IndexReport()
252+
}
221253
$.sub = "【今日天气】" +`${mapSkycon(nowweather)[0]}`
222254
$.msg($.weather.data.city +"天气预报 "+$.weather.data.forecast_day[0].predict_date +$.weather.data.forecast_day[0].predict_week,$.sub, $.desc,{"media-url": `${mapSkycon(nowweather)[1]}`
223-
})
255+
})
224256
}
225257

226258
function Env(t,e){class s{constructor(t){this.env=t}send(t,e="GET"){t="string"==typeof t?{url:t}:t;let s=this.get;return"POST"===e&&(s=this.post),new Promise((e,i)=>{s.call(this,t,(t,s,r)=>{t?i(t):e(s)})})}get(t){return this.send.call(this.env,t)}post(t){return this.send.call(this.env,t,"POST")}}return new class{constructor(t,e){this.name=t,this.http=new s(this),this.data=null,this.dataFile="box.dat",this.logs=[],this.isMute=!1,this.isNeedRewrite=!1,this.logSeparator="\n",this.startTime=(new Date).getTime(),Object.assign(this,e),this.log("",`\ud83d\udd14${this.name}, \u5f00\u59cb!`)}isNode(){return"undefined"!=typeof module&&!!module.exports}isQuanX(){return"undefined"!=typeof $task}isSurge(){return"undefined"!=typeof $httpClient&&"undefined"==typeof $loon}isLoon(){return"undefined"!=typeof $loon}toObj(t,e=null){try{return JSON.parse(t)}catch{return e}}toStr(t,e=null){try{return JSON.stringify(t)}catch{return e}}getjson(t,e){let s=e;const i=this.getdata(t);if(i)try{s=JSON.parse(this.getdata(t))}catch{}return s}setjson(t,e){try{return this.setdata(JSON.stringify(t),e)}catch{return!1}}getScript(t){return new Promise(e=>{this.get({url:t},(t,s,i)=>e(i))})}runScript(t,e){return new Promise(s=>{let i=this.getdata("@chavy_boxjs_userCfgs.httpapi");i=i?i.replace(/\n/g,"").trim():i;let r=this.getdata("@chavy_boxjs_userCfgs.httpapi_timeout");r=r?1*r:20,r=e&&e.timeout?e.timeout:r;const[o,h]=i.split("@"),a={url:`http://${h}/v1/scripting/evaluate`,body:{script_text:t,mock_type:"cron",timeout:r},headers:{"X-Key":o,Accept:"*/*"}};this.post(a,(t,e,i)=>s(i))}).catch(t=>this.logErr(t))}loaddata(){if(!this.isNode())return{};{this.fs=this.fs?this.fs:require("fs"),this.path=this.path?this.path:require("path");const t=this.path.resolve(this.dataFile),e=this.path.resolve(process.cwd(),this.dataFile),s=this.fs.existsSync(t),i=!s&&this.fs.existsSync(e);if(!s&&!i)return{};{const i=s?t:e;try{return JSON.parse(this.fs.readFileSync(i))}catch(t){return{}}}}}writedata(){if(this.isNode()){this.fs=this.fs?this.fs:require("fs"),this.path=this.path?this.path:require("path");const t=this.path.resolve(this.dataFile),e=this.path.resolve(process.cwd(),this.dataFile),s=this.fs.existsSync(t),i=!s&&this.fs.existsSync(e),r=JSON.stringify(this.data);s?this.fs.writeFileSync(t,r):i?this.fs.writeFileSync(e,r):this.fs.writeFileSync(t,r)}}lodash_get(t,e,s){const i=e.replace(/\[(\d+)\]/g,".$1").split(".");let r=t;for(const t of i)if(r=Object(r)[t],void 0===r)return s;return r}lodash_set(t,e,s){return Object(t)!==t?t:(Array.isArray(e)||(e=e.toString().match(/[^.[\]]+/g)||[]),e.slice(0,-1).reduce((t,s,i)=>Object(t[s])===t[s]?t[s]:t[s]=Math.abs(e[i+1])>>0==+e[i+1]?[]:{},t)[e[e.length-1]]=s,t)}getdata(t){let e=this.getval(t);if(/^@/.test(t)){const[,s,i]=/^@(.*?)\.(.*?)$/.exec(t),r=s?this.getval(s):"";if(r)try{const t=JSON.parse(r);e=t?this.lodash_get(t,i,""):e}catch(t){e=""}}return e}setdata(t,e){let s=!1;if(/^@/.test(e)){const[,i,r]=/^@(.*?)\.(.*?)$/.exec(e),o=this.getval(i),h=i?"null"===o?null:o||"{}":"{}";try{const e=JSON.parse(h);this.lodash_set(e,r,t),s=this.setval(JSON.stringify(e),i)}catch(e){const o={};this.lodash_set(o,r,t),s=this.setval(JSON.stringify(o),i)}}else s=this.setval(t,e);return s}getval(t){return this.isSurge()||this.isLoon()?$persistentStore.read(t):this.isQuanX()?$prefs.valueForKey(t):this.isNode()?(this.data=this.loaddata(),this.data[t]):this.data&&this.data[t]||null}setval(t,e){return this.isSurge()||this.isLoon()?$persistentStore.write(t,e):this.isQuanX()?$prefs.setValueForKey(t,e):this.isNode()?(this.data=this.loaddata(),this.data[e]=t,this.writedata(),!0):this.data&&this.data[e]||null}initGotEnv(t){this.got=this.got?this.got:require("got"),this.cktough=this.cktough?this.cktough:require("tough-cookie"),this.ckjar=this.ckjar?this.ckjar:new this.cktough.CookieJar,t&&(t.headers=t.headers?t.headers:{},void 0===t.headers.Cookie&&void 0===t.cookieJar&&(t.cookieJar=this.ckjar))}get(t,e=(()=>{})){t.headers&&(delete t.headers["Content-Type"],delete t.headers["Content-Length"]),this.isSurge()||this.isLoon()?(this.isSurge()&&this.isNeedRewrite&&(t.headers=t.headers||{},Object.assign(t.headers,{"X-Surge-Skip-Scripting":!1})),$httpClient.get(t,(t,s,i)=>{!t&&s&&(s.body=i,s.statusCode=s.status),e(t,s,i)})):this.isQuanX()?(this.isNeedRewrite&&(t.opts=t.opts||{},Object.assign(t.opts,{hints:!1})),$task.fetch(t).then(t=>{const{statusCode:s,statusCode:i,headers:r,body:o}=t;e(null,{status:s,statusCode:i,headers:r,body:o},o)},t=>e(t))):this.isNode()&&(this.initGotEnv(t),this.got(t).on("redirect",(t,e)=>{try{if(t.headers["set-cookie"]){const s=t.headers["set-cookie"].map(this.cktough.Cookie.parse).toString();this.ckjar.setCookieSync(s,null),e.cookieJar=this.ckjar}}catch(t){this.logErr(t)}}).then(t=>{const{statusCode:s,statusCode:i,headers:r,body:o}=t;e(null,{status:s,statusCode:i,headers:r,body:o},o)},t=>{const{message:s,response:i}=t;e(s,i,i&&i.body)}))}post(t,e=(()=>{})){if(t.body&&t.headers&&!t.headers["Content-Type"]&&(t.headers["Content-Type"]="application/x-www-form-urlencoded"),t.headers&&delete t.headers["Content-Length"],this.isSurge()||this.isLoon())this.isSurge()&&this.isNeedRewrite&&(t.headers=t.headers||{},Object.assign(t.headers,{"X-Surge-Skip-Scripting":!1})),$httpClient.post(t,(t,s,i)=>{!t&&s&&(s.body=i,s.statusCode=s.status),e(t,s,i)});else if(this.isQuanX())t.method="POST",this.isNeedRewrite&&(t.opts=t.opts||{},Object.assign(t.opts,{hints:!1})),$task.fetch(t).then(t=>{const{statusCode:s,statusCode:i,headers:r,body:o}=t;e(null,{status:s,statusCode:i,headers:r,body:o},o)},t=>e(t));else if(this.isNode()){this.initGotEnv(t);const{url:s,...i}=t;this.got.post(s,i).then(t=>{const{statusCode:s,statusCode:i,headers:r,body:o}=t;e(null,{status:s,statusCode:i,headers:r,body:o},o)},t=>{const{message:s,response:i}=t;e(s,i,i&&i.body)})}}time(t){let e={"M+":(new Date).getMonth()+1,"d+":(new Date).getDate(),"H+":(new Date).getHours(),"m+":(new Date).getMinutes(),"s+":(new Date).getSeconds(),"q+":Math.floor(((new Date).getMonth()+3)/3),S:(new Date).getMilliseconds()};/(y+)/.test(t)&&(t=t.replace(RegExp.$1,((new Date).getFullYear()+"").substr(4-RegExp.$1.length)));for(let s in e)new RegExp("("+s+")").test(t)&&(t=t.replace(RegExp.$1,1==RegExp.$1.length?e[s]:("00"+e[s]).substr((""+e[s]).length)));return t}msg(e=t,s="",i="",r){const o=t=>{if(!t)return t;if("string"==typeof t)return this.isLoon()?t:this.isQuanX()?{"open-url":t}:this.isSurge()?{url:t}:void 0;if("object"==typeof t){if(this.isLoon()){let e=t.openUrl||t.url||t["open-url"],s=t.mediaUrl||t["media-url"];return{openUrl:e,mediaUrl:s}}if(this.isQuanX()){let e=t["open-url"]||t.url||t.openUrl,s=t["media-url"]||t.mediaUrl;return{"open-url":e,"media-url":s}}if(this.isSurge()){let e=t.url||t.openUrl||t["open-url"];return{url:e}}}};this.isMute||(this.isSurge()||this.isLoon()?$notification.post(e,s,i,o(r)):this.isQuanX()&&$notify(e,s,i,o(r)));let h=["","==============\ud83d\udce3\u7cfb\u7edf\u901a\u77e5\ud83d\udce3=============="];h.push(e),s&&h.push(s),i&&h.push(i),console.log(h.join("\n")),this.logs=this.logs.concat(h)}log(...t){t.length>0&&(this.logs=[...this.logs,...t]),console.log(t.join(this.logSeparator))}logErr(t,e){const s=!this.isSurge()&&!this.isQuanX()&&!this.isLoon();s?this.log("",`\u2757\ufe0f${this.name}, \u9519\u8bef!`,t.stack):this.log("",`\u2757\ufe0f${this.name}, \u9519\u8bef!`,t)}wait(t){return new Promise(e=>setTimeout(e,t))}done(t={}){const e=(new Date).getTime(),s=(e-this.startTime)/1e3;this.log("",`\ud83d\udd14${this.name}, \u7ed3\u675f! \ud83d\udd5b ${s} \u79d2`),this.log(),(this.isSurge()||this.isQuanX()||this.isLoon())&&$done(t)}}(t,e)}

0 commit comments

Comments
 (0)