/*

Copyright 2008-2013 Clipperz Srl

This file is part of Clipperz, the online password manager.
For further information about its features and functionalities please
refer to http://www.clipperz.com.

* Clipperz is free software: you can redistribute it and/or modify it
  under the terms of the GNU Affero General Public License as published
  by the Free Software Foundation, either version 3 of the License, or 
  (at your option) any later version.

* Clipperz is distributed in the hope that it will be useful, but 
  WITHOUT ANY WARRANTY; without even the implied warranty of 
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  See the GNU Affero General Public License for more details.

* You should have received a copy of the GNU Affero General Public
  License along with Clipperz. If not, see http://www.gnu.org/licenses/.

*/

if (typeof(Clipperz) == 'undefined') { Clipperz = {}; }
if (typeof(Clipperz.PM) == 'undefined') { Clipperz.PM = {}; }
if (typeof(Clipperz.PM.Components) == 'undefined') { Clipperz.PM.Components = {}; }
if (typeof(Clipperz.PM.Components.Panels) == 'undefined') { Clipperz.PM.Components.Panels = {}; }

//#############################################################################

Clipperz.PM.Components.Panels.MainPanel = function(anElement, args) {
	args = args || {};

    Clipperz.PM.Components.Panels.MainPanel.superclass.constructor.call(this, anElement, args);

	this._recordListDataModel = null;
	this._selectedRecord = null;
	this._recordDetailComponent = null;
	this._recordListGrid = null;

	this._directLinkItemTemplate = null;
	this._recordItemTemplate = null;
	
	this._addNewRecordButton = null;
	this._deleteRecordButton = null;

	this._creationWizard = null;

	Clipperz.NotificationCenter.register(null, 'selectAndEnterEditMode', this, 'selectRecordAndEnterEditModeHandler');

	Clipperz.NotificationCenter.register(null, 'recordAdded', this, 'recordAddedHandler');
	Clipperz.NotificationCenter.register(null, 'recordUpdated', this, 'recordUpdatedHandler');
	Clipperz.NotificationCenter.register(null, 'recordRemoved', this, 'recordRemovedHandler');

	Clipperz.NotificationCenter.register(null, 'directLoginAdded', this, 'directLoginAddedHandler');
	Clipperz.NotificationCenter.register(null, 'directLoginUpdated', this, 'directLoginUpdatedHandler');
	Clipperz.NotificationCenter.register(null, 'directLoginRemoved', this, 'directLoginRemovedHandler');

	Clipperz.NotificationCenter.register(null, 'accountLocked', this, 'accountLockedHandler');

	MochiKit.Signal.connect(MochiKit.DOM.currentWindow(), 'onresize', this, 'resizeModalMask');
	this.render();
	
	return this;
}

//=============================================================================

