1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
|
/*!
* Matomo - free/libre analytics platform
*
* @link https://matomo.org
* @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
*/
/**
* Usage:
* <div piwik-content-block>
*/
(function () {
angular.module('piwikApp').directive('piwikContentBlock', piwikContentBlock);
piwikContentBlock.$inject = ['piwik'];
function piwikContentBlock(piwik){
var adminContent = null;
return {
restrict: 'A',
replace: true,
transclude: true,
scope: {
contentTitle: '@',
feature: '@',
helpUrl: '@',
helpText: '@',
anchor: '@?'
},
templateUrl: 'plugins/CoreHome/angularjs/content-block/content-block.directive.html?cb=' + piwik.cacheBuster,
controllerAs: 'contentBlock',
compile: function (element, attrs) {
if (attrs.feature === 'true') {
attrs.feature = true;
}
return function (scope, element, attrs) {
if (scope.anchor) {
var anchor = $('<a></a>').attr('id', scope.anchor);
element.prepend(anchor);
}
var inlineHelp = element.find('[ng-transclude] > .contentHelp');
if (inlineHelp.length) {
scope.helpText = inlineHelp.html();
inlineHelp.remove();
}
if (scope.feature && (scope.feature===true || scope.feature ==='true')) {
scope.feature = scope.contentTitle;
}
if (adminContent === null) {
// cache admin node for further content blocks
adminContent = $('#content.admin');
}
var contentTopPosition = false;
if (adminContent.length) {
contentTopPosition = adminContent.offset().top;
}
if (contentTopPosition || contentTopPosition === 0) {
var parents = element.parentsUntil('.col', '[piwik-widget-loader]');
var topThis;
if (parents.length) {
// when shown within the widget loader, we need to get the offset of that element
// as the widget loader might be still shown. Would otherwise not position correctly
// the widgets on the admin home page
topThis = parents.offset().top;
} else {
topThis = element.offset().top;
}
if ((topThis - contentTopPosition) < 17) {
// we make sure to display the first card with no margin-top to have it on same as line as
// navigation
element.css('marginTop', '0');
}
}
};
}
};
}
})();
|