/*-
* ============LICENSE_START=======================================================
* SDC
* ================================================================================
* Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
* ================================================================================
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* ============LICENSE_END=========================================================
*/
///
module Sdc.Directives {
'use strict';
export interface IPerfectScrollerScope extends ng.IScope {
//update(event:string): void;
}
export class PerfectScrollerDirective implements ng.IDirective {
constructor(
private $templateCache: ng.ITemplateCacheService,
private $parse:any,
private $window:any) {
}
replace = true;
restrict = 'EA';
transclude = true;
template = (): string => {
return '
';
};
link = ($scope:IPerfectScrollerScope, $elem, $attr) => {
let self = this;
let options = {};
let psOptions = [
'wheelSpeed', 'wheelPropagation', 'minScrollbarLength', 'useBothWheelAxes',
'useKeyboard', 'suppressScrollX', 'suppressScrollY', 'scrollXMarginOffset',
'scrollYMarginOffset', 'includePadding'//, 'onScroll', 'scrollDown'
];
for (let i=0, l=psOptions.length; i {
$scope.$evalAsync(function() {
//if ($attr.scrollDown == 'true' && event != 'mouseenter') {
if (event != 'mouseenter') {
setTimeout(function () {
$($elem).scrollTop($($elem).prop("scrollHeight"));
}, 100);
}
$elem.perfectScrollbar('update');
});
};
*/
// This is necessary when you don't watch anything with the scrollbar
$elem.bind('mouseenter', function(){
//console.log("mouseenter");
$elem.perfectScrollbar('update');
});
$elem.bind('mouseleave', function(){
//console.log("mouseleave");
setTimeout(function () {
$(window).trigger('mouseup');
$elem.perfectScrollbar('update');
}, 10);
});
$elem.bind('click', function(){
//console.log("click");
// Wait 500 milliseconds until the collapse finish closing and update.
setTimeout(function () {
$elem.perfectScrollbar('update');
}, 500);
});
/**
* Check if the content of the scroller was changed, and if changed update the scroller.
* Because DOMSubtreeModified event is fire many time (while filling the content), I'm checking that
* there is at least 100 milliseconds between DOMSubtreeModified events to update the scrollbar.
* @type {boolean}
*/
let insideDOMSubtreeModified=false;
$elem.bind('DOMSubtreeModified', function(){
if (insideDOMSubtreeModified==false) {
insideDOMSubtreeModified=true;
setTimeout(function () {
insideDOMSubtreeModified=false;
$elem.perfectScrollbar('update');
}, 100);
}
});
// Possible future improvement - check the type here and use the appropriate watch for non-arrays
if ($attr.refreshOnChange) {
$scope.$watchCollection($attr.refreshOnChange, function() {
$elem.perfectScrollbar('update');
});
}
/*
// this is from a pull request - I am not totally sure what the original issue is but seems harmless
if ($attr.refreshOnResize) {
self.$window.on('resize', function(e){$scope.update(e)});
}
*/
$elem.bind('$destroy', function() {
//self.$window.off('resize', function(e){$scope.update(e)});
$elem.perfectScrollbar('destroy');
});
};
public static factory = ($templateCache: ng.ITemplateCacheService, $parse:any, $window:any)=> {
return new PerfectScrollerDirective($templateCache, $parse, $window);
};
}
PerfectScrollerDirective.factory.$inject = ['$templateCache','$parse','$window'];
}