2019-06-23 03:35:23 -07:00
< template >
< div v-if ="dialogVisible" >
< credentials -edit :dialogVisible ="credentialEditDialogVisible" @closeDialog ="closeCredentialEditDialog" @credentialsUpdated ="reloadCredentialList" @credentialsCreated ="reloadCredentialList" : setCredentialType = "editCredentials && editCredentials.type" :editCredentials ="editCredentials" > < / c r e d e n t i a l s - e d i t >
< el -dialog :visible ="dialogVisible" append -to -body width = "80%" title = "Credentials" :before-close ="closeDialog" >
< div class = "text-very-light" >
Your saved credentials :
< / div >
< el -button title = "Create New Credentials" class = "new-credentials-button" @click ="createCredential()" >
< font -awesome -icon icon = "plus" / >
< div class = "next-icon-text" >
Add New
< / div >
< / e l - b u t t o n >
< el -table :data ="credentials" : default -sort = " { prop : ' name ' , order : ' ascending ' } " stripe @row-click ="editCredential" max -height = " 450 " v-loading ="isDataLoading" >
< el -table -column property = "name" label = "Name" class -name = " clickable " sortable > < / e l - t a b l e - c o l u m n >
< el -table -column property = "type" label = "Type" class -name = " clickable " sortable >
< template slot -scope = " scope " >
{ { credentialTypeDisplayNames [ scope . row . type ] } }
< / template >
< / e l - t a b l e - c o l u m n >
< el -table -column property = "createdAt" label = "Created" class -name = " clickable " sortable > < / e l - t a b l e - c o l u m n >
< el -table -column property = "updatedAt" label = "Updated" class -name = " clickable " sortable > < / e l - t a b l e - c o l u m n >
< el -table -column
label = "Operations"
2020-01-10 12:26:06 -08:00
width = "120" >
2019-06-23 03:35:23 -07:00
< template slot -scope = " scope " >
< el -button title = "Edit Credentials" @click.stop ="editCredential(scope.row)" icon = "el-icon-edit" circle > < / e l - b u t t o n >
< el -button title = "Delete Credentials" @click.stop ="deleteCredential(scope.row)" type = "danger" icon = "el-icon-delete" circle > < / e l - b u t t o n >
< / template >
< / e l - t a b l e - c o l u m n >
< / e l - t a b l e >
< / e l - d i a l o g >
< / div >
< / template >
< script lang = "ts" >
import { restApi } from '@/components/mixins/restApi' ;
import { ICredentialsResponse } from '@/Interface' ;
import { nodeHelpers } from '@/components/mixins/nodeHelpers' ;
import { showMessage } from '@/components/mixins/showMessage' ;
import CredentialsEdit from '@/components/CredentialsEdit.vue' ;
import { genericHelpers } from '@/components/mixins/genericHelpers' ;
import mixins from 'vue-typed-mixins' ;
export default mixins (
genericHelpers ,
nodeHelpers ,
restApi ,
showMessage ,
) . extend ( {
name : 'CredentialsList' ,
props : [
'dialogVisible' ,
] ,
components : {
CredentialsEdit ,
} ,
data ( ) {
return {
credentialEditDialogVisible : false ,
credentialTypeDisplayNames : { } as { [ key : string ] : string ; } ,
credentials : [ ] as ICredentialsResponse [ ] ,
displayAddCredentials : false ,
editCredentials : null as ICredentialsResponse | null ,
isDataLoading : false ,
} ;
} ,
watch : {
2019-12-29 13:02:21 -08:00
dialogVisible ( newValue ) {
2019-06-23 03:35:23 -07:00
if ( newValue ) {
this . loadCredentials ( ) ;
this . loadCredentialTypes ( ) ;
}
} ,
} ,
methods : {
closeCredentialEditDialog ( ) {
this . credentialEditDialogVisible = false ;
} ,
closeDialog ( ) {
// Handle the close externally as the visible parameter is an external prop
// and is so not allowed to be changed here.
this . $emit ( 'closeDialog' ) ;
return false ;
} ,
createCredential ( ) {
this . editCredentials = null ;
this . credentialEditDialogVisible = true ;
} ,
editCredential ( credential : ICredentialsResponse ) {
const editCredentials = {
id : credential . id ,
name : credential . name ,
type : credential . type ,
} as ICredentialsResponse ;
this . editCredentials = editCredentials ;
this . credentialEditDialogVisible = true ;
} ,
reloadCredentialList ( ) {
this . loadCredentials ( ) ;
} ,
loadCredentialTypes ( ) {
if ( Object . keys ( this . credentialTypeDisplayNames ) . length !== 0 ) {
// Data is already loaded
return ;
}
if ( this . $store . getters . allCredentialTypes === null ) {
// Data is not ready yet to be loaded
return ;
}
for ( const credentialType of this . $store . getters . allCredentialTypes ) {
this . credentialTypeDisplayNames [ credentialType . name ] = credentialType . displayName ;
}
} ,
loadCredentials ( ) {
this . isDataLoading = true ;
try {
this . credentials = JSON . parse ( JSON . stringify ( this . $store . getters . allCredentials ) ) ;
} catch ( error ) {
2020-01-10 12:26:06 -08:00
this . $showError ( error , 'Proble loading credentials' , 'There was a problem loading the credentials:' ) ;
2019-06-23 03:35:23 -07:00
this . isDataLoading = false ;
return ;
}
this . credentials . forEach ( ( credentialData : ICredentialsResponse ) => {
credentialData . createdAt = this . convertToDisplayDate ( credentialData . createdAt as number ) ;
credentialData . updatedAt = this . convertToDisplayDate ( credentialData . updatedAt as number ) ;
} ) ;
this . isDataLoading = false ;
} ,
async deleteCredential ( credential : ICredentialsResponse ) {
const deleteConfirmed = await this . confirmMessage ( ` Are you sure that you want to delete the credentials " ${ credential . name } "? ` , 'Delete Credentials?' , 'warning' , 'Yes, delete!' ) ;
if ( deleteConfirmed === false ) {
return ;
}
try {
2019-12-29 13:02:21 -08:00
await this . restApi ( ) . deleteCredentials ( credential . id ! ) ;
2019-06-23 03:35:23 -07:00
} catch ( error ) {
this . $showError ( error , 'Problem deleting credentials' , 'There was a problem deleting the credentials:' ) ;
return ;
}
// Remove also from local store
this . $store . commit ( 'removeCredentials' , credential ) ;
// Now that the credentials got removed check if any nodes used them
this . updateNodesCredentialsIssues ( ) ;
this . $showMessage ( {
title : 'Credentials deleted' ,
message : ` The credential " ${ credential . name } " got deleted! ` ,
type : 'success' ,
} ) ;
// Refresh list
this . loadCredentials ( ) ;
} ,
} ,
} ) ;
< / script >
< style lang = "scss" >
. new - credentials - button {
float : right ;
position : relative ;
top : - 15 px ;
}
< / style >