mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	Remove UI test data
This commit is contained in:
		
							parent
							
								
									cdbf85e3e6
								
							
						
					
					
						commit
						83bc7d1c81
					
				
							
								
								
									
										1571
									
								
								ui/index-test.html
									
									
									
									
									
								
							
							
						
						
									
										1571
									
								
								ui/index-test.html
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -1536,8 +1536,6 @@ | ||||
|     <script src="scripts/ui/widgets/treeView.js" type="text/javascript"></script> | ||||
|     <script src="scripts/ui/widgets/notifications.js" type="text/javascript"></script> | ||||
| 
 | ||||
|     <script src="scripts-test/test-data.js" type="text/javascript"></script> | ||||
| 
 | ||||
|     <!-- Common libraries --> | ||||
|     <script src="lib/date.js" type="text/javascript"></script> | ||||
|     <script src="lib/jquery.cookies.js" type="text/javascript"></script> | ||||
|  | ||||
| @ -1,69 +0,0 @@ | ||||
| (function(cloudStack) { | ||||
|   cloudStack.sections.accounts = {     | ||||
|     title: 'Accounts', | ||||
|     id: 'accounts', | ||||
|     sectionSelect: { | ||||
|       label: 'Select view' | ||||
|     }, | ||||
|     sections: { | ||||
|       accounts: { | ||||
|         type: 'select', | ||||
|         title: 'Accounts', | ||||
|         listView: { | ||||
|           id: 'accounts', | ||||
|           fields: { | ||||
|             name: { label: 'Name', editable: true }, | ||||
|             domain: { label: 'Domain' }, | ||||
|             state: { label: 'State' } | ||||
|           }, | ||||
|           filters: { | ||||
|             mine: { label: 'My Accounts' }, | ||||
|             all: { label: 'All Accounts' } | ||||
|           }, | ||||
|           dataProvider: testData.dataProvider.listView('accounts'), | ||||
|            | ||||
|           detailView: { | ||||
|             name: 'Account details', | ||||
|             viewAll: { path: 'accounts.users', label: 'Users' }, | ||||
|              | ||||
|             tabs: { | ||||
|               details: { | ||||
|                 title: 'Details', | ||||
|                 fields: [ | ||||
|                   { | ||||
|                     name: { label: 'Name' } | ||||
|                   }, | ||||
|                   { | ||||
|                     domain: { label: 'Domain' }, | ||||
|                     vmlimit: { label: 'VM Limit' }, | ||||
|                     vmtotal: { label: 'Total VMs' }, | ||||
|                     iplimit: { label: 'IP Limit' }, | ||||
|                     iptotal: { label: 'Total IPs' } | ||||
|                   } | ||||
|                 ], | ||||
|                 dataProvider: testData.dataProvider.detailView('accounts') | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         }         | ||||
|       }, | ||||
|       users: { | ||||
|         type: 'select', | ||||
|         title: 'Users', | ||||
|         listView: { | ||||
|           id: 'users', | ||||
|           fields: { | ||||
|             username: { label: 'Username', editable: true }, | ||||
|             email: { label: 'E-mail' }, | ||||
|             state: { label: 'State' } | ||||
|           }, | ||||
|           filters: { | ||||
|             mine: { label: 'My Accounts' }, | ||||
|             all: { label: 'All Accounts' } | ||||
|           }, | ||||
|           dataProvider: testData.dataProvider.listView('users') | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   };   | ||||
| })(cloudStack); | ||||
| @ -1,113 +0,0 @@ | ||||
| (function(cloudStack, $, testData) { | ||||
|   $.extend(cloudStack, testData, { | ||||
|     home: 'dashboard', | ||||
| 
 | ||||
|     sectionPreFilter: function(args) { | ||||
|       var user = args.context.users[0]; | ||||
| 
 | ||||
|       if (user.role == 'admin') | ||||
|         return args.context.sections; | ||||
| 
 | ||||
|       return ['dashboard', 'instances', 'storage', 'templates', 'events', 'projects']; | ||||
|     }, | ||||
|     sections: { | ||||
|       dashboard: {}, | ||||
|       instances: {}, | ||||
|       storage: {}, | ||||
|       network: {}, | ||||
|       templates: {}, | ||||
|       accounts: {}, | ||||
|       domains: {}, | ||||
|       events: {}, | ||||
|       system: {}, | ||||
|       projects: {}, | ||||
|       'global-settings': {}, | ||||
|       configuration: {} | ||||
|     } | ||||
|   }); | ||||
| 
 | ||||
|   $(function() { | ||||
|     var $container = $('#cloudStack3-container'); | ||||
| 
 | ||||
|     var loginArgs = { | ||||
|       $container: $container, | ||||
| 
 | ||||
|       // Use this for checking the session, to bypass login screen
 | ||||
|       bypassLoginCheck: function(args) { | ||||
|         var disabledLogin = document.location.href.split('?')[1] == 'login=disabled'; | ||||
| 
 | ||||
|         if (disabledLogin) | ||||
|           return { | ||||
|             user: { | ||||
|               login: 'wchan', | ||||
|               name: 'Will Chan', | ||||
|               role: 'admin' | ||||
|             } | ||||
|           }; | ||||
|         else | ||||
|           return false; | ||||
|       }, | ||||
| 
 | ||||
|       // Actual login process, via form
 | ||||
|       loginAction: function(args) { | ||||
|         if (args.data.username != 'invalid'){ | ||||
|           return args.response.success({ | ||||
|             data: { | ||||
|               user: { | ||||
|                 username: args.data.username, | ||||
|                 name: args.data.name ? args.data.name : args.data.username, | ||||
|                 role: args.data.username == 'jdoe' ? 'user' : 'admin' | ||||
|               } | ||||
|             } | ||||
|           }); | ||||
|         } | ||||
| 
 | ||||
|         return args.response.error(); | ||||
|       }, | ||||
| 
 | ||||
|       logoutAction: function(args) { | ||||
|         document.location.reload(); | ||||
|       }, | ||||
| 
 | ||||
|       complete: function(args) { | ||||
|         var context = { | ||||
|           users: [args.user] | ||||
|         }; | ||||
|         var cloudStackArgs = $.extend(cloudStack, { | ||||
|           context: context | ||||
|         }); | ||||
| 
 | ||||
|         // Check to invoke install wizard
 | ||||
|         cloudStack.installWizard.check({ | ||||
|           context: context, | ||||
|           response: { | ||||
|             success: function(args) { | ||||
|               if (args.doInstall) { | ||||
|                 cloudStack.uiCustom.installWizard({ | ||||
|                   $container: $container, | ||||
|                   context: context, | ||||
|                   complete: function() { | ||||
|                     $container.cloudStack(cloudStackArgs); | ||||
|                   } | ||||
|                 }); | ||||
|               } else { | ||||
|                 // Show cloudStack main UI
 | ||||
|                 $container.cloudStack(cloudStackArgs); | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         }); | ||||
| 
 | ||||
|         // Logout action
 | ||||
|         $('#user-options a').live('click', function() { | ||||
|           loginArgs.logoutAction({ | ||||
|             context: cloudStack.context | ||||
|           }); | ||||
|         }); | ||||
|       } | ||||
|     }; | ||||
| 
 | ||||
|     // Login
 | ||||
|     cloudStack.uiCustom.login(loginArgs); | ||||
|   }); | ||||
| })(cloudStack, jQuery, testData); | ||||
| @ -1,547 +0,0 @@ | ||||
| (function(cloudStack, testData, $) { | ||||
|   cloudStack.sections.configuration = { | ||||
|     title: 'Configuration', | ||||
|     id: 'configuration', | ||||
|     sectionSelect: { | ||||
|       label: 'Select Offering' | ||||
|     }, | ||||
|     sections: { | ||||
|       serviceOfferings: { | ||||
|         type: 'select', | ||||
|         title: 'Service', | ||||
|         listView: { | ||||
|           label: 'Service Offerings', | ||||
|           fields: { | ||||
|             name: { label: 'Name', editable: true }, | ||||
|             storagetype: { label: 'Storage Type' }, | ||||
|             cpuspeed: { label: 'CPU' }, | ||||
|             memory: { label: 'Memory' }, | ||||
|             domain: { label: 'Domain'} | ||||
|           }, | ||||
|           actions: { | ||||
|             add: { | ||||
|               label: 'Add service offering', | ||||
| 
 | ||||
|               action: function(args) { | ||||
|                 args.response.success(); | ||||
|               }, | ||||
| 
 | ||||
|               messages: { | ||||
|                 confirm: function(args) { | ||||
|                   return 'Are you sure you want to add ' + args.name + '?'; | ||||
|                 }, | ||||
|                 success: function(args) { | ||||
|                   return 'Your new service offering is being created.'; | ||||
|                 }, | ||||
|                 notification: function(args) { | ||||
|                   return 'Created service offering'; | ||||
|                 }, | ||||
|                 complete: function(args) { | ||||
|                   return 'Service offering has been created'; | ||||
|                 } | ||||
|               }, | ||||
| 
 | ||||
|               createForm: { | ||||
|                 title: 'New service offering', | ||||
|                 desc: 'Please fill in the following data to add a new service offering.', | ||||
|                 fields: { | ||||
|                   name: { label: 'Name', editable: true }, | ||||
|                   displayText: { label: 'Display Text' }, | ||||
|                   storageType: { | ||||
|                     label: 'Storage Type', | ||||
|                     select: [ | ||||
|                       { id: 'shared', description: 'Shared' }, | ||||
|                       { id: 'local', description: 'Local' } | ||||
|                     ] | ||||
|                   }, | ||||
|                   cpuCores: { label: '# of CPU cores' }, | ||||
|                   cpuSpeed: { label: 'CPU Speed (in MHz)'}, | ||||
|                   memory: { label: 'Memory (in MB)' }, | ||||
|                   tags: { label: 'Tags' }, | ||||
|                   offerHA: { label: 'Offer HA', isBoolean: true }, | ||||
|                   isPublic: { label: 'Public', isBoolean: true } | ||||
|                 } | ||||
|               }, | ||||
| 
 | ||||
|               notification: { | ||||
|                 poll: testData.notifications.testPoll | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
| 
 | ||||
|           reorder: { | ||||
|             moveTop: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             }, | ||||
|             moveBottom: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             }, | ||||
|             moveUp: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             }, | ||||
|             moveDown: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             }, | ||||
|             moveDrag: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
| 
 | ||||
|           dataProvider: function(args) { | ||||
|             setTimeout(function() { | ||||
|               args.response.success({ | ||||
|                 data: testData.data.serviceOfferings | ||||
|               }); | ||||
|             }); | ||||
|           } | ||||
|         } | ||||
|       }, | ||||
| 
 | ||||
|       systemServiceOfferings: { | ||||
|         type: 'select', | ||||
|         title: 'System Service', | ||||
|         listView: { | ||||
|           label: 'System Service Offerings', | ||||
|           fields: { | ||||
|             name: { label: 'Name', editable: true }, | ||||
|             storagetype: { label: 'Storage Type' }, | ||||
|             cpuspeed: { label: 'CPU' }, | ||||
|             memory: { label: 'Memory' }, | ||||
|             domain: { label: 'Domain'} | ||||
|           }, | ||||
| 
 | ||||
|           reorder: { | ||||
|             moveTop: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             }, | ||||
|             moveBottom: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             }, | ||||
|             moveUp: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             }, | ||||
|             moveDown: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             }, | ||||
|             moveDrag: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
| 
 | ||||
|           actions: { | ||||
|             add: { | ||||
|               label: 'Add system service offering', | ||||
| 
 | ||||
|               action: function(args) { | ||||
|                 args.response.success(); | ||||
|               }, | ||||
| 
 | ||||
|               messages: { | ||||
|                 confirm: function(args) { | ||||
|                   return 'Are you sure you want to add ' + args.name + '?'; | ||||
|                 }, | ||||
|                 success: function(args) { | ||||
|                   return 'Your new system service offering is being created.'; | ||||
|                 }, | ||||
|                 notification: function(args) { | ||||
|                   return 'Created system service offering'; | ||||
|                 }, | ||||
|                 complete: function(args) { | ||||
|                   return 'Sysmte service offering has been created'; | ||||
|                 } | ||||
|               }, | ||||
| 
 | ||||
|               createForm: { | ||||
|                 title: 'New system service offering', | ||||
|                 desc: 'Please fill in the following data to add a new service offering.', | ||||
|                 fields: { | ||||
|                   name: { label: 'Name', editable: true }, | ||||
|                   displayText: { label: 'Display Text' }, | ||||
|                   storageType: { | ||||
|                     label: 'Storage Type', | ||||
|                     select: [ | ||||
|                       { id: 'shared', description: 'Shared' }, | ||||
|                       { id: 'local', description: 'Local' } | ||||
|                     ] | ||||
|                   }, | ||||
|                   cpuCores: { label: '# of CPU cores' }, | ||||
|                   cpuSpeed: { label: 'CPU Speed (in MHz)'}, | ||||
|                   memory: { label: 'Memory (in MB)' }, | ||||
|                   tags: { label: 'Tags' }, | ||||
|                   offerHA: { label: 'Offer HA', isBoolean: true }, | ||||
|                   isPublic: { label: 'Public', isBoolean: true } | ||||
|                 } | ||||
|               }, | ||||
| 
 | ||||
|               notification: { | ||||
|                 poll: testData.notifications.testPoll | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
|           dataProvider: function(args) { | ||||
|             setTimeout(function() { | ||||
|               args.response.success({ | ||||
|                 data: testData.data.systemServiceOfferings | ||||
|               }); | ||||
|             }); | ||||
|           } | ||||
|         } | ||||
|       }, | ||||
| 
 | ||||
|       diskOfferings: { | ||||
|         type: 'select', | ||||
|         title: 'Disk', | ||||
|         listView: { | ||||
|           label: 'Disk Offerings', | ||||
|           fields: { | ||||
|             displaytext: { label: 'Name' }, | ||||
|             disksize: { label: 'Disk Size' }, | ||||
|             domain: { label: 'Domain'} | ||||
|           }, | ||||
|           dataProvider: function(args) { | ||||
|             setTimeout(function() { | ||||
|               args.response.success({ | ||||
|                 data: testData.data.diskOfferings | ||||
|               }); | ||||
|             }); | ||||
|           }, | ||||
| 
 | ||||
|           reorder: { | ||||
|             moveTop: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             }, | ||||
|             moveBottom: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             }, | ||||
|             moveUp: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             }, | ||||
|             moveDown: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             }, | ||||
|             moveDrag: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
| 
 | ||||
|           actions: { | ||||
|             add: { | ||||
|               label: 'Add disk offering', | ||||
| 
 | ||||
|               messages: { | ||||
|                 confirm: function(args) { | ||||
|                   return 'Are you sure you want to add a disk offering?'; | ||||
|                 }, | ||||
|                 success: function(args) { | ||||
|                   return 'Your new disk offering is being created.'; | ||||
|                 }, | ||||
|                 notification: function(args) { | ||||
|                   return 'Creating new disk offering'; | ||||
|                 }, | ||||
|                 complete: function(args) { | ||||
|                   return 'Disk offering has been created successfully!'; | ||||
|                 } | ||||
|               }, | ||||
| 
 | ||||
|               createForm: { | ||||
|                 title: 'Add disk offering', | ||||
|                 fields: { | ||||
|                   name: { | ||||
|                     label: 'Name', | ||||
|                     validation: { required: true } | ||||
|                   }, | ||||
|                   description: { | ||||
|                     label: 'Description', | ||||
|                     validation: { required: true } | ||||
|                   }, | ||||
|                   isCustomized: { | ||||
|                     label: 'Custom disk size', | ||||
|                     isBoolean: true, | ||||
|                     isReverse: true, | ||||
|                     isChecked: true | ||||
|                   }, | ||||
|                   disksize: { | ||||
|                     label: 'Disk size (in GB)', | ||||
|                     dependsOn: 'isCustomized', | ||||
|                     validation: { required: true, number: true }, | ||||
|                     isHidden: true | ||||
|                   }, | ||||
|                   tags: { | ||||
|                     label: 'Storage tags' | ||||
|                   }, | ||||
|                   isDomainSpecific: { | ||||
|                     label: 'Domain specific', | ||||
|                     isBoolean: true | ||||
|                   }, | ||||
|                   domainId: { | ||||
|                     label: 'Domain', | ||||
|                     dependsOn: 'isDomainSpecific', | ||||
|                     select: function(args) { | ||||
|                       setTimeout(function() { | ||||
|                         args.response.success({ | ||||
|                           descriptionField: 'name', | ||||
|                           data: testData.data.domains | ||||
|                         }); | ||||
|                       }); | ||||
|                     }, | ||||
|                     isHidden: true | ||||
|                   } | ||||
|                 } | ||||
|               }, | ||||
| 
 | ||||
|               action: function(args) { | ||||
|                 args.response.success(); | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       }, | ||||
|       networkOfferings: { | ||||
|         type: 'select', | ||||
|         title: 'Network', | ||||
|         listView: { | ||||
|           label: 'Network Offerings', | ||||
|           fields: { | ||||
|             name: { label: 'Name', editable: true }, | ||||
|             networkrate: { label: 'Network Rate' }, | ||||
|             traffictype: { label: 'Traffic Type'} | ||||
|           }, | ||||
| 
 | ||||
|           reorder: { | ||||
|             moveTop: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             }, | ||||
|             moveBottom: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             }, | ||||
|             moveUp: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             }, | ||||
|             moveDown: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             }, | ||||
|             moveDrag: { | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 500); | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
| 
 | ||||
|           actions: { | ||||
|             add: { | ||||
|               label: 'Add network offering', | ||||
| 
 | ||||
|               action: function(args) { | ||||
|                 setTimeout(function() { | ||||
|                   args.response.success(); | ||||
|                 }, 200); | ||||
|               }, | ||||
| 
 | ||||
|               createForm: { | ||||
|                 title: 'Add network offering', | ||||
|                 desc: 'Please specify the network offering', | ||||
|                 fields: { | ||||
|                   name: { label: 'Name', validation: { required: true } }, | ||||
| 
 | ||||
|                   displayText: { label: 'Display Text', validation: { required: true } }, | ||||
| 
 | ||||
|                   maxConnections: { label: 'Max Connections' }, | ||||
| 
 | ||||
|                   networkRate: { label: 'Network Rate' }, | ||||
| 
 | ||||
|                   trafficType: { | ||||
|                     label: 'Traffic Type', validation: { required: true }, | ||||
|                     select: function(args) { | ||||
|                       args.response.success({ | ||||
|                         data: [ | ||||
|                           { id: 'GUEST', description: 'Guest' } | ||||
|                         ] | ||||
|                       }); | ||||
|                     } | ||||
|                   }, | ||||
| 
 | ||||
|                   guestType: { | ||||
|                     label: 'Guest Type', | ||||
|                     select: function(args) { | ||||
|                       args.response.success({ | ||||
|                         data: [ | ||||
|                           { id: 'Isolated', description: 'Isolated' }, | ||||
|                           { id: 'Shared', description: 'Shared' } | ||||
|                         ] | ||||
|                       }); | ||||
|                     } | ||||
|                   }, | ||||
| 
 | ||||
|                   availability: { | ||||
|                     label: 'Availability', | ||||
|                     select: function(args) { | ||||
|                       args.response.success({ | ||||
|                         data: [ | ||||
|                           { id: 'Required', description: 'Required' }, | ||||
|                           { id: 'Optional', description: 'Optional' }, | ||||
|                           { id: 'Unavailable', description: 'Unavailable' } | ||||
|                         ] | ||||
|                       }); | ||||
|                     } | ||||
|                   }, | ||||
| 
 | ||||
|                   serviceOfferingId: { | ||||
|                     label: 'Service Offering', | ||||
|                     select: function(args) { | ||||
|                       args.response.success({ | ||||
|                         data: $.map(testData.data.serviceOfferings, function(elem) { | ||||
|                           return { | ||||
|                             id: elem.id, | ||||
|                             description: elem.name | ||||
|                           }; | ||||
|                         }) | ||||
|                       }); | ||||
|                     } | ||||
|                   }, | ||||
| 
 | ||||
|                   specifyVlan: { label: 'Specify VLAN', isBoolean: true }, | ||||
| 
 | ||||
|                   vlanId: { label: 'VLAN ID', isHidden: true, dependsOn: 'specifyVlan'}, | ||||
| 
 | ||||
|                   supportedServices: { | ||||
|                     label: 'Supported Services', | ||||
| 
 | ||||
|                     dynamic: function(args) { | ||||
|                       setTimeout(function() { | ||||
|                         var fields = {}; | ||||
|                         var services = ['Vpn', 'Dhcp', 'Gateway', 'Firewall', 'Lb', 'UserData', 'SourceNat', 'StaticNat', 'PortForwarding', 'SecurityGroup']; | ||||
| 
 | ||||
|                         $(services).each(function() { | ||||
|                           var id = { | ||||
|                             isEnabled: this + '.' + 'isEnabled', | ||||
|                             capabilities: this + '.' + 'capabilities', | ||||
|                             provider: this + '.' + 'provider' | ||||
|                           }; | ||||
| 
 | ||||
|                           fields[id.isEnabled] = { label: this, isBoolean: true }; | ||||
|                           fields[id.provider] = { | ||||
|                             label: this + ' Provider', | ||||
|                             isHidden: true, | ||||
|                             dependsOn: id.isEnabled, | ||||
|                             select: function(args) { | ||||
|                               args.response.success({ | ||||
|                                 data: [ | ||||
|                                   { id: 'NetScaler', description: 'NetScaler'}, | ||||
|                                   { id: 'SRX', description: 'SRX' } | ||||
|                                 ] | ||||
|                               }); | ||||
|                             } | ||||
|                           }; | ||||
|                         }); | ||||
| 
 | ||||
|                         args.response.success({ | ||||
|                           fields: fields | ||||
|                         }); | ||||
|                       }, 50); | ||||
|                     } | ||||
|                   }, | ||||
| 
 | ||||
|                   tags: { label: 'Tags' } | ||||
|                 } | ||||
|               }, | ||||
| 
 | ||||
|               notification: { | ||||
|                 poll: testData.notifications.testPoll | ||||
|               }, | ||||
|               messages: { | ||||
|                 notification: function(args) { | ||||
|                   return 'Added network offering'; | ||||
|                 } | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
|           dataProvider: function(args) { | ||||
|             setTimeout(function() { | ||||
|               args.response.success({ | ||||
|                 data: testData.data.networkOfferings | ||||
|               }); | ||||
|             }); | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   }; | ||||
| })(cloudStack, testData, jQuery); | ||||
| @ -1,105 +0,0 @@ | ||||
| (function(cloudStack, testData) { | ||||
|   // Admin dashboard
 | ||||
|   cloudStack.sections.dashboard = { | ||||
|     title: 'Dashboard', | ||||
|     show: cloudStack.uiCustom.dashboard, | ||||
| 
 | ||||
|     adminCheck: function(args) { | ||||
|       return args.context.users[0].role == 'admin'; | ||||
|     }, | ||||
| 
 | ||||
|     user: { | ||||
|       dataProvider: function(args) { | ||||
|         args.response.success({ | ||||
|           data: { | ||||
|             runningInstances: 10, | ||||
|             stoppedInstances: 2, | ||||
|             totalInstances: 12, | ||||
|             accountID: '12', | ||||
|             accountName: 'brian', | ||||
|             userName: 'brian', | ||||
|             accountType: 'user', | ||||
|             accountDomainID: 12 | ||||
|           } | ||||
|         }); | ||||
|       } | ||||
|     }, | ||||
| 
 | ||||
|     admin: { | ||||
|       dataProvider: function(args) { | ||||
|         args.response.success({ | ||||
|           data: { | ||||
|             publicIPAllocated: 50, | ||||
|             publicIPTotal: 100, | ||||
|             publicIPPercentage: 50, | ||||
|             privateIPAllocated: 50, | ||||
|             privateIPTotal: 100, | ||||
|             privateIPPercentage: (100 / 50) * 10, | ||||
|             memoryAllocated: 256, | ||||
|             memoryTotal: 1024, | ||||
|             memoryPercentage: (1024 / 256) * 10, | ||||
|             cpuAllocated: 500, | ||||
|             cpuTotal: 1200, | ||||
|             cpuPercentage: (1200 / 500) * 10, | ||||
|             zoneCapacities: [ | ||||
|               { | ||||
|                 type: 'Public IP', | ||||
|                 zoneName: 'zone', | ||||
|                 percent: 50, | ||||
|                 total: 4, | ||||
|                 used: 2 | ||||
|               }, | ||||
|               { | ||||
|                 type: 'Reserved System IP', | ||||
|                 zoneName: 'zone', | ||||
|                 percent: 50, | ||||
|                 total: 10, | ||||
|                 used: 40 | ||||
|               }, | ||||
|               { | ||||
|                 type: 'Storage Used', | ||||
|                 zoneName: 'zone', | ||||
|                 percent: 10, | ||||
|                 total: '50 GB', | ||||
|                 used: '15 GB' | ||||
|               }, | ||||
|               { | ||||
|                 type: 'Secondary Storage', | ||||
|                 zoneName: 'zone', | ||||
|                 percent: 10, | ||||
|                 total: '50 GB', | ||||
|                 used: '15 GB' | ||||
|               }, | ||||
|               { | ||||
|                 type: 'Domain Router', | ||||
|                 zoneName: 'zone', | ||||
|                 percent: 25, | ||||
|                 total: 30, | ||||
|                 used: 100 | ||||
|               }, | ||||
|               { | ||||
|                 type: 'Host', | ||||
|                 zoneName: 'zone', | ||||
|                 percent: 15, | ||||
|                 total: '15.5 gHZ', | ||||
|                 used: '100 gHZ' | ||||
|               } | ||||
|             ], | ||||
|             alerts: $.map(testData.data.alerts, function(alert) { | ||||
|               return { | ||||
|                 name: 'System Alert', | ||||
|                 description: alert.description | ||||
|               }; | ||||
|             }), | ||||
|             hostAlerts: $.map(testData.data.alerts, function(alert) { | ||||
|               return { | ||||
|                 name: 'Host Alert', | ||||
|                 description: alert.description | ||||
|               }; | ||||
|             }) | ||||
|           } | ||||
|         }); | ||||
|       } | ||||
|     } | ||||
|   }; | ||||
| })(cloudStack, testData); | ||||
| @ -1,156 +0,0 @@ | ||||
| (function(cloudStack) { | ||||
|   cloudStack.sections.domains = { | ||||
|     title: 'Domains', | ||||
|     id: 'domains', | ||||
| 
 | ||||
|     // Domain tree
 | ||||
|     treeView: { | ||||
|       // Details
 | ||||
|       detailView: { | ||||
|         name: 'Domain details', | ||||
|         viewAll: { | ||||
|           label: 'Accounts', | ||||
|           path: 'accounts.accounts' | ||||
|         }, | ||||
| 
 | ||||
|         // Detail actions
 | ||||
|         actions: { | ||||
|           // Destroy
 | ||||
|           destroy: { | ||||
|             label: 'Remove domain', | ||||
|             messages: { | ||||
|               confirm: function(args) { | ||||
|                 return 'Are you sure you want to destroy this domain?'; | ||||
|               }, | ||||
|               notification: function(args) { | ||||
|                 return 'Removed domain: ' + args.name; | ||||
|               } | ||||
|             }, | ||||
|             action: function(args) { | ||||
|               setTimeout(function() { | ||||
|                 args.response.success(); | ||||
|               }, 200); | ||||
|             }, | ||||
|             notification: { | ||||
|               poll: testData.notifications.testPoll | ||||
|             } | ||||
|           }, | ||||
|            | ||||
|           // Edit domain
 | ||||
|           edit: { | ||||
|             label: 'Edit domain details', | ||||
|             messages: { | ||||
|               notification: function(args) { | ||||
|                 return 'Edited domain: ' + args.name; | ||||
|               } | ||||
|             }, | ||||
|             action: function(args) { | ||||
|               setTimeout(function() { | ||||
|                 args.response.success(); | ||||
|               }, 200); | ||||
|             } | ||||
|           }, | ||||
| 
 | ||||
|           // Add domain
 | ||||
|           create: { | ||||
|             label: 'Add domain', | ||||
| 
 | ||||
|             action: function(args) { | ||||
|               args.response.success(); | ||||
|             }, | ||||
| 
 | ||||
|             messages: { | ||||
|               notification: function(args) { | ||||
|                 return 'Created domain'; | ||||
|               } | ||||
|             }, | ||||
| 
 | ||||
|             createForm: { | ||||
|               title: 'Add subdomain', | ||||
|               desc: 'Please specify the domain you want to create.', | ||||
|               fields: { | ||||
|                 name: { | ||||
|                   label: 'Name', | ||||
|                   validation: { required: true } | ||||
|                 }, | ||||
|                 parent: { | ||||
|                   label: 'Parent Domain', | ||||
|                   validation: { required: true } | ||||
|                 } | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         tabs: { | ||||
|           details: { | ||||
|             title: 'Details', | ||||
|             fields: [ | ||||
|               { | ||||
|                 name: { label: 'Name', isEditable: true } | ||||
|               }, | ||||
|               { | ||||
|                 accounts: { label: 'Accounts' }, | ||||
|                 instances: { label: 'Instances' }, | ||||
|                 volumes: { label: 'Volumes' } | ||||
|               } | ||||
|             ], | ||||
|             dataProvider: function(args) { | ||||
|               args.response.success({ | ||||
|                 data: { | ||||
|                   name: 'Domain name', | ||||
|                   accounts: 12, | ||||
|                   volumes: 23 | ||||
|                 } | ||||
|               }); | ||||
|             } | ||||
|           }, | ||||
|           adminAccounts: { | ||||
|             title: 'Admin Accounts', | ||||
|             multiple: true, | ||||
|             fields: [ | ||||
|               { | ||||
|                 name: { label: 'Name' }, | ||||
|                 vmtotal: { label: 'VMs' }, | ||||
|                 iptotal: { label: 'IPs' }, | ||||
|                 receivedbytes: { label: 'Bytes received' }, | ||||
|                 sentbytes: { label: 'Bytes sent' }, | ||||
|                 state: { label: 'State' } | ||||
|               } | ||||
|             ], | ||||
|             dataProvider: function(args) { | ||||
|               args.response.success({ | ||||
|                 data: $.grep(testData.data.accounts, function(item, index) { | ||||
|                   return item.domain === 'ROOT' && index <= 5; | ||||
|                 }) | ||||
|               }); | ||||
|             } | ||||
|           }, | ||||
|           resourceLimits: { | ||||
|             title: 'Resource Limits', | ||||
|             fields: { | ||||
|               vmlimit: { label: 'Instance Limit' }, | ||||
|               iplimit: { label: 'Public IP Limit' }, | ||||
|               volumelimit: { label: 'Volume Limit' }, | ||||
|               snapshotlimit: { label: 'Snapshot Limit' }, | ||||
|               templatelimit: { label: 'Template Limit' } | ||||
|             }, | ||||
|             dataProvider: function(args) { | ||||
|               args.response.success({ | ||||
|                 data: testData.data.accounts[4] | ||||
|               }); | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       }, | ||||
|       labelField: 'name', | ||||
|       dataProvider: function(args) { | ||||
|         args.response.success({ | ||||
|           data: [ | ||||
|             { id: 'domainA', name: 'Domain A' }, | ||||
|             { id: 'domainB', name: 'Domain B' } | ||||
|           ] | ||||
|         }); | ||||
|       } | ||||
|     } | ||||
|   }; | ||||
| })(cloudStack); | ||||
| @ -1,64 +0,0 @@ | ||||
| (function(cloudStack) { | ||||
|   cloudStack.sections.events = { | ||||
|     title: 'Events', | ||||
|     id: 'events', | ||||
|     sectionSelect: { | ||||
|       preFilter: function(args) { | ||||
|         var user = args.context.users[0]; | ||||
| 
 | ||||
|         if (user.role == 'admin') | ||||
|           return args.context.sections; | ||||
| 
 | ||||
|         return ['events']; | ||||
|       }, | ||||
|       label: 'Select view' | ||||
|     }, | ||||
|     sections: { | ||||
|       events: { | ||||
|         type: 'select', | ||||
|         title: 'Events', | ||||
|         listView: { | ||||
|           id: 'events', | ||||
|           label: 'Events', | ||||
|           fields: { | ||||
|             type: { label: 'Type' }, | ||||
|             description: { label: 'Description' }, | ||||
|             username: { label: 'Initiated By' }, | ||||
|             created: { label: 'Date' } | ||||
|           }, | ||||
|           dataProvider: testData.dataProvider.listView('events') | ||||
|         } | ||||
|       }, | ||||
|       alerts: { | ||||
|         type: 'select', | ||||
|         title: 'Alerts', | ||||
|         listView: { | ||||
|           id: 'alerts', | ||||
|           label: 'Alerts', | ||||
|           fields: { | ||||
|             type: { label: 'Type' }, | ||||
|             description: { label: 'Description' }, | ||||
|             sent: { label: 'Date' } | ||||
|           }, | ||||
|           dataProvider: testData.dataProvider.listView('alerts'), | ||||
|           detailView: { | ||||
|             name: 'Alert details', | ||||
|             tabs: { | ||||
|               details: { | ||||
|                 title: 'Details', | ||||
|                 fields: [ | ||||
|                   { | ||||
|                     type: { label: 'Type' }, | ||||
|                     description: { label: 'Description' }, | ||||
|                     created: { label: 'Sent' } | ||||
|                   } | ||||
|                 ], | ||||
|                 dataProvider: testData.dataProvider.detailView('alerts') | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   }; | ||||
| })(cloudStack); | ||||
| @ -1,26 +0,0 @@ | ||||
| (function(cloudStack) { | ||||
|   cloudStack.sections['global-settings'] = { | ||||
|     title: 'Global Settings', | ||||
|     id: 'global-settings', | ||||
|     listView: { | ||||
|       label: 'Global Settings', | ||||
|       actions: { | ||||
|         edit: { | ||||
|           label: 'Change value', | ||||
|           action: function(args) { | ||||
|             args.response.success(); | ||||
|           }, | ||||
|           notification: { | ||||
|             poll: testData.notifications.testPoll | ||||
|           } | ||||
|         } | ||||
|       }, | ||||
|       fields: { | ||||
|         name: { label: 'Name', id: true }, | ||||
|         description: { label: 'Description' }, | ||||
|         value: { label: 'Value', editable: true } | ||||
|       }, | ||||
|       dataProvider: testData.dataProvider.listView('globalSettings') | ||||
|     } | ||||
|   }; | ||||
| })(cloudStack); | ||||
| @ -1,287 +0,0 @@ | ||||
| (function($, cloudStack, testData) { | ||||
|   cloudStack.installWizard = { | ||||
|     // Check if install wizard should be invoked
 | ||||
|     check: function(args) { | ||||
|       args.response.success({ | ||||
|         doInstall: args.context.users[0].username == 'newuser' | ||||
|       }); | ||||
|     }, | ||||
| 
 | ||||
|     changeUser: function(args) { | ||||
|       setTimeout(function() { | ||||
|         args.response.success({ | ||||
|           data: { | ||||
|             newUser: { | ||||
|               username: args.data.username | ||||
|             } | ||||
|           } | ||||
|         }); | ||||
|       }, 500); | ||||
|     }, | ||||
| 
 | ||||
|     // Copy text
 | ||||
|     copy: { | ||||
|       // Tooltips
 | ||||
|       'tooltip.addZone.name': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'A name for the zone.' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addZone.dns1': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'These are DNS servers for use by guest VMs in the zone. These DNS servers will be accessed via the public network you will add later. The public IP addresses for the zone must have a route to the DNS server named here.' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addZone.dns2': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'These are DNS servers for use by guest VMs in the zone. These DNS servers will be accessed via the public network you will add later. The public IP addresses for the zone must have a route to the DNS server named here.' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addZone.internaldns1': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'These are DNS servers for use by system VMs in the zone. These DNS servers will be accessed via the private network interface of the System VMs. The private IP address you provide for the pods must have a route to the DNS server named here.' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addZone.internaldns2': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'These are DNS servers for use by system VMs in the zone. These DNS servers will be accessed via the private network interface of the System VMs. The private IP address you provide for the pods must have a route to the DNS server named here.' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addGuestNetwork.name': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'A name for your network' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addGuestNetwork.description': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'A description for your network' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addGuestNetwork.guestGateway': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'The gateway that the guests should use' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addGuestNetwork.guestNetmask': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'The netmask in use on the subnet that the guests should use' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addGuestNetwork.guestStartIp': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'The range of IP addresses that will be available for allocation to guests in this zone.  If one NIC is used, these IPs should be in the same CIDR as the pod CIDR.' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addGuestNetwork.guestEndIp': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'The range of IP addresses that will be available for allocation to guests in this zone.  If one NIC is used, these IPs should be in the same CIDR as the pod CIDR.' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addPod.name': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'A name for the pod' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addPod.gateway': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'The gateway for the hosts in that pod.' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addPod.netmask': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'The netmask in use on the subnet the guests will use.' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addPod.startip': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'This is the IP range in the private network that the CloudStack uses to manage Secondary Storage VMs and Console Proxy VMs. These IP addresses are taken from the same subnet as computing servers.' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addPod.endip': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'This is the IP range in the private network that the CloudStack uses to manage Secondary Storage VMs and Console Proxy VMs. These IP addresses are taken from the same subnet as computing servers.' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addCluster.name': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'A name for the cluster.  This can be text of your choosing and is not used by CloudStack.' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addHost.hostname': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'The DNS name or IP address of the host.' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addHost.username': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'Usually root.' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addHost.password': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'This is the password for the user named above (from your XenServer install).' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addPrimaryStorage.name': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'The name for the storage device.' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addPrimaryStorage.server': function(args) { | ||||
|         args.response.success({ | ||||
|           text: '(for NFS, iSCSI, or PreSetup) The IP address or DNS name of the storage device.' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addPrimaryStorage.path': function(args) { | ||||
|         args.response.success({ | ||||
|           text: '(for NFS) In NFS this is the exported path from the server. Path (for SharedMountPoint).  With KVM this is the path on each host that is where this primary storage is mounted.  For example, "/mnt/primary".' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addSecondaryStorage.nfsServer': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'The IP address of the NFS server hosting the secondary storage' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       'tooltip.addSecondaryStorage.path': function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'The exported path, located on the server you specified above' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       // Intro text
 | ||||
|       whatIsCloudStack: function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'CloudStack™ is a software platform that pools computing resources to build public, private, and hybrid Infrastructure as a Service (IaaS) clouds. CloudStack™ manages the network, storage, and compute nodes that make up a cloud infrastructure. Use CloudStack™ to deploy, manage, and configure cloud computing environments.<br/><br/>Extending beyond individual virtual machine images running on commodity hardware, CloudStack™ provides a turnkey cloud infrastructure software stack for delivering virtual datacenters as a service - delivering all of the essential components to build, deploy, and manage multi-tier and multi-tenant cloud applications. Both open-source and Premium versions are available, with the open-source version offering nearly identical features. ' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       whatIsAZone: function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'A zone is the largest organizational unit within a CloudStack™ deployment. A zone typically corresponds to a single datacenter, although it is permissible to have multiple zones in a datacenter. The benefit of organizing infrastructure into zones is to provide physical isolation and redundancy. For example, each zone can have its own power supply and network uplink, and the zones can be widely separated geographically (though this is not required).' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       whatIsAPod: function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'A pod often represents a single rack. Hosts in the same pod are in the same subnet.<br/><br/>A pod is the second-largest organizational unit within a CloudStack™ deployment. Pods are contained within zones. Each zone can contain one or more pods; in the Basic Installation, you will have just one pod in your zone' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       whatIsACluster: function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'A cluster provides a way to group hosts. The hosts in a cluster all have identical hardware, run the same hypervisor, are on the same subnet, and access the same shared storage. Virtual machine instances (VMs) can be live-migrated from one host to another within the same cluster, without interrupting service to the user. A cluster is the third-largest organizational unit within a CloudStack™ deployment. Clusters are contained within pods, and pods are contained within zones.<br/><br/>CloudStack™ allows multiple clusters in a cloud deployment, but for a Basic Installation, we only need one cluster. ' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       whatIsAHost: function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'A host is a single computer. Hosts provide the computing resources that run the guest virtual machines. Each host has hypervisor software installed on it to manage the guest VMs (except for bare metal hosts, which are a special case discussed in the Advanced Installation Guide). For example, a Linux KVM-enabled server, a Citrix XenServer server, and an ESXi server are hosts. In a Basic Installation, we use a single host running XenServer.<br/><br/>The host is the smallest organizational unit within a CloudStack™ deployment. Hosts are contained within clusters, clusters are contained within pods, and pods are contained within zones. ' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       whatIsPrimaryStorage: function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'A CloudStack™ cloud infrastructure makes use of two types of storage: primary storage and secondary storage. Both of these can be iSCSI or NFS servers, or localdisk.<br/><br/><strong>Primary storage</strong> is associated with a cluster, and it stores the disk volumes of each guest VM for all the VMs running on hosts in that cluster. The primary storage server is typically located close to the hosts. ' | ||||
|         }); | ||||
|       }, | ||||
| 
 | ||||
|       whatIsSecondaryStorage: function(args) { | ||||
|         args.response.success({ | ||||
|           text: 'Secondary storage is associated with a zone, and it stores the following:<ul><li>Templates - OS images that can be used to boot VMs and can include additional configuration information, such as installed applications</li><li>ISO images - OS images that can be bootable or non-bootable</li><li>Disk volume snapshots - saved copies of VM data which can be used for data recovery or to create new templates</ul>' | ||||
|         }); | ||||
|       } | ||||
|     }, | ||||
| 
 | ||||
|     action: function(args) { | ||||
|       var complete = args.response.success; | ||||
|       var error = args.response.error; | ||||
|       var message = args.response.message; | ||||
|       var startFn = args.startFn; | ||||
| 
 | ||||
|       var createZone = function(args) { | ||||
|         message('Creating zone'); | ||||
|         setTimeout(function() { | ||||
|           createPod(); | ||||
|         }, 500); | ||||
|       }; | ||||
| 
 | ||||
|       var createPod = function(args) { | ||||
|         message('Creating pod'); | ||||
|         setTimeout(function() { | ||||
|           createIPRange(); | ||||
|         }, 500); | ||||
|       }; | ||||
| 
 | ||||
|       var createIPRange = function(args) { | ||||
|         message('Creating network'); | ||||
|         setTimeout(function() { | ||||
|           createCluster(); | ||||
|         }, 500); | ||||
|       }; | ||||
| 
 | ||||
|       var createCluster = function(args) { | ||||
|         message('Creating cluster'); | ||||
|         setTimeout(function() { | ||||
|           createHost(); | ||||
|           //error('addCluster', 'Could not create cluster.', createPod);
 | ||||
|         }, 500); | ||||
|       }; | ||||
| 
 | ||||
|       var createHost = function(args) { | ||||
|         message('Creating host'); | ||||
|         setTimeout(function() { | ||||
|           createPrimaryStorage(); | ||||
|         }, 500); | ||||
|       }; | ||||
| 
 | ||||
|       var createPrimaryStorage = function(args) { | ||||
|         message('Creating primary storage'); | ||||
|         setTimeout(function() { | ||||
|           createSecondaryStorage(); | ||||
|         }, 500); | ||||
|       }; | ||||
| 
 | ||||
|       var createSecondaryStorage = function(args) { | ||||
|         message('Creating secondary storage'); | ||||
|         setTimeout(function() { | ||||
|           pollSystemVMs();           | ||||
|         }, 500); | ||||
|       }; | ||||
| 
 | ||||
|       var pollSystemVMs = function() { | ||||
|         message('Creating system VMs (this may take a while)'); | ||||
|         setTimeout(complete, 5000); | ||||
|       }; | ||||
| 
 | ||||
|       if (startFn) { | ||||
|         startFn(); | ||||
|       } else { | ||||
|         createZone();         | ||||
|       } | ||||
|     } | ||||
|   }; | ||||
| }(jQuery, cloudStack, testData)); | ||||
| @ -1,497 +0,0 @@ | ||||
| (function($, cloudStack) { | ||||
|   cloudStack.sections.instances = { | ||||
|     title: 'Instances', | ||||
|     id: 'instances', | ||||
|     listView: { | ||||
|       section: 'instances', | ||||
|       filters: { | ||||
|         mine: { label: 'My instances' }, | ||||
|         all: { label: 'All instances' }, | ||||
|         running: { label: 'Running instances' }, | ||||
|         destroyed: { label: 'Destroyed instances' } | ||||
|       }, | ||||
|       fields: { | ||||
|         name: { label: 'Name', editable: true }, | ||||
|         account: { label: 'Account' }, | ||||
|         zonename: { label: 'Zone' }, | ||||
|         state: { | ||||
|           label: 'Status', | ||||
|           indicator: { | ||||
|             'Running': 'on', | ||||
|             'Stopped': 'off', | ||||
|             'Destroyed': 'off' | ||||
|           } | ||||
|         } | ||||
|       }, | ||||
| 
 | ||||
|       // List view actions
 | ||||
|       actions: { | ||||
|         // Add instance wizard
 | ||||
|         add: { | ||||
|           label: 'Add instance', | ||||
| 
 | ||||
|           action: { | ||||
|             custom: cloudStack.instanceWizard({ | ||||
|               steps: [ | ||||
|                 // Step 1: Setup
 | ||||
|                 function(args) { | ||||
|                   args.response.success({ | ||||
|                     data: { | ||||
|                       zones: testData.data.zones | ||||
|                     } | ||||
|                   }); | ||||
|                 }, | ||||
| 
 | ||||
|                 // Step 2: Select template
 | ||||
|                 function(args) { | ||||
|                   args.response.success({ | ||||
|                     hypervisor: { | ||||
|                       idField: 'id', | ||||
|                       nameField: 'displayname' | ||||
|                     }, | ||||
|                     data: { | ||||
|                       templates: { | ||||
|                         featuredtemplates: $.grep(testData.data.isos, function(elem) { | ||||
|                           return elem.isfeatured === true; | ||||
|                         }), | ||||
|                         communitytemplates: [], | ||||
|                         mytemplates: $.grep(testData.data.isos, function(elem) { | ||||
|                           return elem.isfeatured === true; | ||||
|                         }), | ||||
|                         isos: $.grep(testData.data.isos, function(elem) { | ||||
|                           return elem.isfeatured === false; | ||||
|                         }) | ||||
|                       }, | ||||
|                       hypervisors: [ | ||||
|                         { id: 123, displayname: 'KVM' }, | ||||
|                         { id: 124, displayname: 'Xen' }, | ||||
|                         { id: 125, displayname: 'VMWare' } | ||||
|                       ] | ||||
|                     } | ||||
|                   }); | ||||
|                 }, | ||||
| 
 | ||||
|                 // Step 3: Service offering
 | ||||
|                 function(args) { | ||||
|                   args.response.success({ | ||||
|                     data: { | ||||
|                       serviceOfferings: testData.data.serviceOfferings | ||||
|                     } | ||||
|                   }); | ||||
|                 }, | ||||
| 
 | ||||
|                 // Step 4: Data disk offering
 | ||||
|                 function(args) { | ||||
|                   args.response.success({ | ||||
|                     required: true, | ||||
|                     customFlag: 'iscustomized', // Field determines if custom slider is shown
 | ||||
|                     data: { | ||||
|                       diskOfferings: testData.data.diskOfferings | ||||
|                     } | ||||
|                   }); | ||||
|                 }, | ||||
| 
 | ||||
|                 // Step 5: Network
 | ||||
|                 function(args) { | ||||
|                   args.response.success({ | ||||
|                     type: 'select-network', | ||||
|                     data: { | ||||
|                       myNetworks: $.grep(testData.data.networks, function(elem) { | ||||
|                         return elem.isdefault === true; | ||||
|                       }), | ||||
|                       sharedNetworks: $.grep(testData.data.networks, function(elem) { | ||||
|                         return elem.isdefault === false; | ||||
|                       }), | ||||
|                       securityGroups: testData.data.securityGroups, | ||||
|                       networkOfferings: testData.data.networkOfferings | ||||
|                     } | ||||
|                   }); | ||||
|                 }, | ||||
| 
 | ||||
|                 // Step 6: Review
 | ||||
|                 function(args) { | ||||
|                   args.response.success({}); | ||||
|                 } | ||||
|               ], | ||||
|               action: function(args) { | ||||
|                 args.response.success({ | ||||
|                   _custom: { jobID: 12345 } | ||||
|                 }); | ||||
|               } | ||||
|             }) | ||||
|           }, | ||||
| 
 | ||||
|           messages: { | ||||
|             confirm: function(args) { | ||||
|               return 'Are you sure you want to add ' + args.name + '?'; | ||||
|             }, | ||||
|             notification: function(args) { | ||||
|               return 'Creating new VM: ' + args.name; | ||||
|             } | ||||
|           }, | ||||
|           notification: { | ||||
|             poll: testData.notifications.customPoll( | ||||
|               testData.data.instances[1] | ||||
|             ) | ||||
|           } | ||||
|         }, | ||||
| 
 | ||||
|         edit: { | ||||
|           label: 'Edit instance name', | ||||
|           action: function(args) { | ||||
|             if ((args.data.name) == '') { | ||||
|               args.response.error({ message: 'Instance name cannot be blank.' }); | ||||
|             } else { | ||||
|               args.response.success(); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
| 
 | ||||
|         restart: { | ||||
|           label: 'Restart instance', | ||||
|           action: function(args) { | ||||
|             setTimeout(function() { | ||||
|               args.response.success({ | ||||
|                 data: { | ||||
|                   state: 'Restarting' | ||||
|                 } | ||||
|               }); | ||||
|             }, 1000); | ||||
|           }, | ||||
|           messages: { | ||||
|             confirm: function(args) { | ||||
|               return 'Are you sure you want to restart ' + args.name + '?'; | ||||
|             }, | ||||
|             notification: function(args) { | ||||
|               return 'Rebooting VM: ' + args.name; | ||||
|             } | ||||
|           }, | ||||
|           notification: { | ||||
|             poll: testData.notifications.customPoll({ | ||||
|               state: 'Running' | ||||
|             }) | ||||
|           } | ||||
|         }, | ||||
|         stop: { | ||||
|           label: 'Stop instance', | ||||
|           action: function(args) { | ||||
|             setTimeout(function() { | ||||
|               args.response.success({ | ||||
|                 data: { state: 'Stopping' } | ||||
|               }); | ||||
|             }, 500); | ||||
|           }, | ||||
|           messages: { | ||||
|             confirm: function(args) { | ||||
|               return 'Are you sure you want to shutdown ' + args.name + '?'; | ||||
|             }, | ||||
|             notification: function(args) { | ||||
|               return 'Rebooting VM: ' + args.name; | ||||
|             } | ||||
|           }, | ||||
|           notification: { | ||||
|             poll: testData.notifications.customPoll({ | ||||
|               state: 'Stopped' | ||||
|             }) | ||||
|           } | ||||
|         }, | ||||
|         start: { | ||||
|           label: 'Start instance', | ||||
|           action: function(args) { | ||||
|             setTimeout(function() { | ||||
|               args.response.success({ | ||||
|                 data: { state: 'Starting' } | ||||
|               }); | ||||
|             }, 500); | ||||
|           }, | ||||
|           messages: { | ||||
|             confirm: function(args) { | ||||
|               return 'Are you sure you want to start ' + args.name + '?'; | ||||
|             }, | ||||
|             notification: function(args) { | ||||
|               return 'Starting VM: ' + args.name; | ||||
|             } | ||||
|           }, | ||||
|           notification: { | ||||
|             poll: testData.notifications.customPoll({ | ||||
|               state: 'Running' | ||||
|             }) | ||||
|           } | ||||
|         }, | ||||
|         destroy: { | ||||
|           label: 'Destroy instance', | ||||
|           messages: { | ||||
|             confirm: function(args) { | ||||
|               return 'Are you sure you want to destroy ' + args.name + '?'; | ||||
|             }, | ||||
|             notification: function(args) { | ||||
|               return 'Destroyed VM: ' + args.name; | ||||
|             } | ||||
|           }, | ||||
|           action: function(args) { | ||||
|             setTimeout(function() { | ||||
|               args.response.success({ data: { state: 'Destroying' }}); | ||||
|             }, 200); | ||||
|           }, | ||||
|           notification: { | ||||
|             poll: testData.notifications.customPoll({ | ||||
|               state: 'Destroyed' | ||||
|             }) | ||||
|           } | ||||
|         } | ||||
|       }, | ||||
|       dataProvider: testData.dataProvider.listView('instances'), | ||||
|       detailView: { | ||||
|         name: 'Instance details', | ||||
|         viewAll: { path: 'storage.volumes', label: 'Volumes' }, | ||||
| 
 | ||||
|         // Detail view actions
 | ||||
|         actions: { | ||||
|           edit: { | ||||
|             label: 'Edit VM details', action: function(args) { | ||||
|               setTimeout(function() { | ||||
|                 args.response.success(); | ||||
|               }, 500); | ||||
|             }, | ||||
|             notification: { | ||||
|               poll: testData.notifications.testPoll | ||||
|             } | ||||
|           }, | ||||
|           viewConsole: { | ||||
|             label: 'View VM console', | ||||
|             action: { | ||||
|               externalLink: { | ||||
|                 url: function(args) { | ||||
|                   return 'http://localhost:8080/client/console?cmd=access&vm=' + | ||||
|                     args.context.instances[0].id; | ||||
|                 }, | ||||
|                 title: function(args) { | ||||
|                   return args.context.instances[0].displayname + ' console'; | ||||
|                 }, | ||||
|                 width: 800, | ||||
|                 height: 600 | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
|           stop: { | ||||
|             label: 'Stop VM', | ||||
|             messages: { | ||||
|               confirm: function(args) { | ||||
|                 return 'Are you sure you want to stop ' + args.name + '?'; | ||||
|               }, | ||||
|               notification: function(args) { | ||||
|                 return 'Stopping VM: ' + args.name; | ||||
|               } | ||||
|             }, | ||||
|             notification: { | ||||
|               poll: testData.notifications.customPoll({ | ||||
|                 state: 'Stopped' | ||||
|               }) | ||||
|             }, | ||||
|             action: function(args) { | ||||
|               setTimeout(function() { | ||||
|                 args.response.success({ | ||||
|                   _custom: { jobID: args.data.id } | ||||
|                 }); | ||||
|               }, 1000); | ||||
|             } | ||||
|           }, | ||||
|           start: { | ||||
|             label: 'Start VM', | ||||
|             messages: { | ||||
|               confirm: function(args) { | ||||
|                 return 'Are you sure you want to start ' + args.name + '?'; | ||||
|               }, | ||||
|               notification: function(args) { | ||||
|                 return 'Starting VM: ' + args.name; | ||||
|               } | ||||
|             }, | ||||
|             notification: { | ||||
|               poll: testData.notifications.customPoll({ | ||||
|                 state: 'Running' | ||||
|               }) | ||||
|             }, | ||||
|             action: function(args) { | ||||
|               setTimeout(function() { | ||||
|                 args.response.success({ | ||||
|                   _custom: { jobID: args.data.id } | ||||
|                 }); | ||||
|               }, 1000); | ||||
|             } | ||||
|           }, | ||||
|           restart: { | ||||
|             label: 'Restart VM', | ||||
|             messages: { | ||||
|               confirm: function(args) { | ||||
|                 return 'Are you sure you want to restart ' + args.name + '?'; | ||||
|               }, | ||||
|               notification: function(args) { | ||||
|                 return 'Rebooting VM: ' + args.name; | ||||
|               } | ||||
|             }, | ||||
|             notification: { | ||||
|               poll: testData.notifications.testPoll | ||||
|             }, | ||||
|             action: function(args) { | ||||
|               setTimeout(function() { | ||||
|                 args.response.success({ | ||||
|                   _custom: { jobID: args.data.id } | ||||
|                 }); | ||||
|               }, 1000); | ||||
|             } | ||||
|           }, | ||||
|           destroy: { | ||||
|             label: 'Destroy VM', | ||||
|             messages: { | ||||
|               confirm: function(args) { | ||||
|                 return 'Are you sure you want to destroy ' + args.name + '?'; | ||||
|               }, | ||||
|               notification: function(args) { | ||||
|                 return 'Destroying VM: ' + args.name; | ||||
|               } | ||||
|             }, | ||||
|             notification: { | ||||
|               poll: testData.notifications.customPoll({ | ||||
|                 state: 'Destroyed' | ||||
|               }) | ||||
|             }, | ||||
|             action: function(args) { | ||||
|               setTimeout(function() { | ||||
|                 args.response.success(); | ||||
|               }, 1000); | ||||
|             } | ||||
|           }, | ||||
|           migrate: { | ||||
|             notification: { | ||||
|               desc: 'Migrated VM', | ||||
|               poll: testData.notifications.testPoll | ||||
|             }, | ||||
|             label: 'Migrate VM', action: function(args) { | ||||
|               args.response.success(); | ||||
|             } | ||||
|           }, | ||||
|           attachISO: { | ||||
|             label: 'Attach ISO', action: function(args) { | ||||
|               args.response.success(); | ||||
|             } | ||||
|           }, | ||||
|           resetPassword: { | ||||
|             label: 'Reset password', | ||||
|             preAction: function(args) { | ||||
|               cloudStack.dialog.notice({ | ||||
|                 message: 'You cannot reset your password.' | ||||
|               }); | ||||
| 
 | ||||
|               return false; | ||||
|             }, | ||||
|             action: function(args) { | ||||
|               args.response.success({}); | ||||
|             }, | ||||
|             messages: { | ||||
|               confirm: function(args) { | ||||
|                 return 'Do you really want to reset your password?'; | ||||
|               }, | ||||
|               notification: function(args) { | ||||
|                 return 'Resetting VM password'; | ||||
|               }, | ||||
|               complete: function(args) { | ||||
|                 return 'VM password reset. New password is: ' + args.password; | ||||
|               } | ||||
|             }, | ||||
|             notification: { | ||||
|               poll: testData.notifications.customPoll({ | ||||
|                 password: '1284018jaj#' | ||||
|               }) | ||||
|             } | ||||
|           }, | ||||
|           changeService: { | ||||
|             label: 'Change Service', action: function(args) { | ||||
|               args.response.success(); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         tabs: { | ||||
|           // Details tab
 | ||||
|           details: { | ||||
|             title: 'Details', | ||||
|             fields: [ | ||||
|               { | ||||
|                 name: { | ||||
|                   label: 'Name', isEditable: true | ||||
|                 } | ||||
|               }, | ||||
|               { | ||||
|                 id: { label: 'ID', isEditable: false }, | ||||
|                 zonename: { label: 'Zone', isEditable: false }, | ||||
|                 templateid: { | ||||
|                   label: 'Template type', | ||||
|                   isEditable: true, | ||||
|                   select: function(args) { | ||||
|                     var items = []; | ||||
| 
 | ||||
|                     $(testData.data.templates).each(function() { | ||||
|                       items.push({ id: this.id, description: this.name }); | ||||
|                     }); | ||||
|                     setTimeout(function() { | ||||
|                       args.response.success({ data: items }); | ||||
|                     }, 500); | ||||
|                   } | ||||
|                 }, | ||||
|                 serviceofferingname: { label: 'Service offering', isEditable: false }, | ||||
|                 group: { label: 'Group', isEditable: true } | ||||
|               } | ||||
|             ], | ||||
|             dataProvider: testData.dataProvider.detailView('instances') | ||||
|           }, | ||||
| 
 | ||||
|           /** | ||||
|            * NICs tab | ||||
|            */ | ||||
|           nics: { | ||||
|             title: 'NICs', | ||||
|             isMultiple: true, | ||||
|             preFilter: function(args) { | ||||
|               return ['type']; | ||||
|             }, | ||||
|             fields: [ | ||||
|               { | ||||
|                 name: { label: 'Name', header: true }, | ||||
|                 ipaddress: { label: 'IP Address' }, | ||||
|                 gateway: { label: 'Default gateway' }, | ||||
|                 netmask: { label: 'Netmask' }, | ||||
|                 type: { label: 'Type' } | ||||
|               } | ||||
|             ], | ||||
|             dataProvider: function(args) { | ||||
|               setTimeout(function() { | ||||
|                 var instance = $.grep(testData.data.instances, function(elem) { | ||||
|                   return elem.id == args.id; | ||||
|                 }); | ||||
|                 args.response.success({ | ||||
|                   data: $.map(instance[0].nic, function(item, index) { | ||||
|                     item.name = 'NIC ' + (index + 1); | ||||
|                     return item; | ||||
|                   }) | ||||
|                 }); | ||||
|               }, 500); | ||||
|             } | ||||
|           }, | ||||
| 
 | ||||
|           /** | ||||
|            * Statistics tab | ||||
|            */ | ||||
|           stats: { | ||||
|             title: 'Statistics', | ||||
|             fields: { | ||||
|               cpuspeed: { label: 'Total CPU' }, | ||||
|               cpuused: { label: 'CPU Utilized' }, | ||||
|               networkkbsread: { label: 'Network Read' }, | ||||
|               networkkbswrite: { label: 'Network Write' } | ||||
|             }, | ||||
|             dataProvider: testData.dataProvider.detailView('instances') | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   }; | ||||
| })(jQuery, cloudStack); | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -1,332 +0,0 @@ | ||||
| (function($, cloudStack, testData) { | ||||
|   cloudStack.projects = { | ||||
|     requireInvitation: function(args) { | ||||
|       return cloudStack.context.users[0].username == 'jdoe'; | ||||
|     }, | ||||
| 
 | ||||
|     dashboard: function(args) { | ||||
|       var dataFns = { | ||||
|         instances: function(data) { | ||||
|           dataFns.storage($.extend(data, { | ||||
|             runningInstances: 40, | ||||
|             stoppedInstances: 10, | ||||
|             totalInstances: 50 | ||||
|           })); | ||||
|         }, | ||||
| 
 | ||||
|         storage: function(data) { | ||||
|           dataFns.bandwidth($.extend(data, { | ||||
|             totalVolumes: 70 | ||||
|           })); | ||||
|         }, | ||||
| 
 | ||||
|         bandwidth: function(data) { | ||||
|           dataFns.ipAddresses($.extend(data, { | ||||
|             totalBandwidth: 1500 | ||||
|           })); | ||||
|         }, | ||||
| 
 | ||||
|         ipAddresses: function(data) { | ||||
|           dataFns.loadBalancingRules($.extend(data, { | ||||
|             totalIPAddresses: 20 | ||||
|           })); | ||||
|         }, | ||||
| 
 | ||||
|         loadBalancingRules: function(data) { | ||||
|           dataFns.portForwardingRules($.extend(data, { | ||||
|             totalLoadBalancers: 12 | ||||
|           })); | ||||
|         }, | ||||
| 
 | ||||
|         portForwardingRules: function(data) { | ||||
|           dataFns.users($.extend(data, { | ||||
|             totalPortForwards: 30 | ||||
|           })); | ||||
|         }, | ||||
| 
 | ||||
|         users: function(data) { | ||||
|           dataFns.events($.extend(data, { | ||||
|             users: $.map(testData.data.users, function(user) { | ||||
|               return { | ||||
|                 account: user.account | ||||
|               }; | ||||
|             }) | ||||
|           })); | ||||
|         }, | ||||
| 
 | ||||
|         events: function(data) { | ||||
|           complete($.extend(data, { | ||||
|             events: $.map(testData.data.events, function(event) { | ||||
|               return { | ||||
|                 date: event.created.substr(5, 2) + | ||||
|                   '/' + event.created.substr(8, 2) + | ||||
|                   '/' + event.created.substr(2, 2), | ||||
|                 desc: event.description | ||||
|               }; | ||||
|             }) | ||||
|           })); | ||||
|         } | ||||
|       }; | ||||
| 
 | ||||
|       var complete = function(data) { | ||||
|         args.response.success({ | ||||
|           data: data | ||||
|         }); | ||||
|       }; | ||||
| 
 | ||||
|       dataFns.instances({}); | ||||
|     }, | ||||
| 
 | ||||
|     resourceManagement: { | ||||
|       update: function(args) { | ||||
|         args.response.success(); | ||||
|       }, | ||||
| 
 | ||||
|       dataProvider: function(args) { | ||||
|         args.response.success({ | ||||
|           data: $.map( | ||||
|             testData.data.projectResourceLimits, | ||||
|             function(resource) { | ||||
|               var resourceMap = { | ||||
|                 0: { | ||||
|                   id: 'user_vm', | ||||
|                   label: 'Max. User VMs' | ||||
|                 }, | ||||
|                 1: { | ||||
|                   id: 'public_ip', | ||||
|                   label: 'Max. Public IPs' | ||||
|                 }, | ||||
|                 2: { | ||||
|                   id: 'volume', | ||||
|                   label: 'Max. Volumes' | ||||
|                 }, | ||||
|                 3: { | ||||
|                   id: 'snapshot', | ||||
|                   label: 'Max. Snapshots' | ||||
|                 }, | ||||
|                 4: { | ||||
|                   id: 'template', | ||||
|                   label: 'Max. Templates' | ||||
|                 }, | ||||
|                 5: { | ||||
|                   id: 'project', | ||||
|                   label: 'Max. Projects' | ||||
|                 } | ||||
|               }; | ||||
|               return { | ||||
|                 id: resourceMap[resource.resourcetype].id, | ||||
|                 label: resourceMap[resource.resourcetype].label, | ||||
|                 type: resource.resourcetype, | ||||
|                 value: resource.max | ||||
|               }; | ||||
|             } | ||||
|           ) | ||||
|         }); | ||||
| 
 | ||||
|       } | ||||
|     }, | ||||
|      | ||||
|     add: function(args) { | ||||
|       setTimeout(function() { | ||||
|         args.response.success({ | ||||
|           data: { | ||||
|             name: args.data['project-name'], | ||||
|             displayText: args.data['project-display-text'], | ||||
|             users: [] | ||||
|           } | ||||
|         }); | ||||
|       }, 1000); | ||||
|     }, | ||||
|     inviteForm: { | ||||
|       noSelect: true, | ||||
|       fields: { | ||||
|         'email': { edit: true, label: 'E-mail' }, | ||||
|         'add-user': { addButton: true, label: '' } | ||||
|       }, | ||||
|       add: { | ||||
|         label: 'Invite', | ||||
|         action: function(args) { | ||||
|           setTimeout(function() { | ||||
|             args.response.success({ | ||||
|               data: args.data, | ||||
|               notification: { | ||||
|                 label: 'Invited user to project', | ||||
|                 poll: testData.notifications.testPoll | ||||
|               } | ||||
|             }); | ||||
|           }, 100); | ||||
|         } | ||||
|       }, | ||||
|       actionPreFilter: function(args) { | ||||
|         if (cloudStack.context.projects && | ||||
|             cloudStack.context.projects[0] && | ||||
|             !cloudStack.context.projects[0].isNew) { | ||||
|           return args.context.actions; | ||||
|         } | ||||
| 
 | ||||
|         return ['destroy']; | ||||
|       }, | ||||
| 
 | ||||
|       actions: {}, | ||||
| 
 | ||||
|       // Project users data provider
 | ||||
|       dataProvider: function(args) { | ||||
|         var data = cloudStack.context.projects ? | ||||
|               [ | ||||
|                 { email: 'brian.federle@citrix.com' }, | ||||
|                 { email: 'john.doe@aol.com' }, | ||||
|                 { email: 'some.user@gmail.com' } | ||||
|               ] : []; | ||||
| 
 | ||||
|         setTimeout(function() { | ||||
|           args.response.success({ | ||||
|             data: data | ||||
|           }); | ||||
|         }, 100); | ||||
|       } | ||||
|     }, | ||||
|     addUserForm: { | ||||
|       noSelect: true, | ||||
|       fields: { | ||||
|         'username': { edit: true, label: 'Account' }, | ||||
|         'add-user': { addButton: true, label: '' } | ||||
|       }, | ||||
|       add: { | ||||
|         label: 'Add user', | ||||
|         action: function(args) { | ||||
|           setTimeout(function() { | ||||
|             args.response.success({ | ||||
|               data: args.data, | ||||
|               notification: { | ||||
|                 label: 'Added user to project', | ||||
|                 poll: testData.notifications.testPoll | ||||
|               } | ||||
|             }); | ||||
|           }, 100); | ||||
|         } | ||||
|       }, | ||||
|       actionPreFilter: function(args) { | ||||
|         if (cloudStack.context.projects && | ||||
|             cloudStack.context.projects[0] && | ||||
|             !cloudStack.context.projects[0].isNew) { | ||||
|           return args.context.actions; | ||||
|         } | ||||
| 
 | ||||
|         return ['destroy']; | ||||
|       }, | ||||
|       actions: { | ||||
|         destroy: { | ||||
|           label: 'Remove user from project', | ||||
|           action: function(args) { | ||||
|             setTimeout(function() { | ||||
|               args.response.success({ | ||||
|                 notification: { | ||||
|                   label: 'Removed user from project', | ||||
|                   poll: testData.notifications.testPoll | ||||
|                 } | ||||
|               }); | ||||
|             }, 500); | ||||
|           } | ||||
|         }, | ||||
| 
 | ||||
|         makeOwner: { | ||||
|           label: 'Make user project owner', | ||||
|           action: function(args) { | ||||
|             setTimeout(function() { | ||||
|               args.response.success({ | ||||
|                 notification: { | ||||
|                   label: 'Assigned new owner to project', | ||||
|                   poll: testData.notifications.testPoll | ||||
|                 } | ||||
|               }); | ||||
|             }); | ||||
|           } | ||||
|         } | ||||
|       }, | ||||
| 
 | ||||
|       // Project users data provider
 | ||||
|       dataProvider: function(args) { | ||||
|         var data = cloudStack.context.projects ? | ||||
|               cloudStack.context.projects[0].users : []; | ||||
| 
 | ||||
|         setTimeout(function() { | ||||
|           args.response.success({ | ||||
|             data: data | ||||
|           }); | ||||
|         }, 100); | ||||
|       } | ||||
|     }, | ||||
| 
 | ||||
|     // Project listing data provider
 | ||||
|     dataProvider: function(args) { | ||||
|       var user = args.context.users[0]; | ||||
|       setTimeout(function() { | ||||
|         args.response.success({ | ||||
|           data: user.username == 'bfederle' ? [] : testData.data.projects | ||||
|         }); | ||||
|       }, 200); | ||||
|     } | ||||
|   }; | ||||
| 
 | ||||
|   /** | ||||
|    * Projects section -- list view | ||||
|    */ | ||||
|   cloudStack.sections.projects = { | ||||
|     title: 'Projects', | ||||
|     id: 'projects', | ||||
|     listView: { | ||||
|       fields: { | ||||
|         name: { label: 'Project Name' }, | ||||
|         displayText: { label: 'Display Text' }, | ||||
|         domain: { label: 'Domain' }, | ||||
|         account: { label: 'Owner' } | ||||
|       }, | ||||
| 
 | ||||
|       dataProvider: testData.dataProvider.listView('projects'), | ||||
| 
 | ||||
|       actions: { | ||||
|         add: { | ||||
|           label: 'New Project', | ||||
|           action: { | ||||
|             custom: function(args) { | ||||
|               $(window).trigger('cloudStack.newProject'); | ||||
|             } | ||||
|           }, | ||||
| 
 | ||||
|           messages: { | ||||
|             confirm: function(args) { | ||||
|               return 'Are you sure you want to remove ' + args.name + '?'; | ||||
|             }, | ||||
|             notification: function(args) { | ||||
|               return 'Removed project'; | ||||
|             } | ||||
|           }, | ||||
| 
 | ||||
|           notification: { | ||||
|             poll: testData.notifications.testPoll | ||||
|           } | ||||
|         }, | ||||
| 
 | ||||
|         destroy: { | ||||
|           label: 'Remove project', | ||||
|           action: function(args) { | ||||
|             args.response.success({}); | ||||
|           }, | ||||
| 
 | ||||
|           messages: { | ||||
|             confirm: function(args) { | ||||
|               return 'Are you sure you want to remove ' + args.name + '?'; | ||||
|             }, | ||||
|             notification: function(args) { | ||||
|               return 'Removed project'; | ||||
|             } | ||||
|           }, | ||||
| 
 | ||||
|           notification: { | ||||
|             poll: testData.notifications.testPoll | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   }; | ||||
| } (jQuery, cloudStack, testData)); | ||||
| @ -1,538 +0,0 @@ | ||||
| (function(cloudStack, $, testData) { | ||||
|   cloudStack.sections.storage = { | ||||
|     title: 'Storage', | ||||
|     id: 'storage', | ||||
|     sectionSelect: { | ||||
|       label: 'Select view' | ||||
|     }, | ||||
|     sections: { | ||||
|       /** | ||||
|        * Volumes | ||||
|        */ | ||||
|       volumes: { | ||||
|         type: 'select', | ||||
|         title: 'Volumes', | ||||
|         listView: { | ||||
|           id: 'volumes', | ||||
|           label: 'Volumes', | ||||
|           fields: { | ||||
|             name: { label: 'Name', editable: true }, | ||||
|             type: { label: 'Type' }, | ||||
|             zonename: { label: 'Zone' }, | ||||
|             size: { label: 'Size' }, | ||||
|             state: { | ||||
|               label: 'Status', | ||||
|               indicator: { | ||||
|                 'Ready': 'on' | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
| 
 | ||||
|           filters: { | ||||
|             mine: { label: 'My volumes' }, | ||||
|             large: { label: 'Large volumes' }, | ||||
|             small: { label: 'Small volumes' } | ||||
|           }, | ||||
| 
 | ||||
|           // List view actions
 | ||||
|           actions: { | ||||
|             // Add volume
 | ||||
|             add: { | ||||
|               label: 'Add volume', | ||||
| 
 | ||||
|               action: function(args) { | ||||
|                 args.response.success({ | ||||
|                   _custom: { jobID: new Date() } | ||||
|                 }); | ||||
|               }, | ||||
| 
 | ||||
|               messages: { | ||||
|                 confirm: function(args) { | ||||
|                   return 'Are you sure you want to add ' + args.name + '?'; | ||||
|                 }, | ||||
|                 notification: function(args) { | ||||
|                   return 'Creating new volume'; | ||||
|                 } | ||||
|               }, | ||||
| 
 | ||||
|               createForm: { | ||||
|                 title: 'Add volume', | ||||
|                 desc: 'Please fill in the following data to add a new volume.', | ||||
|                 fields: { | ||||
|                   name: { | ||||
|                     label: 'Name', | ||||
|                     validation: { required: true } | ||||
|                   }, | ||||
|                   availabilityZone: { | ||||
|                     label: 'Availability Zone', | ||||
|                     select: function(args) { | ||||
|                       args.response.success({ | ||||
|                         descriptionField: 'displayname', | ||||
|                         data: [ | ||||
|                           { id: 'sanjose', displayname: 'San Jose' }, | ||||
|                           { id: 'Chicago', displayname: 'Chicago' } | ||||
|                         ] | ||||
|                       }); | ||||
|                     } | ||||
|                   }, | ||||
|                   diskOffering: { | ||||
|                     label: 'Disk Offering', | ||||
|                     dependsOn: 'availabilityZone', | ||||
|                     select: function(args) { | ||||
|                       /** | ||||
|                        * Example to show/hide fields | ||||
|                        * | ||||
|                        * -Select Pod2 to show conditional fields | ||||
|                        * -Select any other field to hide conditional fields | ||||
|                        */ | ||||
|                       args.$select.change(function() { | ||||
|                         var $input = $(this); | ||||
|                         var $form = $input.closest('form'); | ||||
| 
 | ||||
|                         // Note: need to actually select the .form-item div containing the input
 | ||||
|                         var $diskSize = $form.find('.form-item[rel=diskSize]'); | ||||
| 
 | ||||
|                         $diskSize.hide(); | ||||
| 
 | ||||
|                         if ($input.val() == 'custom') { | ||||
|                           // Note: need to show by setting display=inline-block, not .show()
 | ||||
|                           $diskSize.css('display', 'inline-block'); | ||||
|                         } | ||||
|                       }); | ||||
| 
 | ||||
|                       args.response.success({ | ||||
|                         descriptionField: 'description', | ||||
|                         data: [ | ||||
|                           { id: 'small', description: 'Small Disk, 5GB' }, | ||||
|                           { id: 'medium', description: 'Medium Disk, 20GB' }, | ||||
|                           { id: 'large', description: 'Large Disk, 100GB' }, | ||||
|                           { id: 'custom', description: 'Custom Disk Size' } | ||||
|                         ] | ||||
|                       }); | ||||
|                     } | ||||
|                   }, | ||||
|                   diskSize: { | ||||
|                     label: 'Disk size (in GB)', | ||||
|                     validation: { required: true, number: true }, | ||||
|                     hidden: true | ||||
|                   } | ||||
|                 } | ||||
|               }, | ||||
| 
 | ||||
|               notification: { | ||||
|                 poll: testData.notifications.customPoll( | ||||
|                   testData.data.storage[0] | ||||
|                 ) | ||||
|               } | ||||
|             }, | ||||
|             edit: { | ||||
|               label: 'Edit volume name', | ||||
|               action: function(args) { | ||||
|                 args.response.success(args.data[0]); | ||||
|               } | ||||
|             }, | ||||
|             snapshot: { | ||||
|               label: 'Take snapshot', | ||||
|               messages: { | ||||
|                 confirm: function(args) { | ||||
|                   return 'Please confirm that you want to take a snapshot of ' + args.name; | ||||
|                 }, | ||||
|                 notification: function(args) { | ||||
|                   return 'Made snapshot of volume: ' + args.name; | ||||
|                 } | ||||
|               }, | ||||
|               action: function(args) { | ||||
|                 args.response.success({ | ||||
|                   data: { state: 'Shapshotting' } | ||||
|                 }); | ||||
|               }, | ||||
|               notification: { | ||||
|                 poll: testData.notifications.customPoll({ | ||||
|                   state: 'Ready' | ||||
|                 }) | ||||
|               } | ||||
|             }, | ||||
|             recurringSnapshot: { | ||||
|               label: 'Setup recurring snapshots', | ||||
|               action: { | ||||
|                 custom: cloudStack.uiCustom.recurringSnapshots({ | ||||
|                   desc: 'You can setup recurring snapshot schedules by selecting from the available options below and applying your policy preference.', | ||||
|                   dataProvider: function(args) { | ||||
|                     setTimeout(function() { | ||||
|                       args.response.success({ | ||||
|                         data: [ | ||||
|                           { | ||||
|                             type: 0, | ||||
|                             time: 10, | ||||
|                             timezone: 'Pacific/Samoa', | ||||
|                             keep: 23 | ||||
|                           }, | ||||
|                           { | ||||
|                             type: 3, | ||||
|                             time: '12:33 AM', | ||||
|                             timezone: 'Pacific/Samoa', | ||||
|                             keep: 23, | ||||
|                             'day-of-month': 31 | ||||
|                           } | ||||
|                         ] | ||||
|                       });                       | ||||
|                     }, 100); | ||||
|                   }, | ||||
|                   actions: { | ||||
|                     add: function(args) { | ||||
|                       var snap = args.snapshot; | ||||
|                        | ||||
|                       var data = { | ||||
|                         keep: snap.maxsnaps, | ||||
|                         timezone: snap.timezone | ||||
|                       }; | ||||
| 
 | ||||
|                       switch (snap['snapshot-type']) { | ||||
|                         case 'hourly': // Hourly
 | ||||
|                         $.extend(data, { | ||||
|                           type: 0, | ||||
|                           time: snap.schedule | ||||
|                         }); break; | ||||
| 
 | ||||
|                         case 'daily': // Daily
 | ||||
|                         $.extend(data, { | ||||
|                           type: 1, | ||||
|                           time: snap['time-hour'] + ':' + snap['time-minute'] + ' ' + snap['time-meridiem'] | ||||
|                         }); break; | ||||
| 
 | ||||
|                         case 'weekly': // Weekly
 | ||||
|                         $.extend(data, { | ||||
|                           type: 2, | ||||
|                           time: snap['time-hour'] + ':' + snap['time-minute'] + ' ' + snap['time-meridiem'], | ||||
|                           'day-of-week': snap['day-of-week'] | ||||
|                         }); break; | ||||
| 
 | ||||
|                         case 'monthly': // Monthly
 | ||||
|                         $.extend(data, { | ||||
|                           type: 3, | ||||
|                           time: snap['time-hour'] + ':' + snap['time-minute'] + ' ' + snap['time-meridiem'], | ||||
|                           'day-of-month': snap['day-of-month']                           | ||||
|                         }); break; | ||||
|                       } | ||||
| 
 | ||||
|                       setTimeout(function() { | ||||
|                         args.response.success({ | ||||
|                           data: data | ||||
|                         }); | ||||
|                       }, 300); | ||||
|                     }, | ||||
|                     remove: function(args) { | ||||
|                       args.response.success(); | ||||
|                     } | ||||
|                   }, | ||||
| 
 | ||||
|                   // Select data
 | ||||
|                   selects: { | ||||
|                     schedule: function(args) { | ||||
|                       var time = []; | ||||
| 
 | ||||
|                       for (var i = 1; i <= 59; i++) { | ||||
|                         time.push({ | ||||
|                           id: i, | ||||
|                           name: i | ||||
|                         }); | ||||
|                       } | ||||
| 
 | ||||
|                       args.response.success({ | ||||
|                         data: time | ||||
|                       }); | ||||
|                     }, | ||||
|                     timezone: function(args) { | ||||
|                       args.response.success({ | ||||
|                         data: [ | ||||
|                           { | ||||
|                             id: 'Etc/GMT+12', | ||||
|                             name: '[UTC-12:00] GMT-12:00' | ||||
|                           }, | ||||
|                           { | ||||
|                             id: 'Pacific/Samoa', | ||||
|                             name: '[UTC-11:00] Samoa Standard Time' | ||||
|                           } | ||||
|                         ] | ||||
|                       }); | ||||
|                     }, | ||||
|                     'day-of-week': function(args) { | ||||
|                       args.response.success({ | ||||
|                         data: [ | ||||
|                           { id: 1, name: 'Sunday' }, | ||||
|                           { id: 2, name: 'Monday' }, | ||||
|                           { id: 3, name: 'Tuesday' }, | ||||
|                           { id: 4, name: 'Wednesday' }, | ||||
|                           { id: 5, name: 'Thursday' }, | ||||
|                           { id: 6, name: 'Friday' }, | ||||
|                           { id: 7, name: 'Saturday' } | ||||
|                         ] | ||||
|                       }); | ||||
|                     }, | ||||
| 
 | ||||
|                     'day-of-month': function(args) { | ||||
|                       var time = []; | ||||
| 
 | ||||
|                       for (var i = 1; i <= 31; i++) { | ||||
|                         time.push({ | ||||
|                           id: i, | ||||
|                           name: i | ||||
|                         }); | ||||
|                       } | ||||
| 
 | ||||
|                       args.response.success({ | ||||
|                         data: time | ||||
|                       }); | ||||
|                     }, | ||||
| 
 | ||||
|                     'time-hour': function(args) { | ||||
|                       var time = []; | ||||
| 
 | ||||
|                       for (var i = 1; i <= 12; i++) { | ||||
|                         time.push({ | ||||
|                           id: i, | ||||
|                           name: i | ||||
|                         }); | ||||
|                       } | ||||
| 
 | ||||
|                       args.response.success({ | ||||
|                         data: time | ||||
|                       }); | ||||
|                     }, | ||||
| 
 | ||||
|                     'time-minute': function(args) { | ||||
|                       var time = []; | ||||
| 
 | ||||
|                       for (var i = 0; i <= 59; i++) { | ||||
|                         time.push({ | ||||
|                           id: i < 10 ? '0' + i : i, | ||||
|                           name: i < 10 ? '0' + i : i | ||||
|                         }); | ||||
|                       } | ||||
| 
 | ||||
|                       args.response.success({ | ||||
|                         data: time | ||||
|                       }); | ||||
|                     }, | ||||
| 
 | ||||
|                     'time-meridiem': function(args) { | ||||
|                       args.response.success({ | ||||
|                         data: [ | ||||
|                           { id: 'AM', name: 'AM' }, | ||||
|                           { id: 'PM', name: 'PM' } | ||||
|                         ] | ||||
|                       }); | ||||
|                     } | ||||
|                   } | ||||
|                 }) | ||||
|               }, | ||||
|               messages: { | ||||
|                 notification: function(args) { | ||||
|                   return 'Setup recurring snapshot'; | ||||
|                 } | ||||
|               }, | ||||
|               notification: { | ||||
|                 poll: testData.notifications.testPoll | ||||
|               } | ||||
|             }, | ||||
|             create: { | ||||
|               label: 'Create template', | ||||
|               addRow: 'false', | ||||
|               messages: { | ||||
|                 notification: function(args) { | ||||
|                   return 'Making new template: ' + args.name; | ||||
|                 } | ||||
|               }, | ||||
|               action: function(args) { | ||||
|                 args.response.success({ | ||||
|                   data: { | ||||
|                     state: 'Templating' | ||||
|                   } | ||||
|                 }); | ||||
|               }, | ||||
|               createForm: { | ||||
|                 title: 'Create a template', | ||||
|                 desc: 'To create a template from the selected volume, please complete the fields below.', | ||||
|                 fields: { | ||||
|                   name: { label: 'Name' }, | ||||
|                   displayText: { label: 'Display text' }, | ||||
|                   'public': { | ||||
|                     label: 'Public', isBoolean: true | ||||
|                   }, | ||||
|                   osType: { | ||||
|                     label: 'OS Type', | ||||
|                     dependsOn: 'public', | ||||
|                     hidden: true, | ||||
|                     select: function(args) { | ||||
|                       args.response.success({ | ||||
|                         descriptionField: 'description', | ||||
|                         data: [ | ||||
|                           { id: 'centos53-64', description: 'CentOS 5.3 (64-bit)' }, | ||||
|                           { id: 'rhel5-64', description: 'Red Hat Enterprise Linux 5.0 (64-bit)' }, | ||||
|                           { id: 'deb6-32', description: 'Debian GNU/Linux 6.0 (32-bit)' } | ||||
|                         ] | ||||
|                       }); | ||||
|                     } | ||||
|                   }, | ||||
|                   usePassword: { | ||||
|                     label: 'Use Password?', | ||||
|                     isBoolean: true, | ||||
|                     hidden: true, | ||||
|                     dependsOn: 'public' | ||||
|                   }, | ||||
|                   password: { | ||||
|                     label: 'Password', | ||||
|                     hidden: true, | ||||
|                     dependsOn: 'usePassword', | ||||
|                     password: true | ||||
|                   } | ||||
|                 } | ||||
|               }, | ||||
|               notification: { | ||||
|                 poll: testData.notifications.customPoll({ | ||||
|                   state: 'Ready' | ||||
|                 }) | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
|           dataProvider: testData.dataProvider.listView('storage'), | ||||
|           detailView: { | ||||
|             name: 'Volume details', | ||||
|             viewAll: { path: 'storage.snapshots', label: 'Snapshots' }, | ||||
|             actions: { | ||||
|               edit: { | ||||
|                 label: 'Edit volume details', | ||||
|                 action: function(args) { | ||||
|                   setTimeout(function() { | ||||
|                     args.response.success();                     | ||||
|                   }, 500); | ||||
|                 } | ||||
|               }, | ||||
|               snapshot: { | ||||
|                 label: 'Take snapshot', | ||||
|                 messages: { | ||||
|                   confirm: function(args) { | ||||
|                     return 'Please confirm that you want to take a snapshot of ' + args.name; | ||||
|                   }, | ||||
|                   notification: function(args) { | ||||
|                     return 'Made snapshot of volume: ' + args.name; | ||||
|                   } | ||||
|                 }, | ||||
|                 action: function(args) { | ||||
|                   args.response.success(); | ||||
|                 }, | ||||
|                 notification: { | ||||
|                   poll: testData.notifications.testPoll | ||||
|                 } | ||||
|               }, | ||||
|               createTemplate: { | ||||
|                 label: 'Create template', | ||||
|                 messages: { | ||||
|                   success: function(args) { | ||||
|                     return 'Your new template ' + args.name + ' is being created.'; | ||||
|                   }, | ||||
|                   notification: function(args) { | ||||
|                     return 'Making new template: ' + args.name; | ||||
|                   } | ||||
|                 }, | ||||
|                 action: function(args) { | ||||
|                   args.response.success(); | ||||
|                 }, | ||||
|                 createForm: { | ||||
|                   title: 'Create a template', | ||||
|                   desc: 'To create a template from the selected volume, please complete the fields below.', | ||||
|                   fields: { | ||||
|                     name: { label: 'Name', validation: { required: true } }, | ||||
|                     displayText: { label: 'Display text' }, | ||||
|                     osType: { | ||||
|                       label: 'OS Type', | ||||
|                       select: function(args) { | ||||
|                         args.response.success({ | ||||
|                           descriptionField: 'description', | ||||
|                           data: [ | ||||
|                             { id: 'centos53-64', description: 'CentOS 5.3 (64-bit)' }, | ||||
|                             { id: 'rhel5-64', description: 'Red Hat Enterprise Linux 5.0 (64-bit)' }, | ||||
|                             { id: 'deb6-32', description: 'Debian GNU/Linux 6.0 (32-bit)' } | ||||
|                           ] | ||||
|                         }); | ||||
|                       } | ||||
|                     }, | ||||
|                     'public': { | ||||
|                       label: 'Public', isBoolean: true | ||||
|                     }, | ||||
|                     usePassword: { | ||||
|                       label: 'Use password?', isBoolean: true | ||||
|                     } | ||||
|                   } | ||||
|                 }, | ||||
|                 notification: { | ||||
|                   poll: testData.notifications.testPoll | ||||
|                 } | ||||
|               } | ||||
|             }, | ||||
|             tabs: { | ||||
|               details: { | ||||
|                 title: 'Details', | ||||
|                 fields: [ | ||||
|                   { | ||||
|                     name: { label: 'Name', isEditable: true } | ||||
|                   }, | ||||
|                   { | ||||
|                     id: { label: 'ID' }, | ||||
|                     type: { label: 'Type' }, | ||||
|                     zone: { label: 'Zone' } | ||||
|                   } | ||||
|                 ], | ||||
|                 dataProvider: testData.dataProvider.detailView('storage') | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       }, | ||||
| 
 | ||||
|       /** | ||||
|        * Snapshots | ||||
|        */ | ||||
|       snapshots: { | ||||
|         type: 'select', | ||||
|         title: 'Snapshots', | ||||
|         listView: { | ||||
|           id: 'snapshots', | ||||
|           label: 'Snapshots', | ||||
|           fields: { | ||||
|             volumename: { label: 'Volume' }, | ||||
|             state: { label: 'State' }, | ||||
|             intervaltype: { label: 'Interval Type' }, | ||||
|             created: { label: 'Date' } | ||||
|           }, | ||||
|           filters: { | ||||
|             mine: { label: 'My snapshots' } | ||||
|           }, | ||||
|           dataProvider: testData.dataProvider.listView('snapshots'), | ||||
|           detailView: { | ||||
|             name: 'Snapshot detail', | ||||
|             tabs: { | ||||
|               details: { | ||||
|                 title: 'Details', | ||||
|                 fields: [ | ||||
|                   { | ||||
|                     name: { label: 'Name' } | ||||
|                   }, | ||||
|                   { | ||||
|                     id: { label: 'ID' }, | ||||
|                     volume: { label: 'Volume' }, | ||||
|                     state: { label: 'State' }, | ||||
|                     intervalType: { label: 'Interval Type' }, | ||||
|                     account: { label: 'Account' }, | ||||
|                     domain: { label: 'Domain' } | ||||
|                   } | ||||
|                 ], | ||||
|                 dataProvider: testData.dataProvider.detailView('snapshots') | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   }; | ||||
| })(cloudStack, jQuery, testData); | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -1,78 +0,0 @@ | ||||
| (function(cloudStack) { | ||||
|   cloudStack.sections.templates = { | ||||
|     title: 'Templates', | ||||
|     id: 'templates', | ||||
|     sectionSelect: { | ||||
|       label: 'Select view' | ||||
|     }, | ||||
|     sections: { | ||||
|       templates: { | ||||
|         type: 'select', | ||||
|         title: 'Templates', | ||||
|         listView: { | ||||
|           id: 'templates', | ||||
|           label: 'Templates', | ||||
|           fields: { | ||||
|             displaytext: { label: 'Name', editable: true }, | ||||
|             desc: { label: 'Details' }, | ||||
|             zonename: { label: 'Zone' }, | ||||
|             hypervisor: { label: 'Hypervisor' } | ||||
|           }, | ||||
|           actions: { | ||||
|             // Add template
 | ||||
|             add: { | ||||
|               label: 'Add template', | ||||
| 
 | ||||
|               action: function(args) { | ||||
|                 args.response.success(); | ||||
|               }, | ||||
| 
 | ||||
|               messages: { | ||||
|                 notification: function(args) { | ||||
|                   return 'Created template'; | ||||
|                 } | ||||
|               }, | ||||
| 
 | ||||
|               createForm: { | ||||
|                 title: 'Add new template', | ||||
|                 desc: 'Please enter the following data to create your new template', | ||||
| 
 | ||||
|                 fields: { | ||||
|                   name: { label: 'Name', validation: { required: true } }, | ||||
|                   displayText: { label: 'Display Text', validation: { required: true } }, | ||||
|                   url: { label: 'URL', validation: { required: true } }, | ||||
|                   passwordEnabled: { label: 'Password', isBoolean: true } | ||||
|                 } | ||||
|               }, | ||||
| 
 | ||||
|               notification: { | ||||
|                 poll: testData.notifications.testPoll | ||||
|               } | ||||
|             }, | ||||
|             edit: { | ||||
|               label: 'Edit template name', | ||||
|               action: function(args) { | ||||
|                 args.response.success(args.data[0]); | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
|           dataProvider: testData.dataProvider.listView('templates') | ||||
|         } | ||||
|       }, | ||||
|       isos: { | ||||
|         type: 'select', | ||||
|         title: 'ISOs', | ||||
|         listView: { | ||||
|           label: 'ISOs', | ||||
|           fields: { | ||||
|             displaytext: { label: 'Name' }, | ||||
|             desc: { label: 'Details' }, | ||||
|             size: { label: 'Size' }, | ||||
|             zonename: { label: 'Zone' } | ||||
|           }, | ||||
|           dataProvider: testData.dataProvider.listView('isos') | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   };   | ||||
| })(cloudStack); | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -1,687 +0,0 @@ | ||||
| (function(cloudStack, $) { | ||||
|   cloudStack.zoneWizard = { | ||||
|     customUI: { | ||||
|       publicTrafficIPRange: function(args) { | ||||
|         var multiEditData = []; | ||||
|         var totalIndex = 0; | ||||
| 
 | ||||
|         return $('<div>').multiEdit({ | ||||
|           context: args.context, | ||||
|           noSelect: true, | ||||
|           fields: { | ||||
|             'gateway': { edit: true, label: 'Gateway' }, | ||||
|             'netmask': { edit: true, label: 'Netmask' }, | ||||
|             'vlanid': { edit: true, label: 'VLAN', isOptional: true }, | ||||
|             'startip': { edit: true, label: 'Start IP' }, | ||||
|             'endip': { edit: true, label: 'End IP' }, | ||||
|             'add-rule': { label: 'Add', addButton: true } | ||||
|           }, | ||||
|           add: { | ||||
|             label: 'Add', | ||||
|             action: function(args) { | ||||
|               multiEditData.push($.extend(args.data, { | ||||
|                 index: totalIndex | ||||
|               })); | ||||
| 
 | ||||
|               totalIndex++; | ||||
|               args.response.success(); | ||||
|             } | ||||
|           }, | ||||
|           actions: { | ||||
|             destroy: { | ||||
|               label: 'Remove Rule', | ||||
|               action: function(args) { | ||||
|                 multiEditData = $.grep(multiEditData, function(item) { | ||||
|                   return item.index != args.context.multiRule[0].index; | ||||
|                 }); | ||||
|                 args.response.success(); | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
|           dataProvider: function(args) { | ||||
|             args.response.success({ | ||||
|               data: multiEditData | ||||
|             }); | ||||
|           } | ||||
|         }); | ||||
|       } | ||||
|     }, | ||||
| 
 | ||||
|     preFilters: { | ||||
|       addPublicNetwork: function(args) { | ||||
|         return args.data['network-model'] == 'Advanced'; | ||||
|       }, | ||||
| 
 | ||||
|       addNetscalerDevice: function(args) { | ||||
|         return args.data['network-model'] == 'Basic'; | ||||
|       }, | ||||
| 
 | ||||
|       setupPhysicalNetwork: function(args) { | ||||
|         return args.data['network-model'] == 'Advanced'; | ||||
|       } | ||||
|     }, | ||||
| 
 | ||||
|     forms: { | ||||
|       zone: { | ||||
|         preFilter: function(args) { | ||||
|           var $form = args.$form; | ||||
| 
 | ||||
|           $form.find('input[name=security-groups-enabled]').change(function() { | ||||
|             if ($(this).is(':checked')) { | ||||
|               $form.find('[rel=networkOfferingIdWithoutSG]').hide(); | ||||
|               $form.find('[rel=networkOfferingIdWithSG]').show(); | ||||
|             } else { | ||||
|               $form.find('[rel=networkOfferingIdWithoutSG]').show(); | ||||
|               $form.find('[rel=networkOfferingIdWithSG]').hide(); | ||||
|             } | ||||
|           }); | ||||
| 
 | ||||
|           if (args.data['network-model'] == 'Advanced') { | ||||
|             args.$form.find('[rel=security-groups-enabled]').hide(); | ||||
|             args.$form.find('[rel=networkOfferingIdWithoutSG]').hide(); | ||||
|             args.$form.find('[rel=networkOfferingIdWithSG]').hide(); | ||||
|           } else { | ||||
|             args.$form.find('[rel=security-groups-enabled]').show(); | ||||
|             args.$form.find('[rel=networkOfferingIdWithoutSG]').show(); | ||||
|             args.$form.find('[rel=networkOfferingIdWithSG]').show(); | ||||
| 
 | ||||
|             $form.find('input[name=security-groups-enabled]:visible').trigger('change'); | ||||
|           } | ||||
|         }, | ||||
|         fields: { | ||||
|           name: { label: 'Name', validation: { required: true } }, | ||||
|           dns1: { label: 'DNS 1', validation: { required: true } }, | ||||
|           dns2: { label: 'DNS 2' }, | ||||
|           internaldns1: { label: 'Internal DNS 1', validation: { required: true } }, | ||||
|           internaldns2: { label: 'Internal DNS 2' }, | ||||
|           networkdomain: { label: 'Network Domain' }, | ||||
|           ispublic: { isBoolean: true, label: 'Public' }, | ||||
|           domain: { | ||||
|             label: 'Domain', | ||||
|             dependsOn: 'ispublic', | ||||
|             isHidden: true, | ||||
|             select: function(args) { | ||||
|               args.response.success({ | ||||
|                 data: $.map(testData.data.domains, function(domain) { | ||||
|                   return { | ||||
|                     id: domain.id, | ||||
|                     description: domain.name | ||||
|                   }; | ||||
|                 }) | ||||
|               }); | ||||
|             } | ||||
|           }, | ||||
|           'security-groups-enabled': { | ||||
|             label: 'Security Groups Enabled', | ||||
|             isBoolean: true, | ||||
|             isReverse: true | ||||
|           }, | ||||
| 
 | ||||
|           networkOfferingIdWithoutSG: { | ||||
|             label: 'Network Offering', | ||||
|             dependsOn: 'security-groups-enabled', | ||||
|             select: function(args) { | ||||
|               args.response.success({ | ||||
|                 data: $.map(testData.data.networkOfferings, function(offering) { | ||||
|                   return { | ||||
|                     id: offering.id, | ||||
|                     description: offering.name | ||||
|                   }; | ||||
|                 }) | ||||
|               }); | ||||
|             } | ||||
|           }, | ||||
| 
 | ||||
|           networkOfferingIdWithSG: { | ||||
|             label: 'Network Offering', | ||||
|             isHidden: true, | ||||
|             select: function(args) { | ||||
|               args.response.success({ | ||||
|                 data: $.map(testData.data.networkOfferings, function(offering) { | ||||
|                   return { | ||||
|                     id: offering.id, | ||||
|                     description: offering.name | ||||
|                   }; | ||||
|                 }) | ||||
|               }); | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       }, | ||||
| 
 | ||||
|       pod: { | ||||
|         fields: { | ||||
|           name: { | ||||
|             label: 'Pod name', | ||||
|             validation: { required: true } | ||||
|           }, | ||||
|           reservedSystemGateway: { | ||||
|             label: 'Reserved system gateway', | ||||
|             validation: { required: true } | ||||
|           }, | ||||
|           reservedSystemNetmask: { | ||||
|             label: 'Reserved system netmask', | ||||
|             validation: { required: true } | ||||
|           }, | ||||
|           reservedSystemStartIp: { | ||||
|             label: 'Start Reserved system IP', | ||||
|             validation: { required: true } | ||||
|           }, | ||||
|           reservedSystemEndIp: { | ||||
|             label: 'End Reserved system IP', | ||||
|             validation: { required: false } | ||||
|           } | ||||
|         } | ||||
|       }, | ||||
| 
 | ||||
|       basicPhysicalNetwork: { | ||||
|         fields: { | ||||
|           name: { label: 'Network name', validation: { required: true } }, | ||||
|           isStorageEnabled: { isBoolean: true, label: 'Storage traffic enabled' } | ||||
|         } | ||||
|       }, | ||||
| 
 | ||||
|       guestTraffic: { | ||||
|         preFilter: function(args) { | ||||
|           var selectedZoneObj = { | ||||
|             networktype: args.data['network-model'] | ||||
|           }; | ||||
| 
 | ||||
|           if (selectedZoneObj.networktype == "Basic") { | ||||
|             args.$form.find('[rel=vlanRange]').hide(); | ||||
|             args.$form.find('[rel=vlanId]').hide(); | ||||
|             args.$form.find('[rel=scope]').hide(); | ||||
|             args.$form.find('[rel=domainId]').hide(); | ||||
|             args.$form.find('[rel=account]').hide(); | ||||
|             args.$form.find('[rel=networkdomain]').hide(); | ||||
| 
 | ||||
|             args.$form.find('[rel=podId]').show(); | ||||
|           } else {  // Advanced
 | ||||
|             args.$form.find('[rel=vlanRange]').show(); | ||||
|             args.$form.find('[rel=vlanId]').show(); | ||||
|             args.$form.find('[rel=scope]').show(); | ||||
|             args.$form.find('[rel=domainId]').show(); | ||||
|             args.$form.find('[rel=account]').show(); | ||||
|             args.$form.find('[rel=networkdomain]').show(); | ||||
|           } | ||||
|         }, | ||||
| 
 | ||||
|         fields: { | ||||
|           vlanRange: { | ||||
|             label: 'VLAN Range', | ||||
|             range: ['vlanRangeStart', 'vlanRangeEnd'], | ||||
|             validation: { required: true } | ||||
|           }, | ||||
|           name: { | ||||
|             label: 'Name', | ||||
|             validation: { required: true } | ||||
|           }, | ||||
|           description: { | ||||
|             label: 'Description', | ||||
|             validation: { required: true } | ||||
|           }, | ||||
|           vlanId: { | ||||
|             label: "VLAN ID" | ||||
|           }, | ||||
|           scope: { | ||||
|             label: 'Scope', | ||||
|             select: function(args) { | ||||
|               var array1 = []; | ||||
|               var selectedZoneObj = { | ||||
|                 securitygroupsenabled: args.context.zones[0]['security-groups-enabled'] | ||||
|               }; | ||||
|               if(selectedZoneObj.securitygroupsenabled) { | ||||
|                 array1.push({id: 'account-specific', description: 'Account'}); | ||||
|               } | ||||
|               else { | ||||
|                 array1.push({id: 'zone-wide', description: 'All'}); | ||||
|                 array1.push({id: 'domain-specific', description: 'Domain'}); | ||||
|                 array1.push({id: 'account-specific', description: 'Account'}); | ||||
|               } | ||||
|               args.response.success({ data: array1 }); | ||||
| 
 | ||||
|               args.$select.change(function() { | ||||
|                 var $form = args.$select.closest('form'); | ||||
| 
 | ||||
|                 if($(this).val() == "zone-wide") { | ||||
|                   $form.find('[rel=domainId]').hide(); | ||||
|                   $form.find('[rel=account]').hide(); | ||||
|                 } | ||||
|                 else if ($(this).val() == "domain-specific") { | ||||
|                   $form.find('[rel=domainId]').show(); | ||||
|                   $form.find('[rel=account]').hide(); | ||||
|                 } | ||||
|                 else if($(this).val() == "account-specific") { | ||||
|                   $form.find('[rel=domainId]').show(); | ||||
|                   $form.find('[rel=account]').show(); | ||||
|                 } | ||||
|               }); | ||||
| 
 | ||||
|               setTimeout(function() { | ||||
|                 args.$select.trigger('change'); | ||||
|               }); | ||||
|             } | ||||
|           }, | ||||
|           domainId: { | ||||
|             label: 'Domain', | ||||
|             select: function(args) { | ||||
|               args.response.success({ | ||||
|                 data: $.map(testData.data.domains, function(offering) { | ||||
|                   return { | ||||
|                     id: offering.id, | ||||
|                     description: offering.name | ||||
|                   }; | ||||
|                 }) | ||||
|               }); | ||||
|             } | ||||
|           }, | ||||
|           account: { label: 'Account' }, | ||||
|           guestGateway: { label: 'Guest gateway' }, | ||||
|           guestNetmask: { label: 'Guest netmask' }, | ||||
|           guestStartIp: { label: 'Guest start IP' }, | ||||
|           guestEndIp: { label: 'Guest end IP' }, | ||||
|           networkdomain: { label: 'Network domain' } | ||||
|         } | ||||
|       }, | ||||
|       cluster: { | ||||
|         fields: { | ||||
|           hypervisor: { | ||||
|             label: 'Hypervisor', | ||||
|             select: function(args) { | ||||
|               args.response.success({ data:testData.data.hypervisors }); | ||||
|             } | ||||
|           }, | ||||
|           name: { | ||||
|             label: 'Cluster Name', | ||||
|             validation: { required: true } | ||||
|           }, | ||||
| 
 | ||||
|           //hypervisor==VMWare begins here
 | ||||
|           vCenterHost: { | ||||
|             label: 'vCenter Host', | ||||
|             validation: { required: true } | ||||
|           }, | ||||
|           vCenterUsername: { | ||||
|             label: 'vCenter Username', | ||||
|             validation: { required: true } | ||||
|           }, | ||||
|           vCenterPassword: { | ||||
|             label: 'vCenter Password', | ||||
|             validation: { required: true }, | ||||
|             isPassword: true | ||||
|           }, | ||||
|           vCenterDatacenter: { | ||||
|             label: 'vCenter Datacenter', | ||||
|             validation: { required: true } | ||||
|           } | ||||
|           //hypervisor==VMWare ends here
 | ||||
|         } | ||||
|       }, | ||||
|       host: { | ||||
|         preFilter: function(args) { | ||||
|           var selectedClusterObj = { | ||||
|             hypervisortype: args.data.hypervisor | ||||
|           }; | ||||
| 
 | ||||
|           var $form = args.$form; | ||||
| 
 | ||||
|           if(selectedClusterObj.hypervisortype == "VMware") { | ||||
|             //$('li[input_group="general"]', $dialogAddHost).hide();
 | ||||
|             $form.find('[rel=hostname]').hide(); | ||||
|             $form.find('[rel=username]').hide(); | ||||
|             $form.find('[rel=password]').hide(); | ||||
| 
 | ||||
|             //$('li[input_group="vmware"]', $dialogAddHost).show();
 | ||||
|             $form.find('[rel=vcenterHost]').css('display', 'block'); | ||||
| 
 | ||||
|             //$('li[input_group="baremetal"]', $dialogAddHost).hide();
 | ||||
|             $form.find('[rel=baremetalCpuCores]').hide(); | ||||
|             $form.find('[rel=baremetalCpu]').hide(); | ||||
|             $form.find('[rel=baremetalMemory]').hide(); | ||||
|             $form.find('[rel=baremetalMAC]').hide(); | ||||
| 
 | ||||
|             //$('li[input_group="Ovm"]', $dialogAddHost).hide();
 | ||||
|             $form.find('[rel=agentUsername]').hide(); | ||||
|             $form.find('[rel=agentPassword]').hide(); | ||||
|           } | ||||
|           else if (selectedClusterObj.hypervisortype == "BareMetal") { | ||||
|             //$('li[input_group="general"]', $dialogAddHost).show();
 | ||||
|             $form.find('[rel=hostname]').css('display', 'block'); | ||||
|             $form.find('[rel=username]').css('display', 'block'); | ||||
|             $form.find('[rel=password]').css('display', 'block'); | ||||
| 
 | ||||
|             //$('li[input_group="baremetal"]', $dialogAddHost).show();
 | ||||
|             $form.find('[rel=baremetalCpuCores]').css('display', 'block'); | ||||
|             $form.find('[rel=baremetalCpu]').css('display', 'block'); | ||||
|             $form.find('[rel=baremetalMemory]').css('display', 'block'); | ||||
|             $form.find('[rel=baremetalMAC]').css('display', 'block'); | ||||
| 
 | ||||
|             //$('li[input_group="vmware"]', $dialogAddHost).hide();
 | ||||
|             $form.find('[rel=vcenterHost]').hide(); | ||||
| 
 | ||||
|             //$('li[input_group="Ovm"]', $dialogAddHost).hide();
 | ||||
|             $form.find('[rel=agentUsername]').hide(); | ||||
|             $form.find('[rel=agentPassword]').hide(); | ||||
|           } | ||||
|           else if (selectedClusterObj.hypervisortype == "Ovm") { | ||||
|             //$('li[input_group="general"]', $dialogAddHost).show();
 | ||||
|             $form.find('[rel=hostname]').css('display', 'block'); | ||||
|             $form.find('[rel=username]').css('display', 'block'); | ||||
|             $form.find('[rel=password]').css('display', 'block'); | ||||
| 
 | ||||
|             //$('li[input_group="vmware"]', $dialogAddHost).hide();
 | ||||
|             $form.find('[rel=vcenterHost]').hide(); | ||||
| 
 | ||||
|             //$('li[input_group="baremetal"]', $dialogAddHost).hide();
 | ||||
|             $form.find('[rel=baremetalCpuCores]').hide(); | ||||
|             $form.find('[rel=baremetalCpu]').hide(); | ||||
|             $form.find('[rel=baremetalMemory]').hide(); | ||||
|             $form.find('[rel=baremetalMAC]').hide(); | ||||
| 
 | ||||
|             //$('li[input_group="Ovm"]', $dialogAddHost).show();
 | ||||
|             $form.find('[rel=agentUsername]').css('display', 'block'); | ||||
|             $form.find('[rel=agentUsername]').find('input').val("oracle"); | ||||
|             $form.find('[rel=agentPassword]').css('display', 'block'); | ||||
|           } | ||||
|           else { | ||||
|             //$('li[input_group="general"]', $dialogAddHost).show();
 | ||||
|             $form.find('[rel=hostname]').css('display', 'block'); | ||||
|             $form.find('[rel=username]').css('display', 'block'); | ||||
|             $form.find('[rel=password]').css('display', 'block'); | ||||
| 
 | ||||
|             //$('li[input_group="vmware"]', $dialogAddHost).hide();
 | ||||
|             $form.find('[rel=vcenterHost]').hide(); | ||||
| 
 | ||||
|             //$('li[input_group="baremetal"]', $dialogAddHost).hide();
 | ||||
|             $form.find('[rel=baremetalCpuCores]').hide(); | ||||
|             $form.find('[rel=baremetalCpu]').hide(); | ||||
|             $form.find('[rel=baremetalMemory]').hide(); | ||||
|             $form.find('[rel=baremetalMAC]').hide(); | ||||
| 
 | ||||
|             //$('li[input_group="Ovm"]', $dialogAddHost).hide();
 | ||||
|             $form.find('[rel=agentUsername]').hide(); | ||||
|             $form.find('[rel=agentPassword]').hide(); | ||||
|           } | ||||
|         }, | ||||
|         fields: { | ||||
|           hostname: { | ||||
|             label: 'Host name', | ||||
|             validation: { required: true }, | ||||
|             isHidden: true | ||||
|           }, | ||||
| 
 | ||||
|           username: { | ||||
|             label: 'User name', | ||||
|             validation: { required: true }, | ||||
|             isHidden: true | ||||
|           }, | ||||
| 
 | ||||
|           password: { | ||||
|             label: 'Password', | ||||
|             validation: { required: true }, | ||||
|             isHidden: true, | ||||
|             isPassword: true | ||||
|           }, | ||||
|           //input_group="general" ends here
 | ||||
| 
 | ||||
|           //input_group="VMWare" starts here
 | ||||
|           vcenterHost: { | ||||
|             label: 'ESX/ESXi Host', | ||||
|             validation: { required: true }, | ||||
|             isHidden: true | ||||
|           }, | ||||
|           //input_group="VMWare" ends here
 | ||||
| 
 | ||||
|           //input_group="BareMetal" starts here
 | ||||
|           baremetalCpuCores: { | ||||
|             label: '# of CPU Cores', | ||||
|             validation: { required: true }, | ||||
|             isHidden: true | ||||
|           }, | ||||
|           baremetalCpu: { | ||||
|             label: 'CPU (in MHz)', | ||||
|             validation: { required: true }, | ||||
|             isHidden: true | ||||
|           }, | ||||
|           baremetalMemory: { | ||||
|             label: 'Memory (in MB)', | ||||
|             validation: { required: true }, | ||||
|             isHidden: true | ||||
|           }, | ||||
|           baremetalMAC: { | ||||
|             label: 'Host MAC', | ||||
|             validation: { required: true }, | ||||
|             isHidden: true | ||||
|           }, | ||||
|           //input_group="BareMetal" ends here
 | ||||
| 
 | ||||
|           //input_group="OVM" starts here
 | ||||
|           agentUsername: { | ||||
|             label: 'Agent Username', | ||||
|             validation: { required: false }, | ||||
|             isHidden: true | ||||
|           }, | ||||
|           agentPassword: { | ||||
|             label: 'Agent Password', | ||||
|             validation: { required: true }, | ||||
|             isHidden: true, | ||||
|             isPassword: true | ||||
|           }, | ||||
|           //input_group="OVM" ends here
 | ||||
| 
 | ||||
|           //always appear (begin)
 | ||||
|           hosttags: { | ||||
|             label: 'Host tags', | ||||
|             validation: { required: false } | ||||
|           } | ||||
|           //always appear (end)
 | ||||
|         } | ||||
|       }, | ||||
|       primaryStorage: { | ||||
|         preFilter: function(args) {}, | ||||
| 
 | ||||
|         fields: { | ||||
|           name: { | ||||
|             label: 'Name', | ||||
|             validation: { required: true } | ||||
|           }, | ||||
|            | ||||
|           server: { | ||||
|             label: 'Server', | ||||
|             validation: { required: true }, | ||||
|             isHidden: true | ||||
|           }, | ||||
| 
 | ||||
|           //nfs
 | ||||
|           path: { | ||||
|             label: 'Path', | ||||
|             validation: { required: true }, | ||||
|             isHidden: true | ||||
|           }, | ||||
| 
 | ||||
|           //iscsi
 | ||||
|           iqn: { | ||||
|             label: 'Target IQN', | ||||
|             validation: { required: true }, | ||||
|             isHidden: true | ||||
|           }, | ||||
|           lun: { | ||||
|             label: 'LUN #', | ||||
|             validation: { required: true }, | ||||
|             isHidden: true | ||||
|           }, | ||||
| 
 | ||||
|           //vmfs
 | ||||
|           vCenterDataCenter: { | ||||
|             label: 'vCenter Datacenter', | ||||
|             validation: { required: true }, | ||||
|             isHidden: true | ||||
|           }, | ||||
|           vCenterDataStore: { | ||||
|             label: 'vCenter Datastore', | ||||
|             validation: { required: true }, | ||||
|             isHidden: true | ||||
|           }, | ||||
| 
 | ||||
|           //always appear (begin)
 | ||||
|           storageTags: { | ||||
|             label: 'Storage Tags', | ||||
|             validation: { required: false } | ||||
|           } | ||||
|           //always appear (end)
 | ||||
|         } | ||||
|       }, | ||||
|       secondaryStorage: { | ||||
|         fields: { | ||||
|           nfsServer: { | ||||
|             label: 'NFS Server', | ||||
|             validation: { required: true } | ||||
|           }, | ||||
|           path: { | ||||
|             label: 'Path', | ||||
|             validation: { required: true } | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
| 
 | ||||
|     action: function(args) { | ||||
|       var success = args.response.success; | ||||
|       var error = args.response.error; | ||||
|       var message = args.response.message; | ||||
|       var data = args.data; | ||||
|       var startFn = args.startFn; | ||||
| 
 | ||||
|       var stepFns = { | ||||
|         addZone: function(args) { | ||||
|           message('Creating zone'); | ||||
| 
 | ||||
|           var zone = {}; | ||||
| 
 | ||||
|           setTimeout(function() { | ||||
|             stepFns.addPhysicalNetworks({ | ||||
|               data: $.extend(args.data, { | ||||
|                 zone: zone | ||||
|               }) | ||||
|             }); | ||||
|           }, 300); | ||||
|         }, | ||||
| 
 | ||||
|         addPhysicalNetworks: function(args) { | ||||
|           message('Creating physical network(s)'); | ||||
| 
 | ||||
|           var physicalNetworks = []; | ||||
| 
 | ||||
|           setTimeout(function() { | ||||
|             stepFns.addPod({ | ||||
|               data: $.extend(args.data, { | ||||
|                 physicalNetworks: physicalNetworks | ||||
|               }) | ||||
|             }); | ||||
|           }, 400); | ||||
|         }, | ||||
| 
 | ||||
|         addPod: function(args) { | ||||
|           message('Creating pod'); | ||||
| 
 | ||||
|           var pod = {}; | ||||
| 
 | ||||
|           setTimeout(function() { | ||||
|             return error('addPod', 'System error 500', { fn: 'configurePublicTraffic', args: args }); | ||||
|             stepFns.configurePublicTraffic({ | ||||
|               data: $.extend(args.data, { | ||||
|                 pod: pod | ||||
|               }) | ||||
|             }); | ||||
|           }, 300); | ||||
|         }, | ||||
| 
 | ||||
|         configurePublicTraffic: function(args) { | ||||
|           message('Configuring public traffic'); | ||||
| 
 | ||||
|           setTimeout(function() { | ||||
|             stepFns.configureGuestTraffic({ | ||||
|               data: args.data | ||||
|             }); | ||||
|           }, 200); | ||||
|         }, | ||||
| 
 | ||||
|         configureGuestTraffic: function(args) { | ||||
|           message('Configuring guest traffic'); | ||||
| 
 | ||||
|           setTimeout(function() { | ||||
|             stepFns.addCluster({ | ||||
|               data: args.data | ||||
|             }); | ||||
|           }, 200); | ||||
|         }, | ||||
| 
 | ||||
|         addCluster: function(args) { | ||||
|           message('Creating cluster'); | ||||
| 
 | ||||
|           var cluster = {}; | ||||
| 
 | ||||
|           setTimeout(function() { | ||||
|             return error('addCluster', 'System error 500', { fn: 'addHost', args: args }); | ||||
|             stepFns.addHost({ | ||||
|               data: $.extend(args.data, { | ||||
|                 cluster: cluster | ||||
|               }) | ||||
|             }); | ||||
|           }, 200); | ||||
|         }, | ||||
| 
 | ||||
|         addHost: function(args) { | ||||
|           message('Adding host'); | ||||
| 
 | ||||
|           var host = {}; | ||||
| 
 | ||||
|           setTimeout(function() { | ||||
|             stepFns.addPrimaryStorage({ | ||||
|               data: $.extend(args.data, { | ||||
|                 host: host | ||||
|               }) | ||||
|             }); | ||||
|           }, 400); | ||||
|         }, | ||||
| 
 | ||||
|         addPrimaryStorage: function(args) { | ||||
|           message('Creating primary storage'); | ||||
| 
 | ||||
|           setTimeout(function() { | ||||
|             stepFns.addSecondaryStorage({ | ||||
|               data: args.data | ||||
|             }); | ||||
|           }, 300); | ||||
|         }, | ||||
| 
 | ||||
|         addSecondaryStorage: function(args) { | ||||
|           message('Creating secondary storage'); | ||||
| 
 | ||||
|           setTimeout(function() { | ||||
|             complete({ | ||||
|               data: data | ||||
|             }); | ||||
|           }, 300); | ||||
|         } | ||||
|       }; | ||||
| 
 | ||||
|       var complete = function(args) { | ||||
|         message('Zone creation complete!'); | ||||
|         success({ data: { zone: { id: '123-4223' }}}); | ||||
|       }; | ||||
| 
 | ||||
|       if (startFn) { | ||||
|         stepFns[startFn.fn](startFn.args); | ||||
|       } else { | ||||
|         stepFns.addZone({}); | ||||
|       } | ||||
|     }, | ||||
| 
 | ||||
|     enableZoneAction: function(args) { | ||||
|       setTimeout(function() { | ||||
|         args.response.success(); | ||||
|       }, 2000); | ||||
|     } | ||||
|   }; | ||||
| }(cloudStack, jQuery)); | ||||
| @ -1,4 +1,4 @@ | ||||
| (function(cloudStack, testData) { | ||||
| (function(cloudStack) { | ||||
| 
 | ||||
|   var rootDomainId = 1; | ||||
| 
 | ||||
| @ -1005,4 +1005,4 @@ | ||||
|     return allowedActions; | ||||
|   } | ||||
| 
 | ||||
| })(cloudStack, testData); | ||||
| })(cloudStack); | ||||
|  | ||||
| @ -1,5 +1,5 @@ | ||||
| (function(cloudStack, $, testData) { | ||||
|   $.extend(window.cloudStack, testData, { | ||||
| (function(cloudStack, $) { | ||||
|   $.extend(cloudStack, { | ||||
|     home: 'dashboard', | ||||
| 
 | ||||
|     sectionPreFilter: function(args) { | ||||
| @ -308,4 +308,4 @@ | ||||
| 
 | ||||
|     cloudStack.uiCustom.login(loginArgs); | ||||
|   }); | ||||
| })(cloudStack, jQuery, testData); | ||||
| })(cloudStack, jQuery); | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| (function(cloudStack, testData, $) { | ||||
| (function(cloudStack, $) { | ||||
|   cloudStack.sections.configuration = { | ||||
|     title: 'Configuration', | ||||
|     id: 'configuration', | ||||
| @ -1652,4 +1652,4 @@ | ||||
|     return allowedActions; | ||||
|   }; | ||||
| 
 | ||||
| })(cloudStack, testData, jQuery); | ||||
| })(cloudStack, jQuery); | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| (function($, cloudStack, testData) { | ||||
| (function($, cloudStack) { | ||||
|   // Admin dashboard
 | ||||
|   cloudStack.sections.dashboard = { | ||||
|     title: 'Dashboard', | ||||
| @ -265,4 +265,4 @@ | ||||
|       } | ||||
|     } | ||||
|   }; | ||||
| })(jQuery, cloudStack, testData); | ||||
| })(jQuery, cloudStack); | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| (function(cloudStack, testData) { | ||||
| (function(cloudStack) { | ||||
|   cloudStack.sections.domains = { | ||||
|     title: 'Domains', | ||||
|     id: 'domains', | ||||
| @ -181,10 +181,6 @@ | ||||
|                   validation: { required: false } | ||||
|                 } | ||||
|               } | ||||
|             }, | ||||
| 
 | ||||
|             notification: { | ||||
|               poll: testData.notifications.testPoll | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
| @ -361,4 +357,4 @@ | ||||
|     return allowedActions; | ||||
|   } | ||||
| 
 | ||||
| })(cloudStack, testData); | ||||
| })(cloudStack); | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| (function(cloudStack, testData) { | ||||
| (function(cloudStack) { | ||||
|   cloudStack.sections.events = { | ||||
|     title: 'Events', | ||||
|     id: 'events', | ||||
| @ -121,4 +121,4 @@ | ||||
|       } | ||||
|     } | ||||
|   }; | ||||
| })(cloudStack, testData); | ||||
| })(cloudStack); | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| (function($, cloudStack, testData) { | ||||
| (function($, cloudStack) { | ||||
|   cloudStack.installWizard = { | ||||
|     // Check if install wizard should be invoked
 | ||||
|     check: function(args) { | ||||
| @ -308,4 +308,4 @@ | ||||
|       })); | ||||
|     } | ||||
|   }; | ||||
| }(jQuery, cloudStack, testData)); | ||||
| }(jQuery, cloudStack)); | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| (function($, cloudStack, testData) { | ||||
| (function($, cloudStack) { | ||||
| 
 | ||||
|   var zoneObjs, hypervisorObjs, featuredTemplateObjs, communityTemplateObjs, myTemplateObjs, isoObjs, serviceOfferingObjs, diskOfferingObjs, networkOfferingObjs; | ||||
|   var selectedZoneObj, selectedTemplateObj, selectedHypervisor, selectedDiskOfferingObj;  | ||||
| @ -1639,7 +1639,6 @@ | ||||
|               networkkbsread: { label: 'Network Read' }, | ||||
|               networkkbswrite: { label: 'Network Write' } | ||||
|             }, | ||||
|             //dataProvider: testData.dataProvider.detailView('instances')
 | ||||
|             dataProvider: function(args) { | ||||
|               var jsonObj = args.context.instances[0];                           | ||||
|               args.response.success({ | ||||
| @ -1717,4 +1716,4 @@ | ||||
|     return allowedActions; | ||||
|   } | ||||
| 
 | ||||
| })(jQuery, cloudStack, testData); | ||||
| })(jQuery, cloudStack); | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| (function(cloudStack, $, testData) { | ||||
| (function(cloudStack, $) { | ||||
|   var ipChangeNotice = function() { | ||||
|     cloudStack.dialog.confirm({ | ||||
|       message: 'Your IP addresses may have changed; would you like to refresh the listing? Note that in this case the details pane will close.', | ||||
| @ -1237,7 +1237,6 @@ | ||||
|                   } | ||||
|                 ], | ||||
| 
 | ||||
|                 //dataProvider: testData.dataProvider.detailView('network')
 | ||||
|                 dataProvider: function(args) { | ||||
|                   var items = args.context.ipAddresses; | ||||
| 
 | ||||
| @ -2666,4 +2665,4 @@ | ||||
|       } | ||||
|     } | ||||
|   }; | ||||
| })(cloudStack, jQuery, testData); | ||||
| })(cloudStack, jQuery); | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| (function(cloudStack, testData) { | ||||
| (function(cloudStack) { | ||||
|   cloudStack.projects = { | ||||
|     requireInvitation: function(args) { | ||||
|       return window.g_projectsInviteRequired; | ||||
| @ -578,10 +578,6 @@ | ||||
|                     notification: function(args) { | ||||
|                       return 'Removed project'; | ||||
|                     } | ||||
|                   }, | ||||
| 
 | ||||
|                   notification: { | ||||
|                     poll: testData.notifications.testPoll | ||||
|                   } | ||||
|                 }, | ||||
| 
 | ||||
| @ -855,4 +851,4 @@ | ||||
| 
 | ||||
|     return ['accept', 'decline']; | ||||
|   }; | ||||
| } (cloudStack, testData)); | ||||
| } (cloudStack)); | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| (function(cloudStack, testData) { | ||||
| (function(cloudStack) { | ||||
| 
 | ||||
|   var diskofferingObjs, selectedDiskOfferingObj; | ||||
| 
 | ||||
| @ -469,9 +469,6 @@ | ||||
| 									notification: function(args) { | ||||
| 										return 'Setup recurring snapshot'; | ||||
| 									} | ||||
| 								}, | ||||
| 								notification: { | ||||
| 									poll: testData.notifications.testPoll | ||||
| 								} | ||||
| 							},             | ||||
| 													 | ||||
| @ -1191,4 +1188,4 @@ | ||||
|     return allowedActions; | ||||
|   } | ||||
| 
 | ||||
| })(cloudStack, testData); | ||||
| })(cloudStack); | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| (function($, cloudStack, testData) { | ||||
| (function($, cloudStack) { | ||||
| 
 | ||||
|   var zoneObjs, podObjs, clusterObjs, domainObjs, networkOfferingObjs; | ||||
|   var selectedClusterObj, selectedZoneObj, selectedPublicNetworkObj, selectedManagementNetworkObj, selectedPhysicalNetworkObj, selectedGuestNetworkObj; | ||||
| @ -7279,4 +7279,4 @@ | ||||
|     } | ||||
|   }; | ||||
| 
 | ||||
| })($, cloudStack, testData); | ||||
| })($, cloudStack); | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| (function(cloudStack, $, testData) { | ||||
| (function(cloudStack, $) { | ||||
| 
 | ||||
|   cloudStack.sections.templates = { | ||||
|     title: 'Templates', | ||||
| @ -1304,4 +1304,4 @@ | ||||
|     return allowedActions; | ||||
|   } | ||||
| 
 | ||||
| })(cloudStack, jQuery, testData); | ||||
| })(cloudStack, jQuery); | ||||
|  | ||||
| @ -1,4 +1,4 @@ | ||||
| (function($, cloudStack, testData) { | ||||
| (function($, cloudStack) { | ||||
|   var installWizard = function(args) { | ||||
|     var context = args.context; | ||||
|     var $installWizard = $('<div>').addClass('install-wizard'); | ||||
| @ -767,4 +767,4 @@ | ||||
|   }; | ||||
| 
 | ||||
|   cloudStack.uiCustom.installWizard = installWizard; | ||||
| }(jQuery, cloudStack, testData)); | ||||
| }(jQuery, cloudStack)); | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user