@alexsab-ru/scripts 0.0.3 → 0.1.0
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.
- package/README.md +74 -24
- package/lib/analytics.js +33 -21
- package/package.json +6 -6
package/README.md
CHANGED
|
@@ -1,36 +1,86 @@
|
|
|
1
|
-
# scripts
|
|
2
|
-
common libs for our websites
|
|
1
|
+
# @alexsab-ru/scripts
|
|
3
2
|
|
|
4
|
-
|
|
3
|
+
common libs for websites
|
|
4
|
+
|
|
5
|
+
## Installation
|
|
5
6
|
```bash
|
|
6
|
-
pnpm i
|
|
7
|
+
pnpm i @alexsab-ru/scripts
|
|
8
|
+
```
|
|
9
|
+
|
|
10
|
+
## Analytics module
|
|
11
|
+
|
|
12
|
+
`reachGoal` and `pageView` functions push to `dataLayer` some data with goal name
|
|
13
|
+
```js
|
|
14
|
+
reachGoal("goalName");
|
|
15
|
+
pageView(goalName);
|
|
16
|
+
```
|
|
17
|
+
|
|
18
|
+
In GTM you can use them for send goals to your analytic system
|
|
19
|
+
|
|
20
|
+
```js
|
|
21
|
+
{
|
|
22
|
+
event: "reachGoal-goalName",
|
|
23
|
+
eventAction: "goalName"
|
|
24
|
+
}
|
|
7
25
|
```
|
|
8
26
|
|
|
9
|
-
|
|
27
|
+
Use example:
|
|
10
28
|
|
|
11
29
|
```js
|
|
12
|
-
import '/
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
window.WebsiteAnalytics.dataLayer("form-open");
|
|
22
|
-
window.WebsiteAnalytics.dataLayer("form-submit");
|
|
23
|
-
window.WebsiteAnalytics.dataLayer("form-required");
|
|
24
|
-
window.WebsiteAnalytics.dataLayer("form-submit");
|
|
25
|
-
window.WebsiteAnalytics.dataLayer("form-error");
|
|
30
|
+
import { reachGoal } from '@alexsab-ru/scripts';
|
|
31
|
+
|
|
32
|
+
// automatic assign from module
|
|
33
|
+
reachGoal("phone_click");
|
|
34
|
+
reachGoal("phone_copy");
|
|
35
|
+
reachGoal("phone_contextmenu");
|
|
36
|
+
reachGoal("email_click");
|
|
37
|
+
reachGoal("email_copy");
|
|
38
|
+
reachGoal("email_contextmenu");
|
|
26
39
|
```
|
|
27
40
|
|
|
28
|
-
|
|
41
|
+
For form's analytics you may use these goals
|
|
42
|
+
|
|
29
43
|
```js
|
|
30
|
-
|
|
44
|
+
reachGoal("form_open");
|
|
45
|
+
reachGoal("form_click"); // automatic assign from module
|
|
46
|
+
reachGoal("form_change"); // automatic assign from module
|
|
47
|
+
reachGoal("form_submit");
|
|
48
|
+
reachGoal("form_required");
|
|
49
|
+
reachGoal("form_error");
|
|
50
|
+
reachGoal("form_success");
|
|
31
51
|
```
|
|
32
52
|
|
|
33
|
-
|
|
53
|
+
`getFormDataObject` is needed for Calltouch request tag.
|
|
54
|
+
|
|
34
55
|
```js
|
|
35
|
-
|
|
36
|
-
|
|
56
|
+
import { getFormDataObject } from '@alexsab-ru/scripts';
|
|
57
|
+
|
|
58
|
+
document.querySelectorAll("form").forEach((form) => {
|
|
59
|
+
form.onsubmit = async (event) => {
|
|
60
|
+
|
|
61
|
+
var formData = new FormData(form);
|
|
62
|
+
// ...
|
|
63
|
+
var formDataObj = getFormDataObject(formData, form.id);
|
|
64
|
+
|
|
65
|
+
await fetch("https://example.com/api/lead/", {
|
|
66
|
+
// ...
|
|
67
|
+
})
|
|
68
|
+
.then((res) => res.json())
|
|
69
|
+
.then((data) => {
|
|
70
|
+
if (data.answer == "required") {
|
|
71
|
+
reachGoal("form_required");
|
|
72
|
+
return;
|
|
73
|
+
} else if (data.answer == "error") {
|
|
74
|
+
reachGoal("form_error");
|
|
75
|
+
return;
|
|
76
|
+
} else {
|
|
77
|
+
reachGoal("form_success", formDataObj);
|
|
78
|
+
}
|
|
79
|
+
form.reset();
|
|
80
|
+
})
|
|
81
|
+
.catch((error) => {
|
|
82
|
+
reachGoal("form_error");
|
|
83
|
+
});
|
|
84
|
+
};
|
|
85
|
+
});
|
|
86
|
+
```
|
package/lib/analytics.js
CHANGED
|
@@ -1,7 +1,21 @@
|
|
|
1
1
|
window.dataLayer = window.dataLayer || [];
|
|
2
2
|
|
|
3
|
-
export function
|
|
4
|
-
|
|
3
|
+
export function reachGoal(eventAction, t = {}) {
|
|
4
|
+
t.eventAction = eventAction;
|
|
5
|
+
dl("reachGoal-"+eventAction, {
|
|
6
|
+
...t
|
|
7
|
+
})
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export function pageView(eventAction, t = {}) {
|
|
11
|
+
t.eventAction = eventAction;
|
|
12
|
+
dl("pageView-"+eventAction, {
|
|
13
|
+
...t
|
|
14
|
+
})
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export function dl(event, t = {}) {
|
|
18
|
+
// console.log(event, t);
|
|
5
19
|
void 0 !== window.dataLayer && window.dataLayer.push({
|
|
6
20
|
event: event,
|
|
7
21
|
...t
|
|
@@ -9,10 +23,10 @@ export function dataLayer(event, t = {}) {
|
|
|
9
23
|
}
|
|
10
24
|
|
|
11
25
|
export function getFormDataObject(formData, form_id) {
|
|
12
|
-
let obj = {"
|
|
13
|
-
formData.forEach((value, key) => (obj["
|
|
14
|
-
obj['
|
|
15
|
-
obj["
|
|
26
|
+
let obj = {"eventProperties":{}};
|
|
27
|
+
formData.forEach((value, key) => (obj["eventProperties"][key] = value));
|
|
28
|
+
obj['eventCategory'] = 'Lead';
|
|
29
|
+
obj["eventProperties"]['formID'] = form_id;
|
|
16
30
|
obj['sourceName'] = 'page';
|
|
17
31
|
return obj;
|
|
18
32
|
}
|
|
@@ -39,25 +53,25 @@ export function ymPage(pageName,goalParams) {
|
|
|
39
53
|
|
|
40
54
|
export function addPhoneGoals(item) {
|
|
41
55
|
item.addEventListener('click', function(evt) {
|
|
42
|
-
|
|
56
|
+
reachGoal('phone_click');
|
|
43
57
|
});
|
|
44
58
|
item.addEventListener('copy', function(evt) {
|
|
45
|
-
|
|
59
|
+
reachGoal('phone_copy');
|
|
46
60
|
});
|
|
47
61
|
item.addEventListener('contextmenu', function(evt) {
|
|
48
|
-
|
|
62
|
+
reachGoal('phone_contextmenu');
|
|
49
63
|
});
|
|
50
64
|
}
|
|
51
65
|
|
|
52
66
|
export function addEmailGoals(item) {
|
|
53
67
|
item.addEventListener('click', function(evt) {
|
|
54
|
-
|
|
68
|
+
reachGoal('email_click');
|
|
55
69
|
});
|
|
56
70
|
item.addEventListener('copy', function(evt) {
|
|
57
|
-
|
|
71
|
+
reachGoal('email_copy');
|
|
58
72
|
});
|
|
59
73
|
item.addEventListener('contextmenu', function(evt) {
|
|
60
|
-
|
|
74
|
+
reachGoal('email_contextmenu');
|
|
61
75
|
});
|
|
62
76
|
}
|
|
63
77
|
|
|
@@ -72,13 +86,13 @@ export function addEmailGoals(item) {
|
|
|
72
86
|
{
|
|
73
87
|
selector: 'form input',
|
|
74
88
|
action: 'click',
|
|
75
|
-
goal: '
|
|
89
|
+
goal: 'form_click',
|
|
76
90
|
title: 'Клик в поле любой формы',
|
|
77
91
|
},
|
|
78
92
|
{
|
|
79
93
|
selector: 'form input',
|
|
80
94
|
action: 'change',
|
|
81
|
-
goal: '
|
|
95
|
+
goal: 'form_change',
|
|
82
96
|
title: 'Изменения полей любой формы',
|
|
83
97
|
},
|
|
84
98
|
|
|
@@ -87,25 +101,23 @@ export function addEmailGoals(item) {
|
|
|
87
101
|
goals.forEach(function(value, index, array){
|
|
88
102
|
if(value.goal != null) {
|
|
89
103
|
document.querySelectorAll(value.selector).forEach(function(element) {
|
|
90
|
-
console.log(
|
|
104
|
+
// console.log("Set \"" + value.goal + "\" goal", element);
|
|
91
105
|
element.addEventListener(value.action, function(){
|
|
92
|
-
|
|
93
|
-
eventAction: value.goal,
|
|
106
|
+
reachGoal(value.goal, {
|
|
94
107
|
title: value.title,
|
|
95
108
|
});
|
|
96
109
|
});
|
|
97
110
|
});
|
|
98
111
|
} else if(value.hit != null) {
|
|
99
112
|
document.querySelectorAll(value.selector).forEach(function(element) {
|
|
100
|
-
console.log(
|
|
113
|
+
// console.log("Set \"" + value.goal + "\" hit", element);
|
|
101
114
|
element.addEventListener(value.action, function(){
|
|
102
|
-
|
|
103
|
-
eventAction: value.hit,
|
|
115
|
+
pageView(value.hit, {
|
|
104
116
|
title: value.title,
|
|
105
117
|
});
|
|
106
118
|
});
|
|
107
119
|
});
|
|
108
120
|
} else {
|
|
109
|
-
console.warn(
|
|
121
|
+
console.warn("Ошибка в списке целей", value);
|
|
110
122
|
}
|
|
111
123
|
});
|
package/package.json
CHANGED
|
@@ -1,11 +1,8 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@alexsab-ru/scripts",
|
|
3
|
-
"version": "0.0
|
|
3
|
+
"version": "0.1.0",
|
|
4
4
|
"description": "common libs for websites",
|
|
5
5
|
"main": "index.js",
|
|
6
|
-
"scripts": {
|
|
7
|
-
"test": "echo \"Error: no test specified\" && exit 1"
|
|
8
|
-
},
|
|
9
6
|
"repository": {
|
|
10
7
|
"type": "git",
|
|
11
8
|
"url": "git+https://github.com/alexsab-ru/scripts.git"
|
|
@@ -25,5 +22,8 @@
|
|
|
25
22
|
"publishConfig": {
|
|
26
23
|
"access": "public"
|
|
27
24
|
},
|
|
28
|
-
"homepage": "https://github.com/alexsab-ru/scripts#readme"
|
|
29
|
-
|
|
25
|
+
"homepage": "https://github.com/alexsab-ru/scripts#readme",
|
|
26
|
+
"scripts": {
|
|
27
|
+
"test": "echo \"Error: no test specified\" && exit 1"
|
|
28
|
+
}
|
|
29
|
+
}
|