| 
									
										
										
										
											2020-04-16 07:58:04 +02:00
										 |  |  | import discourseComputed, { observes } from "discourse-common/utils/decorators"; | 
					
						
							| 
									
										
										
										
											2019-10-23 12:30:52 -04:00
										 |  |  | import Component from "@ember/component"; | 
					
						
							| 
									
										
										
										
											2020-05-13 16:23:41 -04:00
										 |  |  | import I18n from "I18n"; | 
					
						
							| 
									
										
										
										
											2016-09-22 14:39:36 -04:00
										 |  |  | import getUrl from "discourse-common/lib/get-url"; | 
					
						
							| 
									
										
										
										
											2019-11-05 12:43:49 -06:00
										 |  |  | import { htmlSafe } from "@ember/template"; | 
					
						
							|  |  |  | import { schedule } from "@ember/runloop"; | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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-09-20 12:28:22 -04:00
										 |  |  | const alreadyWarned = {}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-23 12:30:52 -04:00
										 |  |  | export default Component.extend({ | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |   classNames: ["wizard-step"], | 
					
						
							|  |  |  |   saving: null, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   didInsertElement() { | 
					
						
							| 
									
										
										
										
											2019-01-19 10:05:51 +01:00
										 |  |  |     this._super(...arguments); | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |     this.autoFocus(); | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 15:38:28 -06:00
										 |  |  |   @discourseComputed("step.index") | 
					
						
							| 
									
										
										
										
											2018-07-30 11:56:48 -04:00
										 |  |  |   showQuitButton: (index) => index === 0, | 
					
						
							| 
									
										
										
										
											2016-09-14 16:36:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 15:38:28 -06:00
										 |  |  |   @discourseComputed("step.displayIndex", "wizard.totalSteps") | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |   showNextButton: (current, total) => current < total, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 15:38:28 -06:00
										 |  |  |   @discourseComputed("step.displayIndex", "wizard.totalSteps") | 
					
						
							| 
									
										
										
										
											2016-08-31 13:35:49 -04:00
										 |  |  |   showDoneButton: (current, total) => current === total, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 15:38:28 -06:00
										 |  |  |   @discourseComputed( | 
					
						
							| 
									
										
										
										
											2018-11-15 20:44:19 +01:00
										 |  |  |     "step.index", | 
					
						
							|  |  |  |     "step.displayIndex", | 
					
						
							|  |  |  |     "wizard.totalSteps", | 
					
						
							|  |  |  |     "wizard.completed" | 
					
						
							|  |  |  |   ) | 
					
						
							|  |  |  |   showFinishButton: (index, displayIndex, total, completed) => { | 
					
						
							|  |  |  |     return index !== 0 && displayIndex !== total && completed; | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 15:38:28 -06:00
										 |  |  |   @discourseComputed("step.index") | 
					
						
							| 
									
										
										
										
											2018-07-30 11:56:48 -04:00
										 |  |  |   showBackButton: (index) => index > 0, | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 15:38:28 -06:00
										 |  |  |   @discourseComputed("step.banner") | 
					
						
							| 
									
										
										
										
											2016-09-20 13:25:56 -04:00
										 |  |  |   bannerImage(src) { | 
					
						
							|  |  |  |     if (!src) { | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-09-22 14:39:36 -04:00
										 |  |  |     return getUrl(`/images/wizard/${src}`); | 
					
						
							| 
									
										
										
										
											2016-09-20 13:25:56 -04:00
										 |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-01 08:36:50 -05:00
										 |  |  |   @discourseComputed("step.id") | 
					
						
							|  |  |  |   bannerAndDescriptionClass(id) { | 
					
						
							|  |  |  |     return `wizard-banner-and-description wizard-banner-and-description-${id}`; | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |   @observes("step.id") | 
					
						
							|  |  |  |   _stepChanged() { | 
					
						
							|  |  |  |     this.set("saving", false); | 
					
						
							|  |  |  |     this.autoFocus(); | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   keyPress(key) { | 
					
						
							|  |  |  |     if (key.keyCode === 13) { | 
					
						
							| 
									
										
										
										
											2019-05-27 10:15:39 +02:00
										 |  |  |       if (this.showDoneButton) { | 
					
						
							| 
									
										
										
										
											2016-09-22 13:38:40 -04:00
										 |  |  |         this.send("quit"); | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         this.send("nextStep"); | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-07 15:38:28 -06:00
										 |  |  |   @discourseComputed("step.index", "wizard.totalSteps") | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |   barStyle(displayIndex, totalSteps) { | 
					
						
							| 
									
										
										
										
											2016-09-20 14:04:18 -04:00
										 |  |  |     let ratio = parseFloat(displayIndex) / parseFloat(totalSteps - 1); | 
					
						
							|  |  |  |     if (ratio < 0) { | 
					
						
							|  |  |  |       ratio = 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (ratio > 1) { | 
					
						
							|  |  |  |       ratio = 1; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-05 12:43:49 -06:00
										 |  |  |     return htmlSafe(`width: ${ratio * 200}px`); | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   autoFocus() { | 
					
						
							| 
									
										
										
										
											2020-04-16 07:58:04 +02:00
										 |  |  |     schedule("afterRender", () => { | 
					
						
							| 
									
										
										
										
											2020-11-20 16:48:39 -05:00
										 |  |  |       const $invalid = $( | 
					
						
							|  |  |  |         ".wizard-field.invalid:nth-of-type(1) .wizard-focusable" | 
					
						
							|  |  |  |       ); | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |       if ($invalid.length) { | 
					
						
							|  |  |  |         return $invalid.focus(); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-20 16:48:39 -05:00
										 |  |  |       $(".wizard-focusable:nth-of-type(1)").focus(); | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |     }); | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-15 16:01:44 -04:00
										 |  |  |   animateInvalidFields() { | 
					
						
							| 
									
										
										
										
											2020-04-16 07:58:04 +02:00
										 |  |  |     schedule("afterRender", () => | 
					
						
							| 
									
										
										
										
											2016-09-20 17:01:54 -04:00
										 |  |  |       $(".invalid input[type=text], .invalid textarea").wiggle(2, 100) | 
					
						
							|  |  |  |     ); | 
					
						
							| 
									
										
										
										
											2016-09-15 16:01:44 -04:00
										 |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-20 12:28:22 -04:00
										 |  |  |   advance() { | 
					
						
							|  |  |  |     this.set("saving", true); | 
					
						
							| 
									
										
										
										
											2019-05-27 10:15:39 +02:00
										 |  |  |     this.step | 
					
						
							| 
									
										
										
										
											2016-09-20 12:28:22 -04:00
										 |  |  |       .save() | 
					
						
							| 
									
										
										
										
											2019-01-10 11:06:01 +01:00
										 |  |  |       .then((response) => this.goNext(response)) | 
					
						
							| 
									
										
										
										
											2016-09-20 12:28:22 -04:00
										 |  |  |       .catch(() => this.animateInvalidFields()) | 
					
						
							|  |  |  |       .finally(() => this.set("saving", false)); | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |   actions: { | 
					
						
							| 
									
										
										
										
											2016-09-14 16:36:08 -04:00
										 |  |  |     quit() { | 
					
						
							| 
									
										
										
										
											2016-09-22 14:39:36 -04:00
										 |  |  |       document.location = getUrl("/"); | 
					
						
							| 
									
										
										
										
											2016-09-14 16:36:08 -04:00
										 |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-15 20:44:19 +01:00
										 |  |  |     exitEarly() { | 
					
						
							| 
									
										
										
										
											2019-05-27 10:15:39 +02:00
										 |  |  |       const step = this.step; | 
					
						
							| 
									
										
										
										
											2018-11-15 20:44:19 +01:00
										 |  |  |       step.validate(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (step.get("valid")) { | 
					
						
							|  |  |  |         this.set("saving", true); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         step | 
					
						
							|  |  |  |           .save() | 
					
						
							|  |  |  |           .then(() => this.send("quit")) | 
					
						
							|  |  |  |           .catch(() => this.animateInvalidFields()) | 
					
						
							|  |  |  |           .finally(() => this.set("saving", false)); | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         this.animateInvalidFields(); | 
					
						
							|  |  |  |         this.autoFocus(); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |     backStep() { | 
					
						
							| 
									
										
										
										
											2019-05-27 10:15:39 +02:00
										 |  |  |       if (this.saving) { | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |         return; | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-01-10 11:06:01 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |       this.goBack(); | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     nextStep() { | 
					
						
							| 
									
										
										
										
											2019-05-27 10:15:39 +02:00
										 |  |  |       if (this.saving) { | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |         return; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-27 10:15:39 +02:00
										 |  |  |       const step = this.step; | 
					
						
							| 
									
										
										
										
											2016-09-20 12:28:22 -04:00
										 |  |  |       const result = step.validate(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (result.warnings.length) { | 
					
						
							|  |  |  |         const unwarned = result.warnings.filter((w) => !alreadyWarned[w]); | 
					
						
							|  |  |  |         if (unwarned.length) { | 
					
						
							|  |  |  |           unwarned.forEach((w) => (alreadyWarned[w] = true)); | 
					
						
							| 
									
										
										
										
											2020-11-10 11:31:54 -05:00
										 |  |  |           return window.bootbox.confirm( | 
					
						
							|  |  |  |             unwarned.map((w) => I18n.t(`wizard.${w}`)).join("\n"), | 
					
						
							|  |  |  |             I18n.t("no_value"), | 
					
						
							|  |  |  |             I18n.t("yes_value"), | 
					
						
							| 
									
										
										
										
											2016-09-20 12:28:22 -04:00
										 |  |  |             (confirmed) => { | 
					
						
							|  |  |  |               if (confirmed) { | 
					
						
							|  |  |  |                 this.advance(); | 
					
						
							| 
									
										
										
										
											2018-06-15 17:03:24 +02:00
										 |  |  |               } | 
					
						
							| 
									
										
										
										
											2016-09-20 12:28:22 -04:00
										 |  |  |             } | 
					
						
							|  |  |  |           ); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |       if (step.get("valid")) { | 
					
						
							| 
									
										
										
										
											2016-09-20 12:28:22 -04:00
										 |  |  |         this.advance(); | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2016-09-15 16:01:44 -04:00
										 |  |  |         this.animateInvalidFields(); | 
					
						
							| 
									
										
										
										
											2016-08-25 13:14:56 -04:00
										 |  |  |         this.autoFocus(); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | }); |