import { Component, Injector, ViewChild, ViewEncapsulation } from '@angular/core'; import { ActivatedRoute, Router } from '@angular/router'; import { appModuleAnimation } from '@shared/animations/routerTransition'; import { AppComponentBase } from '@shared/common/app-component-base'; import { CreateOrUpdateContactUserInput,VendorsServiceProxy, LocationServiceProxy, CreateLocationContactInput, CreateContactInput, CreateAddressInput, PostalCodeServiceProxy, CreateContactAddressInput,PasswordComplexitySetting,UserRoleDto, CreateContactUserAddressInput, UpdateContactInput, ContactServiceProxy, UpdateAddressInput, UserEditDto, AddressTypeServiceProxy} from '@shared/service-proxies/service-proxies'; import { LazyLoadEvent } from 'primeng/components/common/lazyloadevent'; import { finalize } from 'rxjs/operators'; import * as moment from 'moment'; import * as _ from 'lodash'; import {Location} from '@angular/common'; import { AddressFormComponent } from '@app/shared/layout/form/address-form.component'; import { ContactFormComponent } from '@app/shared/layout/form/contact.form.component'; declare var KTWizard: any; declare var $: any; declare var KTApp: any; declare let swal: any; @Component({ templateUrl: './create-vendor.component.html', encapsulation: ViewEncapsulation.None, animations: [appModuleAnimation()] }) export class CreateVendorComponent extends AppComponentBase { @ViewChild(AddressFormComponent, { static: false }) addressForm; @ViewChild(ContactFormComponent, { static: false }) contactForm; active = false; saving = false; id: any; vendor: UserEditDto = new UserEditDto(); contact: CreateContactUserAddressInput = new CreateContactUserAddressInput(); address: CreateAddressInput = new CreateAddressInput(); defaultAddressType: any; defaultCountry: any; defaultStates: any; defaultPostal: any; defaultCity: any; selectedAddressType: any; selectedCountry: any; selectedPostalCode: any; selectedState: any; selectedCity: any; country: any; filteredCountries: any; city: any; filteredCities: any; state: any; filteredStates: any; postal: any; filteredPostal: any; addressType: any; filteredAddressType: any; canChangeUserName = true; isActive = true; isTwoFactorEnabled: boolean = false //this.setting.getBoolean('Abp.Zero.UserManagement.TwoFactorLogin.IsEnabled'); isLockoutEnabled: boolean = false //this.setting.getBoolean('Abp.Zero.UserManagement.UserLockOut.IsEnabled'); passwordComplexitySetting: PasswordComplexitySetting = new PasswordComplexitySetting(); roles: UserRoleDto[]; sendActivationEmail = false; setRandomPassword = false; passwordComplexityInfo = ''; constructor( injector: Injector, private _contactService: ContactServiceProxy, // private _countryService: CountryServiceProxy, // private _cityService: CityServiceProxy, // private _stateService: StateServiceProxy, private _addressTypeService: AddressTypeServiceProxy, private _postalCodeService: PostalCodeServiceProxy, private _vendorService: VendorsServiceProxy, private router: Router, private route: ActivatedRoute, private _location:Location, ) { super(injector); } setPasswordComplexityInfo(): void { this.passwordComplexityInfo = ''; } ngOnInit(){ $('.kt-select2').select2(); this.route.paramMap.subscribe(params => { this.id = params.get("id") }) // this.KTWizard2(); $("#addressTypeSelectInput").change(function(){ this.selectedAddressType = $("#addressTypeSelectInput option:selected").text(); $("#selectedAddressType").text("AddressType: " +this.selectedAddressType); }); $("#countrySelectInput").change(function(){ this.selectedCountry = $("#countrySelectInput option:selected").text(); $("#selectedCountry").text(this.selectedCountry); }); $("#postalSelectInput").change(function(){ this.selectedPostalCode = $("#postalSelectInput option:selected").text(); $("#selectedPostalCode").text(this.selectedPostalCode); }); $("#stateSelectInput").change(function(){ this.selectedState = $("#stateSelectInput option:selected").text(); $("#selectedState").text(this.selectedState); }); $("#citySelectInput").change(function(){ this.selectedCity = $("#citySelectInput option:selected").text(); $("#selectedCity").text(this.selectedCity); }); var KTWizard2 = function () { var e, r, i; return { init: function () { var t; KTUtil.get("kt_wizard_v2"), e = $("#kt_form"), (i = new KTWizard("kt_wizard_v2", { startStep: 1, clickableSteps: !0 })).on("beforeNext", function (e) { !0 !== r.form() && e.stop() }), i.on("beforePrev", function (e) { !0 !== r.form() && e.stop() }), i.on("change", function (e) { KTUtil.scrollTop() }), r = e.validate({ ignore: ":hidden", rules: { Name: { required: !0 }, Surname: { required: !0 }, EmailAddress: { required: !0, email: !0 }, locationSelectInput: { required: !0 }, UserName: { required: !0, minlength: 5}, Password: { required: !0, minlength: 5 }, PasswordRepeat: { required: !0,minlength: 5, equalTo:"#Password" }, Address1: { required: !0 }, postalSelectInput: { required: !0 }, countrySelectInput: { required: !0 }, stateSelectInput: { required: !0 }, citySelectInput: { required: !0 } }, invalidHandler: function (e, r) { KTUtil.scrollTop(), swal.fire({ title: "", text: "There are some errors in your submission. Please correct them.", type: "error", confirmButtonClass: "btn btn-secondary" }) }, submitHandler: function (e) { } }) } } }(); jQuery(document).ready(function () { KTWizard2.init() }); } ngAfterViewInit() { let maxCount = 1000; this.filterAddressTypes(maxCount); // this.filterCountries(maxCount); // this.filterPostal(maxCount); // this.filterCities(maxCount); // this.filterStates(maxCount); } save(): void { let input = new CreateOrUpdateContactUserInput(); this.contact.firstName =this.contactForm.fName; this.contact.lastName = this.contactForm.sName; this.address = this.addressForm.address; this.address.postalCodeId = Number((document.getElementById('postalSelectInput')).value); this.address.addressTypeId = Number((document.getElementById('addressTypeSelectInput')).value); input.setRandomPassword = this.setRandomPassword; input.user = this.vendor; input.user.name = this.contactForm.fName; input.user.surname = this.contactForm.sName; input.user.emailAddress = this.contactForm.emailAddress; input.user.isActive = this.isActive; input.sendActivationEmail = this.sendActivationEmail; input.assignedRoleNames = _.map( _.filter(this.roles, { isAssigned: true }), role => role.roleName ); this.contact.contactUser = input; this.contact.address = this.address; this.saving = true; this._contactService.createContactVendorAddress(this.contact) .pipe(finalize(() => { this.saving = false; })) .subscribe(() => { this.notify.info(this.l('SavedSuccessfully')); this.router.navigate(['/app/sprintship/vendors']); console.log(this.contact); }); } // filterPostal(maxCount): void { // this._postalCodeService.getPostalCode( // undefined, // undefined, // undefined, // maxCount, // undefined // ).subscribe(result => { // this.filteredPostal = result.items; // }); // } // filterCountries(maxCount): void { // this._countryService.getCountry( // undefined, // undefined, // undefined, // maxCount, // undefined // ).subscribe(result => { // this.filteredCountries = result.items; // }); // } // filterCities(maxCount): void { // this._cityService.getCity( // undefined, // undefined, // undefined, // maxCount, // undefined // ).subscribe(result => { // this.filteredCities = result.items; // }); // } // filterStates(maxCount): void { // this._stateService.getState( // undefined, // undefined, // undefined, // maxCount, // undefined // ).subscribe(result => { // this.filteredStates = result.items; // }); // } filterAddressTypes(maxCount): void { this._addressTypeService.getAddressType( undefined, undefined, undefined, undefined, maxCount, undefined ).subscribe(result => { this.filteredAddressType = result.items; }); } // Class definition KTWizard2(): void { // Base elements var wizardEl; var formEl; var validator; var wizard; // Private functions var initWizard = function () { // Initialize form wizard wizard = new KTWizard('kt_wizard_v2', { startStep: 1, }); function validateEmail(sEmail) { var filter =/^\b[A-Z0-9._%-]+@[A-Z0-9.-]+\.[A-Z]{2,4}\b$/i; if (filter.test(sEmail)) { return true; } else { return false; } } // Validation before going to next page wizard.on('beforeNext', function (wizardObj) { if (wizardObj.currentStep == 1) { if ($('#Name').val() == '' || ($('#Surname').val() == '') // || ($('#PhoneNumber').val() == ''|| $('#minutesPerStopInput').val()==0) || $('#EmailAddress').val() == '' || $('#UserName').val() == '' || $('#Password').val() == '' || $('#PasswordRepeat').val() == '' ) { wizardObj.stop(); // don't go to the next step } if(!validateEmail($('#EmailAddress').val())){ wizardObj.stop(); } } else if (wizardObj.currentStep == 2) { if ($('#address1Input').val() == '' || ($('#countrySelectInput').val() == null || $('#countrySelectInput').val() == 0) || ($('#postalSelectInput').val() == null || $('#postalSelectInput').val() == 0) || ($('#stateSelectInput').val() == null || $('#stateSelectInput').val() == 0) || ($('#citySelectInput').val() == null || $('#citySelectInput').val() == 0) // || ($('#addressTypeSelectInput').val() == null || $('#addressTypeSelectInput').val() == 0) ) { wizardObj.stop(); // don't go to the next step } } }); // Change event wizard.on('change', function (wizard) { KTUtil.scrollTop(); }); } wizardEl = KTUtil.get('kt_wizard_v2'); formEl = $('#kt_form').serialize(); return initWizard(); //return initValidation(); //return initSubmit(); } goBack(){ this._location.back(); } }