mirror of https://github.com/abpframework/abp
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
216 lines
20 KiB
216 lines
20 KiB
/**
|
|
* @fileoverview added by tsickle
|
|
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
*/
|
|
import * as tslib_1 from "tslib";
|
|
import { ConfirmationService } from '@abp/ng.theme.shared';
|
|
import { Component, TemplateRef, ViewChild } from '@angular/core';
|
|
import { FormBuilder, Validators, FormControl } from '@angular/forms';
|
|
import { Select, Store } from '@ngxs/store';
|
|
import { Observable } from 'rxjs';
|
|
import { finalize, pluck } from 'rxjs/operators';
|
|
import { CreateRole, DeleteRole, GetRoleById, GetRoles, UpdateRole } from '../../actions/identity.actions';
|
|
import { IdentityState } from '../../states/identity.state';
|
|
export class RolesComponent {
|
|
/**
|
|
* @param {?} confirmationService
|
|
* @param {?} fb
|
|
* @param {?} store
|
|
*/
|
|
constructor(confirmationService, fb, store) {
|
|
this.confirmationService = confirmationService;
|
|
this.fb = fb;
|
|
this.store = store;
|
|
this.visiblePermissions = false;
|
|
this.pageQuery = {
|
|
sorting: 'name',
|
|
};
|
|
this.loading = false;
|
|
this.modalBusy = false;
|
|
this.sortOrder = 'asc';
|
|
}
|
|
/**
|
|
* @param {?} value
|
|
* @return {?}
|
|
*/
|
|
onSearch(value) {
|
|
this.pageQuery.filter = value;
|
|
this.get();
|
|
}
|
|
/**
|
|
* @return {?}
|
|
*/
|
|
createForm() {
|
|
this.form = this.fb.group({
|
|
name: new FormControl({ value: this.selected.name || '', disabled: this.selected.isStatic }, [
|
|
Validators.required,
|
|
Validators.maxLength(256),
|
|
]),
|
|
isDefault: [this.selected.isDefault || false],
|
|
isPublic: [this.selected.isPublic || false],
|
|
});
|
|
}
|
|
/**
|
|
* @return {?}
|
|
*/
|
|
openModal() {
|
|
this.createForm();
|
|
this.isModalVisible = true;
|
|
}
|
|
/**
|
|
* @return {?}
|
|
*/
|
|
onAdd() {
|
|
this.selected = (/** @type {?} */ ({}));
|
|
this.openModal();
|
|
}
|
|
/**
|
|
* @param {?} id
|
|
* @return {?}
|
|
*/
|
|
onEdit(id) {
|
|
this.store
|
|
.dispatch(new GetRoleById(id))
|
|
.pipe(pluck('IdentityState', 'selectedRole'))
|
|
.subscribe((/**
|
|
* @param {?} selectedRole
|
|
* @return {?}
|
|
*/
|
|
selectedRole => {
|
|
this.selected = selectedRole;
|
|
this.openModal();
|
|
}));
|
|
}
|
|
/**
|
|
* @return {?}
|
|
*/
|
|
save() {
|
|
if (!this.form.valid)
|
|
return;
|
|
this.modalBusy = true;
|
|
this.store
|
|
.dispatch(this.selected.id
|
|
? new UpdateRole(Object.assign({}, this.form.value, { id: this.selected.id }))
|
|
: new CreateRole(this.form.value))
|
|
.subscribe((/**
|
|
* @return {?}
|
|
*/
|
|
() => {
|
|
this.modalBusy = false;
|
|
this.isModalVisible = false;
|
|
}));
|
|
}
|
|
/**
|
|
* @param {?} id
|
|
* @param {?} name
|
|
* @return {?}
|
|
*/
|
|
delete(id, name) {
|
|
this.confirmationService
|
|
.warn('AbpIdentity::RoleDeletionConfirmationMessage', 'AbpIdentity::AreYouSure', {
|
|
messageLocalizationParams: [name],
|
|
})
|
|
.subscribe((/**
|
|
* @param {?} status
|
|
* @return {?}
|
|
*/
|
|
(status) => {
|
|
if (status === "confirm" /* confirm */) {
|
|
this.store.dispatch(new DeleteRole(id));
|
|
}
|
|
}));
|
|
}
|
|
/**
|
|
* @param {?} data
|
|
* @return {?}
|
|
*/
|
|
onPageChange(data) {
|
|
this.pageQuery.skipCount = data.first;
|
|
this.pageQuery.maxResultCount = data.rows;
|
|
this.get();
|
|
}
|
|
/**
|
|
* @return {?}
|
|
*/
|
|
get() {
|
|
this.loading = true;
|
|
this.store
|
|
.dispatch(new GetRoles(this.pageQuery))
|
|
.pipe(finalize((/**
|
|
* @return {?}
|
|
*/
|
|
() => (this.loading = false))))
|
|
.subscribe();
|
|
}
|
|
/**
|
|
* @return {?}
|
|
*/
|
|
changeSortOrder() {
|
|
this.sortOrder = this.sortOrder.toLowerCase() === 'asc' ? 'desc' : 'asc';
|
|
}
|
|
}
|
|
RolesComponent.decorators = [
|
|
{ type: Component, args: [{
|
|
selector: 'abp-roles',
|
|
template: "<div class=\"row entry-row\">\n <div class=\"col-auto\">\n <h1 class=\"content-header-title\">{{ 'AbpIdentity::Roles' | abpLocalization }}</h1>\n </div>\n <div class=\"col\">\n <div class=\"text-lg-right pt-2\" id=\"AbpContentToolbar\">\n <button id=\"create-role\" class=\"btn btn-primary\" type=\"button\" (click)=\"onAdd()\">\n <i class=\"fa fa-plus mr-1\"></i> <span>{{ 'AbpIdentity::NewRole' | abpLocalization }}</span>\n </button>\n </div>\n </div>\n</div>\n\n<div id=\"identity-roles-wrapper\" class=\"card\">\n <div class=\"card-body\">\n <div id=\"data-tables-table-filter\" class=\"data-tables-filter\">\n <label\n ><input\n type=\"search\"\n class=\"form-control form-control-sm\"\n [placeholder]=\"'AbpUi::PagerSearch' | abpLocalization\"\n (input.debounce)=\"onSearch($event.target.value)\"\n /></label>\n </div>\n <p-table\n *ngIf=\"[130, 200] as columnWidths\"\n [value]=\"data$ | async\"\n [lazy]=\"true\"\n [lazyLoadOnInit]=\"false\"\n [paginator]=\"true\"\n [rows]=\"10\"\n [totalRecords]=\"totalCount$ | async\"\n [loading]=\"loading\"\n [resizableColumns]=\"true\"\n [scrollable]=\"true\"\n (onLazyLoad)=\"onPageChange($event)\"\n >\n <ng-template pTemplate=\"colgroup\">\n <colgroup>\n <col *ngFor=\"let width of columnWidths\" [ngStyle]=\"{ 'width.px': width }\" />\n </colgroup>\n </ng-template>\n <ng-template pTemplate=\"emptymessage\" let-columns>\n <tr\n abp-table-empty-message\n [attr.colspan]=\"columnWidths.length\"\n localizationResource=\"AbpIdentityServer\"\n localizationProp=\"NoDataAvailableInDatatable\"\n ></tr>\n </ng-template>\n <ng-template pTemplate=\"header\" let-columns>\n <tr>\n <th>{{ 'AbpIdentity::Actions' | abpLocalization }}</th>\n <th pResizableColumn (click)=\"changeSortOrder()\">\n {{ 'AbpIdentity::RoleName' | abpLocalization }}\n <span class=\"float-right\"\n ><i [ngClass]=\"['fa', sortOrder === 'desc' ? 'fa-sort-desc' : 'fa-sort-asc']\"></i\n ></span>\n </th>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"body\" let-data>\n <tr>\n <td>\n <div ngbDropdown container=\"body\" class=\"d-inline-block\">\n <button\n class=\"btn btn-primary btn-sm dropdown-toggle\"\n data-toggle=\"dropdown\"\n aria-haspopup=\"true\"\n ngbDropdownToggle\n >\n <i class=\"fa fa-cog mr-1\"></i>{{ 'AbpIdentity::Actions' | abpLocalization }}\n </button>\n <div ngbDropdownMenu>\n <button ngbDropdownItem (click)=\"onEdit(data.id)\">{{ 'AbpIdentity::Edit' | abpLocalization }}</button>\n <button ngbDropdownItem (click)=\"providerKey = data.name; visiblePermissions = true\">\n {{ 'AbpIdentity::Permissions' | abpLocalization }}\n </button>\n <button ngbDropdownItem (click)=\"delete(data.id, data.name)\">\n {{ 'AbpIdentity::Delete' | abpLocalization }}\n </button>\n </div>\n </div>\n </td>\n <td>{{ data.name }}</td>\n </tr>\n </ng-template>\n </p-table>\n </div>\n</div>\n\n<abp-modal size=\"md\" [(visible)]=\"isModalVisible\" [busy]=\"modalBusy\">\n <ng-template #abpHeader>\n <h3>{{ (selected?.id ? 'AbpIdentity::Edit' : 'AbpIdentity::NewRole') | abpLocalization }}</h3>\n </ng-template>\n\n <ng-template #abpBody>\n <form [formGroup]=\"form\" (ngSubmit)=\"save()\">\n <div class=\"form-group\">\n <label for=\"role-name\">{{ 'AbpIdentity::RoleName' | abpLocalization }}</label\n ><span> * </span>\n <input autofocus type=\"text\" id=\"role-name\" class=\"form-control\" formControlName=\"name\" />\n </div>\n\n <div class=\"custom-checkbox custom-control mb-2\">\n <input type=\"checkbox\" id=\"role-is-default\" class=\"custom-control-input\" formControlName=\"isDefault\" />\n <label class=\"custom-control-label\" for=\"role-is-default\">{{\n 'AbpIdentity::DisplayName:IsDefault' | abpLocalization\n }}</label>\n </div>\n\n <div class=\"custom-checkbox custom-control mb-2\">\n <input type=\"checkbox\" id=\"role-is-public\" class=\"custom-control-input\" formControlName=\"isPublic\" />\n <label class=\"custom-control-label\" for=\"role-is-public\">{{\n 'AbpIdentity::DisplayName:IsPublic' | abpLocalization\n }}</label>\n </div>\n </form>\n </ng-template>\n\n <ng-template #abpFooter>\n <button type=\"button\" class=\"btn btn-secondary\" #abpClose>\n {{ 'AbpIdentity::Cancel' | abpLocalization }}\n </button>\n <abp-button iconClass=\"fa fa-check\" (click)=\"save()\">{{ 'AbpIdentity::Save' | abpLocalization }}</abp-button>\n </ng-template>\n</abp-modal>\n\n<abp-permission-management\n [(visible)]=\"visiblePermissions\"\n providerName=\"Role\"\n [providerKey]=\"providerKey\"\n></abp-permission-management>\n"
|
|
}] }
|
|
];
|
|
/** @nocollapse */
|
|
RolesComponent.ctorParameters = () => [
|
|
{ type: ConfirmationService },
|
|
{ type: FormBuilder },
|
|
{ type: Store }
|
|
];
|
|
RolesComponent.propDecorators = {
|
|
modalContent: [{ type: ViewChild, args: ['modalContent', { static: false },] }]
|
|
};
|
|
tslib_1.__decorate([
|
|
Select(IdentityState.getRoles),
|
|
tslib_1.__metadata("design:type", Observable)
|
|
], RolesComponent.prototype, "data$", void 0);
|
|
tslib_1.__decorate([
|
|
Select(IdentityState.getRolesTotalCount),
|
|
tslib_1.__metadata("design:type", Observable)
|
|
], RolesComponent.prototype, "totalCount$", void 0);
|
|
if (false) {
|
|
/** @type {?} */
|
|
RolesComponent.prototype.data$;
|
|
/** @type {?} */
|
|
RolesComponent.prototype.totalCount$;
|
|
/** @type {?} */
|
|
RolesComponent.prototype.form;
|
|
/** @type {?} */
|
|
RolesComponent.prototype.selected;
|
|
/** @type {?} */
|
|
RolesComponent.prototype.isModalVisible;
|
|
/** @type {?} */
|
|
RolesComponent.prototype.visiblePermissions;
|
|
/** @type {?} */
|
|
RolesComponent.prototype.providerKey;
|
|
/** @type {?} */
|
|
RolesComponent.prototype.pageQuery;
|
|
/** @type {?} */
|
|
RolesComponent.prototype.loading;
|
|
/** @type {?} */
|
|
RolesComponent.prototype.modalBusy;
|
|
/** @type {?} */
|
|
RolesComponent.prototype.sortOrder;
|
|
/** @type {?} */
|
|
RolesComponent.prototype.modalContent;
|
|
/**
|
|
* @type {?}
|
|
* @private
|
|
*/
|
|
RolesComponent.prototype.confirmationService;
|
|
/**
|
|
* @type {?}
|
|
* @private
|
|
*/
|
|
RolesComponent.prototype.fb;
|
|
/**
|
|
* @type {?}
|
|
* @private
|
|
*/
|
|
RolesComponent.prototype.store;
|
|
}
|
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"roles.component.js","sourceRoot":"ng://@abp/ng.identity/","sources":["lib/components/roles/roles.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ABP } from '@abp/ng.core';\nimport { ConfirmationService, Toaster } from '@abp/ng.theme.shared';\nimport { Component, TemplateRef, ViewChild } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators, FormControl } from '@angular/forms';\nimport { Select, Store } from '@ngxs/store';\nimport { Observable } from 'rxjs';\nimport { finalize, pluck } from 'rxjs/operators';\nimport { CreateRole, DeleteRole, GetRoleById, GetRoles, UpdateRole } from '../../actions/identity.actions';\nimport { Identity } from '../../models/identity';\nimport { IdentityState } from '../../states/identity.state';\n\n@Component({\n  selector: 'abp-roles',\n  templateUrl: './roles.component.html',\n})\nexport class RolesComponent {\n  @Select(IdentityState.getRoles)\n  data$: Observable<Identity.RoleItem[]>;\n\n  @Select(IdentityState.getRolesTotalCount)\n  totalCount$: Observable<number>;\n\n  form: FormGroup;\n\n  selected: Identity.RoleItem;\n\n  isModalVisible: boolean;\n\n  visiblePermissions: boolean = false;\n\n  providerKey: string;\n\n  pageQuery: ABP.PageQueryParams = {\n    sorting: 'name',\n  };\n\n  loading: boolean = false;\n\n  modalBusy: boolean = false;\n\n  sortOrder: string = 'asc';\n\n  @ViewChild('modalContent', { static: false })\n  modalContent: TemplateRef<any>;\n\n  constructor(private confirmationService: ConfirmationService, private fb: FormBuilder, private store: Store) {}\n\n  onSearch(value) {\n    this.pageQuery.filter = value;\n    this.get();\n  }\n\n  createForm() {\n    this.form = this.fb.group({\n      name: new FormControl({ value: this.selected.name || '', disabled: this.selected.isStatic }, [\n        Validators.required,\n        Validators.maxLength(256),\n      ]),\n      isDefault: [this.selected.isDefault || false],\n      isPublic: [this.selected.isPublic || false],\n    });\n  }\n\n  openModal() {\n    this.createForm();\n    this.isModalVisible = true;\n  }\n\n  onAdd() {\n    this.selected = {} as Identity.RoleItem;\n    this.openModal();\n  }\n\n  onEdit(id: string) {\n    this.store\n      .dispatch(new GetRoleById(id))\n      .pipe(pluck('IdentityState', 'selectedRole'))\n      .subscribe(selectedRole => {\n        this.selected = selectedRole;\n        this.openModal();\n      });\n  }\n\n  save() {\n    if (!this.form.valid) return;\n    this.modalBusy = true;\n\n    this.store\n      .dispatch(\n        this.selected.id\n          ? new UpdateRole({ ...this.form.value, id: this.selected.id })\n          : new CreateRole(this.form.value),\n      )\n      .subscribe(() => {\n        this.modalBusy = false;\n        this.isModalVisible = false;\n      });\n  }\n\n  delete(id: string, name: string) {\n    this.confirmationService\n      .warn('AbpIdentity::RoleDeletionConfirmationMessage', 'AbpIdentity::AreYouSure', {\n        messageLocalizationParams: [name],\n      })\n      .subscribe((status: Toaster.Status) => {\n        if (status === Toaster.Status.confirm) {\n          this.store.dispatch(new DeleteRole(id));\n        }\n      });\n  }\n\n  onPageChange(data) {\n    this.pageQuery.skipCount = data.first;\n    this.pageQuery.maxResultCount = data.rows;\n\n    this.get();\n  }\n\n  get() {\n    this.loading = true;\n    this.store\n      .dispatch(new GetRoles(this.pageQuery))\n      .pipe(finalize(() => (this.loading = false)))\n      .subscribe();\n  }\n\n  changeSortOrder() {\n    this.sortOrder = this.sortOrder.toLowerCase() === 'asc' ? 'desc' : 'asc';\n  }\n}\n"]}
|