YAHOO.extendX(Clipperz.PM.Components.Panels.MainPanel, Clipperz.PM.Components.Panels.BasePanel, {

	'toString': function() {
		return "Clipperz.PM.Components.Panels.MainPanel component";
	},
	
	//-------------------------------------------------------------------------

	'render': function() {
		this.element().update("");
		Clipperz.YUI.DomHelper.append(this.element().dom, {tag:'table', id:'mainPanelTABLE', border:'0', cellspacing:'0', cellpadding:'0', children:[
			{tag:'tbody', children:[
				{tag:'tr', children:[
					{tag:'td', width:'15', children:[
						{tag:'div', cls:'mainPanelMinHeightDiv'}
					]},
					{tag:'td', valign:'top', id:'directLoginsTD', width:'200', children:[
						{tag:'div', id:'accountStatus', children:[
							{tag:'div', cls:'header', children:[{tag:'h5', cls:'title', htmlString:"Account info"}]},
//							{tag:'div', cls:'accountStatus', html:"early adopter"},
							{tag:'div', cls:'accountLevel', children:[
								{tag:'span', cls:'label', html:"status"},
								{tag:'span', cls:'status', html:"early adopter"}
							]},
							{tag:'div', cls:'accountLevel', children:[
								{tag:'span', cls:'label', html:"level"},
//								{tag:'span', cls:'level', html:"★☆☆☆"}
								{tag:'span', cls:'level', html:"☆☆☆☆"}
							]},
							{tag:'div', cls:'accountExpiration', children:[
								{tag:'span', cls:'label', html:"expires"},
//								{tag:'span', cls:'expriation', html:"on 26 April 2014"}
								{tag:'span', cls:'expriation', html:"never"}
							]},
//							{tag:'div', cls:'payButton', children:[
//								{tag:'a', href:'#', cls:'info', html:"info"}
//							]}
							{tag:'div', id:'payButton', cls:'payButton'}
						]},
						{tag:'div', id:'directLoginsBlock', children:[
							{tag:'div', cls:'directLoginsBlockHeaderBox', children:[{tag:'h3', id:'directLoginTitle', htmlString:Clipperz.PM.Strings['mainPanelDirectLoginBlockLabel']}]},
							{tag:'div', id:'directLoginsDescription', htmlString:Clipperz.PM.Strings['mainPanelDirectLoginBlockDescription']},
							{tag:'ul', id:'directLogins'}
						]}
					]},
					{tag:'td', width:'15', children:[
						{tag:'div', cls:'mainPanelMinHeightDiv'}
					]},
					{tag:'td', valign:'top', children:[
						{tag:'div', id:'mainContent', children:[
							{tag:'div', id:'recordListBlockHeader'},
							{tag:'div', id:'recordListAndDetailBlock', children:[
								{tag:'table', id:'recordListAndDetailBlockTABLE', border:'0', cellspacing:'0', cellpadding:'0', children:[
									{tag:'tbody', children:[
										{tag:'tr', children:[
											{tag:'td', valign:'top', width:'250', children:[
												{tag:'div', id:'recordListBlock', children:[
													{tag:'div', id:'recordListFilterHeader'},
													{tag:'ul', id:'records'}
												]}
											]},
											{tag:'td', id:'recordDetailSeparatorTD', rowspan:'2', valign:'top', bgcolor:'#ddddff', html:' '},
											{tag:'td', valign:'top', children:[
												{tag:'div', id:'recordDetailMainBlock', children:[
													{tag:'div', id:'recordTitleTopBlock'},
													{tag:'div', id:'recordDetailBlock', children:[
														{tag:'div', id:'recordDetail'}
													]}
												]},
												{tag:'div', id:'recordCreationWizardMainBlock', children:[
													{tag:'div', id:'recordCreationWizard', html:"WIZARD"}
												]}
											]}
										]},
										{tag:'tr', children:[
											{tag:'td', id:'cardBoxLowerLeftTD', html:' '},
											{tag:'td', id:'cardBoxLowerRightTD', html:' '}
										]}
									]}
								]}
							]}
						]}
					]},
					{tag:'td', width:'15', html:" "}
				]}
			]}
		]});

		this.renderRecordListBlockHeader();
//		this.renderRecordListFilterHeader();

		YAHOO.ext.Element.get('directLogins').setVisibilityMode(YAHOO.ext.Element.DISPLAY).hide();
		//	TODO
		new YAHOO.ext.Button('payButton', {text:"Info", handler:this.payButtonHandler, scope:this});
		
		this.recordDetailComponent();

		YAHOO.ext.Element.get('recordDetailMainBlock').setVisibilityMode(YAHOO.ext.Element.DISPLAY).show();
		YAHOO.ext.Element.get('recordCreationWizardMainBlock').setVisibilityMode(YAHOO.ext.Element.DISPLAY).hide();
	},

	//-------------------------------------------------------------------------

	'payButtonHandler': function(anEvent) {
		window.open('https://www.clipperz.com/pricing/', '_blank');
	},
	
	//-------------------------------------------------------------------------

	'addNewRecordButton': function() {
		return this._addNewRecordButton;
	},
	
	'setAddNewRecordButton': function(aValue) {
		this._addNewRecordButton = aValue;
	},
	
	'deleteRecordButton': function() {
		return this._deleteRecordButton;
	},
	
	'setDeleteRecordButton': function(aValue) {
		this._deleteRecordButton = aValue;
	},

	//-------------------------------------------------------------------------
	
	'addNewRecord': function(anEvent) {
		var deferredResult;
//		var currentNumberOfRecords;
		
		deferredResult = new MochiKit.Async.Deferred();
		
//		currentNumberOfRecords = MochiKit.Base.keys(this.user().records()).length;
/*
//		if ((this.user().preferences().shouldShowDonationPanel()) && (currentNumberOfRecords > 0) && ((currentNumberOfRecords%10) == 0)) {
//		if (true) {
		if ((this.user().preferences().shouldShowDonationPanel()) && (currentNumberOfRecords >= 5)) {
			deferredResult.addCallback(Clipperz.PM.showDonationSplashScreen, this.user(), 'recordListAddRecordButton');
		}
*/
		deferredResult.addCallback(MochiKit.Base.bind(function() {
			var currentlySelectedRecord;
			
			currentlySelecedRecord = this.selectedRecord();
			this.setSelectedRecord(null);
		
			YAHOO.ext.Element.get('recordDetailMainBlock').hide();
			YAHOO.ext.Element.get('recordCreationWizardMainBlock').show();
			this.setCreationWizard(new Clipperz.PM.Components.RecordDetail.CreationWizard(YAHOO.ext.Element.get('recordCreationWizardMainBlock'), {previouslySelectedRecord:currentlySelecedRecord, mainComponent:this}));
		
			this.enterModalView();
		}, this));

		deferredResult.callback();
	},

	//-------------------------------------------------------------------------

	'creationWizard': function() {
		return this._creationWizard;
	},
	
	'setCreationWizard': function(aValue) {
		this._creationWizard = aValue;
	},
	
	//-------------------------------------------------------------------------
	
	'exitWizard': function(aSelectedRecord, shouldEnterEditMode) {
//MochiKit.Logging.logDebug(">>> MainPanel.exitWizard - " + aSelectedRecord)
		YAHOO.ext.Element.get('recordCreationWizardMainBlock').hide();
		YAHOO.ext.Element.get('recordDetailMainBlock').show();

		if (shouldEnterEditMode == true) {
			this.selectRecordAndEnterEditMode(aSelectedRecord);
		} else {
			this.setSelectedRecord(aSelectedRecord);
			this.exitModalView();
		}
		
		this.creationWizard().remove();
		this.setCreationWizard(null);
//MochiKit.Logging.logDebug("<<< MainPanel.exitWizard");
	},
	
	//-------------------------------------------------------------------------

	'selectRecordAndEnterEditMode': function(aRecord) {
		this.setSelectedRecord(aRecord);
		this.recordDetailComponent().setEditMode('EDIT');
	},

	'selectRecordAndEnterEditModeHandler': function(anEvent) {
		this.selectRecordAndEnterEditMode(anEvent.source());
	},

	//-------------------------------------------------------------------------

	'resizeModalMask': function() {
//MochiKit.Logging.logDebug(">>> MainPanel.resizeModalMask");
		MochiKit.Style.setElementDimensions('recordDetailEditModeHeaderMask', {w:MochiKit.Style.getElementDimensions('mainDiv').w, h:119});

		MochiKit.Style.setElementDimensions('recordDetailEditModeVerticalMask', {w:511, h:MochiKit.Style.getElementDimensions('mainDiv').h - 119});
//MochiKit.Logging.logDebug("<<< MainPanel.resizeModalMask");
	},

	//-------------------------------------------------------------------------
	
	'enterModalView': function() {
		if (this.user().preferences().useSafeEditMode()) {
			var headerMaskElement;
			var verticalMaskElement;

			this.resizeModalMask();

			headerMaskElement = YAHOO.ext.Element.get('recordDetailEditModeHeaderMask');
			headerMaskElement.show();
			headerMaskElement.mask();

			verticalMaskElement = YAHOO.ext.Element.get('recordDetailEditModeVerticalMask');
			verticalMaskElement.show();
			verticalMaskElement.mask();
		}
	},
	
	//-------------------------------------------------------------------------

	'exitModalView': function() {
		if (this.user().preferences().useSafeEditMode()) {
			var headerMaskElement;
			var verticalMaskElement;
			
			headerMaskElement = YAHOO.ext.Element.get('recordDetailEditModeHeaderMask');
			headerMaskElement.unmask();
			headerMaskElement.hide();

			verticalMaskElement = YAHOO.ext.Element.get('recordDetailEditModeVerticalMask');
			verticalMaskElement.unmask();
			verticalMaskElement.hide();
		}
	},

	//-------------------------------------------------------------------------

	'removeSelectedRecord': function() {
		var selectedRecordReferences;

//MochiKit.Logging.logDebug(">>> MainPanel.removeSelectedRecord");
		if (this.selectedRecord() != null) {
			selectedRecordReferences = [this.selectedRecord().reference()];
		} else {
			selectedRecordReferences = [];
		}

		if (selectedRecordReferences.length > 0 ) {
			var	recordReference;
			var	records;
			var deferred;
			
			records = [];
			for (recordReference in selectedRecordReferences) {
				var record;
		
//MochiKit.Logging.logDebug("### MainPanel.removeSelectedRecord - recordReference: " + selectedRecordReferences[recordReference]);
				record = this.user().records()[selectedRecordReferences[recordReference]];
//MochiKit.Logging.logDebug("### MainPanel.removeSelectedRecord - record: " + record);
				records.push(record);
			}
//MochiKit.Logging.logDebug("### MainPanel.removeSelectedRecord - records.length: " + records.length);

			deferred = new MochiKit.Async.Deferred();
//MochiKit.Logging.logDebug("--- MainPanel.removeSelectedRecord - 1:");
//deferred.addBoth(function(res) {MochiKit.Logging.logDebug("MainPanel.removeSelectedRecord - 1: " + res); return res;});
//MochiKit.Logging.logDebug("--- MainPanel.removeSelectedRecord - 2:");
			deferred.addCallback(function() {
				var deferredResult;
				
				deferredResult = new MochiKit.Async.Deferred();
				Clipperz.PM.Components.MessageBox().deferredShow({
					title:Clipperz.PM.Strings['mainPanelDeletingRecordPanelConfirmationTitle'],
					text:Clipperz.PM.Strings['mainPanelDeleteRecordPanelConfirmationText'],
					width:240,
					showProgressBar:false,
					showCloseButton:false,
					buttons:{
						'yes':Clipperz.PM.Strings['mainPanelDeleteRecordPanelConfirmButtonLabel'],
						'no':Clipperz.PM.Strings['mainPanelDeleteRecordPanelDenyButtonLabel']
 					},
					fn:MochiKit.Base.partial(function(aDeferred, aResult) {
						if (aResult == 'yes') {
							aDeferred.callback(aResult);
						} else {
							aDeferred.errback(aResult);
						}
					}, deferredResult)
				}, 'recordListRemoveRecordButton');
				
				return deferredResult;
			});
//MochiKit.Logging.logDebug("--- MainPanel.removeSelectedRecord - 3:");
//deferred.addBoth(function(res) {MochiKit.Logging.logDebug("MainPanel.removeSelectedRecord - 2: " + res); return res;});
//MochiKit.Logging.logDebug("--- MainPanel.removeSelectedRecord - 4:");
//deferred.addBoth(function(res) {MochiKit.Logging.logDebug("MainPanel.removeSelectedRecord - 3: " + res); return res;});
			deferred.addCallback(MochiKit.Base.method(Clipperz.PM.Components.MessageBox(), 'deferredShow'),
				{
					title:Clipperz.PM.Strings['mainPanelDeletingRecordPanelInitialTitle'],
					text:Clipperz.PM.Strings['mainPanelDeletingRecordPanelInitialText'],
					width:240,
					showProgressBar:true,
					showCloseButton:false,
					steps:5
				}
			);
//MochiKit.Logging.logDebug("--- MainPanel.removeSelectedRecord - 5:");
//deferred.addBoth(function(res) {MochiKit.Logging.logDebug("MainPanel.removeSelectedRecord - 4: " + res); return res;});
			deferred.addCallback(MochiKit.Base.method(this.user(), 'deleteRecordsAction'), records);
//MochiKit.Logging.logDebug("--- MainPanel.removeSelectedRecord - 6:");
//deferred.addBoth(function(res) {MochiKit.Logging.logDebug("MainPanel.removeSelectedRecord - 5: " + res); return res;});
//MochiKit.Logging.logDebug("--- MainPanel.removeSelectedRecord - 7:");
//deferred.addBoth(function(res) {MochiKit.Logging.logDebug("MainPanel.removeSelectedRecord - 6: " + res); return res;});
			deferred.addCallback(function() {
				Clipperz.PM.Components.MessageBox().update({
					title:null,
					text:Clipperz.PM.Strings['mainPanelDeletingRecordPanelCompletedText'],
					step:'next',
					buttons:{}
				});
			});
//MochiKit.Logging.logDebug("--- MainPanel.removeSelectedRecord - 8:");
//deferred.addBoth(function(res) {MochiKit.Logging.logDebug("MainPanel.removeSelectedRecord - 7: " + res); return res;});
			deferred.addCallback(MochiKit.Async.wait, 1);
//MochiKit.Logging.logDebug("--- MainPanel.removeSelectedRecord - 9:");
//deferred.addBoth(function(res) {MochiKit.Logging.logDebug("MainPanel.removeSelectedRecord - 8: " + res); return res;});
			deferred.addCallback(function(res) {
				Clipperz.PM.Components.MessageBox().hide(YAHOO.ext.Element.get('main'));
				return res;
			});
//MochiKit.Logging.logDebug("--- MainPanel.removeSelectedRecord - 10:");
//deferred.addBoth(function(res) {MochiKit.Logging.logDebug("MainPanel.removeSelectedRecord - 9: " + res); return res;});
			deferred.callback();
		} else {
//MochiKit.Logging.logDebug("+++ MainPanel.removeSelectedRecord - nothing selected");
		}
	},

	//-------------------------------------------------------------------------

	'recordDetailComponent': function() {
//MochiKit.Logging.logDebug(">>> MainPanel.recordDetailComponent");
		if (this._recordDetailComponent == null) {
//MochiKit.Logging.logDebug("--- MainPanel.recordDetailComponent - 1");
//MochiKit.Logging.logDebug("--- MainPanel.recordDetailComponent - 1 - user: " + this.user());
			this._recordDetailComponent = new Clipperz.PM.Components.RecordDetail.MainComponent(
				YAHOO.ext.Element.get('recordDetail'),
				{user:this.user(), mainPanel:this}
			);
		}

//MochiKit.Logging.logDebug("<<< MainPanel.recordDetailComponent");
		
		return this._recordDetailComponent;
	},

	//-------------------------------------------------------------------------

	'selectedRecord': function() {
		return this._selectedRecord;
	},
	
	'setSelectedRecord': function(aValue) {
//		this.hideNewRecordPanel();
//MochiKit.Logging.logDebug(">>> MainPanel.setSelectedRecord");
		if (aValue != this._selectedRecord) {
//MochiKit.Logging.logDebug("--- MainPanel.setSelectedRecord - 1");
			this._selectedRecord = aValue;
//MochiKit.Logging.logDebug("--- MainPanel.setSelectedRecord - 2");
			this.redrawRecordItems();
//MochiKit.Logging.logDebug("--- MainPanel.setSelectedRecord - 3");
			this.recordDetailComponent().setRecord(aValue);
//MochiKit.Logging.logDebug("--- MainPanel.setSelectedRecord - 4");
		}
		
		if ((aValue == null) || (Clipperz.PM.Proxy.defaultProxy.isReadOnly())) {
			this.deleteRecordButton().disable();
		} else {
			this.deleteRecordButton().enable();
		}
//MochiKit.Logging.logDebug("<<< MainPanel.setSelectedRecord");
	},

	//-------------------------------------------------------------------------

	'recordAddedHandler': function(anEvent) {
//MochiKit.Logging.logDebug(">>> MainPanel.recordAddedHandler");
		this.recordDetailComponent();
		this.redrawRecordItems();
//MochiKit.Logging.logDebug("<<< MainPanel.recordAddedHandler");
	},
	
	'recordUpdatedHandler': function(anEvent) {
//MochiKit.Logging.logDebug(">>> MainPanel.recordUpdatedHandler");
		this.redrawRecordItems();
//MochiKit.Logging.logDebug("<<< MainPanel.recordUpdatedHandler");
	},

	'recordRemovedHandler': function(anEvent) {
//MochiKit.Logging.logDebug(">>> MainPanel.recordRemovedHandler");
		this.setSelectedRecord(null);
//MochiKit.Logging.logDebug("--- MainPanel.recordRemovedHandler - 1");
		this.redrawRecordItems();
//MochiKit.Logging.logDebug("<<< MainPanel.recordRemovedHandler");
	},
	
	'compareRecords': function(a, b) {
//MochiKit.Logging.logDebug("=== compareRecords: " + a.toString() + " - " + b.toString());
		return MochiKit.Base.compare(a.label().toLowerCase(), b.label().toLowerCase());
	},
	
	'redrawRecordItems': function() {
		var template;
		var allRecords;

//MochiKit.Logging.logDebug(">>> MainPanel.redrawRecordItems");
		MochiKit.Iter.forEach(YAHOO.ext.Element.get('records').getChildrenByTagName('li'), function(aRecordElement) {
			MochiKit.Signal.disconnectAll(aRecordElement.dom);
		})
//MochiKit.Logging.logDebug("--- MainPanel.redrawRecordItems - 1");
		YAHOO.ext.Element.get('records').update("");
//MochiKit.Logging.logDebug("--- MainPanel.redrawRecordItems - 2");
		allRecords = MochiKit.Base.values(this.user().records());
//MochiKit.Logging.logDebug("--- MainPanel.redrawRecordItems - 3");
		allRecords.sort(this.compareRecords);
//MochiKit.Logging.logDebug("--- MainPanel.redrawRecordItems - 4");
		template = this.recordItemTemplate();
//MochiKit.Logging.logDebug("--- MainPanel.redrawRecordItems - 5");
		MochiKit.Iter.forEach(allRecords, MochiKit.Base.bind(function(aRecord) {
			var	recordElement;
			recordElement = template.append('records', {
				recordTitle:aRecord.label(),
				recordReference:aRecord.reference(),
				cls:((aRecord == this.selectedRecord()) ? 'selected': '')
			}, true);
//MochiKit.Logging.logDebug("--- MainPanel.redrawRecordItems - 6: " + recordElement.dom);
			recordElement.addClassOnOver('hover');
			MochiKit.Signal.connect(recordElement.dom, 'onclick', this, 'selectRecord');
		}, this));
//MochiKit.Logging.logDebug("<<< MainPanel.redrawRecordItems");
	},

	'selectRecord': function(anEvent) {
//MochiKit.Logging.logDebug(">>> MainPanel.selectRecord");
//MochiKit.Logging.logDebug("--- MainPanel.selectRecord !!! - ", this.user().records()[anEvent.src().id].label());
		this.setSelectedRecord(this.user().records()[anEvent.src().id]);
//MochiKit.Logging.logDebug("<<< MainPanel.selectRecord");		
	},
	
	//-------------------------------------------------------------------------

	'directLoginAddedHandler': function(anEvent) {
//MochiKit.Logging.logDebug(">>> MainPanel.recordRemovedHandler");
		this.redrawDirectLoginItems();
//MochiKit.Logging.logDebug("<<< MainPanel.recordRemovedHandler");
	},
	
	'directLoginUpdatedHandler': function(anEvent) {
//MochiKit.Logging.logDebug(">>> MainPanel.directLoginUpdatedHandler");
		this.redrawDirectLoginItems();
//MochiKit.Logging.logDebug("<<< MainPanel.directLoginUpdatedHandler");
	},
	
	'directLoginRemovedHandler': function(anEvent) {
//MochiKit.Logging.logDebug(">>> MainPanel.directLoginRemovedHandler");
		this.redrawDirectLoginItems();
//MochiKit.Logging.logDebug("<<< MainPanel.directLoginRemovedHandler");
	},

	'compareDirectLogins': function(a, b) {
		return MochiKit.Base.compare(a.label().toLowerCase(), b.label().toLowerCase());
	},
	
	'redrawDirectLoginItems': function() {
		var template;
		var allDirectLogins;

//MochiKit.Logging.logDebug(">>> MainPanel.redrawDirectLoginItems");
		MochiKit.Iter.forEach(YAHOO.ext.Element.get('directLogins').getChildrenByTagName('li'), function(aDirectLoginElement) {
			MochiKit.Signal.disconnectAll(aDirectLoginElement.dom);
//MochiKit.Logging.logDebug("disconnecting IMG " + aDirectLoginElement.getChildrenByTagName('img')[0].dom.src);
			MochiKit.Signal.disconnectAll(aDirectLoginElement.getChildrenByTagName('img')[0].dom);
		})
//MochiKit.Logging.logDebug("--- MainPanel.redrawDirectLoginItems - 1");
		YAHOO.ext.Element.get('directLogins').update("");
//MochiKit.Logging.logDebug("--- MainPanel.redrawDirectLoginItems - 2");
		allDirectLogins = MochiKit.Base.values(this.user().directLoginReferences());
//MochiKit.Logging.logDebug("--- MainPanel.redrawDirectLoginItems - 3");
		allDirectLogins.sort(this.compareDirectLogins);

		if (allDirectLogins.length == 0) {
			YAHOO.ext.Element.get('directLoginsDescription').show();
			YAHOO.ext.Element.get('directLogins').setVisibilityMode(YAHOO.ext.Element.DISPLAY).hide();
		} else {
			YAHOO.ext.Element.get('directLoginsDescription').setVisibilityMode(YAHOO.ext.Element.DISPLAY).hide();
			YAHOO.ext.Element.get('directLogins').show();
		}
//MochiKit.Logging.logDebug("--- MainPanel.redrawDirectLoginItems - 4");
		template = this.directLoginItemTemplate();
//MochiKit.Logging.logDebug("--- MainPanel.redrawDirectLoginItems - 5");
		MochiKit.Iter.forEach(allDirectLogins, MochiKit.Base.bind(function(aDirectLogin) {
			var	directLoginElement;
			var	faviconImageElementID;
			
			faviconImageElementID = aDirectLogin.reference() + "_faviconIMG";
			directLoginElement = template.append('directLogins', {
				elementID:faviconImageElementID,
				faviconUrl:aDirectLogin.fixedFavicon(), 
				directLoginTitle:aDirectLogin.label(),
				directLoginReference:aDirectLogin.reference()
			}, true);
//MochiKit.Logging.logDebug("--- MainPanel.redrawDirectLoginItems - 6: " + recordElement.dom);
			directLoginElement.addClassOnOver("hover");
			MochiKit.Signal.connect(directLoginElement.dom, 'onclick', this, 'handleDirectLoginClick');

			MochiKit.Signal.connect(faviconImageElementID, 'onload', this, 'handleLoadedFaviconImage');
			MochiKit.Signal.connect(faviconImageElementID, 'onerror', aDirectLogin, 'handleMissingFaviconImage');
			MochiKit.Signal.connect(faviconImageElementID, 'onabort', aDirectLogin, 'handleMissingFaviconImage');
			
//			YAHOO.ext.Element.get(faviconImageElementID).dom.src = aDirectLogin.fixedFavicon();
		}, this));
//MochiKit.Logging.logDebug("<<< MainPanel.redrawDirectLoginItems");
	},

	//-------------------------------------------------------------------------

	'handleDirectLoginClick': function(anEvent) {
		var	directLoginReference;
//MochiKit.Logging.logDebug(">>> MainPanel.handleDirectLoginClick !!!");

		directLoginReference = this.user().directLoginReferences()[anEvent.src().id];
		if (anEvent.target().className == 'directLoginItemEditButton') {
			this.editDirectLogin(directLoginReference);
		} else {
			this.openDirectLogin(directLoginReference);
		}
//MochiKit.Logging.logDebug("<<< MainPanel.handleDirectLoginClick");		
	},

	'editDirectLogin': function(aDirectLoginReference) {
//MochiKit.Logging.logDebug("=== MainPanel.editDirectLogin - " + aDirectLoginReference.label());
		this.setSelectedRecord(aDirectLoginReference.record());
	},
	
	'openDirectLogin': function(aDirectLoginReference) {
		var	deferredResult;
		var	newWindow;
				
//MochiKit.Logging.logDebug(">>> MainPanel.openDirectLogin - " + aDirectLoginReference.label());
		deferredResult = new MochiKit.Async.Deferred();
//deferredResult.addBoth(function(res) {MochiKit.Logging.logDebug("MainPanel.openDirectLogin - 1: " + res); return res;});
		deferredResult.addCallback(MochiKit.Base.method(aDirectLoginReference, 'setupJumpPageWindow'));
		deferredResult.addCallback(MochiKit.Base.method(aDirectLoginReference, 'deferredDirectLogin'));
		deferredResult.addCallback(function(aDirectLogin) {
			aDirectLogin.runDirectLogin(newWindow);
		});

		newWindow = window.open(Clipperz.PM.Strings['directLoginJumpPageUrl'], "");
//		MochiKit.Signal.connect(newWindow, 'onload', MochiKit.Base.method(deferredResult, 'callback', newWindow))
//		MochiKit.Signal.connect(newWindow, 'onload', MochiKit.Base.partial(alert, "done"));
		deferredResult.callback(newWindow);
//MochiKit.Logging.logDebug("<<< MainPanel.openDirectLogin");
	},

	//-------------------------------------------------------------------------

	'handleLoadedFaviconImage': function(anEvent) {
//MochiKit.Logging.logDebug(">>> MainPanel.handleLoadedFaviconImage");
		MochiKit.Signal.disconnectAll(anEvent.src())
//MochiKit.Logging.logDebug("<<< MainPanel.handleLoadedFaviconImage");
	},
	
	//-------------------------------------------------------------------------

	'recordItemTemplate': function() {
		if (this._recordItemTemplate == null) {
			this._recordItemTemplate = Clipperz.YUI.DomHelper.createTemplate({tag:'li', cls:'{cls}', id:'{recordReference}', children:[
				{tag:'span', html:'{recordTitle}'}
			]});
			this._recordItemTemplate.compile();
		}
		
		return this._recordItemTemplate;
	},
	
	'directLoginItemTemplate': function() {
		if (this._directLoginItemTemplate == null) {
			this._directLoginItemTemplate = Clipperz.YUI.DomHelper.createTemplate({tag:'li', id:'{directLoginReference}', children:[
				{tag:'table', border:'0', cellpadding:'0', cellspacing:'0', children:[
					{tag:'tbody', children:[
						{tag:'tr', children:[
							{tag:'td', width:'20', align:'center', valign:'top', children:[
								{tag:'img', id:'{elementID}', src:'{faviconUrl}'}
							]},
							{tag:'td', valign:'top', children:[
								{tag:'a', cls:'directLoginItemTitle', html:'{directLoginTitle}'}
							]},
							{tag:'td', valign:'top', align:'right', children:[
//								{tag:'span', cls:'directLoginItemEditButton', htmlString:Clipperz.PM.Strings['directLinkReferenceShowButtonLabel']}
								{tag:'a', cls:'directLoginItemEditButton', htmlString:Clipperz.PM.Strings['directLinkReferenceShowButtonLabel']}
							]}
						]}
					]}
				]}
			]});
			this._directLoginItemTemplate.compile();
		}
		
		return this._directLoginItemTemplate;
	},
	
	//-------------------------------------------------------------------------
/*
	'newRecordButton': function() {
		return this._newRecordButton;
	},

	'setNewRecordButton': function(aValue) {
		this._newRecordButton = aValue;
	},
	
	'newRecordCancelButton': function() {
		return this._newRecordCancelButton;
	},
	
	'setNewRecordCancelButton': function(aValue) {
		this._newRecordCancelButton = aValue;
	},
*/	
	//-------------------------------------------------------------------------

	'onkeydown': function(anEvent) {
//MochiKit.Logging.logDebug(">>> onkeydown - " + anEvent.src().id + ": " + anEvent.key().code);
		switch (anEvent.src().id) {
/*
			case this.getId('newRecordForm'):
				if (anEvent.key().code == 13) {
					this.newRecordButton().focus();
//					this.addNewRecord();
				} else if (anEvent.key().code == 27) {
					this.newRecordCancelButton().focus();
					this.hideNewRecordPanel(true);
				}
				break;
*/
			case "recordFilterSearchForm":
				if (anEvent.key().code == 13) {
//MochiKit.Logging.logDebug("SEARCH");
					this.filterCardsWithName(YAHOO.ext.Element.get('recordFilterSearchValue').dom.value);
					anEvent.event().stopPropagation();
					YAHOO.ext.Element.get('recordFilterSearchValue').focus();
				} else if (anEvent.key().code == 27) {
					this.hideRecordFilterSearchPanel(true);
					this.showRecordFilterAllPanel();
				}
				break;
		}

	},

	//-------------------------------------------------------------------------

	'renderRecordListBlockHeader': function(){
		var recordListBlockHeaderElement;
		
		recordListBlockHeaderElement = YAHOO.ext.Element.get('recordListBlockHeader');
		recordListBlockHeaderElement.update("");
		Clipperz.YUI.DomHelper.append(recordListBlockHeaderElement.dom, 		
			{tag:'table', cls:'recordListBlockHeaderTABLE', border:'0', cellspacing:'0', cellpadding:'0', children:[
				{tag:'tbody', children:[
					{tag:'tr', children:[
						{tag:'td', /*width:'50%',*/ cls:'recordBlockTitleTD', children:[
							{tag:'h3', id:'recordBlockTitle', htmlString:Clipperz.PM.Strings['mainPanelRecordsBlockLabel']}
						]},
						{tag:'td', align:'right', children:[
							{tag:'table', id:'recordListButtonsTABLE', border:'0', cellspacing:'0', cellpadding:'0', children:[
								{tag:'tbody', children:[
									{tag:'tr', children:[
										{tag:'td', cls:'recordButtonTD', align:'right', children:[
											{tag:'div', cls:'recordButton', id:'recordListAddRecordButton'}
										]},
										{tag:'td', cls:'recordButtonTD', align:'left', children:[
											{tag:'div', cls:'recordButton', id:'recordListRemoveRecordButton'}
										]}
									]}
								]}
							]}
						]},
						{tag:'td', width:'15', html:"&nbsp;"}
					]}
				]}
			]}
		);
		
		this.setAddNewRecordButton(new YAHOO.ext.Button('recordListAddRecordButton', {text:Clipperz.PM.Strings['mainPanelAddRecordButtonLabel'], handler:this.addNewRecord, scope:this}));
//		this.setAddNewRecordButton(new YAHOO.ext.Button('recordListAddRecordButton', {text:Clipperz.PM.Strings['mainPanelAddRecordButtonLabel'], handler:this.showNewRecordPanel, scope:this}));
		this.setDeleteRecordButton(new YAHOO.ext.Button('recordListRemoveRecordButton', {text:Clipperz.PM.Strings['mainPanelRemoveRecordButtonLabel'], handler:this.removeSelectedRecord, scope:this}));


		if ((Clipperz.PM.Proxy.defaultProxy.isReadOnly()) || (this.selectedRecord() == null)) {
			this.deleteRecordButton().disable();
		}
		
		if (Clipperz.PM.Proxy.defaultProxy.isReadOnly()) {
			this.addNewRecordButton().disable();
		}

	},

	//-------------------------------------------------------------------------

	'renderRecordListFilterHeader': function(){
		var recordListFilterHeaderElement;
		
		recordListFilterHeaderElement = YAHOO.ext.Element.get('recordListFilterHeader');
		recordListFilterHeaderElement.update("");
		Clipperz.YUI.DomHelper.append(recordListFilterHeaderElement.dom, 		
			{tag:'div', id:'recordFiltersDIV', children:[
				{tag:'div', id:'recordFiltersTableWrapper', children:[
					{tag:'table', id:'recordFiltersTABLE', border:'0', cellspacing:'0', cellpadding:'0', children:[
						{tag:'tbody', children:[
							{tag:'tr', children:[
								{tag:'td', id:'recordFilterAllTD', children:[{tag:'div', children:[{tag:'a', id:'recordFilterAll', htmlString:Clipperz.PM.Strings['mainPanelRecordFilterBlockAllLabel']}]}]},
								{tag:'td', id:'recordFilterTagsTD', children:[{tag:'div', children:[{tag:'a', id:'recordFilterTags', htmlString:Clipperz.PM.Strings['mainPanelRecordFilterBlockTagsLabel']}]}]},
								{tag:'td', id:'recordFilterSearchTD', children:[{tag:'div', children:[{tag:'a', id:'recordFilterSearch', htmlString:Clipperz.PM.Strings['mainPanelRecordFilterBlockSearchLabel']}]}]}
							]}
						]}
					]}
				]},
				{tag:'div', id:'recordFiltersTagsPanel'},
				{tag:'div', id:'recordFiltersSearchPanel', children:[{tag:'div', id:'recordFiltersSearchInnerPanel', children:[{tag:'div', id:'recordFiltersSearchInnerInnerPanel', children:[
					{tag:'form', id:'recordFilterSearchForm', children:[
						{tag:'input', type:'text', name:'search', id:'recordFilterSearchValue'}
					]}
				]}]}]}
			]}
		);
		
///		YAHOO.ext.Element.get('recordFiltersSearchPanel').setVisibilityMode(YAHOO.ext.Element.DISPLAY).hide();
		this.showRecordFilterAllPanel(false);

		MochiKit.Signal.connect('recordFilterSearchForm', 'onkeydown', this, 'onkeydown');
		MochiKit.Signal.connect('recordFilterSearchForm', 'onsubmit', this, 'onkeydown');
		
		MochiKit.Signal.connect('recordFilterAll', 'onclick', this, 'showRecordFilterAllPanel');
		MochiKit.Signal.connect('recordFilterTags', 'onclick', this, 'showRecordFilterTagsPanel');
		MochiKit.Signal.connect('recordFilterSearch', 'onclick', this, 'showRecordFilterSearchPanel');
	},

	//-------------------------------------------------------------------------

	'showRecordFilterAllPanel': function(shouldSlide) {
		this.hideRecordFilterTagsPanel(shouldSlide);
		this.hideRecordFilterSearchPanel(shouldSlide);
		YAHOO.ext.Element.get('recordFilterAllTD').addClass('selectedTab');
	},
	
	'hideRecordFilterAllPanel': function(shouldSlide) {
		YAHOO.ext.Element.get('recordFilterAllTD').removeClass('selectedTab');
	},
	
	//-------------------------------------------------------------------------

	'showRecordFilterTagsPanel': function(shouldSlide) {
		this.hideRecordFilterAllPanel(shouldSlide);
		this.hideRecordFilterSearchPanel(shouldSlide);
		YAHOO.ext.Element.get('recordFilterTagsTD').addClass('selectedTab');
	},

	'hideRecordFilterTagsPanel': function(shouldSlide) {
		YAHOO.ext.Element.get('recordFilterTagsTD').removeClass('selectedTab');
	},

	//-------------------------------------------------------------------------

	'showRecordFilterSearchPanel': function(shouldSlide) {
		var searchPanelActor;
		
		this.hideRecordFilterAllPanel(shouldSlide);
		this.hideRecordFilterTagsPanel(shouldSlide);
		YAHOO.ext.Element.get('recordFilterSearchTD').addClass('selectedTab');
		YAHOO.ext.Element.get('recordFilterSearchValue').dom.value = "";
		
		searchPanelActor = new YAHOO.ext.Actor('recordFiltersSearchPanel');

		searchPanelActor.startCapture(true);
		searchPanelActor.slideShow('top', 54);
		searchPanelActor.play(MochiKit.Base.bind(function() {
			YAHOO.ext.Element.get('recordFilterSearchValue').focus();
		}, this));
	},

	'hideRecordFilterSearchPanel': function(shouldSlide) {
		var searchPanelActor;
		var	callback;
		
		YAHOO.ext.Element.get('recordFilterSearchTD').removeClass('selectedTab');

		searchPanelActor = new YAHOO.ext.Actor('recordFiltersSearchPanel');

		searchPanelActor.startCapture(true)
		if (shouldSlide === false) {
			searchPanelActor.hide();
			searchPanelActor.slideHide('top');
			searchPanelActor.show();
		} else {
			searchPanelActor.slideHide('top');
		}
		
		callback = MochiKit.Base.bind(function() {
		}, this);
		
		searchPanelActor.play(callback);
	},

	//-------------------------------------------------------------------------

	'filterCardsWithName': function(aValue) {
MochiKit.Logging.logDebug(">>> filterCardsWithName: " + aValue);
		
MochiKit.Logging.logDebug("<<< filterCardsWithName");
	},

	'accountLockedHandler': function() {
		this.setSelectedRecord(null);
	},
	
	//-------------------------------------------------------------------------

	'switchLanguageHandler': function() {
		YAHOO.ext.Element.get('directLoginTitle').update(Clipperz.PM.Strings['mainPanelDirectLoginBlockLabel']);
		YAHOO.ext.Element.get('directLoginsDescription').update("");
		MochiKit.Iter.forEach(Clipperz.PM.Strings['mainPanelDirectLoginBlockDescriptionConfig'], function(aConfigItem) {
			Clipperz.YUI.DomHelper.append(YAHOO.ext.Element.get('directLoginsDescription').dom, aConfigItem);
		});
		YAHOO.ext.Element.get('recordBlockTitle').update(Clipperz.PM.Strings['mainPanelRecordsBlockLabel']);
		this.renderRecordListBlockHeader();
//		this.renderRecordListFilterHeader();

//		YAHOO.ext.Element.get('newRecordPanelTitleH2').update(Clipperz.PM.Strings['mainPanelNewRecordPanelTitle']);
//		YAHOO.ext.Element.get('newRecordPanelTitleLabel').update(Clipperz.PM.Strings['mainPanelNewRecordPanelRecordTitleLabel']);
//		YAHOO.ext.Element.get('newRecordPanelConfigLabel').update("");
//		MochiKit.Iter.forEach(Clipperz.PM.Strings['mainPanelNewRecordPanelRecordConfigConfig'], function(aConfigItem) {
//			Clipperz.YUI.DomHelper.append(YAHOO.ext.Element.get('newRecordPanelConfigLabel').dom, aConfigItem);
//		});
//		this.newRecordButton().setText(Clipperz.PM.Strings['mainPanelNewRecordPanelCreateButtonLabel']);
//		this.newRecordCancelButton().setText(Clipperz.PM.Strings['mainPanelNewRecordPanelCancelButtonLabel']);
		
		this.recordDetailComponent().render();
	},

	//-------------------------------------------------------------------------
	__syntaxFix__: "syntax fix"
	
});