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.
633 lines
18 KiB
633 lines
18 KiB
5 years ago
|
import { Component, OnInit, Inject } from '@angular/core';
|
||
|
import {MatDialog, MatDialogRef, MAT_DIALOG_DATA} from '@angular/material/dialog';
|
||
|
import {FormControl} from '@angular/forms';
|
||
|
import { HttpClient } from '@angular/common/http';
|
||
|
import { CacheTokenService } from '../../http-interceptors/cache-token.service'
|
||
|
import format from 'date-fns/format';
|
||
|
import {MatTreeFlatDataSource, MatTreeFlattener} from '@angular/material/tree';
|
||
|
import {FlatTreeControl} from '@angular/cdk/tree';
|
||
|
import { TreeService } from '../../http-interceptors/tree.service'
|
||
|
import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar';
|
||
|
|
||
|
|
||
|
|
||
|
export interface roledata {
|
||
|
id: string,
|
||
|
name: string,//名称
|
||
|
order: number,
|
||
|
enabled: boolean,
|
||
|
creationTime: string
|
||
|
}
|
||
|
@Component({
|
||
|
selector: 'app-role',
|
||
|
templateUrl: './role.component.html',
|
||
|
styleUrls: ['./role.component.scss']
|
||
|
})
|
||
|
|
||
|
export class RoleComponent implements OnInit {
|
||
|
constructor(private http: HttpClient,public dialog: MatDialog,public createtime:CacheTokenService,private tree:TreeService,public snackBar: MatSnackBar) { }
|
||
|
displayedColumns: string[] = ['name','createtiome', 'edit'];
|
||
|
dataSource: any
|
||
|
|
||
|
public compare(property){
|
||
|
return function(a,b){
|
||
|
var value1 = a[property];
|
||
|
var value2 = b[property];
|
||
|
return value1 - value2;
|
||
|
}
|
||
|
}
|
||
|
//获取角色列表并且给排头和排尾赋是否为首尾
|
||
|
getlist(){
|
||
|
this.http.get('/api/Roles').subscribe( (data:Array<roledata>)=>{
|
||
|
this.dataSource = data
|
||
|
this.dataSource[0].isTop = true;
|
||
|
this.dataSource[this.dataSource.length-1].isBottom = true
|
||
|
})
|
||
|
}
|
||
|
//初始化视图
|
||
|
ngOnInit() {
|
||
|
this.getlist()
|
||
|
}
|
||
|
//向上按钮
|
||
|
up(node){
|
||
|
let newdate = new Date();
|
||
|
let time = format(newdate, 'yyyy-MM-dd')
|
||
|
this.http.put(//把上一节点order换成点击的节点
|
||
|
`/api/Roles/${this.dataSource[node.order -1].id}`,
|
||
|
{
|
||
|
id:this.dataSource[node.order -1].id,
|
||
|
name: this.dataSource[node.order -1].name,
|
||
|
order: node.order,
|
||
|
enabled: true,
|
||
|
creationTime:time,
|
||
|
}
|
||
|
).subscribe(data=>{
|
||
|
this.getlist()
|
||
|
})
|
||
|
|
||
|
this.http.put(//把当前节点order换成上一点击的节点
|
||
|
`/api/Roles/${node.id}`,
|
||
|
{
|
||
|
id:node.id,
|
||
|
name: node.name,
|
||
|
order: node.order-1,
|
||
|
enabled: true,
|
||
|
creationTime:time,
|
||
|
}
|
||
|
).subscribe(data=>{
|
||
|
this.getlist()
|
||
|
})
|
||
|
|
||
|
}
|
||
|
//向下按钮
|
||
|
down(node){
|
||
|
let newdate = new Date();
|
||
|
let time = format(newdate, 'yyyy-MM-dd')
|
||
|
this.http.put(//把下一节点order换成点击的节点
|
||
|
`/api/Roles/${this.dataSource[node.order + 1].id}`,
|
||
|
{
|
||
|
id:this.dataSource[node.order + 1].id,
|
||
|
name: this.dataSource[node.order + 1].name,
|
||
|
order: node.order,
|
||
|
enabled: true,
|
||
|
creationTime:time,
|
||
|
}
|
||
|
).subscribe(data=>{
|
||
|
this.getlist()
|
||
|
})
|
||
|
|
||
|
this.http.put(//把当前节点order换成下一点击的节点
|
||
|
`/api/Roles/${node.id}`,
|
||
|
{
|
||
|
id:node.id,
|
||
|
name: node.name,
|
||
|
order: node.order + 1,
|
||
|
enabled: true,
|
||
|
creationTime:time,
|
||
|
}
|
||
|
).subscribe(data=>{
|
||
|
this.getlist()
|
||
|
})
|
||
|
}
|
||
|
//创建按钮并且弹出对话框
|
||
|
createuser(){
|
||
|
const dialogRef = this.dialog.open(CreateRole, {//调用open方法打开对话框并且携带参数过去
|
||
|
width: '600px',
|
||
|
height:'658px',
|
||
|
data: {name: this.createuser.name,data: this.dataSource,length:this.dataSource.length}
|
||
|
});
|
||
|
dialogRef.afterClosed().subscribe(
|
||
|
data=>{
|
||
|
this.getlist()
|
||
|
}
|
||
|
);
|
||
|
}
|
||
|
|
||
|
//删除按钮
|
||
|
deleteduser(roledata){
|
||
|
var isdeleted = confirm("确定要删除此用户吗?")
|
||
|
if(isdeleted){
|
||
|
//请求删除接口
|
||
|
this.http.delete(`/api/Roles/${roledata.id}`).subscribe( data=>{
|
||
|
this.getlist()
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
//编辑按钮
|
||
|
allot(roledata){
|
||
|
const dialogRef = this.dialog.open(EditRole, {//调用open方法打开对话框并且携带参数过去
|
||
|
width: '600px',
|
||
|
height:'658px',
|
||
|
data: {id:roledata.id,name:roledata.name,order:roledata.order}//把点击的id传过去
|
||
|
});
|
||
|
|
||
|
dialogRef.afterClosed().subscribe(
|
||
|
data=>{
|
||
|
this.getlist()
|
||
|
}
|
||
|
);
|
||
|
}
|
||
|
|
||
|
//启用或禁用按钮
|
||
|
open(roledata){
|
||
|
let newdate = new Date();
|
||
|
let time = format(newdate, 'yyyy-MM-dd')
|
||
|
this.http.put(
|
||
|
`/api/Roles/${roledata['id']}`,
|
||
|
{
|
||
|
id:roledata['id'],
|
||
|
name: roledata.name,
|
||
|
order: roledata.order,
|
||
|
enabled: !roledata.enabled,
|
||
|
creationTime: time,
|
||
|
}
|
||
|
).subscribe(
|
||
|
data=>{
|
||
|
this.getlist()
|
||
|
}
|
||
|
)
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
//创建角色组件
|
||
|
@Component({
|
||
|
selector: 'createrole',
|
||
|
templateUrl: './createrole.component.html',
|
||
|
styleUrls: ['./role.component.scss']
|
||
|
})
|
||
|
export class CreateRole {
|
||
|
private _transformer = (node: any, level: number) => {
|
||
|
return {
|
||
|
expandable: !!node.children && node.children.length > 0,
|
||
|
name: node.name,
|
||
|
level: level,
|
||
|
id:node.id
|
||
|
};
|
||
|
}
|
||
|
treeControl = new FlatTreeControl<any>(
|
||
|
node => node.level, node => node.expandable);
|
||
|
|
||
|
treeFlattener = new MatTreeFlattener(
|
||
|
this._transformer, node => node.level, node => node.expandable, node => node.children);
|
||
|
|
||
|
dataSource = new MatTreeFlatDataSource(this.treeControl, this.treeFlattener);
|
||
|
dataSource2 = new MatTreeFlatDataSource(this.treeControl, this.treeFlattener);
|
||
|
myControl = new FormControl();
|
||
|
//注入MatDialogRef,可以用来关闭对话框
|
||
|
//要访问对话框组件中的数据,必须使用MAT_DIALOG_DATA注入令牌
|
||
|
constructor(private http: HttpClient,public dialogRef: MatDialogRef<CreateRole>,@Inject(MAT_DIALOG_DATA) public data,private tree:TreeService,public snackBar: MatSnackBar) {}
|
||
|
olddata =[]
|
||
|
olddata2 = []
|
||
|
xxx = {}
|
||
|
jjj = {}
|
||
|
//用于存放选中的数组
|
||
|
checkedMap = {}
|
||
|
//初始化两棵tree
|
||
|
ngOnInit(){
|
||
|
this.http.get('/api/Permissions').subscribe((data: any[])=>{
|
||
|
this.olddata =data
|
||
|
this.dataSource.data = this.tree.toTree(data);
|
||
|
this.treeControl.expandAll()
|
||
|
this.dataSource.data.forEach(item=>{
|
||
|
if(item.children){
|
||
|
var childarr = []
|
||
|
item.children.forEach(n => {
|
||
|
childarr.push(n.id)
|
||
|
})
|
||
|
this.xxx[item.id] = childarr
|
||
|
}
|
||
|
})
|
||
|
|
||
|
})
|
||
|
|
||
|
this.http.get('/api/NavMenus').subscribe((data: any[])=>{
|
||
|
this.olddata2 =data
|
||
|
this.dataSource2.data = this.tree.toTree(data);
|
||
|
this.treeControl.expandAll()
|
||
|
this.dataSource2.data.forEach(item=>{
|
||
|
if(item.children){
|
||
|
var childarr = []
|
||
|
item.children.forEach(n => {
|
||
|
childarr.push(n.id)
|
||
|
})
|
||
|
this.jjj[item.id] = childarr
|
||
|
}
|
||
|
})
|
||
|
})
|
||
|
}
|
||
|
|
||
|
//选中后子节点默认选中
|
||
|
selectedAll(event, node){
|
||
|
this.olddata.forEach(item=>{
|
||
|
if(item.parentId == node.id){
|
||
|
this.checkedMap[item.id] = event.checked;
|
||
|
}
|
||
|
})
|
||
|
|
||
|
// console.log(this.olddata2,node )
|
||
|
var menus =[] //导航菜单可能有三级 用于存储第二级
|
||
|
//选中一级菜单
|
||
|
this.olddata2.forEach(item=>{
|
||
|
if(item.parentId == node.id){
|
||
|
this.checkedMap[item.id] = event.checked;
|
||
|
menus.push(item)
|
||
|
}
|
||
|
})
|
||
|
//将二级菜单也选中
|
||
|
menus.forEach(item=>{
|
||
|
if(item.children){
|
||
|
item.children.forEach(n => {
|
||
|
this.checkedMap[n.id] = event.checked;
|
||
|
});
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
|
||
|
//数据权限tree的全选功能
|
||
|
leftTreeAll(event,form){
|
||
|
const values = form.value;
|
||
|
for (let key in values) {
|
||
|
if(key.indexOf("second")){
|
||
|
this.checkedMap[key.split('.')[1]] = event.checked;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
//菜单权限tree的全选功能
|
||
|
rightTreeAll(event,form){
|
||
|
const values = form.value;
|
||
|
for (let key in values) {
|
||
|
if(key.indexOf("first")){
|
||
|
this.checkedMap[key.split('.')[1]] = event.checked;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
hasChild = (_: number, node: any) => node.expandable;
|
||
|
|
||
|
onNoClick(): void {
|
||
|
this.dialogRef.close();
|
||
|
}
|
||
|
//提交
|
||
|
onSubmit(value){
|
||
|
let newdate = new Date();
|
||
|
let time = format(newdate, 'yyyy-MM-dd')
|
||
|
this.http.post(
|
||
|
'/api/Roles',
|
||
|
{
|
||
|
id:"",
|
||
|
name: value.name,
|
||
|
order: this.data.data[this.data.data.length - 1].order + 1,
|
||
|
enabled: true,
|
||
|
creationTime: time,
|
||
|
}
|
||
|
).subscribe(
|
||
|
data=>{
|
||
|
var id = data['id']
|
||
|
// console.log(value)
|
||
|
var keydata = [] //菜单权限id集合
|
||
|
var keydata2 = [] //数据权限id集合
|
||
|
for(let i in value){
|
||
|
if(value[i]){
|
||
|
if(i.indexOf("first") && i!="name"){
|
||
|
keydata.push(i.split('.')[1])
|
||
|
}
|
||
|
if(i.indexOf("second") && i!="name"){
|
||
|
keydata2.push(i.split('.')[1])
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function includes(arr1, arr2) {
|
||
|
return arr2.every(val => arr1.includes(val));
|
||
|
}
|
||
|
const orginalList = [...keydata2];
|
||
|
orginalList.forEach((item) => { // forEach 里面 splice 有问题,详见 https://blog.csdn.net/qq_38128179/article/details/92798157
|
||
|
if (item in this.xxx) { // 根据 key,可以直接在 对象 里面获取数据
|
||
|
const datachildarrboxArr = this.xxx[item];
|
||
|
if (!includes(keydata2, datachildarrboxArr)) { // 如果不全部包含
|
||
|
keydata2.splice(keydata2.findIndex(items => items == item), 1);
|
||
|
}
|
||
|
}
|
||
|
});
|
||
|
|
||
|
this.http.post(
|
||
|
`/api/Roles/${id}/Permissions`,
|
||
|
keydata2
|
||
|
).subscribe(
|
||
|
data=>{
|
||
|
this.http.post(
|
||
|
`/api/Roles/${id}/NavMenus`,
|
||
|
keydata
|
||
|
).subscribe(
|
||
|
data=>{
|
||
|
this.dialogRef.close();
|
||
|
const config = new MatSnackBarConfig();
|
||
|
config.verticalPosition = 'top';
|
||
|
config.duration = 3000
|
||
|
this.snackBar.open('创建成功','确定',config);
|
||
|
},
|
||
|
err=>{
|
||
|
this.dialogRef.close();
|
||
|
const config = new MatSnackBarConfig();
|
||
|
config.verticalPosition = 'top';
|
||
|
config.duration = 3000
|
||
|
this.snackBar.open('创建菜单权限失败','确定',config);
|
||
|
}
|
||
|
)
|
||
|
},
|
||
|
err=>{
|
||
|
this.dialogRef.close();
|
||
|
const config = new MatSnackBarConfig();
|
||
|
config.verticalPosition = 'top';
|
||
|
config.duration = 3000
|
||
|
this.snackBar.open('创建数据权限失败','确定',config);
|
||
|
}
|
||
|
)
|
||
|
|
||
|
},
|
||
|
err=>{
|
||
|
const config = new MatSnackBarConfig();
|
||
|
config.verticalPosition = 'top';
|
||
|
config.duration = 3000
|
||
|
this.snackBar.open('角色名称不符合规范','确定',config);
|
||
|
}
|
||
|
)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
//编辑组件
|
||
|
@Component({
|
||
|
selector: 'editrole',
|
||
|
templateUrl: './editrole.component.html',
|
||
|
styleUrls: ['./role.component.scss']
|
||
|
})
|
||
|
export class EditRole {
|
||
|
private _transformer = (node: any, level: number) => {
|
||
|
return {
|
||
|
expandable: !!node.children && node.children.length > 0,
|
||
|
name: node.name,
|
||
|
level: level,
|
||
|
id:node.id,
|
||
|
children:node.children
|
||
|
};
|
||
|
}
|
||
|
treeControl = new FlatTreeControl<any>(
|
||
|
node => node.level, node => node.expandable);
|
||
|
|
||
|
treeFlattener = new MatTreeFlattener(
|
||
|
this._transformer, node => node.level, node => node.expandable, node => node.children);
|
||
|
|
||
|
dataSource = new MatTreeFlatDataSource(this.treeControl, this.treeFlattener);
|
||
|
dataSource2 = new MatTreeFlatDataSource(this.treeControl, this.treeFlattener);
|
||
|
|
||
|
myControl = new FormControl();
|
||
|
//注入MatDialogRef,可以用来关闭对话框
|
||
|
//要访问对话框组件中的数据,必须使用MAT_DIALOG_DATA注入令牌
|
||
|
constructor(private http: HttpClient,public dialogRef: MatDialogRef<EditRole>,public snackBar: MatSnackBar,@Inject(MAT_DIALOG_DATA) public data,private tree:TreeService) {}
|
||
|
|
||
|
olddata =[] //原始所有--数据权限
|
||
|
olddata2 =[] //原始所有--菜单权限
|
||
|
newdata = []
|
||
|
newdata2 = []
|
||
|
placeholdername = this.data.name
|
||
|
datachildarrbox = {} //数据权限存放有children的 父id:子id1 子id2 子id3
|
||
|
menuchildarrbox = {} //菜单权限存放有children的 父id:子id1 子id2 子id3
|
||
|
checkedMap = {}
|
||
|
ngOnInit(){
|
||
|
//获得角色的数据权限,选中的checked为true
|
||
|
this.http.get(`/api/Roles/${this.data.id}/Permissions`).subscribe((data: any[])=>{
|
||
|
this.olddata =data
|
||
|
this.newdata = this.tree.toTree(this.olddata)
|
||
|
|
||
|
//如果子节点存在选中则父节点默认选中
|
||
|
this.newdata.forEach(item=>{
|
||
|
if(item.children){
|
||
|
item.children.forEach(element => {
|
||
|
if(element.checked){
|
||
|
this.checkedMap[item.id] = true
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
})
|
||
|
|
||
|
data.forEach(item=>{
|
||
|
if(item.checked){
|
||
|
this.checkedMap[item.id] = true;
|
||
|
}
|
||
|
|
||
|
})
|
||
|
this.dataSource.data = this.newdata;
|
||
|
this.treeControl.expandAll()
|
||
|
this.dataSource.data.forEach(item=>{
|
||
|
if(item.children){
|
||
|
var childarr = []
|
||
|
item.children.forEach(n => {
|
||
|
childarr.push(n.id)
|
||
|
})
|
||
|
this.datachildarrbox[item.id] = childarr
|
||
|
}
|
||
|
})
|
||
|
})
|
||
|
|
||
|
|
||
|
//获得角色的菜单权限,选中的checked为true
|
||
|
this.http.get(`/api/Roles/${this.data.id}/NavMenus`).subscribe((data: any[])=>{
|
||
|
this.olddata2 =data
|
||
|
this.newdata2 = this.tree.toTree(this.olddata2)
|
||
|
data.forEach(item => {
|
||
|
if(item.checked){
|
||
|
this.checkedMap[item.id] = item.checked;
|
||
|
}
|
||
|
});
|
||
|
|
||
|
this.dataSource2.data = this.newdata2;
|
||
|
this.treeControl.expandAll()
|
||
|
|
||
|
this.dataSource2.data.forEach(item=>{
|
||
|
if(item.children){
|
||
|
var childarr = []
|
||
|
item.children.forEach(n => {
|
||
|
childarr.push(n.id)
|
||
|
})
|
||
|
this.menuchildarrbox[item.id] = childarr
|
||
|
}
|
||
|
})
|
||
|
})
|
||
|
}
|
||
|
|
||
|
//选中对应小组
|
||
|
selectedAll(event, node){
|
||
|
this.olddata.forEach(item=>{
|
||
|
if(item.parentId == node.id){
|
||
|
this.checkedMap[item.id] = event.checked;
|
||
|
}
|
||
|
})
|
||
|
// console.log(this.olddata2,node )
|
||
|
var menus =[] //导航菜单可能有三级 用于存储第二级
|
||
|
//选中一级菜单
|
||
|
this.olddata2.forEach(item=>{
|
||
|
if(item.parentId == node.id){
|
||
|
this.checkedMap[item.id] = event.checked;
|
||
|
menus.push(item)
|
||
|
}
|
||
|
})
|
||
|
//将二级菜单也选中
|
||
|
menus.forEach(item=>{
|
||
|
if(item.children){
|
||
|
item.children.forEach(n => {
|
||
|
this.checkedMap[n.id] = event.checked;
|
||
|
});
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
|
||
|
hasChild = (_: number, node: any) => node.expandable;
|
||
|
|
||
|
onNoClick(): void {
|
||
|
this.dialogRef.close();
|
||
|
}
|
||
|
|
||
|
|
||
|
onSubmit(value){
|
||
|
var keydata = [] //存储选中的菜单权限
|
||
|
var keydata2 = [] //存储选中的数据权限
|
||
|
|
||
|
for(let i in value){
|
||
|
if(value[i]){
|
||
|
if(i.indexOf("first") && i!="name" && i!="order"){
|
||
|
keydata.push(i.split('.')[1])
|
||
|
}
|
||
|
if(i.indexOf("second") && i!="name" && i!="order"){
|
||
|
keydata2.push(i.split('.')[1])
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
let newdate = new Date();
|
||
|
let time = format(newdate, 'yyyy-MM-dd')
|
||
|
if(this.data['id'] != "0" && this.data['id'] != "1"){
|
||
|
this.http.put(
|
||
|
`/api/Roles/${this.data['id']}`,
|
||
|
{
|
||
|
id:this.data['id'],
|
||
|
name: value.name,
|
||
|
order: this.data.order,
|
||
|
enabled: true,
|
||
|
creationTime:time,
|
||
|
}
|
||
|
).subscribe(data=>{
|
||
|
|
||
|
},
|
||
|
err=>{
|
||
|
const config = new MatSnackBarConfig();
|
||
|
config.verticalPosition = 'top';
|
||
|
config.duration = 3000
|
||
|
this.snackBar.open('修改角色姓名请求失败','确定',config);
|
||
|
})
|
||
|
function includes(arr1, arr2) {
|
||
|
return arr2.every(val => arr1.includes(val));
|
||
|
}
|
||
|
const orginalList = [...keydata2];
|
||
|
orginalList.forEach((item) => { // forEach 里面 splice 有问题,详见 https://blog.csdn.net/qq_38128179/article/details/92798157
|
||
|
if (item in this.datachildarrbox) { // 根据 key,可以直接在 对象 里面获取数据
|
||
|
const datachildarrboxArr = this.datachildarrbox[item];
|
||
|
if (!includes(keydata2, datachildarrboxArr)) { // 如果不全部包含
|
||
|
keydata2.splice(keydata2.findIndex(items => items == item), 1);
|
||
|
}
|
||
|
}
|
||
|
});
|
||
|
this.http.post(
|
||
|
`/api/Roles/${this.data.id}/Permissions`,
|
||
|
keydata2
|
||
|
).subscribe(data=>{
|
||
|
|
||
|
},
|
||
|
err=>{
|
||
|
const config = new MatSnackBarConfig();
|
||
|
config.verticalPosition = 'top';
|
||
|
config.duration = 3000
|
||
|
this.snackBar.open('分配数据权限请求失败','确定',config);
|
||
|
})
|
||
|
}
|
||
|
this.http.post(
|
||
|
`/api/Roles/${this.data.id}/NavMenus`,
|
||
|
keydata
|
||
|
).subscribe(
|
||
|
data=>{
|
||
|
this.dialogRef.close();
|
||
|
const config = new MatSnackBarConfig();
|
||
|
config.verticalPosition = 'top';
|
||
|
config.duration = 3000
|
||
|
this.snackBar.open('编辑成功','确定',config);
|
||
|
},
|
||
|
err=>{
|
||
|
this.dialogRef.close();
|
||
|
const config = new MatSnackBarConfig();
|
||
|
config.verticalPosition = 'top';
|
||
|
config.duration = 3000
|
||
|
this.snackBar.open('分配菜单权限失败','确定',config);
|
||
|
}
|
||
|
)
|
||
|
// this.http.put(
|
||
|
// `/api/Roles/${this.data['id']}`,
|
||
|
// {
|
||
|
// id:this.data['id'],
|
||
|
// name: value.name,
|
||
|
// order: this.data.order,
|
||
|
// enabled: true,
|
||
|
// creationTime:time,
|
||
|
// }
|
||
|
// ).subscribe(
|
||
|
// data=>{
|
||
|
|
||
|
|
||
|
|
||
|
// },
|
||
|
// err=>{
|
||
|
// const config = new MatSnackBarConfig();
|
||
|
// config.verticalPosition = 'top';
|
||
|
// config.duration = 3000
|
||
|
// this.snackBar.open('名称格式不正确','确定',config);
|
||
|
// }
|
||
|
// )
|
||
|
|
||
|
|
||
|
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|