Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 | 2x 2x 2x 2x 2x 55x 55x 55x 55x 55x 55x 1x 2x | /*
* Copyright 2021 Harness Inc. All rights reserved.
* Use of this source code is governed by the PolyForm Shield 1.0.0 license
* that can be found in the licenses directory at the root of this repository, also available at
* https://polyformproject.org/wp-content/uploads/2020/06/PolyForm-Shield-1.0.0.txt.
*/
import { Intent } from '@blueprintjs/core'
import { useConfirmationDialog } from '@wings-software/uicore'
import { useStrings } from 'framework/strings'
import { Service, useDeleteService } from 'services/lw'
interface UseDeleteServiceHookProps {
serviceData: Service
accountId: string
onSuccess?: (data: Service) => void
onFailure?: (error: any) => void
}
interface UseDeleteServiceHookReturn {
triggerDelete: () => void
}
const useDeleteServiceHook = (props: UseDeleteServiceHookProps): UseDeleteServiceHookReturn => {
const { accountId, serviceData } = props
const { getString } = useStrings()
const { mutate: deleteServiceApiCall } = useDeleteService({
account_id: accountId,
queryParams: {
accountIdentifier: accountId
}
})
const deleteRule = async (isConfirmed: boolean) => {
if (isConfirmed) {
try {
const deletionResponse: any = await deleteServiceApiCall(serviceData.id as number)
if (deletionResponse.success) {
props.onSuccess?.(serviceData)
} else {
props.onFailure?.(deletionResponse.errors?.join('\n'))
}
} catch (e) {
props.onFailure?.(e)
}
}
}
const { openDialog } = useConfirmationDialog({
titleText: getString('ce.co.autoStoppingRule.confirm.deleteServiceTitle', { name: serviceData.name }),
contentText: getString('ce.co.autoStoppingRule.confirm.deleteDialogText'),
confirmButtonText: getString('delete'),
cancelButtonText: getString('cancel'),
intent: Intent.DANGER,
onCloseDialog: deleteRule
})
return {
triggerDelete: () => openDialog()
}
}
export default useDeleteServiceHook
|