Skip to content
This repository has been archived by the owner on Apr 3, 2024. It is now read-only.

⚡️ Modernize #46

Merged
merged 50 commits into from
Oct 8, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
50 commits
Select commit Hold shift + click to select a range
c2a7110
Remove xo
nettofarah Oct 4, 2019
90b190c
Add typescript
nettofarah Oct 4, 2019
b6c7ef6
Build with TS
nettofarah Oct 4, 2019
be2666a
Ignore build folder
nettofarah Oct 4, 2019
f4bdf2a
Ignore build
nettofarah Oct 4, 2019
b5827a1
Add ability to build webpack with TS
nettofarah Oct 4, 2019
0648c1f
Add available type defs
nettofarah Oct 5, 2019
1b4388a
Use typed version of in-eu
nettofarah Oct 5, 2019
c03de6e
Install jest
nettofarah Oct 5, 2019
a1c7b8f
Setup jest
nettofarah Oct 5, 2019
9194840
Nuke ava
nettofarah Oct 5, 2019
bdc19b6
Migrate analytics test to TS
nettofarah Oct 5, 2019
35b9e56
Migrate analytics to TS
nettofarah Oct 5, 2019
cb00feb
First pass at typedefs
nettofarah Oct 6, 2019
b0bb5ef
Add a few more types
nettofarah Oct 6, 2019
c27ab80
Bump size limits
nettofarah Oct 6, 2019
8050f04
Migrate some components over
nettofarah Oct 7, 2019
ec9f745
Prettify
nettofarah Oct 7, 2019
619f478
Migrate more components
nettofarah Oct 7, 2019
80cc32f
Migrate container to TS
nettofarah Oct 7, 2019
eb45f08
Fix up types
nettofarah Oct 7, 2019
60bd55e
Add specific category types
nettofarah Oct 7, 2019
9f7d6b4
Type standalone consent manager
nettofarah Oct 7, 2019
78f6ec8
Fix up stories
nettofarah Oct 7, 2019
6122573
Fix up standalone build
nettofarah Oct 7, 2019
44cffee
Fix standalone entry point
nettofarah Oct 7, 2019
b909d27
Update circle image
nettofarah Oct 7, 2019
1e4240c
Switch from inferno to preact
nettofarah Oct 7, 2019
0249d4b
Update size limits
nettofarah Oct 7, 2019
232007b
Update storybook
nettofarah Oct 7, 2019
5883f20
No longer require babel
nettofarah Oct 7, 2019
22747b3
Migrate stories to TS
nettofarah Oct 7, 2019
b5ed955
Add source code next to story
nettofarah Oct 7, 2019
11f409f
Create a story for the HTML script
nettofarah Oct 8, 2019
d7773c1
Use good demo
nettofarah Oct 8, 2019
199db95
Use preact/compact
nettofarah Oct 8, 2019
3e886ca
Update react
nettofarah Oct 8, 2019
cb64ccf
Bump peer deps
nettofarah Oct 8, 2019
dd5d6fa
Alpha
nettofarah Oct 8, 2019
c0310a3
Format addon source
nettofarah Oct 8, 2019
1f20521
Add linting
nettofarah Oct 8, 2019
b028b4b
Include type declarations
nettofarah Oct 8, 2019
2507717
Include standalone build in storybook
nettofarah Oct 8, 2019
edaceee
Include standalone script on publish
nettofarah Oct 8, 2019
8465374
Bump alpha
nettofarah Oct 8, 2019
7bf7073
Only run tests in src
nettofarah Oct 8, 2019
99357a2
Include __tests__ in tsconfig
nettofarah Oct 8, 2019
5bd72ff
Remove declaration for now
nettofarah Oct 8, 2019
72770e7
Improve Destination and AJS types
nettofarah Oct 8, 2019
947072d
Harden more types
nettofarah Oct 8, 2019
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
27 changes: 0 additions & 27 deletions .babelrc

This file was deleted.

3 changes: 2 additions & 1 deletion .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ version: 2
jobs:
build:
docker:
- image: circleci/node:8.10
- image: circleci/node:10
steps:
- checkout
- restore_cache:
Expand All @@ -13,6 +13,7 @@ jobs:
paths:
- ./node_modules
- run: yarn build
- run: yarn lint
- run: yarn test
- run: yarn size-limit

