diff --git a/.npmignore b/.npmignore
index cee0cc8..7830f40 100644
--- a/.npmignore
+++ b/.npmignore
@@ -10,7 +10,6 @@ lerna-debug.log*
node_modules
.DS_Store
-dist
dist-ssr
coverage
*.local
diff --git a/README.md b/README.md
index a611389..8473db2 100644
--- a/README.md
+++ b/README.md
@@ -1,8 +1,12 @@
-
-
-
# Wide Angle Analytics for Vue.js
+[![License][license-src]][license-href]
+[![Latest][npm-version-src]][npm-version-href]
+[![Downloads][npm-downloads-src]][npm-downloads-href]
+[![Wide Angle][wideangle-src]][wideangle-href]
+
+
+
Enable **privacy-friendly** web analytics in your Vue.js 3.x application with our official plugin.
[Wide Angle Analytics](https://wideangle.co) is powerful, strictly-GDPR compliant Google Analytics alternative.
@@ -36,10 +40,11 @@ option|description|required|default|example
siteId| The Site ID from Wide Angle Site settings| :white_check_mark: | _none_ | 8D27G3B9ACA01F4241
domain| Domain hosting the script, can be found in Wide Angle Analytics Site settings | :white_check_mark: | _none_ | stats.wideangle.co
fingerprint | Should script use browser fingerprinting; this might require collecting consent depeing on the applicable laws | :x: | false | true
-supressDnt | Should script ingore Do Not Track browser setting. If not enabled, not events will be sent if user's browser has DNT enabled | :x: | false | true
+suppressDnt | Should script ingore Do Not Track browser setting. If not enabled, not events will be sent if user's browser has DNT enabled | :x: | false | true
includeParams | An array of query parameters that can be passed as part of tracking event. By default only `utm_*` and `ref` parameters are passed in the event | :x: | `[]` | `['sessionId', 'offset']`
excludePaths | An array of URL paths that should not trigger default events such as page view, page leave | :x: | `[]` | `['^/wp-admin/.*', ]`
ignoreHash | If enabled, change in the URL fragment will not trigger page view event | :x: | false | true
+consentMarker | Cookie (with or without) value which present implies consent and absence lack its lack | :x: | n/a | `WAA_CONSENT=true`
You will find more details about these settings in [Wide Angle Analytics documentation](https://wideangle.co/documentation/configure-site).
@@ -55,7 +60,7 @@ app.use(WideAngle, {
siteId: "8D27G3B9ACA01F4241",
domain: "stats.example.com",
fingerprint: true,
- supressDnt: true
+ suppressDnt: true
});
```
@@ -118,3 +123,74 @@ const sendEvent = async () => {
}
```
+
+# Consent Handling
+
+By default, Wide Angle Analytics does nore require consent thanks to its privacy-first, anonymous tracking and principaled approached to compliance.
+
+However, you have additional toggles should you wish to control consent, either in **Opt-In** or **Opt-Out** mode.
+
+## Opt-Out by default
+
+If the visitors browsers has `DoNotTrack` setting enabled in the browser, it will be understood as opt-out and not tracking events will be issued.
+
+You website can't overwrite this behaviour by specifying `suppressDnt` setting.
+
+```javascript
+app.use(WideAngle, {
+ siteId: "8D27G3B9ACA01F4241",
+ suppressDnt: true
+});
+```
+
+## Opt-In or Opt-Out based on Cookie
+
+Wide Angle can be configure to handle presence of a cookie, or a cookie with specific value, as an implicit consent. Lack of the cookie will be handled as implicit opt-out.
+
+Example configuration with cookie marker, expecting cookie name `WAA_CONSENT` with value `true`:
+
+```javascript
+app.use(WideAngle, {
+ siteId: "8D27G3B9ACA01F4241",
+ consentMarker: "WAA_CONSENT=true"
+});
+```
+
+
+## Programmatic consent
+
+The Wide Angle serving offers two additional methods, which allow for recording tracking consent:
+
+- `recordConsent(subjectId: String): void`, and
+- `revokeConsent()`
+
+
+Calling above methods on `waa` service will overwrite other consent mechanism (ie. DoNotTrack, and cookie marker).
+
+Example usage:
+
+```vue
+
+```
+
+
+
+
+[license-src]: https://img.shields.io/npm/l/wideangle-vuejs.svg?style=flat&colorA=18181B&colorB=28CF8D
+[license-href]: https://opensource.org/license/apache-2-0/
+
+[npm-downloads-src]: https://img.shields.io/npm/dm/wideangle-vuejs.svg?style=flat&colorA=18181B&colorB=28CF8DD
+[npm-downloads-href]: https://npmjs.com/package/wideangle-vuejs
+
+[npm-version-src]: https://img.shields.io/npm/v/wideangle-vuejs/latest.svg?style=flat&colorA=18181B&colorB=28CF8DD
+[npm-version-href]: https://npmjs.com/package/wideangle-vuejs
+
+[wideangle-src]: https://img.shields.io/badge/logo-wideangle-blue?label=&logo=
+[wideangle-href]: https://wideangle.co?utm_source=github&utm_content=wideangle-vuejs
+
+
+
diff --git a/assets/full_logo_color_light_transparent.png b/assets/full_logo_color_light_transparent.png
new file mode 100755
index 0000000..6f98b15
Binary files /dev/null and b/assets/full_logo_color_light_transparent.png differ
diff --git a/index.js b/index.js
index dfb0b1a..1d0b8d4 100644
--- a/index.js
+++ b/index.js
@@ -1,15 +1,16 @@
-import { initWideAngle } from "./src";
+import { initWideAngle } from "./dist";
import { ref } from 'vue';
+export { initWideAngle } from "./dist";
export default {
- install: async (app, options) => {
+ install: (app, options) => {
const waaRef = ref()
- app.provide('waa', waaRef);
+ app.provide('waa', waaRef);
initWideAngle(options)
- .then(waa => {
+ .then(waa => {
waaRef.value = waa;
console.debug("[WAA] Wide Angle Analytics instance available");
- })
- .catch(e => { console.error("Failed to load Wide Angle Plugin", e)});
+ }).catch(e => { console.error("[WAA] Failed to load Wide Angle Plugin", e)});
+ return waaRef;
}
}
diff --git a/package-lock.json b/package-lock.json
new file mode 100644
index 0000000..d422b80
--- /dev/null
+++ b/package-lock.json
@@ -0,0 +1,37 @@
+{
+ "name": "wideangle-vuejs",
+ "version": "0.0.3",
+ "lockfileVersion": 2,
+ "requires": true,
+ "packages": {
+ "": {
+ "name": "wideangle-vuejs",
+ "version": "0.0.3",
+ "license": "Apache-2.0",
+ "devDependencies": {
+ "typescript": "^5.0.4"
+ }
+ },
+ "node_modules/typescript": {
+ "version": "5.0.4",
+ "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.0.4.tgz",
+ "integrity": "sha512-cW9T5W9xY37cc+jfEnaUvX91foxtHkza3Nw3wkoF4sSlKn0MONdkdEndig/qPBWXNkmplh3NzayQzCiHM4/hqw==",
+ "dev": true,
+ "bin": {
+ "tsc": "bin/tsc",
+ "tsserver": "bin/tsserver"
+ },
+ "engines": {
+ "node": ">=12.20"
+ }
+ }
+ },
+ "dependencies": {
+ "typescript": {
+ "version": "5.0.4",
+ "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.0.4.tgz",
+ "integrity": "sha512-cW9T5W9xY37cc+jfEnaUvX91foxtHkza3Nw3wkoF4sSlKn0MONdkdEndig/qPBWXNkmplh3NzayQzCiHM4/hqw==",
+ "dev": true
+ }
+ }
+}
diff --git a/package.json b/package.json
index 965cd3c..16d27b5 100644
--- a/package.json
+++ b/package.json
@@ -1,11 +1,18 @@
{
"name": "wideangle-vuejs",
- "version": "0.0.2",
+ "version": "2.0.0",
"description": "Wide Angle Analytics web analytics Plugin for Vue.js 3.x",
"homepage": "https://wideangle.co",
- "repository": "github:inputobjects/wideangle-vuejs",
+ "repository": {
+ "type": "git",
+ "url": "https://cloud.inputobjects.eu/forge/wideangle/wideangle-vuejs.git"
+ },
"main": "index.js",
"scripts": {
+ "build": "tsc -p tsconfig.json",
+ "clear": "rimraf dist",
+ "rebuild": "npm run clear && npm run build",
+ "prepublishOnly": "npm run rebuild"
},
"keywords": [
"wide angle analytics",
@@ -13,8 +20,13 @@
"vue.js",
"vuejs",
"plugin",
- "vuejs plugin"
+ "vuejs plugin",
+ "privacy web analytics",
+ "privacy"
],
"author": "Wide Angle Analytics ",
- "license": "Apache-2.0"
+ "license": "Apache-2.0",
+ "devDependencies": {
+ "typescript": "^5.0.4"
+ }
}
diff --git a/sample/vue-sample/package-lock.json b/sample/vue-sample/package-lock.json
index edcac82..30c61a4 100644
--- a/sample/vue-sample/package-lock.json
+++ b/sample/vue-sample/package-lock.json
@@ -9,8 +9,7 @@
"version": "0.0.0",
"dependencies": {
"vue": "^3.2.47",
- "vue-router": "^4.1.6",
- "wideangle-vue": "file:../../"
+ "vue-router": "^4.1.6"
},
"devDependencies": {
"@vitejs/plugin-vue": "^4.0.0",
@@ -18,9 +17,12 @@
}
},
"../..": {
- "name": "wideangle-vuejs",
- "version": "0.0.1",
- "license": "Apache-2.0"
+ "version": "2.0.0",
+ "extraneous": true,
+ "license": "Apache-2.0",
+ "devDependencies": {
+ "typescript": "^5.0.4"
+ }
},
"node_modules/@babel/parser": {
"version": "7.21.2",
@@ -771,10 +773,6 @@
"peerDependencies": {
"vue": "^3.2.0"
}
- },
- "node_modules/wideangle-vue": {
- "resolved": "../..",
- "link": true
}
},
"dependencies": {
@@ -1175,9 +1173,6 @@
"requires": {
"@vue/devtools-api": "^6.4.5"
}
- },
- "wideangle-vue": {
- "version": "file:../.."
}
}
}
diff --git a/sample/vue-sample/package.json b/sample/vue-sample/package.json
index cc7d528..2a8f55d 100644
--- a/sample/vue-sample/package.json
+++ b/sample/vue-sample/package.json
@@ -3,14 +3,13 @@
"version": "0.0.0",
"private": true,
"scripts": {
- "dev": "vite",
+ "dev": "vite --host 0.0.0.0",
"build": "vite build",
"preview": "vite preview"
},
"dependencies": {
"vue": "^3.2.47",
- "vue-router": "^4.1.6",
- "wideangle-vue": "file:../../"
+ "vue-router": "^4.1.6"
},
"devDependencies": {
"@vitejs/plugin-vue": "^4.0.0",
diff --git a/sample/vue-sample/src/main.js b/sample/vue-sample/src/main.js
index 04c128c..d9e8e45 100644
--- a/sample/vue-sample/src/main.js
+++ b/sample/vue-sample/src/main.js
@@ -1,7 +1,7 @@
import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
-import WideAngle from 'wideangle-vue'
+import WideAngle from 'wideangle-vuejs'
import './assets/main.css'
@@ -10,8 +10,8 @@ const app = createApp(App)
app.use(router)
app.use(WideAngle, {
siteId: "8D27G3B9ACA01F4241",
- domain: "wideangle.local:3000",
+ domain: "events.wideangle.test",
fingerprint: true,
- supressDnt: true
+ suppressDnt: true
})
app.mount('#app')
diff --git a/tsconfig.json b/tsconfig.json
new file mode 100644
index 0000000..c8b7297
--- /dev/null
+++ b/tsconfig.json
@@ -0,0 +1,14 @@
+{
+ "include": ["src/**/*"],
+ "compilerOptions": {
+ "target": "es2016",
+ // "module": "commonjs",
+ "declaration": true,
+ "esModuleInterop": true,
+ "forceConsistentCasingInFileNames": true,
+ "strict": true,
+ "allowJs": true,
+ "outDir": "dist",
+ "skipLibCheck": true
+ }
+}