| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  | import { default as computed, observes } from 'ember-addons/ember-computed-decorators'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-15 16:01:44 -04:00
										 |  |  | jQuery.fn.wiggle = function (times, duration) { | 
					
						
							|  |  |  |   if (times > 0) { | 
					
						
							|  |  |  |     this.animate({ | 
					
						
							|  |  |  |       marginLeft: times-- % 2 === 0 ? -15 : 15 | 
					
						
							|  |  |  |     }, duration, 0, () => this.wiggle(times, duration)); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     this.animate({ marginLeft: 0 }, duration, 0); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return this; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  | export default Ember.Component.extend({ | 
					
						
							|  |  |  |   classNames: ['wizard-step'], | 
					
						
							|  |  |  |   saving: null, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   didInsertElement() { | 
					
						
							|  |  |  |     this._super(); | 
					
						
							|  |  |  |     this.autoFocus(); | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-14 16:36:08 -04:00
										 |  |  |   @computed('step.index') | 
					
						
							|  |  |  |   showQuitButton: index => index === 0, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |   @computed('step.displayIndex', 'wizard.totalSteps') | 
					
						
							|  |  |  |   showNextButton: (current, total) => current < total, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-31 13:35:49 -04:00
										 |  |  |   @computed('step.displayIndex', 'wizard.totalSteps') | 
					
						
							|  |  |  |   showDoneButton: (current, total) => current === total, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |   @computed('step.index') | 
					
						
							|  |  |  |   showBackButton: index => index > 0, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   @observes('step.id') | 
					
						
							|  |  |  |   _stepChanged() { | 
					
						
							|  |  |  |     this.set('saving', false); | 
					
						
							|  |  |  |     this.autoFocus(); | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   keyPress(key) { | 
					
						
							|  |  |  |     if (key.keyCode === 13) { | 
					
						
							|  |  |  |       this.send('nextStep'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   @computed('step.displayIndex', 'wizard.totalSteps') | 
					
						
							|  |  |  |   barStyle(displayIndex, totalSteps) { | 
					
						
							|  |  |  |     const ratio = parseFloat(displayIndex) / parseFloat(totalSteps) * 100; | 
					
						
							|  |  |  |     return Ember.String.htmlSafe(`width: ${ratio}%`); | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   autoFocus() { | 
					
						
							|  |  |  |     Ember.run.scheduleOnce('afterRender', () => { | 
					
						
							|  |  |  |       const $invalid = $('.wizard-field.invalid:eq(0) input'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if ($invalid.length) { | 
					
						
							|  |  |  |         return $invalid.focus(); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       $('input:eq(0)').focus(); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-15 16:01:44 -04:00
										 |  |  |   animateInvalidFields() { | 
					
						
							|  |  |  |     Ember.run.scheduleOnce('afterRender', () => $('.invalid input[type=text]').wiggle(2, 100)); | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |   actions: { | 
					
						
							| 
									
										
										
										
											2016-09-14 16:36:08 -04:00
										 |  |  |     quit() { | 
					
						
							|  |  |  |       document.location = "/"; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |     backStep() { | 
					
						
							|  |  |  |       if (this.get('saving')) { return; } | 
					
						
							|  |  |  |       this.sendAction('goBack'); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     nextStep() { | 
					
						
							|  |  |  |       if (this.get('saving')) { return; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const step = this.get('step'); | 
					
						
							|  |  |  |       step.checkFields(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (step.get('valid')) { | 
					
						
							|  |  |  |         this.set('saving', true); | 
					
						
							|  |  |  |         step.save() | 
					
						
							| 
									
										
										
										
											2016-09-07 18:04:01 -04:00
										 |  |  |           .then(response => this.sendAction('goNext', response)) | 
					
						
							| 
									
										
										
										
											2016-09-15 16:01:44 -04:00
										 |  |  |           .catch(() => this.animateInvalidFields())  | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |           .finally(() => this.set('saving', false)); | 
					
						
							|  |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2016-09-15 16:01:44 -04:00
										 |  |  |         this.animateInvalidFields(); | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |         this.autoFocus(); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | }); |