Expand Down
33 changes: 33 additions & 0 deletions .eslintrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
{
"parser": "@typescript-eslint/parser",
"parserOptions": {
"project": "./tsconfig.json"
},
"extends": [
"eslint:recommended",
"plugin:@typescript-eslint/recommended",
"plugin:@typescript-eslint/recommended-requiring-type-checking",
"plugin:@typescript-eslint/eslint-recommended",
"prettier",
"prettier/@typescript-eslint"
],
"plugins": ["react", "@typescript-eslint", "prettier"],
"env": {
"browser": true,
"jest": true
},
"rules": {
"@typescript-eslint/no-unused-vars": "off",
"@typescript-eslint/no-floating-promises": "error",
"@typescript-eslint/explicit-function-return-type": "off",
"@typescript-eslint/ban-ts-ignore": "warn",
"no-global-assign": "off",
"@typescript-eslint/unbound-method": "warn"
},
"settings": {
"react": {
"pragma": "React",
"version": "detect"
}
}
}
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@
/commonjs/
/esm/
/standalone/
/build
/storybook-static

# IDE
.vscode/
1 change: 1 addition & 0 deletions .storybook/addons.js
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
import '@storybook/addon-options/register'
import '@storybook/addon-storysource/register'
11 changes: 1 addition & 10 deletions .storybook/config.js
Original file line number Diff line number Diff line change
@@ -1,12 +1,3 @@
import { configure } from '@storybook/react'
import { setOptions } from '@storybook/addon-options'

setOptions({
showDownPanel: false
})

function loadStories() {
require('../tools/stories')
}

configure(loadStories, module)
configure(require.context('../stories', true, /\.stories\.tsx$/), module)
42 changes: 42 additions & 0 deletions .storybook/webpack.config.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
const webpack = require('webpack')
const pkg = require('../package.json')

module.exports = {
mode: 'development',
resolve: {
extensions: ['.tsx', '.ts', '.js']
},
module: {
rules: [
{
test: /\.stories\.tsx?$/,
loaders: [
{
loader: require.resolve('@storybook/source-loader'),
options: {
parser: 'typescript',
prettierConfig: {
printWidth: 100,
singleQuote: false
}
}
}
],
enforce: 'pre'
},
{
test: /\.tsx?$/,
exclude: /node_modules/,
loader: 'ts-loader'
}
]
},
plugins: [
new webpack.DefinePlugin({
'process.env': {
NODE_ENV: JSON.stringify('production'),
VERSION: JSON.stringify(pkg.version)
}
})
]
}
69 changes: 36 additions & 33 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ It works by taking control of the analytics.js load process to only load destina
- Fine grained control of tools or categories used for tracking.
- 30s setup with a drop in script tag.
- Or fully customizable UI/UX through React components.
- EU traffic detection through [@segment/in-eu][inEU].
- EU traffic detection through [@segment/in-eu][ineu].
- Ability for visitors to reconsent and change preferences.
- Automatically updates to reflect the destinations you have enabled in Segment.

Expand All @@ -30,7 +30,7 @@ To get started, make sure you're using the latest version of the [analytics.js s

### Standalone Script

The standalone script is a prebuilt bundle that uses the [ConsentManager][] React component with [Inferno][] (a lightweight React alternative). It's best for if you want to get up and running quickly or you don't have a preexisting React setup.
The standalone script is a prebuilt bundle that uses the [ConsentManager][] React component with [Preact][] (a lightweight React alternative). It's best for if you want to get up and running quickly or you don't have a preexisting React setup.

Include the consent manager script tag after your analytic.js snippet and add your own custom copy. The standalone script can be configured in one of two ways, via data attributes for simple usage or via a global callback function for advanced usage. Both methods allow the consent manager script to be loaded async.

Expand Down Expand Up @@ -67,13 +67,13 @@ The following global variables are also exposed:
- `consentManager.version` - Version of the consent manager.
- `consentManager.openConsentManager()` - Opens the consent manager preferences dialog.
- `consentManager.doNotTrack()` - Utility function that returns the user's Do Not Track preference (normalises the cross browser API differences). Returns `true`, `false` or `null` (no preference specified).
- `consentManager.inEU()` - The [@segment/in-eu][inEU] `inEU()` function.
- `consentManager.inEU()` - The [@segment/in-eu][ineu] `inEU()` function.

