This commit is contained in:
Korbs 2025-02-20 19:16:44 -05:00
parent 812080d74a
commit 574dffb08b
Signed by: Korbs
SSH key fingerprint: SHA256:Q0b0KraMldpAO9oKa+w+gcsXsOTykQ4UkAKn0ByGn5U
16 changed files with 282 additions and 1052 deletions

View file

@ -1,76 +0,0 @@
# Zalvena
## 0.5.0
- Removed examples
- Removed Eslintrc file
- Removed package lock file
- Removed Engines from `packages.json`
- Removed `/.changeset/`
- Removed `/.github/`
- Removed `/.vscode/`
- Removed other packages: `["angular", "react", "browser"]`
- Removed `isInBrowserExtension` from `shared.ts`
- Removed `isInBrowserExtension` from `shared.ts`
- Updated license from MIT to MIT-NON-AI
- Updated the package `@types/node` from `v20.5.7` to `v22.13.4`
- Updated the package `prettier` from `v3.0.3` to `v3.5.1`
- Updated the package `tsup` from `v7.2.0` to `v8.3.6`
- Updated the package `turbo` from `v1.10.13` to `v2.4.2`
- Added SudoVanilla's Zalvena instance to `regions` list as `SV`
- Using Bun over NPM
You can view other changes by viewing the commit history.
---
# Officially from Aptabase
## 0.4.3
- Move browser locale and is debug reads from import to first event to better support SSR
## 0.4.2
- Fix error when running on chrome
## 0.4.1
- Support for custom API path
## 0.4.0
- Internal refactor
## 0.3.2
- better version of the session id generator
## 0.3.1
- use new session id format
## 0.3.0
- Added an option to specify `isDebug` at init time
## 0.2.0
- Some internal refactor to support the new `@aptabase/react` package
## 0.1.3
- Add automatic session timeout after 1 hour of inactivity
## 0.1.2
- Added support for automatic segregation of Debug/Release events
## 0.1.1
- Refactor on session generator
## 0.1.0
- Move to Rollup 3
- Output both CJS and ESM modules

View file

@ -1,35 +1,35 @@
{
"name": "@sudovanilla/zalvena",
"version": "1.1.0",
"type": "module",
"description": "JavaScript SDK for Zalvena",
"main": "./dist/index.cjs",
"module": "./dist/index.js",
"types": "./dist/index.d.ts",
"exports": {
".": {
"types": "./dist/index.d.ts",
"require": "./dist/index.cjs",
"import": "./dist/index.js"
}
},
"repository": {
"type": "git",
"url": "git+https://ark.sudovanilla.org/korbs/zalvena",
"directory": "packages/web"
},
"bugs": {
"url": "https://ark.sudovanilla.org/korbs/zalvena/issues"
},
"homepage": "https://ark.sudovanilla.org/korbs/zalvena",
"license": "MIT",
"scripts": {
"build": "tsup",
"prepublishOnly": "bun run build"
},
"files": [
"LICENSE",
"dist",
"package.json"
]
"name": "@sudovanilla/zalvena",
"version": "1.1.0",
"type": "module",
"description": "JavaScript SDK for Zalvena",
"main": "./dist/index.cjs",
"module": "./dist/index.js",
"types": "./dist/index.d.ts",
"exports": {
".": {
"types": "./dist/index.d.ts",
"require": "./dist/index.cjs",
"import": "./dist/index.js"
}
},
"repository": {
"type": "git",
"url": "git+https://ark.sudovanilla.org/korbs/zalvena",
"directory": "packages/web"
},
"bugs": {
"url": "https://ark.sudovanilla.org/korbs/zalvena/issues"
},
"homepage": "https://ark.sudovanilla.org/korbs/zalvena",
"license": "MIT",
"scripts": {
"build": "tsup",
"prepublishOnly": "bun run build"
},
"files": [
"LICENSE",
"dist",
"package.json"
]
}

View file

@ -1,6 +1,5 @@
import { getApiUrl, inMemorySessionId, sendEvent, validateAppKey, type ZalvenaOptions } from '../../shared';
import { GetApiURL, InMemorySessionId, SendEvent, ValidateAppKey, type ZalvenaOptions } from '../../shared';
// Session expires after 1 hour of inactivity
const SESSION_TIMEOUT = 1 * 60 * 60;
const sdkVersion = `Zalvena-web@${process.env.PKG_VERSION}`;
@ -10,27 +9,27 @@ let _options: ZalvenaOptions | undefined;
export { type ZalvenaOptions };
export function init(appKey: string, options?: ZalvenaOptions) {
if (!validateAppKey(appKey)) return;
export function Init(appKey: string, options?: ZalvenaOptions) {
if (!ValidateAppKey(appKey)) return;
_apiUrl = options?.apiUrl ?? getApiUrl(appKey, options);
_appKey = appKey;
_options = options;
_apiUrl = options?.apiUrl ?? GetApiURL(appKey, options);
_appKey = appKey;
_options = options;
}
export async function trackEvent(eventName: string, props?: Record<string, string | number | boolean>): Promise<void> {
if (!_apiUrl) return;
export async function Event(eventName: string, props?: Record<string, string | number | boolean>): Promise<void> {
if (!_apiUrl) return;
const sessionId = inMemorySessionId(SESSION_TIMEOUT);
const sessionId = InMemorySessionId(SESSION_TIMEOUT);
await sendEvent({
apiUrl: _apiUrl,
sessionId,
appKey: _appKey,
isDevelopment: _options?.isDevelopment,
appVersion: _options?.appVersion,
sdkVersion,
eventName,
props,
});
await SendEvent({
apiUrl: _apiUrl,
sessionId,
appKey: _appKey,
isDevelopment: _options?.isDevelopment,
appVersion: _options?.appVersion,
sdkVersion,
eventName,
props,
});
}

View file

@ -1,15 +1,15 @@
{
"compilerOptions": {
"target": "es2022",
"strict": true,
"moduleResolution": "node",
"esModuleInterop": true,
"jsx": "react-jsx",
"baseUrl": ".",
"paths": {
"types": ["@types"]
},
"declaration": true,
"declarationDir": "./dist"
}
"compilerOptions": {
"target": "es2022",
"strict": true,
"moduleResolution": "node",
"esModuleInterop": true,
"jsx": "react-jsx",
"baseUrl": ".",
"paths": {
"types": ["@types"]
},
"declaration": true,
"declarationDir": "./dist"
}
}

View file

@ -2,14 +2,14 @@ import { defineConfig } from 'tsup';
const { version } = require('./package.json');
export default defineConfig({
entry: ['src/index.ts'],
format: ['cjs', 'esm'],
dts: true,
splitting: false,
minify: true,
sourcemap: true,
clean: true,
env: {
PKG_VERSION: version,
},
entry: ['src/index.ts'],
format: ['cjs', 'esm'],
dts: true,
splitting: false,
minify: true,
sourcemap: true,
clean: true,
env: {
PKG_VERSION: version,
},
});