Merge pull request #12 in KWA/mobile-device-management from feature/KMP-7-list-folders-that-have-been-opened to master
* commit '568eb9170d61f661bfad04767cdd05e63fa1676a': List folders that have been opened through the api
This commit is contained in:
		
							
								
								
									
										21
									
								
								js/MDM.js
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								js/MDM.js
									
									
									
									
									
								
							| @@ -16,6 +16,12 @@ Zarafa.plugins.mdm.MDM = Ext.extend(Zarafa.core.Plugin, { | ||||
| 	constructor : function(config) { | ||||
| 		config = config || {}; | ||||
| 		Zarafa.plugins.mdm.MDM.superclass.constructor.call(this, config); | ||||
|  | ||||
| 		// Module information for MDM which will use in shadow store. | ||||
| 		Zarafa.core.ModuleNames["IPM.MDM"] = { | ||||
| 			list: 'pluginmdmmodule', | ||||
| 			item: 'pluginmdmmodule' | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	/** | ||||
| @@ -28,6 +34,7 @@ Zarafa.plugins.mdm.MDM = Ext.extend(Zarafa.core.Plugin, { | ||||
| 		this.registerInsertionPoint('context.settings.categories', this.createSettingCategory, this); | ||||
| 		this.registerInsertionPoint('settings.versioninformation', this.createVersionInfo, this); | ||||
| 		Zarafa.core.data.SharedComponentType.addProperty('mdm.dialog.mdmdevicecontentpanel'); | ||||
| 		Zarafa.core.data.SharedComponentType.addProperty('mdm.dialog.mdmmanagesharedfoldercontentpanel'); | ||||
| 		Zarafa.plugins.mdm.MDM.superclass.initPlugin.apply(this, arguments); | ||||
| 	}, | ||||
|  | ||||
| @@ -44,6 +51,9 @@ Zarafa.plugins.mdm.MDM = Ext.extend(Zarafa.core.Plugin, { | ||||
| 			case Zarafa.core.data.SharedComponentType['mdm.dialog.mdmdevicecontentpanel']: | ||||
| 				bid = 1; | ||||
| 				break; | ||||
| 			case Zarafa.core.data.SharedComponentType['mdm.dialog.mdmmanagesharedfoldercontentpanel']: | ||||
| 				bid = 1; | ||||
| 				break; | ||||
| 		} | ||||
| 		return bid; | ||||
| 	}, | ||||
| @@ -57,7 +67,16 @@ Zarafa.plugins.mdm.MDM = Ext.extend(Zarafa.core.Plugin, { | ||||
| 	 */ | ||||
| 	getSharedComponent : function (type, record) | ||||
| 	{ | ||||
| 		return Zarafa.plugins.mdm.dialogs.MDMDeviceContentPanel; | ||||
| 		var component; | ||||
| 		switch (type) { | ||||
| 			case Zarafa.core.data.SharedComponentType['mdm.dialog.mdmdevicecontentpanel']: | ||||
| 				component = Zarafa.plugins.mdm.dialogs.MDMDeviceContentPanel; | ||||
| 				break; | ||||
| 			case Zarafa.core.data.SharedComponentType['mdm.dialog.mdmmanagesharedfoldercontentpanel']: | ||||
| 				component = Zarafa.plugins.mdm.dialogs.MDMManageSharedFolderContentPanel; | ||||
| 				break; | ||||
| 		} | ||||
| 		return component; | ||||
| 	}, | ||||
|  | ||||
|  | ||||
|   | ||||
							
								
								
									
										41
									
								
								js/data/JsonDeviceFolderReader.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								js/data/JsonDeviceFolderReader.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,41 @@ | ||||
| Ext.namespace('Zarafa.plugins.mdm.data'); | ||||
|  | ||||
| /** | ||||
|  * @class Zarafa.plugins.mdm.data.JsonDeviceFolderReader | ||||
|  * @extends Zarafa.core.data.JsonReader | ||||
|  * | ||||
|  * This extension of the {@link Zarafa.core.data.JsonReader} supports | ||||
|  * {@link Zarafa.plugins.mdm.data.MDMDeviceStore stores} which can hold different type of | ||||
|  * {@link Zarafa.plugins.mdm.data.MDMDeviceRecord records}. | ||||
|  */ | ||||
| Zarafa.plugins.mdm.data.JsonDeviceFolderReader = Ext.extend(Zarafa.core.data.JsonReader, { | ||||
|  | ||||
| 	/** | ||||
| 	 * @cfg {Zarafa.core.data.RecordCustomObjectType} customObjectType The custom object type | ||||
| 	 * which represents the {@link Ext.data.Record records} which should be created using | ||||
| 	 * {@link Zarafa.core.data.RecordFactory#createRecordObjectByCustomType}. | ||||
| 	 */ | ||||
| 	customObjectType: Zarafa.core.data.RecordCustomObjectType.MDM_Device_Folder, | ||||
|  | ||||
| 	/** | ||||
| 	 * @constructor | ||||
| 	 * @param {Object} meta Metadata configuration options. | ||||
| 	 * @param {Object} recordType (optional) Optional Record type matches the type | ||||
| 	 * which must be read from response. If no type is given, it will use the | ||||
| 	 * record type for the {@link Zarafa.core.data.RecordCustomObjectType#ZARAFA_RECIPIENT}. | ||||
| 	 */ | ||||
| 	constructor: function (meta, recordType) | ||||
| 	{ | ||||
| 		meta = Ext.applyIf(meta || {}, { | ||||
| 			id: 'folderid', | ||||
| 			idProperty: 'folderid', | ||||
| 			dynamicRecord: false | ||||
| 		}); | ||||
|  | ||||
| 		if (!Ext.isDefined(recordType)) { | ||||
| 			recordType = Zarafa.core.data.RecordFactory.getRecordClassByCustomType(meta.customObjectType || this.customObjectType); | ||||
| 		} | ||||
|  | ||||
| 		Zarafa.plugins.mdm.data.JsonDeviceFolderReader.superclass.constructor.call(this, meta, recordType); | ||||
| 	} | ||||
| }); | ||||
| @@ -5,28 +5,21 @@ Ext.namespace('Zarafa.plugins.mdm.data'); | ||||
|  * @extends Zarafa.core.data.JsonReader | ||||
|  */ | ||||
| Zarafa.plugins.mdm.data.JsonCertificateReader = Ext.extend(Zarafa.core.data.JsonReader, { | ||||
|         /** | ||||
|          * @cfg {Zarafa.core.data.RecordCustomObjectType} customObjectType The custom object type | ||||
|          * which represents the {@link Ext.data.Record records} which should be created using | ||||
|          * {@link Zarafa.core.data.RecordFactory#createRecordObjectByCustomType}. | ||||
|          */ | ||||
|         customObjectType : Zarafa.core.data.RecordCustomObjectType.ZARAFA_MDM, | ||||
|  | ||||
|         /** | ||||
|          * @constructor | ||||
|          * @param {Object} meta Metadata configuration options. | ||||
|          * @param {Object} recordType (optional) Optional Record type matches the type | ||||
|          * which must be read from response. If no type is given, it will use the | ||||
|          * record type for the {@link Zarafa.core.data.RecordCustomObjectType#ZARAFA_MDM}. | ||||
|          */ | ||||
|         constructor : function(meta, recordType) | ||||
|         { | ||||
|                 meta = Ext.applyIf(meta || {}, { | ||||
|                         dynamicRecord : false | ||||
|                 }); | ||||
| 	/** | ||||
| 	 * @constructor | ||||
| 	 * @param {Object} meta Metadata configuration options. | ||||
| 	 * @param {Object} recordType (optional) Optional Record type matches the type | ||||
| 	 * which must be read from response. If no type is given, it will use the | ||||
| 	 * record type for the {@link Zarafa.core.mapi.ObjectType#MAPI_MDM}. | ||||
| 	 */ | ||||
| 	constructor: function (meta, recordType) | ||||
| 	{ | ||||
| 		meta = Ext.applyIf(meta || {}, { | ||||
| 			dynamicRecord: false | ||||
| 		}); | ||||
| 		recordType = Zarafa.core.data.RecordFactory.getRecordClassByMessageClass('IPM.MDM'); | ||||
|  | ||||
| 		recordType = Zarafa.core.data.RecordFactory.getRecordClassByCustomType(Zarafa.core.data.RecordCustomObjectType.ZARAFA_MDM); | ||||
|  | ||||
|                 Zarafa.plugins.mdm.data.JsonCertificateReader.superclass.constructor.call(this, meta, recordType); | ||||
|         } | ||||
| 		Zarafa.plugins.mdm.data.JsonCertificateReader.superclass.constructor.call(this, meta, recordType); | ||||
| 	} | ||||
| }); | ||||
|   | ||||
							
								
								
									
										21
									
								
								js/data/MDMDeviceFolderRecord.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								js/data/MDMDeviceFolderRecord.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | ||||
| Ext.namespace('Zarafa.plugins.mdm'); | ||||
|  | ||||
| /** | ||||
|  * @class Zarafa.plugins.mdm.data.MDMDeviceFolderRecordFields | ||||
|  * | ||||
|  * Array of default fields for the {@link Zarafa.plugins.mdm.data.MDMDeviceFolderRecord} object. | ||||
|  * These fields will always be added, regardless of the exact type of | ||||
|  * {@link Zarafa.plugins.mdm.data.MDMDeviceFolderRecord record}. | ||||
|  */ | ||||
| Zarafa.plugins.mdm.data.MDMDeviceFolderRecordFields = [ | ||||
| 	{name: 'store', type: 'string'}, | ||||
| 	{name: 'folderid', type: 'string'}, | ||||
| 	{name: 'name', type: 'string'}, | ||||
| 	{name: 'type', type: 'int'}, | ||||
| 	{name: 'flags', type: 'int'}, | ||||
| 	{name: 'entryid', type: 'string'} | ||||
| ]; | ||||
|  | ||||
| Zarafa.core.data.RecordCustomObjectType.addProperty('MDM_Device_Folder'); | ||||
| Zarafa.core.data.RecordFactory.addFieldToCustomType(Zarafa.core.data.RecordCustomObjectType.MDM_Device_Folder, Zarafa.plugins.mdm.data.MDMDeviceFolderRecordFields); | ||||
| Zarafa.core.data.RecordFactory.setBaseClassToCustomType(Zarafa.core.data.RecordCustomObjectType.MDM_Device_Folder, Zarafa.core.data.MAPIRecord); | ||||
							
								
								
									
										33
									
								
								js/data/MDMDeviceFolderStore.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								js/data/MDMDeviceFolderStore.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | ||||
| Ext.namespace('Zarafa.plugins.mdm.data'); | ||||
|  | ||||
| /** | ||||
|  * @class Zarafa.plugins.mdm.data.MDMDeviceFolderStore | ||||
|  * @extends Zarafa.core.data.MAPISubStore | ||||
|  * @xtype mdm.devicefolderstore | ||||
|  * Store specific for MDM Plugin which creates {@link Zarafa.plugins.mdm.MDMDeviceFolderStore record}. | ||||
|  */ | ||||
| Zarafa.plugins.mdm.data.MDMDeviceFolderStore = Ext.extend(Zarafa.core.data.MAPISubStore, { | ||||
| 	/** | ||||
| 	 * @constructor | ||||
| 	 * @param config Configuration object | ||||
| 	 */ | ||||
| 	constructor: function (config) | ||||
| 	{ | ||||
| 		config = config || {}; | ||||
|  | ||||
| 		Ext.applyIf(config, { | ||||
| 			autoLoad: true, | ||||
| 			remoteSort: false, | ||||
| 			reader: new Zarafa.plugins.mdm.data.JsonDeviceFolderReader(), | ||||
| 			writer: new Zarafa.core.data.JsonWriter(), | ||||
| 			proxy: new Zarafa.core.data.IPMProxy({ | ||||
| 				listModuleName: 'pluginmdmmodule', | ||||
| 				itemModuleName: 'pluginmdmmodule' | ||||
| 			}) | ||||
| 		}); | ||||
|  | ||||
| 		Zarafa.plugins.mdm.data.MDMDeviceFolderStore.superclass.constructor.call(this, config); | ||||
| 	} | ||||
| }); | ||||
|  | ||||
| Ext.reg('mdm.devicefolderstore', Zarafa.plugins.mdm.data.MDMDeviceFolderStore); | ||||
							
								
								
									
										54
									
								
								js/data/MDMDeviceProxy.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								js/data/MDMDeviceProxy.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,54 @@ | ||||
| Ext.namespace('Zarafa.plugins.mdm.data'); | ||||
|  | ||||
| /** | ||||
|  * @class Zarafa.plugins.mdm.data.MDMDeviceProxy | ||||
|  * @extends Zarafa.core.data.MAPIProxy | ||||
|  */ | ||||
| Zarafa.plugins.mdm.data.MDMDeviceProxy = Ext.extend(Zarafa.core.data.MAPIProxy, { | ||||
|  | ||||
| 	/** | ||||
| 	 * @constructor | ||||
| 	 * @param {Object} config Configuration object | ||||
| 	 */ | ||||
| 	constructor: function (config) | ||||
| 	{ | ||||
| 		config = config || {}; | ||||
| 		Ext.applyIf(config, { | ||||
| 			listModuleName: 'pluginmdmmodule', | ||||
| 			itemModuleName: 'pluginmdmmodule' | ||||
| 		}); | ||||
|  | ||||
| 		Zarafa.plugins.mdm.data.MDMDeviceProxy.superclass.constructor.call(this, config); | ||||
| 	}, | ||||
|  | ||||
| 	/** | ||||
| 	 * This will create a {@link Zarafa.core.data.ProxyResponseHandler ProxyResponseHandler} object | ||||
| 	 * which will be used by the {@link Zarafa.core.data.ResponseRouter ResponseRouter} when the | ||||
| 	 * response for the given request has returned. | ||||
| 	 * | ||||
| 	 * @param {String} modulename The modulename which is being accessed with this request | ||||
| 	 * @param {Zarafa.core.Actions} serverAction The action to perform on the server. | ||||
| 	 * @param {Ext.data.Api.action} action name of the action to perform. | ||||
| 	 * @param {Ext.data.Record[]} records list of records to operate on. | ||||
| 	 * @param {Object} parameters object containing user parameters such as range (pagination) information, sorting information, etc. | ||||
| 	 * @param {Ext.data.DataReader} reader data reader. Converts raw JavaScript objects (in our case) to instances of {@link Ext.data.Record} | ||||
| 	 * @param {Function} callback call back function to call when the request has finished successfully. | ||||
| 	 * @param {Object} scope scope for the call back function. | ||||
| 	 * @param {Object} args arguments object. This will be passed to the call back function on successful read. | ||||
| 	 * @return {Object} An instance of the {@link Zarafa.plugins.mdm.data.MDMDeviceResponseHandler ProxyResponseHandler} | ||||
| 	 * which should be used for this request. | ||||
| 	 * @private | ||||
| 	 */ | ||||
| 	getResponseHandlerForRequest: function (modulename, serverAction, action, records, parameters, reader, callback, scope, args) | ||||
| 	{ | ||||
| 		return new Zarafa.plugins.mdm.data.MDMDeviceResponseHandler({ | ||||
| 			proxy: this, | ||||
| 			action: action, | ||||
| 			reader: reader, | ||||
| 			sendRecords: records, | ||||
| 			options: args, | ||||
| 			callback: callback, | ||||
| 			scope: scope | ||||
| 		}); | ||||
| 	} | ||||
| }); | ||||
| @@ -1,5 +1,10 @@ | ||||
| Ext.namespace('Zarafa.plugins.mdm'); | ||||
|  | ||||
| /** | ||||
|  * @class Zarafa.plugins.mdm.data.MDMDeviceRecordFields Array of {@link Ext.data.Field field} configurations for the | ||||
|  * {@link Zarafa.plugins.mdm.data.MDMDeviceRecord record} object. | ||||
|  * @private | ||||
|  */ | ||||
| Zarafa.plugins.mdm.data.MDMDeviceRecordFields = [ | ||||
| 	{name: 'entryid', type: 'string'}, | ||||
| 	{name: 'devicetype', type: 'string'}, | ||||
| @@ -12,30 +17,22 @@ Zarafa.plugins.mdm.data.MDMDeviceRecordFields = [ | ||||
| 	{name: 'lastupdatetime', type: 'date', dateFormat: 'timestamp'}, | ||||
| 	{name: 'wipestatus', type: 'string'}, | ||||
| 	{name: 'policyname', type: 'string'}, | ||||
| 	{name: 'totalfolders', type: 'string'}, | ||||
| 	{name: 'sharedfolders', type: 'string'}, | ||||
| 	{name: 'shortfolderids', type: 'string'}, | ||||
| 	{name: 'synchronizedfolders', type: 'string'}, | ||||
| 	{name: 'emailsfolder', type: 'string'}, | ||||
| 	{name: 'contactsfolder', type: 'string'}, | ||||
| 	{name: 'tasksfolder', type: 'string'}, | ||||
| 	{name: 'calendarsfolder', type: 'string'}, | ||||
| 	{name: 'notesfolder', type: 'string'}, | ||||
| 	{name: 'synchronizedfolders', type: 'string', defaultValue:'0'}, | ||||
| 	{name: 'emailsfolder', type: 'string', defaultValue:'0'}, | ||||
| 	{name: 'contactsfolder', type: 'string', defaultValue:'0'}, | ||||
| 	{name: 'tasksfolder', type: 'string', defaultValue:'0'}, | ||||
| 	{name: 'calendarsfolder', type: 'string', defaultValue:'0'}, | ||||
| 	{name: 'notesfolder', type: 'string', defaultValue:'0'}, | ||||
| 	{name: 'koeversion', type: 'string'}, | ||||
| 	{name: 'koebuild', type: 'string'}, | ||||
| 	{name: 'koebuilddate', type: 'date', dateFormat: 'timestamp'} | ||||
| 	{name: 'koebuilddate', type: 'date', dateFormat: 'timestamp'}, | ||||
| 	{name: 'message_class', type: 'string', defaultValue:"IPM.MDM"} | ||||
| ]; | ||||
|  | ||||
| /** | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| Zarafa.plugins.mdm.data.MDMDeviceRecord = Ext.extend(Zarafa.core.data.IPMRecord, {}); | ||||
| Zarafa.core.data.RecordCustomObjectType.addProperty('ZARAFA_MDM'); | ||||
| Zarafa.core.data.RecordFactory.addFieldToCustomType(Zarafa.core.data.RecordCustomObjectType.ZARAFA_MDM, Zarafa.plugins.mdm.data.MDMDeviceRecordFields); | ||||
|  | ||||
| Zarafa.core.data.RecordFactory.addListenerToCustomType(Zarafa.core.data.RecordCustomObjectType.ZARAFA_MDM, 'createphantom', function(record) | ||||
| { | ||||
| 	// Phantom records must always be marked as opened (they contain the full set of data) | ||||
| 	record.afterOpen(); | ||||
| }); | ||||
|  | ||||
| Zarafa.core.data.RecordFactory.setBaseClassToCustomType(Zarafa.core.data.RecordCustomObjectType.ZARAFA_MDM, Zarafa.plugins.mdm.data.MDMDeviceRecord); | ||||
| Zarafa.core.data.RecordFactory.addFieldToMessageClass('IPM.MDM', Zarafa.plugins.mdm.data.MDMDeviceRecordFields); | ||||
| Zarafa.core.data.RecordFactory.setBaseClassToMessageClass('IPM.MDM', Zarafa.plugins.mdm.data.MDMDeviceRecord); | ||||
| Zarafa.core.data.RecordFactory.setSubStoreToMessageClass('IPM.MDM', 'sharedfolders', Zarafa.plugins.mdm.data.MDMDeviceFolderStore); | ||||
|   | ||||
							
								
								
									
										41
									
								
								js/data/MDMDeviceResponseHandler.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								js/data/MDMDeviceResponseHandler.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,41 @@ | ||||
| Ext.namespace('Zarafa.plugins.mdm.data'); | ||||
|  | ||||
| /** | ||||
|  * @class Zarafa.plugins.mdm.data.MDMDeviceResponseHandler | ||||
|  * @extends Zarafa.core.data.ProxyResponseHandler | ||||
|  * | ||||
|  * A Simple implementation for a {@link Zarafa.plugins.mdm.data.MDMDeviceResponseHandler ResponseHandler}. | ||||
|  * This one can only be used by {@link Ext.data.DataProxy proxies} which wish to handle a Response | ||||
|  * to their Request. | ||||
|  * | ||||
|  * This implementation limits itself to firing an {@link Ext.data.DataProxy#exception exception} | ||||
|  * on error, and calling a callback function when all processing has been completed. | ||||
|  */ | ||||
| Zarafa.plugins.mdm.data.MDMDeviceResponseHandler = Ext.extend(Zarafa.core.data.ProxyResponseHandler, { | ||||
|  | ||||
| 	/** | ||||
| 	 * Handles the list response. Gathers the stores from the response data, converts each entry | ||||
| 	 * into a {@link Zarafa.core.MAPIStore MAPIStore} and pushes them into the collectedItems. | ||||
| 	 * @param {Object} data The response object belonging to the given command. | ||||
| 	 * @return {Boolean} False when action could not be handled successfully. This will | ||||
| 	 * not cancel the transaction itself, but rather causes the 'success' argument for the | ||||
| 	 * {@link #done} function to be false. | ||||
| 	 */ | ||||
| 	doOpen: function(response) | ||||
| 	{ | ||||
| 		this.receivedRecords = this.readRecordsFromResponse(response, 'item'); | ||||
| 	}, | ||||
|  | ||||
| 	/** | ||||
| 	 * Handles the list response. Gathers the stores from the response data, converts each entry | ||||
| 	 * into a {@link Zarafa.core.MAPIStore MAPIStore} and pushes them into the collectedItems. | ||||
| 	 * @param {Object} data The response object belonging to the given command. | ||||
| 	 * @return {Boolean} False when action could not be handled successfully. This will | ||||
| 	 * not cancel the transaction itself, but rather causes the 'success' argument for the | ||||
| 	 * {@link #done} function to be false. | ||||
| 	 */ | ||||
| 	doList: function(response) | ||||
| 	{ | ||||
| 		this.receivedRecords = this.readRecordsFromResponse(response, 'item'); | ||||
| 	} | ||||
| }); | ||||
| @@ -20,10 +20,7 @@ Zarafa.plugins.mdm.data.MDMDeviceStore = Ext.extend(Zarafa.core.data.ListModuleS | ||||
| 			remoteSort: false, | ||||
| 			reader : new Zarafa.plugins.mdm.data.JsonCertificateReader(), | ||||
| 			writer : new Zarafa.core.data.JsonWriter(), | ||||
| 			proxy  : new Zarafa.core.data.IPMProxy({ | ||||
| 				listModuleName: 'pluginmdmmodule', | ||||
| 				itemModuleName: 'pluginmdmmodule' | ||||
| 			}) | ||||
| 			proxy  : new Zarafa.plugins.mdm.data.MDMDeviceProxy() | ||||
| 		}); | ||||
|  | ||||
| 		Zarafa.plugins.mdm.data.MDMDeviceStore.superclass.constructor.call(this, config); | ||||
|   | ||||
							
								
								
									
										57
									
								
								js/data/MDMHierarchyTreeLoader.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								js/data/MDMHierarchyTreeLoader.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,57 @@ | ||||
| Ext.namespace('Zarafa.hierarchy.data'); | ||||
|  | ||||
| /** | ||||
|  * @class Zarafa.plugins.mdm.data.MDMHierarchyTreeLoader | ||||
|  * @extends Zarafa.hierarchy.data.HierarchyTreeLoader | ||||
|  * | ||||
|  * A Special treeloader to be used by the {@link Zarafa.plugins.mdm.data.MDMHierarchyTreeLoader MDMHierarchyTree}. | ||||
|  * This wil dynamically load the child nodes for a given node by obtaining the subfolders of | ||||
|  * the folder related to the given node. | ||||
|  */ | ||||
| Zarafa.plugins.mdm.data.MDMHierarchyTreeLoader = Ext.extend(Zarafa.hierarchy.data.HierarchyTreeLoader, { | ||||
|  | ||||
| 	/** | ||||
| 	 * @constructor | ||||
| 	 * @param {Object} config Configuration object | ||||
| 	 */ | ||||
| 	constructor : function(config) | ||||
| 	{ | ||||
| 		Zarafa.plugins.mdm.data.MDMHierarchyTreeLoader.superclass.constructor.call(this, config); | ||||
| 	}, | ||||
|  | ||||
| 	/** | ||||
| 	 * Add extra attributes for a new {@link Zarafa.hierarchy.ui.FolderNode folderNode} which is about | ||||
| 	 * to be created. This will check the {@link Zarafa.hierarchy.ui.FolderNode#folder folder} to | ||||
| 	 * see what properties must be set. | ||||
| 	 * | ||||
| 	 * Override to provide (@link Zarafa.plugins.mdm.ui.MDMFolderNodeUI MDMFolderNodeUI} to ui provider | ||||
| 	 * @param {Object} attr The attributes which will be used to create the node | ||||
| 	 * @return {Zarafa.hierarchy.ui.FolderNode} The created node | ||||
| 	 */ | ||||
| 	createNode : function(attr) | ||||
| 	{ | ||||
| 		var folder = attr.folder; | ||||
|  | ||||
| 		if (folder) { | ||||
| 			if (attr.nodeType === 'rootfolder') { | ||||
| 				attr.extendedDisplayName = this.tree.hasFilter(); | ||||
| 			} | ||||
|  | ||||
| 			// To uniquely identify the favorites tree nodes we append the "favorites-" key word with node id | ||||
| 			// when the node is created. | ||||
| 			attr.id = folder.isFavoritesFolder() ? "favorites-" + folder.get('entryid') : folder.get('entryid'); | ||||
| 			if (folder.isFavoritesRootFolder()) { | ||||
| 				attr.leaf = folder.get('assoc_content_count') === 0; | ||||
| 			} else { | ||||
| 				attr.leaf = !folder.get('has_subfolder'); | ||||
| 			} | ||||
|  | ||||
| 			attr.uiProvider = Zarafa.plugins.mdm.ui.MDMFolderNodeUI; | ||||
| 			attr.expanded = this.tree.isFolderOpened(folder); | ||||
| 			attr.allowDrag = !folder.isDefaultFolder(); | ||||
| 		} | ||||
|  | ||||
| 		// call parent of parent because of parent class will change ui provider | ||||
| 		return Zarafa.hierarchy.data.HierarchyTreeLoader.superclass.createNode.apply(this, arguments); | ||||
| 	} | ||||
| }); | ||||
| @@ -2,12 +2,12 @@ Ext.namespace('Zarafa.plugins.mdm.dialogs'); | ||||
|  | ||||
| /** | ||||
|  * @class Zarafa.plugins.mdm.dialogs.MDMDeviceContentPanel | ||||
|  * @extends Zarafa.core.ui.ContentPanel | ||||
|  * @extends Zarafa.core.ui.RecordContentPanel | ||||
|  * @xtype mdmplugin.devicecontentpanel | ||||
|  * | ||||
|  * The content panel which is use to show device detail panel. | ||||
|  */ | ||||
| Zarafa.plugins.mdm.dialogs.MDMDeviceContentPanel = Ext.extend(Zarafa.core.ui.ContentPanel, { | ||||
| Zarafa.plugins.mdm.dialogs.MDMDeviceContentPanel = Ext.extend(Zarafa.core.ui.RecordContentPanel, { | ||||
|  | ||||
| 	/** | ||||
| 	 * @constructor | ||||
| @@ -16,19 +16,24 @@ Zarafa.plugins.mdm.dialogs.MDMDeviceContentPanel = Ext.extend(Zarafa.core.ui.Con | ||||
| 	constructor: function (config) | ||||
| 	{ | ||||
| 		config = config || {}; | ||||
| 		var isKOE =  config.record && config.record.get('koeversion') ? true : false; | ||||
| 		var isKOE = config.record && config.record.get('koeversion') ? true : false; | ||||
| 		Ext.applyIf(config, { | ||||
| 			xtype: 'mdmplugin.devicecontentpanel', | ||||
| 			modal: true, | ||||
| 			title: dgettext('plugin_mdm', config.record.get('devicetype')), | ||||
| 			layout  : 'fit', | ||||
| 			stateful : false, | ||||
| 			width : isKOE ? 440 : 405, | ||||
| 			height : isKOE ? 395 : 360, | ||||
| 			recordComponentPluginConfig: Ext.applyIf(config.recordComponentPluginConfig || {}, { | ||||
| 				allowWrite: true, | ||||
| 				useShadowStore: true | ||||
| 			}), | ||||
| 			layout: 'fit', | ||||
| 			stateful: false, | ||||
| 			showLoadMask: false, | ||||
| 			width: isKOE ? 440 : 405, | ||||
| 			height: isKOE ? 450 : 420, | ||||
| 			items: [{ | ||||
| 				xtype: 'mdmplugin.mdmdevicepanel', | ||||
| 				record: config.record, | ||||
| 				isKoe : isKOE, | ||||
| 				isKoe: isKOE, | ||||
| 				buttons: [{ | ||||
| 					text: _('Ok'), | ||||
| 					handler: this.onOk, | ||||
|   | ||||
| @@ -12,7 +12,7 @@ Zarafa.plugins.mdm.dialogs.MDMDeviceGeneralTab = Ext.extend(Ext.form.FormPanel, | ||||
| 	/** | ||||
| 	 * @cfg {Boolean} isKoe True if device has Kopano Outlook Extension information. | ||||
| 	 */ | ||||
| 	isKoe : false, | ||||
| 	isKoe: false, | ||||
|  | ||||
| 	/** | ||||
| 	 * @constructor | ||||
| @@ -54,7 +54,7 @@ Zarafa.plugins.mdm.dialogs.MDMDeviceGeneralTab = Ext.extend(Ext.form.FormPanel, | ||||
| 	createDeviceInfoPanel: function (config) | ||||
| 	{ | ||||
| 		return { | ||||
| 			cls : 'mdm-device-panel', | ||||
| 			cls: 'mdm-device-panel', | ||||
| 			defaultType: 'displayfield', | ||||
| 			defaults: { | ||||
| 				disabled: true | ||||
| @@ -89,7 +89,7 @@ Zarafa.plugins.mdm.dialogs.MDMDeviceGeneralTab = Ext.extend(Ext.form.FormPanel, | ||||
| 	createFolderInfoPanel: function () | ||||
| 	{ | ||||
| 		return { | ||||
| 			cls : 'mdm-device-panel mdm-field-sep', | ||||
| 			cls: 'mdm-device-panel mdm-field-sep', | ||||
| 			defaultType: 'displayfield', | ||||
| 			items: [{ | ||||
| 				cls: 'mdm-display-name', | ||||
| @@ -104,7 +104,7 @@ Zarafa.plugins.mdm.dialogs.MDMDeviceGeneralTab = Ext.extend(Ext.form.FormPanel, | ||||
| 				xtype: 'fieldset', | ||||
| 				layout: 'form', | ||||
| 				labelWidth: 140, | ||||
| 				cls : 'mdm-synchronize-panel', | ||||
| 				cls: 'mdm-synchronize-panel', | ||||
| 				defaultType: 'displayfield', | ||||
| 				defaults: { | ||||
| 					labelSeparator: '', | ||||
| @@ -126,7 +126,48 @@ Zarafa.plugins.mdm.dialogs.MDMDeviceGeneralTab = Ext.extend(Ext.form.FormPanel, | ||||
| 				}, { | ||||
| 					fieldLabel: _('Tasks'), | ||||
| 					name: 'tasksfolder' | ||||
| 				}] | ||||
| 				}, | ||||
|                     this.createSharedFolderInfoPanel() | ||||
| 				] | ||||
| 			}] | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	/** | ||||
| 	 * Function which is use to create shared folders panel | ||||
| 	 * @returns {Object} Configuration object for the panel which shows folders properties | ||||
| 	 */ | ||||
| 	createSharedFolderInfoPanel: function () | ||||
| 	{ | ||||
| 		return { | ||||
| 			xtype: 'panel', | ||||
| 			border: false, | ||||
|             cls: 'mdm-synchronize-shared-panel', | ||||
| 			height: 50, | ||||
|             disabled: false, | ||||
| 			layout: { | ||||
| 				type: 'hbox', | ||||
| 				align: 'stretch', | ||||
| 				pack: 'start' | ||||
| 			}, | ||||
| 			items: [{ | ||||
| 				layout: 'form', | ||||
| 				border: false, | ||||
| 				items: [{ | ||||
| 					xtype: 'displayfield', | ||||
| 					fieldLabel: 'Shared Folders', | ||||
| 					disabled: true, | ||||
| 					name : 'sharedfolders' | ||||
| 				}], | ||||
| 				flex: 1 | ||||
| 			}, { | ||||
| 				xtype: 'button', | ||||
| 				text: dgettext('plugin_mdm', 'Managed shared Folders'), | ||||
| 				cls: 'mdm-managesharedfolder-button', | ||||
| 				listeners: { | ||||
| 					click: this.onClickManageSharedFolder, | ||||
| 					scope: this | ||||
| 				} | ||||
| 			}] | ||||
| 		}; | ||||
| 	}, | ||||
| @@ -142,13 +183,25 @@ Zarafa.plugins.mdm.dialogs.MDMDeviceGeneralTab = Ext.extend(Ext.form.FormPanel, | ||||
|  | ||||
| 	/** | ||||
| 	 * Function which handles the after render event of status field. | ||||
| 	 * Which is use to set the the display name for the given Provisioning Status into given field | ||||
| 	 * Which is use to set the display name for the given Provisioning Status into given field | ||||
| 	 * @param {Ext.form.TextField} statusField text field | ||||
| 	 */ | ||||
| 	onAfterRenderStatus: function (statusField) | ||||
| 	{ | ||||
| 		var status = parseInt(this.record.get("wipestatus")); | ||||
| 		statusField.setValue(Zarafa.plugins.mdm.data.ProvisioningStatus.getDisplayName(status)); | ||||
| 	}, | ||||
|  | ||||
| 	/** | ||||
| 	 * Function which handles the click event of manage shared folder button. | ||||
| 	 * It will open {@link Zarafa.plugins.mdm.dialogs.MDMManageSharedFolderContentPanel dialog} | ||||
| 	 */ | ||||
| 	onClickManageSharedFolder: function () | ||||
| 	{ | ||||
| 		Zarafa.core.data.UIFactory.openLayerComponent(Zarafa.core.data.SharedComponentType['mdm.dialog.mdmmanagesharedfoldercontentpanel'], undefined, { | ||||
| 			manager: Ext.WindowMgr, | ||||
| 			record: this.dialog.record | ||||
| 		}); | ||||
| 	} | ||||
| }); | ||||
|  | ||||
|   | ||||
							
								
								
									
										36
									
								
								js/dialogs/MDMManageSharedFolderContentPanel.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								js/dialogs/MDMManageSharedFolderContentPanel.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,36 @@ | ||||
| Ext.namespace('Zarafa.plugins.mdm.dialogs'); | ||||
|  | ||||
| /** | ||||
|  * @class Zarafa.plugins.mdm.dialogs.MDMManageSharedFolderContentPanel | ||||
|  * @extends Zarafa.core.ui.ContentPanel | ||||
|  * @xtype zarafa.managesharedfoldercontentpanel | ||||
|  * | ||||
|  * This will display a {@link Zarafa.plugins.mdm.dialogs.MDMManageSharedFolderPanel contentpanel} | ||||
|  * to show {@link Zarafa.core.data.IPFRecord folders} which are shared with device. | ||||
|  */ | ||||
| Zarafa.plugins.mdm.dialogs.MDMManageSharedFolderContentPanel = Ext.extend(Zarafa.core.ui.ContentPanel, { | ||||
|  | ||||
| 	/** | ||||
| 	 * @constructor | ||||
| 	 * @param config Configuration structure | ||||
| 	 */ | ||||
| 	constructor: function (config) { | ||||
| 		config = config || {}; | ||||
|  | ||||
| 		Ext.applyIf(config, | ||||
| 			{ | ||||
| 			xtype: 'mdm.managesharedfoldercontentpanel', | ||||
| 			layout: 'fit', | ||||
| 			title: dgettext('plugin_mdm','Manage Shared Folder'), | ||||
| 			width: 300, | ||||
| 			height: 350, | ||||
| 			items: [{ | ||||
| 				xtype: 'mdm.managesharedfolderpanel' | ||||
| 			}] | ||||
| 		}); | ||||
|  | ||||
| 		Zarafa.plugins.mdm.dialogs.MDMManageSharedFolderContentPanel.superclass.constructor.call(this, config); | ||||
| 	} | ||||
| }); | ||||
|  | ||||
| Ext.reg('mdm.managesharedfoldercontentpanel', Zarafa.plugins.mdm.dialogs.MDMManageSharedFolderContentPanel); | ||||
							
								
								
									
										132
									
								
								js/dialogs/MDMManageSharedFolderPanel.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										132
									
								
								js/dialogs/MDMManageSharedFolderPanel.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,132 @@ | ||||
| Ext.namespace('Zarafa.plugins.mdm.dialogs'); | ||||
|  | ||||
| /** | ||||
|  * @class Zarafa.plugins.mdm.dialogs.MDMManageSharedFolderPanel | ||||
|  * @extends Ext.Panel | ||||
|  * @xtype mdm.managesharedfolderpanel | ||||
|  * | ||||
|  * Panel for users to show the {@link Zarafa.core.data.IPFRecord folders} which are shared with device | ||||
|  */ | ||||
| Zarafa.plugins.mdm.dialogs.MDMManageSharedFolderPanel = Ext.extend(Ext.Panel, { | ||||
|  | ||||
| 	/** | ||||
| 	 * @constructor | ||||
| 	 * @param {Object} config Configuration structure | ||||
| 	 */ | ||||
| 	constructor: function (config) | ||||
| 	{ | ||||
| 		config = config || {}; | ||||
|  | ||||
| 		Ext.applyIf(config, { | ||||
| 			xtype: 'mdm.managesharedfolderpanel', | ||||
| 			layout: { | ||||
| 				type: 'fit', | ||||
| 				align: 'stretch' | ||||
| 			}, | ||||
| 			border: false, | ||||
| 			header: false, | ||||
| 			items: [ | ||||
| 				this.createTreePanel() | ||||
| 			], | ||||
| 			buttonAlign: 'right', | ||||
| 			buttons: [{ | ||||
| 				text: _('Apply'), | ||||
| 				ref: '../okButton', | ||||
| 				cls: 'zarafa-action', | ||||
| 				scope: this | ||||
| 			}, { | ||||
| 				text: _('Cancel'), | ||||
| 				ref: '../cancelButton', | ||||
| 				handler: this.onCancel, | ||||
| 				scope: this | ||||
| 			}] | ||||
| 		}); | ||||
|  | ||||
| 		Zarafa.plugins.mdm.dialogs.MDMManageSharedFolderPanel.superclass.constructor.call(this, config); | ||||
| 	}, | ||||
|  | ||||
| 	/** | ||||
| 	 * Creates a {@link Zarafa.hierarchy.ui.Tree treepanel} | ||||
| 	 * which contains all the {@link Zarafa.hierarchy.data.MAPIFolderRecord folders} | ||||
| 	 * on which search get perform. | ||||
| 	 * @return {Object} Configuration object for the tree panel. | ||||
| 	 * @private | ||||
| 	 */ | ||||
| 	createTreePanel: function () | ||||
| 	{ | ||||
| 		return { | ||||
| 			xtype: 'panel', | ||||
| 			layout : 'form', | ||||
| 			defaults: { | ||||
| 				cls : 'mdm-create-tree-panel-item' | ||||
| 			}, | ||||
| 			border: false, | ||||
| 			flex: 1, | ||||
| 			items: [{ | ||||
| 				xtype: 'displayfield', | ||||
| 				hideLabel : true, | ||||
| 				value: dgettext('plugin_mdm','Select folders to sync on your device') | ||||
| 			}, { | ||||
| 				xtype: 'mdm.hierarchytree', | ||||
| 				autoScroll : true, | ||||
| 				nodeConfig : { | ||||
| 					checked : false | ||||
| 				}, | ||||
| 				multiSelect: true, | ||||
| 				hideShowAllFolders: true, | ||||
| 				border: true, | ||||
| 				treeSorter: true, | ||||
| 				bbarConfig: { | ||||
| 					hidden: true | ||||
| 				}, | ||||
| 				enableDD: false, | ||||
| 				anchor: '100% 90%', | ||||
| 				ref: '../hierarchyTree' | ||||
| 			}] | ||||
| 		}; | ||||
| 	}, | ||||
|  | ||||
| 	/** | ||||
| 	 * Initialize the events | ||||
| 	 * @private | ||||
| 	 */ | ||||
| 	initEvents: function () | ||||
| 	{ | ||||
| 		Zarafa.plugins.mdm.dialogs.MDMManageSharedFolderPanel.superclass.initEvents.apply(this, arguments); | ||||
| 		this.mon(this.hierarchyTree, 'load', this.onTreeNodeLoad, this); | ||||
| 	}, | ||||
|  | ||||
| 	/** | ||||
| 	 * Fired when the {@link Zarafa.hierarchy.ui.Tree Tree} fires the {@link Zarafa.hierarchy.ui.Tree#load load} | ||||
| 	 * event. This function will try to select those {@link Ext.tree.TreeNode TreeNode} in | ||||
| 	 * {@link Zarafa.hierarchy.ui.Tree Tree} which was shared with respective device. When the given node is not loaded yet, it will try again | ||||
| 	 * later when the event is fired again. | ||||
| 	 * | ||||
| 	 * @private | ||||
| 	 */ | ||||
| 	onTreeNodeLoad: function () | ||||
| 	{ | ||||
| 		var subStore = this.dialog.record.getSubStore('sharedfolders'); | ||||
| 		var folders = subStore.getRange(); | ||||
| 		folders.forEach(function (folder) { | ||||
| 			var node = this.hierarchyTree.getNodeById(folder.get('entryid')); | ||||
| 			if (Ext.isDefined(node)) { | ||||
| 				if(node.hasChildNodes()){ | ||||
| 					node.expand(); | ||||
| 				} | ||||
| 				node.getUI().toggleCheck(true) | ||||
| 			} | ||||
| 		}, this); | ||||
| 	}, | ||||
|  | ||||
| 	/** | ||||
| 	 * Action handler when the user presses the "Cancel" button. | ||||
| 	 * This will close the panel. | ||||
| 	 */ | ||||
| 	onCancel: function () | ||||
| 	{ | ||||
| 		this.dialog.close(); | ||||
| 	} | ||||
| }); | ||||
|  | ||||
| Ext.reg('mdm.managesharedfolderpanel', Zarafa.plugins.mdm.dialogs.MDMManageSharedFolderPanel); | ||||
| @@ -208,6 +208,7 @@ Zarafa.plugins.mdm.settings.MDMSettingsWidget = Ext.extend(Zarafa.settings.ui.Se | ||||
| 	onRowDblClick : function (grid, rowIndex) | ||||
| 	{ | ||||
| 		var record = grid.getStore().getAt(rowIndex); | ||||
| 		record.opened = false; | ||||
| 		Zarafa.core.data.UIFactory.openLayerComponent(Zarafa.core.data.SharedComponentType['mdm.dialog.mdmdevicecontentpanel'], undefined, { | ||||
| 			manager : Ext.WindowMgr, | ||||
| 			record : record | ||||
|   | ||||
							
								
								
									
										151
									
								
								js/ui/MDMFolderNodeUI.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										151
									
								
								js/ui/MDMFolderNodeUI.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,151 @@ | ||||
| Ext.namespace('Zarafa.plugins.mdm.ui'); | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * @class Zarafa.plugins.mdm.ui.MDMFolderNodeUI | ||||
|  * @extends Zarafa.hierarchy.ui.FolderNodeUI | ||||
|  * | ||||
|  * {@link Zarafa.hierarchy.ui.FolderNodeUI} has limitation that it can add | ||||
|  * (@link Ext.form.Checkbox check box} preceded to calendar item only. | ||||
|  * So, It will add (@link Ext.form.Checkbox check box} preceded to all context items. | ||||
|  */ | ||||
| Zarafa.plugins.mdm.ui.MDMFolderNodeUI = Ext.extend(Zarafa.hierarchy.ui.FolderNodeUI, { | ||||
|  | ||||
| 	/** | ||||
| 	 * Function will render {@link Zarafa.hierachy.ui.FolderNode FolderNode} based on modified template for | ||||
| 	 * our custom needs. | ||||
| 	 * @param {Zarafa.hierarchy.ui.FolderNode} node tree node. | ||||
| 	 * @param {Object} config config object of {@link Zarafa.hierarchy.ui.FolderNode FolderNode}. | ||||
| 	 * @param {Ext.Element} targetNode element in which {@link Zarafa.hierarchy.ui.FolderNode FolderNode} will be rendered. | ||||
| 	 * @param {Boolean} bulkRender | ||||
| 	 */ | ||||
| 	renderElements : function(node, config, targetNode, bulkRender) | ||||
| 	{ | ||||
| 		// add some indent caching, this helps performance when rendering a large tree | ||||
| 		this.indentMarkup = node.parentNode ? node.parentNode.ui.getChildIndent() : ''; | ||||
|  | ||||
| 		var scheme; | ||||
| 		var cb = Ext.isBoolean(config.checked); | ||||
| 		var isCalenderNode = config.folder.isCalendarFolder(); | ||||
| 		var calendarSVGIcon = ''; | ||||
|  | ||||
| 		if (isCalenderNode) { | ||||
| 			var calendarContextModel = node.getOwnerTree().model; | ||||
|  | ||||
| 			// We started providing color choosing facility to all the calendar tree-nodes. | ||||
| 			// CalendarContextModel is responsible for this facility. | ||||
| 			// There is no CalendarContextModel available in the case where that particular | ||||
| 			// calendar-tree-node doesn't belongs to MultiSelectHierarchyTree. | ||||
| 			// So, simply made that ContextModel available to current HierarchyTree. | ||||
| 			if (!calendarContextModel) { | ||||
| 				var calendarContext = container.getContextByName('calendar'); | ||||
| 				calendarContextModel = calendarContext.getModel(); | ||||
| 				node.getOwnerTree().model = calendarContextModel; | ||||
| 			} | ||||
|  | ||||
| 			scheme = calendarContextModel.getColorScheme(config.folder.get('entryid')); | ||||
|  | ||||
| 			// Get the scheme base only if we are able to get scheme successfully, | ||||
| 			// otherwise let it be undefined instead of a JS fatal error. | ||||
| 			if(scheme && scheme.base) { | ||||
| 				calendarSVGIcon = '<svg xmlns:svg="http://www.w3.org/2000/svg" xmlns="http://www.w3.org/2000/svg" width="15" height="13" viewBox="0 0 15 13" style="color:'+scheme.base+'; position:relative; top:2px;">' +  | ||||
| 									'<g>' +  | ||||
| 										'<g class="icbg" style="fill:currentColor;stroke:none">' +  | ||||
| 											'<rect width="15" height="12" x="0" y="1" />' +  | ||||
| 											'<rect width="1" height="1" x="2" y="0" />' +  | ||||
| 											'<rect width="1" height="1" x="7" y="0" />' +  | ||||
| 											'<rect width="1" height="1" x="12" y="0" />' + | ||||
| 										'</g>' +  | ||||
| 										'<path class="icgr" d="M 2.5,6.5 h 10 v 4 h -10 v -4.5 M 4.5,6.5 v 4 M 6.5,6.5 v 4 M 8.5,6.5 v 4 M 10.5,6.5 v 4 M 2.5,8.5 h 9.5" style="fill:currentColor;stroke:#ffffff;stroke-width:1;stroke-linejoin=miter" />' +  | ||||
| 									'</g>' +  | ||||
| 								'</svg>' ; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		var icon = '<img src="' + (config.icon || this.emptyIcon) + '" class="x-tree-node-icon" unselectable="on" />', | ||||
| 		nel, | ||||
| 		href = config.href ? config.href : Ext.isGecko ? "" : "#", | ||||
| 		buf = '<li class="x-tree-node">' + | ||||
| 				'<div ext:tree-node-id="' + node.id + '" class="x-tree-node-el x-tree-node-leaf x-unselectable zarafa-hierarchy-node" unselectable="on">' + | ||||
| 					// indent space | ||||
| 					'<span class="x-tree-node-indent">' + this.indentMarkup + "</span>" + | ||||
| 					// expand icon | ||||
| 					'<img src="' + this.emptyIcon + '" class="x-tree-ec-icon x-tree-elbow" />' + | ||||
| 					// checkbox | ||||
| 					(cb ? '<input class="x-tree-node-cb zarafa-hierarchy-node-cb" type="checkbox" ' + (config.checked ? 'checked="checked" />' : '/>') : '') + | ||||
| 					// node icon | ||||
| 					(isCalenderNode ? calendarSVGIcon : icon) + | ||||
| 					// node element (this.elNode) | ||||
| 					'<a hidefocus="on" class="x-tree-node-anchor zarafa-hierarchy-node-anchor" ' + | ||||
| 						'href="' + href + '" tabIndex="1" ' + | ||||
| 						(config.hrefTarget ? ' target="' + config.hrefTarget + '"' : "") + ">" + | ||||
| 							// hierarchy node text (this.textNode) | ||||
| 							'<span unselectable="on">' + (node.tpl ? node.tpl.apply(config) : node.text) + '</span>' + | ||||
| 							// counter node (this.counterNode) | ||||
| 							'<span class="zarafa-hierarchy-node-counter" unselectable="on"></span>' + | ||||
| 							'<span class="zarafa-hierarchy-node-owner" unselectable="on"></span>'+ | ||||
| 					"</a>" + | ||||
| 				"</div>" + | ||||
| 				'<ul class="x-tree-node-ct" style="display:none;"></ul>' + | ||||
| 			"</li>"; | ||||
|  | ||||
| 		if (bulkRender !== true && node.nextSibling && (nel = node.nextSibling.ui.getEl())) { | ||||
| 			this.wrap = Ext.DomHelper.insertHtml("beforeBegin", nel, buf); | ||||
| 		}else{ | ||||
| 			this.wrap = Ext.DomHelper.insertHtml("beforeEnd", targetNode, buf); | ||||
| 		} | ||||
|  | ||||
| 		this.elNode = this.wrap.childNodes[0]; | ||||
| 		this.ctNode = this.wrap.childNodes[1]; | ||||
| 		var cs = this.elNode.childNodes; | ||||
| 		this.indentNode = cs[0]; | ||||
| 		this.ecNode = cs[1]; | ||||
| 		this.iconNode = cs[2]; | ||||
| 		var index = 3; | ||||
| 		if (cb) { | ||||
| 			this.checkbox = cs[2]; | ||||
| 			this.iconNode = cs[3]; | ||||
|  | ||||
| 			// Get child elements of caledar icon which is used to register in drag and drop manager. | ||||
| 			var groupContainerNode = this.iconNode.childNodes[0]; | ||||
| 			if (Ext.isDefined(groupContainerNode)) { | ||||
| 				var groupNode = groupContainerNode.childNodes[0]; | ||||
| 				var rectNode = groupNode.childNodes[0]; | ||||
| 				var pathNode = groupContainerNode.childNodes[1]; | ||||
| 				this.calendarSVGIconChilds = [rectNode, pathNode]; | ||||
| 			} | ||||
| 			index++; | ||||
| 		} | ||||
| 		this.anchor = cs[index]; | ||||
| 		this.textNode = cs[index].firstChild; | ||||
|  | ||||
| 		this.counterNode = cs[index].firstChild.nextSibling; | ||||
| 		this.folderOwnerNode = this.counterNode.nextSibling; | ||||
| 		// Apply some optional CSS classes | ||||
| 		var elNode = Ext.get(this.elNode); | ||||
| 		var iconNode = Ext.get(this.iconNode); | ||||
| 		var containerNode = Ext.get(this.wrap); | ||||
| 		var textNode = Ext.get(this.textNode); | ||||
| 		if (isCalenderNode) { | ||||
| 			textNode.addClass('zarafa-hierarchy-node-color'); | ||||
| 		} | ||||
| 		if (!Ext.isEmpty(config.cls)) { | ||||
| 			elNode.addClass(config.cls); | ||||
| 		} | ||||
|  | ||||
| 		if (config.icon) { | ||||
| 			iconNode.addClass('x-tree-node-inline-icon'); | ||||
| 		} | ||||
|  | ||||
| 		if (config.iconCls) { | ||||
| 			iconNode.addClass(config.iconCls); | ||||
| 		} | ||||
|  | ||||
| 		if (!Ext.isEmpty(config.containerCls)) { | ||||
| 			containerNode.addClass(config.containerCls); | ||||
| 		} | ||||
|  | ||||
| 		this.updateCounter(node); | ||||
| 		this.showFolderOwner(node); | ||||
| 	} | ||||
| }); | ||||
							
								
								
									
										44
									
								
								js/ui/MDMHierarchyTreePanel.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								js/ui/MDMHierarchyTreePanel.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | ||||
| Ext.namespace('Zarafa.plugins.mdm.ui'); | ||||
|  | ||||
| /** | ||||
|  * @class Zarafa.plugins.mdm.ui.MDMHierarchyTreePanel | ||||
|  * @extends Zarafa.hierarchy.ui.Tree | ||||
|  * @xtype mdm.hierarchytree | ||||
|  * | ||||
|  * MDMHierarchyTreePanel for hierachy list in the | ||||
|  * {@link Zarafa.plugins.mdm.dialogs.MDMManageSharedFolderPanel manageSharedFolderPanel}. | ||||
|  */ | ||||
| Zarafa.plugins.mdm.ui.MDMHierarchyTreePanel = Ext.extend(Zarafa.hierarchy.ui.Tree, { | ||||
|  | ||||
| 	/** | ||||
| 	 * @constructor | ||||
| 	 * @param {Object} config Configuration object | ||||
| 	 */ | ||||
| 	constructor : function(config) | ||||
| 	{ | ||||
| 		Zarafa.plugins.mdm.ui.MDMHierarchyTreePanel.superclass.constructor.call(this, config); | ||||
| 	}, | ||||
|  | ||||
| 	/** | ||||
| 	 * Function will initialize {@link Zarafa.hierarchy.ui.Tree Tree} and creates a | ||||
| 	 * {@link Zarafa.common.ui.LoadMask} if {@link Zarafa.hierarchy.ui.Tree Tree} is intantiated as full tree. | ||||
| 	 * @protected | ||||
| 	 */ | ||||
| 	initComponent : function() | ||||
| 	{ | ||||
| 		// Intialize the loader | ||||
| 		if (!this.loader) { | ||||
| 			this.loader = new Zarafa.plugins.mdm.data.MDMHierarchyTreeLoader({ | ||||
| 				tree : this, | ||||
| 				store : this.store, | ||||
| 				nodeConfig : this.nodeConfig, | ||||
| 				deferredLoading : this.deferredLoading | ||||
| 			}); | ||||
| 		} | ||||
|  | ||||
| 		// call parent | ||||
| 		Zarafa.plugins.mdm.ui.MDMHierarchyTreePanel.superclass.initComponent.apply(this, arguments); | ||||
| 	} | ||||
| }); | ||||
|  | ||||
| Ext.reg('mdm.hierarchytree', Zarafa.plugins.mdm.ui.MDMHierarchyTreePanel); | ||||
							
								
								
									
										10
									
								
								manifest.xml
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								manifest.xml
									
									
									
									
									
								
							| @@ -26,18 +26,28 @@ | ||||
| 					<clientfile load="release">js/mdm.js</clientfile> | ||||
| 					<clientfile load="debug">js/mdm-debug.js</clientfile> | ||||
| 					<clientfile load="source">js/MDM.js</clientfile> | ||||
| 					<clientfile load="source">js/data/MDMDeviceFolderStore.js</clientfile> | ||||
| 					<clientfile load="source">js/data/MDMDeviceFolderRecord.js</clientfile> | ||||
| 					<clientfile load="source">js/data/JsonDeviceFolderReader.js</clientfile> | ||||
| 					<clientfile load="source">js/data/MDMResponseHandler.js</clientfile> | ||||
| 					<clientfile load="source">js/data/MDMDeviceRecord.js</clientfile> | ||||
| 					<clientfile load="source">js/data/JsonDeviceReader.js</clientfile> | ||||
| 					<clientfile load="source">js/data/MDMDeviceStore.js</clientfile> | ||||
| 					<clientfile load="source">js/data/ProvisioningStatus.js</clientfile> | ||||
| 					<clientfile load="source">js/data/MDMDeviceProxy.js</clientfile> | ||||
| 					<clientfile load="source">js/data/MDMDeviceResponseHandler.js</clientfile> | ||||
| 					<clientfile load="source">js/data/MDMHierarchyTreeLoader.js</clientfile> | ||||
| 					<clientfile load="source">js/settings/MDMSettingsWidget.js</clientfile> | ||||
| 					<clientfile load="source">js/settings/MDMSettingsCategory.js</clientfile> | ||||
| 					<clientfile load="source">js/dialogs/MDMDeviceContentPanel.js</clientfile> | ||||
| 					<clientfile load="source">js/dialogs/MDMDeviceGeneralTab.js</clientfile> | ||||
| 					<clientfile load="source">js/dialogs/MDMDevicePanel.js</clientfile> | ||||
| 					<clientfile load="source">js/dialogs/MDMDeviceDetailsTab.js</clientfile> | ||||
| 					<clientfile load="source">js/dialogs/MDMManageSharedFolderContentPanel.js</clientfile> | ||||
| 					<clientfile load="source">js/dialogs/MDMManageSharedFolderPanel.js</clientfile> | ||||
| 					<clientfile load="source">js/ui/Renderers.js</clientfile> | ||||
| 					<clientfile load="source">js/ui/MDMFolderNodeUI.js</clientfile> | ||||
| 					<clientfile load="source">js/ui/MDMHierarchyTreePanel.js</clientfile> | ||||
| 				</client> | ||||
| 				<resources> | ||||
| 					<resourcefile load="release">resources/css/mdm.css</resourcefile> | ||||
|   | ||||
| @@ -171,6 +171,20 @@ class PluginMDMModule extends Module | ||||
| 							$this->addActionData('list', $data); | ||||
| 							$GLOBALS['bus']->addData($this->getResponseData()); | ||||
| 							break; | ||||
|  | ||||
| 						case 'open': | ||||
| 							$data = array(); | ||||
| 							$rawData = $this->getDevices(); | ||||
| 							foreach($rawData as $device){ | ||||
| 								if($device->data['deviceid'] === $actionData['entryid']) { | ||||
| 									$data['props'] = $this->getDeviceProps($device->data); | ||||
| 									$data["sharedfolders"] = array("item" => $this->getAdditionalFolderList($actionData['entryid'])); | ||||
| 								} | ||||
| 							} | ||||
| 							$item = array("item" => $data); | ||||
| 							$this->addActionData('item', $item); | ||||
| 							$GLOBALS['bus']->addData($this->getResponseData()); | ||||
| 							break; | ||||
| 						default: | ||||
| 							$this->handleUnknownActionType($actionType); | ||||
| 					} | ||||
| @@ -212,6 +226,7 @@ class PluginMDMModule extends Module | ||||
| 			'lastsynctime', 'lastupdatetime', 'wipestatus', 'policyname', 'koeversion', 'koebuild', 'koebuilddate']; | ||||
|  | ||||
| 		$item['entryid'] = $device['deviceid']; | ||||
| 		$item['message_class'] = "IPM.MDM"; | ||||
| 		foreach ($propsList as $prop) { | ||||
| 			if (isset($device[$prop])) { | ||||
| 				$item[$prop] = $device[$prop]; | ||||
| @@ -262,11 +277,11 @@ class PluginMDMModule extends Module | ||||
| 			$synchronizedFolders += $value; | ||||
| 			$syncFoldersProps[strtolower($key) . 'folder'] = $value; | ||||
| 		} | ||||
|  | ||||
|  | ||||
| 		$syncFoldersProps["totalfolders"] = count($folders); | ||||
| 		$client = $this->getSoapClient(); | ||||
| 		$items = $client->AdditionalFolderList($device['deviceid']); | ||||
| 		$syncFoldersProps['sharedfolders'] = count($items); | ||||
| 		$syncFoldersProps["shortfolderids"] = $device['hasfolderidmapping'] ? dgettext('plugin_mdm', "Yes") : dgettext('plugin_mdm', "No"); | ||||
| 		$syncFoldersProps['synchronizedfolders'] = $synchronizedFolders; | ||||
| 		$syncFoldersProps['synchronizedfolders'] = $synchronizedFolders + count($items); | ||||
|  | ||||
| 		return $syncFoldersProps; | ||||
| 	} | ||||
| @@ -309,5 +324,34 @@ class PluginMDMModule extends Module | ||||
| 		} | ||||
| 		return $folderType; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Function which is use to get list of additional folders which was shared with given device | ||||
| 	 * @param string $devid device id | ||||
| 	 * @return array has list of properties related to shared folders | ||||
| 	 */ | ||||
| 	function getAdditionalFolderList($devid) | ||||
| 	{ | ||||
| 		$stores = $GLOBALS["mapisession"]->getAllMessageStores(); | ||||
| 		$client = $this->getSoapClient(); | ||||
| 		$items = $client->AdditionalFolderList($devid); | ||||
| 		$data = array(); | ||||
| 		foreach ($items as $item) | ||||
| 		{ | ||||
| 			foreach ($stores as $store) | ||||
| 			{ | ||||
| 				try { | ||||
| 					$entryid = mapi_msgstore_entryidfromsourcekey($store, hex2bin($item->folderid)); | ||||
| 				} catch (MAPIException $me) { | ||||
| 					continue; | ||||
| 				} | ||||
| 			} | ||||
| 			if (isset($entryid)) { | ||||
| 				$item->entryid = bin2hex($entryid); | ||||
| 			} | ||||
| 			array_push($data, array("props" => $item)); | ||||
| 		} | ||||
| 		return $data; | ||||
| 	} | ||||
| }; | ||||
| ?> | ||||
|   | ||||
| @@ -2,7 +2,6 @@ | ||||
| 	background-image:url(../icons/mdm_icon.png) !important; | ||||
| } | ||||
|  | ||||
|  | ||||
| .mdm-devicepanel.x-panel.tabpanel-container | ||||
| > .x-panel-bwrap | ||||
| > .x-panel-body { | ||||
| @@ -17,7 +16,6 @@ | ||||
| 	padding: 0!important; | ||||
| } | ||||
|  | ||||
|  | ||||
| .mdm-display-name { | ||||
| 	font-weight: bold !important; | ||||
| 	padding: 4px 0 2px 0; | ||||
| @@ -36,5 +34,17 @@ | ||||
| .mdm-synchronize-panel { | ||||
| 	border: 0px; | ||||
| 	margin-left: 10px; | ||||
| 	padding: 0px; | ||||
| 	padding: 9px 0 0 0; | ||||
| } | ||||
|  | ||||
| .mdm-managesharedfolder-button { | ||||
| 	padding-right: 10px; | ||||
| } | ||||
|  | ||||
| .mdm-create-tree-panel-item { | ||||
| 	margin: 0 0 5px 0; | ||||
| } | ||||
|  | ||||
| .mdm-synchronize-shared-panel { | ||||
| 	padding-top: 9px; | ||||
| } | ||||
		Reference in New Issue
	
	Block a user