#### Data Attributes

The `shouldRequireConsent` option isn't supported and the `otherWriteKeys` option should be a comma separated list.

*Note: the data attributes [won't work in Internet Explorer][currentScript] (Edge works fine though).*
_Note: the data attributes [won't work in Internet Explorer][currentscript] (Edge works fine though)._

```html
<script
Expand All @@ -95,11 +95,11 @@ The `shouldRequireConsent` option isn't supported and the `otherWriteKeys` optio

All the options are supported. The callback function also receives these exports:

- `React` - Reference to the [Inferno][] library (the API is React compatible). Useful for if you need to use virtual DOM in your content.
- `React` - Reference to the [Preact][] library (the API is React compatible). Useful for if you need to use virtual DOM in your content.
- `version` - Version of the consent manager.
- `openConsentManager()` - Opens the consent manager preferences dialog.
- `doNotTrack()` - Utility function that returns the user's Do Not Track preference (normalises the cross browser API differences). Returns `true`, `false` or `null` (no preference specified).
- `inEU()` - The [@segment/in-eu][inEU] `inEU()` function.
- `inEU()` - The [@segment/in-eu][ineu] `inEU()` function.

```html
<script>
Expand All @@ -114,16 +114,18 @@ All the options are supported. The callback function also receives these exports
' ',
React.createElement(
'a',
{href: '/docs/legal/website-data-collection-policy/', target: '_blank'},
{ href: '/docs/legal/website-data-collection-policy/', target: '_blank' },
'Website Data Collection Policy'
),
'.'
)
var bannerSubContent = 'You can change your preferences at any time.'
var preferencesDialogTitle = 'Website Data Collection Preferences'
var preferencesDialogContent = 'We use data collected by cookies and JavaScript libraries to improve your browsing experience, analyze site traffic, deliver personalized advertisements, and increase the overall performance of our site.'
var preferencesDialogContent =
'We use data collected by cookies and JavaScript libraries to improve your browsing experience, analyze site traffic, deliver personalized advertisements, and increase the overall performance of our site.'
var cancelDialogTitle = 'Are you sure you want to cancel?'
var cancelDialogContent = 'Your preferences have not been saved. By continuing to use our website, you՚re agreeing to our Website Data Collection Policy.'
var cancelDialogContent =
'Your preferences have not been saved. By continuing to use our website, you՚re agreeing to our Website Data Collection Policy.'

return {
container: '#target-container',
Expand Down Expand Up @@ -163,7 +165,7 @@ The write key analytics.js should be loaded with.
Type: `array<string>`<br>
Default: `[]`

Other write keys that you want to load destination information for. This is useful for including your server-side destinations in the consent manager, so that you can easily apply the user's tracking preferences to your server-side analytics too. *No data will be sent to these write keys.*
Other write keys that you want to load destination information for. This is useful for including your server-side destinations in the consent manager, so that you can easily apply the user's tracking preferences to your server-side analytics too. _No data will be sent to these write keys._

##### shouldRequireConsent

Expand Down Expand Up @@ -242,25 +244,27 @@ The content of the cancel dialog.

```javascript
import React from 'react'
import {ConsentManager, openConsentManager} from '@segment/consent-manager'
import { ConsentManager, openConsentManager } from '@segment/consent-manager'
import inEU from '@segment/in-eu'

export default function() {
const bannerContent = (
<span>
We use cookies (and other similar technologies) to collect data to improve
your experience on our site. By using our website, you’re agreeing to the
collection of data as described in our{' '}
We use cookies (and other similar technologies) to collect data to improve your experience on
our site. By using our website, you’re agreeing to the collection of data as described in our{' '}
<a href="/docs/legal/website-data-collection-policy/" target="_blank">
Website Data Collection Policy
</a>.
</a>
.
</span>
)
const bannerSubContent = 'You can change your preferences at any time.'
const preferencesDialogTitle = 'Website Data Collection Preferences'
const preferencesDialogContent = 'We use data collected by cookies and JavaScript libraries to improve your browsing experience, analyze site traffic, deliver personalized advertisements, and increase the overall performance of our site.'
const preferencesDialogContent =
'We use data collected by cookies and JavaScript libraries to improve your browsing experience, analyze site traffic, deliver personalized advertisements, and increase the overall performance of our site.'
const cancelDialogTitle = 'Are you sure you want to cancel?'
const cancelDialogContent = 'Your preferences have not been saved. By continuing to use our website, you՚re agreeing to our Website Data Collection Policy.'
const cancelDialogContent =
'Your preferences have not been saved. By continuing to use our website, you՚re agreeing to our Website Data Collection Policy.'

return (
<div>
Expand Down Expand Up @@ -306,7 +310,7 @@ The write key analytics.js should be loaded with.
Type: `array<string>`<br>
Default: `[]`

Other write keys that you want to load destination information for. This is useful for including your server-side destinations in the consent manager, so that you can easily apply the user's tracking preferences to your server-side analytics too. *No data will be sent to these write keys.*
Other write keys that you want to load destination information for. This is useful for including your server-side destinations in the consent manager, so that you can easily apply the user's tracking preferences to your server-side analytics too. _No data will be sent to these write keys._

##### shouldRequireConsent

Expand Down Expand Up @@ -344,6 +348,7 @@ Type: `array<object>`<br>
Default: `[]`

Destinations enabled for the provided write keys. Each destination contains these properties:

```
{
id,
Expand All @@ -366,7 +371,7 @@ New destinations that have been enabled since the user last gave consent.
Type: `object`<br>
Default: `{}`

The current preferences in state. By default if should be in the format of `{destinationId: true|false}`, but if you're using [mapCustomPreferences][] the object map can be in any format you want. *Note: this isn't the saved preferences.*
The current preferences in state. By default if should be in the format of `{destinationId: true|false}`, but if you're using [mapCustomPreferences][] the object map can be in any format you want. _Note: this isn't the saved preferences._

##### isConsentRequired

Expand Down Expand Up @@ -399,12 +404,12 @@ For a more detailed/advanced example, checkout the [ConsentManager implementatio

```javascript
import React from 'react'
import {ConsentManagerBuilder} from '@segment/consent-manager'
import { ConsentManagerBuilder } from '@segment/consent-manager'

export default function() {
return (
<ConsentManagerBuilder writeKey="<your-segment-write-key>">
{({destinations, preferences, setPreferences, saveConsent}) => (
{({ destinations, preferences, setPreferences, saveConsent }) => (
<div>
<h2>Tracking tools</h2>
<ul>
Expand Down Expand Up @@ -447,24 +452,22 @@ export default function() {
- `openConsentManager()` - Opens the [ConsentManager][] preferences dialog.
- `doNotTrack()` - Returns the user's Do Not Track preference (normalises the cross browser API differences). Returns `true`, `false` or `null` (no preference specified).


## License

consent-manager is released under the MIT license.

Copyright © 2018, Segment.io, Inc.


[analytics.js snippet]: https://segment.com/docs/sources/website/analytics.js/quickstart/#step-1-copy-the-snippet
[Inferno]: https://infernojs.org/
[currentScript]: https://caniuse.com/#feat=document-currentscript
[inEU]: https://github.com/segmentio/in-eu
[ConsentManager]: #consentmanager
[ConsentManagerBuilder]: #consentmanagerbuilder
[preact]: https://preactjs.com
[currentscript]: https://caniuse.com/#feat=document-currentscript
[ineu]: https://github.com/segmentio/in-eu
[consentmanager]: #consentmanager
[consentmanagerbuilder]: #consentmanagerbuilder
[top-domain]: https://github.com/segmentio/top-domain
[mapCustomPreferences]: #mapcustompreferences
[shouldRequireConsent]: #shouldrequireconsent-1
[mapcustompreferences]: #mapcustompreferences
[shouldrequireconsent]: #shouldrequireconsent-1
[preferences]: #preferences
[setPreferences]: #setpreferences
[ConsentManager implementation]: src/consent-manager
[CSS selector]: https://developer.mozilla.org/en-US/docs/Web/API/Document/querySelector
[setpreferences]: #setpreferences
[consentmanager implementation]: src/consent-manager
[css selector]: https://developer.mozilla.org/en-US/docs/Web/API/Document/querySelector
Loading