Your IP : 18.118.144.244


Current Path : /var/www/www-root/data/webdav/www.catalog.monolith-realty.ru/bitrix/js/ui/animations/
Upload File :
Current File : /var/www/www-root/data/webdav/www.catalog.monolith-realty.ru/bitrix/js/ui/animations/animations.js

(function() {

var BX = window.BX;

BX.namespace('BX.UI');

if (!!BX.UI.Animations)
{
	return;
}

BX.UI.Animations = {

	expand: function(params)
	{
		if (!BX(params.moreButtonNode))
		{
			return;
		}

		var classBlock = (BX.Type.isStringFilled(params.classBlock) ? params.classBlock : 'feed-post-text-block');
		var classOuter = (BX.Type.isStringFilled(params.classOuter) ? params.classOuter : 'feed-post-text-block-inner');
		var classInner = (BX.Type.isStringFilled(params.classInner) ? params.classInner : 'feed-post-text-block-inner-inner');
		var heightLimit = (
			!BX.Type.isUndefined(params.heightLimit)
			&& parseInt(params.heightLimit) > 0
				? parseInt(params.heightLimit)
				: 300
		);

		var tmpNode = BX.findParent(BX(params.moreButtonNode), {
			tag: 'div',
			className: classBlock
		});

		if (!tmpNode)
		{
			return;
		}

		var el = BX.findChild(tmpNode, {
			tag: 'div',
			className: classOuter,
		}, true);
		var el2 = BX.findChild(tmpNode, {
			tag: 'div',
			className: classInner,
		}, true);

		if (!el || !el2)
		{
			return;
		}

		var fxStart = heightLimit;
		var fxFinish = parseInt(el2.offsetHeight);
		var start1 = {
			height: fxStart,
		};
		var finish1 = {
			height: fxFinish,
		};

		if (!!params.moreButtonNode)
		{
			BX.remove(params.moreButtonNode);
		}

		var time = (fxFinish - fxStart) / (2000 - fxStart);
		time = (time < 0.3 ? 0.3 : (time > 0.8 ? 0.8 : time));

		el.style.maxHeight = start1.height+'px';
		el.style.overflow = 'hidden';

		el.style.maxHeight = start1.height+'px';
		el.style.overflow = 'hidden';

		(new BX["easing"]({
			duration : time*1000,
			start : start1,
			finish : finish1,
			transition : BX.easing.makeEaseOut(BX.easing.transitions.quart),
			step : function(state){
				el.style.maxHeight = state.height + "px";
				el.style.opacity = state.opacity / 100;
			},
			complete : function(){
				el.style.cssText = '';
				el.style.maxHeight = 'none';

				BX.LazyLoad.showImages(true);

				if (BX.type.isFunction(params.callback))
				{
					params.callback(el);
				}
			}
		})).animate();

		return true;
	},

	onPlayerPlay: function(playerNode)
	{
		var classes = {
			post: {
				block: 'feed-post-text-block',
				outer: 'feed-post-text-block-inner',
				inner: 'feed-post-text-block-inner-inner'
			},
			comment: {
				block: 'feed-com-block',
				outer: 'feed-com-text-inner',
				inner: 'feed-com-text-inner-inner'
			},
			more: 'feed-post-text-more'
		};
		var contentNode = BX.findParent(playerNode, {
			className: classes.post.block
		});

		var type = null;

		if (contentNode)
		{
			type = 'post';
		}
		else
		{
			contentNode = BX.findParent(playerNode, {
				className: classes.comment.block
			});

			if (contentNode)
			{
				type = 'comment';
			}
		}

		if (!contentNode)
		{
			return;
		}

		var moreButtonNode = BX.findChild(contentNode, {
			className: classes.more
		}, true);

		var doExpand = (!!moreButtonNode);
		if (doExpand)
		{
			var contentViewNode = BX.findChild(contentNode, {
				className: classes[type].outer
			}, true);

			if (contentViewNode)
			{
				var contentId = contentViewNode.getAttribute('bx-content-view-xml-id');
				if (BX.type.isNotEmptyString(contentId))
				{
					var viewedContent = BX.localStorage.get('viewedContent');
					if (BX.type.isArray(viewedContent))
					{
						if (BX.util.in_array(contentId, viewedContent))
						{
							doExpand = false;
						}
					}
				}
			}
		}

		if (doExpand)
		{
			BX.UI.Animations.expand({
				moreButtonNode: moreButtonNode,
				type: type,
				classBlock: classes[type].block,
				classOuter: classes[type].outer,
				classInner: classes[type].inner,
				heightLimit: (type == 'comment' ? 200 : 300)
			});
		}
	}
};

BX.ready(function () {
	BX.addCustomEvent('Player:onPlay', function(player)
	{
		var node = player.getElement();
		if (node)
		{
			BX.UI.Animations.onPlayerPlay(node);
		}
	});
});

})();