@abp/ng.account 5.0.1 → 5.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +3 -3
- package/abp-ng.account.d.ts +5 -5
- package/bundles/abp-ng.account-config.umd.js +78 -78
- package/bundles/abp-ng.account-config.umd.js.map +1 -1
- package/bundles/abp-ng.account.umd.js +893 -893
- package/bundles/abp-ng.account.umd.js.map +1 -1
- package/config/abp-ng.account-config.d.ts +5 -5
- package/config/account-config.module.d.ts +8 -8
- package/config/enums/index.d.ts +1 -1
- package/config/enums/route-names.d.ts +8 -8
- package/config/providers/index.d.ts +1 -1
- package/config/providers/route.provider.d.ts +8 -8
- package/config/public-api.d.ts +3 -3
- package/config/utils/factories.d.ts +2 -2
- package/esm2015/abp-ng.account.js +4 -4
- package/esm2015/config/abp-ng.account-config.js +4 -4
- package/esm2015/config/account-config.module.js +27 -27
- package/esm2015/config/enums/index.js +2 -2
- package/esm2015/config/enums/route-names.js +2 -2
- package/esm2015/config/providers/index.js +2 -2
- package/esm2015/config/providers/route.provider.js +50 -50
- package/esm2015/config/public-api.js +4 -4
- package/esm2015/config/utils/factories.js +11 -11
- package/esm2015/lib/account-routing.module.js +89 -89
- package/esm2015/lib/account.module.js +85 -85
- package/esm2015/lib/components/change-password/change-password.component.js +90 -90
- package/esm2015/lib/components/forgot-password/forgot-password.component.js +46 -46
- package/esm2015/lib/components/index.js +8 -8
- package/esm2015/lib/components/login/login.component.js +68 -68
- package/esm2015/lib/components/manage-profile/manage-profile.component.js +50 -50
- package/esm2015/lib/components/personal-settings/personal-settings.component.js +59 -59
- package/esm2015/lib/components/register/register.component.js +87 -87
- package/esm2015/lib/components/reset-password/reset-password.component.js +71 -71
- package/esm2015/lib/enums/components.js +2 -2
- package/esm2015/lib/enums/index.js +2 -2
- package/esm2015/lib/guards/authentication-flow.guard.js +21 -21
- package/esm2015/lib/guards/index.js +2 -2
- package/esm2015/lib/models/account.js +3 -3
- package/esm2015/lib/models/config-options.js +2 -2
- package/esm2015/lib/models/index.js +3 -3
- package/esm2015/lib/services/index.js +2 -2
- package/esm2015/lib/services/manage-profile.state.service.js +27 -27
- package/esm2015/lib/tokens/config-options.token.js +3 -3
- package/esm2015/lib/tokens/index.js +2 -2
- package/esm2015/lib/utils/auth-utils.js +8 -8
- package/esm2015/lib/utils/factory-utils.js +4 -4
- package/esm2015/public-api.js +8 -8
- package/fesm2015/abp-ng.account-config.js +75 -75
- package/fesm2015/abp-ng.account-config.js.map +1 -1
- package/fesm2015/abp-ng.account.js +545 -545
- package/fesm2015/abp-ng.account.js.map +1 -1
- package/lib/account-routing.module.d.ts +7 -7
- package/lib/account.module.d.ts +22 -22
- package/lib/components/change-password/change-password.component.d.ts +24 -24
- package/lib/components/forgot-password/forgot-password.component.d.ts +14 -14
- package/lib/components/index.d.ts +7 -7
- package/lib/components/login/login.component.d.ts +24 -24
- package/lib/components/manage-profile/manage-profile.component.d.ts +18 -18
- package/lib/components/personal-settings/personal-settings.component.d.ts +21 -21
- package/lib/components/register/register.component.d.ts +26 -26
- package/lib/components/reset-password/reset-password.component.d.ts +22 -22
- package/lib/enums/components.d.ts +11 -11
- package/lib/enums/index.d.ts +1 -1
- package/lib/guards/authentication-flow.guard.d.ts +10 -10
- package/lib/guards/index.d.ts +1 -1
- package/lib/models/account.d.ts +14 -14
- package/lib/models/config-options.d.ts +3 -3
- package/lib/models/index.d.ts +2 -2
- package/lib/services/index.d.ts +1 -1
- package/lib/services/manage-profile.state.service.d.ts +29 -29
- package/lib/tokens/config-options.token.d.ts +3 -3
- package/lib/tokens/index.d.ts +1 -1
- package/lib/utils/auth-utils.d.ts +2 -2
- package/lib/utils/factory-utils.d.ts +4 -4
- package/package.json +4 -4
- package/public-api.d.ts +7 -7
|
@@ -1,50 +1,50 @@
|
|
|
1
|
-
import { ProfileService } from '@abp/ng.account.core/proxy';
|
|
2
|
-
import { fadeIn } from '@abp/ng.theme.shared';
|
|
3
|
-
import { transition, trigger, useAnimation } from '@angular/animations';
|
|
4
|
-
import { Component } from '@angular/core';
|
|
5
|
-
import { ManageProfileStateService } from '../../services/manage-profile.state.service';
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "@abp/ng.account.core/proxy";
|
|
8
|
-
import * as i2 from "../../services/manage-profile.state.service";
|
|
9
|
-
import * as i3 from "../change-password/change-password.component";
|
|
10
|
-
import * as i4 from "../personal-settings/personal-settings.component";
|
|
11
|
-
import * as i5 from "@abp/ng.theme.shared";
|
|
12
|
-
import * as i6 from "@angular/common";
|
|
13
|
-
import * as i7 from "@abp/ng.core";
|
|
14
|
-
export class ManageProfileComponent {
|
|
15
|
-
constructor(profileService, manageProfileState) {
|
|
16
|
-
this.profileService = profileService;
|
|
17
|
-
this.manageProfileState = manageProfileState;
|
|
18
|
-
this.selectedTab = 0;
|
|
19
|
-
this.changePasswordKey = "Account.ChangePasswordComponent" /* ChangePassword */;
|
|
20
|
-
this.personalSettingsKey = "Account.PersonalSettingsComponent" /* PersonalSettings */;
|
|
21
|
-
this.profile$ = this.manageProfileState.getProfile$();
|
|
22
|
-
}
|
|
23
|
-
ngOnInit() {
|
|
24
|
-
this.profileService.get().subscribe(profile => {
|
|
25
|
-
this.manageProfileState.setProfile(profile);
|
|
26
|
-
if (profile.isExternal) {
|
|
27
|
-
this.hideChangePasswordTab = true;
|
|
28
|
-
this.selectedTab = 1;
|
|
29
|
-
}
|
|
30
|
-
});
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
ManageProfileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: ManageProfileComponent, deps: [{ token: i1.ProfileService }, { token: i2.ManageProfileStateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
34
|
-
ManageProfileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.13", type: ManageProfileComponent, selector: "abp-manage-profile", ngImport: i0, template: "<div id=\"AbpContentToolbar\"></div>\
|
|
35
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: ManageProfileComponent, decorators: [{
|
|
36
|
-
type: Component,
|
|
37
|
-
args: [{
|
|
38
|
-
selector: 'abp-manage-profile',
|
|
39
|
-
templateUrl: './manage-profile.component.html',
|
|
40
|
-
animations: [trigger('fadeIn', [transition(':enter', useAnimation(fadeIn))])],
|
|
41
|
-
styles: [
|
|
42
|
-
`
|
|
43
|
-
.min-h-400 {
|
|
44
|
-
min-height: 400px;
|
|
45
|
-
}
|
|
46
|
-
`,
|
|
47
|
-
],
|
|
48
|
-
}]
|
|
49
|
-
}], ctorParameters: function () { return [{ type: i1.ProfileService }, { type: i2.ManageProfileStateService }]; } });
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { ProfileService } from '@abp/ng.account.core/proxy';
|
|
2
|
+
import { fadeIn } from '@abp/ng.theme.shared';
|
|
3
|
+
import { transition, trigger, useAnimation } from '@angular/animations';
|
|
4
|
+
import { Component } from '@angular/core';
|
|
5
|
+
import { ManageProfileStateService } from '../../services/manage-profile.state.service';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@abp/ng.account.core/proxy";
|
|
8
|
+
import * as i2 from "../../services/manage-profile.state.service";
|
|
9
|
+
import * as i3 from "../change-password/change-password.component";
|
|
10
|
+
import * as i4 from "../personal-settings/personal-settings.component";
|
|
11
|
+
import * as i5 from "@abp/ng.theme.shared";
|
|
12
|
+
import * as i6 from "@angular/common";
|
|
13
|
+
import * as i7 from "@abp/ng.core";
|
|
14
|
+
export class ManageProfileComponent {
|
|
15
|
+
constructor(profileService, manageProfileState) {
|
|
16
|
+
this.profileService = profileService;
|
|
17
|
+
this.manageProfileState = manageProfileState;
|
|
18
|
+
this.selectedTab = 0;
|
|
19
|
+
this.changePasswordKey = "Account.ChangePasswordComponent" /* ChangePassword */;
|
|
20
|
+
this.personalSettingsKey = "Account.PersonalSettingsComponent" /* PersonalSettings */;
|
|
21
|
+
this.profile$ = this.manageProfileState.getProfile$();
|
|
22
|
+
}
|
|
23
|
+
ngOnInit() {
|
|
24
|
+
this.profileService.get().subscribe(profile => {
|
|
25
|
+
this.manageProfileState.setProfile(profile);
|
|
26
|
+
if (profile.isExternal) {
|
|
27
|
+
this.hideChangePasswordTab = true;
|
|
28
|
+
this.selectedTab = 1;
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
ManageProfileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: ManageProfileComponent, deps: [{ token: i1.ProfileService }, { token: i2.ManageProfileStateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
34
|
+
ManageProfileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.13", type: ManageProfileComponent, selector: "abp-manage-profile", ngImport: i0, template: "<div id=\"AbpContentToolbar\"></div>\n\n<div class=\"card border-0 shadow-sm min-h-400\" [abpLoading]=\"!(profile$ | async)?.userName\">\n <div class=\"card-body\">\n <div class=\"row\">\n <div class=\"col-12 col-md-3\">\n <ul class=\"nav flex-column nav-pills\" id=\"nav-tab\" role=\"tablist\">\n <li\n *ngIf=\"!hideChangePasswordTab && (profile$ | async)\"\n class=\"nav-item\"\n (click)=\"selectedTab = 0\"\n >\n <a\n class=\"nav-link\"\n [ngClass]=\"{ active: selectedTab === 0 }\"\n role=\"tab\"\n href=\"javascript:void(0)\"\n >{{ 'AbpUi::ChangePassword' | abpLocalization }}</a\n >\n </li>\n <li class=\"nav-item mb-2\" (click)=\"selectedTab = 1\">\n <a\n class=\"nav-link\"\n [ngClass]=\"{ active: selectedTab === 1 }\"\n role=\"tab\"\n href=\"javascript:void(0)\"\n >{{ 'AbpAccount::PersonalSettings' | abpLocalization }}</a\n >\n </li>\n </ul>\n </div>\n <div *ngIf=\"profile$ | async\" class=\"col-12 col-md-9\">\n <div class=\"tab-content\" *ngIf=\"selectedTab === 0\" [@fadeIn]>\n <div class=\"tab-pane active\" role=\"tabpanel\">\n <h4>\n {{ 'AbpIdentity::ChangePassword' | abpLocalization }}\n <hr />\n </h4>\n <abp-change-password-form\n *abpReplaceableTemplate=\"{\n componentKey: changePasswordKey\n }\"\n ></abp-change-password-form>\n </div>\n </div>\n <div class=\"tab-content\" *ngIf=\"selectedTab === 1\" [@fadeIn]>\n <div class=\"tab-pane active\" role=\"tabpanel\">\n <h4>\n {{ 'AbpIdentity::PersonalSettings' | abpLocalization }}\n <hr />\n </h4>\n <abp-personal-settings-form\n *abpReplaceableTemplate=\"{\n componentKey: personalSettingsKey\n }\"\n ></abp-personal-settings-form>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: ["\n .min-h-400 {\n min-height: 400px;\n }\n "], components: [{ type: i3.ChangePasswordComponent, selector: "abp-change-password-form", exportAs: ["abpChangePasswordForm"] }, { type: i4.PersonalSettingsComponent, selector: "abp-personal-settings-form", exportAs: ["abpPersonalSettingsForm"] }], directives: [{ type: i5.LoadingDirective, selector: "[abpLoading]", inputs: ["abpLoading", "abpLoadingTargetElement", "abpLoadingDelay"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i7.ReplaceableTemplateDirective, selector: "[abpReplaceableTemplate]", inputs: ["abpReplaceableTemplate"] }], pipes: { "async": i6.AsyncPipe, "abpLocalization": i7.LocalizationPipe }, animations: [trigger('fadeIn', [transition(':enter', useAnimation(fadeIn))])] });
|
|
35
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: ManageProfileComponent, decorators: [{
|
|
36
|
+
type: Component,
|
|
37
|
+
args: [{
|
|
38
|
+
selector: 'abp-manage-profile',
|
|
39
|
+
templateUrl: './manage-profile.component.html',
|
|
40
|
+
animations: [trigger('fadeIn', [transition(':enter', useAnimation(fadeIn))])],
|
|
41
|
+
styles: [
|
|
42
|
+
`
|
|
43
|
+
.min-h-400 {
|
|
44
|
+
min-height: 400px;
|
|
45
|
+
}
|
|
46
|
+
`,
|
|
47
|
+
],
|
|
48
|
+
}]
|
|
49
|
+
}], ctorParameters: function () { return [{ type: i1.ProfileService }, { type: i2.ManageProfileStateService }]; } });
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFuYWdlLXByb2ZpbGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYWNjb3VudC9zcmMvbGliL2NvbXBvbmVudHMvbWFuYWdlLXByb2ZpbGUvbWFuYWdlLXByb2ZpbGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYWNjb3VudC9zcmMvbGliL2NvbXBvbmVudHMvbWFuYWdlLXByb2ZpbGUvbWFuYWdlLXByb2ZpbGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzVELE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUM5QyxPQUFPLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN4RSxPQUFPLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBRWxELE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLDZDQUE2QyxDQUFDOzs7Ozs7Ozs7QUFjeEYsTUFBTSxPQUFPLHNCQUFzQjtJQVdqQyxZQUNZLGNBQThCLEVBQzlCLGtCQUE2QztRQUQ3QyxtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7UUFDOUIsdUJBQWtCLEdBQWxCLGtCQUFrQixDQUEyQjtRQVp6RCxnQkFBVyxHQUFHLENBQUMsQ0FBQztRQUVoQixzQkFBaUIsMERBQXFDO1FBRXRELHdCQUFtQiw4REFBdUM7UUFFMUQsYUFBUSxHQUFHLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQU85QyxDQUFDO0lBRUosUUFBUTtRQUNOLElBQUksQ0FBQyxjQUFjLENBQUMsR0FBRyxFQUFFLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxFQUFFO1lBQzVDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDNUMsSUFBSSxPQUFPLENBQUMsVUFBVSxFQUFFO2dCQUN0QixJQUFJLENBQUMscUJBQXFCLEdBQUcsSUFBSSxDQUFDO2dCQUNsQyxJQUFJLENBQUMsV0FBVyxHQUFHLENBQUMsQ0FBQzthQUN0QjtRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7b0hBeEJVLHNCQUFzQjt3R0FBdEIsc0JBQXNCLDBEQ25CbkMsb3NFQThEQSx5ekJEcERjLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDLFVBQVUsQ0FBQyxRQUFRLEVBQUUsWUFBWSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDOzRGQVNsRSxzQkFBc0I7a0JBWmxDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG9CQUFvQjtvQkFDOUIsV0FBVyxFQUFFLGlDQUFpQztvQkFDOUMsVUFBVSxFQUFFLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDLFVBQVUsQ0FBQyxRQUFRLEVBQUUsWUFBWSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO29CQUM3RSxNQUFNLEVBQUU7d0JBQ047Ozs7S0FJQztxQkFDRjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFByb2ZpbGVTZXJ2aWNlIH0gZnJvbSAnQGFicC9uZy5hY2NvdW50LmNvcmUvcHJveHknO1xuaW1wb3J0IHsgZmFkZUluIH0gZnJvbSAnQGFicC9uZy50aGVtZS5zaGFyZWQnO1xuaW1wb3J0IHsgdHJhbnNpdGlvbiwgdHJpZ2dlciwgdXNlQW5pbWF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvYW5pbWF0aW9ucyc7XG5pbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZUFjY291bnRDb21wb25lbnRzIH0gZnJvbSAnLi4vLi4vZW51bXMvY29tcG9uZW50cyc7XG5pbXBvcnQgeyBNYW5hZ2VQcm9maWxlU3RhdGVTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvbWFuYWdlLXByb2ZpbGUuc3RhdGUuc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FicC1tYW5hZ2UtcHJvZmlsZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9tYW5hZ2UtcHJvZmlsZS5jb21wb25lbnQuaHRtbCcsXG4gIGFuaW1hdGlvbnM6IFt0cmlnZ2VyKCdmYWRlSW4nLCBbdHJhbnNpdGlvbignOmVudGVyJywgdXNlQW5pbWF0aW9uKGZhZGVJbikpXSldLFxuICBzdHlsZXM6IFtcbiAgICBgXG4gICAgICAubWluLWgtNDAwIHtcbiAgICAgICAgbWluLWhlaWdodDogNDAwcHg7XG4gICAgICB9XG4gICAgYCxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgTWFuYWdlUHJvZmlsZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIHNlbGVjdGVkVGFiID0gMDtcblxuICBjaGFuZ2VQYXNzd29yZEtleSA9IGVBY2NvdW50Q29tcG9uZW50cy5DaGFuZ2VQYXNzd29yZDtcblxuICBwZXJzb25hbFNldHRpbmdzS2V5ID0gZUFjY291bnRDb21wb25lbnRzLlBlcnNvbmFsU2V0dGluZ3M7XG5cbiAgcHJvZmlsZSQgPSB0aGlzLm1hbmFnZVByb2ZpbGVTdGF0ZS5nZXRQcm9maWxlJCgpO1xuXG4gIGhpZGVDaGFuZ2VQYXNzd29yZFRhYjogYm9vbGVhbjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcm90ZWN0ZWQgcHJvZmlsZVNlcnZpY2U6IFByb2ZpbGVTZXJ2aWNlLFxuICAgIHByb3RlY3RlZCBtYW5hZ2VQcm9maWxlU3RhdGU6IE1hbmFnZVByb2ZpbGVTdGF0ZVNlcnZpY2UsXG4gICkge31cblxuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLnByb2ZpbGVTZXJ2aWNlLmdldCgpLnN1YnNjcmliZShwcm9maWxlID0+IHtcbiAgICAgIHRoaXMubWFuYWdlUHJvZmlsZVN0YXRlLnNldFByb2ZpbGUocHJvZmlsZSk7XG4gICAgICBpZiAocHJvZmlsZS5pc0V4dGVybmFsKSB7XG4gICAgICAgIHRoaXMuaGlkZUNoYW5nZVBhc3N3b3JkVGFiID0gdHJ1ZTtcbiAgICAgICAgdGhpcy5zZWxlY3RlZFRhYiA9IDE7XG4gICAgICB9XG4gICAgfSk7XG4gIH1cbn1cbiIsIjxkaXYgaWQ9XCJBYnBDb250ZW50VG9vbGJhclwiPjwvZGl2PlxuXG48ZGl2IGNsYXNzPVwiY2FyZCBib3JkZXItMCBzaGFkb3ctc20gbWluLWgtNDAwXCIgW2FicExvYWRpbmddPVwiIShwcm9maWxlJCB8IGFzeW5jKT8udXNlck5hbWVcIj5cbiAgPGRpdiBjbGFzcz1cImNhcmQtYm9keVwiPlxuICAgIDxkaXYgY2xhc3M9XCJyb3dcIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtMTIgY29sLW1kLTNcIj5cbiAgICAgICAgPHVsIGNsYXNzPVwibmF2IGZsZXgtY29sdW1uIG5hdi1waWxsc1wiIGlkPVwibmF2LXRhYlwiIHJvbGU9XCJ0YWJsaXN0XCI+XG4gICAgICAgICAgPGxpXG4gICAgICAgICAgICAqbmdJZj1cIiFoaWRlQ2hhbmdlUGFzc3dvcmRUYWIgJiYgKHByb2ZpbGUkIHwgYXN5bmMpXCJcbiAgICAgICAgICAgIGNsYXNzPVwibmF2LWl0ZW1cIlxuICAgICAgICAgICAgKGNsaWNrKT1cInNlbGVjdGVkVGFiID0gMFwiXG4gICAgICAgICAgPlxuICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgY2xhc3M9XCJuYXYtbGlua1wiXG4gICAgICAgICAgICAgIFtuZ0NsYXNzXT1cInsgYWN0aXZlOiBzZWxlY3RlZFRhYiA9PT0gMCB9XCJcbiAgICAgICAgICAgICAgcm9sZT1cInRhYlwiXG4gICAgICAgICAgICAgIGhyZWY9XCJqYXZhc2NyaXB0OnZvaWQoMClcIlxuICAgICAgICAgICAgICA+e3sgJ0FicFVpOjpDaGFuZ2VQYXNzd29yZCcgfCBhYnBMb2NhbGl6YXRpb24gfX08L2FcbiAgICAgICAgICAgID5cbiAgICAgICAgICA8L2xpPlxuICAgICAgICAgIDxsaSBjbGFzcz1cIm5hdi1pdGVtIG1iLTJcIiAoY2xpY2spPVwic2VsZWN0ZWRUYWIgPSAxXCI+XG4gICAgICAgICAgICA8YVxuICAgICAgICAgICAgICBjbGFzcz1cIm5hdi1saW5rXCJcbiAgICAgICAgICAgICAgW25nQ2xhc3NdPVwieyBhY3RpdmU6IHNlbGVjdGVkVGFiID09PSAxIH1cIlxuICAgICAgICAgICAgICByb2xlPVwidGFiXCJcbiAgICAgICAgICAgICAgaHJlZj1cImphdmFzY3JpcHQ6dm9pZCgwKVwiXG4gICAgICAgICAgICAgID57eyAnQWJwQWNjb3VudDo6UGVyc29uYWxTZXR0aW5ncycgfCBhYnBMb2NhbGl6YXRpb24gfX08L2FcbiAgICAgICAgICAgID5cbiAgICAgICAgICA8L2xpPlxuICAgICAgICA8L3VsPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2ICpuZ0lmPVwicHJvZmlsZSQgfCBhc3luY1wiIGNsYXNzPVwiY29sLTEyIGNvbC1tZC05XCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJ0YWItY29udGVudFwiICpuZ0lmPVwic2VsZWN0ZWRUYWIgPT09IDBcIiBbQGZhZGVJbl0+XG4gICAgICAgICAgPGRpdiBjbGFzcz1cInRhYi1wYW5lIGFjdGl2ZVwiIHJvbGU9XCJ0YWJwYW5lbFwiPlxuICAgICAgICAgICAgPGg0PlxuICAgICAgICAgICAgICB7eyAnQWJwSWRlbnRpdHk6OkNoYW5nZVBhc3N3b3JkJyB8IGFicExvY2FsaXphdGlvbiB9fVxuICAgICAgICAgICAgICA8aHIgLz5cbiAgICAgICAgICAgIDwvaDQ+XG4gICAgICAgICAgICA8YWJwLWNoYW5nZS1wYXNzd29yZC1mb3JtXG4gICAgICAgICAgICAgICphYnBSZXBsYWNlYWJsZVRlbXBsYXRlPVwie1xuICAgICAgICAgICAgICAgIGNvbXBvbmVudEtleTogY2hhbmdlUGFzc3dvcmRLZXlcbiAgICAgICAgICAgICAgfVwiXG4gICAgICAgICAgICA+PC9hYnAtY2hhbmdlLXBhc3N3b3JkLWZvcm0+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8ZGl2IGNsYXNzPVwidGFiLWNvbnRlbnRcIiAqbmdJZj1cInNlbGVjdGVkVGFiID09PSAxXCIgW0BmYWRlSW5dPlxuICAgICAgICAgIDxkaXYgY2xhc3M9XCJ0YWItcGFuZSBhY3RpdmVcIiByb2xlPVwidGFicGFuZWxcIj5cbiAgICAgICAgICAgIDxoND5cbiAgICAgICAgICAgICAge3sgJ0FicElkZW50aXR5OjpQZXJzb25hbFNldHRpbmdzJyB8IGFicExvY2FsaXphdGlvbiB9fVxuICAgICAgICAgICAgICA8aHIgLz5cbiAgICAgICAgICAgIDwvaDQ+XG4gICAgICAgICAgICA8YWJwLXBlcnNvbmFsLXNldHRpbmdzLWZvcm1cbiAgICAgICAgICAgICAgKmFicFJlcGxhY2VhYmxlVGVtcGxhdGU9XCJ7XG4gICAgICAgICAgICAgICAgY29tcG9uZW50S2V5OiBwZXJzb25hbFNldHRpbmdzS2V5XG4gICAgICAgICAgICAgIH1cIlxuICAgICAgICAgICAgPjwvYWJwLXBlcnNvbmFsLXNldHRpbmdzLWZvcm0+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
|
|
@@ -1,59 +1,59 @@
|
|
|
1
|
-
import { ProfileService } from '@abp/ng.account.core/proxy';
|
|
2
|
-
import { ToasterService } from '@abp/ng.theme.shared';
|
|
3
|
-
import { Component } from '@angular/core';
|
|
4
|
-
import { FormBuilder, Validators } from '@angular/forms';
|
|
5
|
-
import { finalize } from 'rxjs/operators';
|
|
6
|
-
import { ManageProfileStateService } from '../../services/manage-profile.state.service';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "@angular/forms";
|
|
9
|
-
import * as i2 from "@abp/ng.theme.shared";
|
|
10
|
-
import * as i3 from "@abp/ng.account.core/proxy";
|
|
11
|
-
import * as i4 from "../../services/manage-profile.state.service";
|
|
12
|
-
import * as i5 from "@angular/common";
|
|
13
|
-
import * as i6 from "@abp/ng.core";
|
|
14
|
-
import * as i7 from "@ngx-validate/core";
|
|
15
|
-
const { maxLength, required, email } = Validators;
|
|
16
|
-
export class PersonalSettingsComponent {
|
|
17
|
-
constructor(fb, toasterService, profileService, manageProfileState) {
|
|
18
|
-
this.fb = fb;
|
|
19
|
-
this.toasterService = toasterService;
|
|
20
|
-
this.profileService = profileService;
|
|
21
|
-
this.manageProfileState = manageProfileState;
|
|
22
|
-
}
|
|
23
|
-
ngOnInit() {
|
|
24
|
-
this.buildForm();
|
|
25
|
-
}
|
|
26
|
-
buildForm() {
|
|
27
|
-
const profile = this.manageProfileState.getProfile();
|
|
28
|
-
this.form = this.fb.group({
|
|
29
|
-
userName: [profile.userName, [required, maxLength(256)]],
|
|
30
|
-
email: [profile.email, [required, email, maxLength(256)]],
|
|
31
|
-
name: [profile.name || '', [maxLength(64)]],
|
|
32
|
-
surname: [profile.surname || '', [maxLength(64)]],
|
|
33
|
-
phoneNumber: [profile.phoneNumber || '', [maxLength(16)]],
|
|
34
|
-
});
|
|
35
|
-
}
|
|
36
|
-
submit() {
|
|
37
|
-
if (this.form.invalid)
|
|
38
|
-
return;
|
|
39
|
-
this.inProgress = true;
|
|
40
|
-
this.profileService
|
|
41
|
-
.update(this.form.value)
|
|
42
|
-
.pipe(finalize(() => (this.inProgress = false)))
|
|
43
|
-
.subscribe(profile => {
|
|
44
|
-
this.manageProfileState.setProfile(profile);
|
|
45
|
-
this.toasterService.success('AbpAccount::PersonalSettingsSaved', 'Success', { life: 5000 });
|
|
46
|
-
});
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
PersonalSettingsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: PersonalSettingsComponent, deps: [{ token: i1.FormBuilder }, { token: i2.ToasterService }, { token: i3.ProfileService }, { token: i4.ManageProfileStateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
50
|
-
PersonalSettingsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.13", type: PersonalSettingsComponent, selector: "abp-personal-settings-form", exportAs: ["abpPersonalSettingsForm"], ngImport: i0, template: "<form validateOnSubmit *ngIf=\"form\" [formGroup]=\"form\" (ngSubmit)=\"submit()\">\
|
|
51
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: PersonalSettingsComponent, decorators: [{
|
|
52
|
-
type: Component,
|
|
53
|
-
args: [{
|
|
54
|
-
selector: 'abp-personal-settings-form',
|
|
55
|
-
templateUrl: './personal-settings.component.html',
|
|
56
|
-
exportAs: 'abpPersonalSettingsForm',
|
|
57
|
-
}]
|
|
58
|
-
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.ToasterService }, { type: i3.ProfileService }, { type: i4.ManageProfileStateService }]; } });
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { ProfileService } from '@abp/ng.account.core/proxy';
|
|
2
|
+
import { ToasterService } from '@abp/ng.theme.shared';
|
|
3
|
+
import { Component } from '@angular/core';
|
|
4
|
+
import { FormBuilder, Validators } from '@angular/forms';
|
|
5
|
+
import { finalize } from 'rxjs/operators';
|
|
6
|
+
import { ManageProfileStateService } from '../../services/manage-profile.state.service';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/forms";
|
|
9
|
+
import * as i2 from "@abp/ng.theme.shared";
|
|
10
|
+
import * as i3 from "@abp/ng.account.core/proxy";
|
|
11
|
+
import * as i4 from "../../services/manage-profile.state.service";
|
|
12
|
+
import * as i5 from "@angular/common";
|
|
13
|
+
import * as i6 from "@abp/ng.core";
|
|
14
|
+
import * as i7 from "@ngx-validate/core";
|
|
15
|
+
const { maxLength, required, email } = Validators;
|
|
16
|
+
export class PersonalSettingsComponent {
|
|
17
|
+
constructor(fb, toasterService, profileService, manageProfileState) {
|
|
18
|
+
this.fb = fb;
|
|
19
|
+
this.toasterService = toasterService;
|
|
20
|
+
this.profileService = profileService;
|
|
21
|
+
this.manageProfileState = manageProfileState;
|
|
22
|
+
}
|
|
23
|
+
ngOnInit() {
|
|
24
|
+
this.buildForm();
|
|
25
|
+
}
|
|
26
|
+
buildForm() {
|
|
27
|
+
const profile = this.manageProfileState.getProfile();
|
|
28
|
+
this.form = this.fb.group({
|
|
29
|
+
userName: [profile.userName, [required, maxLength(256)]],
|
|
30
|
+
email: [profile.email, [required, email, maxLength(256)]],
|
|
31
|
+
name: [profile.name || '', [maxLength(64)]],
|
|
32
|
+
surname: [profile.surname || '', [maxLength(64)]],
|
|
33
|
+
phoneNumber: [profile.phoneNumber || '', [maxLength(16)]],
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
submit() {
|
|
37
|
+
if (this.form.invalid)
|
|
38
|
+
return;
|
|
39
|
+
this.inProgress = true;
|
|
40
|
+
this.profileService
|
|
41
|
+
.update(this.form.value)
|
|
42
|
+
.pipe(finalize(() => (this.inProgress = false)))
|
|
43
|
+
.subscribe(profile => {
|
|
44
|
+
this.manageProfileState.setProfile(profile);
|
|
45
|
+
this.toasterService.success('AbpAccount::PersonalSettingsSaved', 'Success', { life: 5000 });
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
PersonalSettingsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: PersonalSettingsComponent, deps: [{ token: i1.FormBuilder }, { token: i2.ToasterService }, { token: i3.ProfileService }, { token: i4.ManageProfileStateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
50
|
+
PersonalSettingsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.13", type: PersonalSettingsComponent, selector: "abp-personal-settings-form", exportAs: ["abpPersonalSettingsForm"], ngImport: i0, template: "<form validateOnSubmit *ngIf=\"form\" [formGroup]=\"form\" (ngSubmit)=\"submit()\">\n <div class=\"mb-3 form-group\">\n <label for=\"username\" class=\"form-label\">{{\n 'AbpIdentity::DisplayName:UserName' | abpLocalization\n }}</label\n ><span> * </span\n ><input\n type=\"text\"\n id=\"username\"\n class=\"form-control\"\n formControlName=\"userName\"\n autofocus\n (keydown.space)=\"$event.preventDefault()\"\n />\n </div>\n <div class=\"row\">\n <div class=\"col col-md-6\">\n <div class=\"mb-3 form-group\">\n <label for=\"name\" class=\"form-label\">{{\n 'AbpIdentity::DisplayName:Name' | abpLocalization\n }}</label\n ><input type=\"text\" id=\"name\" class=\"form-control\" formControlName=\"name\" />\n </div>\n </div>\n <div class=\"col col-md-6\">\n <div class=\"mb-3 form-group\">\n <label for=\"surname\" class=\"form-label\">{{\n 'AbpIdentity::DisplayName:Surname' | abpLocalization\n }}</label\n ><input type=\"text\" id=\"surname\" class=\"form-control\" formControlName=\"surname\" />\n </div>\n </div>\n </div>\n <div class=\"mb-3 form-group\">\n <label for=\"email-address\" class=\"form-label\">{{\n 'AbpIdentity::DisplayName:Email' | abpLocalization\n }}</label\n ><span> * </span\n ><input type=\"text\" id=\"email-address\" class=\"form-control\" formControlName=\"email\" />\n </div>\n <div class=\"mb-3 form-group\">\n <label for=\"phone-number\" class=\"form-label\">{{\n 'AbpIdentity::DisplayName:PhoneNumber' | abpLocalization\n }}</label\n ><input type=\"text\" id=\"phone-number\" class=\"form-control\" formControlName=\"phoneNumber\" />\n </div>\n <abp-button\n buttonType=\"submit\"\n iconClass=\"fa fa-check\"\n buttonClass=\"btn btn-primary color-white\"\n [loading]=\"inProgress\"\n [disabled]=\"form?.invalid\"\n >\n {{ 'AbpIdentity::Save' | abpLocalization }}</abp-button\n >\n</form>\n", components: [{ type: i2.ButtonComponent, selector: "abp-button", inputs: ["buttonId", "buttonClass", "buttonType", "iconClass", "loading", "disabled", "attributes"], outputs: ["click", "focus", "blur", "abpClick", "abpFocus", "abpBlur"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i6.FormSubmitDirective, selector: "form[ngSubmit][formGroup]", inputs: ["debounce", "notValidateOnSubmit"], outputs: ["ngSubmit"] }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i7.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["disabled", "formControlName", "ngModel"], outputs: ["ngModelChange"] }, { type: i7.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { type: i6.AutofocusDirective, selector: "[autofocus]", inputs: ["autofocus"] }], pipes: { "abpLocalization": i6.LocalizationPipe } });
|
|
51
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: PersonalSettingsComponent, decorators: [{
|
|
52
|
+
type: Component,
|
|
53
|
+
args: [{
|
|
54
|
+
selector: 'abp-personal-settings-form',
|
|
55
|
+
templateUrl: './personal-settings.component.html',
|
|
56
|
+
exportAs: 'abpPersonalSettingsForm',
|
|
57
|
+
}]
|
|
58
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.ToasterService }, { type: i3.ProfileService }, { type: i4.ManageProfileStateService }]; } });
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"personal-settings.component.js","sourceRoot":"","sources":["../../../../../../../packages/account/src/lib/components/personal-settings/personal-settings.component.ts","../../../../../../../packages/account/src/lib/components/personal-settings/personal-settings.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,SAAS,EAAU,MAAM,eAAe,CAAC;AAClD,OAAO,EAAE,WAAW,EAAa,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACpE,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAE1C,OAAO,EAAE,yBAAyB,EAAE,MAAM,6CAA6C,CAAC;;;;;;;;;AAExF,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,UAAU,CAAC;AAOlD,MAAM,OAAO,yBAAyB;IAUpC,YACU,EAAe,EACf,cAA8B,EAC9B,cAA8B,EAC9B,kBAA6C;QAH7C,OAAE,GAAF,EAAE,CAAa;QACf,mBAAc,GAAd,cAAc,CAAgB;QAC9B,mBAAc,GAAd,cAAc,CAAgB;QAC9B,uBAAkB,GAAlB,kBAAkB,CAA2B;IACpD,CAAC;IAEJ,QAAQ;QACN,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAED,SAAS;QACP,MAAM,OAAO,GAAG,IAAI,CAAC,kBAAkB,CAAC,UAAU,EAAE,CAAC;QACrD,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YACxB,QAAQ,EAAE,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;YACxD,KAAK,EAAE,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE,KAAK,EAAE,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;YACzD,IAAI,EAAE,CAAC,OAAO,CAAC,IAAI,IAAI,EAAE,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC;YAC3C,OAAO,EAAE,CAAC,OAAO,CAAC,OAAO,IAAI,EAAE,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC;YACjD,WAAW,EAAE,CAAC,OAAO,CAAC,WAAW,IAAI,EAAE,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC;SAC1D,CAAC,CAAC;IACL,CAAC;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,OAAO;QAC9B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,cAAc;aAChB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;aACvB,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,CAAC,CAAC;aAC/C,SAAS,CAAC,OAAO,CAAC,EAAE;YACnB,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;YAC5C,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,mCAAmC,EAAE,SAAS,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;QAC9F,CAAC,CAAC,CAAC;IACP,CAAC;;uHA1CU,yBAAyB;2GAAzB,yBAAyB,yGCftC,6+DAwDA;4FDzCa,yBAAyB;kBALrC,SAAS;mBAAC;oBACT,QAAQ,EAAE,4BAA4B;oBACtC,WAAW,EAAE,oCAAoC;oBACjD,QAAQ,EAAE,yBAAyB;iBACpC","sourcesContent":["import { ProfileService } from '@abp/ng.account.core/proxy';\nimport { ToasterService } from '@abp/ng.theme.shared';\nimport { Component, OnInit } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { finalize } from 'rxjs/operators';\nimport { Account } from '../../models/account';\nimport { ManageProfileStateService } from '../../services/manage-profile.state.service';\n\nconst { maxLength, required, email } = Validators;\n\n@Component({\n  selector: 'abp-personal-settings-form',\n  templateUrl: './personal-settings.component.html',\n  exportAs: 'abpPersonalSettingsForm',\n})\nexport class PersonalSettingsComponent\n  implements\n    OnInit,\n    Account.PersonalSettingsComponentInputs,\n    Account.PersonalSettingsComponentOutputs\n{\n  form: FormGroup;\n\n  inProgress: boolean;\n\n  constructor(\n    private fb: FormBuilder,\n    private toasterService: ToasterService,\n    private profileService: ProfileService,\n    private manageProfileState: ManageProfileStateService,\n  ) {}\n\n  ngOnInit() {\n    this.buildForm();\n  }\n\n  buildForm() {\n    const profile = this.manageProfileState.getProfile();\n    this.form = this.fb.group({\n      userName: [profile.userName, [required, maxLength(256)]],\n      email: [profile.email, [required, email, maxLength(256)]],\n      name: [profile.name || '', [maxLength(64)]],\n      surname: [profile.surname || '', [maxLength(64)]],\n      phoneNumber: [profile.phoneNumber || '', [maxLength(16)]],\n    });\n  }\n\n  submit() {\n    if (this.form.invalid) return;\n    this.inProgress = true;\n    this.profileService\n      .update(this.form.value)\n      .pipe(finalize(() => (this.inProgress = false)))\n      .subscribe(profile => {\n        this.manageProfileState.setProfile(profile);\n        this.toasterService.success('AbpAccount::PersonalSettingsSaved', 'Success', { life: 5000 });\n      });\n  }\n}\n","<form validateOnSubmit *ngIf=\"form\" [formGroup]=\"form\" (ngSubmit)=\"submit()\">\n  <div class=\"mb-3 form-group\">\n    <label for=\"username\" class=\"form-label\">{{\n      'AbpIdentity::DisplayName:UserName' | abpLocalization\n    }}</label\n    ><span> * </span\n    ><input\n      type=\"text\"\n      id=\"username\"\n      class=\"form-control\"\n      formControlName=\"userName\"\n      autofocus\n      (keydown.space)=\"$event.preventDefault()\"\n    />\n  </div>\n  <div class=\"row\">\n    <div class=\"col col-md-6\">\n      <div class=\"mb-3 form-group\">\n        <label for=\"name\" class=\"form-label\">{{\n          'AbpIdentity::DisplayName:Name' | abpLocalization\n        }}</label\n        ><input type=\"text\" id=\"name\" class=\"form-control\" formControlName=\"name\" />\n      </div>\n    </div>\n    <div class=\"col col-md-6\">\n      <div class=\"mb-3 form-group\">\n        <label for=\"surname\" class=\"form-label\">{{\n          'AbpIdentity::DisplayName:Surname' | abpLocalization\n        }}</label\n        ><input type=\"text\" id=\"surname\" class=\"form-control\" formControlName=\"surname\" />\n      </div>\n    </div>\n  </div>\n  <div class=\"mb-3 form-group\">\n    <label for=\"email-address\" class=\"form-label\">{{\n      'AbpIdentity::DisplayName:Email' | abpLocalization\n    }}</label\n    ><span> * </span\n    ><input type=\"text\" id=\"email-address\" class=\"form-control\" formControlName=\"email\" />\n  </div>\n  <div class=\"mb-3 form-group\">\n    <label for=\"phone-number\" class=\"form-label\">{{\n      'AbpIdentity::DisplayName:PhoneNumber' | abpLocalization\n    }}</label\n    ><input type=\"text\" id=\"phone-number\" class=\"form-control\" formControlName=\"phoneNumber\" />\n  </div>\n  <abp-button\n    buttonType=\"submit\"\n    iconClass=\"fa fa-check\"\n    buttonClass=\"btn btn-primary color-white\"\n    [loading]=\"inProgress\"\n    [disabled]=\"form?.invalid\"\n  >\n    {{ 'AbpIdentity::Save' | abpLocalization }}</abp-button\n  >\n</form>\n"]}
|
|
@@ -1,87 +1,87 @@
|
|
|
1
|
-
import { AccountService } from '@abp/ng.account.core/proxy';
|
|
2
|
-
import { AuthService, ConfigStateService } from '@abp/ng.core';
|
|
3
|
-
import { getPasswordValidators, ToasterService } from '@abp/ng.theme.shared';
|
|
4
|
-
import { Component, Injector } from '@angular/core';
|
|
5
|
-
import { FormBuilder, Validators } from '@angular/forms';
|
|
6
|
-
import { throwError } from 'rxjs';
|
|
7
|
-
import { catchError, finalize, switchMap } from 'rxjs/operators';
|
|
8
|
-
import { getRedirectUrl } from '../../utils/auth-utils';
|
|
9
|
-
import * as i0 from "@angular/core";
|
|
10
|
-
import * as i1 from "@angular/forms";
|
|
11
|
-
import * as i2 from "@abp/ng.account.core/proxy";
|
|
12
|
-
import * as i3 from "@abp/ng.core";
|
|
13
|
-
import * as i4 from "@abp/ng.theme.shared";
|
|
14
|
-
import * as i5 from "@angular/router";
|
|
15
|
-
import * as i6 from "@angular/common";
|
|
16
|
-
import * as i7 from "@ngx-validate/core";
|
|
17
|
-
const { maxLength, required, email } = Validators;
|
|
18
|
-
export class RegisterComponent {
|
|
19
|
-
constructor(fb, accountService, configState, toasterService, authService, injector) {
|
|
20
|
-
this.fb = fb;
|
|
21
|
-
this.accountService = accountService;
|
|
22
|
-
this.configState = configState;
|
|
23
|
-
this.toasterService = toasterService;
|
|
24
|
-
this.authService = authService;
|
|
25
|
-
this.injector = injector;
|
|
26
|
-
this.isSelfRegistrationEnabled = true;
|
|
27
|
-
this.authWrapperKey = "Account.AuthWrapperComponent" /* AuthWrapper */;
|
|
28
|
-
}
|
|
29
|
-
ngOnInit() {
|
|
30
|
-
this.init();
|
|
31
|
-
this.buildForm();
|
|
32
|
-
}
|
|
33
|
-
init() {
|
|
34
|
-
this.isSelfRegistrationEnabled =
|
|
35
|
-
(this.configState.getSetting('Abp.Account.IsSelfRegistrationEnabled') || '').toLowerCase() !==
|
|
36
|
-
'false';
|
|
37
|
-
if (!this.isSelfRegistrationEnabled) {
|
|
38
|
-
this.toasterService.warn({
|
|
39
|
-
key: 'AbpAccount::SelfRegistrationDisabledMessage',
|
|
40
|
-
defaultValue: 'Self registration is disabled.',
|
|
41
|
-
}, null, { life: 10000 });
|
|
42
|
-
return;
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
buildForm() {
|
|
46
|
-
this.form = this.fb.group({
|
|
47
|
-
username: ['', [required, maxLength(255)]],
|
|
48
|
-
password: ['', [required, ...getPasswordValidators(this.injector)]],
|
|
49
|
-
email: ['', [required, email]],
|
|
50
|
-
});
|
|
51
|
-
}
|
|
52
|
-
onSubmit() {
|
|
53
|
-
if (this.form.invalid)
|
|
54
|
-
return;
|
|
55
|
-
this.inProgress = true;
|
|
56
|
-
const newUser = {
|
|
57
|
-
userName: this.form.get('username').value,
|
|
58
|
-
password: this.form.get('password').value,
|
|
59
|
-
emailAddress: this.form.get('email').value,
|
|
60
|
-
appName: 'Angular',
|
|
61
|
-
};
|
|
62
|
-
this.accountService
|
|
63
|
-
.register(newUser)
|
|
64
|
-
.pipe(switchMap(() => this.authService.login({
|
|
65
|
-
username: newUser.userName,
|
|
66
|
-
password: newUser.password,
|
|
67
|
-
redirectUrl: getRedirectUrl(this.injector),
|
|
68
|
-
})), catchError(err => {
|
|
69
|
-
var _a, _b;
|
|
70
|
-
this.toasterService.error(((_a = err.error) === null || _a === void 0 ? void 0 : _a.error_description) ||
|
|
71
|
-
((_b = err.error) === null || _b === void 0 ? void 0 : _b.error.message) ||
|
|
72
|
-
'AbpAccount::DefaultErrorMessage', null, { life: 7000 });
|
|
73
|
-
return throwError(err);
|
|
74
|
-
}), finalize(() => (this.inProgress = false)))
|
|
75
|
-
.subscribe();
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
RegisterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: RegisterComponent, deps: [{ token: i1.FormBuilder }, { token: i2.AccountService }, { token: i3.ConfigStateService }, { token: i4.ToasterService }, { token: i3.AuthService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
|
|
79
|
-
RegisterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.13", type: RegisterComponent, selector: "abp-register", ngImport: i0, template: "<h4>{{ 'AbpAccount::Register' | abpLocalization }}</h4>\
|
|
80
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: RegisterComponent, decorators: [{
|
|
81
|
-
type: Component,
|
|
82
|
-
args: [{
|
|
83
|
-
selector: 'abp-register',
|
|
84
|
-
templateUrl: './register.component.html',
|
|
85
|
-
}]
|
|
86
|
-
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.AccountService }, { type: i3.ConfigStateService }, { type: i4.ToasterService }, { type: i3.AuthService }, { type: i0.Injector }]; } });
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"register.component.js","sourceRoot":"","sources":["../../../../../../../packages/account/src/lib/components/register/register.component.ts","../../../../../../../packages/account/src/lib/components/register/register.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AccountService, RegisterDto } from '@abp/ng.account.core/proxy';\r\nimport { AuthService, ConfigStateService } from '@abp/ng.core';\r\nimport { getPasswordValidators, ToasterService } from '@abp/ng.theme.shared';\r\nimport { Component, Injector, OnInit } from '@angular/core';\r\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport { throwError } from 'rxjs';\r\nimport { catchError, finalize, switchMap } from 'rxjs/operators';\r\nimport { eAccountComponents } from '../../enums/components';\r\nimport { getRedirectUrl } from '../../utils/auth-utils';\r\n\r\nconst { maxLength, required, email } = Validators;\r\n\r\n@Component({\r\n  selector: 'abp-register',\r\n  templateUrl: './register.component.html',\r\n})\r\nexport class RegisterComponent implements OnInit {\r\n  form: FormGroup;\r\n\r\n  inProgress: boolean;\r\n\r\n  isSelfRegistrationEnabled = true;\r\n\r\n  authWrapperKey = eAccountComponents.AuthWrapper;\r\n\r\n  constructor(\r\n    protected fb: FormBuilder,\r\n    protected accountService: AccountService,\r\n    protected configState: ConfigStateService,\r\n    protected toasterService: ToasterService,\r\n    protected authService: AuthService,\r\n    protected injector: Injector,\r\n  ) {}\r\n\r\n  ngOnInit() {\r\n    this.init();\r\n    this.buildForm();\r\n  }\r\n\r\n  protected init() {\r\n    this.isSelfRegistrationEnabled =\r\n      (this.configState.getSetting('Abp.Account.IsSelfRegistrationEnabled') || '').toLowerCase() !==\r\n      'false';\r\n\r\n    if (!this.isSelfRegistrationEnabled) {\r\n      this.toasterService.warn(\r\n        {\r\n          key: 'AbpAccount::SelfRegistrationDisabledMessage',\r\n          defaultValue: 'Self registration is disabled.',\r\n        },\r\n        null,\r\n        { life: 10000 },\r\n      );\r\n      return;\r\n    }\r\n  }\r\n\r\n  protected buildForm() {\r\n    this.form = this.fb.group({\r\n      username: ['', [required, maxLength(255)]],\r\n      password: ['', [required, ...getPasswordValidators(this.injector)]],\r\n      email: ['', [required, email]],\r\n    });\r\n  }\r\n\r\n  onSubmit() {\r\n    if (this.form.invalid) return;\r\n\r\n    this.inProgress = true;\r\n\r\n    const newUser = {\r\n      userName: this.form.get('username').value,\r\n      password: this.form.get('password').value,\r\n      emailAddress: this.form.get('email').value,\r\n      appName: 'Angular',\r\n    } as RegisterDto;\r\n\r\n    this.accountService\r\n      .register(newUser)\r\n      .pipe(\r\n        switchMap(() =>\r\n          this.authService.login({\r\n            username: newUser.userName,\r\n            password: newUser.password,\r\n            redirectUrl: getRedirectUrl(this.injector),\r\n          }),\r\n        ),\r\n        catchError(err => {\r\n          this.toasterService.error(\r\n            err.error?.error_description ||\r\n              err.error?.error.message ||\r\n              'AbpAccount::DefaultErrorMessage',\r\n            null,\r\n            { life: 7000 },\r\n          );\r\n\r\n          return throwError(err);\r\n        }),\r\n        finalize(() => (this.inProgress = false)),\r\n      )\r\n      .subscribe();\r\n  }\r\n}\r\n","<h4>{{ 'AbpAccount::Register' | abpLocalization }}</h4>\r\n<strong>\r\n  {{ 'AbpAccount::AlreadyRegistered' | abpLocalization }}\r\n  <a class=\"text-decoration-none\" routerLink=\"/account/login\">{{\r\n    'AbpAccount::Login' | abpLocalization\r\n  }}</a>\r\n</strong>\r\n<form\r\n  *ngIf=\"isSelfRegistrationEnabled\"\r\n  [formGroup]=\"form\"\r\n  (ngSubmit)=\"onSubmit()\"\r\n  validateOnSubmit\r\n  class=\"mt-4\"\r\n>\r\n  <div class=\"mb-3 form-group\">\r\n    <label for=\"input-user-name\" class=\"form-label\">{{\r\n      'AbpAccount::UserName' | abpLocalization\r\n    }}</label\r\n    ><span> * </span\r\n    ><input\r\n      autofocus\r\n      type=\"text\"\r\n      id=\"input-user-name\"\r\n      class=\"form-control\"\r\n      formControlName=\"username\"\r\n      autocomplete=\"username\"\r\n    />\r\n  </div>\r\n  <div class=\"mb-3 form-group\">\r\n    <label for=\"input-email-address\" class=\"form-label\">{{\r\n      'AbpAccount::EmailAddress' | abpLocalization\r\n    }}</label\r\n    ><span> * </span\r\n    ><input type=\"email\" id=\"input-email-address\" class=\"form-control\" formControlName=\"email\" />\r\n  </div>\r\n  <div class=\"mb-3 form-group\">\r\n    <label for=\"input-password\" class=\"form-label\">{{\r\n      'AbpAccount::Password' | abpLocalization\r\n    }}</label\r\n    ><span> * </span\r\n    ><input\r\n      type=\"password\"\r\n      id=\"input-password\"\r\n      class=\"form-control\"\r\n      formControlName=\"password\"\r\n      autocomplete=\"current-password\"\r\n    />\r\n  </div>\r\n  <abp-button\r\n    [loading]=\"inProgress\"\r\n    buttonType=\"submit\"\r\n    name=\"Action\"\r\n    buttonClass=\"btn-block btn-lg mt-3 btn btn-primary\"\r\n  >\r\n    {{ 'AbpAccount::Register' | abpLocalization }}\r\n  </abp-button>\r\n</form>\r\n"]}
|
|
1
|
+
import { AccountService } from '@abp/ng.account.core/proxy';
|
|
2
|
+
import { AuthService, ConfigStateService } from '@abp/ng.core';
|
|
3
|
+
import { getPasswordValidators, ToasterService } from '@abp/ng.theme.shared';
|
|
4
|
+
import { Component, Injector } from '@angular/core';
|
|
5
|
+
import { FormBuilder, Validators } from '@angular/forms';
|
|
6
|
+
import { throwError } from 'rxjs';
|
|
7
|
+
import { catchError, finalize, switchMap } from 'rxjs/operators';
|
|
8
|
+
import { getRedirectUrl } from '../../utils/auth-utils';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "@angular/forms";
|
|
11
|
+
import * as i2 from "@abp/ng.account.core/proxy";
|
|
12
|
+
import * as i3 from "@abp/ng.core";
|
|
13
|
+
import * as i4 from "@abp/ng.theme.shared";
|
|
14
|
+
import * as i5 from "@angular/router";
|
|
15
|
+
import * as i6 from "@angular/common";
|
|
16
|
+
import * as i7 from "@ngx-validate/core";
|
|
17
|
+
const { maxLength, required, email } = Validators;
|
|
18
|
+
export class RegisterComponent {
|
|
19
|
+
constructor(fb, accountService, configState, toasterService, authService, injector) {
|
|
20
|
+
this.fb = fb;
|
|
21
|
+
this.accountService = accountService;
|
|
22
|
+
this.configState = configState;
|
|
23
|
+
this.toasterService = toasterService;
|
|
24
|
+
this.authService = authService;
|
|
25
|
+
this.injector = injector;
|
|
26
|
+
this.isSelfRegistrationEnabled = true;
|
|
27
|
+
this.authWrapperKey = "Account.AuthWrapperComponent" /* AuthWrapper */;
|
|
28
|
+
}
|
|
29
|
+
ngOnInit() {
|
|
30
|
+
this.init();
|
|
31
|
+
this.buildForm();
|
|
32
|
+
}
|
|
33
|
+
init() {
|
|
34
|
+
this.isSelfRegistrationEnabled =
|
|
35
|
+
(this.configState.getSetting('Abp.Account.IsSelfRegistrationEnabled') || '').toLowerCase() !==
|
|
36
|
+
'false';
|
|
37
|
+
if (!this.isSelfRegistrationEnabled) {
|
|
38
|
+
this.toasterService.warn({
|
|
39
|
+
key: 'AbpAccount::SelfRegistrationDisabledMessage',
|
|
40
|
+
defaultValue: 'Self registration is disabled.',
|
|
41
|
+
}, null, { life: 10000 });
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
buildForm() {
|
|
46
|
+
this.form = this.fb.group({
|
|
47
|
+
username: ['', [required, maxLength(255)]],
|
|
48
|
+
password: ['', [required, ...getPasswordValidators(this.injector)]],
|
|
49
|
+
email: ['', [required, email]],
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
onSubmit() {
|
|
53
|
+
if (this.form.invalid)
|
|
54
|
+
return;
|
|
55
|
+
this.inProgress = true;
|
|
56
|
+
const newUser = {
|
|
57
|
+
userName: this.form.get('username').value,
|
|
58
|
+
password: this.form.get('password').value,
|
|
59
|
+
emailAddress: this.form.get('email').value,
|
|
60
|
+
appName: 'Angular',
|
|
61
|
+
};
|
|
62
|
+
this.accountService
|
|
63
|
+
.register(newUser)
|
|
64
|
+
.pipe(switchMap(() => this.authService.login({
|
|
65
|
+
username: newUser.userName,
|
|
66
|
+
password: newUser.password,
|
|
67
|
+
redirectUrl: getRedirectUrl(this.injector),
|
|
68
|
+
})), catchError(err => {
|
|
69
|
+
var _a, _b;
|
|
70
|
+
this.toasterService.error(((_a = err.error) === null || _a === void 0 ? void 0 : _a.error_description) ||
|
|
71
|
+
((_b = err.error) === null || _b === void 0 ? void 0 : _b.error.message) ||
|
|
72
|
+
'AbpAccount::DefaultErrorMessage', null, { life: 7000 });
|
|
73
|
+
return throwError(err);
|
|
74
|
+
}), finalize(() => (this.inProgress = false)))
|
|
75
|
+
.subscribe();
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
RegisterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: RegisterComponent, deps: [{ token: i1.FormBuilder }, { token: i2.AccountService }, { token: i3.ConfigStateService }, { token: i4.ToasterService }, { token: i3.AuthService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
|
|
79
|
+
RegisterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.13", type: RegisterComponent, selector: "abp-register", ngImport: i0, template: "<h4>{{ 'AbpAccount::Register' | abpLocalization }}</h4>\n<strong>\n {{ 'AbpAccount::AlreadyRegistered' | abpLocalization }}\n <a class=\"text-decoration-none\" routerLink=\"/account/login\">{{\n 'AbpAccount::Login' | abpLocalization\n }}</a>\n</strong>\n<form\n *ngIf=\"isSelfRegistrationEnabled\"\n [formGroup]=\"form\"\n (ngSubmit)=\"onSubmit()\"\n validateOnSubmit\n class=\"mt-4\"\n>\n <div class=\"mb-3 form-group\">\n <label for=\"input-user-name\" class=\"form-label\">{{\n 'AbpAccount::UserName' | abpLocalization\n }}</label\n ><span> * </span\n ><input\n autofocus\n type=\"text\"\n id=\"input-user-name\"\n class=\"form-control\"\n formControlName=\"username\"\n autocomplete=\"username\"\n />\n </div>\n <div class=\"mb-3 form-group\">\n <label for=\"input-email-address\" class=\"form-label\">{{\n 'AbpAccount::EmailAddress' | abpLocalization\n }}</label\n ><span> * </span\n ><input type=\"email\" id=\"input-email-address\" class=\"form-control\" formControlName=\"email\" />\n </div>\n <div class=\"mb-3 form-group\">\n <label for=\"input-password\" class=\"form-label\">{{\n 'AbpAccount::Password' | abpLocalization\n }}</label\n ><span> * </span\n ><input\n type=\"password\"\n id=\"input-password\"\n class=\"form-control\"\n formControlName=\"password\"\n autocomplete=\"current-password\"\n />\n </div>\n <abp-button\n [loading]=\"inProgress\"\n buttonType=\"submit\"\n name=\"Action\"\n buttonClass=\"btn-block btn-lg mt-3 btn btn-primary\"\n >\n {{ 'AbpAccount::Register' | abpLocalization }}\n </abp-button>\n</form>\n", components: [{ type: i4.ButtonComponent, selector: "abp-button", inputs: ["buttonId", "buttonClass", "buttonType", "iconClass", "loading", "disabled", "attributes"], outputs: ["click", "focus", "blur", "abpClick", "abpFocus", "abpBlur"] }], directives: [{ type: i5.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["routerLink", "target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i3.FormSubmitDirective, selector: "form[ngSubmit][formGroup]", inputs: ["debounce", "notValidateOnSubmit"], outputs: ["ngSubmit"] }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i7.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.AutofocusDirective, selector: "[autofocus]", inputs: ["autofocus"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["disabled", "formControlName", "ngModel"], outputs: ["ngModelChange"] }, { type: i7.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }], pipes: { "abpLocalization": i3.LocalizationPipe } });
|
|
80
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: RegisterComponent, decorators: [{
|
|
81
|
+
type: Component,
|
|
82
|
+
args: [{
|
|
83
|
+
selector: 'abp-register',
|
|
84
|
+
templateUrl: './register.component.html',
|
|
85
|
+
}]
|
|
86
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.AccountService }, { type: i3.ConfigStateService }, { type: i4.ToasterService }, { type: i3.AuthService }, { type: i0.Injector }]; } });
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"register.component.js","sourceRoot":"","sources":["../../../../../../../packages/account/src/lib/components/register/register.component.ts","../../../../../../../packages/account/src/lib/components/register/register.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AccountService, RegisterDto } from '@abp/ng.account.core/proxy';\nimport { AuthService, ConfigStateService } from '@abp/ng.core';\nimport { getPasswordValidators, ToasterService } from '@abp/ng.theme.shared';\nimport { Component, Injector, OnInit } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { throwError } from 'rxjs';\nimport { catchError, finalize, switchMap } from 'rxjs/operators';\nimport { eAccountComponents } from '../../enums/components';\nimport { getRedirectUrl } from '../../utils/auth-utils';\n\nconst { maxLength, required, email } = Validators;\n\n@Component({\n  selector: 'abp-register',\n  templateUrl: './register.component.html',\n})\nexport class RegisterComponent implements OnInit {\n  form: FormGroup;\n\n  inProgress: boolean;\n\n  isSelfRegistrationEnabled = true;\n\n  authWrapperKey = eAccountComponents.AuthWrapper;\n\n  constructor(\n    protected fb: FormBuilder,\n    protected accountService: AccountService,\n    protected configState: ConfigStateService,\n    protected toasterService: ToasterService,\n    protected authService: AuthService,\n    protected injector: Injector,\n  ) {}\n\n  ngOnInit() {\n    this.init();\n    this.buildForm();\n  }\n\n  protected init() {\n    this.isSelfRegistrationEnabled =\n      (this.configState.getSetting('Abp.Account.IsSelfRegistrationEnabled') || '').toLowerCase() !==\n      'false';\n\n    if (!this.isSelfRegistrationEnabled) {\n      this.toasterService.warn(\n        {\n          key: 'AbpAccount::SelfRegistrationDisabledMessage',\n          defaultValue: 'Self registration is disabled.',\n        },\n        null,\n        { life: 10000 },\n      );\n      return;\n    }\n  }\n\n  protected buildForm() {\n    this.form = this.fb.group({\n      username: ['', [required, maxLength(255)]],\n      password: ['', [required, ...getPasswordValidators(this.injector)]],\n      email: ['', [required, email]],\n    });\n  }\n\n  onSubmit() {\n    if (this.form.invalid) return;\n\n    this.inProgress = true;\n\n    const newUser = {\n      userName: this.form.get('username').value,\n      password: this.form.get('password').value,\n      emailAddress: this.form.get('email').value,\n      appName: 'Angular',\n    } as RegisterDto;\n\n    this.accountService\n      .register(newUser)\n      .pipe(\n        switchMap(() =>\n          this.authService.login({\n            username: newUser.userName,\n            password: newUser.password,\n            redirectUrl: getRedirectUrl(this.injector),\n          }),\n        ),\n        catchError(err => {\n          this.toasterService.error(\n            err.error?.error_description ||\n              err.error?.error.message ||\n              'AbpAccount::DefaultErrorMessage',\n            null,\n            { life: 7000 },\n          );\n\n          return throwError(err);\n        }),\n        finalize(() => (this.inProgress = false)),\n      )\n      .subscribe();\n  }\n}\n","<h4>{{ 'AbpAccount::Register' | abpLocalization }}</h4>\n<strong>\n  {{ 'AbpAccount::AlreadyRegistered' | abpLocalization }}\n  <a class=\"text-decoration-none\" routerLink=\"/account/login\">{{\n    'AbpAccount::Login' | abpLocalization\n  }}</a>\n</strong>\n<form\n  *ngIf=\"isSelfRegistrationEnabled\"\n  [formGroup]=\"form\"\n  (ngSubmit)=\"onSubmit()\"\n  validateOnSubmit\n  class=\"mt-4\"\n>\n  <div class=\"mb-3 form-group\">\n    <label for=\"input-user-name\" class=\"form-label\">{{\n      'AbpAccount::UserName' | abpLocalization\n    }}</label\n    ><span> * </span\n    ><input\n      autofocus\n      type=\"text\"\n      id=\"input-user-name\"\n      class=\"form-control\"\n      formControlName=\"username\"\n      autocomplete=\"username\"\n    />\n  </div>\n  <div class=\"mb-3 form-group\">\n    <label for=\"input-email-address\" class=\"form-label\">{{\n      'AbpAccount::EmailAddress' | abpLocalization\n    }}</label\n    ><span> * </span\n    ><input type=\"email\" id=\"input-email-address\" class=\"form-control\" formControlName=\"email\" />\n  </div>\n  <div class=\"mb-3 form-group\">\n    <label for=\"input-password\" class=\"form-label\">{{\n      'AbpAccount::Password' | abpLocalization\n    }}</label\n    ><span> * </span\n    ><input\n      type=\"password\"\n      id=\"input-password\"\n      class=\"form-control\"\n      formControlName=\"password\"\n      autocomplete=\"current-password\"\n    />\n  </div>\n  <abp-button\n    [loading]=\"inProgress\"\n    buttonType=\"submit\"\n    name=\"Action\"\n    buttonClass=\"btn-block btn-lg mt-3 btn btn-primary\"\n  >\n    {{ 'AbpAccount::Register' | abpLocalization }}\n  </abp-button>\n</form>\n"]}
|