@idmwx/idmui-gl3 4.7.9 → 4.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +1074 -1036
- package/dist/index.umd.cjs +14 -14
- package/dist/loading-blue.gif +0 -0
- package/dist/mapbox/src/components/other/point.vue.d.ts +1 -0
- package/dist/style.css +1 -1
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -1,21 +1,21 @@
|
|
|
1
1
|
var G0 = Object.defineProperty;
|
|
2
|
-
var
|
|
3
|
-
var
|
|
4
|
-
import { LayerHelper as x0, CompanyHelper as
|
|
5
|
-
import { resolveComponent as
|
|
6
|
-
import * as
|
|
7
|
-
import
|
|
8
|
-
import
|
|
9
|
-
import
|
|
10
|
-
import { TropicalHelper as
|
|
11
|
-
import { Meteo2Assist as
|
|
12
|
-
import
|
|
13
|
-
const
|
|
2
|
+
var U0 = (z, M, b) => M in z ? G0(z, M, { enumerable: !0, configurable: !0, writable: !0, value: b }) : z[M] = b;
|
|
3
|
+
var Y = (z, M, b) => (U0(z, typeof M != "symbol" ? M + "" : M, b), b);
|
|
4
|
+
import { LayerHelper as x0, CompanyHelper as I0 } from "@idm-plugin/tag";
|
|
5
|
+
import { resolveComponent as I, openBlock as s, createElementBlock as W, createElementVNode as c, normalizeStyle as c0, createVNode as C, withCtx as t0, normalizeClass as V, Fragment as F, renderList as K, toDisplayString as T, createCommentVNode as j, createTextVNode as z0, withDirectives as y0, createStaticVNode as K0, vShow as X0, defineComponent as J0, withModifiers as T0, mergeProps as H } from "vue";
|
|
6
|
+
import * as v from "@turf/turf";
|
|
7
|
+
import Y0 from "@mapbox/sphericalmercator";
|
|
8
|
+
import G from "moment";
|
|
9
|
+
import w0 from "mapbox-gl";
|
|
10
|
+
import { TropicalHelper as Q0, LngLatHelper as b0, LaneHelper as g0 } from "@idm-plugin/geo";
|
|
11
|
+
import { Meteo2Assist as k0 } from "@idm-plugin/meteo";
|
|
12
|
+
import N0 from "axios";
|
|
13
|
+
const Q = (z, M) => {
|
|
14
14
|
const b = z.__vccOpts || z;
|
|
15
15
|
for (const [O, p] of M)
|
|
16
16
|
b[O] = p;
|
|
17
17
|
return b;
|
|
18
|
-
},
|
|
18
|
+
}, V0 = {
|
|
19
19
|
name: "IdmGlLayer",
|
|
20
20
|
props: {
|
|
21
21
|
map: {
|
|
@@ -184,7 +184,7 @@ const I = (z, M) => {
|
|
|
184
184
|
this.show3d = !this.show3d, this.$emit("3d", this.show3d);
|
|
185
185
|
}
|
|
186
186
|
}
|
|
187
|
-
}, Z0 = { class: "idm-gl3-layer" },
|
|
187
|
+
}, Z0 = { class: "idm-gl3-layer" }, $0 = { class: "bar-item layer-bars" }, M1 = { class: "bar-item tool-bars" }, b1 = { class: "flex-between" }, z1 = {
|
|
188
188
|
key: 0,
|
|
189
189
|
class: "iconfont active"
|
|
190
190
|
}, p1 = {
|
|
@@ -193,16 +193,16 @@ const I = (z, M) => {
|
|
|
193
193
|
}, O1 = ["onClick"], o1 = ["onClick"], c1 = {
|
|
194
194
|
key: 0,
|
|
195
195
|
class: "flex-start"
|
|
196
|
-
},
|
|
196
|
+
}, A1 = {
|
|
197
197
|
key: 1,
|
|
198
198
|
class: "flex-start"
|
|
199
|
-
},
|
|
199
|
+
}, e1 = { class: "header-box flex-between" }, t1 = { class: "weather-layers card-bg" }, a1 = { class: "layers-title flex-between" }, q1 = {
|
|
200
200
|
key: 0,
|
|
201
201
|
class: "iconfont active"
|
|
202
202
|
}, i1 = {
|
|
203
203
|
key: 1,
|
|
204
204
|
class: "iconfont"
|
|
205
|
-
}, r1 = { class: "layers-body" }, n1 = { class: "flex-start" }, d1 = ["onClick"],
|
|
205
|
+
}, r1 = { class: "layers-body" }, n1 = { class: "flex-start" }, d1 = ["onClick"], s1 = ["onClick"], W1 = {
|
|
206
206
|
key: 0,
|
|
207
207
|
class: "flex-start"
|
|
208
208
|
}, l1 = {
|
|
@@ -214,30 +214,30 @@ const I = (z, M) => {
|
|
|
214
214
|
}, L1 = {
|
|
215
215
|
key: 1,
|
|
216
216
|
class: "iconfont bookmark-icon inactive"
|
|
217
|
-
}, R1 = { class: "other-layers card-bg" }, h1 = { class: "layers-body" }, m1 = ["onClick"],
|
|
217
|
+
}, R1 = { class: "other-layers card-bg" }, h1 = { class: "layers-body" }, m1 = ["onClick"], B1 = { class: "flex-start" }, g1 = { class: "switch flex-center" }, N1 = {
|
|
218
218
|
key: 0,
|
|
219
219
|
class: "iconfont active"
|
|
220
|
-
},
|
|
220
|
+
}, y1 = {
|
|
221
221
|
key: 1,
|
|
222
222
|
class: "iconfont"
|
|
223
|
-
}, X1 = { class: "source-layers card-bg" },
|
|
224
|
-
function
|
|
225
|
-
const
|
|
226
|
-
return
|
|
223
|
+
}, X1 = { class: "source-layers card-bg" }, w1 = { class: "layers-body" };
|
|
224
|
+
function C1(z, M, b, O, p, o) {
|
|
225
|
+
const A = I("ElTooltip"), t = I("ElRadio"), q = I("ElRadioGroup"), r = I("ElScrollbar");
|
|
226
|
+
return s(), W("div", Z0, [
|
|
227
227
|
c("div", {
|
|
228
228
|
class: "menu-bar-box",
|
|
229
|
-
style:
|
|
229
|
+
style: c0({ top: b.top + 10 + "px", right: p.right + "px" })
|
|
230
230
|
}, [
|
|
231
|
-
c("div",
|
|
232
|
-
|
|
231
|
+
c("div", $0, [
|
|
232
|
+
C(A, {
|
|
233
233
|
placement: "left",
|
|
234
234
|
effect: "light",
|
|
235
235
|
content: "Menu",
|
|
236
236
|
"show-after": 1e3
|
|
237
237
|
}, {
|
|
238
|
-
default:
|
|
238
|
+
default: t0(() => [
|
|
239
239
|
c("div", {
|
|
240
|
-
class:
|
|
240
|
+
class: V(b.layerToggle ? "menu-icon active" : "menu-icon"),
|
|
241
241
|
onClick: M[0] || (M[0] = (...a) => o.handleMenuToggle && o.handleMenuToggle(...a))
|
|
242
242
|
}, M[17] || (M[17] = [
|
|
243
243
|
c("span", { class: "iconfont" }, "", -1)
|
|
@@ -249,18 +249,18 @@ function T1(z, M, b, O, p, o) {
|
|
|
249
249
|
], 4),
|
|
250
250
|
c("div", {
|
|
251
251
|
class: "menu-bar-box",
|
|
252
|
-
style:
|
|
252
|
+
style: c0({ top: b.top + 160 + "px", right: p.right + "px" })
|
|
253
253
|
}, [
|
|
254
254
|
c("div", M1, [
|
|
255
|
-
|
|
255
|
+
C(A, {
|
|
256
256
|
placement: "left",
|
|
257
257
|
effect: "light",
|
|
258
258
|
content: "Measure",
|
|
259
259
|
"show-after": 1e3
|
|
260
260
|
}, {
|
|
261
|
-
default:
|
|
261
|
+
default: t0(() => [
|
|
262
262
|
c("div", {
|
|
263
|
-
class:
|
|
263
|
+
class: V(p.showMeasure ? "menu-icon active" : "menu-icon"),
|
|
264
264
|
onClick: M[1] || (M[1] = (...a) => o.handleMeasureToggle && o.handleMeasureToggle(...a))
|
|
265
265
|
}, M[18] || (M[18] = [
|
|
266
266
|
c("span", { class: "iconfont" }, "", -1)
|
|
@@ -268,15 +268,15 @@ function T1(z, M, b, O, p, o) {
|
|
|
268
268
|
]),
|
|
269
269
|
_: 1
|
|
270
270
|
}),
|
|
271
|
-
|
|
271
|
+
C(A, {
|
|
272
272
|
placement: "left",
|
|
273
273
|
effect: "light",
|
|
274
274
|
content: "Point Meteo",
|
|
275
275
|
"show-after": 1e3
|
|
276
276
|
}, {
|
|
277
|
-
default:
|
|
277
|
+
default: t0(() => [
|
|
278
278
|
c("div", {
|
|
279
|
-
class:
|
|
279
|
+
class: V(p.showPoint ? "menu-icon active" : "menu-icon"),
|
|
280
280
|
onClick: M[2] || (M[2] = (...a) => o.handlePointToggle && o.handlePointToggle(...a))
|
|
281
281
|
}, M[19] || (M[19] = [
|
|
282
282
|
c("span", { class: "iconfont" }, "", -1)
|
|
@@ -284,15 +284,15 @@ function T1(z, M, b, O, p, o) {
|
|
|
284
284
|
]),
|
|
285
285
|
_: 1
|
|
286
286
|
}),
|
|
287
|
-
|
|
287
|
+
C(A, {
|
|
288
288
|
placement: "left",
|
|
289
289
|
effect: "light",
|
|
290
290
|
content: "Grid",
|
|
291
291
|
"show-after": 1e3
|
|
292
292
|
}, {
|
|
293
|
-
default:
|
|
293
|
+
default: t0(() => [
|
|
294
294
|
c("div", {
|
|
295
|
-
class:
|
|
295
|
+
class: V(p.showCoord ? "menu-icon active" : "menu-icon"),
|
|
296
296
|
onClick: M[3] || (M[3] = (...a) => o.handleCoordToggle && o.handleCoordToggle(...a))
|
|
297
297
|
}, M[20] || (M[20] = [
|
|
298
298
|
c("span", { class: "iconfont" }, "", -1)
|
|
@@ -300,15 +300,15 @@ function T1(z, M, b, O, p, o) {
|
|
|
300
300
|
]),
|
|
301
301
|
_: 1
|
|
302
302
|
}),
|
|
303
|
-
|
|
303
|
+
C(A, {
|
|
304
304
|
placement: "left",
|
|
305
305
|
effect: "light",
|
|
306
306
|
content: "3D",
|
|
307
307
|
"show-after": 1e3
|
|
308
308
|
}, {
|
|
309
|
-
default:
|
|
309
|
+
default: t0(() => [
|
|
310
310
|
c("div", {
|
|
311
|
-
class:
|
|
311
|
+
class: V(p.show3d ? "menu-icon active" : "menu-icon"),
|
|
312
312
|
onClick: M[4] || (M[4] = (...a) => o.handle3DToggle && o.handle3DToggle(...a))
|
|
313
313
|
}, M[21] || (M[21] = [
|
|
314
314
|
c("span", { class: "iconfont" }, "", -1)
|
|
@@ -318,10 +318,10 @@ function T1(z, M, b, O, p, o) {
|
|
|
318
318
|
})
|
|
319
319
|
])
|
|
320
320
|
], 4),
|
|
321
|
-
o.hasCollectedLayers ? (
|
|
321
|
+
o.hasCollectedLayers ? (s(), W("div", {
|
|
322
322
|
key: 0,
|
|
323
323
|
class: "active-layers",
|
|
324
|
-
style:
|
|
324
|
+
style: c0({ right: p.right + "px", bottom: "100px" })
|
|
325
325
|
}, [
|
|
326
326
|
c("div", b1, [
|
|
327
327
|
M[22] || (M[22] = c("div", { style: { margin: "2px 5px" } }, "My Favorites", -1)),
|
|
@@ -330,12 +330,12 @@ function T1(z, M, b, O, p, o) {
|
|
|
330
330
|
style: { "font-size": "28px", "margin-right": "0" },
|
|
331
331
|
onClick: M[5] || (M[5] = (...a) => o.toggleAutoActive && o.toggleAutoActive(...a))
|
|
332
332
|
}, [
|
|
333
|
-
p.autoActive ? (
|
|
333
|
+
p.autoActive ? (s(), W("i", z1, "")) : (s(), W("i", p1, ""))
|
|
334
334
|
])
|
|
335
335
|
]),
|
|
336
|
-
(
|
|
336
|
+
(s(!0), W(F, null, K(p.layers.weather.filter((a) => a.collected), (a) => (s(), W("div", {
|
|
337
337
|
key: a.key,
|
|
338
|
-
class:
|
|
338
|
+
class: V(o.computeLayerClass(a, p.activeWeatherLayers))
|
|
339
339
|
}, [
|
|
340
340
|
c("div", {
|
|
341
341
|
class: "checkbox",
|
|
@@ -344,45 +344,45 @@ function T1(z, M, b, O, p, o) {
|
|
|
344
344
|
c("span", {
|
|
345
345
|
class: "name",
|
|
346
346
|
onClick: (i) => o.handleWeatherLayerPick(a)
|
|
347
|
-
},
|
|
348
|
-
a.key === "wind" && p.activeWeatherLayers.some((i) => i.key === a.key) ? (
|
|
347
|
+
}, T(a.name), 9, o1),
|
|
348
|
+
a.key === "wind" && p.activeWeatherLayers.some((i) => i.key === a.key) ? (s(), W("div", c1, [
|
|
349
349
|
c("i", {
|
|
350
|
-
class:
|
|
350
|
+
class: V(["iconfont sub-layer-icon", b.showWindParticle ? "active" : ""]),
|
|
351
351
|
onClick: M[6] || (M[6] = (i) => o.handleToggleWindParticle())
|
|
352
352
|
}, "", 2),
|
|
353
353
|
c("i", {
|
|
354
|
-
class:
|
|
354
|
+
class: V(["iconfont sub-layer-icon", b.showWindFeather ? "active" : ""]),
|
|
355
355
|
onClick: M[7] || (M[7] = (i) => o.handleToggleWindFeather())
|
|
356
356
|
}, "", 2)
|
|
357
|
-
])) :
|
|
358
|
-
a.key === "current" && p.activeWeatherLayers.some((i) => i.key === a.key) ? (
|
|
357
|
+
])) : j("", !0),
|
|
358
|
+
a.key === "current" && p.activeWeatherLayers.some((i) => i.key === a.key) ? (s(), W("div", A1, [
|
|
359
359
|
c("i", {
|
|
360
|
-
class:
|
|
360
|
+
class: V(["iconfont sub-layer-icon", b.showCurrentParticle ? "active" : ""]),
|
|
361
361
|
onClick: M[8] || (M[8] = (i) => o.handleToggleCurrentParticle())
|
|
362
362
|
}, "", 2),
|
|
363
363
|
c("i", {
|
|
364
|
-
class:
|
|
364
|
+
class: V(["iconfont sub-layer-icon", b.showCurrentIsoband ? "active" : ""]),
|
|
365
365
|
onClick: M[9] || (M[9] = (i) => o.handleToggleCurrentIsoband())
|
|
366
366
|
}, "", 2)
|
|
367
|
-
])) :
|
|
367
|
+
])) : j("", !0)
|
|
368
368
|
], 2))), 128))
|
|
369
|
-
], 4)) :
|
|
369
|
+
], 4)) : j("", !0),
|
|
370
370
|
c("div", {
|
|
371
371
|
class: "available-layers flex-center",
|
|
372
|
-
style:
|
|
372
|
+
style: c0({ top: b.top + "px", right: b.layerToggle ? "0px" : "-240px" })
|
|
373
373
|
}, [
|
|
374
374
|
c("div", {
|
|
375
|
-
class:
|
|
375
|
+
class: V(["list-box", b.layerToggle ? "right-bar" : ""])
|
|
376
376
|
}, [
|
|
377
|
-
c("div",
|
|
377
|
+
c("div", e1, [
|
|
378
378
|
M[23] || (M[23] = c("div", null, "Layers", -1)),
|
|
379
379
|
c("div", {
|
|
380
380
|
class: "iconfont close-btn",
|
|
381
381
|
onClick: M[10] || (M[10] = (...a) => o.handleMenuToggle && o.handleMenuToggle(...a))
|
|
382
382
|
}, "")
|
|
383
383
|
]),
|
|
384
|
-
|
|
385
|
-
default:
|
|
384
|
+
C(r, { style: { flex: "1" } }, {
|
|
385
|
+
default: t0(() => [
|
|
386
386
|
c("div", t1, [
|
|
387
387
|
c("div", a1, [
|
|
388
388
|
M[24] || (M[24] = c("div", null, "Weather Layers", -1)),
|
|
@@ -391,16 +391,16 @@ function T1(z, M, b, O, p, o) {
|
|
|
391
391
|
style: { "margin-right": "0" },
|
|
392
392
|
onClick: M[11] || (M[11] = (...a) => o.toggleAutoActive && o.toggleAutoActive(...a))
|
|
393
393
|
}, [
|
|
394
|
-
p.autoActive ? (
|
|
394
|
+
p.autoActive ? (s(), W("i", q1, "")) : (s(), W("i", i1, ""))
|
|
395
395
|
])
|
|
396
396
|
]),
|
|
397
397
|
c("div", r1, [
|
|
398
|
-
(
|
|
398
|
+
(s(!0), W(F, null, K(p.layers.weather, (a) => (s(), W(F, {
|
|
399
399
|
key: a.key
|
|
400
400
|
}, [
|
|
401
|
-
a.hide ?
|
|
401
|
+
a.hide ? j("", !0) : (s(), W("div", {
|
|
402
402
|
key: 0,
|
|
403
|
-
class:
|
|
403
|
+
class: V(o.computeLayerClass(a, p.activeWeatherLayers))
|
|
404
404
|
}, [
|
|
405
405
|
c("div", n1, [
|
|
406
406
|
c("div", {
|
|
@@ -410,32 +410,32 @@ function T1(z, M, b, O, p, o) {
|
|
|
410
410
|
c("span", {
|
|
411
411
|
class: "name",
|
|
412
412
|
onClick: (i) => o.handleWeatherLayerPick(a)
|
|
413
|
-
},
|
|
414
|
-
a.key === "wind" && p.activeWeatherLayers.some((i) => i.key === a.key) ? (
|
|
413
|
+
}, T(a.name), 9, s1),
|
|
414
|
+
a.key === "wind" && p.activeWeatherLayers.some((i) => i.key === a.key) ? (s(), W("div", W1, [
|
|
415
415
|
c("i", {
|
|
416
|
-
class:
|
|
416
|
+
class: V(["iconfont sub-layer-icon", b.showWindParticle ? "active" : ""]),
|
|
417
417
|
onClick: M[12] || (M[12] = (i) => o.handleToggleWindParticle())
|
|
418
418
|
}, "", 2),
|
|
419
419
|
c("i", {
|
|
420
|
-
class:
|
|
420
|
+
class: V(["iconfont sub-layer-icon", b.showWindFeather ? "active" : ""]),
|
|
421
421
|
onClick: M[13] || (M[13] = (i) => o.handleToggleWindFeather())
|
|
422
422
|
}, "", 2)
|
|
423
|
-
])) :
|
|
424
|
-
a.key === "current" && p.activeWeatherLayers.some((i) => i.key === a.key) ? (
|
|
423
|
+
])) : j("", !0),
|
|
424
|
+
a.key === "current" && p.activeWeatherLayers.some((i) => i.key === a.key) ? (s(), W("div", l1, [
|
|
425
425
|
c("i", {
|
|
426
|
-
class:
|
|
426
|
+
class: V(["iconfont sub-layer-icon", b.showCurrentParticle ? "active" : ""]),
|
|
427
427
|
onClick: M[14] || (M[14] = (i) => o.handleToggleCurrentParticle())
|
|
428
428
|
}, "", 2),
|
|
429
429
|
c("i", {
|
|
430
|
-
class:
|
|
430
|
+
class: V(["iconfont sub-layer-icon", b.showCurrentIsoband ? "active" : ""]),
|
|
431
431
|
onClick: M[15] || (M[15] = (i) => o.handleToggleCurrentIsoband())
|
|
432
432
|
}, "", 2)
|
|
433
|
-
])) :
|
|
433
|
+
])) : j("", !0)
|
|
434
434
|
]),
|
|
435
435
|
c("div", {
|
|
436
436
|
onClick: (i) => o.handleWeatherLayerCollect(a)
|
|
437
437
|
}, [
|
|
438
|
-
a.collected ? (
|
|
438
|
+
a.collected ? (s(), W("i", u1, "")) : (s(), W("i", L1, ""))
|
|
439
439
|
], 8, f1)
|
|
440
440
|
], 2))
|
|
441
441
|
], 64))), 128)),
|
|
@@ -451,18 +451,18 @@ function T1(z, M, b, O, p, o) {
|
|
|
451
451
|
c("div", R1, [
|
|
452
452
|
M[26] || (M[26] = c("div", { class: "layers-title" }, "Other Layers", -1)),
|
|
453
453
|
c("div", h1, [
|
|
454
|
-
(
|
|
454
|
+
(s(!0), W(F, null, K(p.layers.other, (a) => {
|
|
455
455
|
var i;
|
|
456
|
-
return
|
|
456
|
+
return s(), W("div", {
|
|
457
457
|
key: a.key,
|
|
458
|
-
class:
|
|
458
|
+
class: V(["layer flex-between", o.computeLayerClass(a, p.activeOtherLayers)]),
|
|
459
459
|
onClick: (L) => o.handleOtherLayerPick(a)
|
|
460
460
|
}, [
|
|
461
|
-
c("div",
|
|
462
|
-
c("div",
|
|
463
|
-
(i = o.computeLayerClass(a, p.activeOtherLayers)) != null && i.includes("active") ? (
|
|
461
|
+
c("div", B1, [
|
|
462
|
+
c("div", g1, [
|
|
463
|
+
(i = o.computeLayerClass(a, p.activeOtherLayers)) != null && i.includes("active") ? (s(), W("i", N1, "")) : (s(), W("i", y1, ""))
|
|
464
464
|
]),
|
|
465
|
-
c("span", null,
|
|
465
|
+
c("span", null, T(a.name), 1)
|
|
466
466
|
])
|
|
467
467
|
], 10, m1);
|
|
468
468
|
}), 128))
|
|
@@ -470,22 +470,22 @@ function T1(z, M, b, O, p, o) {
|
|
|
470
470
|
]),
|
|
471
471
|
c("div", X1, [
|
|
472
472
|
M[29] || (M[29] = c("span", { class: "layers-title" }, "Forecast Model", -1)),
|
|
473
|
-
c("div",
|
|
474
|
-
|
|
473
|
+
c("div", w1, [
|
|
474
|
+
C(q, {
|
|
475
475
|
modelValue: p.source,
|
|
476
476
|
"onUpdate:modelValue": M[16] || (M[16] = (a) => p.source = a),
|
|
477
477
|
class: "layer-radio flex-col-center-start"
|
|
478
478
|
}, {
|
|
479
|
-
default:
|
|
480
|
-
|
|
481
|
-
default:
|
|
482
|
-
|
|
479
|
+
default: t0(() => [
|
|
480
|
+
C(t, { value: "GFS" }, {
|
|
481
|
+
default: t0(() => M[27] || (M[27] = [
|
|
482
|
+
z0("GFS")
|
|
483
483
|
])),
|
|
484
484
|
_: 1
|
|
485
485
|
}),
|
|
486
|
-
|
|
487
|
-
default:
|
|
488
|
-
|
|
486
|
+
C(t, { value: "CMEMS" }, {
|
|
487
|
+
default: t0(() => M[28] || (M[28] = [
|
|
488
|
+
z0("CMEMS")
|
|
489
489
|
])),
|
|
490
490
|
_: 1
|
|
491
491
|
})
|
|
@@ -501,8 +501,8 @@ function T1(z, M, b, O, p, o) {
|
|
|
501
501
|
], 4)
|
|
502
502
|
]);
|
|
503
503
|
}
|
|
504
|
-
const
|
|
505
|
-
const
|
|
504
|
+
const v1 = /* @__PURE__ */ Q(V0, [["render", C1]]);
|
|
505
|
+
const T1 = {
|
|
506
506
|
name: "IdmWindBarb",
|
|
507
507
|
props: {
|
|
508
508
|
map: {
|
|
@@ -537,7 +537,7 @@ const C1 = {
|
|
|
537
537
|
return {
|
|
538
538
|
source: "wind-barb-source",
|
|
539
539
|
barbs: [0, 2, 5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 65, 70, 75, 80, 85, 90, 95, 100, 105],
|
|
540
|
-
empty:
|
|
540
|
+
empty: v.featureCollection([]),
|
|
541
541
|
right: 10,
|
|
542
542
|
bottom: 125,
|
|
543
543
|
windBarbLoaded: !1
|
|
@@ -585,9 +585,9 @@ const C1 = {
|
|
|
585
585
|
}, 500);
|
|
586
586
|
else if (this.wind) {
|
|
587
587
|
const p = (/* @__PURE__ */ new Date()).valueOf();
|
|
588
|
-
let o = 0,
|
|
588
|
+
let o = 0, A = 0, t = this.empty;
|
|
589
589
|
if ((z = this.wind) != null && z.active && (t = (M = this.wind) == null ? void 0 : M.data), (b = this.map) != null && b.getSource(this.source))
|
|
590
|
-
(O = this.map) == null || O.getSource(this.source).setData(t),
|
|
590
|
+
(O = this.map) == null || O.getSource(this.source).setData(t), A = (/* @__PURE__ */ new Date()).valueOf() - (p + o), console.log("[wind] update elapsed: ", A, ", total: ", o += A);
|
|
591
591
|
else {
|
|
592
592
|
this.map.addSource(this.source, { type: "geojson", data: t });
|
|
593
593
|
for (let q = 0; q < (this.barbs ?? []).length - 1; q++) {
|
|
@@ -628,7 +628,7 @@ const C1 = {
|
|
|
628
628
|
this.beforeLayer
|
|
629
629
|
);
|
|
630
630
|
}
|
|
631
|
-
this.windBarbLoaded = !0,
|
|
631
|
+
this.windBarbLoaded = !0, A = (/* @__PURE__ */ new Date()).valueOf() - (p + o), console.log("[wind] add elapsed: ", A, ", total: ", o += A);
|
|
632
632
|
}
|
|
633
633
|
}
|
|
634
634
|
},
|
|
@@ -649,24 +649,24 @@ const C1 = {
|
|
|
649
649
|
this.map.getSource(this.source) && this.map.removeSource(this.source), this.windBarbLoaded = !1;
|
|
650
650
|
}
|
|
651
651
|
}
|
|
652
|
-
},
|
|
652
|
+
}, E1 = { key: 0 };
|
|
653
653
|
function x1(z, M, b, O, p, o) {
|
|
654
|
-
var
|
|
655
|
-
return (
|
|
654
|
+
var A;
|
|
655
|
+
return (A = b.wind) != null && A.active ? (s(), W("div", E1)) : j("", !0);
|
|
656
656
|
}
|
|
657
|
-
const
|
|
658
|
-
class
|
|
657
|
+
const I1 = /* @__PURE__ */ Q(T1, [["render", x1]]);
|
|
658
|
+
class D0 {
|
|
659
659
|
constructor(M) {
|
|
660
|
-
|
|
661
|
-
|
|
662
|
-
|
|
663
|
-
|
|
664
|
-
|
|
665
|
-
|
|
666
|
-
|
|
667
|
-
|
|
668
|
-
|
|
669
|
-
this.map = M, this.mercator = new
|
|
660
|
+
Y(this, "map");
|
|
661
|
+
Y(this, "mercator");
|
|
662
|
+
Y(this, "rampColorLayer");
|
|
663
|
+
Y(this, "rampColorSource");
|
|
664
|
+
Y(this, "particleLayer");
|
|
665
|
+
Y(this, "particleSource");
|
|
666
|
+
Y(this, "rampColorCanvas");
|
|
667
|
+
Y(this, "particleCanvas");
|
|
668
|
+
Y(this, "ratio");
|
|
669
|
+
this.map = M, this.mercator = new Y0(), this.rampColorLayer = "ramp-color-layer", this.rampColorSource = "ramp-color-source", this.particleLayer = "particle-layer", this.particleSource = "particle-source", this.rampColorCanvas = document.createElement("canvas"), this.particleCanvas = document.createElement("canvas"), this.ratio = window.devicePixelRatio;
|
|
670
670
|
}
|
|
671
671
|
/**
|
|
672
672
|
* 转换为[-180, 180]的经度,且包含转换次数
|
|
@@ -700,7 +700,7 @@ class E0 {
|
|
|
700
700
|
* @param [lb.x, lb.y, rt.x, rt.y]
|
|
701
701
|
*/
|
|
702
702
|
getBoundPixel() {
|
|
703
|
-
const M = this.map.getBounds(), b = this.map.getZoom() + 1, O = [M._ne.lng, M._ne.lat], p = [M._sw.lng, M._sw.lat], [o,
|
|
703
|
+
const M = this.map.getBounds(), b = this.map.getZoom() + 1, O = [M._ne.lng, M._ne.lat], p = [M._sw.lng, M._sw.lat], [o, A] = this.convertNLng(O[0]), [t, q] = this.convertNLng(p[0]), [r, a] = this.mercator.px([o, O[1]], b), [i, L] = this.mercator.px([t, p[1]], b), n = Math.round(this.mercator.size * Math.pow(2, b) * (A + q));
|
|
704
704
|
return [i, L, r + n, a];
|
|
705
705
|
}
|
|
706
706
|
/**
|
|
@@ -716,9 +716,9 @@ class E0 {
|
|
|
716
716
|
* @param zoom
|
|
717
717
|
*/
|
|
718
718
|
getWorldCopy(M, b) {
|
|
719
|
-
const O = 2 ** b, [p, o,
|
|
719
|
+
const O = 2 ** b, [p, o, A, t] = M.map((a) => ~~(a / (O * 256))), q = [];
|
|
720
720
|
for (let a = t; a <= o; a++)
|
|
721
|
-
for (let i = p; i <=
|
|
721
|
+
for (let i = p; i <= A; i++)
|
|
722
722
|
q.push([i, a]);
|
|
723
723
|
return q.map((a) => {
|
|
724
724
|
const i = 2 ** b * 256;
|
|
@@ -738,7 +738,7 @@ class E0 {
|
|
|
738
738
|
b !== O && this.map.setLayoutProperty(this.particleLayer, "visibility", O);
|
|
739
739
|
}
|
|
740
740
|
}
|
|
741
|
-
class
|
|
741
|
+
class C0 {
|
|
742
742
|
/**
|
|
743
743
|
* 创建着色器
|
|
744
744
|
* @see https://webglfundamentals.org/webgl/lessons/zh_cn/webgl-shaders-and-glsl.html
|
|
@@ -763,9 +763,9 @@ class T0 {
|
|
|
763
763
|
* @param width??
|
|
764
764
|
* @param height??
|
|
765
765
|
*/
|
|
766
|
-
createTexture(M, b, O, p, o,
|
|
766
|
+
createTexture(M, b, O, p, o, A, t) {
|
|
767
767
|
const q = M.createTexture();
|
|
768
|
-
return M.bindTexture(M.TEXTURE_2D, q), M.texParameteri(M.TEXTURE_2D, M.TEXTURE_MIN_FILTER, b), M.texParameteri(M.TEXTURE_2D, M.TEXTURE_MAG_FILTER, O), M.texParameteri(M.TEXTURE_2D, M.TEXTURE_WRAP_S, p), M.texParameteri(M.TEXTURE_2D, M.TEXTURE_WRAP_T, p), o instanceof Uint8Array ? M.texImage2D(M.TEXTURE_2D, 0, M.RGBA,
|
|
768
|
+
return M.bindTexture(M.TEXTURE_2D, q), M.texParameteri(M.TEXTURE_2D, M.TEXTURE_MIN_FILTER, b), M.texParameteri(M.TEXTURE_2D, M.TEXTURE_MAG_FILTER, O), M.texParameteri(M.TEXTURE_2D, M.TEXTURE_WRAP_S, p), M.texParameteri(M.TEXTURE_2D, M.TEXTURE_WRAP_T, p), o instanceof Uint8Array ? M.texImage2D(M.TEXTURE_2D, 0, M.RGBA, A, t, 0, M.RGBA, M.UNSIGNED_BYTE, o) : M.texImage2D(M.TEXTURE_2D, 0, M.RGBA, M.RGBA, M.UNSIGNED_BYTE, o), M.bindTexture(M.TEXTURE_2D, null), q;
|
|
769
769
|
}
|
|
770
770
|
/**
|
|
771
771
|
* 创建数据资源
|
|
@@ -788,8 +788,8 @@ class T0 {
|
|
|
788
788
|
* @param fragmentSchema
|
|
789
789
|
*/
|
|
790
790
|
createProgram(M, b, O) {
|
|
791
|
-
const p = M.createProgram(), o = this.createShader(M, M.VERTEX_SHADER, b),
|
|
792
|
-
if (p && o &&
|
|
791
|
+
const p = M.createProgram(), o = this.createShader(M, M.VERTEX_SHADER, b), A = this.createShader(M, M.FRAGMENT_SHADER, O);
|
|
792
|
+
if (p && o && A && (M.attachShader(p, o), M.attachShader(p, A), M.linkProgram(p), !M.getProgramParameter(p, M.LINK_STATUS)))
|
|
793
793
|
throw new Error(M.getProgramInfoLog(p) || "error happened while creating ramp color program");
|
|
794
794
|
return p;
|
|
795
795
|
}
|
|
@@ -802,8 +802,8 @@ class T0 {
|
|
|
802
802
|
createProgramWrapper(M, b, O) {
|
|
803
803
|
const p = this.createProgram(M, b, O);
|
|
804
804
|
if (p) {
|
|
805
|
-
const o = { program: p },
|
|
806
|
-
for (let q = 0; q <
|
|
805
|
+
const o = { program: p }, A = M.getProgramParameter(p, M.ACTIVE_ATTRIBUTES);
|
|
806
|
+
for (let q = 0; q < A; q++) {
|
|
807
807
|
const r = M.getActiveAttrib(p, q);
|
|
808
808
|
o[r.name] = M.getAttribLocation(p, r.name);
|
|
809
809
|
}
|
|
@@ -820,21 +820,21 @@ class T0 {
|
|
|
820
820
|
* @param colors
|
|
821
821
|
*/
|
|
822
822
|
setup(M, b, O = !1, p, o) {
|
|
823
|
-
const
|
|
824
|
-
|
|
825
|
-
const t =
|
|
823
|
+
const A = document.createElement("canvas");
|
|
824
|
+
A.width = 256, A.height = 1;
|
|
825
|
+
const t = A.getContext("2d");
|
|
826
826
|
if (t && M) {
|
|
827
827
|
const q = t == null ? void 0 : t.createLinearGradient(0, 0, 256, 0);
|
|
828
828
|
return b.forEach(([r, a]) => {
|
|
829
829
|
q.addColorStop(r, a);
|
|
830
830
|
}), t.fillStyle = q, t.fillRect(0, 0, 256, 1), {
|
|
831
|
-
canvas:
|
|
831
|
+
canvas: A,
|
|
832
832
|
texture: this.createTexture(
|
|
833
833
|
M,
|
|
834
834
|
M.LINEAR,
|
|
835
835
|
M.LINEAR,
|
|
836
836
|
M.CLAMP_TO_EDGE,
|
|
837
|
-
O ? new Uint8Array(t.getImageData(0, 0, 256, 1).data) :
|
|
837
|
+
O ? new Uint8Array(t.getImageData(0, 0, 256, 1).data) : A,
|
|
838
838
|
p,
|
|
839
839
|
o
|
|
840
840
|
)
|
|
@@ -845,17 +845,17 @@ class T0 {
|
|
|
845
845
|
const O = Math.ceil(Math.sqrt(b)), p = O * O, o = new Uint8Array(p * 4);
|
|
846
846
|
for (let a = 0; a < o.length; a++)
|
|
847
847
|
o[a] = Math.floor(Math.random() * 256);
|
|
848
|
-
const
|
|
848
|
+
const A = this.createTexture(M, M.NEAREST, M.NEAREST, M.CLAMP_TO_EDGE, o, O, O), t = this.createTexture(M, M.NEAREST, M.NEAREST, M.CLAMP_TO_EDGE, o, O, O), q = new Float32Array(p);
|
|
849
849
|
for (let a = 0; a < p; a++)
|
|
850
850
|
q[a] = a;
|
|
851
851
|
const r = this.createDataBuffer(M, "array", q);
|
|
852
|
-
return { resolution: O, total: p, texture0:
|
|
852
|
+
return { resolution: O, total: p, texture0: A, texture1: t, indexBuffer: r };
|
|
853
853
|
}
|
|
854
854
|
bind(M, b, O) {
|
|
855
855
|
const p = this.createProgram(M, b, O);
|
|
856
856
|
if (p) {
|
|
857
|
-
const o = this.createDataBuffer(M, "array", void 0),
|
|
858
|
-
M.enableVertexAttribArray(
|
|
857
|
+
const o = this.createDataBuffer(M, "array", void 0), A = M.getAttribLocation(p, "a_position");
|
|
858
|
+
M.enableVertexAttribArray(A), M.vertexAttribPointer(A, 2, M.FLOAT, !1, 0, 0);
|
|
859
859
|
const t = new Float32Array([0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1]);
|
|
860
860
|
this.createDataBuffer(M, "array", t);
|
|
861
861
|
const q = M.getAttribLocation(p, "a_texCoord");
|
|
@@ -863,11 +863,11 @@ class T0 {
|
|
|
863
863
|
}
|
|
864
864
|
return {};
|
|
865
865
|
}
|
|
866
|
-
bindParticle(M, b, O, p, o,
|
|
867
|
-
const t = this.createProgramWrapper(M, b, O), q = this.createProgramWrapper(M, p, o), r = this.createProgramWrapper(M, p,
|
|
866
|
+
bindParticle(M, b, O, p, o, A) {
|
|
867
|
+
const t = this.createProgramWrapper(M, b, O), q = this.createProgramWrapper(M, p, o), r = this.createProgramWrapper(M, p, A), a = this.createDataBuffer(M, "array", new Float32Array([0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1])), i = M.createFramebuffer();
|
|
868
868
|
return { particle: t, screen: q, update: r, quadBuffer: a, frameBuffer: i };
|
|
869
869
|
}
|
|
870
|
-
draw(M, b, O, p, o,
|
|
870
|
+
draw(M, b, O, p, o, A, t) {
|
|
871
871
|
var q, r;
|
|
872
872
|
if (b && O) {
|
|
873
873
|
M.resize(), b == null || b.viewport(0, 0, (q = b == null ? void 0 : b.canvas) == null ? void 0 : q.width, (r = b == null ? void 0 : b.canvas) == null ? void 0 : r.height), b.clearColor(0, 0, 0, 0), b.clear(b.COLOR_BUFFER_BIT | b.DEPTH_BUFFER_BIT);
|
|
@@ -879,8 +879,8 @@ class T0 {
|
|
|
879
879
|
}
|
|
880
880
|
const n = M.getBoundPixel(), h = M.map.getZoom() + 1, u = M.getWorldCopy(n, h);
|
|
881
881
|
for (const d of u) {
|
|
882
|
-
const m = (d[0] - n[0]) * M.ratio, R = (d[1] - n[3]) * M.ratio, X = d[2] * M.ratio, [
|
|
883
|
-
b.bindBuffer(b.ARRAY_BUFFER,
|
|
882
|
+
const m = (d[0] - n[0]) * M.ratio, R = (d[1] - n[3]) * M.ratio, X = d[2] * M.ratio, [E, y, _, J] = [m, X + m, R, X + R], Z = new Float32Array([E, _, y, _, E, J, E, J, y, _, y, J]);
|
|
883
|
+
b.bindBuffer(b.ARRAY_BUFFER, A), b.bufferData(b.ARRAY_BUFFER, Z, b.STATIC_DRAW), b.drawArrays(b.TRIANGLES, 0, 6);
|
|
884
884
|
}
|
|
885
885
|
} catch (a) {
|
|
886
886
|
console.log(`render failed...${a}`);
|
|
@@ -888,8 +888,8 @@ class T0 {
|
|
|
888
888
|
}
|
|
889
889
|
}
|
|
890
890
|
drawParticle(M, b, O, p, o) {
|
|
891
|
-
var
|
|
892
|
-
b && (b == null || b.viewport(0, 0, (
|
|
891
|
+
var A, t;
|
|
892
|
+
b && (b == null || b.viewport(0, 0, (A = b == null ? void 0 : b.canvas) == null ? void 0 : A.width, (t = b == null ? void 0 : b.canvas) == null ? void 0 : t.height), b.disable(b.DEPTH_TEST), b.disable(b.STENCIL_TEST), b.activeTexture(b.TEXTURE0), b.bindTexture(b.TEXTURE_2D, O), b.activeTexture(b.TEXTURE1), b.bindTexture(b.TEXTURE_2D, p.texture0), this.renderScreen(M, b, p, o), this.updateParticles(M, b, p, o));
|
|
893
893
|
}
|
|
894
894
|
renderScreen(M, b, O, p) {
|
|
895
895
|
b.bindFramebuffer(b.FRAMEBUFFER, O.frameBuffer), b.framebufferTexture2D(b.FRAMEBUFFER, b.COLOR_ATTACHMENT0, b.TEXTURE_2D, O.screenTexture, 0), b.viewport(0, 0, b.canvas.width, b.canvas.height), this.renderScreenTexture(b, O.backgroundTexture, O.screen, O.quadBuffer, 0.95), this.renderParticles(M, b, O, p), b.bindFramebuffer(b.FRAMEBUFFER, null), this.renderScreenTexture(b, O.screenTexture, O.screen, O.quadBuffer, 1);
|
|
@@ -907,11 +907,11 @@ class T0 {
|
|
|
907
907
|
}
|
|
908
908
|
}
|
|
909
909
|
updateParticles(M, b, O, p) {
|
|
910
|
-
var
|
|
910
|
+
var A, t;
|
|
911
911
|
if (b) {
|
|
912
912
|
b.bindFramebuffer(b.FRAMEBUFFER, O.frameBuffer), b.framebufferTexture2D(b.FRAMEBUFFER, b.COLOR_ATTACHMENT0, b.TEXTURE_2D, O.texture1, 0), b.viewport(0, 0, O.resolution, O.resolution), b.useProgram(O.update.program), b.bindBuffer(b.ARRAY_BUFFER, O.quadBuffer), b.enableVertexAttribArray(O.update.a_pos), b.vertexAttribPointer(O.update.a_pos, 2, b.FLOAT, !1, 0, 0), b.uniform1i(O.update.u_factor, 0), b.uniform1i(O.update.u_particles, 1);
|
|
913
913
|
const q = M.getBoundRange();
|
|
914
|
-
b.uniform4f(O.update.u_viewport, q[0], q[1], q[2], q[3]), b.uniform1f(O.update.u_rand_seed, Math.random()), b.uniform2f(O.update.u_factor_res, (
|
|
914
|
+
b.uniform4f(O.update.u_viewport, q[0], q[1], q[2], q[3]), b.uniform1f(O.update.u_rand_seed, Math.random()), b.uniform2f(O.update.u_factor_res, (A = O == null ? void 0 : O.image) == null ? void 0 : A.width, (t = O == null ? void 0 : O.image) == null ? void 0 : t.height), b.uniform2f(O.update.u_factor_min, p.uvRange[0], p.uvRange[0]), b.uniform2f(O.update.u_factor_max, p.uvRange[1], p.uvRange[1]), b.uniform1f(O.update.u_speed_factor, p.speedFactor * M.ratio), b.uniform1f(O.update.u_drop_rate, p.dropRate), b.uniform1f(O.update.u_drop_rate_bump, p.dropRateBump), b.drawArrays(b.TRIANGLES, 0, 6);
|
|
915
915
|
}
|
|
916
916
|
const o = O.texture0;
|
|
917
917
|
O.texture0 = O.texture1, O.texture1 = o;
|
|
@@ -931,7 +931,7 @@ class T0 {
|
|
|
931
931
|
class e0 {
|
|
932
932
|
}
|
|
933
933
|
// 顶点渲染
|
|
934
|
-
|
|
934
|
+
Y(e0, "vertexSchema", `
|
|
935
935
|
//canvas 坐标系上的坐标 (x, y)
|
|
936
936
|
attribute vec2 a_position; //像素坐标
|
|
937
937
|
attribute vec2 a_texCoord; //纹理坐标
|
|
@@ -946,7 +946,7 @@ V(e0, "vertexSchema", `
|
|
|
946
946
|
gl_Position = vec4(position * vec2(1, -1), 0.0, 1.0);
|
|
947
947
|
v_texCoord = a_texCoord;
|
|
948
948
|
}`), // 类如风、流等u v双变量片元渲染
|
|
949
|
-
|
|
949
|
+
Y(e0, "uvFragmentSchema", `
|
|
950
950
|
precision mediump float;
|
|
951
951
|
uniform sampler2D u_image;
|
|
952
952
|
uniform vec2 u_range_u_v;
|
|
@@ -965,7 +965,7 @@ V(e0, "uvFragmentSchema", `
|
|
|
965
965
|
|
|
966
966
|
gl_FragColor = color;
|
|
967
967
|
}`), // 类如浪、气压等单变量片元渲染
|
|
968
|
-
|
|
968
|
+
Y(e0, "fragmentSchema", `
|
|
969
969
|
precision mediump float;
|
|
970
970
|
uniform sampler2D u_image; // 灰度
|
|
971
971
|
uniform sampler2D u_color; // 色值映射
|
|
@@ -976,9 +976,9 @@ V(e0, "fragmentSchema", `
|
|
|
976
976
|
vec4 color = texture2D(u_color, vec2(rgba.r, 0));
|
|
977
977
|
gl_FragColor = color;
|
|
978
978
|
}`);
|
|
979
|
-
class
|
|
979
|
+
class i0 {
|
|
980
980
|
}
|
|
981
|
-
|
|
981
|
+
Y(i0, "vertexSchema", `
|
|
982
982
|
precision mediump float;
|
|
983
983
|
|
|
984
984
|
attribute float a_index; // 索引
|
|
@@ -1002,7 +1002,7 @@ V(q0, "vertexSchema", `
|
|
|
1002
1002
|
gl_PointSize = 1.0;
|
|
1003
1003
|
// gl_PointSize = u_point;
|
|
1004
1004
|
gl_Position = vec4(2.0 * v_particle_pos.x - 1.0, 1.0 - 2.0 * v_particle_pos.y, 0, 1);
|
|
1005
|
-
}`),
|
|
1005
|
+
}`), Y(i0, "fragmentSchema", `
|
|
1006
1006
|
precision mediump float;
|
|
1007
1007
|
|
|
1008
1008
|
uniform sampler2D u_factor;
|
|
@@ -1024,7 +1024,7 @@ V(q0, "vertexSchema", `
|
|
|
1024
1024
|
|
|
1025
1025
|
float f = 1.0 - uv.b;
|
|
1026
1026
|
gl_FragColor = texture2D(u_color_ramp, ramp_pos) * f;
|
|
1027
|
-
}`),
|
|
1027
|
+
}`), Y(i0, "quadVertSchema", `
|
|
1028
1028
|
precision mediump float;
|
|
1029
1029
|
|
|
1030
1030
|
attribute vec2 a_pos;
|
|
@@ -1034,7 +1034,7 @@ V(q0, "vertexSchema", `
|
|
|
1034
1034
|
void main() {
|
|
1035
1035
|
v_tex_pos = a_pos;
|
|
1036
1036
|
gl_Position = vec4(1.0 - 2.0 * a_pos, 0, 1);
|
|
1037
|
-
}`),
|
|
1037
|
+
}`), Y(i0, "screenFragmentSchema", `
|
|
1038
1038
|
precision mediump float;
|
|
1039
1039
|
|
|
1040
1040
|
uniform sampler2D u_screen;
|
|
@@ -1046,7 +1046,7 @@ V(q0, "vertexSchema", `
|
|
|
1046
1046
|
vec4 color = texture2D(u_screen, 1.0 - v_tex_pos);
|
|
1047
1047
|
// a hack to guarantee opacity fade out even with a value close to 1.0
|
|
1048
1048
|
gl_FragColor = vec4(floor(255.0 * color * u_opacity) / 255.0);
|
|
1049
|
-
}`),
|
|
1049
|
+
}`), Y(i0, "updateFragmentSchema", `
|
|
1050
1050
|
precision mediump float;
|
|
1051
1051
|
|
|
1052
1052
|
uniform sampler2D u_particles;
|
|
@@ -1125,14 +1125,14 @@ V(q0, "vertexSchema", `
|
|
|
1125
1125
|
fract(pos * 255.0),
|
|
1126
1126
|
floor(pos * 255.0) / 255.0);
|
|
1127
1127
|
}`);
|
|
1128
|
-
class
|
|
1128
|
+
class D1 {
|
|
1129
1129
|
constructor(M = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6ImNseTVudHJzYzAwNWUwbHBsZHkyaDRqczMiLCJyb2xlIjoxLCJuYW1lIjoiZmFrZUBvcm13eC5jb20iLCJwbGF0SWQiOiJnZDBtdDFkIiwiY29tcGFueSI6eyJpZCI6bnVsbCwiY2hpbGRyZW4iOltdfSwiaWF0IjoxNzIzMDI0MDI0LCJleHAiOjM5MzA1NDQwMjR9.RrKcdcMnq-FxBLJQ-i6lx2FscDE46y8EvHIemPW4HTg") {
|
|
1130
|
-
|
|
1131
|
-
|
|
1132
|
-
|
|
1133
|
-
|
|
1134
|
-
|
|
1135
|
-
|
|
1130
|
+
Y(this, "token");
|
|
1131
|
+
Y(this, "mapboxCustomer");
|
|
1132
|
+
Y(this, "i4");
|
|
1133
|
+
Y(this, "hi");
|
|
1134
|
+
Y(this, "td");
|
|
1135
|
+
Y(this, "windy");
|
|
1136
1136
|
this.token = M, this.mapboxCustomer = {
|
|
1137
1137
|
source: this.initialOnlineStyle().sources.composite,
|
|
1138
1138
|
layers: {
|
|
@@ -2736,7 +2736,7 @@ const P1 = {
|
|
|
2736
2736
|
type: Object
|
|
2737
2737
|
},
|
|
2738
2738
|
viewport: {
|
|
2739
|
-
type:
|
|
2739
|
+
type: D0
|
|
2740
2740
|
},
|
|
2741
2741
|
bottom: {
|
|
2742
2742
|
type: String,
|
|
@@ -2753,7 +2753,7 @@ const P1 = {
|
|
|
2753
2753
|
texture: void 0,
|
|
2754
2754
|
rampColor: void 0,
|
|
2755
2755
|
aPositionBuffer: void 0,
|
|
2756
|
-
webgl: new
|
|
2756
|
+
webgl: new C0(),
|
|
2757
2757
|
etime: void 0,
|
|
2758
2758
|
wrapper: void 0,
|
|
2759
2759
|
animation: void 0,
|
|
@@ -2807,8 +2807,8 @@ const P1 = {
|
|
|
2807
2807
|
}
|
|
2808
2808
|
},
|
|
2809
2809
|
handleClear() {
|
|
2810
|
-
var z, M, b, O, p, o,
|
|
2811
|
-
(z = this.viewport) == null || z.toggle(!1), (M = this.viewport) == null || M.toggleParticle(!1), this.context = void 0, this.particleContext = void 0, this.etime = void 0, this.initial = !0, (O = (b = this.viewport) == null ? void 0 : b.map) == null || O.off("resize", this.handleResize), (o = (p = this.viewport) == null ? void 0 : p.map) == null || o.off("movestart", this.handlePause), (t = (
|
|
2810
|
+
var z, M, b, O, p, o, A, t;
|
|
2811
|
+
(z = this.viewport) == null || z.toggle(!1), (M = this.viewport) == null || M.toggleParticle(!1), this.context = void 0, this.particleContext = void 0, this.etime = void 0, this.initial = !0, (O = (b = this.viewport) == null ? void 0 : b.map) == null || O.off("resize", this.handleResize), (o = (p = this.viewport) == null ? void 0 : p.map) == null || o.off("movestart", this.handlePause), (t = (A = this.viewport) == null ? void 0 : A.map) == null || t.off("moveend", this.handlePlay), this.handlePause();
|
|
2812
2812
|
},
|
|
2813
2813
|
handleSetup() {
|
|
2814
2814
|
if (!this.context) {
|
|
@@ -2857,11 +2857,11 @@ const P1 = {
|
|
|
2857
2857
|
];
|
|
2858
2858
|
this.wrapper = this.webgl.bindParticle(
|
|
2859
2859
|
this.particleContext,
|
|
2860
|
-
|
|
2861
|
-
|
|
2862
|
-
|
|
2863
|
-
|
|
2864
|
-
|
|
2860
|
+
i0.vertexSchema,
|
|
2861
|
+
i0.fragmentSchema,
|
|
2862
|
+
i0.quadVertSchema,
|
|
2863
|
+
i0.screenFragmentSchema,
|
|
2864
|
+
i0.updateFragmentSchema
|
|
2865
2865
|
), this.wrapper.color = this.webgl.setup(this.particleContext, z, !0, 16, 16), this.wrapper = { ...this.wrapper, ...this.webgl.setupParticle(this.particleContext, 9e3), ...this.webgl.resize(this.viewport, this.particleContext) }, this.viewport.map.on("resize", this.handleResize), this.viewport.map.on("movestart", this.handlePause), this.viewport.map.on("moveend", this.handlePlay);
|
|
2866
2866
|
}
|
|
2867
2867
|
},
|
|
@@ -2891,13 +2891,13 @@ const P1 = {
|
|
|
2891
2891
|
});
|
|
2892
2892
|
}
|
|
2893
2893
|
}
|
|
2894
|
-
},
|
|
2895
|
-
function
|
|
2896
|
-
var
|
|
2897
|
-
return (
|
|
2894
|
+
}, S1 = { key: 0 };
|
|
2895
|
+
function k1(z, M, b, O, p, o) {
|
|
2896
|
+
var A;
|
|
2897
|
+
return (A = b.factor) != null && A.active ? (s(), W("div", S1, [
|
|
2898
2898
|
c("div", {
|
|
2899
2899
|
class: "legend-bars flex-center",
|
|
2900
|
-
style:
|
|
2900
|
+
style: c0([{ position: "absolute" }, { right: p.right + "px", bottom: b.bottom }])
|
|
2901
2901
|
}, M[0] || (M[0] = [
|
|
2902
2902
|
c("span", null, "kts", -1),
|
|
2903
2903
|
c("span", null, "0", -1),
|
|
@@ -2908,10 +2908,10 @@ function D1(z, M, b, O, p, o) {
|
|
|
2908
2908
|
c("span", null, "40", -1),
|
|
2909
2909
|
c("span", null, "60", -1)
|
|
2910
2910
|
]), 4)
|
|
2911
|
-
])) :
|
|
2911
|
+
])) : j("", !0);
|
|
2912
2912
|
}
|
|
2913
|
-
const
|
|
2914
|
-
const
|
|
2913
|
+
const Q1 = /* @__PURE__ */ Q(P1, [["render", k1], ["__scopeId", "data-v-14070127"]]);
|
|
2914
|
+
const H1 = {
|
|
2915
2915
|
name: "IdmCurrent",
|
|
2916
2916
|
props: {
|
|
2917
2917
|
map: {
|
|
@@ -2949,7 +2949,7 @@ const j1 = {
|
|
|
2949
2949
|
directionLayer: "current-direction-layer",
|
|
2950
2950
|
speedLayer: "current-speed-layer",
|
|
2951
2951
|
speedLabelLayer: "current-speed-label-layer",
|
|
2952
|
-
empty:
|
|
2952
|
+
empty: v.featureCollection([]),
|
|
2953
2953
|
right: 10,
|
|
2954
2954
|
bottom: 95
|
|
2955
2955
|
};
|
|
@@ -3064,12 +3064,12 @@ const j1 = {
|
|
|
3064
3064
|
this.map.getLayer(this.speedLayer) && this.map.removeLayer(this.speedLayer), this.map.getLayer(this.speedLabelLayer) && this.map.removeLayer(this.speedLabelLayer), this.map.getLayer(this.directionLayer) && this.map.removeLayer(this.directionLayer), this.map.getSource(this.source) && this.map.removeSource(this.source);
|
|
3065
3065
|
}
|
|
3066
3066
|
}
|
|
3067
|
-
},
|
|
3068
|
-
function
|
|
3069
|
-
var
|
|
3070
|
-
return (
|
|
3067
|
+
}, _1 = { key: 0 };
|
|
3068
|
+
function j1(z, M, b, O, p, o) {
|
|
3069
|
+
var A;
|
|
3070
|
+
return (A = b.current) != null && A.active ? (s(), W("div", _1)) : j("", !0);
|
|
3071
3071
|
}
|
|
3072
|
-
const
|
|
3072
|
+
const F1 = /* @__PURE__ */ Q(H1, [["render", j1]]);
|
|
3073
3073
|
const G1 = {
|
|
3074
3074
|
name: "IdmCurrentParticle",
|
|
3075
3075
|
props: {
|
|
@@ -3077,7 +3077,7 @@ const G1 = {
|
|
|
3077
3077
|
type: Object
|
|
3078
3078
|
},
|
|
3079
3079
|
viewport: {
|
|
3080
|
-
type:
|
|
3080
|
+
type: D0
|
|
3081
3081
|
},
|
|
3082
3082
|
bottom: {
|
|
3083
3083
|
type: String,
|
|
@@ -3094,7 +3094,7 @@ const G1 = {
|
|
|
3094
3094
|
texture: void 0,
|
|
3095
3095
|
rampColor: void 0,
|
|
3096
3096
|
aPositionBuffer: void 0,
|
|
3097
|
-
webgl: new
|
|
3097
|
+
webgl: new C0(),
|
|
3098
3098
|
etime: void 0,
|
|
3099
3099
|
wrapper: void 0,
|
|
3100
3100
|
animation: void 0,
|
|
@@ -3148,8 +3148,8 @@ const G1 = {
|
|
|
3148
3148
|
}
|
|
3149
3149
|
},
|
|
3150
3150
|
handleClear() {
|
|
3151
|
-
var z, M, b, O, p, o,
|
|
3152
|
-
(z = this.viewport) == null || z.toggle(!1), (M = this.viewport) == null || M.toggleParticle(!1), this.context = void 0, this.particleContext = void 0, this.etime = void 0, this.initial = !0, (O = (b = this.viewport) == null ? void 0 : b.map) == null || O.off("resize", this.handleResize), (o = (p = this.viewport) == null ? void 0 : p.map) == null || o.off("movestart", this.handlePause), (t = (
|
|
3151
|
+
var z, M, b, O, p, o, A, t;
|
|
3152
|
+
(z = this.viewport) == null || z.toggle(!1), (M = this.viewport) == null || M.toggleParticle(!1), this.context = void 0, this.particleContext = void 0, this.etime = void 0, this.initial = !0, (O = (b = this.viewport) == null ? void 0 : b.map) == null || O.off("resize", this.handleResize), (o = (p = this.viewport) == null ? void 0 : p.map) == null || o.off("movestart", this.handlePause), (t = (A = this.viewport) == null ? void 0 : A.map) == null || t.off("moveend", this.handlePlay), this.handlePause();
|
|
3153
3153
|
},
|
|
3154
3154
|
handleSetup() {
|
|
3155
3155
|
if (!this.context) {
|
|
@@ -3189,11 +3189,11 @@ const G1 = {
|
|
|
3189
3189
|
];
|
|
3190
3190
|
this.wrapper = this.webgl.bindParticle(
|
|
3191
3191
|
this.particleContext,
|
|
3192
|
-
|
|
3193
|
-
|
|
3194
|
-
|
|
3195
|
-
|
|
3196
|
-
|
|
3192
|
+
i0.vertexSchema,
|
|
3193
|
+
i0.fragmentSchema,
|
|
3194
|
+
i0.quadVertSchema,
|
|
3195
|
+
i0.screenFragmentSchema,
|
|
3196
|
+
i0.updateFragmentSchema
|
|
3197
3197
|
), this.wrapper.color = this.webgl.setup(this.particleContext, z, !0, 16, 16), this.wrapper = {
|
|
3198
3198
|
...this.wrapper,
|
|
3199
3199
|
...this.webgl.setupParticle(this.particleContext, 12e3),
|
|
@@ -3227,13 +3227,13 @@ const G1 = {
|
|
|
3227
3227
|
});
|
|
3228
3228
|
}
|
|
3229
3229
|
}
|
|
3230
|
-
},
|
|
3230
|
+
}, U1 = { key: 0 };
|
|
3231
3231
|
function K1(z, M, b, O, p, o) {
|
|
3232
|
-
var
|
|
3233
|
-
return (
|
|
3232
|
+
var A;
|
|
3233
|
+
return (A = b.factor) != null && A.active ? (s(), W("div", U1, [
|
|
3234
3234
|
c("div", {
|
|
3235
3235
|
class: "legend-bars flex-center",
|
|
3236
|
-
style:
|
|
3236
|
+
style: c0([{ position: "absolute" }, { right: p.right + "px", bottom: b.bottom }])
|
|
3237
3237
|
}, M[0] || (M[0] = [
|
|
3238
3238
|
c("span", null, "kts", -1),
|
|
3239
3239
|
c("span", null, "0", -1),
|
|
@@ -3243,9 +3243,9 @@ function K1(z, M, b, O, p, o) {
|
|
|
3243
3243
|
c("span", null, "2", -1),
|
|
3244
3244
|
c("span", null, "3.2", -1)
|
|
3245
3245
|
]), 4)
|
|
3246
|
-
])) :
|
|
3246
|
+
])) : j("", !0);
|
|
3247
3247
|
}
|
|
3248
|
-
const J1 = /* @__PURE__ */
|
|
3248
|
+
const J1 = /* @__PURE__ */ Q(G1, [["render", K1], ["__scopeId", "data-v-163d1f9a"]]), Y1 = {
|
|
3249
3249
|
name: "IdmSigWave",
|
|
3250
3250
|
props: {
|
|
3251
3251
|
map: {
|
|
@@ -3266,7 +3266,7 @@ const J1 = /* @__PURE__ */ I(G1, [["render", K1], ["__scopeId", "data-v-163d1f9a
|
|
|
3266
3266
|
source: "sig-wave-source",
|
|
3267
3267
|
heightLayer: "sig-wave-height-layer",
|
|
3268
3268
|
heightLabelLayer: "sig-wave-height-label-layer",
|
|
3269
|
-
empty:
|
|
3269
|
+
empty: v.featureCollection([])
|
|
3270
3270
|
};
|
|
3271
3271
|
},
|
|
3272
3272
|
watch: {
|
|
@@ -3364,10 +3364,10 @@ const J1 = /* @__PURE__ */ I(G1, [["render", K1], ["__scopeId", "data-v-163d1f9a
|
|
|
3364
3364
|
}
|
|
3365
3365
|
}
|
|
3366
3366
|
};
|
|
3367
|
-
function
|
|
3368
|
-
return
|
|
3367
|
+
function V1(z, M, b, O, p, o) {
|
|
3368
|
+
return s(), W("div");
|
|
3369
3369
|
}
|
|
3370
|
-
const Z1 = /* @__PURE__ */
|
|
3370
|
+
const Z1 = /* @__PURE__ */ Q(Y1, [["render", V1]]), $1 = {
|
|
3371
3371
|
name: "IdmSwell",
|
|
3372
3372
|
props: {
|
|
3373
3373
|
map: {
|
|
@@ -3389,7 +3389,7 @@ const Z1 = /* @__PURE__ */ I(Q1, [["render", $1]]), Y1 = {
|
|
|
3389
3389
|
directionLayer: "swell-direction-layer",
|
|
3390
3390
|
heightLayer: "swell-height-layer",
|
|
3391
3391
|
heightLabelLayer: "swell-height-label-layer",
|
|
3392
|
-
empty:
|
|
3392
|
+
empty: v.featureCollection([])
|
|
3393
3393
|
};
|
|
3394
3394
|
},
|
|
3395
3395
|
watch: {
|
|
@@ -3523,9 +3523,9 @@ const Z1 = /* @__PURE__ */ I(Q1, [["render", $1]]), Y1 = {
|
|
|
3523
3523
|
}
|
|
3524
3524
|
};
|
|
3525
3525
|
function M2(z, M, b, O, p, o) {
|
|
3526
|
-
return
|
|
3526
|
+
return s(), W("div");
|
|
3527
3527
|
}
|
|
3528
|
-
const b2 = /* @__PURE__ */
|
|
3528
|
+
const b2 = /* @__PURE__ */ Q($1, [["render", M2]]), z2 = {
|
|
3529
3529
|
name: "IdmPrmsl",
|
|
3530
3530
|
props: {
|
|
3531
3531
|
map: {
|
|
@@ -3550,7 +3550,7 @@ const b2 = /* @__PURE__ */ I(Y1, [["render", M2]]), z2 = {
|
|
|
3550
3550
|
layer: "prmsl-layer",
|
|
3551
3551
|
labelLayer: "prmsl-label-layer",
|
|
3552
3552
|
pointLabelLayer: "prmsl-point-label-layer",
|
|
3553
|
-
empty:
|
|
3553
|
+
empty: v.featureCollection([])
|
|
3554
3554
|
};
|
|
3555
3555
|
},
|
|
3556
3556
|
watch: {
|
|
@@ -3580,8 +3580,8 @@ const b2 = /* @__PURE__ */ I(Y1, [["render", M2]]), z2 = {
|
|
|
3580
3580
|
}, 500);
|
|
3581
3581
|
else if (this.prmsl) {
|
|
3582
3582
|
const O = (/* @__PURE__ */ new Date()).valueOf();
|
|
3583
|
-
let p = 0, o = 0,
|
|
3584
|
-
this.prmsl.active && (
|
|
3583
|
+
let p = 0, o = 0, A = this.empty;
|
|
3584
|
+
this.prmsl.active && (A = this.prmsl.data), (z = this.map) != null && z.getSource(this.source) ? ((M = this.map) == null || M.getSource(this.source).setData(A), o = (/* @__PURE__ */ new Date()).valueOf() - (O + p), console.log("[prmsl] update elapsed: ", o, ", total: ", p += o)) : (this.map.addSource(this.source, { type: "geojson", data: A }), this.map.addLayer(
|
|
3585
3585
|
{
|
|
3586
3586
|
id: this.layer,
|
|
3587
3587
|
type: "line",
|
|
@@ -3663,9 +3663,9 @@ const b2 = /* @__PURE__ */ I(Y1, [["render", M2]]), z2 = {
|
|
|
3663
3663
|
}
|
|
3664
3664
|
};
|
|
3665
3665
|
function p2(z, M, b, O, p, o) {
|
|
3666
|
-
return
|
|
3666
|
+
return s(), W("div");
|
|
3667
3667
|
}
|
|
3668
|
-
const O2 = /* @__PURE__ */
|
|
3668
|
+
const O2 = /* @__PURE__ */ Q(z2, [["render", p2]]), o2 = {
|
|
3669
3669
|
name: "IdmIceberg",
|
|
3670
3670
|
props: {
|
|
3671
3671
|
map: {
|
|
@@ -3682,7 +3682,7 @@ const O2 = /* @__PURE__ */ I(z2, [["render", p2]]), o2 = {
|
|
|
3682
3682
|
return {
|
|
3683
3683
|
source: "iceberg-source",
|
|
3684
3684
|
layer: "iceberg-layer",
|
|
3685
|
-
empty:
|
|
3685
|
+
empty: v.featureCollection([])
|
|
3686
3686
|
};
|
|
3687
3687
|
},
|
|
3688
3688
|
watch: {
|
|
@@ -3723,10 +3723,10 @@ const O2 = /* @__PURE__ */ I(z2, [["render", p2]]), o2 = {
|
|
|
3723
3723
|
}
|
|
3724
3724
|
};
|
|
3725
3725
|
function c2(z, M, b, O, p, o) {
|
|
3726
|
-
return
|
|
3726
|
+
return s(), W("div");
|
|
3727
3727
|
}
|
|
3728
|
-
const
|
|
3729
|
-
const
|
|
3728
|
+
const A2 = /* @__PURE__ */ Q(o2, [["render", c2]]);
|
|
3729
|
+
const e2 = {
|
|
3730
3730
|
name: "IdmTropicals",
|
|
3731
3731
|
props: {
|
|
3732
3732
|
map: {
|
|
@@ -3746,7 +3746,7 @@ const A2 = {
|
|
|
3746
3746
|
emits: ["tropical", "tropicalProbability"],
|
|
3747
3747
|
data() {
|
|
3748
3748
|
return {
|
|
3749
|
-
helper:
|
|
3749
|
+
helper: I0,
|
|
3750
3750
|
source: "tropicals-source",
|
|
3751
3751
|
clusterSource: "tropicals-cluster-source",
|
|
3752
3752
|
historyLayer: "tropicals-history-layer",
|
|
@@ -3764,9 +3764,9 @@ const A2 = {
|
|
|
3764
3764
|
showTropicals: !1,
|
|
3765
3765
|
activeTropicals: void 0,
|
|
3766
3766
|
activeTropicalsMarker: void 0,
|
|
3767
|
-
empty:
|
|
3767
|
+
empty: v.featureCollection([]),
|
|
3768
3768
|
circleSource: "circle-source",
|
|
3769
|
-
circleSourceData:
|
|
3769
|
+
circleSourceData: v.featureCollection([]),
|
|
3770
3770
|
circleLayer: "tropical-circle-layer"
|
|
3771
3771
|
};
|
|
3772
3772
|
},
|
|
@@ -3774,7 +3774,7 @@ const A2 = {
|
|
|
3774
3774
|
computeTime() {
|
|
3775
3775
|
return function(z) {
|
|
3776
3776
|
if (z) {
|
|
3777
|
-
const M =
|
|
3777
|
+
const M = G(z).utc().utcOffset(this.timeZone), b = this.timeZone < 0 ? this.timeZone : "+" + this.timeZone;
|
|
3778
3778
|
return `${M.format("MMM-DD,HHmm")}[ UTC ${b} ] ( ${M == null ? void 0 : M.fromNow()} )`;
|
|
3779
3779
|
}
|
|
3780
3780
|
return "-";
|
|
@@ -3811,13 +3811,13 @@ const A2 = {
|
|
|
3811
3811
|
methods: {
|
|
3812
3812
|
handleRefresh() {
|
|
3813
3813
|
var O, p;
|
|
3814
|
-
const z = ((p = (O = this.tropicals) == null ? void 0 : O.data) == null ? void 0 : p.features) || [], M =
|
|
3814
|
+
const z = ((p = (O = this.tropicals) == null ? void 0 : O.data) == null ? void 0 : p.features) || [], M = G().utc().hour(), b = [];
|
|
3815
3815
|
z.forEach((o) => {
|
|
3816
|
-
var
|
|
3817
|
-
(
|
|
3816
|
+
var A, t, q;
|
|
3817
|
+
(A = o.properties) != null && A.name && !b.includes((t = o.properties) == null ? void 0 : t.name) && b.push((q = o.properties) == null ? void 0 : q.name);
|
|
3818
3818
|
}), b.forEach((o) => {
|
|
3819
3819
|
var r;
|
|
3820
|
-
let
|
|
3820
|
+
let A = 0, t;
|
|
3821
3821
|
const q = z.filter((a) => {
|
|
3822
3822
|
var i, L;
|
|
3823
3823
|
return ((L = (i = a.properties) == null ? void 0 : i.category) == null ? void 0 : L.split("-")[0]) === o;
|
|
@@ -3827,13 +3827,13 @@ const A2 = {
|
|
|
3827
3827
|
return ((i = a.geometry) == null ? void 0 : i.type) === "LineString" && ((L = a.properties) == null ? void 0 : L.type) === "forecast";
|
|
3828
3828
|
})[0]) == null || r.properties.model, q.forEach((a, i) => {
|
|
3829
3829
|
var L, n, h, u, d, m;
|
|
3830
|
-
((L = a.geometry) == null ? void 0 : L.type) === "Point" && ((n = a.properties) == null ? void 0 : n.type) === "history" && (
|
|
3830
|
+
((L = a.geometry) == null ? void 0 : L.type) === "Point" && ((n = a.properties) == null ? void 0 : n.type) === "history" && (A = i, t = t === void 0 ? i : t), ((h = a.geometry) == null ? void 0 : h.type) === "Point" && ((u = a.properties) == null ? void 0 : u.type) === "forecast" && t === void 0 && (t = i), ((d = a.geometry) == null ? void 0 : d.type) === "LineString" && ((m = a.properties) == null || m.type);
|
|
3831
3831
|
}), q.map((a, i) => {
|
|
3832
3832
|
var L, n, h, u, d, m, R;
|
|
3833
|
-
if (((L = a.geometry) == null ? void 0 : L.type) === "LineString" && ((n = a.properties) == null || n.type), ((h = a.geometry) == null ? void 0 : h.type) === "Point" && ((u = a.properties) == null ? void 0 : u.type) === "forecast" && (a.properties.name = o, a.properties.format =
|
|
3834
|
-
a.properties.format =
|
|
3835
|
-
const X =
|
|
3836
|
-
a.properties.showHistoryLabel = X || i ===
|
|
3833
|
+
if (((L = a.geometry) == null ? void 0 : L.type) === "LineString" && ((n = a.properties) == null || n.type), ((h = a.geometry) == null ? void 0 : h.type) === "Point" && ((u = a.properties) == null ? void 0 : u.type) === "forecast" && (a.properties.name = o, a.properties.format = G(a.properties.date).utcOffset(this.timeZone).format(`MMM-DD,HHmm [(utc ${this.computeTimezone})]`)), ((d = a.geometry) == null ? void 0 : d.type) === "Point" && ((m = a.properties) == null ? void 0 : m.type) === "history") {
|
|
3834
|
+
a.properties.format = G(a.properties.date).utcOffset(this.timeZone).format(`MMM-DD,HHmm [(utc ${this.computeTimezone})]`);
|
|
3835
|
+
const X = G((R = a.properties) == null ? void 0 : R.date).utc().format("HHmm") === G().utc().hour(Math.floor(M / 6) * 6).minute("00").format("HHmm");
|
|
3836
|
+
a.properties.showHistoryLabel = X || i === A, a.properties.showNameLabel = i === A, a.properties.name = o;
|
|
3837
3837
|
}
|
|
3838
3838
|
return a;
|
|
3839
3839
|
});
|
|
@@ -3870,7 +3870,7 @@ const A2 = {
|
|
|
3870
3870
|
));
|
|
3871
3871
|
},
|
|
3872
3872
|
handleRender() {
|
|
3873
|
-
var z, M, b, O, p, o,
|
|
3873
|
+
var z, M, b, O, p, o, A, t, q, r;
|
|
3874
3874
|
if (!this.map)
|
|
3875
3875
|
setTimeout(() => {
|
|
3876
3876
|
this.handleRender();
|
|
@@ -3976,7 +3976,7 @@ const A2 = {
|
|
|
3976
3976
|
],
|
|
3977
3977
|
"text-halo-width": 4
|
|
3978
3978
|
}
|
|
3979
|
-
}), n = (/* @__PURE__ */ new Date()).valueOf() - (i + L), console.log("[tropical] add elapsed: ", n, ", total: ", L += n)), (o = this.map) != null && o.getSource(this.clusterSource) ? ((t = this.map) == null || t.getSource(this.clusterSource).setData((
|
|
3979
|
+
}), n = (/* @__PURE__ */ new Date()).valueOf() - (i + L), console.log("[tropical] add elapsed: ", n, ", total: ", L += n)), (o = this.map) != null && o.getSource(this.clusterSource) ? ((t = this.map) == null || t.getSource(this.clusterSource).setData((A = this.tropicals) != null && A.active ? this.tropicals.data : this.empty), n = (/* @__PURE__ */ new Date()).valueOf() - (i + L), console.log("[tropical] update elapsed: ", n, ", total: ", L += n)) : (this.map.addSource(this.clusterSource, {
|
|
3980
3980
|
type: "geojson",
|
|
3981
3981
|
data: (q = this.tropicals) != null && q.active ? (r = this.tropicals) == null ? void 0 : r.data : this.empty
|
|
3982
3982
|
// cluster: true,
|
|
@@ -4096,7 +4096,7 @@ const A2 = {
|
|
|
4096
4096
|
}), n = (/* @__PURE__ */ new Date()).valueOf() - (i + L), console.log("[tropical] add elapsed: ", n, ", total: ", L += n));
|
|
4097
4097
|
}
|
|
4098
4098
|
this.handleDrawCircle();
|
|
4099
|
-
const a =
|
|
4099
|
+
const a = Q0.interpolate(this.tropicals, 1);
|
|
4100
4100
|
this.interpolateData = JSON.parse(JSON.stringify(a)), this.interpolateData.filter((i) => i.properties.name === "kristy" && i.properties.model === "ecmwf"), this.handleDateChange();
|
|
4101
4101
|
}
|
|
4102
4102
|
},
|
|
@@ -4105,14 +4105,14 @@ const A2 = {
|
|
|
4105
4105
|
this.map && (this.map.getLayer(this.historyLayer) && this.map.removeLayer(this.historyLayer), this.map.getLayer(this.forecastLayer) && this.map.removeLayer(this.forecastLayer), this.map.getLayer(this.forecastModelLayer) && this.map.removeLayer(this.forecastModelLayer), this.map.getLayer(this.forecastNameLayer) && this.map.removeLayer(this.forecastNameLayer), this.map.getLayer(this.pointCircleLayer) && this.map.removeLayer(this.pointCircleLayer), this.map.getLayer(this.pointCircleLayer + "-border") && this.map.removeLayer(this.pointCircleLayer + "-border"), this.map.getLayer(this.pointLabelLayer) && this.map.removeLayer(this.pointLabelLayer), this.map.getLayer(this.historyPointCircleLayer) && this.map.removeLayer(this.historyPointCircleLayer), this.map.getLayer(this.historyPointCircleLayer + "-border") && this.map.removeLayer(this.historyPointCircleLayer + "-border"), this.map.getLayer(this.historyPointCircleLayer + "-inner") && this.map.removeLayer(this.historyPointCircleLayer + "-inner"), this.map.getLayer(this.historyPointLabelLayer) && this.map.removeLayer(this.historyPointLabelLayer), this.map.getLayer(this.interpolateLineLayer) && this.map.removeLayer(this.interpolateLineLayer), (z = this.interpolateMarkers) == null || z.forEach((M) => M == null ? void 0 : M.remove()), this.map.getSource(this.source) && this.map.removeSource(this.source), this.map.getSource(this.clusterSource) && this.map.removeSource(this.clusterSource), this.map.getSource(this.interpolateSource) && this.map.removeSource(this.interpolateSource), this.map.getLayer(this.circleLayer) && this.map.removeLayer(this.circleLayer), this.map.getSource(this.circleSource) && this.map.removeSource(this.circleSource));
|
|
4106
4106
|
},
|
|
4107
4107
|
handleDateChange() {
|
|
4108
|
-
var z, M, b, O, p, o,
|
|
4108
|
+
var z, M, b, O, p, o, A, t, q, r, a, i, L, n, h, u, d, m, R, X, E, y, _, J, Z, M0, N, x, d0, s0, r0, L0, o0, h0, m0, W0;
|
|
4109
4109
|
if ((z = this.interpolateMarkers) == null || z.forEach((n0) => n0 == null ? void 0 : n0.remove()), this.circleSourceData.features = [], (M = this.interpolateData) != null && M.length && this.tropicals.active) {
|
|
4110
|
-
const n0 =
|
|
4111
|
-
|
|
4112
|
-
|
|
4113
|
-
}), (b = this.map) != null && b.getSource(this.interpolateSource) ? (O = this.map) == null || O.getSource(this.interpolateSource).setData(
|
|
4110
|
+
const n0 = G(this.date).utc().set({ minute: 0, second: 0, millisecond: 0 }), l0 = this.interpolateData.filter((S) => S.properties.date === n0.format() && !S.properties.disabled), B0 = this.handleComputePolygons(l0), f0 = v.featureCollection([...l0]);
|
|
4111
|
+
B0.forEach((S) => {
|
|
4112
|
+
f0.features.push(S);
|
|
4113
|
+
}), (b = this.map) != null && b.getSource(this.interpolateSource) ? (O = this.map) == null || O.getSource(this.interpolateSource).setData(f0) : ((p = this.map) == null || p.addSource(this.interpolateSource, {
|
|
4114
4114
|
type: "geojson",
|
|
4115
|
-
data:
|
|
4115
|
+
data: f0
|
|
4116
4116
|
}), (o = this.map) == null || o.addLayer({
|
|
4117
4117
|
id: this.interpolateLineLayer,
|
|
4118
4118
|
type: "line",
|
|
@@ -4124,17 +4124,17 @@ const A2 = {
|
|
|
4124
4124
|
"line-width": 1
|
|
4125
4125
|
}
|
|
4126
4126
|
})), this.interpolateMarkers = [];
|
|
4127
|
-
for (const
|
|
4128
|
-
if (!
|
|
4129
|
-
let
|
|
4130
|
-
((t = (
|
|
4131
|
-
const
|
|
4127
|
+
for (const S of l0)
|
|
4128
|
+
if (!S.properties.disabled) {
|
|
4129
|
+
let p0 = "#f44336";
|
|
4130
|
+
((t = (A = S.properties) == null ? void 0 : A.wind) == null ? void 0 : t.spd) < 17.2 || !((r = (q = S.properties) == null ? void 0 : q.wind) != null && r.spd) ? p0 = "#03f869" : ((i = (a = S.properties) == null ? void 0 : a.wind) == null ? void 0 : i.spd) >= 17.2 && ((n = (L = S.properties) == null ? void 0 : L.wind) == null ? void 0 : n.spd) < 24.5 ? p0 = "#f2f202" : ((u = (h = S.properties) == null ? void 0 : h.wind) == null ? void 0 : u.spd) >= 24.5 && ((m = (d = S.properties) == null ? void 0 : d.wind) == null ? void 0 : m.spd) < 32.7 ? p0 = "#ff9100" : ((X = (R = S.properties) == null ? void 0 : R.wind) == null ? void 0 : X.spd) >= 32.7 && ((y = (E = S.properties) == null ? void 0 : E.wind) == null ? void 0 : y.spd) < 41.5 ? p0 = "#f44336" : ((J = (_ = S.properties) == null ? void 0 : _.wind) == null ? void 0 : J.spd) >= 41.5 && ((M0 = (Z = S.properties) == null ? void 0 : Z.wind) == null ? void 0 : M0.spd) < 51 ? p0 = "#f903d0" : ((x = (N = S.properties) == null ? void 0 : N.wind) == null ? void 0 : x.spd) >= 51 ? p0 = "#8702f9" : p0 = "#f44336";
|
|
4131
|
+
const a0 = `<svg t="1719918955501"
|
|
4132
4132
|
class="icon" viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg" p-id="18382"
|
|
4133
4133
|
xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200">
|
|
4134
4134
|
<path
|
|
4135
4135
|
d="M515.17000001 169.34666667c41-77.73 95.33-96 95.33-96-240 0-434.5 194.53-434.5 434.5 0 186.47 150.78 337.7 337.06 338.48C472.11000001 923.66666667 418.00000001 941.83666667 418.00000001 941.83666667c240 0 434.5-194.54 434.5-434.5l0.5 0.5C853.00000001 321.10666667 701.81000001 169.66666667 515.17000001 169.34666667z m-0.67 468A129.5 129.5 0 1 1 644.00000001 507.83666667a129.5 129.5 0 0 1-129.5 129.5z"
|
|
4136
|
-
fill="${
|
|
4137
|
-
<path d="M514.50000001 507.83666667m-129.5 0a129.5 129.5 0 1 0 259 0 129.5 129.5 0 1 0-259 0Z" fill="${
|
|
4136
|
+
fill="${p0}" p-id="18383"></path>
|
|
4137
|
+
<path d="M514.50000001 507.83666667m-129.5 0a129.5 129.5 0 1 0 259 0 129.5 129.5 0 1 0-259 0Z" fill="${p0}"
|
|
4138
4138
|
p-id="18384"></path>
|
|
4139
4139
|
<path
|
|
4140
4140
|
d="M517.16666667 654.67c-80.23 0-145.5-65.27-145.5-145.5s65.27-145.5 145.5-145.5S662.66666667 428.94 662.66666667 509.17s-65.27 145.5-145.5 145.5z m0-259A113.5 113.5 0 1 0 630.66666667 509.17a113.63 113.63 0 0 0-113.5-113.5z"
|
|
@@ -4142,27 +4142,27 @@ const A2 = {
|
|
|
4142
4142
|
<path
|
|
4143
4143
|
d="M420.66666667 959.17a16.08 16.08 0 0 1-15.91-13.49A15.89 15.89 0 0 1 415.50666667 928c1.49-0.55 38.88-14.76 72.79-65.52A354.55 354.55 0 0 1 162.66666667 509.17a450.14 450.14 0 0 1 450.5-450.5 16.07 16.07 0 0 1 15.91 13.48 15.88 15.88 0 0 1-10.75 17.66c-1.58 0.58-39.13 14.9-73.07 65.95A354.22 354.22 0 0 1 871.66666667 509.17a16 16 0 0 1-0.52 4.05A450.14 450.14 0 0 1 420.66666667 959.17zM554.80666667 94.72C351.57666667 123.2 194.66666667 298.21 194.66666667 509.17c0 177.08 144.06 321.74 321.13 322.48a16 16 0 0 1 14.07 23.49c-16.11 30.42-34.27 52.37-50.85 68C682.25666667 894.63 839.16666667 719.63 839.16666667 508.67a15.94 15.94 0 0 1 0.47-3.86C837.30666667 329.33 693.82666667 187 517.80666667 186.67A16 16 0 0 1 503.66666667 163.21c16.21-30.69 34.47-52.79 51.14-68.49z"
|
|
4144
4144
|
fill="#ffffff" p-id="18386"></path>
|
|
4145
|
-
</svg>`,
|
|
4146
|
-
|
|
4147
|
-
const
|
|
4148
|
-
if (this.interpolateMarkers.push(
|
|
4149
|
-
const
|
|
4150
|
-
(
|
|
4151
|
-
|
|
4145
|
+
</svg>`, D = document.createElement("div");
|
|
4146
|
+
D.className = "hurricane-hourly-marker", D.innerHTML = `<div class="${S.geometry.coordinates[1] >= 0 ? "center north" : "center south"}">${a0}</div>`;
|
|
4147
|
+
const O0 = new w0.Marker(D).setLngLat(S.geometry.coordinates).addTo(this.map);
|
|
4148
|
+
if (this.interpolateMarkers.push(O0), (d0 = S.properties) != null && d0.showCircle) {
|
|
4149
|
+
const u0 = { radius: 100, coordinates: S.geometry.coordinates }, A0 = { radius: 200, coordinates: S.geometry.coordinates }, R0 = { radius: 500, coordinates: S.geometry.coordinates };
|
|
4150
|
+
(s0 = this.circleSourceData) == null || s0.features.push(
|
|
4151
|
+
v.circle(u0.coordinates, u0.radius, { steps: 100, units: "kilometers", properties: { type: "tropicalCircle" } })
|
|
4152
4152
|
), (r0 = this.circleSourceData) == null || r0.features.push(
|
|
4153
|
-
|
|
4154
|
-
), (
|
|
4155
|
-
|
|
4153
|
+
v.circle(A0.coordinates, A0.radius, { steps: 100, units: "kilometers", properties: { type: "tropicalCircle" } })
|
|
4154
|
+
), (L0 = this.circleSourceData) == null || L0.features.push(
|
|
4155
|
+
v.circle(R0.coordinates, R0.radius, { steps: 100, units: "kilometers", properties: { type: "tropicalCircle" } })
|
|
4156
4156
|
);
|
|
4157
4157
|
}
|
|
4158
|
-
(h0 = (
|
|
4158
|
+
(h0 = (o0 = this.map) == null ? void 0 : o0.getSource(this.circleSource)) == null || h0.setData(this.circleSourceData);
|
|
4159
4159
|
}
|
|
4160
4160
|
} else
|
|
4161
|
-
(m0 = this.map) != null && m0.getSource(this.interpolateSource) && ((
|
|
4161
|
+
(m0 = this.map) != null && m0.getSource(this.interpolateSource) && ((W0 = this.map) == null || W0.getSource(this.interpolateSource).setData(this.empty));
|
|
4162
4162
|
},
|
|
4163
4163
|
handleClick(z) {
|
|
4164
|
-
var o,
|
|
4165
|
-
const M = z.features[0], b = (
|
|
4164
|
+
var o, A, t, q, r, a, i, L;
|
|
4165
|
+
const M = z.features[0], b = (A = (o = this.tropicals) == null ? void 0 : o.data) == null ? void 0 : A.features.filter(
|
|
4166
4166
|
(n) => {
|
|
4167
4167
|
var h;
|
|
4168
4168
|
return n.geometry.type === "LineString" && n.properties.type === "forecast" && n.properties.name === ((h = M == null ? void 0 : M.properties) == null ? void 0 : h.name);
|
|
@@ -4185,17 +4185,17 @@ const A2 = {
|
|
|
4185
4185
|
showCircle: (L = (i = b[0]) == null ? void 0 : i.properties) == null ? void 0 : L.showCircle
|
|
4186
4186
|
}, this.showTropicals = !0;
|
|
4187
4187
|
const p = document.getElementById("active-tropical");
|
|
4188
|
-
this.activeTropicalsMarker ? this.activeTropicalsMarker.setLngLat([z.lngLat.lng, z.lngLat.lat]) : this.activeTropicalsMarker = new
|
|
4188
|
+
this.activeTropicalsMarker ? this.activeTropicalsMarker.setLngLat([z.lngLat.lng, z.lngLat.lat]) : this.activeTropicalsMarker = new w0.Marker(p).setLngLat([z.lngLat.lng, z.lngLat.lat]).setOffset([220, 0]).addTo(this.map);
|
|
4189
4189
|
},
|
|
4190
4190
|
handleForecastToggle(z) {
|
|
4191
|
-
var O, p, o,
|
|
4191
|
+
var O, p, o, A, t, q;
|
|
4192
4192
|
z.disabled = !z.disabled;
|
|
4193
4193
|
const M = `${z.name}-${z.model}`, b = (p = (O = this.map) == null ? void 0 : O.getSource(this.source)._data) == null ? void 0 : p.features;
|
|
4194
4194
|
b.forEach((r) => {
|
|
4195
4195
|
r.properties.category === M && (r.properties.disabled = z.disabled);
|
|
4196
4196
|
}), this.interpolateData.forEach((r) => {
|
|
4197
4197
|
r.properties.category === M && (r.properties.disabled = z.disabled);
|
|
4198
|
-
}), (
|
|
4198
|
+
}), (A = (o = this.map) == null ? void 0 : o.getSource(this.source)) == null || A.setData(v.featureCollection(b)), (q = (t = this.map) == null ? void 0 : t.getSource(this.clusterSource)) == null || q.setData(v.featureCollection(b)), this.handleDateChange();
|
|
4199
4199
|
},
|
|
4200
4200
|
handleStrikeProbability(z) {
|
|
4201
4201
|
this.$emit("tropicalProbability", z);
|
|
@@ -4234,12 +4234,12 @@ const A2 = {
|
|
|
4234
4234
|
nw: O.r7nw >= 0 ? O.r7nw : void 0
|
|
4235
4235
|
}, o = this.handleComputeArc(b.geometry.coordinates, p, { ...b.properties, level: 7 });
|
|
4236
4236
|
M.push(o);
|
|
4237
|
-
const
|
|
4237
|
+
const A = {
|
|
4238
4238
|
ne: O.r10ne >= 0 ? O.r10ne : void 0,
|
|
4239
4239
|
se: O.r10se >= 0 ? O.r10se : void 0,
|
|
4240
4240
|
sw: O.r10sw >= 0 ? O.r10sw : void 0,
|
|
4241
4241
|
nw: O.r10nw >= 0 ? O.r10nw : void 0
|
|
4242
|
-
}, t = this.handleComputeArc(b.geometry.coordinates,
|
|
4242
|
+
}, t = this.handleComputeArc(b.geometry.coordinates, A, { ...b.properties, level: 10 });
|
|
4243
4243
|
M.push(t);
|
|
4244
4244
|
}
|
|
4245
4245
|
return M;
|
|
@@ -4247,27 +4247,27 @@ const A2 = {
|
|
|
4247
4247
|
handleComputeArc(z, M, b) {
|
|
4248
4248
|
var o;
|
|
4249
4249
|
const O = [];
|
|
4250
|
-
for (const
|
|
4251
|
-
const t = M[
|
|
4250
|
+
for (const A in M) {
|
|
4251
|
+
const t = M[A] ?? 0;
|
|
4252
4252
|
let q;
|
|
4253
|
-
switch (
|
|
4253
|
+
switch (A) {
|
|
4254
4254
|
case "ne":
|
|
4255
|
-
q =
|
|
4255
|
+
q = v.lineArc(z, t * 1.852, 0, 90, { steps: t > 0 ? 64 : 1 });
|
|
4256
4256
|
break;
|
|
4257
4257
|
case "se":
|
|
4258
|
-
q =
|
|
4258
|
+
q = v.lineArc(z, t * 1.852, 90, 180, { steps: t > 0 ? 64 : 1 });
|
|
4259
4259
|
break;
|
|
4260
4260
|
case "sw":
|
|
4261
|
-
q =
|
|
4261
|
+
q = v.lineArc(z, t * 1.852, 180, 270, { steps: t > 0 ? 64 : 1 });
|
|
4262
4262
|
break;
|
|
4263
4263
|
case "nw":
|
|
4264
|
-
q =
|
|
4264
|
+
q = v.lineArc(z, t * 1.852, 270, 360, { steps: t > 0 ? 64 : 1 });
|
|
4265
4265
|
break;
|
|
4266
4266
|
}
|
|
4267
4267
|
O.push(...(o = q == null ? void 0 : q.geometry) == null ? void 0 : o.coordinates);
|
|
4268
4268
|
}
|
|
4269
|
-
const p =
|
|
4270
|
-
return
|
|
4269
|
+
const p = v.lineString(O);
|
|
4270
|
+
return v.lineToPolygon(p, { properties: b });
|
|
4271
4271
|
}
|
|
4272
4272
|
}
|
|
4273
4273
|
}, t2 = {
|
|
@@ -4276,7 +4276,7 @@ const A2 = {
|
|
|
4276
4276
|
}, a2 = { class: "header-box" }, q2 = { class: "main" }, i2 = { key: 0 }, r2 = { class: "sub" }, n2 = {
|
|
4277
4277
|
id: "meteoBox",
|
|
4278
4278
|
class: "main-box"
|
|
4279
|
-
}, d2 = { class: "content" },
|
|
4279
|
+
}, d2 = { class: "content" }, s2 = { class: "row" }, W2 = {
|
|
4280
4280
|
class: "col col-left",
|
|
4281
4281
|
style: { "justify-content": "flex-start" }
|
|
4282
4282
|
}, l2 = {
|
|
@@ -4287,49 +4287,49 @@ const A2 = {
|
|
|
4287
4287
|
style: { "justify-content": "flex-start" }
|
|
4288
4288
|
}, L2 = { class: "forecast-models" }, R2 = ["onClick"], h2 = { class: "more" };
|
|
4289
4289
|
function m2(z, M, b, O, p, o) {
|
|
4290
|
-
var
|
|
4291
|
-
return
|
|
4290
|
+
var A, t, q, r, a, i, L, n, h, u, d, m, R, X, E;
|
|
4291
|
+
return y0((s(), W("div", t2, [
|
|
4292
4292
|
c("div", a2, [
|
|
4293
4293
|
c("div", {
|
|
4294
4294
|
class: "iconfont close-btn",
|
|
4295
|
-
onClick: M[0] || (M[0] = (
|
|
4295
|
+
onClick: M[0] || (M[0] = (y) => p.showTropicals = !1)
|
|
4296
4296
|
}, ""),
|
|
4297
4297
|
c("div", q2, [
|
|
4298
|
-
(t = (
|
|
4299
|
-
|
|
4298
|
+
(t = (A = p.activeTropicals) == null ? void 0 : A.history) != null && t.level ? (s(), W("span", i2, T((r = (q = p.activeTropicals) == null ? void 0 : q.history) == null ? void 0 : r.level) + " , ", 1)) : j("", !0),
|
|
4299
|
+
z0(T((a = p.activeTropicals) == null ? void 0 : a.name), 1)
|
|
4300
4300
|
]),
|
|
4301
|
-
c("div", r2, " Last update: " +
|
|
4301
|
+
c("div", r2, " Last update: " + T(o.computeTime(((L = (i = p.activeTropicals) == null ? void 0 : i.history) == null ? void 0 : L.updated) || ((u = (h = (n = p.activeTropicals) == null ? void 0 : n.forecasts) == null ? void 0 : h.filter((y) => !y.disabled)[0]) == null ? void 0 : u.date))), 1)
|
|
4302
4302
|
]),
|
|
4303
4303
|
c("div", n2, [
|
|
4304
4304
|
c("div", d2, [
|
|
4305
|
-
c("div",
|
|
4306
|
-
c("div",
|
|
4305
|
+
c("div", s2, [
|
|
4306
|
+
c("div", W2, [
|
|
4307
4307
|
M[2] || (M[2] = c("label", null, "Wind speed : ", -1)),
|
|
4308
|
-
c("span", null,
|
|
4308
|
+
c("span", null, T(((m = (d = p.activeTropicals) == null ? void 0 : d.history) == null ? void 0 : m.kts) || "-") + "[kts]", 1)
|
|
4309
4309
|
]),
|
|
4310
4310
|
c("div", l2, [
|
|
4311
4311
|
M[3] || (M[3] = c("label", null, "Pressure : ", -1)),
|
|
4312
|
-
c("span", null,
|
|
4312
|
+
c("span", null, T(((X = (R = p.activeTropicals) == null ? void 0 : R.history) == null ? void 0 : X.pressure) || "-") + "[hPa]", 1)
|
|
4313
4313
|
])
|
|
4314
4314
|
]),
|
|
4315
4315
|
c("div", f2, [
|
|
4316
4316
|
c("div", u2, [
|
|
4317
4317
|
M[4] || (M[4] = c("label", { style: { width: "max-content" } }, "Forecast Models : ", -1)),
|
|
4318
4318
|
c("div", L2, [
|
|
4319
|
-
(
|
|
4320
|
-
var
|
|
4321
|
-
return
|
|
4322
|
-
key:
|
|
4323
|
-
class:
|
|
4319
|
+
(s(!0), W(F, null, K((E = p.activeTropicals) == null ? void 0 : E.forecasts, (y, _) => {
|
|
4320
|
+
var J, Z, M0, N;
|
|
4321
|
+
return s(), W("div", {
|
|
4322
|
+
key: _,
|
|
4323
|
+
class: V([
|
|
4324
4324
|
"model",
|
|
4325
|
-
|
|
4326
|
-
|
|
4325
|
+
y.disabled ? "" : "active",
|
|
4326
|
+
_ > 0 && _ < ((Z = (J = p.activeTropicals) == null ? void 0 : J.forecasts) == null ? void 0 : Z.length) - 1 && ((N = (M0 = p.activeTropicals) == null ? void 0 : M0.forecasts) == null ? void 0 : N.length) > 2 ? "center-child" : ""
|
|
4327
4327
|
]),
|
|
4328
|
-
onClick: (
|
|
4328
|
+
onClick: (x) => o.handleForecastToggle(y)
|
|
4329
4329
|
}, [
|
|
4330
4330
|
c("span", {
|
|
4331
|
-
class:
|
|
4332
|
-
},
|
|
4331
|
+
class: V(y.model)
|
|
4332
|
+
}, T(y.model), 3)
|
|
4333
4333
|
], 10, R2);
|
|
4334
4334
|
}), 128))
|
|
4335
4335
|
])
|
|
@@ -4340,16 +4340,16 @@ function m2(z, M, b, O, p, o) {
|
|
|
4340
4340
|
c("div", h2, [
|
|
4341
4341
|
c("div", {
|
|
4342
4342
|
class: "button",
|
|
4343
|
-
onClick: M[1] || (M[1] = (
|
|
4343
|
+
onClick: M[1] || (M[1] = (y) => o.handleStrikeProbability(p.activeTropicals))
|
|
4344
4344
|
}, "Strike Probability >>")
|
|
4345
4345
|
])
|
|
4346
4346
|
])
|
|
4347
4347
|
], 512)), [
|
|
4348
|
-
[
|
|
4348
|
+
[X0, p.showTropicals && !z.$attrs.hideTropicalsLegend]
|
|
4349
4349
|
]);
|
|
4350
4350
|
}
|
|
4351
|
-
const
|
|
4352
|
-
const
|
|
4351
|
+
const H0 = /* @__PURE__ */ Q(e2, [["render", m2], ["__scopeId", "data-v-44a4e671"]]);
|
|
4352
|
+
const B2 = {
|
|
4353
4353
|
name: "IdmPrecip3h",
|
|
4354
4354
|
props: {
|
|
4355
4355
|
factor: {
|
|
@@ -4377,7 +4377,7 @@ const N2 = {
|
|
|
4377
4377
|
texture: void 0,
|
|
4378
4378
|
rampColor: void 0,
|
|
4379
4379
|
aPositionBuffer: void 0,
|
|
4380
|
-
webgl: new
|
|
4380
|
+
webgl: new C0(),
|
|
4381
4381
|
etime: void 0,
|
|
4382
4382
|
right: 10
|
|
4383
4383
|
};
|
|
@@ -4450,13 +4450,13 @@ const N2 = {
|
|
|
4450
4450
|
this.webgl.draw(this.viewport, this.context, this.program, this.texture, this.rampColor.texture, this.aPositionBuffer), this.viewport.toggle(!0);
|
|
4451
4451
|
}
|
|
4452
4452
|
}
|
|
4453
|
-
},
|
|
4454
|
-
function
|
|
4455
|
-
var
|
|
4456
|
-
return (
|
|
4453
|
+
}, g2 = { key: 0 };
|
|
4454
|
+
function N2(z, M, b, O, p, o) {
|
|
4455
|
+
var A;
|
|
4456
|
+
return (A = b.factor) != null && A.active ? (s(), W("div", g2, [
|
|
4457
4457
|
c("div", {
|
|
4458
4458
|
class: "legend-bars flex-center",
|
|
4459
|
-
style:
|
|
4459
|
+
style: c0([{ position: "absolute" }, { right: p.right + "px", bottom: b.bottom }])
|
|
4460
4460
|
}, M[0] || (M[0] = [
|
|
4461
4461
|
c("span", null, "mm", -1),
|
|
4462
4462
|
c("span", null, "1.5", -1),
|
|
@@ -4467,9 +4467,9 @@ function y2(z, M, b, O, p, o) {
|
|
|
4467
4467
|
c("span", null, "20", -1),
|
|
4468
4468
|
c("span", null, "30", -1)
|
|
4469
4469
|
]), 4)
|
|
4470
|
-
])) :
|
|
4470
|
+
])) : j("", !0);
|
|
4471
4471
|
}
|
|
4472
|
-
const
|
|
4472
|
+
const y2 = /* @__PURE__ */ Q(B2, [["render", N2], ["__scopeId", "data-v-e83717bd"]]);
|
|
4473
4473
|
const X2 = {
|
|
4474
4474
|
name: "IdmVisibility",
|
|
4475
4475
|
props: {
|
|
@@ -4498,7 +4498,7 @@ const X2 = {
|
|
|
4498
4498
|
texture: void 0,
|
|
4499
4499
|
rampColor: void 0,
|
|
4500
4500
|
aPositionBuffer: void 0,
|
|
4501
|
-
webgl: new
|
|
4501
|
+
webgl: new C0(),
|
|
4502
4502
|
etime: void 0
|
|
4503
4503
|
};
|
|
4504
4504
|
},
|
|
@@ -4564,13 +4564,13 @@ const X2 = {
|
|
|
4564
4564
|
this.webgl.draw(this.viewport, this.context, this.program, this.texture, this.rampColor.texture, this.aPositionBuffer), this.viewport.toggle(!0);
|
|
4565
4565
|
}
|
|
4566
4566
|
}
|
|
4567
|
-
},
|
|
4568
|
-
function
|
|
4569
|
-
var
|
|
4570
|
-
return (
|
|
4567
|
+
}, w2 = { key: 0 };
|
|
4568
|
+
function C2(z, M, b, O, p, o) {
|
|
4569
|
+
var A;
|
|
4570
|
+
return (A = b.factor) != null && A.active ? (s(), W("div", w2, [
|
|
4571
4571
|
c("div", {
|
|
4572
4572
|
class: "legend-bars flex-center",
|
|
4573
|
-
style:
|
|
4573
|
+
style: c0([{ position: "absolute" }, { right: z.right + "px", bottom: b.bottom }])
|
|
4574
4574
|
}, M[0] || (M[0] = [
|
|
4575
4575
|
c("span", null, "nm", -1),
|
|
4576
4576
|
c("span", null, "0", -1),
|
|
@@ -4579,10 +4579,10 @@ function T2(z, M, b, O, p, o) {
|
|
|
4579
4579
|
c("span", null, "3", -1),
|
|
4580
4580
|
c("span", null, "9", -1)
|
|
4581
4581
|
]), 4)
|
|
4582
|
-
])) :
|
|
4582
|
+
])) : j("", !0);
|
|
4583
4583
|
}
|
|
4584
|
-
const
|
|
4585
|
-
const
|
|
4584
|
+
const v2 = /* @__PURE__ */ Q(X2, [["render", C2], ["__scopeId", "data-v-1c8a9237"]]);
|
|
4585
|
+
const T2 = {
|
|
4586
4586
|
name: "IdmWaterTemp",
|
|
4587
4587
|
props: {
|
|
4588
4588
|
factor: {
|
|
@@ -4610,7 +4610,7 @@ const C2 = {
|
|
|
4610
4610
|
texture: void 0,
|
|
4611
4611
|
rampColor: void 0,
|
|
4612
4612
|
aPositionBuffer: void 0,
|
|
4613
|
-
webgl: new
|
|
4613
|
+
webgl: new C0(),
|
|
4614
4614
|
etime: void 0,
|
|
4615
4615
|
right: 10
|
|
4616
4616
|
};
|
|
@@ -4684,13 +4684,13 @@ const C2 = {
|
|
|
4684
4684
|
this.webgl.draw(this.viewport, this.context, this.program, this.texture, this.rampColor.texture, this.aPositionBuffer), this.viewport.toggle(!0);
|
|
4685
4685
|
}
|
|
4686
4686
|
}
|
|
4687
|
-
},
|
|
4687
|
+
}, E2 = { key: 0 };
|
|
4688
4688
|
function x2(z, M, b, O, p, o) {
|
|
4689
|
-
var
|
|
4690
|
-
return (
|
|
4689
|
+
var A;
|
|
4690
|
+
return (A = b.factor) != null && A.active ? (s(), W("div", E2, [
|
|
4691
4691
|
c("div", {
|
|
4692
4692
|
class: "legend-bars flex-center",
|
|
4693
|
-
style:
|
|
4693
|
+
style: c0([{ position: "absolute" }, { right: p.right + "px", bottom: b.bottom }])
|
|
4694
4694
|
}, M[0] || (M[0] = [
|
|
4695
4695
|
c("span", null, "°C", -1),
|
|
4696
4696
|
c("span", null, "0", -1),
|
|
@@ -4699,10 +4699,10 @@ function x2(z, M, b, O, p, o) {
|
|
|
4699
4699
|
c("span", null, "30", -1),
|
|
4700
4700
|
c("span", null, "40", -1)
|
|
4701
4701
|
]), 4)
|
|
4702
|
-
])) :
|
|
4702
|
+
])) : j("", !0);
|
|
4703
4703
|
}
|
|
4704
|
-
const
|
|
4705
|
-
const
|
|
4704
|
+
const I2 = /* @__PURE__ */ Q(T2, [["render", x2], ["__scopeId", "data-v-8974924d"]]);
|
|
4705
|
+
const D2 = {
|
|
4706
4706
|
name: "IdmTemp",
|
|
4707
4707
|
props: {
|
|
4708
4708
|
factor: {
|
|
@@ -4730,7 +4730,7 @@ const E2 = {
|
|
|
4730
4730
|
texture: void 0,
|
|
4731
4731
|
rampColor: void 0,
|
|
4732
4732
|
aPositionBuffer: void 0,
|
|
4733
|
-
webgl: new
|
|
4733
|
+
webgl: new C0(),
|
|
4734
4734
|
etime: void 0,
|
|
4735
4735
|
right: 10
|
|
4736
4736
|
};
|
|
@@ -4808,12 +4808,12 @@ const E2 = {
|
|
|
4808
4808
|
}
|
|
4809
4809
|
}
|
|
4810
4810
|
}, P2 = { key: 0 };
|
|
4811
|
-
function
|
|
4812
|
-
var
|
|
4813
|
-
return (
|
|
4811
|
+
function S2(z, M, b, O, p, o) {
|
|
4812
|
+
var A;
|
|
4813
|
+
return (A = b.factor) != null && A.active ? (s(), W("div", P2, [
|
|
4814
4814
|
c("div", {
|
|
4815
4815
|
class: "legend-bars flex-center",
|
|
4816
|
-
style:
|
|
4816
|
+
style: c0([{ position: "absolute" }, { right: p.right + "px", bottom: b.bottom }])
|
|
4817
4817
|
}, M[0] || (M[0] = [
|
|
4818
4818
|
c("span", null, "°C", -1),
|
|
4819
4819
|
c("span", null, "-20", -1),
|
|
@@ -4824,10 +4824,10 @@ function k2(z, M, b, O, p, o) {
|
|
|
4824
4824
|
c("span", null, "30", -1),
|
|
4825
4825
|
c("span", null, "40", -1)
|
|
4826
4826
|
]), 4)
|
|
4827
|
-
])) :
|
|
4827
|
+
])) : j("", !0);
|
|
4828
4828
|
}
|
|
4829
|
-
const
|
|
4830
|
-
const
|
|
4829
|
+
const k2 = /* @__PURE__ */ Q(D2, [["render", S2], ["__scopeId", "data-v-d709ba86"]]);
|
|
4830
|
+
const Q2 = {
|
|
4831
4831
|
name: "IdmArctic",
|
|
4832
4832
|
props: {
|
|
4833
4833
|
factor: {
|
|
@@ -4855,7 +4855,7 @@ const I2 = {
|
|
|
4855
4855
|
texture: void 0,
|
|
4856
4856
|
rampColor: void 0,
|
|
4857
4857
|
aPositionBuffer: void 0,
|
|
4858
|
-
webgl: new
|
|
4858
|
+
webgl: new C0(),
|
|
4859
4859
|
etime: void 0,
|
|
4860
4860
|
right: 10
|
|
4861
4861
|
};
|
|
@@ -4923,13 +4923,13 @@ const I2 = {
|
|
|
4923
4923
|
this.webgl.draw(this.viewport, this.context, this.program, this.texture, this.rampColor.texture, this.aPositionBuffer), this.viewport.toggle(!0);
|
|
4924
4924
|
}
|
|
4925
4925
|
}
|
|
4926
|
-
},
|
|
4927
|
-
function
|
|
4928
|
-
var
|
|
4929
|
-
return (
|
|
4926
|
+
}, H2 = { key: 0 };
|
|
4927
|
+
function _2(z, M, b, O, p, o) {
|
|
4928
|
+
var A;
|
|
4929
|
+
return (A = b.factor) != null && A.active ? (s(), W("div", H2, [
|
|
4930
4930
|
c("div", {
|
|
4931
4931
|
class: "legend-bars flex-center",
|
|
4932
|
-
style:
|
|
4932
|
+
style: c0([{ position: "absolute" }, { right: p.right + "px", bottom: b.bottom }])
|
|
4933
4933
|
}, M[0] || (M[0] = [
|
|
4934
4934
|
c("span", null, "m", -1),
|
|
4935
4935
|
c("span", null, "0", -1),
|
|
@@ -4938,15 +4938,15 @@ function U2(z, M, b, O, p, o) {
|
|
|
4938
4938
|
c("span", null, "1.5", -1),
|
|
4939
4939
|
c("span", null, "2", -1)
|
|
4940
4940
|
]), 4)
|
|
4941
|
-
])) :
|
|
4941
|
+
])) : j("", !0);
|
|
4942
4942
|
}
|
|
4943
|
-
const
|
|
4943
|
+
const j2 = /* @__PURE__ */ Q(Q2, [["render", _2], ["__scopeId", "data-v-5bb73794"]]);
|
|
4944
4944
|
/*! Element Plus Icons Vue v2.3.1 */
|
|
4945
|
-
var
|
|
4945
|
+
var F2 = /* @__PURE__ */ J0({
|
|
4946
4946
|
name: "LocationFilled",
|
|
4947
4947
|
__name: "location-filled",
|
|
4948
4948
|
setup(z) {
|
|
4949
|
-
return (M, b) => (
|
|
4949
|
+
return (M, b) => (s(), W("svg", {
|
|
4950
4950
|
xmlns: "http://www.w3.org/2000/svg",
|
|
4951
4951
|
viewBox: "0 0 1024 1024"
|
|
4952
4952
|
}, [
|
|
@@ -4956,11 +4956,11 @@ var H2 = /* @__PURE__ */ J0({
|
|
|
4956
4956
|
})
|
|
4957
4957
|
]));
|
|
4958
4958
|
}
|
|
4959
|
-
}), G2 =
|
|
4959
|
+
}), G2 = F2, U2 = typeof globalThis < "u" ? globalThis : typeof window < "u" ? window : typeof global < "u" ? global : typeof self < "u" ? self : {};
|
|
4960
4960
|
function K2(z) {
|
|
4961
4961
|
return z && z.__esModule && Object.prototype.hasOwnProperty.call(z, "default") ? z.default : z;
|
|
4962
4962
|
}
|
|
4963
|
-
var
|
|
4963
|
+
var _0 = { exports: {} }, j0 = { exports: {} };
|
|
4964
4964
|
(function(z) {
|
|
4965
4965
|
//! moment-timezone.js
|
|
4966
4966
|
//! version : 0.5.47
|
|
@@ -4968,276 +4968,276 @@ var U0 = { exports: {} }, F0 = { exports: {} };
|
|
|
4968
4968
|
//! license : MIT
|
|
4969
4969
|
//! github.com/moment/moment-timezone
|
|
4970
4970
|
(function(M, b) {
|
|
4971
|
-
z.exports ? z.exports = b(
|
|
4972
|
-
})(
|
|
4971
|
+
z.exports ? z.exports = b(G) : b(M.moment);
|
|
4972
|
+
})(U2, function(M) {
|
|
4973
4973
|
M.version === void 0 && M.default && (M = M.default);
|
|
4974
|
-
var b = "0.5.47", O = {}, p = {}, o = {},
|
|
4975
|
-
(!M || typeof M.version != "string") &&
|
|
4974
|
+
var b = "0.5.47", O = {}, p = {}, o = {}, A = {}, t = {}, q;
|
|
4975
|
+
(!M || typeof M.version != "string") && a0("Moment Timezone requires Moment.js. See https://momentjs.com/timezone/docs/#/use-it/browser/");
|
|
4976
4976
|
var r = M.version.split("."), a = +r[0], i = +r[1];
|
|
4977
|
-
(a < 2 || a === 2 && i < 6) &&
|
|
4978
|
-
function L(
|
|
4979
|
-
return
|
|
4980
|
-
}
|
|
4981
|
-
function n(
|
|
4982
|
-
var
|
|
4983
|
-
for (
|
|
4984
|
-
|
|
4985
|
-
for (
|
|
4986
|
-
P = P / 60,
|
|
4987
|
-
return
|
|
4988
|
-
}
|
|
4989
|
-
function h(
|
|
4990
|
-
for (var
|
|
4991
|
-
|
|
4992
|
-
}
|
|
4993
|
-
function u(
|
|
4994
|
-
for (var
|
|
4995
|
-
|
|
4996
|
-
|
|
4997
|
-
}
|
|
4998
|
-
function d(
|
|
4999
|
-
var
|
|
5000
|
-
for (
|
|
5001
|
-
|
|
5002
|
-
return
|
|
5003
|
-
}
|
|
5004
|
-
function m(
|
|
5005
|
-
var
|
|
5006
|
-
return h(
|
|
5007
|
-
name:
|
|
5008
|
-
abbrs: d(
|
|
5009
|
-
offsets: d(
|
|
5010
|
-
untils:
|
|
5011
|
-
population:
|
|
4977
|
+
(a < 2 || a === 2 && i < 6) && a0("Moment Timezone requires Moment.js >= 2.6.0. You are using Moment.js " + M.version + ". See momentjs.com");
|
|
4978
|
+
function L(e) {
|
|
4979
|
+
return e > 96 ? e - 87 : e > 64 ? e - 29 : e - 48;
|
|
4980
|
+
}
|
|
4981
|
+
function n(e) {
|
|
4982
|
+
var l = 0, f = e.split("."), B = f[0], w = f[1] || "", P = 1, $, k = 0, U = 1;
|
|
4983
|
+
for (e.charCodeAt(0) === 45 && (l = 1, U = -1), l; l < B.length; l++)
|
|
4984
|
+
$ = L(B.charCodeAt(l)), k = 60 * k + $;
|
|
4985
|
+
for (l = 0; l < w.length; l++)
|
|
4986
|
+
P = P / 60, $ = L(w.charCodeAt(l)), k += $ * P;
|
|
4987
|
+
return k * U;
|
|
4988
|
+
}
|
|
4989
|
+
function h(e) {
|
|
4990
|
+
for (var l = 0; l < e.length; l++)
|
|
4991
|
+
e[l] = n(e[l]);
|
|
4992
|
+
}
|
|
4993
|
+
function u(e, l) {
|
|
4994
|
+
for (var f = 0; f < l; f++)
|
|
4995
|
+
e[f] = Math.round((e[f - 1] || 0) + e[f] * 6e4);
|
|
4996
|
+
e[l - 1] = 1 / 0;
|
|
4997
|
+
}
|
|
4998
|
+
function d(e, l) {
|
|
4999
|
+
var f = [], B;
|
|
5000
|
+
for (B = 0; B < l.length; B++)
|
|
5001
|
+
f[B] = e[l[B]];
|
|
5002
|
+
return f;
|
|
5003
|
+
}
|
|
5004
|
+
function m(e) {
|
|
5005
|
+
var l = e.split("|"), f = l[2].split(" "), B = l[3].split(""), w = l[4].split(" ");
|
|
5006
|
+
return h(f), h(B), h(w), u(w, B.length), {
|
|
5007
|
+
name: l[0],
|
|
5008
|
+
abbrs: d(l[1].split(" "), B),
|
|
5009
|
+
offsets: d(f, B),
|
|
5010
|
+
untils: w,
|
|
5011
|
+
population: l[5] | 0
|
|
5012
5012
|
};
|
|
5013
5013
|
}
|
|
5014
|
-
function R(
|
|
5015
|
-
|
|
5014
|
+
function R(e) {
|
|
5015
|
+
e && this._set(m(e));
|
|
5016
5016
|
}
|
|
5017
|
-
function X(
|
|
5018
|
-
var
|
|
5019
|
-
if (
|
|
5017
|
+
function X(e, l) {
|
|
5018
|
+
var f = l.length;
|
|
5019
|
+
if (e < l[0])
|
|
5020
5020
|
return 0;
|
|
5021
|
-
if (
|
|
5022
|
-
return
|
|
5023
|
-
if (
|
|
5021
|
+
if (f > 1 && l[f - 1] === 1 / 0 && e >= l[f - 2])
|
|
5022
|
+
return f - 1;
|
|
5023
|
+
if (e >= l[f - 1])
|
|
5024
5024
|
return -1;
|
|
5025
|
-
for (var
|
|
5026
|
-
|
|
5025
|
+
for (var B, w = 0, P = f - 1; P - w > 1; )
|
|
5026
|
+
B = Math.floor((w + P) / 2), l[B] <= e ? w = B : P = B;
|
|
5027
5027
|
return P;
|
|
5028
5028
|
}
|
|
5029
5029
|
R.prototype = {
|
|
5030
|
-
_set: function(
|
|
5031
|
-
this.name =
|
|
5030
|
+
_set: function(e) {
|
|
5031
|
+
this.name = e.name, this.abbrs = e.abbrs, this.untils = e.untils, this.offsets = e.offsets, this.population = e.population;
|
|
5032
5032
|
},
|
|
5033
|
-
_index: function(
|
|
5034
|
-
var
|
|
5035
|
-
if (
|
|
5036
|
-
return
|
|
5033
|
+
_index: function(e) {
|
|
5034
|
+
var l = +e, f = this.untils, B;
|
|
5035
|
+
if (B = X(l, f), B >= 0)
|
|
5036
|
+
return B;
|
|
5037
5037
|
},
|
|
5038
5038
|
countries: function() {
|
|
5039
|
-
var
|
|
5040
|
-
return Object.keys(o).filter(function(
|
|
5041
|
-
return o[
|
|
5039
|
+
var e = this.name;
|
|
5040
|
+
return Object.keys(o).filter(function(l) {
|
|
5041
|
+
return o[l].zones.indexOf(e) !== -1;
|
|
5042
5042
|
});
|
|
5043
5043
|
},
|
|
5044
|
-
parse: function(
|
|
5045
|
-
var
|
|
5046
|
-
for (
|
|
5047
|
-
if (P =
|
|
5048
|
-
return
|
|
5049
|
-
return
|
|
5044
|
+
parse: function(e) {
|
|
5045
|
+
var l = +e, f = this.offsets, B = this.untils, w = B.length - 1, P, $, k, U;
|
|
5046
|
+
for (U = 0; U < w; U++)
|
|
5047
|
+
if (P = f[U], $ = f[U + 1], k = f[U && U - 1], P < $ && D.moveAmbiguousForward ? P = $ : P > k && D.moveInvalidForward && (P = k), l < B[U] - P * 6e4)
|
|
5048
|
+
return f[U];
|
|
5049
|
+
return f[w];
|
|
5050
5050
|
},
|
|
5051
|
-
abbr: function(
|
|
5052
|
-
return this.abbrs[this._index(
|
|
5051
|
+
abbr: function(e) {
|
|
5052
|
+
return this.abbrs[this._index(e)];
|
|
5053
5053
|
},
|
|
5054
|
-
offset: function(
|
|
5055
|
-
return
|
|
5054
|
+
offset: function(e) {
|
|
5055
|
+
return a0("zone.offset has been deprecated in favor of zone.utcOffset"), this.offsets[this._index(e)];
|
|
5056
5056
|
},
|
|
5057
|
-
utcOffset: function(
|
|
5058
|
-
return this.offsets[this._index(
|
|
5057
|
+
utcOffset: function(e) {
|
|
5058
|
+
return this.offsets[this._index(e)];
|
|
5059
5059
|
}
|
|
5060
5060
|
};
|
|
5061
|
-
function
|
|
5062
|
-
this.name =
|
|
5061
|
+
function E(e, l) {
|
|
5062
|
+
this.name = e, this.zones = l;
|
|
5063
5063
|
}
|
|
5064
|
-
function
|
|
5065
|
-
var
|
|
5066
|
-
|
|
5064
|
+
function y(e) {
|
|
5065
|
+
var l = e.toTimeString(), f = l.match(/\([a-z ]+\)/i);
|
|
5066
|
+
f && f[0] ? (f = f[0].match(/[A-Z]/g), f = f ? f.join("") : void 0) : (f = l.match(/[A-Z]{3,5}/g), f = f ? f[0] : void 0), f === "GMT" && (f = void 0), this.at = +e, this.abbr = f, this.offset = e.getTimezoneOffset();
|
|
5067
5067
|
}
|
|
5068
|
-
function
|
|
5069
|
-
this.zone =
|
|
5068
|
+
function _(e) {
|
|
5069
|
+
this.zone = e, this.offsetScore = 0, this.abbrScore = 0;
|
|
5070
5070
|
}
|
|
5071
|
-
|
|
5072
|
-
this.offsetScore += Math.abs(this.zone.utcOffset(
|
|
5071
|
+
_.prototype.scoreOffsetAt = function(e) {
|
|
5072
|
+
this.offsetScore += Math.abs(this.zone.utcOffset(e.at) - e.offset), this.zone.abbr(e.at).replace(/[^A-Z]/g, "") !== e.abbr && this.abbrScore++;
|
|
5073
5073
|
};
|
|
5074
|
-
function
|
|
5075
|
-
for (var
|
|
5076
|
-
|
|
5077
|
-
return
|
|
5078
|
-
}
|
|
5079
|
-
function
|
|
5080
|
-
var
|
|
5081
|
-
for (
|
|
5082
|
-
|
|
5083
|
-
for (
|
|
5084
|
-
|
|
5085
|
-
return
|
|
5086
|
-
}
|
|
5087
|
-
function
|
|
5088
|
-
return
|
|
5089
|
-
}
|
|
5090
|
-
function
|
|
5091
|
-
var
|
|
5092
|
-
for (h(
|
|
5093
|
-
|
|
5094
|
-
}
|
|
5095
|
-
function
|
|
5096
|
-
var
|
|
5097
|
-
for (P = 0; P <
|
|
5098
|
-
if (
|
|
5099
|
-
|
|
5100
|
-
for (
|
|
5101
|
-
|
|
5102
|
-
|
|
5074
|
+
function J(e, l) {
|
|
5075
|
+
for (var f, B; B = ((l.at - e.at) / 12e4 | 0) * 6e4; )
|
|
5076
|
+
f = new y(new Date(e.at + B)), f.offset === e.offset ? e = f : l = f;
|
|
5077
|
+
return e;
|
|
5078
|
+
}
|
|
5079
|
+
function Z() {
|
|
5080
|
+
var e = (/* @__PURE__ */ new Date()).getFullYear() - 2, l = new y(new Date(e, 0, 1)), f = l.offset, B = [l], w, P, $, k;
|
|
5081
|
+
for (k = 1; k < 48; k++)
|
|
5082
|
+
$ = new Date(e, k, 1).getTimezoneOffset(), $ !== f && (P = new y(new Date(e, k, 1)), w = J(l, P), B.push(w), B.push(new y(new Date(w.at + 6e4))), l = P, f = $);
|
|
5083
|
+
for (k = 0; k < 4; k++)
|
|
5084
|
+
B.push(new y(new Date(e + k, 0, 1))), B.push(new y(new Date(e + k, 6, 1)));
|
|
5085
|
+
return B;
|
|
5086
|
+
}
|
|
5087
|
+
function M0(e, l) {
|
|
5088
|
+
return e.offsetScore !== l.offsetScore ? e.offsetScore - l.offsetScore : e.abbrScore !== l.abbrScore ? e.abbrScore - l.abbrScore : e.zone.population !== l.zone.population ? l.zone.population - e.zone.population : l.zone.name.localeCompare(e.zone.name);
|
|
5089
|
+
}
|
|
5090
|
+
function N(e, l) {
|
|
5091
|
+
var f, B;
|
|
5092
|
+
for (h(l), f = 0; f < l.length; f++)
|
|
5093
|
+
B = l[f], t[B] = t[B] || {}, t[B][e] = !0;
|
|
5094
|
+
}
|
|
5095
|
+
function x(e) {
|
|
5096
|
+
var l = e.length, f = {}, B = [], w = {}, P, $, k, U;
|
|
5097
|
+
for (P = 0; P < l; P++)
|
|
5098
|
+
if (k = e[P].offset, !w.hasOwnProperty(k)) {
|
|
5099
|
+
U = t[k] || {};
|
|
5100
|
+
for ($ in U)
|
|
5101
|
+
U.hasOwnProperty($) && (f[$] = !0);
|
|
5102
|
+
w[k] = !0;
|
|
5103
5103
|
}
|
|
5104
|
-
for (P in
|
|
5105
|
-
|
|
5106
|
-
return
|
|
5104
|
+
for (P in f)
|
|
5105
|
+
f.hasOwnProperty(P) && B.push(A[P]);
|
|
5106
|
+
return B;
|
|
5107
5107
|
}
|
|
5108
|
-
function
|
|
5108
|
+
function d0() {
|
|
5109
5109
|
try {
|
|
5110
|
-
var
|
|
5111
|
-
if (
|
|
5112
|
-
var
|
|
5113
|
-
if (
|
|
5114
|
-
return
|
|
5115
|
-
|
|
5110
|
+
var e = Intl.DateTimeFormat().resolvedOptions().timeZone;
|
|
5111
|
+
if (e && e.length > 3) {
|
|
5112
|
+
var l = A[r0(e)];
|
|
5113
|
+
if (l)
|
|
5114
|
+
return l;
|
|
5115
|
+
a0("Moment Timezone found " + e + " from the Intl api, but did not have that data loaded.");
|
|
5116
5116
|
}
|
|
5117
5117
|
} catch {
|
|
5118
5118
|
}
|
|
5119
|
-
var
|
|
5120
|
-
for (
|
|
5121
|
-
for (
|
|
5122
|
-
|
|
5123
|
-
P.push(
|
|
5119
|
+
var f = Z(), B = f.length, w = x(f), P = [], $, k, U;
|
|
5120
|
+
for (k = 0; k < w.length; k++) {
|
|
5121
|
+
for ($ = new _(o0(w[k])), U = 0; U < B; U++)
|
|
5122
|
+
$.scoreOffsetAt(f[U]);
|
|
5123
|
+
P.push($);
|
|
5124
5124
|
}
|
|
5125
|
-
return P.sort(
|
|
5125
|
+
return P.sort(M0), P.length > 0 ? P[0].zone.name : void 0;
|
|
5126
5126
|
}
|
|
5127
|
-
function
|
|
5128
|
-
return (!q ||
|
|
5127
|
+
function s0(e) {
|
|
5128
|
+
return (!q || e) && (q = d0()), q;
|
|
5129
5129
|
}
|
|
5130
|
-
function r0(
|
|
5131
|
-
return (
|
|
5130
|
+
function r0(e) {
|
|
5131
|
+
return (e || "").toLowerCase().replace(/\//g, "_");
|
|
5132
5132
|
}
|
|
5133
|
-
function
|
|
5134
|
-
var
|
|
5135
|
-
for (typeof
|
|
5136
|
-
|
|
5133
|
+
function L0(e) {
|
|
5134
|
+
var l, f, B, w;
|
|
5135
|
+
for (typeof e == "string" && (e = [e]), l = 0; l < e.length; l++)
|
|
5136
|
+
B = e[l].split("|"), f = B[0], w = r0(f), O[w] = e[l], A[w] = f, N(w, B[2].split(" "));
|
|
5137
5137
|
}
|
|
5138
|
-
function
|
|
5139
|
-
|
|
5140
|
-
var
|
|
5141
|
-
return
|
|
5138
|
+
function o0(e, l) {
|
|
5139
|
+
e = r0(e);
|
|
5140
|
+
var f = O[e], B;
|
|
5141
|
+
return f instanceof R ? f : typeof f == "string" ? (f = new R(f), O[e] = f, f) : p[e] && l !== o0 && (B = o0(p[e], o0)) ? (f = O[e] = new R(), f._set(B), f.name = A[e], f) : null;
|
|
5142
5142
|
}
|
|
5143
5143
|
function h0() {
|
|
5144
|
-
var
|
|
5145
|
-
for (
|
|
5146
|
-
|
|
5147
|
-
return
|
|
5144
|
+
var e, l = [];
|
|
5145
|
+
for (e in A)
|
|
5146
|
+
A.hasOwnProperty(e) && (O[e] || O[p[e]]) && A[e] && l.push(A[e]);
|
|
5147
|
+
return l.sort();
|
|
5148
5148
|
}
|
|
5149
5149
|
function m0() {
|
|
5150
5150
|
return Object.keys(o);
|
|
5151
5151
|
}
|
|
5152
|
-
function
|
|
5153
|
-
var
|
|
5154
|
-
for (typeof
|
|
5155
|
-
|
|
5156
|
-
}
|
|
5157
|
-
function n0(
|
|
5158
|
-
var
|
|
5159
|
-
if (!(!
|
|
5160
|
-
for (
|
|
5161
|
-
|
|
5162
|
-
|
|
5163
|
-
|
|
5152
|
+
function W0(e) {
|
|
5153
|
+
var l, f, B, w;
|
|
5154
|
+
for (typeof e == "string" && (e = [e]), l = 0; l < e.length; l++)
|
|
5155
|
+
f = e[l].split("|"), B = r0(f[0]), w = r0(f[1]), p[B] = w, A[B] = f[0], p[w] = B, A[w] = f[1];
|
|
5156
|
+
}
|
|
5157
|
+
function n0(e) {
|
|
5158
|
+
var l, f, B, w;
|
|
5159
|
+
if (!(!e || !e.length))
|
|
5160
|
+
for (l = 0; l < e.length; l++)
|
|
5161
|
+
w = e[l].split("|"), f = w[0].toUpperCase(), B = w[1].split(" "), o[f] = new E(
|
|
5162
|
+
f,
|
|
5163
|
+
B
|
|
5164
5164
|
);
|
|
5165
5165
|
}
|
|
5166
|
-
function
|
|
5167
|
-
return
|
|
5166
|
+
function l0(e) {
|
|
5167
|
+
return e = e.toUpperCase(), o[e] || null;
|
|
5168
5168
|
}
|
|
5169
|
-
function
|
|
5170
|
-
if (
|
|
5169
|
+
function B0(e, l) {
|
|
5170
|
+
if (e = l0(e), !e)
|
|
5171
5171
|
return null;
|
|
5172
|
-
var
|
|
5173
|
-
return
|
|
5174
|
-
var
|
|
5172
|
+
var f = e.zones.sort();
|
|
5173
|
+
return l ? f.map(function(B) {
|
|
5174
|
+
var w = o0(B);
|
|
5175
5175
|
return {
|
|
5176
|
-
name:
|
|
5177
|
-
offset:
|
|
5176
|
+
name: B,
|
|
5177
|
+
offset: w.utcOffset(/* @__PURE__ */ new Date())
|
|
5178
5178
|
};
|
|
5179
|
-
}) :
|
|
5179
|
+
}) : f;
|
|
5180
5180
|
}
|
|
5181
|
-
function
|
|
5182
|
-
|
|
5181
|
+
function f0(e) {
|
|
5182
|
+
L0(e.zones), W0(e.links), n0(e.countries), D.dataVersion = e.version;
|
|
5183
5183
|
}
|
|
5184
|
-
function
|
|
5185
|
-
return
|
|
5184
|
+
function S(e) {
|
|
5185
|
+
return S.didShowError || (S.didShowError = !0, a0("moment.tz.zoneExists('" + e + "') has been deprecated in favor of !moment.tz.zone('" + e + "')")), !!o0(e);
|
|
5186
5186
|
}
|
|
5187
|
-
function
|
|
5188
|
-
var
|
|
5189
|
-
return !!(
|
|
5187
|
+
function p0(e) {
|
|
5188
|
+
var l = e._f === "X" || e._f === "x";
|
|
5189
|
+
return !!(e._a && e._tzm === void 0 && !l);
|
|
5190
5190
|
}
|
|
5191
|
-
function
|
|
5192
|
-
typeof console < "u" && typeof console.error == "function" && console.error(
|
|
5191
|
+
function a0(e) {
|
|
5192
|
+
typeof console < "u" && typeof console.error == "function" && console.error(e);
|
|
5193
5193
|
}
|
|
5194
|
-
function
|
|
5195
|
-
var
|
|
5196
|
-
return !M.isMoment(
|
|
5194
|
+
function D(e) {
|
|
5195
|
+
var l = Array.prototype.slice.call(arguments, 0, -1), f = arguments[arguments.length - 1], B = M.utc.apply(null, l), w;
|
|
5196
|
+
return !M.isMoment(e) && p0(B) && (w = o0(f)) && B.add(w.parse(B), "minutes"), B.tz(f), B;
|
|
5197
5197
|
}
|
|
5198
|
-
|
|
5199
|
-
var
|
|
5200
|
-
M.tz =
|
|
5201
|
-
var
|
|
5202
|
-
if (
|
|
5203
|
-
if (
|
|
5204
|
-
var
|
|
5205
|
-
|
|
5198
|
+
D.version = b, D.dataVersion = "", D._zones = O, D._links = p, D._names = A, D._countries = o, D.add = L0, D.link = W0, D.load = f0, D.zone = o0, D.zoneExists = S, D.guess = s0, D.names = h0, D.Zone = R, D.unpack = m, D.unpackBase60 = n, D.needsOffset = p0, D.moveInvalidForward = !0, D.moveAmbiguousForward = !1, D.countries = m0, D.zonesForCountry = B0;
|
|
5199
|
+
var O0 = M.fn;
|
|
5200
|
+
M.tz = D, M.defaultZone = null, M.updateOffset = function(e, l) {
|
|
5201
|
+
var f = M.defaultZone, B;
|
|
5202
|
+
if (e._z === void 0 && (f && p0(e) && !e._isUTC && e.isValid() && (e._d = M.utc(e._a)._d, e.utc().add(f.parse(e), "minutes")), e._z = f), e._z)
|
|
5203
|
+
if (B = e._z.utcOffset(e), Math.abs(B) < 16 && (B = B / 60), e.utcOffset !== void 0) {
|
|
5204
|
+
var w = e._z;
|
|
5205
|
+
e.utcOffset(-B, l), e._z = w;
|
|
5206
5206
|
} else
|
|
5207
|
-
|
|
5208
|
-
},
|
|
5209
|
-
if (
|
|
5210
|
-
if (typeof
|
|
5211
|
-
throw new Error("Time zone name must be a string, got " +
|
|
5212
|
-
return this._z =
|
|
5207
|
+
e.zone(B, l);
|
|
5208
|
+
}, O0.tz = function(e, l) {
|
|
5209
|
+
if (e) {
|
|
5210
|
+
if (typeof e != "string")
|
|
5211
|
+
throw new Error("Time zone name must be a string, got " + e + " [" + typeof e + "]");
|
|
5212
|
+
return this._z = o0(e), this._z ? M.updateOffset(this, l) : a0("Moment Timezone has no data for " + e + ". See http://momentjs.com/timezone/docs/#/data-loading/."), this;
|
|
5213
5213
|
}
|
|
5214
5214
|
if (this._z)
|
|
5215
5215
|
return this._z.name;
|
|
5216
5216
|
};
|
|
5217
|
-
function
|
|
5217
|
+
function u0(e) {
|
|
5218
5218
|
return function() {
|
|
5219
|
-
return this._z ? this._z.abbr(this) :
|
|
5219
|
+
return this._z ? this._z.abbr(this) : e.call(this);
|
|
5220
5220
|
};
|
|
5221
5221
|
}
|
|
5222
|
-
function
|
|
5222
|
+
function A0(e) {
|
|
5223
5223
|
return function() {
|
|
5224
|
-
return this._z = null,
|
|
5224
|
+
return this._z = null, e.apply(this, arguments);
|
|
5225
5225
|
};
|
|
5226
5226
|
}
|
|
5227
|
-
function
|
|
5227
|
+
function R0(e) {
|
|
5228
5228
|
return function() {
|
|
5229
|
-
return arguments.length > 0 && (this._z = null),
|
|
5229
|
+
return arguments.length > 0 && (this._z = null), e.apply(this, arguments);
|
|
5230
5230
|
};
|
|
5231
5231
|
}
|
|
5232
|
-
|
|
5233
|
-
return (a < 2 || a === 2 && i < 9) &&
|
|
5232
|
+
O0.zoneName = u0(O0.zoneName), O0.zoneAbbr = u0(O0.zoneAbbr), O0.utc = A0(O0.utc), O0.local = A0(O0.local), O0.utcOffset = R0(O0.utcOffset), M.tz.setDefault = function(e) {
|
|
5233
|
+
return (a < 2 || a === 2 && i < 9) && a0("Moment Timezone setDefault() requires Moment.js >= 2.9.0. You are using Moment.js " + M.version + "."), M.defaultZone = e ? o0(e) : null, M;
|
|
5234
5234
|
};
|
|
5235
|
-
var
|
|
5236
|
-
return Object.prototype.toString.call(
|
|
5235
|
+
var g = M.momentProperties;
|
|
5236
|
+
return Object.prototype.toString.call(g) === "[object Array]" ? (g.push("_z"), g.push("_a")) : g && (g._z = null), M;
|
|
5237
5237
|
});
|
|
5238
|
-
})(
|
|
5239
|
-
var J2 =
|
|
5240
|
-
const
|
|
5238
|
+
})(j0);
|
|
5239
|
+
var J2 = j0.exports;
|
|
5240
|
+
const Y2 = "2025a", V2 = [
|
|
5241
5241
|
"Africa/Abidjan|LMT GMT|g.8 0|01|-2ldXH.Q|48e5",
|
|
5242
5242
|
"Africa/Nairobi|LMT +0230 EAT +0245|-2r.g -2u -30 -2J|012132|-2ua2r.g N6nV.g 3Fbu h1cu dzbJ|47e5",
|
|
5243
5243
|
"Africa/Algiers|LMT PMT WET WEST CET CEST|-c.c -9.l 0 -10 -10 -20|01232323232323232454542423234542324|-3bQ0c.c MDA2.P cNb9.l HA0 19A0 1iM0 11c0 1oo0 Wo0 1rc0 QM0 1EM0 UM0 DA0 Imo0 rd0 De0 9Xz0 1fb0 1ap0 16K0 2yo0 mEp0 hwL0 jxA0 11A0 dDd0 17b0 11B0 1cN0 2Dy0 1cN0 1fB0 1cL0|26e5",
|
|
@@ -5835,7 +5835,7 @@ const Q2 = "2025a", $2 = [
|
|
|
5835
5835
|
"Pacific/Tarawa|Pacific/Majuro",
|
|
5836
5836
|
"Pacific/Tarawa|Pacific/Wake",
|
|
5837
5837
|
"Pacific/Tarawa|Pacific/Wallis"
|
|
5838
|
-
],
|
|
5838
|
+
], $2 = [
|
|
5839
5839
|
"AD|Europe/Andorra",
|
|
5840
5840
|
"AE|Asia/Dubai",
|
|
5841
5841
|
"AF|Asia/Kabul",
|
|
@@ -6084,16 +6084,16 @@ const Q2 = "2025a", $2 = [
|
|
|
6084
6084
|
"ZM|Africa/Maputo Africa/Lusaka",
|
|
6085
6085
|
"ZW|Africa/Maputo Africa/Harare"
|
|
6086
6086
|
], MM = {
|
|
6087
|
-
version:
|
|
6088
|
-
zones:
|
|
6087
|
+
version: Y2,
|
|
6088
|
+
zones: V2,
|
|
6089
6089
|
links: Z2,
|
|
6090
|
-
countries:
|
|
6090
|
+
countries: $2
|
|
6091
6091
|
};
|
|
6092
|
-
var bM =
|
|
6092
|
+
var bM = _0.exports = J2;
|
|
6093
6093
|
bM.tz.load(MM);
|
|
6094
|
-
var zM =
|
|
6095
|
-
const _0 = /* @__PURE__ */ K2(zM);
|
|
6096
|
-
const
|
|
6094
|
+
var zM = _0.exports;
|
|
6095
|
+
const E0 = /* @__PURE__ */ K2(zM), pM = "data:image/gif;base64,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";
|
|
6096
|
+
const OM = {
|
|
6097
6097
|
name: "IdmPoint",
|
|
6098
6098
|
components: { LocationFilled: G2 },
|
|
6099
6099
|
props: {
|
|
@@ -6120,8 +6120,9 @@ const pM = {
|
|
|
6120
6120
|
data() {
|
|
6121
6121
|
return {
|
|
6122
6122
|
showMeteo: !1,
|
|
6123
|
+
loading: !1,
|
|
6123
6124
|
point: {},
|
|
6124
|
-
meteoTime:
|
|
6125
|
+
meteoTime: G().utc().format(),
|
|
6125
6126
|
meteoData: void 0,
|
|
6126
6127
|
tableData: {
|
|
6127
6128
|
hours: [void 0, void 0, void 0, void 0, void 0, void 0, void 0, void 0],
|
|
@@ -6171,7 +6172,7 @@ const pM = {
|
|
|
6171
6172
|
handler() {
|
|
6172
6173
|
var z;
|
|
6173
6174
|
if (this.showMeteo = !0, this.showMeteo && this.ts && this.meteoTime) {
|
|
6174
|
-
const M = Math.ceil((z =
|
|
6175
|
+
const M = Math.ceil((z = G(this.ts)) == null ? void 0 : z.diff(G(), "d", !0)), b = M > 0 ? 15 - M : 15;
|
|
6175
6176
|
this.fetchMeteoData(this.point, this.ts, b);
|
|
6176
6177
|
}
|
|
6177
6178
|
}
|
|
@@ -6180,11 +6181,11 @@ const pM = {
|
|
|
6180
6181
|
handler() {
|
|
6181
6182
|
var z, M;
|
|
6182
6183
|
if (this.showMeteo && this.ts && this.meteoTime) {
|
|
6183
|
-
const b = (z =
|
|
6184
|
+
const b = (z = G(this.ts)) == null ? void 0 : z.diff(G(this.meteoTime), "d", !0);
|
|
6184
6185
|
if (b >= 0 && b <= 14)
|
|
6185
6186
|
this.meteoData && this.initTableData(this.meteoData);
|
|
6186
6187
|
else if (b > 14) {
|
|
6187
|
-
const O = Math.ceil((M =
|
|
6188
|
+
const O = Math.ceil((M = G(this.ts)) == null ? void 0 : M.diff(G(), "d", !0));
|
|
6188
6189
|
if (O <= 15) {
|
|
6189
6190
|
const p = O > 0 ? 15 - O : 15;
|
|
6190
6191
|
this.fetchMeteoData(this.point, this.ts, p);
|
|
@@ -6199,27 +6200,27 @@ const pM = {
|
|
|
6199
6200
|
computed: {
|
|
6200
6201
|
computeHourL() {
|
|
6201
6202
|
return function(z) {
|
|
6202
|
-
return z ? `${
|
|
6203
|
+
return z ? `${E0(z).tz(this.positionGmt).format("HH")}` : "-";
|
|
6203
6204
|
};
|
|
6204
6205
|
},
|
|
6205
6206
|
computeHourZ() {
|
|
6206
6207
|
return function(z) {
|
|
6207
|
-
return z ? `${
|
|
6208
|
+
return z ? `${G(z).utc().format("HH")}Z` : "-";
|
|
6208
6209
|
};
|
|
6209
6210
|
},
|
|
6210
6211
|
computeLat() {
|
|
6211
6212
|
return function(z, M = 4) {
|
|
6212
|
-
return
|
|
6213
|
+
return b0.lat2pretty(z, M).pretty;
|
|
6213
6214
|
};
|
|
6214
6215
|
},
|
|
6215
6216
|
computeLng() {
|
|
6216
6217
|
return function(z, M = 4) {
|
|
6217
|
-
return
|
|
6218
|
+
return b0.lng2pretty(z, M).pretty;
|
|
6218
6219
|
};
|
|
6219
6220
|
},
|
|
6220
6221
|
roundPrecision() {
|
|
6221
6222
|
return function(z, M = 4) {
|
|
6222
|
-
return isNaN(z) ? "-" :
|
|
6223
|
+
return isNaN(z) ? "-" : b0.roundPrecision(z, M);
|
|
6223
6224
|
};
|
|
6224
6225
|
}
|
|
6225
6226
|
},
|
|
@@ -6227,49 +6228,50 @@ const pM = {
|
|
|
6227
6228
|
},
|
|
6228
6229
|
methods: {
|
|
6229
6230
|
async fetchMeteoData(z, M, b) {
|
|
6230
|
-
this.point = z, this.clearTable(), this.tableData.hours = [void 0, void 0, void 0, void 0, void 0, void 0, void 0, void 0], this.handleRender();
|
|
6231
|
-
let O = M ?
|
|
6231
|
+
this.point = z, this.loading = !0, this.clearTable(), this.tableData.hours = [void 0, void 0, void 0, void 0, void 0, void 0, void 0, void 0], this.handleRender();
|
|
6232
|
+
let O = M ? G(M).utc().format() : G().utc().format(), p = {
|
|
6232
6233
|
lat: z.lat,
|
|
6233
6234
|
lng: z.lng,
|
|
6234
6235
|
datetime: O,
|
|
6235
6236
|
forecastDays: b ?? 15
|
|
6236
6237
|
// selfHosted: false
|
|
6237
|
-
}, o = await
|
|
6238
|
+
}, o = await N0.post(`${this.gateway}/api/arc/meteo2/spot/forecast`, p, {
|
|
6238
6239
|
headers: {
|
|
6239
6240
|
Authorization: this.token || this.defaultMeteoToken
|
|
6240
6241
|
}
|
|
6241
6242
|
});
|
|
6242
|
-
(o == null ? void 0 : o.data.code) === 0 ? (this.meteoData = o == null ? void 0 : o.data.data, this.meteoTime = O, this.initTableData(this.meteoData)) : (this.
|
|
6243
|
+
(o == null ? void 0 : o.data.code) === 0 ? (this.meteoData = o == null ? void 0 : o.data.data, this.meteoTime = O, this.loading = !1, this.initTableData(this.meteoData)) : (this.loading = !1, this.tableData.hours = [void 0, void 0, void 0, void 0, void 0, void 0, void 0, void 0], this.handleRender()), G(this.startTs).diff(G(), "d", !0) < -1 && (O = M ? G(M).add(-14, "d").utc().format() : G().utc().format(), p = {
|
|
6243
6244
|
lat: z.lat,
|
|
6244
6245
|
lng: z.lng,
|
|
6245
6246
|
datetime: O,
|
|
6246
6247
|
forecastDays: 15
|
|
6247
|
-
}, o = await
|
|
6248
|
+
}, o = await N0.post(`${this.gateway}/api/arc/meteo2/spot/forecast`, p, {
|
|
6248
6249
|
headers: {
|
|
6249
6250
|
Authorization: this.token || this.defaultMeteoToken
|
|
6250
6251
|
}
|
|
6251
6252
|
}), (o == null ? void 0 : o.data.code) === 0 && (this.historyMeteoData = o == null ? void 0 : o.data.data));
|
|
6252
6253
|
},
|
|
6253
6254
|
initTableData(z) {
|
|
6254
|
-
var b, O, p, o
|
|
6255
|
-
this.clearTable(), this.currentHourData = ((
|
|
6256
|
-
|
|
6257
|
-
|
|
6258
|
-
|
|
6259
|
-
|
|
6260
|
-
|
|
6261
|
-
|
|
6262
|
-
|
|
6263
|
-
|
|
6264
|
-
|
|
6265
|
-
|
|
6266
|
-
|
|
6267
|
-
|
|
6268
|
-
|
|
6255
|
+
var M, b, O, p, o;
|
|
6256
|
+
this.clearTable(), this.currentHourData = ((M = k0.pickHourly(z, this.ts ? G(this.ts) : G())) == null ? void 0 : M[0]) || {}, this.positionGmt = (O = (b = z == null ? void 0 : z.weather) == null ? void 0 : b[0]) == null ? void 0 : O.timezone, this.localDate = (o = (p = E0(this.ts)) == null ? void 0 : p.tz(this.positionGmt)) == null ? void 0 : o.format("MMM-DD/HHmm[LT]"), this.$nextTick(() => {
|
|
6257
|
+
var t, q, r, a, i, L, n, h, u, d, m, R, X, E, y, _, J, Z, M0, N, x, d0, s0, r0, L0, o0, h0, m0, W0, n0, l0, B0, f0, S, p0, a0, D, O0, u0;
|
|
6258
|
+
const A = document.getElementById("meteoMainBox");
|
|
6259
|
+
if (A.className = "main-box", A.style.backgroundImage = null, A.style.backgroundPosition = "top left", ((q = (t = this.currentHourData) == null ? void 0 : t.weather) == null ? void 0 : q.code) === 0 && ((a = (r = this.currentHourData) == null ? void 0 : r.weather) == null ? void 0 : a.isDay) === 0)
|
|
6260
|
+
A.className = "main-box night-bg";
|
|
6261
|
+
else {
|
|
6262
|
+
const A0 = (L = (i = this.currentHourData) == null ? void 0 : i.weather) == null ? void 0 : L.bg;
|
|
6263
|
+
A0 ? (A.className = "main-box font-color-white", A.style.backgroundImage = `url(${A0})`, (A0 === "https://osshz.idmwx.com/asset/weather/bg2.png" || A0 === "https://osshz.idmwx.com/asset/weather/bg5.png") && (A.style.backgroundPosition = "right bottom")) : A.className = "main-box day-bg";
|
|
6264
|
+
}
|
|
6265
|
+
for (let A0 = 0; A0 < 8; A0++) {
|
|
6266
|
+
const R0 = E0(this.ts).tz(this.positionGmt).add(3 * A0, "h").format();
|
|
6267
|
+
this.tableData.hours.push(R0);
|
|
6268
|
+
const g = ((n = k0.pickHourly(z, R0)) == null ? void 0 : n[0]) || {};
|
|
6269
|
+
this.tableData.temp.push(this.roundPrecision((h = g == null ? void 0 : g.weather) == null ? void 0 : h.temp, 0) ?? "-"), this.tableData.precipProbability.push(this.roundPrecision((d = (u = g == null ? void 0 : g.weather) == null ? void 0 : u.precip) == null ? void 0 : d.probability, 0) ?? "-"), this.tableData.precip1h.push(this.roundPrecision((R = (m = g == null ? void 0 : g.weather) == null ? void 0 : m.precip) == null ? void 0 : R.sum, 0) ?? "-"), this.tableData.visibility.push(this.roundPrecision((X = g == null ? void 0 : g.weather) == null ? void 0 : X.visibility, 0) ?? "-"), this.tableData.windSpeed.push(this.roundPrecision((y = (E = g == null ? void 0 : g.weather) == null ? void 0 : E.wind) == null ? void 0 : y.kts, 1) ?? "-"), this.tableData.windDir.push((J = (_ = g == null ? void 0 : g.weather) == null ? void 0 : _.wind) == null ? void 0 : J.bearing), this.tableData.windGust.push(this.roundPrecision((M0 = (Z = g == null ? void 0 : g.weather) == null ? void 0 : Z.wind) == null ? void 0 : M0.gusts, 1) ?? "-"), this.tableData.sigwaveHeight.push(this.roundPrecision((x = (N = g == null ? void 0 : g.wave) == null ? void 0 : N.sig) == null ? void 0 : x.height, 1) ?? "-"), this.tableData.sigwaveDir.push((s0 = (d0 = g == null ? void 0 : g.wave) == null ? void 0 : d0.sig) == null ? void 0 : s0.bearing), this.tableData.windwaveHeight.push(this.roundPrecision((L0 = (r0 = g == null ? void 0 : g.wave) == null ? void 0 : r0.wd) == null ? void 0 : L0.height, 1) ?? "-"), this.tableData.windwaveDir.push((h0 = (o0 = g == null ? void 0 : g.wave) == null ? void 0 : o0.wd) == null ? void 0 : h0.bearing), this.tableData.windwavePeriod.push(this.roundPrecision((W0 = (m0 = g == null ? void 0 : g.wave) == null ? void 0 : m0.wd) == null ? void 0 : W0.period, 1) ?? "-"), this.tableData.swellHeight.push(this.roundPrecision((l0 = (n0 = g == null ? void 0 : g.wave) == null ? void 0 : n0.swell) == null ? void 0 : l0.height, 1) ?? "-"), this.tableData.swellDir.push((f0 = (B0 = g == null ? void 0 : g.wave) == null ? void 0 : B0.swell) == null ? void 0 : f0.bearing), this.tableData.swellPeriod.push(this.roundPrecision((p0 = (S = g == null ? void 0 : g.wave) == null ? void 0 : S.swell) == null ? void 0 : p0.period, 1) ?? "-"), this.tableData.currentSpeed.push(this.roundPrecision((a0 = g == null ? void 0 : g.current) == null ? void 0 : a0.speed, 1) ?? "-"), this.tableData.currentDir.push((D = g == null ? void 0 : g.current) == null ? void 0 : D.bearing), this.tableData.seaLevel.push(this.roundPrecision(g == null ? void 0 : g.height, 1) ?? "-"), this.tableData.seaTemp.push(this.roundPrecision(g == null ? void 0 : g.sst, 0) ?? "-"), this.tableData.weatherUrls.push((O0 = g == null ? void 0 : g.weather) == null ? void 0 : O0.url), this.tableData.weatherNames.push(((u0 = g == null ? void 0 : g.weather) == null ? void 0 : u0.name) ?? "-");
|
|
6270
|
+
}
|
|
6271
|
+
});
|
|
6269
6272
|
},
|
|
6270
6273
|
clearTable() {
|
|
6271
|
-
|
|
6272
|
-
z.className = "main-box", z.style.backgroundImage = null, z.style.backgroundPosition = "top left", this.currentHourData = {}, this.positionGmt = void 0, this.localDate = void 0, this.tableData = {
|
|
6274
|
+
this.currentHourData = {}, this.positionGmt = void 0, this.localDate = void 0, this.tableData = {
|
|
6273
6275
|
hours: [],
|
|
6274
6276
|
weatherUrls: [],
|
|
6275
6277
|
weatherNames: [],
|
|
@@ -6318,135 +6320,143 @@ const pM = {
|
|
|
6318
6320
|
this.$nextTick(() => {
|
|
6319
6321
|
var M;
|
|
6320
6322
|
const z = document.getElementById("point-meteo");
|
|
6321
|
-
this.point && (this.meteoMarker ? (M = this.meteoMarker) == null || M.setLngLat([this.point.lng, this.point.lat]) : this.meteoMarker = new
|
|
6323
|
+
this.point && (this.meteoMarker ? (M = this.meteoMarker) == null || M.setLngLat([this.point.lng, this.point.lat]) : this.meteoMarker = new w0.Marker(z).setLngLat([this.point.lng, this.point.lat]).addTo(this.map));
|
|
6322
6324
|
});
|
|
6323
6325
|
}
|
|
6324
6326
|
}
|
|
6325
|
-
},
|
|
6327
|
+
}, oM = {
|
|
6326
6328
|
id: "point-meteo",
|
|
6327
6329
|
class: "point-meteo"
|
|
6328
|
-
},
|
|
6330
|
+
}, cM = { class: "meteo-box" }, AM = { class: "header-box flex-between" }, eM = { class: "flex-center" }, tM = { class: "lnglat" }, aM = {
|
|
6331
|
+
key: 0,
|
|
6329
6332
|
class: "main-box",
|
|
6330
6333
|
id: "meteoMainBox"
|
|
6331
|
-
},
|
|
6334
|
+
}, qM = { class: "summary-row flex-between" }, iM = { class: "summary flex-center" }, rM = ["src"], nM = {
|
|
6332
6335
|
key: 1,
|
|
6333
6336
|
class: "icon flex-center",
|
|
6334
6337
|
style: { "margin-right": "5px" }
|
|
6335
|
-
},
|
|
6336
|
-
|
|
6337
|
-
|
|
6338
|
-
|
|
6339
|
-
|
|
6340
|
-
|
|
6341
|
-
|
|
6342
|
-
|
|
6338
|
+
}, dM = { class: "temp" }, sM = { class: "des info" }, WM = { class: "flex-start" }, lM = { class: "flex-start" }, fM = { class: "flex-start" }, uM = { class: "date flex-col-center-end" }, LM = { class: "" }, RM = { class: "" }, hM = { class: "detail-box" }, mM = { class: "menu-header flex-start" }, BM = { class: "basic-table" }, gM = { class: "hour" }, NM = { class: "hour" }, yM = { class: "icon" }, XM = ["src"], wM = { class: "text" }, CM = { class: "text" }, vM = { class: "text" }, TM = { class: "text" }, EM = { class: "wave-current-table" }, xM = { class: "hour" }, IM = { class: "hour" }, DM = { class: "icon" }, PM = ["src"], SM = { class: "text" }, kM = { class: "text" }, QM = { class: "text" }, HM = { class: "text" }, _M = { class: "sea-table" }, jM = { class: "hour" }, FM = { class: "hour" }, GM = { class: "icon" }, UM = ["src"], KM = { class: "text" }, JM = { class: "text" }, YM = { class: "text" }, VM = { class: "text" }, ZM = {
|
|
6339
|
+
key: 1,
|
|
6340
|
+
class: "main-box flex-center"
|
|
6341
|
+
};
|
|
6342
|
+
function $M(z, M, b, O, p, o) {
|
|
6343
|
+
var r, a, i, L, n, h, u, d, m, R, X, E, y, _, J, Z, M0;
|
|
6344
|
+
const A = I("LocationFilled"), t = I("ElIcon"), q = I("ElTooltip");
|
|
6345
|
+
return s(), W("div", null, [
|
|
6346
|
+
y0(c("div", oM, [
|
|
6347
|
+
c("div", cM, [
|
|
6348
|
+
c("div", AM, [
|
|
6343
6349
|
c("div", eM, [
|
|
6344
|
-
|
|
6345
|
-
default:
|
|
6346
|
-
|
|
6350
|
+
C(t, { size: "22" }, {
|
|
6351
|
+
default: t0(() => [
|
|
6352
|
+
C(A)
|
|
6347
6353
|
]),
|
|
6348
6354
|
_: 1
|
|
6349
6355
|
}),
|
|
6350
|
-
c("div",
|
|
6356
|
+
c("div", tM, T(o.computeLat((r = p.point) == null ? void 0 : r.lat)) + "," + T(o.computeLng((a = p.point) == null ? void 0 : a.lng)), 1)
|
|
6351
6357
|
]),
|
|
6352
6358
|
c("div", {
|
|
6353
6359
|
class: "iconfont close",
|
|
6354
|
-
onClick: M[0] || (M[0] = (
|
|
6360
|
+
onClick: M[0] || (M[0] = (N) => p.showMeteo = !1)
|
|
6355
6361
|
}, "")
|
|
6356
6362
|
]),
|
|
6357
|
-
|
|
6358
|
-
c("
|
|
6359
|
-
|
|
6360
|
-
|
|
6363
|
+
p.loading ? (s(), W("div", ZM, M[30] || (M[30] = [
|
|
6364
|
+
c("img", { src: pM }, null, -1)
|
|
6365
|
+
]))) : (s(), W("div", aM, [
|
|
6366
|
+
y0(c("div", qM, [
|
|
6367
|
+
c("div", iM, [
|
|
6368
|
+
C(q, {
|
|
6361
6369
|
placement: "top",
|
|
6362
6370
|
effect: "light",
|
|
6363
6371
|
content: (L = (i = p.currentHourData) == null ? void 0 : i.weather) == null ? void 0 : L.name,
|
|
6364
6372
|
"show-after": 1e3
|
|
6365
6373
|
}, {
|
|
6366
|
-
default:
|
|
6367
|
-
var
|
|
6374
|
+
default: t0(() => {
|
|
6375
|
+
var N, x, d0, s0;
|
|
6368
6376
|
return [
|
|
6369
|
-
(
|
|
6377
|
+
(x = (N = p.currentHourData) == null ? void 0 : N.weather) != null && x.url ? (s(), W("img", {
|
|
6370
6378
|
key: 0,
|
|
6371
6379
|
class: "iconfont icon",
|
|
6372
6380
|
style: { "margin-right": "5px" },
|
|
6373
|
-
src: (
|
|
6374
|
-
}, null, 8,
|
|
6381
|
+
src: (s0 = (d0 = p.currentHourData) == null ? void 0 : d0.weather) == null ? void 0 : s0.url
|
|
6382
|
+
}, null, 8, rM)) : (s(), W("span", nM))
|
|
6375
6383
|
];
|
|
6376
6384
|
}),
|
|
6377
6385
|
_: 1
|
|
6378
6386
|
}, 8, ["content"]),
|
|
6379
|
-
c("div",
|
|
6387
|
+
c("div", dM, [
|
|
6380
6388
|
c("div", null, [
|
|
6381
|
-
|
|
6389
|
+
z0(T(o.roundPrecision((h = (n = p.currentHourData) == null ? void 0 : n.weather) == null ? void 0 : h.temp, 0)), 1),
|
|
6382
6390
|
M[4] || (M[4] = c("span", { style: { "font-size": "14px" } }, "°C", -1))
|
|
6383
6391
|
])
|
|
6384
6392
|
]),
|
|
6385
|
-
c("div",
|
|
6393
|
+
c("div", sM, [
|
|
6386
6394
|
c("div", WM, [
|
|
6387
6395
|
M[5] || (M[5] = c("label", null, "Precip : ", -1)),
|
|
6388
|
-
c("span", null,
|
|
6396
|
+
c("span", null, T(o.roundPrecision((m = (d = (u = p.currentHourData) == null ? void 0 : u.weather) == null ? void 0 : d.precip) == null ? void 0 : m.sum, 0)) + " mm", 1)
|
|
6389
6397
|
]),
|
|
6390
|
-
c("div",
|
|
6398
|
+
c("div", lM, [
|
|
6391
6399
|
M[6] || (M[6] = c("label", null, "Visibility : ", -1)),
|
|
6392
|
-
c("span", null,
|
|
6400
|
+
c("span", null, T(o.roundPrecision((X = (R = p.currentHourData) == null ? void 0 : R.weather) == null ? void 0 : X.visibility, 0)) + " nm", 1)
|
|
6393
6401
|
]),
|
|
6394
|
-
c("div",
|
|
6402
|
+
c("div", fM, [
|
|
6395
6403
|
M[7] || (M[7] = c("label", null, "Wind : ", -1)),
|
|
6396
|
-
c("span", null,
|
|
6404
|
+
c("span", null, T(o.roundPrecision((_ = (y = (E = p.currentHourData) == null ? void 0 : E.weather) == null ? void 0 : y.wind) == null ? void 0 : _.kts, 1)) + " kts", 1)
|
|
6397
6405
|
])
|
|
6398
6406
|
])
|
|
6399
6407
|
]),
|
|
6400
|
-
c("div",
|
|
6401
|
-
c("div",
|
|
6402
|
-
c("div",
|
|
6408
|
+
c("div", uM, [
|
|
6409
|
+
c("div", LM, T(p.localDate), 1),
|
|
6410
|
+
c("div", RM, T(p.positionGmt), 1)
|
|
6403
6411
|
])
|
|
6412
|
+
], 512), [
|
|
6413
|
+
[X0, (J = p.currentHourData) == null ? void 0 : J.weather]
|
|
6404
6414
|
]),
|
|
6405
|
-
c("div",
|
|
6406
|
-
c("div",
|
|
6415
|
+
y0(c("div", hM, [
|
|
6416
|
+
c("div", mM, [
|
|
6407
6417
|
c("div", {
|
|
6408
|
-
class:
|
|
6409
|
-
onClick: M[1] || (M[1] =
|
|
6418
|
+
class: V(["menu-item", p.activeIndex === 1 ? "active" : ""]),
|
|
6419
|
+
onClick: M[1] || (M[1] = T0((N) => o.handleSelectTab(1), ["prevent"]))
|
|
6410
6420
|
}, "Basis", 2),
|
|
6411
6421
|
c("div", {
|
|
6412
|
-
class:
|
|
6413
|
-
onClick: M[2] || (M[2] =
|
|
6422
|
+
class: V(["menu-item", p.activeIndex === 2 ? "active" : ""]),
|
|
6423
|
+
onClick: M[2] || (M[2] = T0((N) => o.handleSelectTab(2), ["prevent"]))
|
|
6414
6424
|
}, "Wave & Current", 2),
|
|
6415
6425
|
c("div", {
|
|
6416
|
-
class:
|
|
6417
|
-
onClick: M[3] || (M[3] =
|
|
6426
|
+
class: V(["menu-item", p.activeIndex === 3 ? "active" : ""]),
|
|
6427
|
+
onClick: M[3] || (M[3] = T0((N) => o.handleSelectTab(3), ["prevent"]))
|
|
6418
6428
|
}, "Sea Surface", 2)
|
|
6419
6429
|
]),
|
|
6420
|
-
|
|
6421
|
-
c("tr",
|
|
6430
|
+
y0(c("table", BM, [
|
|
6431
|
+
c("tr", gM, [
|
|
6422
6432
|
M[8] || (M[8] = c("th", {
|
|
6423
6433
|
rowspan: "1",
|
|
6424
6434
|
colspan: "1",
|
|
6425
6435
|
class: "tr-title"
|
|
6426
6436
|
}, [
|
|
6427
|
-
|
|
6437
|
+
z0("Hours"),
|
|
6428
6438
|
c("span", { class: "unit" }, "(LT)")
|
|
6429
6439
|
], -1)),
|
|
6430
|
-
(
|
|
6440
|
+
(s(!0), W(F, null, K(p.tableData.hours, (N) => (s(), W("th", {
|
|
6431
6441
|
rowspan: "1",
|
|
6432
6442
|
colspan: "1",
|
|
6433
6443
|
key: Math.random()
|
|
6434
|
-
},
|
|
6444
|
+
}, T(o.computeHourL(N)), 1))), 128))
|
|
6435
6445
|
]),
|
|
6436
|
-
c("tr",
|
|
6446
|
+
c("tr", NM, [
|
|
6437
6447
|
M[9] || (M[9] = c("th", {
|
|
6438
6448
|
rowspan: "1",
|
|
6439
6449
|
colspan: "1",
|
|
6440
6450
|
class: "tr-title"
|
|
6441
6451
|
}, [
|
|
6442
|
-
|
|
6452
|
+
z0("UTC"),
|
|
6443
6453
|
c("span", { class: "unit" })
|
|
6444
6454
|
], -1)),
|
|
6445
|
-
(
|
|
6455
|
+
(s(!0), W(F, null, K(p.tableData.hours, (N) => (s(), W("th", {
|
|
6446
6456
|
rowspan: "1",
|
|
6447
6457
|
colspan: "1",
|
|
6448
6458
|
key: Math.random()
|
|
6449
|
-
},
|
|
6459
|
+
}, T(o.computeHourZ(N)), 1))), 128))
|
|
6450
6460
|
]),
|
|
6451
6461
|
c("tr", yM, [
|
|
6452
6462
|
M[10] || (M[10] = c("th", {
|
|
@@ -6454,176 +6464,176 @@ function JM(z, M, b, O, p, o) {
|
|
|
6454
6464
|
colspan: "1",
|
|
6455
6465
|
class: "tr-title"
|
|
6456
6466
|
}, null, -1)),
|
|
6457
|
-
(
|
|
6467
|
+
(s(!0), W(F, null, K(p.tableData.weatherUrls, (N, x) => (s(), W("th", {
|
|
6458
6468
|
rowspan: "1",
|
|
6459
6469
|
colspan: "1",
|
|
6460
6470
|
key: Math.random()
|
|
6461
6471
|
}, [
|
|
6462
|
-
|
|
6472
|
+
C(q, {
|
|
6463
6473
|
placement: "top",
|
|
6464
6474
|
effect: "light",
|
|
6465
|
-
content: p.tableData.weatherNames[
|
|
6475
|
+
content: p.tableData.weatherNames[x],
|
|
6466
6476
|
"show-after": 500
|
|
6467
6477
|
}, {
|
|
6468
|
-
default:
|
|
6469
|
-
|
|
6478
|
+
default: t0(() => [
|
|
6479
|
+
N ? (s(), W("img", {
|
|
6470
6480
|
key: 0,
|
|
6471
6481
|
class: "iconfont weather-icon",
|
|
6472
|
-
src:
|
|
6473
|
-
}, null, 8,
|
|
6482
|
+
src: N
|
|
6483
|
+
}, null, 8, XM)) : j("", !0)
|
|
6474
6484
|
]),
|
|
6475
6485
|
_: 2
|
|
6476
6486
|
}, 1032, ["content"])
|
|
6477
6487
|
]))), 128))
|
|
6478
6488
|
]),
|
|
6479
|
-
c("tr",
|
|
6489
|
+
c("tr", wM, [
|
|
6480
6490
|
M[11] || (M[11] = c("td", {
|
|
6481
6491
|
rowspan: "1",
|
|
6482
6492
|
colspan: "1",
|
|
6483
6493
|
class: "tr-title"
|
|
6484
6494
|
}, [
|
|
6485
|
-
|
|
6495
|
+
z0("Temp"),
|
|
6486
6496
|
c("span", { class: "unit" }, "°C")
|
|
6487
6497
|
], -1)),
|
|
6488
|
-
(
|
|
6498
|
+
(s(!0), W(F, null, K(p.tableData.temp, (N) => (s(), W("td", {
|
|
6489
6499
|
rowspan: "1",
|
|
6490
6500
|
colspan: "1",
|
|
6491
6501
|
key: Math.random()
|
|
6492
|
-
},
|
|
6502
|
+
}, T(N), 1))), 128))
|
|
6493
6503
|
]),
|
|
6494
|
-
c("tr",
|
|
6504
|
+
c("tr", CM, [
|
|
6495
6505
|
M[12] || (M[12] = c("td", {
|
|
6496
6506
|
rowspan: "1",
|
|
6497
6507
|
colspan: "1",
|
|
6498
6508
|
class: "tr-title"
|
|
6499
6509
|
}, [
|
|
6500
|
-
|
|
6510
|
+
z0("Precip"),
|
|
6501
6511
|
c("span", { class: "unit" }, "mm")
|
|
6502
6512
|
], -1)),
|
|
6503
|
-
(
|
|
6513
|
+
(s(!0), W(F, null, K(p.tableData.precip1h, (N) => (s(), W("td", {
|
|
6504
6514
|
rowspan: "1",
|
|
6505
6515
|
colspan: "1",
|
|
6506
6516
|
key: Math.random()
|
|
6507
|
-
},
|
|
6517
|
+
}, T(N), 1))), 128))
|
|
6508
6518
|
]),
|
|
6509
|
-
c("tr",
|
|
6519
|
+
c("tr", vM, [
|
|
6510
6520
|
M[13] || (M[13] = c("td", {
|
|
6511
6521
|
rowspan: "1",
|
|
6512
6522
|
colspan: "1",
|
|
6513
6523
|
class: "tr-title"
|
|
6514
6524
|
}, [
|
|
6515
|
-
|
|
6525
|
+
z0("Visibility"),
|
|
6516
6526
|
c("span", { class: "unit" }, "nm")
|
|
6517
6527
|
], -1)),
|
|
6518
|
-
(
|
|
6528
|
+
(s(!0), W(F, null, K(p.tableData.visibility, (N) => (s(), W("td", {
|
|
6519
6529
|
rowspan: "1",
|
|
6520
6530
|
colspan: "1",
|
|
6521
6531
|
key: Math.random()
|
|
6522
|
-
},
|
|
6532
|
+
}, T(N), 1))), 128))
|
|
6523
6533
|
]),
|
|
6524
|
-
c("tr",
|
|
6534
|
+
c("tr", TM, [
|
|
6525
6535
|
M[14] || (M[14] = c("td", {
|
|
6526
6536
|
rowspan: "1",
|
|
6527
6537
|
colspan: "1",
|
|
6528
6538
|
class: "tr-title"
|
|
6529
6539
|
}, [
|
|
6530
|
-
|
|
6540
|
+
z0("Wind"),
|
|
6531
6541
|
c("span", { class: "unit" }, "kts")
|
|
6532
6542
|
], -1)),
|
|
6533
|
-
(
|
|
6543
|
+
(s(!0), W(F, null, K(p.tableData.windSpeed, (N, x) => (s(), W("td", {
|
|
6534
6544
|
rowspan: "1",
|
|
6535
6545
|
colspan: "1",
|
|
6536
6546
|
key: Math.random()
|
|
6537
6547
|
}, [
|
|
6538
|
-
isNaN(p.tableData.windDir[
|
|
6548
|
+
isNaN(p.tableData.windDir[x]) ? j("", !0) : (s(), W("span", {
|
|
6539
6549
|
key: 0,
|
|
6540
6550
|
class: "iconfont icon blue",
|
|
6541
|
-
style:
|
|
6551
|
+
style: c0({ display: "inline-block", transform: `rotate(${p.tableData.windDir[x]}deg)` })
|
|
6542
6552
|
}, "", 4)),
|
|
6543
|
-
c("span", null,
|
|
6553
|
+
c("span", null, T(N), 1)
|
|
6544
6554
|
]))), 128))
|
|
6545
6555
|
])
|
|
6546
6556
|
], 512), [
|
|
6547
|
-
[
|
|
6557
|
+
[X0, p.activeIndex === 1]
|
|
6548
6558
|
]),
|
|
6549
|
-
|
|
6550
|
-
c("tr",
|
|
6559
|
+
y0(c("table", EM, [
|
|
6560
|
+
c("tr", xM, [
|
|
6551
6561
|
M[15] || (M[15] = c("th", {
|
|
6552
6562
|
rowspan: "1",
|
|
6553
6563
|
colspan: "1",
|
|
6554
6564
|
class: "tr-title"
|
|
6555
6565
|
}, [
|
|
6556
|
-
|
|
6566
|
+
z0("Hours"),
|
|
6557
6567
|
c("span", { class: "unit" }, "(LT)")
|
|
6558
6568
|
], -1)),
|
|
6559
|
-
(
|
|
6569
|
+
(s(!0), W(F, null, K(p.tableData.hours, (N) => (s(), W("th", {
|
|
6560
6570
|
rowspan: "1",
|
|
6561
6571
|
colspan: "1",
|
|
6562
6572
|
key: Math.random()
|
|
6563
|
-
},
|
|
6573
|
+
}, T(o.computeHourL(N)), 1))), 128))
|
|
6564
6574
|
]),
|
|
6565
|
-
c("tr",
|
|
6575
|
+
c("tr", IM, [
|
|
6566
6576
|
M[16] || (M[16] = c("th", {
|
|
6567
6577
|
rowspan: "1",
|
|
6568
6578
|
colspan: "1",
|
|
6569
6579
|
class: "tr-title"
|
|
6570
6580
|
}, [
|
|
6571
|
-
|
|
6581
|
+
z0("UTC"),
|
|
6572
6582
|
c("span", { class: "unit" })
|
|
6573
6583
|
], -1)),
|
|
6574
|
-
(
|
|
6584
|
+
(s(!0), W(F, null, K(p.tableData.hours, (N) => (s(), W("th", {
|
|
6575
6585
|
rowspan: "1",
|
|
6576
6586
|
colspan: "1",
|
|
6577
6587
|
key: Math.random()
|
|
6578
|
-
},
|
|
6588
|
+
}, T(o.computeHourZ(N)), 1))), 128))
|
|
6579
6589
|
]),
|
|
6580
|
-
c("tr",
|
|
6590
|
+
c("tr", DM, [
|
|
6581
6591
|
M[17] || (M[17] = c("th", {
|
|
6582
6592
|
rowspan: "1",
|
|
6583
6593
|
colspan: "1"
|
|
6584
6594
|
}, null, -1)),
|
|
6585
|
-
(
|
|
6595
|
+
(s(!0), W(F, null, K(p.tableData.weatherUrls, (N, x) => (s(), W("th", {
|
|
6586
6596
|
rowspan: "1",
|
|
6587
6597
|
colspan: "1",
|
|
6588
6598
|
key: Math.random()
|
|
6589
6599
|
}, [
|
|
6590
|
-
|
|
6600
|
+
C(q, {
|
|
6591
6601
|
placement: "top",
|
|
6592
6602
|
effect: "light",
|
|
6593
|
-
content: p.tableData.weatherNames[
|
|
6603
|
+
content: p.tableData.weatherNames[x],
|
|
6594
6604
|
"show-after": 500
|
|
6595
6605
|
}, {
|
|
6596
|
-
default:
|
|
6597
|
-
|
|
6606
|
+
default: t0(() => [
|
|
6607
|
+
N ? (s(), W("img", {
|
|
6598
6608
|
key: 0,
|
|
6599
6609
|
class: "iconfont weather-icon",
|
|
6600
|
-
src:
|
|
6601
|
-
}, null, 8,
|
|
6610
|
+
src: N
|
|
6611
|
+
}, null, 8, PM)) : j("", !0)
|
|
6602
6612
|
]),
|
|
6603
6613
|
_: 2
|
|
6604
6614
|
}, 1032, ["content"])
|
|
6605
6615
|
]))), 128))
|
|
6606
6616
|
]),
|
|
6607
|
-
c("tr",
|
|
6617
|
+
c("tr", SM, [
|
|
6608
6618
|
M[18] || (M[18] = c("td", {
|
|
6609
6619
|
rowspan: "1",
|
|
6610
6620
|
colspan: "1",
|
|
6611
6621
|
class: "tr-title"
|
|
6612
6622
|
}, [
|
|
6613
|
-
|
|
6623
|
+
z0("Sig Wave"),
|
|
6614
6624
|
c("span", { class: "unit" }, "m")
|
|
6615
6625
|
], -1)),
|
|
6616
|
-
(
|
|
6626
|
+
(s(!0), W(F, null, K(p.tableData.sigwaveHeight, (N, x) => (s(), W("td", {
|
|
6617
6627
|
rowspan: "1",
|
|
6618
6628
|
colspan: "1",
|
|
6619
6629
|
key: Math.random()
|
|
6620
6630
|
}, [
|
|
6621
|
-
isNaN(p.tableData.sigwaveDir[
|
|
6631
|
+
isNaN(p.tableData.sigwaveDir[x]) ? j("", !0) : (s(), W("span", {
|
|
6622
6632
|
key: 0,
|
|
6623
6633
|
class: "iconfont icon blue",
|
|
6624
|
-
style:
|
|
6634
|
+
style: c0({ display: "inline-block", transform: `rotate(${p.tableData.sigwaveDir[x]}deg)` })
|
|
6625
6635
|
}, "", 4)),
|
|
6626
|
-
c("span", null,
|
|
6636
|
+
c("span", null, T(N), 1)
|
|
6627
6637
|
]))), 128))
|
|
6628
6638
|
]),
|
|
6629
6639
|
c("tr", kM, [
|
|
@@ -6632,85 +6642,85 @@ function JM(z, M, b, O, p, o) {
|
|
|
6632
6642
|
colspan: "1",
|
|
6633
6643
|
class: "tr-title"
|
|
6634
6644
|
}, [
|
|
6635
|
-
|
|
6645
|
+
z0("Wind Wave"),
|
|
6636
6646
|
c("span", { class: "unit" }, "m")
|
|
6637
6647
|
], -1)),
|
|
6638
|
-
(
|
|
6648
|
+
(s(!0), W(F, null, K(p.tableData.windwaveHeight, (N, x) => (s(), W("td", {
|
|
6639
6649
|
rowspan: "1",
|
|
6640
6650
|
colspan: "1",
|
|
6641
6651
|
key: Math.random()
|
|
6642
6652
|
}, [
|
|
6643
|
-
isNaN(p.tableData.sigwaveDir[
|
|
6653
|
+
isNaN(p.tableData.sigwaveDir[x]) ? j("", !0) : (s(), W("span", {
|
|
6644
6654
|
key: 0,
|
|
6645
6655
|
class: "iconfont icon orange",
|
|
6646
|
-
style:
|
|
6656
|
+
style: c0({ display: "inline-block", transform: `rotate(${p.tableData.sigwaveDir[x]}deg)` })
|
|
6647
6657
|
}, "", 4)),
|
|
6648
|
-
c("span", null,
|
|
6658
|
+
c("span", null, T(N), 1)
|
|
6649
6659
|
]))), 128))
|
|
6650
6660
|
]),
|
|
6651
|
-
c("tr",
|
|
6661
|
+
c("tr", QM, [
|
|
6652
6662
|
M[20] || (M[20] = c("td", {
|
|
6653
6663
|
rowspan: "1",
|
|
6654
6664
|
colspan: "1",
|
|
6655
6665
|
class: "tr-title"
|
|
6656
6666
|
}, [
|
|
6657
|
-
|
|
6667
|
+
z0("Swell"),
|
|
6658
6668
|
c("span", { class: "unit" }, "m")
|
|
6659
6669
|
], -1)),
|
|
6660
|
-
(
|
|
6670
|
+
(s(!0), W(F, null, K(p.tableData.swellHeight, (N, x) => (s(), W("td", {
|
|
6661
6671
|
rowspan: "1",
|
|
6662
6672
|
colspan: "1",
|
|
6663
6673
|
key: Math.random()
|
|
6664
6674
|
}, [
|
|
6665
|
-
isNaN(p.tableData.swellDir[
|
|
6675
|
+
isNaN(p.tableData.swellDir[x]) ? j("", !0) : (s(), W("span", {
|
|
6666
6676
|
key: 0,
|
|
6667
6677
|
class: "iconfont icon orange",
|
|
6668
|
-
style:
|
|
6678
|
+
style: c0({ display: "inline-block", transform: `rotate(${p.tableData.swellDir[x]}deg)` })
|
|
6669
6679
|
}, "", 4)),
|
|
6670
|
-
c("span", null,
|
|
6680
|
+
c("span", null, T(N), 1)
|
|
6671
6681
|
]))), 128))
|
|
6672
6682
|
]),
|
|
6673
|
-
c("tr",
|
|
6683
|
+
c("tr", HM, [
|
|
6674
6684
|
M[21] || (M[21] = c("td", {
|
|
6675
6685
|
rowspan: "1",
|
|
6676
6686
|
colspan: "1",
|
|
6677
6687
|
class: "tr-title"
|
|
6678
6688
|
}, [
|
|
6679
|
-
|
|
6689
|
+
z0("Current"),
|
|
6680
6690
|
c("span", { class: "unit" }, "kts")
|
|
6681
6691
|
], -1)),
|
|
6682
|
-
(
|
|
6692
|
+
(s(!0), W(F, null, K(p.tableData.currentSpeed, (N, x) => (s(), W("td", {
|
|
6683
6693
|
rowspan: "1",
|
|
6684
6694
|
colspan: "1",
|
|
6685
6695
|
key: Math.random()
|
|
6686
6696
|
}, [
|
|
6687
|
-
isNaN(p.tableData.currentDir[
|
|
6697
|
+
isNaN(p.tableData.currentDir[x]) ? j("", !0) : (s(), W("span", {
|
|
6688
6698
|
key: 0,
|
|
6689
6699
|
class: "iconfont icon gray",
|
|
6690
6700
|
id: "meteoGrayIcon",
|
|
6691
|
-
style:
|
|
6701
|
+
style: c0({ display: "inline-block", transform: `rotate(${p.tableData.currentDir[x]}deg)` })
|
|
6692
6702
|
}, "", 4)),
|
|
6693
|
-
c("span", null,
|
|
6703
|
+
c("span", null, T(N), 1)
|
|
6694
6704
|
]))), 128))
|
|
6695
6705
|
])
|
|
6696
6706
|
], 512), [
|
|
6697
|
-
[
|
|
6707
|
+
[X0, p.activeIndex === 2]
|
|
6698
6708
|
]),
|
|
6699
|
-
|
|
6700
|
-
c("tr",
|
|
6709
|
+
y0(c("table", _M, [
|
|
6710
|
+
c("tr", jM, [
|
|
6701
6711
|
M[22] || (M[22] = c("th", {
|
|
6702
6712
|
rowspan: "1",
|
|
6703
6713
|
colspan: "1",
|
|
6704
6714
|
class: "tr-title"
|
|
6705
6715
|
}, [
|
|
6706
|
-
|
|
6716
|
+
z0("Hours"),
|
|
6707
6717
|
c("span", { class: "unit" }, "(LT)")
|
|
6708
6718
|
], -1)),
|
|
6709
|
-
(
|
|
6719
|
+
(s(!0), W(F, null, K(p.tableData.hours, (N) => (s(), W("th", {
|
|
6710
6720
|
rowspan: "1",
|
|
6711
6721
|
colspan: "1",
|
|
6712
6722
|
key: Math.random()
|
|
6713
|
-
},
|
|
6723
|
+
}, T(o.computeHourL(N)), 1))), 128))
|
|
6714
6724
|
]),
|
|
6715
6725
|
c("tr", FM, [
|
|
6716
6726
|
M[23] || (M[23] = c("th", {
|
|
@@ -6718,88 +6728,116 @@ function JM(z, M, b, O, p, o) {
|
|
|
6718
6728
|
colspan: "1",
|
|
6719
6729
|
class: "tr-title"
|
|
6720
6730
|
}, [
|
|
6721
|
-
|
|
6731
|
+
z0("UTC"),
|
|
6722
6732
|
c("span", { class: "unit" })
|
|
6723
6733
|
], -1)),
|
|
6724
|
-
(
|
|
6734
|
+
(s(!0), W(F, null, K(p.tableData.hours, (N) => (s(), W("th", {
|
|
6725
6735
|
rowspan: "1",
|
|
6726
6736
|
colspan: "1",
|
|
6727
6737
|
key: Math.random()
|
|
6728
|
-
},
|
|
6738
|
+
}, T(o.computeHourZ(N)), 1))), 128))
|
|
6729
6739
|
]),
|
|
6730
|
-
c("tr",
|
|
6740
|
+
c("tr", GM, [
|
|
6731
6741
|
M[24] || (M[24] = c("th", {
|
|
6732
6742
|
rowspan: "1",
|
|
6733
6743
|
colspan: "1",
|
|
6734
6744
|
class: "tr-title"
|
|
6735
6745
|
}, null, -1)),
|
|
6736
|
-
(
|
|
6746
|
+
(s(!0), W(F, null, K(p.tableData.weatherUrls, (N, x) => (s(), W("th", {
|
|
6737
6747
|
rowspan: "1",
|
|
6738
6748
|
colspan: "1",
|
|
6739
6749
|
key: Math.random()
|
|
6740
6750
|
}, [
|
|
6741
|
-
|
|
6751
|
+
C(q, {
|
|
6742
6752
|
placement: "top",
|
|
6743
6753
|
effect: "light",
|
|
6744
|
-
content: p.tableData.weatherNames[
|
|
6754
|
+
content: p.tableData.weatherNames[x],
|
|
6745
6755
|
"show-after": 500
|
|
6746
6756
|
}, {
|
|
6747
|
-
default:
|
|
6748
|
-
|
|
6757
|
+
default: t0(() => [
|
|
6758
|
+
N ? (s(), W("img", {
|
|
6749
6759
|
key: 0,
|
|
6750
6760
|
class: "iconfont weather-icon",
|
|
6751
|
-
src:
|
|
6752
|
-
}, null, 8,
|
|
6761
|
+
src: N
|
|
6762
|
+
}, null, 8, UM)) : j("", !0)
|
|
6753
6763
|
]),
|
|
6754
6764
|
_: 2
|
|
6755
6765
|
}, 1032, ["content"])
|
|
6756
6766
|
]))), 128))
|
|
6757
6767
|
]),
|
|
6758
|
-
c("tr",
|
|
6768
|
+
c("tr", KM, [
|
|
6759
6769
|
M[25] || (M[25] = c("td", {
|
|
6760
6770
|
rowspan: "1",
|
|
6761
6771
|
colspan: "1",
|
|
6762
6772
|
class: "tr-title"
|
|
6763
6773
|
}, [
|
|
6764
|
-
|
|
6774
|
+
z0("SeaLevel"),
|
|
6765
6775
|
c("span", { class: "unit" }, "m")
|
|
6766
6776
|
], -1)),
|
|
6767
|
-
(
|
|
6777
|
+
(s(!0), W(F, null, K(p.tableData.seaLevel, (N) => (s(), W("td", {
|
|
6768
6778
|
rowspan: "1",
|
|
6769
6779
|
colspan: "1",
|
|
6770
6780
|
key: Math.random()
|
|
6771
|
-
},
|
|
6781
|
+
}, T(N), 1))), 128))
|
|
6772
6782
|
]),
|
|
6773
|
-
c("tr",
|
|
6783
|
+
c("tr", JM, [
|
|
6774
6784
|
M[26] || (M[26] = c("td", {
|
|
6775
6785
|
rowspan: "1",
|
|
6776
6786
|
colspan: "1",
|
|
6777
6787
|
class: "tr-title"
|
|
6778
6788
|
}, [
|
|
6779
|
-
|
|
6789
|
+
z0("SeaTemp"),
|
|
6780
6790
|
c("span", { class: "unit" }, "°C")
|
|
6781
6791
|
], -1)),
|
|
6782
|
-
(
|
|
6792
|
+
(s(!0), W(F, null, K(p.tableData.seaTemp, (N) => (s(), W("td", {
|
|
6793
|
+
rowspan: "1",
|
|
6794
|
+
colspan: "1",
|
|
6795
|
+
key: Math.random()
|
|
6796
|
+
}, T(N), 1))), 128))
|
|
6797
|
+
]),
|
|
6798
|
+
c("tr", YM, [
|
|
6799
|
+
M[27] || (M[27] = c("td", {
|
|
6800
|
+
rowspan: "1",
|
|
6801
|
+
colspan: "1",
|
|
6802
|
+
class: "tr-title"
|
|
6803
|
+
}, [
|
|
6804
|
+
c("span", { class: "unit" })
|
|
6805
|
+
], -1)),
|
|
6806
|
+
(s(!0), W(F, null, K(p.tableData.seaTemp, (N) => (s(), W("td", {
|
|
6807
|
+
rowspan: "1",
|
|
6808
|
+
colspan: "1",
|
|
6809
|
+
key: Math.random()
|
|
6810
|
+
}))), 128))
|
|
6811
|
+
]),
|
|
6812
|
+
c("tr", VM, [
|
|
6813
|
+
M[28] || (M[28] = c("td", {
|
|
6814
|
+
rowspan: "1",
|
|
6815
|
+
colspan: "1",
|
|
6816
|
+
class: "tr-title"
|
|
6817
|
+
}, [
|
|
6818
|
+
c("span", { class: "unit" })
|
|
6819
|
+
], -1)),
|
|
6820
|
+
(s(!0), W(F, null, K(p.tableData.seaTemp, (N) => (s(), W("td", {
|
|
6783
6821
|
rowspan: "1",
|
|
6784
6822
|
colspan: "1",
|
|
6785
6823
|
key: Math.random()
|
|
6786
|
-
}
|
|
6824
|
+
}))), 128))
|
|
6787
6825
|
])
|
|
6788
6826
|
], 512), [
|
|
6789
|
-
[
|
|
6827
|
+
[X0, p.activeIndex === 3]
|
|
6790
6828
|
])
|
|
6791
|
-
])
|
|
6792
|
-
|
|
6793
|
-
|
|
6794
|
-
c("
|
|
6795
|
-
]
|
|
6829
|
+
], 512), [
|
|
6830
|
+
[X0, ((M0 = (Z = p.tableData) == null ? void 0 : Z.hours) == null ? void 0 : M0.length) > 0]
|
|
6831
|
+
]),
|
|
6832
|
+
M[29] || (M[29] = c("div", { class: "more" }, "More >>", -1))
|
|
6833
|
+
]))
|
|
6796
6834
|
])
|
|
6797
6835
|
], 512), [
|
|
6798
|
-
[
|
|
6836
|
+
[X0, p.showMeteo]
|
|
6799
6837
|
])
|
|
6800
6838
|
]);
|
|
6801
6839
|
}
|
|
6802
|
-
const
|
|
6840
|
+
const Mb = /* @__PURE__ */ Q(OM, [["render", $M], ["__scopeId", "data-v-6224863f"]]), bb = {
|
|
6803
6841
|
name: "IdmWarZone",
|
|
6804
6842
|
props: {
|
|
6805
6843
|
map: {
|
|
@@ -6889,10 +6927,10 @@ const QM = /* @__PURE__ */ I(pM, [["render", JM], ["__scopeId", "data-v-f1da5f57
|
|
|
6889
6927
|
}
|
|
6890
6928
|
}
|
|
6891
6929
|
};
|
|
6892
|
-
function
|
|
6893
|
-
return
|
|
6930
|
+
function zb(z, M, b, O, p, o) {
|
|
6931
|
+
return s(), W("div");
|
|
6894
6932
|
}
|
|
6895
|
-
const
|
|
6933
|
+
const pb = /* @__PURE__ */ Q(bb, [["render", zb]]), Ob = {
|
|
6896
6934
|
name: "IdmGmdssArea",
|
|
6897
6935
|
props: {
|
|
6898
6936
|
map: {
|
|
@@ -7012,10 +7050,10 @@ const YM = /* @__PURE__ */ I($M, [["render", ZM]]), Mb = {
|
|
|
7012
7050
|
}
|
|
7013
7051
|
}
|
|
7014
7052
|
};
|
|
7015
|
-
function
|
|
7016
|
-
return
|
|
7053
|
+
function ob(z, M, b, O, p, o) {
|
|
7054
|
+
return s(), W("div");
|
|
7017
7055
|
}
|
|
7018
|
-
const
|
|
7056
|
+
const cb = /* @__PURE__ */ Q(Ob, [["render", ob]]), Ab = {
|
|
7019
7057
|
name: "IdmEcaZone",
|
|
7020
7058
|
props: {
|
|
7021
7059
|
map: {
|
|
@@ -7103,11 +7141,11 @@ const zb = /* @__PURE__ */ I(Mb, [["render", bb]]), pb = {
|
|
|
7103
7141
|
}
|
|
7104
7142
|
}
|
|
7105
7143
|
};
|
|
7106
|
-
function
|
|
7107
|
-
return
|
|
7144
|
+
function eb(z, M, b, O, p, o) {
|
|
7145
|
+
return s(), W("div");
|
|
7108
7146
|
}
|
|
7109
|
-
const
|
|
7110
|
-
const
|
|
7147
|
+
const tb = /* @__PURE__ */ Q(Ab, [["render", eb]]);
|
|
7148
|
+
const ab = {
|
|
7111
7149
|
name: "IdmAlertZone",
|
|
7112
7150
|
props: {
|
|
7113
7151
|
map: {
|
|
@@ -7150,7 +7188,7 @@ const cb = {
|
|
|
7150
7188
|
if (b) {
|
|
7151
7189
|
this.showZone = !0, this.form = { ...b.properties };
|
|
7152
7190
|
const p = document.getElementById("idm-gl3-zone-info");
|
|
7153
|
-
this.marker ? this.marker.setLngLat([z.lngLat.lng, z.lngLat.lat]) : this.marker = new
|
|
7191
|
+
this.marker ? this.marker.setLngLat([z.lngLat.lng, z.lngLat.lat]) : this.marker = new w0.Marker(p).setLngLat([z.lngLat.lng, z.lngLat.lat]).setOffset([0, 0]).addTo(this.map);
|
|
7154
7192
|
}
|
|
7155
7193
|
},
|
|
7156
7194
|
handleRender() {
|
|
@@ -7237,24 +7275,24 @@ const cb = {
|
|
|
7237
7275
|
this.map.getLayer(this.polygonLayer) && this.map.removeLayer(this.polygonLayer), this.map.getLayer(this.polygonLayer + "-border") && this.map.removeLayer(this.polygonLayer + "-border"), this.map.getLayer(this.polygonLabelLayer) && this.map.removeLayer(this.polygonLabelLayer), this.map.getLayer(this.lineLayer) && this.map.removeLayer(this.lineLayer), this.map.getLayer(this.lineLabelLayer) && this.map.removeLayer(this.lineLabelLayer), this.map.getLayer(this.pointLayer) && this.map.removeLayer(this.pointLayer), this.map.getSource(this.source) && this.map.removeSource(this.source);
|
|
7238
7276
|
}
|
|
7239
7277
|
}
|
|
7240
|
-
},
|
|
7241
|
-
function
|
|
7242
|
-
var
|
|
7243
|
-
return
|
|
7278
|
+
}, qb = { id: "idm-gl3-zone-info" }, ib = ["innerHTML"];
|
|
7279
|
+
function rb(z, M, b, O, p, o) {
|
|
7280
|
+
var A;
|
|
7281
|
+
return y0((s(), W("div", qb, [
|
|
7244
7282
|
c("div", {
|
|
7245
7283
|
class: "iconfont close",
|
|
7246
7284
|
onClick: M[0] || (M[0] = (t) => p.showZone = !1)
|
|
7247
7285
|
}, ""),
|
|
7248
7286
|
c("div", {
|
|
7249
7287
|
class: "rich-context",
|
|
7250
|
-
innerHTML: (
|
|
7251
|
-
}, null, 8,
|
|
7288
|
+
innerHTML: (A = p.form) == null ? void 0 : A.name
|
|
7289
|
+
}, null, 8, ib)
|
|
7252
7290
|
], 512)), [
|
|
7253
|
-
[
|
|
7291
|
+
[X0, p.showZone]
|
|
7254
7292
|
]);
|
|
7255
7293
|
}
|
|
7256
|
-
const
|
|
7257
|
-
const
|
|
7294
|
+
const nb = /* @__PURE__ */ Q(ab, [["render", rb]]);
|
|
7295
|
+
const db = {
|
|
7258
7296
|
name: "IdmPort",
|
|
7259
7297
|
props: {
|
|
7260
7298
|
map: {
|
|
@@ -7280,12 +7318,12 @@ const qb = {
|
|
|
7280
7318
|
computed: {
|
|
7281
7319
|
computeLat() {
|
|
7282
7320
|
return function(z) {
|
|
7283
|
-
return
|
|
7321
|
+
return b0.lat2pretty(z, 4).pretty;
|
|
7284
7322
|
};
|
|
7285
7323
|
},
|
|
7286
7324
|
computeLng() {
|
|
7287
7325
|
return function(z) {
|
|
7288
|
-
return
|
|
7326
|
+
return b0.lng2pretty(z, 4).pretty;
|
|
7289
7327
|
};
|
|
7290
7328
|
}
|
|
7291
7329
|
},
|
|
@@ -7307,7 +7345,7 @@ const qb = {
|
|
|
7307
7345
|
if (b) {
|
|
7308
7346
|
this.showPort = !0, this.form = { ...b.properties }, this.form.lng = b.geometry.coordinates[0], this.form.lat = b.geometry.coordinates[1];
|
|
7309
7347
|
const p = document.getElementById("port-info");
|
|
7310
|
-
this.marker ? this.marker.setLngLat([z.lngLat.lng, z.lngLat.lat]) : this.marker = new
|
|
7348
|
+
this.marker ? this.marker.setLngLat([z.lngLat.lng, z.lngLat.lat]) : this.marker = new w0.Marker(p).setLngLat([z.lngLat.lng, z.lngLat.lat]).setOffset([0, -85]).addTo(this.map);
|
|
7311
7349
|
}
|
|
7312
7350
|
},
|
|
7313
7351
|
handleEmit() {
|
|
@@ -7346,41 +7384,41 @@ const qb = {
|
|
|
7346
7384
|
this.showPort = !1, this.map.getLayer(this.layer) && this.map.removeLayer(this.layer), this.map.getSource(this.source) && this.map.removeSource(this.source);
|
|
7347
7385
|
}
|
|
7348
7386
|
}
|
|
7349
|
-
},
|
|
7387
|
+
}, sb = { id: "port-info" }, Wb = { class: "port-box" }, lb = { class: "flex-start" }, fb = { class: "flex-start" }, ub = { class: "flex-start" }, Lb = {
|
|
7350
7388
|
class: "flex-start",
|
|
7351
7389
|
style: { "align-items": "flex-start" }
|
|
7352
7390
|
};
|
|
7353
|
-
function
|
|
7354
|
-
return
|
|
7391
|
+
function Rb(z, M, b, O, p, o) {
|
|
7392
|
+
return y0((s(), W("div", sb, [
|
|
7355
7393
|
c("div", {
|
|
7356
7394
|
class: "close iconfont",
|
|
7357
|
-
onClick: M[0] || (M[0] = (
|
|
7395
|
+
onClick: M[0] || (M[0] = (A) => p.showPort = !1)
|
|
7358
7396
|
}, ""),
|
|
7359
|
-
c("div",
|
|
7360
|
-
c("div",
|
|
7397
|
+
c("div", Wb, [
|
|
7398
|
+
c("div", lb, [
|
|
7361
7399
|
M[2] || (M[2] = c("label", null, "Name : ", -1)),
|
|
7362
7400
|
c("span", {
|
|
7363
|
-
onClick: M[1] || (M[1] = (...
|
|
7364
|
-
},
|
|
7401
|
+
onClick: M[1] || (M[1] = (...A) => o.handleEmit && o.handleEmit(...A))
|
|
7402
|
+
}, T(p.form.name), 1)
|
|
7365
7403
|
]),
|
|
7366
|
-
c("div",
|
|
7404
|
+
c("div", fb, [
|
|
7367
7405
|
M[3] || (M[3] = c("label", null, "Position : ", -1)),
|
|
7368
|
-
c("span", null,
|
|
7406
|
+
c("span", null, T(o.computeLat(p.form.lat)) + ", " + T(o.computeLng(p.form.lng)), 1)
|
|
7369
7407
|
]),
|
|
7370
|
-
c("div",
|
|
7408
|
+
c("div", ub, [
|
|
7371
7409
|
M[4] || (M[4] = c("label", null, "LoCode : ", -1)),
|
|
7372
|
-
c("span", null,
|
|
7410
|
+
c("span", null, T(p.form.loCode || "-"), 1)
|
|
7373
7411
|
]),
|
|
7374
|
-
c("div",
|
|
7412
|
+
c("div", Lb, [
|
|
7375
7413
|
M[5] || (M[5] = c("label", null, "Region : ", -1)),
|
|
7376
|
-
c("span", null,
|
|
7414
|
+
c("span", null, T(p.form.zoneName || "-"), 1)
|
|
7377
7415
|
])
|
|
7378
7416
|
])
|
|
7379
7417
|
], 512)), [
|
|
7380
|
-
[
|
|
7418
|
+
[X0, p.showPort]
|
|
7381
7419
|
]);
|
|
7382
7420
|
}
|
|
7383
|
-
const
|
|
7421
|
+
const hb = /* @__PURE__ */ Q(db, [["render", Rb], ["__scopeId", "data-v-c07e4c45"]]), mb = {
|
|
7384
7422
|
name: "IdmLoadLine",
|
|
7385
7423
|
props: {
|
|
7386
7424
|
map: {
|
|
@@ -7450,10 +7488,10 @@ const fb = /* @__PURE__ */ I(qb, [["render", lb], ["__scopeId", "data-v-c07e4c45
|
|
|
7450
7488
|
}
|
|
7451
7489
|
}
|
|
7452
7490
|
};
|
|
7453
|
-
function
|
|
7454
|
-
return
|
|
7491
|
+
function Bb(z, M, b, O, p, o) {
|
|
7492
|
+
return s(), W("div");
|
|
7455
7493
|
}
|
|
7456
|
-
const
|
|
7494
|
+
const gb = /* @__PURE__ */ Q(mb, [["render", Bb]]), Nb = {
|
|
7457
7495
|
name: "IdmTimezone",
|
|
7458
7496
|
props: {
|
|
7459
7497
|
map: {
|
|
@@ -7618,10 +7656,10 @@ const Rb = /* @__PURE__ */ I(ub, [["render", Lb]]), hb = {
|
|
|
7618
7656
|
}
|
|
7619
7657
|
}
|
|
7620
7658
|
};
|
|
7621
|
-
function
|
|
7622
|
-
return
|
|
7659
|
+
function yb(z, M, b, O, p, o) {
|
|
7660
|
+
return s(), W("div");
|
|
7623
7661
|
}
|
|
7624
|
-
const
|
|
7662
|
+
const Xb = /* @__PURE__ */ Q(Nb, [["render", yb]]), wb = {
|
|
7625
7663
|
name: "IdmVoluntaryReportingArea",
|
|
7626
7664
|
props: {
|
|
7627
7665
|
map: {
|
|
@@ -7709,10 +7747,10 @@ const Nb = /* @__PURE__ */ I(hb, [["render", mb]]), Bb = {
|
|
|
7709
7747
|
}
|
|
7710
7748
|
}
|
|
7711
7749
|
};
|
|
7712
|
-
function
|
|
7713
|
-
return
|
|
7750
|
+
function Cb(z, M, b, O, p, o) {
|
|
7751
|
+
return s(), W("div");
|
|
7714
7752
|
}
|
|
7715
|
-
const
|
|
7753
|
+
const vb = /* @__PURE__ */ Q(wb, [["render", Cb]]), Tb = {
|
|
7716
7754
|
name: "IdmSpecialArea",
|
|
7717
7755
|
props: {
|
|
7718
7756
|
map: {
|
|
@@ -7742,7 +7780,7 @@ const gb = /* @__PURE__ */ I(Bb, [["render", yb]]), Xb = {
|
|
|
7742
7780
|
methods: {
|
|
7743
7781
|
handleRender() {
|
|
7744
7782
|
this.map ? (this.handleClear(), this.area && (this.area.features.forEach((z) => {
|
|
7745
|
-
z.geometry.type === "Polygon" && z.geometry.coordinates.forEach((M) =>
|
|
7783
|
+
z.geometry.type === "Polygon" && z.geometry.coordinates.forEach((M) => b0.convertToMonotonicLng2(M));
|
|
7746
7784
|
}), this.map.addSource(this.source, {
|
|
7747
7785
|
type: "geojson",
|
|
7748
7786
|
data: this.area
|
|
@@ -7802,10 +7840,10 @@ const gb = /* @__PURE__ */ I(Bb, [["render", yb]]), Xb = {
|
|
|
7802
7840
|
}
|
|
7803
7841
|
}
|
|
7804
7842
|
};
|
|
7805
|
-
function
|
|
7806
|
-
return
|
|
7843
|
+
function Eb(z, M, b, O, p, o) {
|
|
7844
|
+
return s(), W("div");
|
|
7807
7845
|
}
|
|
7808
|
-
const
|
|
7846
|
+
const xb = /* @__PURE__ */ Q(Tb, [["render", Eb]]), Ib = {
|
|
7809
7847
|
name: "IdmTerminator",
|
|
7810
7848
|
props: {
|
|
7811
7849
|
map: {
|
|
@@ -7854,11 +7892,11 @@ const Tb = /* @__PURE__ */ I(Xb, [["render", vb]]), wb = {
|
|
|
7854
7892
|
}
|
|
7855
7893
|
}
|
|
7856
7894
|
};
|
|
7857
|
-
function
|
|
7858
|
-
return
|
|
7895
|
+
function Db(z, M, b, O, p, o) {
|
|
7896
|
+
return s(), W("div");
|
|
7859
7897
|
}
|
|
7860
|
-
const
|
|
7861
|
-
const
|
|
7898
|
+
const Pb = /* @__PURE__ */ Q(Ib, [["render", Db]]);
|
|
7899
|
+
const Sb = {
|
|
7862
7900
|
name: "IdmLatLng",
|
|
7863
7901
|
props: {
|
|
7864
7902
|
map: {
|
|
@@ -7916,7 +7954,7 @@ const xb = {
|
|
|
7916
7954
|
this.show ? ((z = this.map) == null || z.on("zoomend", this.handleZoomEnd), this.handleRender()) : (this.handleClear(), (M = this.map) == null || M.off("zoomend", this.handleZoomEnd));
|
|
7917
7955
|
},
|
|
7918
7956
|
handleMouseMove(z) {
|
|
7919
|
-
const M = z.lngLat, b =
|
|
7957
|
+
const M = z.lngLat, b = b0.lng2pretty(M.lng, 2), O = b0.lat2pretty(M.lat, 2);
|
|
7920
7958
|
this.lngLat = { lng: b, lat: O };
|
|
7921
7959
|
},
|
|
7922
7960
|
handleComputeLatLngs() {
|
|
@@ -7965,7 +8003,7 @@ const xb = {
|
|
|
7965
8003
|
handleZoomEnd() {
|
|
7966
8004
|
var M;
|
|
7967
8005
|
const z = this.handleComputeLatLngs();
|
|
7968
|
-
(M = this.map) == null || M.getSource(this.source).setData(
|
|
8006
|
+
(M = this.map) == null || M.getSource(this.source).setData(v.featureCollection(z));
|
|
7969
8007
|
},
|
|
7970
8008
|
handleRender() {
|
|
7971
8009
|
if (this.map) {
|
|
@@ -8014,18 +8052,18 @@ const xb = {
|
|
|
8014
8052
|
}
|
|
8015
8053
|
}
|
|
8016
8054
|
};
|
|
8017
|
-
function
|
|
8018
|
-
return p.lngLat ? (
|
|
8055
|
+
function kb(z, M, b, O, p, o) {
|
|
8056
|
+
return p.lngLat ? (s(), W("div", {
|
|
8019
8057
|
key: 0,
|
|
8020
8058
|
class: "lat-lng-tip",
|
|
8021
|
-
style:
|
|
8059
|
+
style: c0({ right: p.right + "px", bottom: b.bottom })
|
|
8022
8060
|
}, [
|
|
8023
|
-
c("span", null,
|
|
8061
|
+
c("span", null, T(p.lngLat.lat.pretty), 1),
|
|
8024
8062
|
M[0] || (M[0] = c("span", null, ", ", -1)),
|
|
8025
|
-
c("span", null,
|
|
8026
|
-
], 4)) :
|
|
8063
|
+
c("span", null, T(p.lngLat.lng.pretty), 1)
|
|
8064
|
+
], 4)) : j("", !0);
|
|
8027
8065
|
}
|
|
8028
|
-
const
|
|
8066
|
+
const F0 = /* @__PURE__ */ Q(Sb, [["render", kb], ["__scopeId", "data-v-ad66a24c"]]), Qb = {
|
|
8029
8067
|
name: "IdmMeasure",
|
|
8030
8068
|
props: {
|
|
8031
8069
|
map: {
|
|
@@ -8066,11 +8104,11 @@ const H0 = /* @__PURE__ */ I(xb, [["render", Sb], ["__scopeId", "data-v-ad66a24c
|
|
|
8066
8104
|
},
|
|
8067
8105
|
methods: {
|
|
8068
8106
|
handleBind() {
|
|
8069
|
-
var z, M, b, O, p, o,
|
|
8107
|
+
var z, M, b, O, p, o, A, t, q, r;
|
|
8070
8108
|
if (this.show)
|
|
8071
8109
|
(z = this.map) == null || z.getCanvas().addEventListener("keydown", this.handleKeydown), (M = this.map) == null || M.on("mousemove", this.handleMove), (b = this.map) == null || b.on("dblclick", this.handleDblClick), (O = this.map) == null || O.on("click", this.handleClick), (p = this.map) == null || p.on("contextmenu", this.handleContextmenu), this.map && (this.map.getCanvas().style.cursor = "crosshair");
|
|
8072
8110
|
else {
|
|
8073
|
-
(o = this.map) == null || o.getCanvas().removeEventListener("keydown", this.handleKeydown), (
|
|
8111
|
+
(o = this.map) == null || o.getCanvas().removeEventListener("keydown", this.handleKeydown), (A = this.map) == null || A.off("mousemove", this.handleMove), (t = this.map) == null || t.off("dblclick", this.handleDblClick), (q = this.map) == null || q.off("click", this.handleClick), (r = this.map) == null || r.off("contextmenu", this.handleContextmenu);
|
|
8074
8112
|
for (const a of this.geojson)
|
|
8075
8113
|
this.handleClear(a, !0);
|
|
8076
8114
|
this.geojson = [], this.map && (this.map.getCanvas().style.cursor = "grab");
|
|
@@ -8084,14 +8122,14 @@ const H0 = /* @__PURE__ */ I(xb, [["render", Sb], ["__scopeId", "data-v-ad66a24c
|
|
|
8084
8122
|
}
|
|
8085
8123
|
},
|
|
8086
8124
|
handleDrag(z) {
|
|
8087
|
-
var b, O, p, o,
|
|
8125
|
+
var b, O, p, o, A, t, q, r, a, i;
|
|
8088
8126
|
const M = (O = (b = z.target) == null ? void 0 : b._element) == null ? void 0 : O.id;
|
|
8089
8127
|
if ((M == null ? void 0 : M.split("-").length) === 2) {
|
|
8090
8128
|
const L = this.geojson.filter((d) => d.id === M.split("-")[0])[0];
|
|
8091
8129
|
this.pointMarkers[L.id].filter((d) => {
|
|
8092
8130
|
var m;
|
|
8093
8131
|
return ((m = d._element) == null ? void 0 : m.id) === M;
|
|
8094
|
-
})[0].setLngLat([(o = (p = z.target) == null ? void 0 : p._lngLat) == null ? void 0 : o.lng, (t = (
|
|
8132
|
+
})[0].setLngLat([(o = (p = z.target) == null ? void 0 : p._lngLat) == null ? void 0 : o.lng, (t = (A = z.target) == null ? void 0 : A._lngLat) == null ? void 0 : t.lat]);
|
|
8095
8133
|
let h;
|
|
8096
8134
|
L.features.forEach((d, m) => {
|
|
8097
8135
|
if (d.geometry.type === "Point" && d.properties.id == M.split("-")[1]) {
|
|
@@ -8109,14 +8147,14 @@ const H0 = /* @__PURE__ */ I(xb, [["render", Sb], ["__scopeId", "data-v-ad66a24c
|
|
|
8109
8147
|
}
|
|
8110
8148
|
},
|
|
8111
8149
|
handleDragEnd(z) {
|
|
8112
|
-
var b, O, p, o,
|
|
8150
|
+
var b, O, p, o, A, t, q, r, a, i;
|
|
8113
8151
|
const M = (O = (b = z.target) == null ? void 0 : b._element) == null ? void 0 : O.id;
|
|
8114
8152
|
if ((M == null ? void 0 : M.split("-").length) === 2) {
|
|
8115
8153
|
const L = this.geojson.filter((u) => u.id === M.split("-")[0])[0];
|
|
8116
8154
|
this.pointMarkers[L.id].filter((u) => {
|
|
8117
8155
|
var d;
|
|
8118
8156
|
return ((d = u._element) == null ? void 0 : d.id) === M;
|
|
8119
|
-
})[0].setLngLat([(o = (p = z.target) == null ? void 0 : p._lngLat) == null ? void 0 : o.lng, (t = (
|
|
8157
|
+
})[0].setLngLat([(o = (p = z.target) == null ? void 0 : p._lngLat) == null ? void 0 : o.lng, (t = (A = z.target) == null ? void 0 : A._lngLat) == null ? void 0 : t.lat]);
|
|
8120
8158
|
const h = L.features.filter((u) => u.geometry.type === "Point" && u.properties.id == M.split("-")[1])[0];
|
|
8121
8159
|
h.geometry.coordinates = [(r = (q = z.target) == null ? void 0 : q._lngLat) == null ? void 0 : r.lng, (i = (a = z.target) == null ? void 0 : a._lngLat) == null ? void 0 : i.lat], L.features = L.features.filter((u) => u.geometry.type === "Point"), this.handlePointUpdate(L);
|
|
8122
8160
|
}
|
|
@@ -8129,24 +8167,24 @@ const H0 = /* @__PURE__ */ I(xb, [["render", Sb], ["__scopeId", "data-v-ad66a24c
|
|
|
8129
8167
|
const t = this.geojson.filter((q) => q.id === M.split("-")[0])[0].features.filter((q) => q.geometry.type === "Point");
|
|
8130
8168
|
if (t.length > 2 && t.filter((r) => r.properties.id === (M == null ? void 0 : M.split("-")[1]))[0]) {
|
|
8131
8169
|
const r = document.createElement("div");
|
|
8132
|
-
r.className = "point-contextmenu-marker", r.innerHTML = `<span id="del-${M}" class="del-point">Del</span>`, this.contextmenu = new
|
|
8170
|
+
r.className = "point-contextmenu-marker", r.innerHTML = `<span id="del-${M}" class="del-point">Del</span>`, this.contextmenu = new w0.Marker(r).setOffset([24, 0]).setLngLat([z.lngLat.lng, z.lngLat.lat]).addTo(this.map);
|
|
8133
8171
|
}
|
|
8134
8172
|
}
|
|
8135
8173
|
},
|
|
8136
8174
|
handleClick(z) {
|
|
8137
|
-
var b, O, p, o,
|
|
8175
|
+
var b, O, p, o, A;
|
|
8138
8176
|
(b = this.contextmenu) == null || b.remove();
|
|
8139
8177
|
const M = z.originalEvent.target.className;
|
|
8140
8178
|
if (M === "marker-close") {
|
|
8141
8179
|
const t = (p = (O = z.originalEvent) == null ? void 0 : O.srcElement) == null ? void 0 : p.id, q = this.geojson.filter((r) => r.id === t)[0];
|
|
8142
8180
|
q && this.handleClear(q, !0), this.geojson = this.geojson.filter((r) => r.id !== t);
|
|
8143
8181
|
} else if (M === "del-point") {
|
|
8144
|
-
const t = (
|
|
8182
|
+
const t = (A = (o = z.originalEvent.target.id) == null ? void 0 : o.replace("del-", "")) == null ? void 0 : A.split("-"), q = this.geojson.filter((r) => r.id === t[0])[0];
|
|
8145
8183
|
q.features = q.features.filter((r) => r.geometry.type === "Point" && r.properties.id !== t[1]), this.handlePointUpdate(q);
|
|
8146
8184
|
} else if (M !== "marker-label") {
|
|
8147
8185
|
let t = this.geojson.at(-1);
|
|
8148
|
-
t || (t =
|
|
8149
|
-
const q =
|
|
8186
|
+
t || (t = v.featureCollection([], { id: (/* @__PURE__ */ new Date()).getTime().toString() }), this.geojson.push(t)), t.features = t.features.filter((r) => r.geometry.type === "Point");
|
|
8187
|
+
const q = v.feature(
|
|
8150
8188
|
{
|
|
8151
8189
|
type: "Point",
|
|
8152
8190
|
coordinates: [z.lngLat.lng, z.lngLat.lat]
|
|
@@ -8165,11 +8203,11 @@ const H0 = /* @__PURE__ */ I(xb, [["render", Sb], ["__scopeId", "data-v-ad66a24c
|
|
|
8165
8203
|
let b = 0;
|
|
8166
8204
|
const O = [];
|
|
8167
8205
|
for (let p = 1; p < M.length; p++) {
|
|
8168
|
-
const o = M[p - 1],
|
|
8169
|
-
b =
|
|
8206
|
+
const o = M[p - 1], A = M[p], t = o.properties, q = { lng: o.geometry.coordinates[0], lat: o.geometry.coordinates[1] }, r = { lng: A.geometry.coordinates[0], lat: A.geometry.coordinates[1] }, a = g0.calculateDistance(q, r, t.mode === "RL", 2), i = g0.calculateBearing(q, r, t.mode === "RL", 2);
|
|
8207
|
+
b = b0.roundPrecision(b + a, 2);
|
|
8170
8208
|
let L;
|
|
8171
|
-
t.mode === "RL" ? L =
|
|
8172
|
-
const n =
|
|
8209
|
+
t.mode === "RL" ? L = b0.convertToMonotonicLng([q, r]) : L = b0.convertToMonotonicLng(g0.interpolateCoordinates(q, r, 200));
|
|
8210
|
+
const n = v.lineString(L.map((h) => [h.lng, h.lat]));
|
|
8173
8211
|
n.properties.dist = a, n.properties.bearing = i, n.properties.total = b, O.push(n);
|
|
8174
8212
|
}
|
|
8175
8213
|
M.push(...O), z.total = b;
|
|
@@ -8177,23 +8215,23 @@ const H0 = /* @__PURE__ */ I(xb, [["render", Sb], ["__scopeId", "data-v-ad66a24c
|
|
|
8177
8215
|
return this.handleRender(z), z;
|
|
8178
8216
|
},
|
|
8179
8217
|
handleTmpPointUpdate(z, M, b, O) {
|
|
8180
|
-
const p =
|
|
8181
|
-
let o,
|
|
8218
|
+
const p = v.featureCollection([]);
|
|
8219
|
+
let o, A;
|
|
8182
8220
|
if (M) {
|
|
8183
8221
|
const q = M.properties, r = { lng: M.geometry.coordinates[0], lat: M.geometry.coordinates[1] }, a = { lng: b.lng, lat: b.lat };
|
|
8184
|
-
o =
|
|
8222
|
+
o = g0.calculateDistance(r, a, q.mode === "RL", 2), A = g0.calculateBearing(r, a, q.mode === "RL", 2);
|
|
8185
8223
|
let i;
|
|
8186
|
-
q.mode === "RL" ? i =
|
|
8187
|
-
const L =
|
|
8188
|
-
L.properties.dist = o, L.properties.bearing =
|
|
8224
|
+
q.mode === "RL" ? i = b0.convertToMonotonicLng([r, a]) : i = b0.convertToMonotonicLng(g0.interpolateCoordinates(r, a, 200));
|
|
8225
|
+
const L = v.lineString(i.map((n) => [n.lng, n.lat]));
|
|
8226
|
+
L.properties.dist = o, L.properties.bearing = A, p.features.push(L);
|
|
8189
8227
|
}
|
|
8190
8228
|
if (O) {
|
|
8191
8229
|
const q = b.properties, r = b, a = { lng: O.geometry.coordinates[0], lat: O.geometry.coordinates[1] };
|
|
8192
|
-
o =
|
|
8230
|
+
o = g0.calculateDistance(r, a, q.mode === "RL", 2), A = g0.calculateBearing(r, a, q.mode === "RL", 2);
|
|
8193
8231
|
let i;
|
|
8194
|
-
q.mode === "RL" ? i =
|
|
8195
|
-
const L =
|
|
8196
|
-
L.properties.dist = o, L.properties.bearing =
|
|
8232
|
+
q.mode === "RL" ? i = b0.convertToMonotonicLng([r, a]) : i = b0.convertToMonotonicLng(g0.interpolateCoordinates(r, a, 200));
|
|
8233
|
+
const L = v.lineString(i.map((n) => [n.lng, n.lat]));
|
|
8234
|
+
L.properties.dist = o, L.properties.bearing = A, p.features.push(L);
|
|
8197
8235
|
}
|
|
8198
8236
|
this.map.getSource(this.tmpSource) ? this.map.getSource(this.tmpSource).setData(p) : this.map.addSource(this.tmpSource, {
|
|
8199
8237
|
type: "geojson",
|
|
@@ -8233,24 +8271,24 @@ const H0 = /* @__PURE__ */ I(xb, [["render", Sb], ["__scopeId", "data-v-ad66a24c
|
|
|
8233
8271
|
}
|
|
8234
8272
|
});
|
|
8235
8273
|
let t;
|
|
8236
|
-
if (O ? t = '<div class="marker-label">Drag and drop</div>' : t = `<div class="marker-label">Tol distance: <b>${
|
|
8274
|
+
if (O ? t = '<div class="marker-label">Drag and drop</div>' : t = `<div class="marker-label">Tol distance: <b>${b0.roundPrecision((z.total ?? 0) + o, 2)}</b>nm, bearing: <b>${A}</b>°</div><div class="marker-label">${this.navigation === "RL" ? "RL" : "GC"} mode, using 'Shift' to switch</div><div class="marker-label">Double click to end</div>`, this.tipMarker)
|
|
8237
8275
|
this.tipMarker._element.innerHTML = t, this.tipMarker.setLngLat([b.lng, b.lat]);
|
|
8238
8276
|
else {
|
|
8239
8277
|
const q = document.createElement("div");
|
|
8240
|
-
q.className = "tip-marker", q.innerHTML = t, this.tipMarker = new
|
|
8278
|
+
q.className = "tip-marker", q.innerHTML = t, this.tipMarker = new w0.Marker(q).setOffset([140, 0]).setLngLat([b.lng, b.lat]).addTo(this.map);
|
|
8241
8279
|
}
|
|
8242
8280
|
},
|
|
8243
8281
|
handleMove(z) {
|
|
8244
8282
|
this.map.getCanvas().style.cursor = "crosshair";
|
|
8245
8283
|
let M = this.geojson.at(-1);
|
|
8246
|
-
M || (M =
|
|
8284
|
+
M || (M = v.featureCollection([], { id: (/* @__PURE__ */ new Date()).getTime().toString() }), this.geojson.push(M));
|
|
8247
8285
|
const b = M.features.filter((O) => O.geometry.type === "Point");
|
|
8248
8286
|
b != null && b.length && this.handleTmpPointUpdate(M, b.at(-1), { lng: z.lngLat.lng, lat: z.lngLat.lat });
|
|
8249
8287
|
},
|
|
8250
8288
|
handleDblClick(z) {
|
|
8251
8289
|
z.preventDefault();
|
|
8252
8290
|
let M = this.geojson.at(-1);
|
|
8253
|
-
M.closed = !0, this.handleRender(M), M =
|
|
8291
|
+
M.closed = !0, this.handleRender(M), M = v.featureCollection([], { id: (/* @__PURE__ */ new Date()).getTime().toString() }), this.geojson.push(M);
|
|
8254
8292
|
},
|
|
8255
8293
|
handleRender(z) {
|
|
8256
8294
|
var M;
|
|
@@ -8291,33 +8329,33 @@ const H0 = /* @__PURE__ */ I(xb, [["render", Sb], ["__scopeId", "data-v-ad66a24c
|
|
|
8291
8329
|
"text-halo-blur": 0
|
|
8292
8330
|
}
|
|
8293
8331
|
});
|
|
8294
|
-
const o = z.features.filter((
|
|
8295
|
-
for (const
|
|
8332
|
+
const o = z.features.filter((A) => A.geometry.type === "Point");
|
|
8333
|
+
for (const A of o) {
|
|
8296
8334
|
const t = document.createElement("div");
|
|
8297
|
-
t.id = `${z.id}-${
|
|
8298
|
-
const q = new
|
|
8335
|
+
t.id = `${z.id}-${A.properties.id}`, t.className = `${z.closed ? "point-marker closed" : "point-marker"}`, t.innerHTML = '<div class="marker-circle"></div>';
|
|
8336
|
+
const q = new w0.Marker({ element: t, draggable: !0, contextmenu: !0 }).setLngLat(A.geometry.coordinates).addTo(this.map);
|
|
8299
8337
|
q.on("drag", this.handleDrag), q.on("dragend", this.handleDragEnd), this.pointMarkers[z.id] ? this.pointMarkers[z.id].push(q) : this.pointMarkers[z.id] = [q];
|
|
8300
8338
|
}
|
|
8301
8339
|
if (z.closed) {
|
|
8302
|
-
const
|
|
8303
|
-
r.className = "point-summary-marker", r.innerHTML = `<div id="${z.id}" class="marker-close">×</div><div class="marker-label">Tol: ${q.properties.total}nm</div>`, this.closeMarkers[z.id] = new
|
|
8340
|
+
const A = o.at(-1), q = z.features.filter((a) => a.geometry.type === "LineString").at(-1), r = document.createElement("div");
|
|
8341
|
+
r.className = "point-summary-marker", r.innerHTML = `<div id="${z.id}" class="marker-close">×</div><div class="marker-label">Tol: ${q.properties.total}nm</div>`, this.closeMarkers[z.id] = new w0.Marker(r).setOffset([60, 0]).setLngLat(A.geometry.coordinates).addTo(this.map);
|
|
8304
8342
|
}
|
|
8305
8343
|
}
|
|
8306
8344
|
},
|
|
8307
8345
|
handleClear(z, M = !0) {
|
|
8308
|
-
var o,
|
|
8346
|
+
var o, A, t, q, r, a, i, L, n;
|
|
8309
8347
|
const b = `${z.id}-${this.source}`, O = `${z.id}-${this.layer}`, p = `${z.id}-${this.labelLayer}`;
|
|
8310
|
-
(o = this.map) != null && o.getLayer(O) && this.map.removeLayer(O), (
|
|
8348
|
+
(o = this.map) != null && o.getLayer(O) && this.map.removeLayer(O), (A = this.map) != null && A.getLayer(p) && this.map.removeLayer(p), (t = this.map) != null && t.getLayer(this.tmpLayer) && this.map.removeLayer(this.tmpLayer), (q = this.map) != null && q.getLayer(this.tmpLabelLayer) && this.map.removeLayer(this.tmpLabelLayer), (r = this.closeMarkers[z.id]) == null || r.remove(), this.closeMarkers[z.id] = void 0, (a = this.pointMarkers[z.id]) == null || a.forEach((h) => {
|
|
8311
8349
|
h == null || h.remove();
|
|
8312
8350
|
}), this.pointMarkers[z.id] = [], (i = this.tipMarker) == null || i.remove(), this.tipMarker = void 0, M && ((L = this.map) != null && L.getSource(b)) && this.map.removeSource(b), M && ((n = this.map) != null && n.getSource(this.tmpSource)) && this.map.removeSource(this.tmpSource);
|
|
8313
8351
|
}
|
|
8314
8352
|
}
|
|
8315
8353
|
};
|
|
8316
|
-
function
|
|
8317
|
-
return
|
|
8354
|
+
function Hb(z, M, b, O, p, o) {
|
|
8355
|
+
return s(), W("div");
|
|
8318
8356
|
}
|
|
8319
|
-
const
|
|
8320
|
-
const
|
|
8357
|
+
const _b = /* @__PURE__ */ Q(Qb, [["render", Hb]]);
|
|
8358
|
+
const jb = {
|
|
8321
8359
|
name: "IdmENC",
|
|
8322
8360
|
props: {
|
|
8323
8361
|
map: {
|
|
@@ -8348,8 +8386,8 @@ const Db = {
|
|
|
8348
8386
|
emits: ["enc"],
|
|
8349
8387
|
data() {
|
|
8350
8388
|
return {
|
|
8351
|
-
helper:
|
|
8352
|
-
vendor: this.$attrs.permission &
|
|
8389
|
+
helper: I0,
|
|
8390
|
+
vendor: this.$attrs.permission & I0.LEVEL.Supper ? "hi" : "i4",
|
|
8353
8391
|
right: 10
|
|
8354
8392
|
};
|
|
8355
8393
|
},
|
|
@@ -8369,24 +8407,24 @@ const Db = {
|
|
|
8369
8407
|
}
|
|
8370
8408
|
},
|
|
8371
8409
|
methods: {}
|
|
8372
|
-
},
|
|
8410
|
+
}, Fb = { key: 0 }, Gb = { class: "bar-item" };
|
|
8373
8411
|
function Ub(z, M, b, O, p, o) {
|
|
8374
|
-
const
|
|
8375
|
-
return b.enabled && b.permission & p.helper.LEVEL.Supper ? (
|
|
8412
|
+
const A = I("ElTooltip");
|
|
8413
|
+
return b.enabled && b.permission & p.helper.LEVEL.Supper ? (s(), W("div", Fb, [
|
|
8376
8414
|
c("div", {
|
|
8377
8415
|
class: "menu-bar-box",
|
|
8378
|
-
style:
|
|
8416
|
+
style: c0({ position: "absolute", right: p.right + "px", bottom: b.bottom })
|
|
8379
8417
|
}, [
|
|
8380
|
-
c("div",
|
|
8381
|
-
|
|
8418
|
+
c("div", Gb, [
|
|
8419
|
+
C(A, {
|
|
8382
8420
|
placement: "left",
|
|
8383
8421
|
effect: "light",
|
|
8384
8422
|
content: "Hifleet",
|
|
8385
8423
|
"show-after": 1e3
|
|
8386
8424
|
}, {
|
|
8387
|
-
default:
|
|
8425
|
+
default: t0(() => [
|
|
8388
8426
|
c("div", {
|
|
8389
|
-
class:
|
|
8427
|
+
class: V(p.vendor === "hi" ? "menu-icon active" : "menu-icon"),
|
|
8390
8428
|
onClick: M[0] || (M[0] = (t) => p.vendor = "hi")
|
|
8391
8429
|
}, M[2] || (M[2] = [
|
|
8392
8430
|
c("span", { class: "iconfont" }, "HI", -1)
|
|
@@ -8394,15 +8432,15 @@ function Ub(z, M, b, O, p, o) {
|
|
|
8394
8432
|
]),
|
|
8395
8433
|
_: 1
|
|
8396
8434
|
}),
|
|
8397
|
-
|
|
8435
|
+
C(A, {
|
|
8398
8436
|
placement: "left",
|
|
8399
8437
|
effect: "light",
|
|
8400
8438
|
content: "I4insight",
|
|
8401
8439
|
"show-after": 1e3
|
|
8402
8440
|
}, {
|
|
8403
|
-
default:
|
|
8441
|
+
default: t0(() => [
|
|
8404
8442
|
c("div", {
|
|
8405
|
-
class:
|
|
8443
|
+
class: V(p.vendor === "i4" ? "menu-icon active" : "menu-icon"),
|
|
8406
8444
|
onClick: M[1] || (M[1] = (t) => p.vendor = "i4")
|
|
8407
8445
|
}, M[3] || (M[3] = [
|
|
8408
8446
|
c("span", { class: "iconfont" }, "I4", -1)
|
|
@@ -8412,42 +8450,42 @@ function Ub(z, M, b, O, p, o) {
|
|
|
8412
8450
|
})
|
|
8413
8451
|
])
|
|
8414
8452
|
], 4)
|
|
8415
|
-
])) :
|
|
8453
|
+
])) : j("", !0);
|
|
8416
8454
|
}
|
|
8417
|
-
const
|
|
8418
|
-
const
|
|
8455
|
+
const Kb = /* @__PURE__ */ Q(jb, [["render", Ub], ["__scopeId", "data-v-7301123d"]]);
|
|
8456
|
+
const Jb = {
|
|
8419
8457
|
name: "IdmGLV2",
|
|
8420
8458
|
components: {
|
|
8421
|
-
IdmGlLayer:
|
|
8422
|
-
IdmWindBarb:
|
|
8423
|
-
IdmWindParticle:
|
|
8424
|
-
IdmCurrents:
|
|
8459
|
+
IdmGlLayer: v1,
|
|
8460
|
+
IdmWindBarb: I1,
|
|
8461
|
+
IdmWindParticle: Q1,
|
|
8462
|
+
IdmCurrents: F1,
|
|
8425
8463
|
IdmCurrentParticle: J1,
|
|
8426
8464
|
IdmSigWave: Z1,
|
|
8427
8465
|
IdmSwell: b2,
|
|
8428
8466
|
IdmPrmsl: O2,
|
|
8429
8467
|
// IdmIceEdge,
|
|
8430
|
-
IdmIceberg:
|
|
8431
|
-
IdmTropicals:
|
|
8432
|
-
IdmPrecip3h:
|
|
8433
|
-
IdmVisibility:
|
|
8434
|
-
IdmWaterTemp:
|
|
8435
|
-
IdmTemp:
|
|
8436
|
-
IdmArctic:
|
|
8437
|
-
IdmWarZone:
|
|
8438
|
-
IdmGmdssArea:
|
|
8439
|
-
IdmEcaZone:
|
|
8440
|
-
IdmAlertZone:
|
|
8441
|
-
IdmPort:
|
|
8442
|
-
IdmLoadLine:
|
|
8443
|
-
IdmTimezone:
|
|
8444
|
-
IdmVRA:
|
|
8445
|
-
IdmSpecialArea:
|
|
8446
|
-
IdmTerminator:
|
|
8447
|
-
IdmLatLng:
|
|
8448
|
-
IdmMeasure:
|
|
8449
|
-
IdmPoint:
|
|
8450
|
-
IdmENC:
|
|
8468
|
+
IdmIceberg: A2,
|
|
8469
|
+
IdmTropicals: H0,
|
|
8470
|
+
IdmPrecip3h: y2,
|
|
8471
|
+
IdmVisibility: v2,
|
|
8472
|
+
IdmWaterTemp: I2,
|
|
8473
|
+
IdmTemp: k2,
|
|
8474
|
+
IdmArctic: j2,
|
|
8475
|
+
IdmWarZone: pb,
|
|
8476
|
+
IdmGmdssArea: cb,
|
|
8477
|
+
IdmEcaZone: tb,
|
|
8478
|
+
IdmAlertZone: nb,
|
|
8479
|
+
IdmPort: hb,
|
|
8480
|
+
IdmLoadLine: gb,
|
|
8481
|
+
IdmTimezone: Xb,
|
|
8482
|
+
IdmVRA: vb,
|
|
8483
|
+
IdmSpecialArea: xb,
|
|
8484
|
+
IdmTerminator: Pb,
|
|
8485
|
+
IdmLatLng: F0,
|
|
8486
|
+
IdmMeasure: _b,
|
|
8487
|
+
IdmPoint: Mb,
|
|
8488
|
+
IdmENC: Kb
|
|
8451
8489
|
},
|
|
8452
8490
|
props: {
|
|
8453
8491
|
map: {
|
|
@@ -8495,13 +8533,13 @@ const Hb = {
|
|
|
8495
8533
|
showCurrentParticle: !1,
|
|
8496
8534
|
enc: "",
|
|
8497
8535
|
defaultMeteoToken: "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6ImNseTVudHJzYzAwNWUwbHBsZHkyaDRqczMiLCJyb2xlIjoxLCJuYW1lIjoiZmFrZUBvcm13eC5jb20iLCJwbGF0SWQiOiJnZDBtdDFkIiwiY29tcGFueSI6eyJpZCI6bnVsbCwiY2hpbGRyZW4iOltdfSwiaWF0IjoxNzIzMDI0MDI0LCJleHAiOjM5MzA1NDQwMjR9.RrKcdcMnq-FxBLJQ-i6lx2FscDE46y8EvHIemPW4HTg",
|
|
8498
|
-
helper: new
|
|
8536
|
+
helper: new D1()
|
|
8499
8537
|
};
|
|
8500
8538
|
},
|
|
8501
8539
|
watch: {
|
|
8502
8540
|
ts: {
|
|
8503
8541
|
handler(z, M) {
|
|
8504
|
-
z && M &&
|
|
8542
|
+
z && M && G(z).utc().format("yyyy-MM-DD HH") !== G(M).utc().format("yyyy-MM-DD HH") && this.$nextTick(() => {
|
|
8505
8543
|
this.handleDateChange({ tropicals: !1 });
|
|
8506
8544
|
});
|
|
8507
8545
|
},
|
|
@@ -8509,22 +8547,22 @@ const Hb = {
|
|
|
8509
8547
|
},
|
|
8510
8548
|
map: {
|
|
8511
8549
|
handler() {
|
|
8512
|
-
this.map && (this.map.on("zoomend", this.handleDragEndWithZoom4Json), this.map.on("dragend", this.handleDragEndWithZoom4Json), this.map.on("move", this.handleDragEndWithZoom4Image), this.viewport = new
|
|
8550
|
+
this.map && (this.map.on("zoomend", this.handleDragEndWithZoom4Json), this.map.on("dragend", this.handleDragEndWithZoom4Json), this.map.on("move", this.handleDragEndWithZoom4Image), this.viewport = new D0(this.map), this.handleRampColorInitial());
|
|
8513
8551
|
},
|
|
8514
8552
|
immediate: !0
|
|
8515
8553
|
},
|
|
8516
8554
|
enc: {
|
|
8517
8555
|
handler(z, M) {
|
|
8518
|
-
var b, O, p, o,
|
|
8519
|
-
z ? ((O = (b = this.map) == null ? void 0 : b.getLayer(z)) == null || O.setLayoutProperty("visibility", "visible"), (o = (p = this.map) == null ? void 0 : p.getLayer(M)) == null || o.setLayoutProperty("visibility", "none")) : ((t = (
|
|
8556
|
+
var b, O, p, o, A, t, q, r;
|
|
8557
|
+
z ? ((O = (b = this.map) == null ? void 0 : b.getLayer(z)) == null || O.setLayoutProperty("visibility", "visible"), (o = (p = this.map) == null ? void 0 : p.getLayer(M)) == null || o.setLayoutProperty("visibility", "none")) : ((t = (A = this.map) == null ? void 0 : A.getLayer("i4")) == null || t.setLayoutProperty("visibility", "none"), (r = (q = this.map) == null ? void 0 : q.getLayer("hi")) == null || r.setLayoutProperty("visibility", "none"));
|
|
8520
8558
|
}
|
|
8521
8559
|
},
|
|
8522
8560
|
activeWeatherLayers: {
|
|
8523
8561
|
handler() {
|
|
8524
|
-
var z, M, b, O, p, o,
|
|
8562
|
+
var z, M, b, O, p, o, A, t, q, r, a, i, L, n, h, u, d, m;
|
|
8525
8563
|
if (!this.map)
|
|
8526
8564
|
return !1;
|
|
8527
|
-
this.activeWeatherLayers.length > 0 ? ((M = (z = this.map) == null ? void 0 : z.getLayer(this.enc)) == null || M.setLayoutProperty("visibility", "none"), (O = (b = this.map) == null ? void 0 : b.getLayer(this.helper.mapboxCustomer.layers.countryBoundary.id)) == null || O.setLayoutProperty("visibility", "visible"), (o = this.map) != null && o.getLayer((p = this.viewport) == null ? void 0 : p.rampColorLayer) && ((
|
|
8565
|
+
this.activeWeatherLayers.length > 0 ? ((M = (z = this.map) == null ? void 0 : z.getLayer(this.enc)) == null || M.setLayoutProperty("visibility", "none"), (O = (b = this.map) == null ? void 0 : b.getLayer(this.helper.mapboxCustomer.layers.countryBoundary.id)) == null || O.setLayoutProperty("visibility", "visible"), (o = this.map) != null && o.getLayer((p = this.viewport) == null ? void 0 : p.rampColorLayer) && ((A = this.map) != null && A.getLayer(this.helper.mapboxCustomer.layers.countryBoundary.id)) && this.mapProjection === "mercator" && ((q = this.map) == null || q.moveLayer((t = this.viewport) == null ? void 0 : t.rampColorLayer, this.helper.mapboxCustomer.layers.countryBoundary.id)), (a = this.map) != null && a.getLayer((r = this.viewport) == null ? void 0 : r.particleLayer) && ((i = this.map) != null && i.getLayer(this.helper.mapboxCustomer.layers.countryBoundary.id)) && this.mapProjection === "mercator" && ((n = this.map) == null || n.moveLayer((L = this.viewport) == null ? void 0 : L.particleLayer, this.helper.mapboxCustomer.layers.countryBoundary.id))) : ((u = (h = this.map) == null ? void 0 : h.getLayer(this.enc)) == null || u.setLayoutProperty("visibility", "visible"), (m = (d = this.map) == null ? void 0 : d.getLayer(this.helper.mapboxCustomer.layers.countryBoundary.id)) == null || m.setLayoutProperty("visibility", "none")), this.$emit("activeWeatherLayers", this.activeWeatherLayers);
|
|
8528
8566
|
},
|
|
8529
8567
|
immediate: !0
|
|
8530
8568
|
},
|
|
@@ -8576,7 +8614,7 @@ const Hb = {
|
|
|
8576
8614
|
},
|
|
8577
8615
|
methods: {
|
|
8578
8616
|
async fetchWeatherLayers(z = { tropicals: !1 }) {
|
|
8579
|
-
var p, o,
|
|
8617
|
+
var p, o, A, t, q, r, a, i;
|
|
8580
8618
|
const M = (/* @__PURE__ */ new Date()).valueOf();
|
|
8581
8619
|
let b = 0, O = 0;
|
|
8582
8620
|
if (this.map) {
|
|
@@ -8591,44 +8629,44 @@ const Hb = {
|
|
|
8591
8629
|
if (this.weatherWeight > 0) {
|
|
8592
8630
|
let u = this.weatherWeight, d;
|
|
8593
8631
|
if (z.tropicals || this.weatherWeight & 256 && (d = this.weatherLayers.tropicals, d && (u -= 256, d.version = Math.random() + 1)), u > 0) {
|
|
8594
|
-
const m = await
|
|
8632
|
+
const m = await N0.get(`${this.gateway}/api/arc/weather/layers/links?l=${u}&v=${this.source}&z=${L}&bbox=${h}&t=${this.ts}`, {
|
|
8595
8633
|
headers: {
|
|
8596
8634
|
Authorization: this.token || this.defaultMeteoToken
|
|
8597
8635
|
}
|
|
8598
8636
|
});
|
|
8599
|
-
if (O = (/* @__PURE__ */ new Date()).valueOf() - (M + b), console.log("weather links elapsed: ", O, ", total: ", b += O), ((
|
|
8637
|
+
if (O = (/* @__PURE__ */ new Date()).valueOf() - (M + b), console.log("weather links elapsed: ", O, ", total: ", b += O), ((A = m == null ? void 0 : m.data) == null ? void 0 : A.code) === 0) {
|
|
8600
8638
|
const R = (t = m == null ? void 0 : m.data) == null ? void 0 : t.data, X = [];
|
|
8601
|
-
for (const
|
|
8602
|
-
|
|
8603
|
-
|
|
8639
|
+
for (const y in R)
|
|
8640
|
+
y === "ice-edge" && (R[y] = "https://idm-hz.oss-cn-hangzhou.aliyuncs.com/test/sea_ice_contours.geojson"), y !== "tropicals" && X.push(
|
|
8641
|
+
N0.get(R[y], {
|
|
8604
8642
|
headers: {
|
|
8605
8643
|
Authorization: this.token || this.defaultMeteoToken,
|
|
8606
|
-
key:
|
|
8644
|
+
key: y
|
|
8607
8645
|
},
|
|
8608
|
-
responseType: /\.(jpg|png)$/.test(R[
|
|
8609
|
-
}).catch((
|
|
8610
|
-
console.log(`[${
|
|
8646
|
+
responseType: /\.(jpg|png)$/.test(R[y]) ? "blob" : "json"
|
|
8647
|
+
}).catch((_) => {
|
|
8648
|
+
console.log(`[${y}] fetch layer error: ${_}`);
|
|
8611
8649
|
})
|
|
8612
8650
|
);
|
|
8613
|
-
const
|
|
8614
|
-
this.weatherLayers = {},
|
|
8615
|
-
var
|
|
8616
|
-
const
|
|
8617
|
-
|
|
8618
|
-
raw:
|
|
8619
|
-
type: ((
|
|
8651
|
+
const E = await Promise.all(X);
|
|
8652
|
+
this.weatherLayers = {}, E.map((y) => {
|
|
8653
|
+
var Z, M0, N, x;
|
|
8654
|
+
const _ = ((Z = y == null ? void 0 : y.data) == null ? void 0 : Z.data) || (y == null ? void 0 : y.data), J = (N = (M0 = y == null ? void 0 : y.config) == null ? void 0 : M0.headers) == null ? void 0 : N.key;
|
|
8655
|
+
J && _ && (this.weatherLayers[J] = {
|
|
8656
|
+
raw: _,
|
|
8657
|
+
type: ((x = y == null ? void 0 : y.config) == null ? void 0 : x.responseType) === "blob" ? "image" : "json",
|
|
8620
8658
|
etime: this.ts
|
|
8621
8659
|
});
|
|
8622
|
-
}), R.tropicals &&
|
|
8660
|
+
}), R.tropicals && N0.get(R.tropicals, {
|
|
8623
8661
|
headers: {
|
|
8624
8662
|
Authorization: this.token || this.defaultMeteoToken,
|
|
8625
8663
|
key: "tropicals"
|
|
8626
8664
|
}
|
|
8627
|
-
}).then((
|
|
8628
|
-
var
|
|
8629
|
-
const
|
|
8630
|
-
this.weatherLayers[
|
|
8631
|
-
data:
|
|
8665
|
+
}).then((y) => {
|
|
8666
|
+
var Z, M0, N;
|
|
8667
|
+
const _ = Q0.convert2Geojson(((Z = y == null ? void 0 : y.data) == null ? void 0 : Z.data) || (y == null ? void 0 : y.data)), J = (N = (M0 = y == null ? void 0 : y.config) == null ? void 0 : M0.headers) == null ? void 0 : N.key;
|
|
8668
|
+
this.weatherLayers[J] = {
|
|
8669
|
+
data: _,
|
|
8632
8670
|
active: !0,
|
|
8633
8671
|
cached: !1,
|
|
8634
8672
|
type: "json",
|
|
@@ -8667,10 +8705,10 @@ const Hb = {
|
|
|
8667
8705
|
if (this.map) {
|
|
8668
8706
|
let o = this.otherWeight;
|
|
8669
8707
|
if (o) {
|
|
8670
|
-
let
|
|
8671
|
-
if (this.otherWeight & 2048 && (o = this.otherWeight - 2048,
|
|
8708
|
+
let A = !1;
|
|
8709
|
+
if (this.otherWeight & 2048 && (o = this.otherWeight - 2048, A = !0), o) {
|
|
8672
8710
|
if (z.all) {
|
|
8673
|
-
const t = await
|
|
8711
|
+
const t = await N0.get(`${this.gateway}/api/arc/other/layers/links?l=${o}&t=${this.ts}`, {
|
|
8674
8712
|
headers: {
|
|
8675
8713
|
Authorization: this.token || this.defaultMeteoToken
|
|
8676
8714
|
}
|
|
@@ -8679,7 +8717,7 @@ const Hb = {
|
|
|
8679
8717
|
const q = (b = t == null ? void 0 : t.data) == null ? void 0 : b.data, r = [];
|
|
8680
8718
|
for (const i in q)
|
|
8681
8719
|
r.push(
|
|
8682
|
-
|
|
8720
|
+
N0.get(q[i], {
|
|
8683
8721
|
headers: {
|
|
8684
8722
|
Authorization: this.token || this.defaultMeteoToken,
|
|
8685
8723
|
key: i
|
|
@@ -8687,14 +8725,14 @@ const Hb = {
|
|
|
8687
8725
|
})
|
|
8688
8726
|
);
|
|
8689
8727
|
const a = await Promise.all(r);
|
|
8690
|
-
this.otherLayers = { enc:
|
|
8728
|
+
this.otherLayers = { enc: A }, a.map((i) => {
|
|
8691
8729
|
var h, u, d;
|
|
8692
8730
|
const L = ((h = i == null ? void 0 : i.data) == null ? void 0 : h.data) || (i == null ? void 0 : i.data), n = (d = (u = i == null ? void 0 : i.config) == null ? void 0 : u.headers) == null ? void 0 : d.key;
|
|
8693
8731
|
this.otherLayers[n] = L;
|
|
8694
8732
|
});
|
|
8695
8733
|
}
|
|
8696
8734
|
} else if (z.dayNight && o & 1024) {
|
|
8697
|
-
const t = await
|
|
8735
|
+
const t = await N0.get(`${this.gateway}/api/arc/other/layers/links?l=1024&t=${this.ts}`, {
|
|
8698
8736
|
headers: {
|
|
8699
8737
|
Authorization: this.token || this.defaultMeteoToken
|
|
8700
8738
|
}
|
|
@@ -8703,7 +8741,7 @@ const Hb = {
|
|
|
8703
8741
|
const q = (p = t == null ? void 0 : t.data) == null ? void 0 : p.data, r = [];
|
|
8704
8742
|
for (const i in q)
|
|
8705
8743
|
r.push(
|
|
8706
|
-
|
|
8744
|
+
N0.get(q[i], {
|
|
8707
8745
|
headers: {
|
|
8708
8746
|
Authorization: this.token || this.defaultMeteoToken,
|
|
8709
8747
|
key: i
|
|
@@ -8718,7 +8756,7 @@ const Hb = {
|
|
|
8718
8756
|
}
|
|
8719
8757
|
}
|
|
8720
8758
|
} else
|
|
8721
|
-
this.otherLayers = { enc:
|
|
8759
|
+
this.otherLayers = { enc: A };
|
|
8722
8760
|
} else
|
|
8723
8761
|
this.otherLayers = {};
|
|
8724
8762
|
this.handleBeforeLayerToggle();
|
|
@@ -8734,7 +8772,7 @@ const Hb = {
|
|
|
8734
8772
|
this.activeWindLayer = !!this.activeWeatherLayers.find((M) => M.key === "wind"), this.$refs.layer && (this.$refs.layer.activeWeatherLayers = this.activeWeatherLayers);
|
|
8735
8773
|
},
|
|
8736
8774
|
handleRampColorInitial() {
|
|
8737
|
-
var z, M, b, O, p, o,
|
|
8775
|
+
var z, M, b, O, p, o, A, t, q, r, a, i;
|
|
8738
8776
|
this.viewport.map.getSource((z = this.viewport) == null ? void 0 : z.rampColorSource) || this.viewport.map.addSource((M = this.viewport) == null ? void 0 : M.rampColorSource, {
|
|
8739
8777
|
type: "canvas",
|
|
8740
8778
|
canvas: (b = this.viewport) == null ? void 0 : b.rampColorCanvas,
|
|
@@ -8750,7 +8788,7 @@ const Hb = {
|
|
|
8750
8788
|
}
|
|
8751
8789
|
},
|
|
8752
8790
|
this.beforeLayer
|
|
8753
|
-
), this.viewport.map.getSource((
|
|
8791
|
+
), this.viewport.map.getSource((A = this.viewport) == null ? void 0 : A.particleSource) || this.viewport.map.addSource((t = this.viewport) == null ? void 0 : t.particleSource, {
|
|
8754
8792
|
type: "canvas",
|
|
8755
8793
|
canvas: (q = this.viewport) == null ? void 0 : q.particleCanvas,
|
|
8756
8794
|
animate: !0,
|
|
@@ -8771,7 +8809,7 @@ const Hb = {
|
|
|
8771
8809
|
var r, a, i, L;
|
|
8772
8810
|
const z = (/* @__PURE__ */ new Date()).valueOf();
|
|
8773
8811
|
let M = 0, b = 0;
|
|
8774
|
-
const O = (r = this.map) == null ? void 0 : r.getBounds(), p = this.map.getZoom(), o =
|
|
8812
|
+
const O = (r = this.map) == null ? void 0 : r.getBounds(), p = this.map.getZoom(), o = b0.convertToStdLng(O._sw.lng), A = b0.convertToStdLng(O._ne.lng), t = Math.floor(O._sw.lat), q = Math.ceil(O._ne.lat);
|
|
8775
8813
|
for (const n in this.weatherLayers)
|
|
8776
8814
|
if (this.weatherLayers[n].active && this.weatherLayers[n].type === "json") {
|
|
8777
8815
|
this.weatherLayers[n].active = !1, this.weatherLayers[n].version = Math.random() + 1;
|
|
@@ -8781,23 +8819,23 @@ const Hb = {
|
|
|
8781
8819
|
for (const d in u)
|
|
8782
8820
|
if (d > t && d < q && (!(p <= this.zoom) || d % (p < this.zoom / 2 ? 5 : 3) === 0)) {
|
|
8783
8821
|
const m = u[d].lng;
|
|
8784
|
-
o >
|
|
8785
|
-
var
|
|
8786
|
-
if ((R >= o && R <= 180 || R >= -180 && R <=
|
|
8787
|
-
const
|
|
8822
|
+
o > A ? m.forEach((R, X) => {
|
|
8823
|
+
var E;
|
|
8824
|
+
if ((R >= o && R <= 180 || R >= -180 && R <= A) && (!(p <= this.zoom) || R % (p < this.zoom / 2 ? 5 : 3) === 0)) {
|
|
8825
|
+
const y = v.point([R, d], {
|
|
8788
8826
|
val: u[d].val[X],
|
|
8789
|
-
spd: (
|
|
8827
|
+
spd: (E = u[d].spd) == null ? void 0 : E[X]
|
|
8790
8828
|
});
|
|
8791
|
-
h.push(
|
|
8829
|
+
h.push(y);
|
|
8792
8830
|
}
|
|
8793
8831
|
}) : m.forEach((R, X) => {
|
|
8794
|
-
var
|
|
8795
|
-
if (R >= o && R <=
|
|
8796
|
-
const
|
|
8832
|
+
var E;
|
|
8833
|
+
if (R >= o && R <= A && (!(p <= this.zoom) || R % (p < this.zoom / 2 ? 5 : 3) === 0)) {
|
|
8834
|
+
const y = v.point([R, d], {
|
|
8797
8835
|
val: u[d].val[X],
|
|
8798
|
-
spd: (
|
|
8836
|
+
spd: (E = u[d].spd) == null ? void 0 : E[X]
|
|
8799
8837
|
});
|
|
8800
|
-
h.push(
|
|
8838
|
+
h.push(y);
|
|
8801
8839
|
}
|
|
8802
8840
|
});
|
|
8803
8841
|
}
|
|
@@ -8808,13 +8846,13 @@ const Hb = {
|
|
|
8808
8846
|
const m = [];
|
|
8809
8847
|
for (const R in (i = d.raw) == null ? void 0 : i.LineString) {
|
|
8810
8848
|
const X = d.raw.LineString[R];
|
|
8811
|
-
for (const
|
|
8849
|
+
for (const E of X)
|
|
8812
8850
|
m.push(
|
|
8813
|
-
|
|
8851
|
+
v.lineString(E, {
|
|
8814
8852
|
val: Number(R)
|
|
8815
8853
|
})
|
|
8816
8854
|
);
|
|
8817
|
-
d.data =
|
|
8855
|
+
d.data = v.featureCollection(m);
|
|
8818
8856
|
}
|
|
8819
8857
|
}
|
|
8820
8858
|
if (d.data) {
|
|
@@ -8830,15 +8868,15 @@ const Hb = {
|
|
|
8830
8868
|
if (!d.data) {
|
|
8831
8869
|
const R = [];
|
|
8832
8870
|
for (const X in (L = d.raw) == null ? void 0 : L.Polygon) {
|
|
8833
|
-
const
|
|
8834
|
-
for (const
|
|
8871
|
+
const E = d.raw.Polygon[X];
|
|
8872
|
+
for (const y of E)
|
|
8835
8873
|
R.push(
|
|
8836
|
-
|
|
8874
|
+
v.polygon(y, {
|
|
8837
8875
|
val: Number(X)
|
|
8838
8876
|
})
|
|
8839
8877
|
);
|
|
8840
8878
|
}
|
|
8841
|
-
d.data =
|
|
8879
|
+
d.data = v.featureCollection(R);
|
|
8842
8880
|
}
|
|
8843
8881
|
const m = p < this.zoom ? d.data.features.filter((R) => R.properties.val > 0.5) : d.data.features;
|
|
8844
8882
|
h = h.concat(m), b = (/* @__PURE__ */ new Date()).valueOf() - (z + M), console.log("speed elapsed: ", b, ", total: ", M += b);
|
|
@@ -8849,21 +8887,21 @@ const Hb = {
|
|
|
8849
8887
|
for (const d in u)
|
|
8850
8888
|
if (d > t && d < q && (!(p <= this.zoom) || d % (p < this.zoom / 2 ? 5 : 3) === 0)) {
|
|
8851
8889
|
const m = u[d].lng;
|
|
8852
|
-
o >
|
|
8853
|
-
if ((R >= o && R <= 180 || R >= -180 && R <=
|
|
8854
|
-
const
|
|
8890
|
+
o > A ? m.forEach((R, X) => {
|
|
8891
|
+
if ((R >= o && R <= 180 || R >= -180 && R <= A) && (!(p <= this.zoom) || R % (p < this.zoom / 2 ? 5 : 3) === 0)) {
|
|
8892
|
+
const E = v.point([R, d], {
|
|
8855
8893
|
val: u[d].val[X],
|
|
8856
8894
|
spd: u[d].spd[X]
|
|
8857
8895
|
});
|
|
8858
|
-
h.push(
|
|
8896
|
+
h.push(E);
|
|
8859
8897
|
}
|
|
8860
8898
|
}) : m.forEach((R, X) => {
|
|
8861
|
-
if (R >= o && R <=
|
|
8862
|
-
const
|
|
8899
|
+
if (R >= o && R <= A && (!(p <= this.zoom) || R % (p < this.zoom / 2 ? 5 : 3) === 0)) {
|
|
8900
|
+
const E = v.point([R, d], {
|
|
8863
8901
|
val: u[d].val[X],
|
|
8864
8902
|
spd: u[d].spd[X]
|
|
8865
8903
|
});
|
|
8866
|
-
h.push(
|
|
8904
|
+
h.push(E);
|
|
8867
8905
|
}
|
|
8868
8906
|
});
|
|
8869
8907
|
}
|
|
@@ -8879,7 +8917,7 @@ const Hb = {
|
|
|
8879
8917
|
const R = u.Polygon[m];
|
|
8880
8918
|
for (const X of R)
|
|
8881
8919
|
d.push(
|
|
8882
|
-
|
|
8920
|
+
v.polygon(X, {
|
|
8883
8921
|
val: Number(m)
|
|
8884
8922
|
})
|
|
8885
8923
|
);
|
|
@@ -8888,7 +8926,7 @@ const Hb = {
|
|
|
8888
8926
|
const R = u.Point[m];
|
|
8889
8927
|
for (const X of R)
|
|
8890
8928
|
d.push(
|
|
8891
|
-
...
|
|
8929
|
+
...v.points(X, {
|
|
8892
8930
|
val: Number(m)
|
|
8893
8931
|
}).features
|
|
8894
8932
|
);
|
|
@@ -8908,15 +8946,15 @@ const Hb = {
|
|
|
8908
8946
|
const R = u.LineString[m];
|
|
8909
8947
|
for (const X of R)
|
|
8910
8948
|
d.push(
|
|
8911
|
-
|
|
8949
|
+
v.lineString(X, {
|
|
8912
8950
|
val: Number(m)
|
|
8913
8951
|
})
|
|
8914
8952
|
);
|
|
8915
8953
|
}
|
|
8916
8954
|
for (const m in u.Point)
|
|
8917
8955
|
u.Point[m].lng.forEach((R, X) => {
|
|
8918
|
-
R =
|
|
8919
|
-
|
|
8956
|
+
R = b0.convertToStdLng(R), d.push(
|
|
8957
|
+
v.point([R, m], {
|
|
8920
8958
|
val: u.Point[m].val[X],
|
|
8921
8959
|
type: u.Point[m].type[X]
|
|
8922
8960
|
})
|
|
@@ -8937,7 +8975,7 @@ const Hb = {
|
|
|
8937
8975
|
const R = u.LineString[m];
|
|
8938
8976
|
for (const X of R)
|
|
8939
8977
|
d.push(
|
|
8940
|
-
|
|
8978
|
+
v.lineString(X, {
|
|
8941
8979
|
val: Number(m)
|
|
8942
8980
|
})
|
|
8943
8981
|
);
|
|
@@ -8947,7 +8985,7 @@ const Hb = {
|
|
|
8947
8985
|
}
|
|
8948
8986
|
b = (/* @__PURE__ */ new Date()).valueOf() - (z + M);
|
|
8949
8987
|
}
|
|
8950
|
-
console.log(n, " elapsed: ", b, ", total: ", M += b), h.length && (this.weatherLayers[n].data =
|
|
8988
|
+
console.log(n, " elapsed: ", b, ", total: ", M += b), h.length && (this.weatherLayers[n].data = v.featureCollection(h)), this.weatherLayers[n].active = !0, this.weatherLayers[n].version = Math.random() + 1;
|
|
8951
8989
|
}
|
|
8952
8990
|
},
|
|
8953
8991
|
handleDragEndWithZoom4Image() {
|
|
@@ -8955,14 +8993,14 @@ const Hb = {
|
|
|
8955
8993
|
this.weatherLayers[z].active && this.weatherLayers[z].type === "image" && (this.weatherLayers[z].active = !0, this.weatherLayers[z].version = Math.random() + 1);
|
|
8956
8994
|
},
|
|
8957
8995
|
handleBboxClip(z, M) {
|
|
8958
|
-
const b = [], O =
|
|
8996
|
+
const b = [], O = b0.convertToStdLng(M._sw.lng), p = b0.convertToStdLng(M._ne.lng);
|
|
8959
8997
|
return z.features.forEach((o) => {
|
|
8960
8998
|
if (o.geometry.type !== "Point")
|
|
8961
8999
|
if (O > p) {
|
|
8962
|
-
let
|
|
8963
|
-
t.geometry.coordinates.length && b.push(t),
|
|
9000
|
+
let A = [O, M._sw.lat, 180, M._ne.lat], t = v.bboxClip(o, A);
|
|
9001
|
+
t.geometry.coordinates.length && b.push(t), A = [-180, M._sw.lat, p, M._ne.lat], t = v.bboxClip(o, A), t.geometry.coordinates.length && b.push(t);
|
|
8964
9002
|
} else {
|
|
8965
|
-
const
|
|
9003
|
+
const A = [O, M._sw.lat, p, M._ne.lat], t = v.bboxClip(o, A);
|
|
8966
9004
|
t.geometry.coordinates.length && b.push(t);
|
|
8967
9005
|
}
|
|
8968
9006
|
else
|
|
@@ -8980,8 +9018,8 @@ const Hb = {
|
|
|
8980
9018
|
this.handleBeforeLayerToggle();
|
|
8981
9019
|
},
|
|
8982
9020
|
handleBeforeLayerToggle() {
|
|
8983
|
-
var z, M, b, O, p, o,
|
|
8984
|
-
(z = this.map) != null && z.getLayer(this.beforeLayer) && ((M = this.activeWeatherLayers) != null && M.length || (b = this.otherLayers) != null && b["war-zones"] || (O = this.otherLayers) != null && O["gmdss-areas"] || (p = this.otherLayers) != null && p["load-lines"] || (o = this.otherLayers) != null && o["high-risk-area"] || (
|
|
9021
|
+
var z, M, b, O, p, o, A, t, q, r, a, i, L;
|
|
9022
|
+
(z = this.map) != null && z.getLayer(this.beforeLayer) && ((M = this.activeWeatherLayers) != null && M.length || (b = this.otherLayers) != null && b["war-zones"] || (O = this.otherLayers) != null && O["gmdss-areas"] || (p = this.otherLayers) != null && p["load-lines"] || (o = this.otherLayers) != null && o["high-risk-area"] || (A = this.otherLayers) != null && A["time-zones"] || (t = this.otherLayers) != null && t.pirates || (q = this.otherLayers) != null && q.ports || (r = this.otherLayers) != null && r.enc || (a = this.otherLayers) != null && a["voluntary-reporting-area"] || (i = this.otherLayers) != null && i["eca-zones"] || (L = this.otherLayers) != null && L["special-area"]) && this.map.setLayoutProperty(this.beforeLayer, "visibility", "visible");
|
|
8985
9023
|
},
|
|
8986
9024
|
handleDateChange(z = { tropicals: !1 }) {
|
|
8987
9025
|
this.fetchWeatherLayers(z), this.fetchOtherLayers({ dayNight: !0 });
|
|
@@ -8991,14 +9029,14 @@ const Hb = {
|
|
|
8991
9029
|
this.activeWeatherLayers = JSON.parse(JSON.stringify(z));
|
|
8992
9030
|
const b = this.activeWeatherLayers.some(
|
|
8993
9031
|
(o) => {
|
|
8994
|
-
var
|
|
8995
|
-
return ["wind", "current"].includes(o.key) && (!((
|
|
9032
|
+
var A;
|
|
9033
|
+
return ["wind", "current"].includes(o.key) && (!((A = Object.keys(o)) != null && A.some((t) => t === "particle")) || !!o.particle);
|
|
8996
9034
|
}
|
|
8997
9035
|
), O = this.activeWeatherLayers.some((o) => ["png", "jpg"].includes(o.type));
|
|
8998
9036
|
b && !O ? (this.activeWeatherLayers.forEach((o) => {
|
|
8999
9037
|
o.key === "wind" && o.particle && (this.particleFactor = o, this.showWindParticle = !0), o.key === "current" && o.particle && (this.particleFactor = o, this.showCurrentParticle = !0);
|
|
9000
9038
|
}), this.particleFactor.particle = !0) : O && this.particleFactor && (this.particleFactor.particle = !1);
|
|
9001
|
-
const p = z == null ? void 0 : z.reduce((o,
|
|
9039
|
+
const p = z == null ? void 0 : z.reduce((o, A) => o + (o & (A == null ? void 0 : A.weight) ? 0 : A == null ? void 0 : A.weight), 0);
|
|
9002
9040
|
this.weatherWeight !== p || this.source !== M ? (this.source = M, this.weatherWeight = p, this.fetchWeatherLayers({ tropicals: !1 })) : this.handleWeatherLayerToggle();
|
|
9003
9041
|
}) : setTimeout(() => {
|
|
9004
9042
|
this.handleWeatherLayerChange(z, M);
|
|
@@ -9015,8 +9053,8 @@ const Hb = {
|
|
|
9015
9053
|
}
|
|
9016
9054
|
},
|
|
9017
9055
|
handle3dToggle(z) {
|
|
9018
|
-
var M, b, O, p, o,
|
|
9019
|
-
z ? (this.map.setProjection("globe"), this.mapProjection = "globe", (b = this.map) != null && b.getLayer((M = this.viewport) == null ? void 0 : M.rampColorLayer) && ((O = this.map) != null && O.getLayer(this.helper.mapboxCustomer.layers.water.id)) && ((o = this.map) == null || o.moveLayer((p = this.viewport) == null ? void 0 : p.rampColorLayer, this.helper.mapboxCustomer.layers.water.id)), (t = this.map) != null && t.getLayer((
|
|
9056
|
+
var M, b, O, p, o, A, t, q, r, a, i, L, n, h, u, d, m, R, X, E;
|
|
9057
|
+
z ? (this.map.setProjection("globe"), this.mapProjection = "globe", (b = this.map) != null && b.getLayer((M = this.viewport) == null ? void 0 : M.rampColorLayer) && ((O = this.map) != null && O.getLayer(this.helper.mapboxCustomer.layers.water.id)) && ((o = this.map) == null || o.moveLayer((p = this.viewport) == null ? void 0 : p.rampColorLayer, this.helper.mapboxCustomer.layers.water.id)), (t = this.map) != null && t.getLayer((A = this.viewport) == null ? void 0 : A.particleLayer) && ((q = this.map) != null && q.getLayer(this.helper.mapboxCustomer.layers.water.id)) && ((a = this.map) == null || a.moveLayer((r = this.viewport) == null ? void 0 : r.particleLayer, this.helper.mapboxCustomer.layers.water.id)), this.map.off("zoomend", this.handleDragEndWithZoom4Json), this.map.off("dragend", this.handleDragEndWithZoom4Json), this.map.off("move", this.handleDragEndWithZoom4Image)) : (this.map.setProjection("mercator"), this.mapProjection = "mercator", this.map.on("zoomend", this.handleDragEndWithZoom4Json), this.map.on("dragend", this.handleDragEndWithZoom4Json), this.map.on("move", this.handleDragEndWithZoom4Image), this.handleDragEndWithZoom4Image(), this.handleDragEndWithZoom4Json(), (L = this.map) != null && L.getLayer((i = this.viewport) == null ? void 0 : i.rampColorLayer) && ((n = this.map) != null && n.getLayer(this.helper.mapboxCustomer.layers.countryBoundary.id)) && ((u = this.map) == null || u.moveLayer((h = this.viewport) == null ? void 0 : h.rampColorLayer, this.helper.mapboxCustomer.layers.countryBoundary.id)), (m = this.map) != null && m.getLayer((d = this.viewport) == null ? void 0 : d.particleLayer) && ((R = this.map) != null && R.getLayer(this.helper.mapboxCustomer.layers.countryBoundary.id)) && ((E = this.map) == null || E.moveLayer((X = this.viewport) == null ? void 0 : X.particleLayer, this.helper.mapboxCustomer.layers.countryBoundary.id)));
|
|
9020
9058
|
},
|
|
9021
9059
|
handleParticle(z) {
|
|
9022
9060
|
this.particleFactor = z, this.weatherLayers[z.key] && (this.weatherLayers[z.key].particle = z.particle), this.activeWeatherLayers.map((O) => {
|
|
@@ -9034,15 +9072,15 @@ const Hb = {
|
|
|
9034
9072
|
this.$emit("toggleVersion", Math.random());
|
|
9035
9073
|
}
|
|
9036
9074
|
}
|
|
9037
|
-
},
|
|
9075
|
+
}, Yb = {
|
|
9038
9076
|
key: 0,
|
|
9039
9077
|
className: "map-gl-home"
|
|
9040
9078
|
};
|
|
9041
9079
|
function Vb(z, M, b, O, p, o) {
|
|
9042
|
-
var
|
|
9043
|
-
const
|
|
9044
|
-
return b.map ? (
|
|
9045
|
-
|
|
9080
|
+
var W0, n0, l0, B0, f0, S, p0, a0, D, O0, u0, A0, R0, g, e, l, f, B, w, P, $, k, U, v0, P0, S0;
|
|
9081
|
+
const A = I("IdmGlLayer"), t = I("IdmENC"), q = I("IdmSigWave"), r = I("IdmSwell"), a = I("IdmPrmsl"), i = I("IdmIceberg"), L = I("IdmTropicals"), n = I("IdmCurrents"), h = I("IdmCurrentParticle"), u = I("IdmWindBarb"), d = I("IdmWindParticle"), m = I("IdmPrecip3h"), R = I("IdmVisibility"), X = I("IdmWaterTemp"), E = I("IdmTemp"), y = I("IdmArctic"), _ = I("IdmWarZone"), J = I("IdmGmdssArea"), Z = I("IdmEcaZone"), M0 = I("IdmAlertZone"), N = I("IdmPort"), x = I("IdmLoadLine"), d0 = I("IdmTimezone"), s0 = I("IdmVRA"), r0 = I("IdmSpecialArea"), L0 = I("IdmTerminator"), o0 = I("IdmLatLng"), h0 = I("IdmMeasure"), m0 = I("IdmPoint");
|
|
9082
|
+
return b.map ? (s(), W("div", Yb, [
|
|
9083
|
+
C(A, H({
|
|
9046
9084
|
ref: "layer",
|
|
9047
9085
|
map: b.map,
|
|
9048
9086
|
"toggle-version": b.toggleVersion,
|
|
@@ -9054,57 +9092,57 @@ function Vb(z, M, b, O, p, o) {
|
|
|
9054
9092
|
}, z.$attrs, {
|
|
9055
9093
|
onWeather: o.handleWeatherLayerChange,
|
|
9056
9094
|
onOther: o.handleOtherLayerChange,
|
|
9057
|
-
onToggleWindParticle: M[0] || (M[0] = (
|
|
9058
|
-
onToggleWindFeather: M[1] || (M[1] = (
|
|
9059
|
-
onToggleCurrentParticle: M[2] || (M[2] = (
|
|
9060
|
-
onToggleCurrentIsoband: M[3] || (M[3] = (
|
|
9061
|
-
onCoordinate: M[4] || (M[4] = (
|
|
9062
|
-
onMeasure: M[5] || (M[5] = (
|
|
9063
|
-
onPoint: M[6] || (M[6] = (
|
|
9095
|
+
onToggleWindParticle: M[0] || (M[0] = (q0) => p.showWindParticle = q0),
|
|
9096
|
+
onToggleWindFeather: M[1] || (M[1] = (q0) => p.showWindFeather = q0),
|
|
9097
|
+
onToggleCurrentParticle: M[2] || (M[2] = (q0) => p.showCurrentParticle = q0),
|
|
9098
|
+
onToggleCurrentIsoband: M[3] || (M[3] = (q0) => p.showCurrentIsoband = q0),
|
|
9099
|
+
onCoordinate: M[4] || (M[4] = (q0) => p.showCoord = q0),
|
|
9100
|
+
onMeasure: M[5] || (M[5] = (q0) => p.showMeasure = q0),
|
|
9101
|
+
onPoint: M[6] || (M[6] = (q0) => p.showPoint = q0),
|
|
9064
9102
|
on3d: o.handle3dToggle,
|
|
9065
9103
|
onHandleToggleVersion: o.handleToggleVersion
|
|
9066
9104
|
}), null, 16, ["map", "toggle-version", "map-projection", "showWindFeather", "showWindParticle", "showCurrentIsoband", "showCurrentParticle", "onWeather", "onOther", "on3d", "onHandleToggleVersion"]),
|
|
9067
|
-
|
|
9105
|
+
C(t, H({
|
|
9068
9106
|
map: b.map,
|
|
9069
9107
|
token: b.token,
|
|
9070
|
-
enabled: (
|
|
9108
|
+
enabled: (W0 = p.otherLayers) == null ? void 0 : W0.enc,
|
|
9071
9109
|
"toggle-version": b.toggleVersion
|
|
9072
9110
|
}, z.$attrs, {
|
|
9073
|
-
onEnc: M[7] || (M[7] = (
|
|
9111
|
+
onEnc: M[7] || (M[7] = (q0) => p.enc = q0)
|
|
9074
9112
|
}), null, 16, ["map", "token", "enabled", "toggle-version"]),
|
|
9075
|
-
|
|
9113
|
+
C(q, H({
|
|
9076
9114
|
map: b.map,
|
|
9077
9115
|
"sig-wave": (n0 = p.weatherLayers) == null ? void 0 : n0["sig-wave-height"],
|
|
9078
9116
|
"before-layer": b.beforeLayer,
|
|
9079
9117
|
activeWeatherLayers: p.activeWeatherLayers
|
|
9080
9118
|
}, z.$attrs), null, 16, ["map", "sig-wave", "before-layer", "activeWeatherLayers"]),
|
|
9081
|
-
|
|
9119
|
+
C(r, H({
|
|
9082
9120
|
map: b.map,
|
|
9083
|
-
swell: (
|
|
9121
|
+
swell: (l0 = p.weatherLayers) == null ? void 0 : l0.swell,
|
|
9084
9122
|
"before-layer": b.beforeLayer,
|
|
9085
9123
|
activeWeatherLayers: p.activeWeatherLayers
|
|
9086
9124
|
}, z.$attrs), null, 16, ["map", "swell", "before-layer", "activeWeatherLayers"]),
|
|
9087
|
-
|
|
9125
|
+
C(a, H({
|
|
9088
9126
|
map: b.map,
|
|
9089
|
-
prmsl: (
|
|
9127
|
+
prmsl: (B0 = p.weatherLayers) == null ? void 0 : B0.prmsl,
|
|
9090
9128
|
"before-layer": b.beforeLayer,
|
|
9091
9129
|
"active-weather-layers": p.activeWeatherLayers
|
|
9092
9130
|
}, z.$attrs), null, 16, ["map", "prmsl", "before-layer", "active-weather-layers"]),
|
|
9093
|
-
|
|
9131
|
+
C(i, H({
|
|
9094
9132
|
map: b.map,
|
|
9095
|
-
iceberg: (
|
|
9133
|
+
iceberg: (f0 = p.weatherLayers) == null ? void 0 : f0.iceberg,
|
|
9096
9134
|
"before-layer": b.beforeLayer
|
|
9097
9135
|
}, z.$attrs), null, 16, ["map", "iceberg", "before-layer"]),
|
|
9098
|
-
|
|
9136
|
+
C(L, H({
|
|
9099
9137
|
map: b.map,
|
|
9100
9138
|
date: b.ts,
|
|
9101
|
-
tropicals: (
|
|
9139
|
+
tropicals: (S = p.weatherLayers) == null ? void 0 : S.tropicals,
|
|
9102
9140
|
"before-layer": b.beforeLayer
|
|
9103
9141
|
}, z.$attrs), null, 16, ["map", "date", "tropicals", "before-layer"]),
|
|
9104
|
-
|
|
9142
|
+
C(n, H({
|
|
9105
9143
|
map: b.map,
|
|
9106
9144
|
"map-projection": p.mapProjection,
|
|
9107
|
-
current: (
|
|
9145
|
+
current: (p0 = p.weatherLayers) == null ? void 0 : p0.current,
|
|
9108
9146
|
"before-layer": b.beforeLayer,
|
|
9109
9147
|
showCurrentIsoband: p.showCurrentIsoband,
|
|
9110
9148
|
showCurrentParticle: p.showCurrentParticle,
|
|
@@ -9115,18 +9153,18 @@ function Vb(z, M, b, O, p, o) {
|
|
|
9115
9153
|
onParticle: o.handleParticle,
|
|
9116
9154
|
onHandleToggleVersion: o.handleToggleVersion
|
|
9117
9155
|
}), null, 16, ["map", "map-projection", "current", "before-layer", "showCurrentIsoband", "showCurrentParticle", "margin-bottom", "toggle-version", "weather-layers", "onParticle", "onHandleToggleVersion"]),
|
|
9118
|
-
|
|
9156
|
+
C(h, H({
|
|
9119
9157
|
viewport: p.viewport,
|
|
9120
|
-
factor: (
|
|
9158
|
+
factor: (a0 = p.weatherLayers) == null ? void 0 : a0["current-particle"],
|
|
9121
9159
|
"before-layer": b.beforeLayer,
|
|
9122
9160
|
"toggle-version": b.toggleVersion
|
|
9123
9161
|
}, z.$attrs), null, 16, ["viewport", "factor", "before-layer", "toggle-version"]),
|
|
9124
|
-
|
|
9162
|
+
C(u, H({
|
|
9125
9163
|
ref: "windBarb",
|
|
9126
9164
|
map: b.map,
|
|
9127
9165
|
"map-projection": p.mapProjection,
|
|
9128
|
-
wind: (
|
|
9129
|
-
current: (
|
|
9166
|
+
wind: (D = p.weatherLayers) == null ? void 0 : D.wind,
|
|
9167
|
+
current: (O0 = p.weatherLayers) == null ? void 0 : O0.current,
|
|
9130
9168
|
"before-layer": b.beforeLayer,
|
|
9131
9169
|
"margin-bottom": p.showRampColor ? "56px" : "30px",
|
|
9132
9170
|
showWindFeather: p.showWindFeather,
|
|
@@ -9136,101 +9174,101 @@ function Vb(z, M, b, O, p, o) {
|
|
|
9136
9174
|
"weather-layers": p.weatherLayers,
|
|
9137
9175
|
onParticle: o.handleParticle
|
|
9138
9176
|
}), null, 16, ["map", "map-projection", "wind", "current", "before-layer", "margin-bottom", "showWindFeather", "showWindParticle", "toggle-version", "weather-layers", "onParticle"]),
|
|
9139
|
-
|
|
9177
|
+
C(d, H({
|
|
9140
9178
|
viewport: p.viewport,
|
|
9141
|
-
factor: (
|
|
9179
|
+
factor: (u0 = p.weatherLayers) == null ? void 0 : u0["wind-particle"],
|
|
9142
9180
|
"before-layer": b.beforeLayer,
|
|
9143
9181
|
"toggle-version": b.toggleVersion
|
|
9144
9182
|
}, z.$attrs), null, 16, ["viewport", "factor", "before-layer", "toggle-version"]),
|
|
9145
|
-
|
|
9183
|
+
C(m, H({
|
|
9146
9184
|
viewport: p.viewport,
|
|
9147
|
-
factor: (
|
|
9185
|
+
factor: (A0 = p.weatherLayers) == null ? void 0 : A0.precip3h,
|
|
9148
9186
|
"before-layer": b.beforeLayer,
|
|
9149
9187
|
"toggle-version": b.toggleVersion
|
|
9150
9188
|
}, z.$attrs), null, 16, ["viewport", "factor", "before-layer", "toggle-version"]),
|
|
9151
|
-
|
|
9189
|
+
C(R, H({
|
|
9152
9190
|
viewport: p.viewport,
|
|
9153
|
-
factor: (
|
|
9191
|
+
factor: (R0 = p.weatherLayers) == null ? void 0 : R0.visibility,
|
|
9154
9192
|
"before-layer": b.beforeLayer,
|
|
9155
9193
|
"toggle-version": b.toggleVersion
|
|
9156
9194
|
}, z.$attrs), null, 16, ["viewport", "factor", "before-layer", "toggle-version"]),
|
|
9157
|
-
|
|
9195
|
+
C(X, H({
|
|
9158
9196
|
viewport: p.viewport,
|
|
9159
|
-
factor: (
|
|
9197
|
+
factor: (g = p.weatherLayers) == null ? void 0 : g["water-temp"],
|
|
9160
9198
|
"before-layer": b.beforeLayer,
|
|
9161
9199
|
"toggle-version": b.toggleVersion
|
|
9162
9200
|
}, z.$attrs), null, 16, ["viewport", "factor", "before-layer", "toggle-version"]),
|
|
9163
|
-
|
|
9201
|
+
C(E, H({
|
|
9164
9202
|
viewport: p.viewport,
|
|
9165
|
-
factor: (
|
|
9203
|
+
factor: (e = p.weatherLayers) == null ? void 0 : e.temp,
|
|
9166
9204
|
"before-layer": b.beforeLayer,
|
|
9167
9205
|
"toggle-version": b.toggleVersion
|
|
9168
9206
|
}, z.$attrs), null, 16, ["viewport", "factor", "before-layer", "toggle-version"]),
|
|
9169
|
-
|
|
9207
|
+
C(y, H({
|
|
9170
9208
|
viewport: p.viewport,
|
|
9171
|
-
factor: (
|
|
9209
|
+
factor: (l = p.weatherLayers) == null ? void 0 : l.arctic,
|
|
9172
9210
|
"before-layer": b.beforeLayer,
|
|
9173
9211
|
"toggle-version": b.toggleVersion
|
|
9174
9212
|
}, z.$attrs), null, 16, ["viewport", "factor", "before-layer", "toggle-version"]),
|
|
9175
|
-
|
|
9213
|
+
C(_, H({
|
|
9176
9214
|
map: b.map,
|
|
9177
|
-
zone: (
|
|
9215
|
+
zone: (f = p.otherLayers) == null ? void 0 : f["war-zones"],
|
|
9178
9216
|
"before-layer": b.beforeLayer
|
|
9179
9217
|
}, z.$attrs), null, 16, ["map", "zone", "before-layer"]),
|
|
9180
|
-
|
|
9218
|
+
C(J, H({
|
|
9181
9219
|
map: b.map,
|
|
9182
|
-
area: (
|
|
9220
|
+
area: (B = p.otherLayers) == null ? void 0 : B["gmdss-areas"],
|
|
9183
9221
|
"before-layer": b.beforeLayer
|
|
9184
9222
|
}, z.$attrs), null, 16, ["map", "area", "before-layer"]),
|
|
9185
|
-
|
|
9223
|
+
C(Z, H({
|
|
9186
9224
|
map: b.map,
|
|
9187
|
-
zone: (
|
|
9225
|
+
zone: (w = p.otherLayers) == null ? void 0 : w["eca-zones"],
|
|
9188
9226
|
"before-layer": b.beforeLayer
|
|
9189
9227
|
}, z.$attrs), null, 16, ["map", "zone", "before-layer"]),
|
|
9190
|
-
|
|
9228
|
+
C(M0, H({
|
|
9191
9229
|
map: b.map,
|
|
9192
9230
|
zone: (P = p.otherLayers) == null ? void 0 : P["alert-zones"],
|
|
9193
9231
|
"before-layer": b.beforeLayer
|
|
9194
9232
|
}, z.$attrs), null, 16, ["map", "zone", "before-layer"]),
|
|
9195
|
-
|
|
9233
|
+
C(N, H({
|
|
9196
9234
|
map: b.map,
|
|
9197
|
-
port: (
|
|
9235
|
+
port: ($ = p.otherLayers) == null ? void 0 : $.ports,
|
|
9198
9236
|
"before-layer": b.beforeLayer
|
|
9199
9237
|
}, z.$attrs), null, 16, ["map", "port", "before-layer"]),
|
|
9200
|
-
|
|
9238
|
+
C(x, H({
|
|
9201
9239
|
map: b.map,
|
|
9202
|
-
line: (
|
|
9240
|
+
line: (k = p.otherLayers) == null ? void 0 : k["load-lines"],
|
|
9203
9241
|
"before-layer": b.beforeLayer
|
|
9204
9242
|
}, z.$attrs), null, 16, ["map", "line", "before-layer"]),
|
|
9205
|
-
|
|
9243
|
+
C(d0, H({
|
|
9206
9244
|
map: b.map,
|
|
9207
|
-
zone: (
|
|
9245
|
+
zone: (U = p.otherLayers) == null ? void 0 : U["time-zones"],
|
|
9208
9246
|
"before-layer": b.beforeLayer
|
|
9209
9247
|
}, z.$attrs), null, 16, ["map", "zone", "before-layer"]),
|
|
9210
|
-
|
|
9248
|
+
C(s0, H({
|
|
9211
9249
|
map: b.map,
|
|
9212
|
-
area: (
|
|
9250
|
+
area: (v0 = p.otherLayers) == null ? void 0 : v0["voluntary-reporting-area"],
|
|
9213
9251
|
"before-layer": b.beforeLayer
|
|
9214
9252
|
}, z.$attrs), null, 16, ["map", "area", "before-layer"]),
|
|
9215
|
-
|
|
9253
|
+
C(r0, H({
|
|
9216
9254
|
map: b.map,
|
|
9217
9255
|
area: (P0 = p.otherLayers) == null ? void 0 : P0["special-area"],
|
|
9218
9256
|
"before-layer": b.beforeLayer
|
|
9219
9257
|
}, z.$attrs), null, 16, ["map", "area", "before-layer"]),
|
|
9220
|
-
|
|
9258
|
+
C(L0, H({
|
|
9221
9259
|
map: b.map,
|
|
9222
|
-
area: (
|
|
9260
|
+
area: (S0 = p.otherLayers) == null ? void 0 : S0["day-night"]
|
|
9223
9261
|
}, z.$attrs), null, 16, ["map", "area"]),
|
|
9224
|
-
|
|
9262
|
+
C(o0, H({
|
|
9225
9263
|
map: b.map,
|
|
9226
9264
|
show: p.showCoord,
|
|
9227
9265
|
"toggle-version": b.toggleVersion
|
|
9228
9266
|
}, z.$attrs), null, 16, ["map", "show", "toggle-version"]),
|
|
9229
|
-
|
|
9267
|
+
C(h0, H({
|
|
9230
9268
|
map: b.map,
|
|
9231
9269
|
show: p.showMeasure
|
|
9232
9270
|
}, z.$attrs), null, 16, ["map", "show"]),
|
|
9233
|
-
|
|
9271
|
+
C(m0, H({
|
|
9234
9272
|
ref: "idmPoint",
|
|
9235
9273
|
map: b.map,
|
|
9236
9274
|
show: p.showPoint,
|
|
@@ -9239,21 +9277,21 @@ function Vb(z, M, b, O, p, o) {
|
|
|
9239
9277
|
token: b.token,
|
|
9240
9278
|
gateway: p.gateway
|
|
9241
9279
|
}, z.$attrs), null, 16, ["map", "show", "meteo", "ts", "token", "gateway"])
|
|
9242
|
-
])) :
|
|
9280
|
+
])) : j("", !0);
|
|
9243
9281
|
}
|
|
9244
|
-
const
|
|
9282
|
+
const Zb = /* @__PURE__ */ Q(Jb, [["render", Vb]]), ez = {
|
|
9245
9283
|
install(z) {
|
|
9246
|
-
z.component("MapboxGL",
|
|
9284
|
+
z.component("MapboxGL", Zb), z.component("TropicalGL", H0), z.component("LatLngGL", F0);
|
|
9247
9285
|
}
|
|
9248
9286
|
};
|
|
9249
9287
|
export {
|
|
9250
|
-
|
|
9251
|
-
|
|
9252
|
-
|
|
9253
|
-
|
|
9254
|
-
|
|
9255
|
-
|
|
9256
|
-
|
|
9257
|
-
|
|
9288
|
+
F0 as LatLngGL,
|
|
9289
|
+
Zb as MapboxGL,
|
|
9290
|
+
ez as MapboxGLPlugin,
|
|
9291
|
+
D1 as MapboxHelper,
|
|
9292
|
+
i0 as ParticleSchema,
|
|
9293
|
+
H0 as TropicalGL,
|
|
9294
|
+
D0 as Viewport,
|
|
9295
|
+
C0 as WebGL,
|
|
9258
9296
|
e0 as WebGLSchema
|
|
9259
9297
|
};
|