@betarena/ad-engine 0.0.5 → 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.
@@ -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>
@@ -0,0 +1,10 @@
1
+ export const
2
+ /**
3
+ * @description
4
+ * 📝 Respective Betarena API endpoint for Ad-Engine Data
5
+ * @example
6
+ * - (local) http://localhost:58749
7
+ * - (dev) https://betarena-test-e2748dab12f5.herokuapp.com
8
+ */
9
+ betarenaEndpoint = 'http://localhost:58749'
10
+ ;
@@ -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,4 @@
1
+ type NullUndef =
2
+ | null
3
+ | undefined
4
+ ;
@@ -0,0 +1,2 @@
1
+ /// <reference types="svelte" />
2
+ /// <reference types="vite/client" />
@@ -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
- plugins: [svelte()],
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
+ );