@betarena/ad-engine 0.0.6 → 0.0.7
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/.eslintrc.yaml +164 -0
- package/package.json +34 -14
- package/src/App.svelte +8 -0
- package/src/lib/Widget-AdEngine.svelte +492 -0
- package/src/lib/Widget-AdGeneral.svelte +284 -0
- package/src/lib/Widget-AdvertSlide.svelte +384 -0
- package/src/lib/assets/icon-close.svg +9 -0
- package/src/lib/assets/icon-external-link.svg +4 -0
- package/src/lib/constants/instance.ts +10 -0
- package/src/lib/store.ts +284 -0
- package/src/lib/types/ad-engine.d.ts +21 -0
- package/src/lib/types/geojs.d.ts +83 -0
- package/src/lib/types/global.d.ts +4 -0
- package/src/lib/types/vite-env.d.ts +2 -0
- package/src/lib/utils/device.ts +37 -0
- package/src/lib/utils/fetch.ts +107 -0
- package/src/lib/utils/geo.ts +34 -0
- package/src/main.ts +17 -0
- package/vite.config.ts +29 -3
- package/dist/assets/index-Cm9IxoHj.js +0 -24
- package/dist/index.html +0 -13
- package/dist/vite.svg +0 -1
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
<svg width="23" height="23" viewBox="0 0 23 23" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
|
|
2
|
+
<rect width="23" height="23" fill="url(#pattern0)"/>
|
|
3
|
+
<defs>
|
|
4
|
+
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
|
|
5
|
+
<use xlink:href="#image0_1860_172" transform="scale(0.005)"/>
|
|
6
|
+
</pattern>
|
|
7
|
+
<image id="image0_1860_172" width="200" height="200" xlink:href=""/>
|
|
8
|
+
</defs>
|
|
9
|
+
</svg>
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
<svg width="15" height="14" viewBox="0 0 15 14" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
2
|
+
<path d="M13.1215 1.08392L1.64569 12.5597" stroke="white" stroke-width="1.73876" stroke-linecap="round" stroke-linejoin="round"/>
|
|
3
|
+
<path d="M5.06506 1.02606L13.1213 1.08286L13.1793 9.14027" stroke="white" stroke-width="1.73876" stroke-linecap="round" stroke-linejoin="round"/>
|
|
4
|
+
</svg>
|
package/src/lib/store.ts
ADDED
|
@@ -0,0 +1,284 @@
|
|
|
1
|
+
// ╭──────────────────────────────────────────────────────────────────────────────────╮
|
|
2
|
+
// │ 📌 High Order Component Overview │
|
|
3
|
+
// ┣──────────────────────────────────────────────────────────────────────────────────┫
|
|
4
|
+
// │ ➤ Internal Svelte Code Format :|: V.8.0 │
|
|
5
|
+
// │ ➤ Status :|: 🔒 LOCKED │
|
|
6
|
+
// │ ➤ Author(s) :|: @migbash │
|
|
7
|
+
// ┣──────────────────────────────────────────────────────────────────────────────────┫
|
|
8
|
+
// │ 📝 Description │
|
|
9
|
+
// ┣──────────────────────────────────────────────────────────────────────────────────┫
|
|
10
|
+
// │ > Client 'Svelte/Store' with 'LocalStorage' Persistance │
|
|
11
|
+
// ╰──────────────────────────────────────────────────────────────────────────────────╯
|
|
12
|
+
|
|
13
|
+
/* eslint-disable camelcase */
|
|
14
|
+
|
|
15
|
+
// #region ➤ 📦 Package Imports
|
|
16
|
+
|
|
17
|
+
import { writable } from 'svelte/store';
|
|
18
|
+
|
|
19
|
+
import type { IAdEngineStore } from './types/ad-engine.js';
|
|
20
|
+
|
|
21
|
+
// #endregion ➤ 📦 Package Imports
|
|
22
|
+
|
|
23
|
+
// #region ➤ 📌 VARIABLES
|
|
24
|
+
|
|
25
|
+
const
|
|
26
|
+
/**
|
|
27
|
+
* @description
|
|
28
|
+
* 📣 Target `data` store.
|
|
29
|
+
*/
|
|
30
|
+
userSettings: IAdEngineStore
|
|
31
|
+
= {
|
|
32
|
+
isBetarenaAdShownForToday: false,
|
|
33
|
+
advertDateLastShown: null
|
|
34
|
+
}
|
|
35
|
+
;
|
|
36
|
+
|
|
37
|
+
type IDataProp =
|
|
38
|
+
| 'toggleAdShownState'
|
|
39
|
+
;
|
|
40
|
+
|
|
41
|
+
// #endregion ➤ 📌 VARIABLES
|
|
42
|
+
|
|
43
|
+
// #region ➤ 🛠️ METHODS
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* @author
|
|
47
|
+
* @migbash
|
|
48
|
+
* @summary
|
|
49
|
+
* 🟥 MAIN
|
|
50
|
+
* @description
|
|
51
|
+
* - 📣 Initializer of `svelte/stores` method.
|
|
52
|
+
* - 📣 Uses `localStorage` persistance.
|
|
53
|
+
* @param { string } key
|
|
54
|
+
* 💠 Target `key` to use for `svelte-stores` / `localStorage`.
|
|
55
|
+
* @return
|
|
56
|
+
* 📤 Store logic.
|
|
57
|
+
*/
|
|
58
|
+
function createLocalStore
|
|
59
|
+
(
|
|
60
|
+
key: string
|
|
61
|
+
)
|
|
62
|
+
{
|
|
63
|
+
const
|
|
64
|
+
/**
|
|
65
|
+
* @description
|
|
66
|
+
* 📣 Default 'svelte/store' exports.
|
|
67
|
+
*/
|
|
68
|
+
{
|
|
69
|
+
subscribe,
|
|
70
|
+
set,
|
|
71
|
+
update
|
|
72
|
+
} = writable
|
|
73
|
+
(
|
|
74
|
+
userSettings
|
|
75
|
+
),
|
|
76
|
+
/**
|
|
77
|
+
* @description
|
|
78
|
+
* 📣 complementary `store` added methods.
|
|
79
|
+
*/
|
|
80
|
+
methods
|
|
81
|
+
= {
|
|
82
|
+
// ╭──────────────────────────────────────────────────────────────────────────────────╮
|
|
83
|
+
// │ 🟦 Local Helper Logic │
|
|
84
|
+
// ╰──────────────────────────────────────────────────────────────────────────────────╯
|
|
85
|
+
|
|
86
|
+
/**
|
|
87
|
+
* @author
|
|
88
|
+
* @migbash
|
|
89
|
+
* @summary
|
|
90
|
+
* - 🟥 MAIN
|
|
91
|
+
* - 🔹 HELPER
|
|
92
|
+
* - IMPORTANT
|
|
93
|
+
* @description
|
|
94
|
+
* 📣 Instantiate `localStorage` data for target `key`.
|
|
95
|
+
* @return { void }
|
|
96
|
+
*/
|
|
97
|
+
useLocalStorage:
|
|
98
|
+
(
|
|
99
|
+
): void =>
|
|
100
|
+
{
|
|
101
|
+
let
|
|
102
|
+
localStore = methods.parseLocalStorage()
|
|
103
|
+
;
|
|
104
|
+
|
|
105
|
+
// [🐞]
|
|
106
|
+
// console.log('localStore', localStore);
|
|
107
|
+
|
|
108
|
+
// ╭─────
|
|
109
|
+
// │ CHECK :|: for absent localstorage object.
|
|
110
|
+
// ╰─────
|
|
111
|
+
if (localStore == null)
|
|
112
|
+
localStore
|
|
113
|
+
= {
|
|
114
|
+
isBetarenaAdShownForToday: false,
|
|
115
|
+
advertDateLastShown: null,
|
|
116
|
+
}
|
|
117
|
+
;
|
|
118
|
+
;
|
|
119
|
+
|
|
120
|
+
// ╭─────
|
|
121
|
+
// │ CHECK :|: for already shown advert
|
|
122
|
+
// ╰─────
|
|
123
|
+
if
|
|
124
|
+
(
|
|
125
|
+
localStore.isBetarenaAdShownForToday
|
|
126
|
+
&& localStore.advertDateLastShown?.getDate() != new Date().getDate()
|
|
127
|
+
)
|
|
128
|
+
methods.updateData
|
|
129
|
+
(
|
|
130
|
+
[
|
|
131
|
+
['toggleAdShownState', undefined]
|
|
132
|
+
]
|
|
133
|
+
);
|
|
134
|
+
;
|
|
135
|
+
|
|
136
|
+
methods.setLocalStorage
|
|
137
|
+
(
|
|
138
|
+
localStore
|
|
139
|
+
);
|
|
140
|
+
|
|
141
|
+
return;
|
|
142
|
+
},
|
|
143
|
+
|
|
144
|
+
/**
|
|
145
|
+
* @author
|
|
146
|
+
* @migbash
|
|
147
|
+
* @summary
|
|
148
|
+
* - 🟥 MAIN
|
|
149
|
+
* - 🔹 HELPER
|
|
150
|
+
* - IMPORTANT
|
|
151
|
+
* @description
|
|
152
|
+
* 📣 Retrieves target `localStorage` for target `key`.
|
|
153
|
+
* @return { IAdEngineStore }
|
|
154
|
+
* 📤 Target `user` data object.
|
|
155
|
+
*/
|
|
156
|
+
parseLocalStorage:
|
|
157
|
+
(
|
|
158
|
+
): IAdEngineStore | NullUndef =>
|
|
159
|
+
{
|
|
160
|
+
const
|
|
161
|
+
localStore = localStorage.getItem(key)
|
|
162
|
+
;
|
|
163
|
+
|
|
164
|
+
if (!localStore) return null;
|
|
165
|
+
|
|
166
|
+
return JSON.parse
|
|
167
|
+
(
|
|
168
|
+
localStore
|
|
169
|
+
);
|
|
170
|
+
},
|
|
171
|
+
|
|
172
|
+
/**
|
|
173
|
+
* @author
|
|
174
|
+
* @migbash
|
|
175
|
+
* @summary
|
|
176
|
+
* - 🟥 MAIN
|
|
177
|
+
* - 🔹 HELPER
|
|
178
|
+
* - IMPORTANT
|
|
179
|
+
* @description
|
|
180
|
+
* 📣 Persists to `localStorage` target data for target `key`.
|
|
181
|
+
* @param { IAdEngineStore } data
|
|
182
|
+
* 💠 **[required]** Target `user` data to be persisted.
|
|
183
|
+
* @return { void }
|
|
184
|
+
*/
|
|
185
|
+
setLocalStorage:
|
|
186
|
+
(
|
|
187
|
+
data: IAdEngineStore
|
|
188
|
+
): void =>
|
|
189
|
+
{
|
|
190
|
+
localStorage.setItem
|
|
191
|
+
(
|
|
192
|
+
key,
|
|
193
|
+
JSON.stringify
|
|
194
|
+
(
|
|
195
|
+
data
|
|
196
|
+
)
|
|
197
|
+
);
|
|
198
|
+
|
|
199
|
+
set
|
|
200
|
+
(
|
|
201
|
+
data
|
|
202
|
+
);
|
|
203
|
+
|
|
204
|
+
return;
|
|
205
|
+
},
|
|
206
|
+
|
|
207
|
+
// ╭──────────────────────────────────────────────────────────────────────────────────╮
|
|
208
|
+
// │ 📣 Main Logic │
|
|
209
|
+
// ╰──────────────────────────────────────────────────────────────────────────────────╯
|
|
210
|
+
|
|
211
|
+
/**
|
|
212
|
+
* @author
|
|
213
|
+
* @migbash
|
|
214
|
+
* @summary
|
|
215
|
+
* - 🔹 HELPER
|
|
216
|
+
* - IMPORTANT
|
|
217
|
+
* @description
|
|
218
|
+
* 📣 Update **target** `list` data of target `properties` to update.
|
|
219
|
+
* @param { [IDataProp, any][] } data
|
|
220
|
+
* 💠 **[required]** Target data to update.
|
|
221
|
+
* @return { void }
|
|
222
|
+
*/
|
|
223
|
+
updateData:
|
|
224
|
+
(
|
|
225
|
+
data: [IDataProp, any][]
|
|
226
|
+
): void =>
|
|
227
|
+
{
|
|
228
|
+
const
|
|
229
|
+
localStore = methods.parseLocalStorage()
|
|
230
|
+
;
|
|
231
|
+
|
|
232
|
+
if (!localStore) return;
|
|
233
|
+
|
|
234
|
+
// ╭─────
|
|
235
|
+
// │ NOTE: |:| loop over data entries
|
|
236
|
+
// ╰─────
|
|
237
|
+
for (const iterator of data)
|
|
238
|
+
{
|
|
239
|
+
const
|
|
240
|
+
/**
|
|
241
|
+
* @description
|
|
242
|
+
* 📝 Data point `name` to be updated
|
|
243
|
+
*/
|
|
244
|
+
dataTarget = iterator[0],
|
|
245
|
+
/**
|
|
246
|
+
* @description
|
|
247
|
+
* 📝 Data point `value` to be set to
|
|
248
|
+
*/
|
|
249
|
+
dataPoint = iterator[1]
|
|
250
|
+
;
|
|
251
|
+
|
|
252
|
+
if (dataTarget == 'toggleAdShownState')
|
|
253
|
+
{
|
|
254
|
+
localStore.isBetarenaAdShownForToday = !localStore.isBetarenaAdShownForToday;
|
|
255
|
+
|
|
256
|
+
if (localStore.isBetarenaAdShownForToday)
|
|
257
|
+
localStore.advertDateLastShown = new Date()
|
|
258
|
+
else
|
|
259
|
+
localStore.advertDateLastShown = null;
|
|
260
|
+
;
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
methods.setLocalStorage
|
|
265
|
+
(
|
|
266
|
+
localStore
|
|
267
|
+
);
|
|
268
|
+
|
|
269
|
+
return;
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
;
|
|
273
|
+
|
|
274
|
+
return {
|
|
275
|
+
subscribe,
|
|
276
|
+
set,
|
|
277
|
+
update,
|
|
278
|
+
...methods,
|
|
279
|
+
};
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
// #endregion ➤ 🛠️ METHODS
|
|
283
|
+
|
|
284
|
+
export const betarenaAdEngineStore = createLocalStore('betarena-ad-engine');
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { IBetarenaUser } from "@betarena/scores-lib/types/_FIREBASE_.js";
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* @author
|
|
5
|
+
* @migbash
|
|
6
|
+
* @summary
|
|
7
|
+
* 🔹 INTERFACE
|
|
8
|
+
*/
|
|
9
|
+
export interface IAdEngineStore
|
|
10
|
+
{
|
|
11
|
+
/**
|
|
12
|
+
* @description
|
|
13
|
+
* 📝 Wether target `advert` has been shown for the `24h`
|
|
14
|
+
*/
|
|
15
|
+
isBetarenaAdShownForToday: boolean;
|
|
16
|
+
/**
|
|
17
|
+
* @description
|
|
18
|
+
* 📝 Last `timestamp (date)` of shown advert and closed
|
|
19
|
+
*/
|
|
20
|
+
advertDateLastShown: Date | null;
|
|
21
|
+
}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @description
|
|
3
|
+
* 📝 GeoJs Interface
|
|
4
|
+
* @see https://www.geojs.io/docs/v1/endpoints/geo/
|
|
5
|
+
*/
|
|
6
|
+
export interface GeoJsResponse
|
|
7
|
+
{
|
|
8
|
+
/**
|
|
9
|
+
* @description
|
|
10
|
+
* 📝 approx. radius around location from IP
|
|
11
|
+
*/
|
|
12
|
+
accuracy: number;
|
|
13
|
+
/**
|
|
14
|
+
* @description
|
|
15
|
+
* 📝 autonomous system number associated with the IP
|
|
16
|
+
*/
|
|
17
|
+
asn: number;
|
|
18
|
+
/**
|
|
19
|
+
* @description
|
|
20
|
+
* 📝 3-letter continent code
|
|
21
|
+
*/
|
|
22
|
+
continent_code: string;
|
|
23
|
+
/**
|
|
24
|
+
* @description
|
|
25
|
+
* 📝 country name in English
|
|
26
|
+
*/
|
|
27
|
+
country: string;
|
|
28
|
+
/**
|
|
29
|
+
* @description
|
|
30
|
+
* 📝 2-letter country code
|
|
31
|
+
*/
|
|
32
|
+
country_code?: string;
|
|
33
|
+
/**
|
|
34
|
+
* @description
|
|
35
|
+
* 📝 3-letter country code
|
|
36
|
+
*/
|
|
37
|
+
country_code3: string;
|
|
38
|
+
/**
|
|
39
|
+
* @description
|
|
40
|
+
* 📝 requested IP
|
|
41
|
+
*/
|
|
42
|
+
ip: string;
|
|
43
|
+
/**
|
|
44
|
+
* @description
|
|
45
|
+
* 📝 IP latitude (Note: this is a string due to historic reasons)
|
|
46
|
+
*/
|
|
47
|
+
latitude: string;
|
|
48
|
+
/**
|
|
49
|
+
* @description
|
|
50
|
+
* 📝 IP longitude (Note: this is a string due to historic reasons)
|
|
51
|
+
*/
|
|
52
|
+
longitude: string;
|
|
53
|
+
/**
|
|
54
|
+
* @description
|
|
55
|
+
* 📝 The organization that the IP is registered to (Note: Unknown is returned when this field is unknown)
|
|
56
|
+
*/
|
|
57
|
+
organization: string;
|
|
58
|
+
/**
|
|
59
|
+
* @description
|
|
60
|
+
* 📝 The ASN and organization field combined (Note: this field is depricated)
|
|
61
|
+
*/
|
|
62
|
+
organization_name: string;
|
|
63
|
+
/**
|
|
64
|
+
* @description
|
|
65
|
+
* 📝 Area code of IP
|
|
66
|
+
*/
|
|
67
|
+
area_code?: string;
|
|
68
|
+
/**
|
|
69
|
+
* @description
|
|
70
|
+
* 📝 City name in English
|
|
71
|
+
*/
|
|
72
|
+
city?: string;
|
|
73
|
+
/**
|
|
74
|
+
* @description
|
|
75
|
+
* 📝 Subdivison of the country the IP is within (State, region etc)
|
|
76
|
+
*/
|
|
77
|
+
region?: string;
|
|
78
|
+
/**
|
|
79
|
+
* @description
|
|
80
|
+
* 📝 Time zone as specified by the IANA Time Zone Database
|
|
81
|
+
*/
|
|
82
|
+
timezone?: string;
|
|
83
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @author
|
|
3
|
+
* @migbash
|
|
4
|
+
* @summary
|
|
5
|
+
* 🟥 MAIN
|
|
6
|
+
* @description
|
|
7
|
+
* 📝 Detect target device type, such as: `mobile` | `tablet` | `desktop`.
|
|
8
|
+
* @returns { string }
|
|
9
|
+
* 📤
|
|
10
|
+
*/
|
|
11
|
+
export function detectDeviceType
|
|
12
|
+
(
|
|
13
|
+
): string
|
|
14
|
+
{
|
|
15
|
+
const
|
|
16
|
+
/**
|
|
17
|
+
* @description
|
|
18
|
+
*/
|
|
19
|
+
userAgentObject = navigator.userAgent.toLowerCase(),
|
|
20
|
+
/**
|
|
21
|
+
* @description
|
|
22
|
+
*/
|
|
23
|
+
isUserAgentMobile = userAgentObject.includes('mobile'),
|
|
24
|
+
/**
|
|
25
|
+
* @description
|
|
26
|
+
*/
|
|
27
|
+
isUserAgentTablet = /tablet|ipad/.test(userAgentObject)
|
|
28
|
+
;
|
|
29
|
+
|
|
30
|
+
if (isUserAgentMobile)
|
|
31
|
+
return 'mobile';
|
|
32
|
+
else if (isUserAgentTablet)
|
|
33
|
+
return 'tablet';
|
|
34
|
+
else
|
|
35
|
+
return 'desktop';
|
|
36
|
+
;
|
|
37
|
+
}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
// #region ➤ 📦 Package Imports
|
|
2
|
+
|
|
3
|
+
import { tryCatchAsyncV2 } from '@betarena/scores-lib/dist/util/util.common.js';
|
|
4
|
+
|
|
5
|
+
// #endregion ➤ 📦 Package Imports
|
|
6
|
+
|
|
7
|
+
interface IResponseError
|
|
8
|
+
{
|
|
9
|
+
/**
|
|
10
|
+
* @description
|
|
11
|
+
* 📝
|
|
12
|
+
*/
|
|
13
|
+
error: boolean;
|
|
14
|
+
/**
|
|
15
|
+
* @description
|
|
16
|
+
* 📝
|
|
17
|
+
*/
|
|
18
|
+
errorLogs: unknown;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* @author
|
|
23
|
+
* @migbash
|
|
24
|
+
* @summary
|
|
25
|
+
* - 🔹 HELPER
|
|
26
|
+
* - 🟥 IMPORTANT
|
|
27
|
+
* @description
|
|
28
|
+
* 📣 PROXY Fetch type POST
|
|
29
|
+
* @param { string } path
|
|
30
|
+
* 💠 **[required]** `endpoint/url` to fetch data from.
|
|
31
|
+
* @param { T2 } data
|
|
32
|
+
* 💠 [optional] Target data to pass as `body`.
|
|
33
|
+
* @returns { Promise < T1 | NullUndef | unknown | IResponseError > }
|
|
34
|
+
* 📤 Returns an `unkown`.
|
|
35
|
+
*/
|
|
36
|
+
export async function postMod
|
|
37
|
+
<
|
|
38
|
+
T1,
|
|
39
|
+
T2
|
|
40
|
+
>
|
|
41
|
+
(
|
|
42
|
+
path: string,
|
|
43
|
+
data: T1
|
|
44
|
+
): Promise < T2 | IResponseError >
|
|
45
|
+
{
|
|
46
|
+
console.log('path', path);
|
|
47
|
+
console.log('data', data);
|
|
48
|
+
|
|
49
|
+
return await tryCatchAsyncV2
|
|
50
|
+
<
|
|
51
|
+
T2
|
|
52
|
+
>
|
|
53
|
+
(
|
|
54
|
+
async (
|
|
55
|
+
): Promise < T2 > =>
|
|
56
|
+
{
|
|
57
|
+
const
|
|
58
|
+
/**
|
|
59
|
+
* @description
|
|
60
|
+
* 📝 Target endpoint response.
|
|
61
|
+
*/
|
|
62
|
+
res: Response
|
|
63
|
+
= await fetch
|
|
64
|
+
(
|
|
65
|
+
path,
|
|
66
|
+
{
|
|
67
|
+
method: 'POST',
|
|
68
|
+
credentials: 'include',
|
|
69
|
+
body: JSON.stringify(data),
|
|
70
|
+
mode: 'cors',
|
|
71
|
+
headers:
|
|
72
|
+
{
|
|
73
|
+
Accept: 'application/json',
|
|
74
|
+
'Content-Type': 'application/json'
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
),
|
|
78
|
+
/**
|
|
79
|
+
* @description
|
|
80
|
+
* 📝 Target `json` resonse from `endpoint`.
|
|
81
|
+
*/
|
|
82
|
+
resJson = await res.json()
|
|
83
|
+
;
|
|
84
|
+
|
|
85
|
+
if (!res.ok)
|
|
86
|
+
throw new Error
|
|
87
|
+
(
|
|
88
|
+
JSON.stringify(resJson) ?? 'network response was not ok'
|
|
89
|
+
);
|
|
90
|
+
;
|
|
91
|
+
|
|
92
|
+
return resJson;
|
|
93
|
+
},
|
|
94
|
+
(
|
|
95
|
+
ex: unknown
|
|
96
|
+
): IResponseError =>
|
|
97
|
+
{
|
|
98
|
+
// [🐞]
|
|
99
|
+
console.error(`💀 Unhandled :: ${ex}`);
|
|
100
|
+
|
|
101
|
+
return {
|
|
102
|
+
error: true,
|
|
103
|
+
errorLogs: ex
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
);
|
|
107
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import type { GeoJsResponse } from '../types/geojs.js';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* @author
|
|
5
|
+
* @migbash
|
|
6
|
+
* @summary
|
|
7
|
+
* 🟥 MAIN
|
|
8
|
+
* @description
|
|
9
|
+
* 📝 Detect user `geo-location`.
|
|
10
|
+
* @returns { Promise <void> }
|
|
11
|
+
*/
|
|
12
|
+
export async function getUserLocation
|
|
13
|
+
(
|
|
14
|
+
): Promise < GeoJsResponse >
|
|
15
|
+
{
|
|
16
|
+
const
|
|
17
|
+
/**
|
|
18
|
+
* @description
|
|
19
|
+
* 📝 Response from `fetch`
|
|
20
|
+
*/
|
|
21
|
+
response = await fetch
|
|
22
|
+
(
|
|
23
|
+
'https://get.geojs.io/v1/ip/geo.json',
|
|
24
|
+
{
|
|
25
|
+
method: 'GET'
|
|
26
|
+
}
|
|
27
|
+
)
|
|
28
|
+
;
|
|
29
|
+
|
|
30
|
+
// [🐞]
|
|
31
|
+
// console.log('geoLocation', geoLocation);
|
|
32
|
+
|
|
33
|
+
return await response.json();
|
|
34
|
+
}
|
package/src/main.ts
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import App from './App.svelte'
|
|
2
|
+
|
|
3
|
+
let app
|
|
4
|
+
|
|
5
|
+
if (typeof document === 'undefined') {
|
|
6
|
+
// during server evaluation
|
|
7
|
+
} else {
|
|
8
|
+
// during client's browser evaluation
|
|
9
|
+
app = new App
|
|
10
|
+
(
|
|
11
|
+
{
|
|
12
|
+
target: document.body
|
|
13
|
+
}
|
|
14
|
+
)
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export default app
|
package/vite.config.ts
CHANGED
|
@@ -2,6 +2,32 @@ import { defineConfig } from 'vite'
|
|
|
2
2
|
import { svelte } from '@sveltejs/vite-plugin-svelte'
|
|
3
3
|
|
|
4
4
|
// https://vitejs.dev/config/
|
|
5
|
-
export default defineConfig
|
|
6
|
-
|
|
7
|
-
|
|
5
|
+
export default defineConfig
|
|
6
|
+
(
|
|
7
|
+
(
|
|
8
|
+
{
|
|
9
|
+
command,
|
|
10
|
+
mode
|
|
11
|
+
}
|
|
12
|
+
) =>
|
|
13
|
+
{
|
|
14
|
+
return {
|
|
15
|
+
plugins:
|
|
16
|
+
[
|
|
17
|
+
svelte()
|
|
18
|
+
],
|
|
19
|
+
|
|
20
|
+
build:
|
|
21
|
+
{
|
|
22
|
+
rollupOptions:
|
|
23
|
+
{
|
|
24
|
+
output:
|
|
25
|
+
{
|
|
26
|
+
entryFileNames: '[name].js',
|
|
27
|
+
assetFileNames: '[name].[ext]',
|
|
28
|
+
},
|
|
29
|
+
},
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
);
|