(function($) {

	$.entwine('ss.tree', function($){
		$('.cms-tree').entwine({
			fromDocument: {
				'oncontext_show.vakata': function(e){
					this.adjustContextClass();
				}
			},
			/*
			 * Add and remove classes from context menus to allow for
			 * adjusting the display
			 */
			adjustContextClass: function(){
				var menus = $('#vakata-contextmenu').find("ul ul");

				menus.each(function(i){
					var col = "1",
						count = $(menus[i]).find('li').length;

					//Assign columns to menus over 10 items long
					if(count > 20){
						col = "3";
					}else if(count > 10){
						col = "2";
					}

					$(menus[i]).addClass('col-' + col).removeClass('right');

					//Remove "right" class that jstree adds on mouseenter
					$(menus[i]).find('li').on("mouseenter", function (e) {
						$(this).parent('ul').removeClass("right");
					});
				});
			},
			getTreeConfig: function() {
				var self = this, config = this._super(), hints = this.getHints();
				config.plugins.push('contextmenu');
				config.contextmenu = {
					'items': function(node) {

						var menuitems = {
								'edit': {
									'label': ss.i18n._t('Tree.EditPage', 'Edit page', 100, 'Used in the context menu when right-clicking on a page node in the CMS tree'),
									'action': function(obj) {
										$('.cms-container').entwine('.ss').loadPanel(ss.i18n.sprintf(
											self.data('urlEditpage'), obj.data('id')
										));
									}
								}
							};

						// Add "show as list"
						if(!node.hasClass('nochildren')) {
							menuitems['showaslist'] = {
								'label': ss.i18n._t('Tree.ShowAsList'),
								'action': function(obj) {
									$('.cms-container').entwine('.ss').loadPanel(
										self.data('urlListview') + '&ParentID=' + obj.data('id'),
										null,
										// Default to list view tab
										{tabState: {'pages-controller-cms-content': {'tabSelector': '.content-listview'}}}
									);
								}
							};
						}

						// Build a list for allowed children as submenu entries
						var pagetype = node.data('pagetype'),
							id = node.data('id'),
							allowedChildren = node.find('>a .item').data('allowedchildren'),
							menuAllowedChildren = {},
							hasAllowedChildren = false;

						// Convert to menu entries
						$.each(allowedChildren, function(klass, title){
							hasAllowedChildren = true;
							menuAllowedChildren["allowedchildren-" + klass ] = {
								'label': '<span class="jstree-pageicon"></span>' + title,
								'_class': 'class-' + klass,
								'action': function(obj) {
									$('.cms-container').entwine('.ss').loadPanel(
										$.path.addSearchParams(
											ss.i18n.sprintf(self.data('urlAddpage'), id, klass),
											self.data('extraParams')
										)
									);
								}
							};
						});

						if(hasAllowedChildren) {
							menuitems['addsubpage'] = {
									'label': ss.i18n._t('Tree.AddSubPage', 'Add page under this page', 100, 'Used in the context menu when right-clicking on a page node in the CMS tree'),
									'submenu': menuAllowedChildren
								};
						}

						menuitems['duplicate'] = {
							'label': ss.i18n._t('Tree.Duplicate'),
							'submenu': [
								{
									'label': ss.i18n._t('Tree.ThisPageOnly'),
									'action': function(obj) {
										$('.cms-container').entwine('.ss').loadPanel(
											$.path.addSearchParams(
												ss.i18n.sprintf(self.data('urlDuplicate'), obj.data('id')),
												self.data('extraParams')
											)
										);
									}
								},{
									'label': ss.i18n._t('Tree.ThisPageAndSubpages'),
									'action': function(obj) {
										$('.cms-container').entwine('.ss').loadPanel(
											$.path.addSearchParams(
												ss.i18n.sprintf(self.data('urlDuplicatewithchildren'), obj.data('id')),
												self.data('extraParams')
											)
										);
									}
								}
							]
						};

						return menuitems;
					}
				};
				return config;
			}
		});

		// Scroll tree down to context of the current page, if it isn't
		// already visible
		$('.cms-tree a.jstree-clicked').entwine({
			onmatch: function(){
				var self = this,
					panel = self.parents('.cms-panel-content'),
					scrollTo;

				if(self.offset().top < 0 ||
					self.offset().top > panel.height() - self.height()) {
					// Current scroll top + our current offset top is our
					// position in the panel
					scrollTo = panel.scrollTop() + self.offset().top
								+ (panel.height() / 2);

					panel.animate({
						scrollTop: scrollTo
					}, 'slow');
				}
			}
		});

		// Clear filters button
		$('.cms-tree-filtered .clear-filter').entwine({
			onclick: function () {
				window.location = location.protocol + '//' + location.host + location.pathname;
			}
		});

		$('.cms-tree-filtered').entwine({
			onmatch: function () {
				var self = this,
					setHeight = function () {
						var height = $('.cms-content-tools .cms-panel-content').height() - self.parent().siblings('.cms-content-toolbar').outerHeight(true);
						self.css('height', height + 'px');
					};

				setHeight();
				$(window).on('resize', window.ss.debounce(setHeight, 300));
			}
		});
	});

}(jQuery));