Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
e2feb523
Commit
e2feb523
authored
Mar 17, 2021
by
Axel García
Committed by
Axel Garcia
Mar 26, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Support both "-event" and "-action" for tracking
parent
c557d48c
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
34 additions
and
24 deletions
+34
-24
app/assets/javascripts/tracking.js
app/assets/javascripts/tracking.js
+5
-3
spec/frontend/tracking_spec.js
spec/frontend/tracking_spec.js
+29
-21
No files found.
app/assets/javascripts/tracking.js
View file @
e2feb523
...
@@ -28,7 +28,7 @@ const DEFAULT_SNOWPLOW_OPTIONS = {
...
@@ -28,7 +28,7 @@ const DEFAULT_SNOWPLOW_OPTIONS = {
};
};
const
createEventPayload
=
(
el
,
{
suffix
=
''
}
=
{})
=>
{
const
createEventPayload
=
(
el
,
{
suffix
=
''
}
=
{})
=>
{
const
action
=
el
.
dataset
.
trackEvent
+
(
suffix
||
''
);
const
action
=
(
el
.
dataset
.
trackAction
||
el
.
dataset
.
trackEvent
)
+
(
suffix
||
''
);
let
value
=
el
.
dataset
.
trackValue
||
el
.
value
||
undefined
;
let
value
=
el
.
dataset
.
trackValue
||
el
.
value
||
undefined
;
if
(
el
.
type
===
'
checkbox
'
&&
!
el
.
checked
)
value
=
false
;
if
(
el
.
type
===
'
checkbox
'
&&
!
el
.
checked
)
value
=
false
;
...
@@ -52,7 +52,7 @@ const createEventPayload = (el, { suffix = '' } = {}) => {
...
@@ -52,7 +52,7 @@ const createEventPayload = (el, { suffix = '' } = {}) => {
};
};
const
eventHandler
=
(
e
,
func
,
opts
=
{})
=>
{
const
eventHandler
=
(
e
,
func
,
opts
=
{})
=>
{
const
el
=
e
.
target
.
closest
(
'
[data-track-event]
'
);
const
el
=
e
.
target
.
closest
(
'
[data-track-event]
, [data-track-action]
'
);
if
(
!
el
)
return
;
if
(
!
el
)
return
;
...
@@ -130,7 +130,9 @@ export default class Tracking {
...
@@ -130,7 +130,9 @@ export default class Tracking {
static
trackLoadEvents
(
category
=
document
.
body
.
dataset
.
page
,
parent
=
document
)
{
static
trackLoadEvents
(
category
=
document
.
body
.
dataset
.
page
,
parent
=
document
)
{
if
(
!
this
.
enabled
())
return
[];
if
(
!
this
.
enabled
())
return
[];
const
loadEvents
=
parent
.
querySelectorAll
(
'
[data-track-event="render"]
'
);
const
loadEvents
=
parent
.
querySelectorAll
(
'
[data-track-action="render"], [data-track-event="render"]
'
,
);
loadEvents
.
forEach
((
element
)
=>
{
loadEvents
.
forEach
((
element
)
=>
{
const
{
action
,
data
}
=
createEventPayload
(
element
);
const
{
action
,
data
}
=
createEventPayload
(
element
);
...
...
spec/frontend/tracking_spec.js
View file @
e2feb523
...
@@ -176,25 +176,29 @@ describe('Tracking', () => {
...
@@ -176,25 +176,29 @@ describe('Tracking', () => {
});
});
});
});
describe
(
'
tracking interface events
'
,
()
=>
{
describe
.
each
`
term
${
'
event
'
}
${
'
action
'
}
`
(
'
tracking interface events with data-track-$term
'
,
({
term
})
=>
{
let
eventSpy
;
let
eventSpy
;
beforeEach
(()
=>
{
beforeEach
(()
=>
{
eventSpy
=
jest
.
spyOn
(
Tracking
,
'
event
'
);
eventSpy
=
jest
.
spyOn
(
Tracking
,
'
event
'
);
Tracking
.
bindDocument
(
'
_category_
'
);
// only happens once
Tracking
.
bindDocument
(
'
_category_
'
);
// only happens once
setHTMLFixture
(
`
setHTMLFixture
(
`
<input data-track-
event
="click_input1" data-track-label="_label_" value="_value_"/>
<input data-track-
${
term
}
="click_input1" data-track-label="_label_" value="_value_"/>
<input data-track-
event
="click_input2" data-track-value="_value_override_" value="_value_"/>
<input data-track-
${
term
}
="click_input2" data-track-value="_value_override_" value="_value_"/>
<input type="checkbox" data-track-
event
="toggle_checkbox" value="_value_" checked/>
<input type="checkbox" data-track-
${
term
}
="toggle_checkbox" value="_value_" checked/>
<input class="dropdown" data-track-
event
="toggle_dropdown"/>
<input class="dropdown" data-track-
${
term
}
="toggle_dropdown"/>
<div data-track-
event
="nested_event"><span class="nested"></span></div>
<div data-track-
${
term
}
="nested_event"><span class="nested"></span></div>
<input data-track-
event
bogus="click_bogusinput" data-track-label="_label_" value="_value_"/>
<input data-track-bogus="click_bogusinput" data-track-label="_label_" value="_value_"/>
<input data-track-
event
="click_input3" data-track-experiment="example" value="_value_"/>
<input data-track-
${
term
}
="click_input3" data-track-experiment="example" value="_value_"/>
`
);
`
);
});
});
it
(
'
binds to clicks on elements matching [data-track-event]
'
,
()
=>
{
it
(
`binds to clicks on elements matching [data-track-
${
term
}
]`
,
()
=>
{
document
.
querySelector
(
'
[data-track-event="click_input1"]
'
).
click
();
document
.
querySelector
(
`[data-track-
${
term
}
="click_input1"]`
).
click
();
expect
(
eventSpy
).
toHaveBeenCalledWith
(
'
_category_
'
,
'
click_input1
'
,
{
expect
(
eventSpy
).
toHaveBeenCalledWith
(
'
_category_
'
,
'
click_input1
'
,
{
label
:
'
_label_
'
,
label
:
'
_label_
'
,
...
@@ -202,14 +206,14 @@ describe('Tracking', () => {
...
@@ -202,14 +206,14 @@ describe('Tracking', () => {
});
});
});
});
it
(
'
does not bind to clicks on elements without [data-track-event]
'
,
()
=>
{
it
(
`does not bind to clicks on elements without [data-track-
${
term
}
]`
,
()
=>
{
document
.
querySelector
(
'
[data-track-
event
bogus="click_bogusinput"]
'
).
click
();
document
.
querySelector
(
'
[data-track-bogus="click_bogusinput"]
'
).
click
();
expect
(
eventSpy
).
not
.
toHaveBeenCalled
();
expect
(
eventSpy
).
not
.
toHaveBeenCalled
();
});
});
it
(
'
allows value override with the data-track-value attribute
'
,
()
=>
{
it
(
'
allows value override with the data-track-value attribute
'
,
()
=>
{
document
.
querySelector
(
'
[data-track-event="click_input2"]
'
).
click
();
document
.
querySelector
(
`[data-track-
${
term
}
="click_input2"]`
).
click
();
expect
(
eventSpy
).
toHaveBeenCalledWith
(
'
_category_
'
,
'
click_input2
'
,
{
expect
(
eventSpy
).
toHaveBeenCalledWith
(
'
_category_
'
,
'
click_input2
'
,
{
value
:
'
_value_override_
'
,
value
:
'
_value_override_
'
,
...
@@ -217,7 +221,7 @@ describe('Tracking', () => {
...
@@ -217,7 +221,7 @@ describe('Tracking', () => {
});
});
it
(
'
handles checkbox values correctly
'
,
()
=>
{
it
(
'
handles checkbox values correctly
'
,
()
=>
{
const
checkbox
=
document
.
querySelector
(
'
[data-track-event="toggle_checkbox"]
'
);
const
checkbox
=
document
.
querySelector
(
`[data-track-
${
term
}
="toggle_checkbox"]`
);
checkbox
.
click
();
// unchecking
checkbox
.
click
();
// unchecking
...
@@ -233,7 +237,7 @@ describe('Tracking', () => {
...
@@ -233,7 +237,7 @@ describe('Tracking', () => {
});
});
it
(
'
handles bootstrap dropdowns
'
,
()
=>
{
it
(
'
handles bootstrap dropdowns
'
,
()
=>
{
const
dropdown
=
document
.
querySelector
(
'
[data-track-event="toggle_dropdown"]
'
);
const
dropdown
=
document
.
querySelector
(
`[data-track-
${
term
}
="toggle_dropdown"]`
);
dropdown
.
dispatchEvent
(
new
Event
(
'
show.bs.dropdown
'
,
{
bubbles
:
true
}));
dropdown
.
dispatchEvent
(
new
Event
(
'
show.bs.dropdown
'
,
{
bubbles
:
true
}));
...
@@ -258,7 +262,7 @@ describe('Tracking', () => {
...
@@ -258,7 +262,7 @@ describe('Tracking', () => {
};
};
getExperimentData
.
mockReturnValue
(
mockExperimentData
);
getExperimentData
.
mockReturnValue
(
mockExperimentData
);
document
.
querySelector
(
'
[data-track-event="click_input3"]
'
).
click
();
document
.
querySelector
(
`[data-track-
${
term
}
="click_input3"]`
).
click
();
expect
(
eventSpy
).
toHaveBeenCalledWith
(
'
_category_
'
,
'
click_input3
'
,
{
expect
(
eventSpy
).
toHaveBeenCalledWith
(
'
_category_
'
,
'
click_input3
'
,
{
value
:
'
_value_
'
,
value
:
'
_value_
'
,
...
@@ -267,22 +271,26 @@ describe('Tracking', () => {
...
@@ -267,22 +271,26 @@ describe('Tracking', () => {
});
});
});
});
describe
(
'
tracking page loaded events
'
,
()
=>
{
describe
.
each
`
term
${
'
event
'
}
${
'
action
'
}
`
(
'
tracking page loaded events with -$term
'
,
({
term
})
=>
{
let
eventSpy
;
let
eventSpy
;
beforeEach
(()
=>
{
beforeEach
(()
=>
{
eventSpy
=
jest
.
spyOn
(
Tracking
,
'
event
'
);
eventSpy
=
jest
.
spyOn
(
Tracking
,
'
event
'
);
setHTMLFixture
(
`
setHTMLFixture
(
`
<input data-track-
event
="render" data-track-label="label1" value="_value_" data-track-property="_property_"/>
<input data-track-
${
term
}
="render" data-track-label="label1" value="_value_" data-track-property="_property_"/>
<span data-track-
event
="render" data-track-label="label2" data-track-value="_value_">
<span data-track-
${
term
}
="render" data-track-label="label2" data-track-value="_value_">
Something
Something
</span>
</span>
<input data-track-
event
="_render_bogus_" data-track-label="label3" value="_value_" data-track-property="_property_"/>
<input data-track-
${
term
}
="_render_bogus_" data-track-label="label3" value="_value_" data-track-property="_property_"/>
`
);
`
);
Tracking
.
trackLoadEvents
(
'
_category_
'
);
// only happens once
Tracking
.
trackLoadEvents
(
'
_category_
'
);
// only happens once
});
});
it
(
'
sends tracking events when [data-track-event="render"] is on an element
'
,
()
=>
{
it
(
`sends tracking events when [data-track-
${
term
}
="render"] is on an element`
,
()
=>
{
expect
(
eventSpy
.
mock
.
calls
).
toEqual
([
expect
(
eventSpy
.
mock
.
calls
).
toEqual
([
[
[
'
_category_
'
,
'
_category_
'
,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment