{"version":3,"sources":["webpack:///./src/components/Forms/Form.vue?7753","webpack:///./src/components/Forms/Form.vue?35da","webpack:///./node_modules/client-website-ts-library/plugins/view/index.ts","webpack:///./src/components/Forms/Form.vue?5630","webpack:///./src/components/Forms/Form.vue","webpack:///./src/components/Forms/Form.vue?d965","webpack:///./src/components/Forms/Form.vue?4d45","webpack:///./src/views/ContactUs.vue?3a21","webpack:///./src/views/ContactUs.vue?54d3","webpack:///./src/views/ContactUs.vue","webpack:///./src/views/ContactUs.vue?e268","webpack:///./src/views/ContactUs.vue?8f5a"],"names":["prolistAnalyticsService","ServiceManager","Get","Analytics","headService","Require","Head","evt","obj","this","getAnalyticsEvent","call","getAnalyticsData","$route","path","name","undefined","triggerAnalyticsEvent","event","GetAll","forEach","adapter","Record","result","head","bind","Promise","then","meta","Update","UpdateWithStatic","View","requestAnimationFrame","updateHead","updateAnalytics","AsyncView","$on","render","_vm","_h","$createElement","_c","_self","staticClass","style","attrs","loading","on","loadAutosave","_v","_s","autosaveDate","_e","domProps","definition","Options","SubmittedText","_l","section","key","SectionId","ref","refInFor","errors","ctx","type","handleFieldInput","class","submitButtonClass","submitButtonColour","submitButtonBackgroundColour","submitForm","SubmitButtonText","staticRenderFns","context","errored","submitted","autosaveManager","FormAutosave","hasAutosave","submitPercent","recaptchaService","ReCaptcha","propertyAdressFormFieldValue","fieldBg","fieldColour","borderColour","labelColour","labelFocusedBg","labelFocusedColour","underlineInactive","underlineActive","progress","total","Math","round","console","log","Items","ClientWebsiteId","Website","Id","Forms","GetForm","def","enableAutosave","state","GetState","catch","Sections","sectionComponent","$refs","setData","fieldDef","filter","err","Key","collectData","includeRecaptcha","data","normalisedData","normaliseData","SubmitForm","Valid","Submitted","$emit","Result","resetRecaptcha","ValidationState","Errors","finally","newValues","entry","Value","Array","length","push","i","resolve","reject","setTimeout","getRecaptchaResponse","recaptchaResponse","Log","Debug","Reset","GetResponse","default","components","Section","Loader","component","office","mapSettings","Offices","Settings","WebsiteId","Markers","Address","AddressLine1","AddressLine2","Title","FranchiseName","Map","Form"],"mappings":"2IAAA,W,oCCAA,W,ihBCcA,IAAM,EAAN,cAAuB,aAAvB,c,oBACY,KAAAA,wBAA0BC,EAAA,KAAeC,IAA6B,OAAYC,UAAW,2BAC7F,KAAAC,YAAcH,EAAA,KAAeI,QAAqB,OAAYC,MAEjE,kBACL,IAAIC,EAA6B,KAC7BC,EAAmC,KAED,qBAA3BC,KAAKC,kBACdH,EAAME,KAAKC,kBAAkBC,KAAKF,MACO,qBAA1BA,KAAKG,mBACpBJ,EAAMC,KAAKG,iBAAiBD,KAAKF,OAGvB,OAARF,IAAcA,EAAM,IAAIJ,EAAA,KAAkBM,KAAKI,OAAOC,KAAML,KAAKI,OAAOE,MAAQ,GAAIP,QAAOQ,IAE/FP,KAAKQ,sBAAsBV,GAGtB,sBAAsBW,GAC3BjB,EAAA,KAAekB,OAA0B,OAAYhB,WAAWiB,QAASC,IACvEA,EAAQC,OAAOJ,KAIZ,4BAA4BA,GACI,OAAjCT,KAAKT,yBAAkCS,KAAKT,wBAAwBsB,OAAOJ,GAGvE,aACR,GAAI,SAAUT,KAAM,CAClB,MAAMc,EAASd,KAAKe,KAAMC,KAAKhB,KAAhBA,GAEZc,aAAkBG,QACnBH,EAAOI,KAAMC,IACXnB,KAAKL,YAAYyB,OAAOD,KAG1BnB,KAAKL,YAAYyB,OAAON,QAG1Bd,KAAKL,YAAY0B,iBAAiBrB,KAAKI,OAAOC,QAzC9C,EAAQ,GADb,QACK,GA+CN,IAAMiB,EAAN,cAAmB,EACV,UACLC,sBAAsB,KACpBvB,KAAKwB,aACLxB,KAAKyB,sBAJLH,EAAI,GADT,QACKA,GAUN,IAAMI,EAAN,cAAwB,EACf,UACL1B,KAAK2B,IAAI,aAAc,KACrBJ,sBAAsB,KACpBvB,KAAKwB,aACLxB,KAAKyB,wBALPC,EAAS,GADd,QACKA,I,kCCvEN,I,EAAIE,EAAS,WAAa,IAAIC,EAAI7B,KAAS8B,EAAGD,EAAIE,eAAmBC,EAAGH,EAAII,MAAMD,IAAIF,EAAG,OAAOE,EAAG,OAAO,CAACE,YAAY,OAAOC,MAAON,EAAa,WAAG,CAACG,EAAG,SAAS,CAACI,MAAM,CAAC,QAAUP,EAAIQ,WAAYR,EAAe,YAAEG,EAAG,MAAM,CAACE,YAAY,qCAAqCI,GAAG,CAAC,MAAQT,EAAIU,eAAe,CAACP,EAAG,IAAI,CAACH,EAAIW,GAAG,+BAA+BX,EAAIY,GAAGZ,EAAIa,cAAc,2CAA2Cb,EAAIc,KAAMd,EAAc,WAAE,CAAEA,EAAa,UAAEG,EAAG,MAAM,CAACE,YAAY,oCAAoC,CAACF,EAAG,IAAI,CAACY,SAAS,CAAC,UAAYf,EAAIY,GAAGZ,EAAIgB,WAAWC,QAAQC,oBAAoB,CAAClB,EAAImB,GAAInB,EAAIgB,WAAmB,UAAE,SAASI,GAAS,OAAOjB,EAAG,UAAU,CAACkB,IAAID,EAAQE,UAAUC,IAAIH,EAAQE,UAAUE,UAAS,EAAKjB,MAAM,CAAC,IAAMa,EAAQ,OAASpB,EAAIyB,OAAO,eAAezB,EAAI0B,IAAI,YAAY1B,EAAI2B,MAAMlB,GAAG,CAAC,YAAcT,EAAI4B,uBAAuB5B,EAAW,QAAEG,EAAG,MAAM,CAACE,YAAY,oCAAoC,CAACF,EAAG,IAAI,CAACH,EAAIW,GAAG,qDAAqDX,EAAIc,KAAKX,EAAG,MAAM,CAACE,YAAY,eAAe,CAACF,EAAG,SAAS,CAACE,YAAY,mBAAmBwB,MAAM7B,EAAI8B,kBAAkBvB,MAAM,CAAC,QAAUP,EAAIQ,QAAQ,OAASR,EAAI+B,mBAAmB,oBAAoB/B,EAAIgC,8BAA8BvB,GAAG,CAAC,MAAQT,EAAIiC,aAAa,CAACjC,EAAIW,GAAGX,EAAIY,GAAGZ,EAAIgB,WAAWC,QAAQiB,sBAAsB,KAAKlC,EAAIc,MAAM,IACxzCqB,EAAkB,G,4DC0EtB,IAAqB,EAAI,EAAzB,cAAkC,OAAlC,c,oBAiDU,KAAAT,IAAevD,KAAKiE,QAEpB,KAAAC,SAAU,EAEV,KAAAC,WAAY,EAEZ,KAAAb,OAA0C,GAE1C,KAAAjB,SAAU,EAEV,KAAAQ,WAAoC,KAEpC,KAAAuB,gBAAmC,OAAexE,QAAyB,OAAYyE,cAEvF,KAAAC,aAAc,EAEd,KAAA5B,aAA8B,KAE9B,KAAA6B,cAAgB,EAEhB,KAAAC,iBAAmB,OAAe5E,QAAQ,OAAY6E,WAEtD,KAAAC,6BAA8C,KAEtD,gBACE,MAAO,CACL,aAAc1E,KAAK2E,QACnB,iBAAkB3E,KAAK4E,YACvB,kBAAmB5E,KAAK6E,aACxB,iBAAkB7E,KAAK8E,YACvB,qBAAsB9E,KAAK+E,eAC3B,yBAA0B/E,KAAKgF,mBAC/B,uBAAwBhF,KAAKiF,kBAC7B,qBAAsBjF,KAAKkF,iBAI/B,WAAWC,EAAkBC,GAC3BpF,KAAKuE,cAAgBc,KAAKC,MAAOH,EAAWC,EAAS,KAErDG,QAAQC,IAAIxF,KAAKuE,eAGnB,UACmB,OAAbvE,KAAKuD,MACPvD,KAAKuD,IAAM,CACTkC,MAAO,GACPC,gBAAiB,OAAOC,QAAQC,UAIHrF,IAA7BP,KAAKuD,IAAImC,kBACX1F,KAAKuD,IAAImC,gBAAkB,OAAOC,QAAQC,IAG5C,OAAIC,MAAMC,QAAQ9F,KAAKwD,KAAMxD,KAAKiE,SAAS/C,KAAM6E,IAI/C,GAHA/F,KAAKqC,SAAU,EACfrC,KAAK6C,WAAakD,EAEd/F,KAAKgG,eAAgB,CACvB,MAAMC,EAAQjG,KAAKoE,gBAAgB8B,SAASlG,KAAKwD,MAEnC,OAAVyC,IACFjG,KAAKsE,aAAc,MAGtB6B,MAAM,KACPnG,KAAKkE,SAAU,IAInB,eACE,IAAKlE,KAAKsE,YAAa,OAEvB,MAAM2B,EAAQjG,KAAKoE,gBAAgB8B,SAASlG,KAAKwD,MAEnC,OAAVyC,GAEJjG,KAAK6C,WAAYuD,SAASzF,QAASsC,IACjC,MAAMoD,EAAoBrG,KAAKsG,MAAMrD,EAAQE,WAAqB,GAElEkD,EAAiBE,QAAQN,KAIrB,iBAAiBO,GACvBxG,KAAKsD,OAAStD,KAAKsD,OAAOmD,OAAQC,GAAQA,EAAIC,MAAQH,EAASG,KAGjE,aACM3G,KAAKqC,UAETrC,KAAKqC,SAAU,EAEfrC,KAAKsD,OAAS,GAEdtD,KAAK4G,YAAY5G,KAAK6G,kBAAkB3F,KAAM4F,IAC5C,MAAMC,EAAiB,EAAKC,cAAcF,GAE1CvB,QAAQC,IAAIuB,GAEZ/G,KAAKqC,SAAU,EAMf,OAAIwD,MAAMoB,WAAWjH,KAAKwD,KAAMxD,KAAKiE,QAAS8C,GAAgB7F,KAAMJ,IAClEd,KAAKqC,SAAU,EAEVvB,EAAOoG,MAODpG,EAAOqG,YAEhBnH,KAAKmE,WAAY,EAIjBnE,KAAKoH,MAAM,YAAatG,EAAOuG,UAX/BrH,KAAKsH,iBAGLtH,KAAKsD,OAASxC,EAAOyG,gBAAgBC,OACrCxH,KAAKkE,SAAU,KAShBiC,MAAM,KAEPnG,KAAKsH,iBAGLtH,KAAKkE,SAAU,IACduD,QAAQ,KACTzH,KAAKqC,SAAU,OAKb,qBAAqByE,GAC3B,MAAMY,EAAyB,GAsB/B,OApBAZ,EAAKnG,QAASgH,IACZ,GAAIA,EAAMC,iBAAiBC,OACzB,GAAIF,EAAMC,MAAME,OAAQ,CACtBJ,EAAUK,KAAK,CACbpB,IAAQgB,EAAMhB,IAAT,UACLiB,MAAOD,EAAMC,MAAME,SAGrB,IAAK,IAAIE,EAAI,EAAGA,EAAIL,EAAMC,MAAME,OAAQE,GAAK,EAC3CN,EAAUK,KAAK,CACbpB,IAAK,GAAGgB,EAAMhB,OAAOqB,IACrBJ,MAAOD,EAAMC,MAAMI,WAKzBN,EAAUK,KAAKJ,KAIZD,EAGD,YAAYb,GAClB,OAAO,IAAI5F,QAAQ,CAACgH,EAASC,KAC3B,MAAMpB,EAAoB,GAU1B,GAPA9G,KAAK6C,WAAYuD,SAASzF,QAASsC,IACjC,MAAMoD,EAAoBrG,KAAKsG,MAAMrD,EAAQE,WAAqB,GAElE2D,EAAKiB,QAAQ1B,EAAiBO,iBAI5BC,EAgBF,OAfAsB,WAAW,KACTnI,KAAKqC,SAAU,GACd,UAEHrC,KAAKoI,uBAAuBlH,KAAMmH,IAChC,OAAOC,IAAI,OAASC,MAAO,SAAU,0BAErCzB,EAAKiB,KAAK,CACRpB,IAAK,aACLiB,MAAOS,IAGTJ,EAAQnB,KACPX,MAAM+B,GAMXD,EAAQnB,KAIJ,iBACN9G,KAAKwE,iBAAiBgE,QAGhB,uBACN,OAAOxI,KAAKwE,iBAAiBiE,gBA3P/B,yBADC,eAAK,CAAEC,QAAS,KAAM,CAAGjD,MAAO,Q,8BAIjC,yBADC,kB,2BAID,yBADC,kB,yCAID,yBADC,kB,mDAID,yBADC,kB,wCAID,yBADC,kB,wCAID,yBADC,kB,qCAID,yBADC,eAAK,CAAEiD,QAAS,0B,8BAIjB,yBADC,eAAK,CAAEA,QAAS,8B,kCAIjB,yBADC,eAAK,CAAEA,QAAS,8B,kCAIjB,yBADC,eAAK,CAAEA,QAAS,qC,mCAIjB,yBADC,eAAK,CAAEA,QAAS,kC,qCAIjB,yBADC,eAAK,CAAEA,QAAS,sC,yCAIjB,yBADC,eAAK,CAAEA,QAAS,U,wCAIjB,yBADC,eAAK,CAAEA,QAAS,0B,sCAIjB,yBADC,eAAK,CAAEA,SAAS,K,uCA9CE,EAAI,2BANxB,eAAU,CACTC,WAAY,CACVC,UAAA,KACAC,SAAA,SAGiB,WC3E4X,I,kCCS7YC,EAAY,eACd,EACAlH,EACAoC,GACA,EACA,KACA,WACA,MAIa,OAAA8E,E,kECpBf,W,yCCAA,IAAIlH,EAAS,WAAa,IAAIC,EAAI7B,KAAS8B,EAAGD,EAAIE,eAAmBC,EAAGH,EAAII,MAAMD,IAAIF,EAAG,OAAOE,EAAG,OAAO,CAACA,EAAG,eAAe,CAACI,MAAM,CAAC,MAAO,EAAK,MAAQ,oHAAoHJ,EAAG,aAAa,CAACA,EAAG,mBAAmB,CAACE,YAAY,6BAA6B,CAACF,EAAG,OAAO,CAACI,MAAM,CAAC,KAAO,iCAAiC,IAAI,IAAI,IAC7Z4B,EAAkB,G,4ZCyBtB,IAAqB,EAArB,cAAuC,eAAO,SAA9C,c,oBACU,KAAA+E,OAAwB,KAExB,KAAAC,YAAkC,KAE1C,UACE,OAAIC,QAAQxJ,IAAI,OAAOkG,QAAQuD,SAAUC,WAAWjI,KAAM6H,IACxD/I,KAAK+I,OAASA,EAEd/I,KAAKgJ,YAAc,IAAI,OAAY,CACjCI,QAAS,CACP,IAAI,OAAU,CACZC,QAAS,GAAGrJ,KAAK+I,OAAOO,gBAAgBtJ,KAAK+I,OAAOQ,eACpDC,MAAOxJ,KAAK+I,OAAOU,uBAbV,EAAS,GAN7B,eAAU,CACTd,WAAY,CACVe,IAAA,OACAC,OAAA,SAGiB,WC1B+W,I,wBCQhYb,EAAY,eACd,EACAlH,EACAoC,GACA,EACA,KACA,WACA,MAIa,aAAA8E,E","file":"js/chunk-332cbb60.6ef99865.js","sourcesContent":["export * from \"-!../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--6-oneOf-1-0!../../../node_modules/css-loader/dist/cjs.js??ref--6-oneOf-1-1!../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../node_modules/postcss-loader/src/index.js??ref--6-oneOf-1-2!../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Form.vue?vue&type=style&index=0&id=69add52b&scoped=true&lang=css&\"","export * from \"-!../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--6-oneOf-1-0!../../../node_modules/css-loader/dist/cjs.js??ref--6-oneOf-1-1!../../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../../node_modules/postcss-loader/src/index.js??ref--6-oneOf-1-2!../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Form.vue?vue&type=style&index=1&lang=css&\"","import Vue from \"vue\";\r\nimport { Component } from \"vue-property-decorator\";\r\nimport { AnalyticsEvent, AnalyticsEventObject, AnalyticsPageView, IAnalyticsAdapter, PROListAnalyticsAdapter } from \"../../services/Analytics\";\r\nimport { HeadService } from \"../../services/HeadService\";\r\nimport { ServiceManager, ServiceType } from \"../../services/ServiceManager\";\r\nimport { RouteMeta } from \"../meta\";\r\n\r\ninterface ViewBase {\r\n getAnalyticsEvent?(): AnalyticsEvent | null;\r\n getAnalyticsData?(): AnalyticsEventObject | null;\r\n head?(): RouteMeta | Promise | null;\r\n}\r\n\r\n@Component\r\nclass ViewBase extends Vue {\r\n protected prolistAnalyticsService = ServiceManager.Get(ServiceType.Analytics, 'PROListAnalyticsAdapter');\r\n protected headService = ServiceManager.Require(ServiceType.Head)!;\r\n\r\n public updateAnalytics() {\r\n let evt: AnalyticsEvent | null = null;\r\n let obj: AnalyticsEventObject | null = null;\r\n\r\n if (typeof this.getAnalyticsEvent !== 'undefined') {\r\n evt = this.getAnalyticsEvent.call(this);\r\n } else if(typeof this.getAnalyticsData !== 'undefined') {\r\n obj = this.getAnalyticsData.call(this);\r\n }\r\n\r\n if (evt === null) evt = new AnalyticsPageView(this.$route.path, this.$route.name || '', obj || undefined);\r\n\r\n this.triggerAnalyticsEvent(evt);\r\n }\r\n\r\n public triggerAnalyticsEvent(event: AnalyticsEvent) {\r\n ServiceManager.GetAll(ServiceType.Analytics).forEach((adapter) => {\r\n adapter.Record(event);\r\n });\r\n }\r\n\r\n public triggerCustomAnalyticsEvent(event: AnalyticsEvent) {\r\n if (this.prolistAnalyticsService !== null) this.prolistAnalyticsService.Record(event);\r\n }\r\n\r\n protected updateHead() {\r\n if ('head' in this) {\r\n const result = this.head!.bind(this)();\r\n\r\n if(result instanceof Promise) {\r\n result.then((meta: RouteMeta | null) => {\r\n this.headService.Update(meta);\r\n });\r\n } else {\r\n this.headService.Update(result as RouteMeta | null);\r\n }\r\n } else {\r\n this.headService.UpdateWithStatic(this.$route.path);\r\n }\r\n }\r\n}\r\n\r\n@Component\r\nclass View extends ViewBase {\r\n public mounted() {\r\n requestAnimationFrame(() => {\r\n this.updateHead();\r\n this.updateAnalytics();\r\n });\r\n }\r\n}\r\n\r\n@Component\r\nclass AsyncView extends ViewBase {\r\n public mounted() {\r\n this.$on('updateView', () => {\r\n requestAnimationFrame(() => {\r\n this.updateHead();\r\n this.updateAnalytics();\r\n });\r\n });\r\n }\r\n}\r\n\r\nexport {\r\n View,\r\n AsyncView\r\n}\r\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('form',{staticClass:\"form\",style:(_vm.formStyle)},[_c('Loader',{attrs:{\"loading\":_vm.loading}}),(_vm.hasAutosave)?_c('div',{staticClass:\"form__panel form__panel--autosaved\",on:{\"click\":_vm.loadAutosave}},[_c('p',[_vm._v(\" This form was autosaved at \"+_vm._s(_vm.autosaveDate)+\". Click here to load the autosave. \")])]):_vm._e(),(_vm.definition)?[(_vm.submitted)?_c('div',{staticClass:\"form__panel form__panel--success\"},[_c('p',{domProps:{\"innerHTML\":_vm._s(_vm.definition.Options.SubmittedText)}})]):[_vm._l((_vm.definition.Sections),function(section){return _c('Section',{key:section.SectionId,ref:section.SectionId,refInFor:true,attrs:{\"def\":section,\"errors\":_vm.errors,\"form-context\":_vm.ctx,\"form-type\":_vm.type},on:{\"field_input\":_vm.handleFieldInput}})}),(_vm.errored)?_c('div',{staticClass:\"form__panel form__panel--errored\"},[_c('p',[_vm._v(\" Please fill out all red highlighted fields. \")])]):_vm._e(),_c('div',{staticClass:\"center-text\"},[_c('Button',{staticClass:\"form__submit-btn\",class:_vm.submitButtonClass,attrs:{\"loading\":_vm.loading,\"colour\":_vm.submitButtonColour,\"background-colour\":_vm.submitButtonBackgroundColour},on:{\"click\":_vm.submitForm}},[_vm._v(_vm._s(_vm.definition.Options.SubmitButtonText))])],1)]]:_vm._e()],2)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\r\nimport { Component, Vue, Prop } from 'vue-property-decorator';\r\nimport { FormDefinition, FormSubmissionValidationError, FormField, FormValue } from 'client-website-ts-library/types/Forms';\r\nimport {\r\n AutosaveManager,\r\n ServiceManager,\r\n ServiceType,\r\n API,\r\n Config,\r\n Logger,\r\n LogLevel,\r\n ReCaptchaService,\r\n} from 'client-website-ts-library/services';\r\nimport { Context } from 'client-website-ts-library/types';\r\nimport { PDFFieldData } from 'client-website-ts-library/types/Forms/FieldTypes';\r\nimport { IRequestProgressDelegate } from 'client-website-ts-library/services/API/IRequestProgressDelegate';\r\n\r\nimport Section from './Section.vue';\r\nimport Loader from '../UI/Loader.vue';\r\n\r\n@Component({\r\n components: {\r\n Section,\r\n Loader,\r\n },\r\n})\r\nexport default class Form extends Vue implements IRequestProgressDelegate {\r\n @Prop({ default: () => ({ Items: [] }) })\r\n private readonly context!: Context;\r\n\r\n @Prop()\r\n private readonly type!: string;\r\n\r\n @Prop()\r\n private readonly submitButtonColour!: string;\r\n\r\n @Prop()\r\n private readonly submitButtonBackgroundColour!: string;\r\n\r\n @Prop()\r\n private readonly submitButtonClass!: string;\r\n\r\n @Prop()\r\n private readonly autosaveNamespace!: string;\r\n\r\n @Prop()\r\n private readonly enableAutosave!: boolean;\r\n\r\n @Prop({ default: 'var(--form-field-bg)' })\r\n private readonly fieldBg!: string;\r\n\r\n @Prop({ default: 'var(--form-field-colour)' })\r\n private readonly fieldColour!: string;\r\n\r\n @Prop({ default: 'var(--form-label-colour)' })\r\n private readonly labelColour!: string;\r\n\r\n @Prop({ default: 'var(--form-field-border-colour)' })\r\n private readonly borderColour!: string;\r\n\r\n @Prop({ default: 'var(--form-label-focused-bg)' })\r\n private readonly labelFocusedBg!: string;\r\n\r\n @Prop({ default: 'var(--form-label-focused-colour)' })\r\n private readonly labelFocusedColour!: string;\r\n\r\n @Prop({ default: '#eee' })\r\n private readonly underlineInactive!: string;\r\n\r\n @Prop({ default: 'var(--brand-primary)' })\r\n private readonly underlineActive!: string;\r\n\r\n @Prop({ default: true })\r\n private readonly includeRecaptcha!: boolean;\r\n\r\n private ctx: Context = this.context;\r\n\r\n private errored = false;\r\n\r\n private submitted = false;\r\n\r\n private errors: FormSubmissionValidationError[] = [];\r\n\r\n private loading = true;\r\n\r\n private definition: FormDefinition | null = null;\r\n\r\n private autosaveManager: AutosaveManager = ServiceManager.Require(ServiceType.FormAutosave);\r\n\r\n private hasAutosave = false;\r\n\r\n private autosaveDate: string | null = null;\r\n\r\n private submitPercent = 0;\r\n\r\n private recaptchaService = ServiceManager.Require(ServiceType.ReCaptcha) as ReCaptchaService;\r\n\r\n private propertyAdressFormFieldValue: string | null = null;\r\n\r\n get formStyle() {\r\n return {\r\n '--field-bg': this.fieldBg,\r\n '--field-colour': this.fieldColour,\r\n '--border-colour': this.borderColour,\r\n '--label-colour': this.labelColour,\r\n '--label-focused-bg': this.labelFocusedBg,\r\n '--label-focused-colour': this.labelFocusedColour,\r\n '--underline-inactive': this.underlineInactive,\r\n '--underline-active': this.underlineActive,\r\n };\r\n }\r\n\r\n onProgress(progress: number, total: number) {\r\n this.submitPercent = Math.round((progress / total) * 100);\r\n\r\n console.log(this.submitPercent);\r\n }\r\n\r\n mounted() {\r\n if (this.ctx === null) {\r\n this.ctx = {\r\n Items: [],\r\n ClientWebsiteId: Config.Website.Id,\r\n };\r\n }\r\n\r\n if (this.ctx.ClientWebsiteId === undefined) {\r\n this.ctx.ClientWebsiteId = Config.Website.Id;\r\n }\r\n\r\n API.Forms.GetForm(this.type, this.context).then((def) => {\r\n this.loading = false;\r\n this.definition = def;\r\n\r\n if (this.enableAutosave) {\r\n const state = this.autosaveManager.GetState(this.type);\r\n\r\n if (state !== null) {\r\n this.hasAutosave = true;\r\n }\r\n }\r\n }).catch(() => {\r\n this.errored = true;\r\n });\r\n }\r\n\r\n loadAutosave(): void {\r\n if (!this.hasAutosave) return;\r\n\r\n const state = this.autosaveManager.GetState(this.type);\r\n\r\n if (state === null) return;\r\n\r\n this.definition!.Sections.forEach((section) => {\r\n const sectionComponent = (this.$refs[section.SectionId] as Vue[])[0] as Section;\r\n\r\n sectionComponent.setData(state);\r\n });\r\n }\r\n\r\n private handleFieldInput(fieldDef: FormField): void {\r\n this.errors = this.errors.filter((err) => err.Key !== fieldDef.Key);\r\n }\r\n\r\n submitForm(): void {\r\n if (this.loading) return;\r\n\r\n this.loading = true;\r\n\r\n this.errors = [];\r\n\r\n this.collectData(this.includeRecaptcha).then((data) => {\r\n const normalisedData = Form.normaliseData(data);\r\n\r\n console.log(normalisedData);\r\n\r\n this.loading = false;\r\n\r\n // this.context.ClientWebsiteId = Config.Website.Id;\r\n\r\n // if (this.enableAutosave) this.autosaveManager.SetState(this.type, data);\r\n\r\n API.Forms.SubmitForm(this.type, this.context, normalisedData).then((result) => {\r\n this.loading = false;\r\n\r\n if (!result.Valid) {\r\n // Reset ReCaptcha\r\n this.resetRecaptcha();\r\n\r\n // Update errors\r\n this.errors = result.ValidationState.Errors;\r\n this.errored = true;\r\n } else if (result.Submitted) {\r\n // Inform the user that the form was submitted\r\n this.submitted = true;\r\n\r\n // this.$router.push({ path: '/thank-you' });\r\n\r\n this.$emit('submitted', result.Result);\r\n }\r\n }).catch(() => {\r\n // Reset ReCaptcha\r\n this.resetRecaptcha();\r\n\r\n // Inform the user that there was an error\r\n this.errored = true;\r\n }).finally(() => {\r\n this.loading = false;\r\n });\r\n });\r\n }\r\n\r\n private static normaliseData(data: FormValue[]): FormValue[] {\r\n const newValues: FormValue[] = [];\r\n\r\n data.forEach((entry) => {\r\n if (entry.Value instanceof Array) {\r\n if (entry.Value.length) {\r\n newValues.push({\r\n Key: `${entry.Key}_length`,\r\n Value: entry.Value.length,\r\n });\r\n\r\n for (let i = 0; i < entry.Value.length; i += 1) {\r\n newValues.push({\r\n Key: `${entry.Key}_${i}`,\r\n Value: entry.Value[i],\r\n });\r\n }\r\n }\r\n } else {\r\n newValues.push(entry);\r\n }\r\n });\r\n\r\n return newValues;\r\n }\r\n\r\n private collectData(includeRecaptcha: boolean): Promise {\r\n return new Promise((resolve, reject) => {\r\n const data: FormValue[] = [];\r\n\r\n // Loop through each form secction and collect the data from it\r\n this.definition!.Sections.forEach((section) => {\r\n const sectionComponent = (this.$refs[section.SectionId] as Vue[])[0] as Section;\r\n\r\n data.push(...sectionComponent.collectData());\r\n });\r\n\r\n // If we also need to submit the ReCaptcha response, make sure we call getResponse on the ReCaptcha component\r\n if (includeRecaptcha) {\r\n setTimeout(() => {\r\n this.loading = false;\r\n }, 1000);\r\n\r\n this.getRecaptchaResponse().then((recaptchaResponse: string) => {\r\n Logger.Log(LogLevel.Debug, '[Form]', 'Got ReCaptcha response');\r\n\r\n data.push({\r\n Key: '_recaptcha',\r\n Value: recaptchaResponse,\r\n });\r\n\r\n resolve(data);\r\n }).catch(reject);\r\n\r\n return;\r\n }\r\n\r\n // If we don't need ReCaptcha, resolve straight away\r\n resolve(data);\r\n });\r\n }\r\n\r\n private resetRecaptcha(): void {\r\n this.recaptchaService.Reset();\r\n }\r\n\r\n private getRecaptchaResponse(): Promise {\r\n return this.recaptchaService.GetResponse();\r\n }\r\n}\r\n","import mod from \"-!../../../node_modules/cache-loader/dist/cjs.js??ref--14-0!../../../node_modules/thread-loader/dist/cjs.js!../../../node_modules/babel-loader/lib/index.js!../../../node_modules/ts-loader/index.js??ref--14-3!../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Form.vue?vue&type=script&lang=ts&\"; export default mod; export * from \"-!../../../node_modules/cache-loader/dist/cjs.js??ref--14-0!../../../node_modules/thread-loader/dist/cjs.js!../../../node_modules/babel-loader/lib/index.js!../../../node_modules/ts-loader/index.js??ref--14-3!../../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Form.vue?vue&type=script&lang=ts&\"","import { render, staticRenderFns } from \"./Form.vue?vue&type=template&id=69add52b&scoped=true&\"\nimport script from \"./Form.vue?vue&type=script&lang=ts&\"\nexport * from \"./Form.vue?vue&type=script&lang=ts&\"\nimport style0 from \"./Form.vue?vue&type=style&index=0&id=69add52b&scoped=true&lang=css&\"\nimport style1 from \"./Form.vue?vue&type=style&index=1&lang=css&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"69add52b\",\n null\n \n)\n\nexport default component.exports","export * from \"-!../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--6-oneOf-1-0!../../node_modules/css-loader/dist/cjs.js??ref--6-oneOf-1-1!../../node_modules/vue-loader/lib/loaders/stylePostLoader.js!../../node_modules/postcss-loader/src/index.js??ref--6-oneOf-1-2!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ContactUs.vue?vue&type=style&index=0&id=58b4d076&scoped=true&lang=css&\"","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('Page',[_c('SiteMasthead',{attrs:{\"mini\":true,\"title\":\"To subscribe for updates and to get you started on your
\\nproperty journey, we welcome you to contact us.\"}}),_c('ContentRow',[_c('ContentContainer',{staticClass:\"content-container--narrow\"},[_c('Form',{attrs:{\"type\":\"Generic.WebsiteContactForm\"}})],1)],1)],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\n\n\n\n\n\n\n\n\n\n\n\n\r\nimport { Component, Mixins } from 'vue-property-decorator';\r\nimport { Office, MapSettings, MapMarker } from 'client-website-ts-library/types';\r\nimport { API, Config } from 'client-website-ts-library/services';\r\nimport { Map } from 'client-website-ts-library/components';\r\nimport { View } from 'client-website-ts-library/plugins';\r\nimport Form from '@/components/Forms/Form.vue';\r\n\r\n@Component({\r\n components: {\r\n Map,\r\n Form,\r\n },\r\n})\r\nexport default class ContactUs extends Mixins(View) {\r\n private office: Office | null = null;\r\n\r\n private mapSettings: MapSettings | null = null;\r\n\r\n mounted() {\r\n API.Offices.Get(Config.Website.Settings!.WebsiteId).then((office) => {\r\n this.office = office;\r\n\r\n this.mapSettings = new MapSettings({\r\n Markers: [\r\n new MapMarker({\r\n Address: `${this.office.AddressLine1} ${this.office.AddressLine2}`,\r\n Title: this.office.FranchiseName,\r\n }),\r\n ],\r\n });\r\n });\r\n }\r\n}\r\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--14-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/ts-loader/index.js??ref--14-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ContactUs.vue?vue&type=script&lang=ts&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--14-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/ts-loader/index.js??ref--14-3!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ContactUs.vue?vue&type=script&lang=ts&\"","import { render, staticRenderFns } from \"./ContactUs.vue?vue&type=template&id=58b4d076&scoped=true&\"\nimport script from \"./ContactUs.vue?vue&type=script&lang=ts&\"\nexport * from \"./ContactUs.vue?vue&type=script&lang=ts&\"\nimport style0 from \"./ContactUs.vue?vue&type=style&index=0&id=58b4d076&scoped=true&lang=css&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n \"58b4d076\",\n null\n \n)\n\nexport default component.exports"],"sourceRoot":""}