Skip to content

Commit

Permalink
Add the ability to delete a template
Browse files Browse the repository at this point in the history
Co-authored-by: Alirie Gray <[email protected]>
  • Loading branch information
Palakp41 and AlirieGray committed Mar 26, 2019
1 parent 949d7bc commit 1e1f57d
Show file tree
Hide file tree
Showing 8 changed files with 102 additions and 25 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
1. [12826](https://github.com/influxdata/influxdb/pull/12826): Enable copying error messages to the clipboard from dashboard cells
1. [12876](https://github.com/influxdata/influxdb/pull/12876): Add the ability to update token's status in Token list
1. [12821](https://github.com/influxdata/influxdb/pull/12821): Allow variables to be re-ordered within control bar on a dashboard.
1. [12888](https://github.com/influxdata/influxdb/pull/12888): Add the ability to delete a template

### Bug Fixes

Expand Down
6 changes: 3 additions & 3 deletions ui/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion ui/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -137,7 +137,7 @@
},
"dependencies": {
"@influxdata/clockface": "0.0.5",
"@influxdata/influx": "0.2.48",
"@influxdata/influx": "0.2.49",
"@influxdata/react-custom-scrollbars": "4.3.8",
"axios": "^0.18.0",
"babel-polyfill": "^6.26.0",
Expand Down
10 changes: 10 additions & 0 deletions ui/src/shared/copy/notifications.ts
Original file line number Diff line number Diff line change
Expand Up @@ -845,6 +845,16 @@ export const createTemplateFailed = (error: string): Notification => ({
message: `Failed to export resource as template: ${error}`,
})

export const deleteTemplateFailed = (error: string): Notification => ({
...defaultErrorNotification,
message: `Failed to delete template: ${error}`,
})

export const deleteTemplateSuccess = (): Notification => ({
...defaultSuccessNotification,
message: 'Template was deleted successfully',
})

export const resourceSavedAsTemplate = (
resourceName: string
): Notification => ({
Expand Down
35 changes: 33 additions & 2 deletions ui/src/templates/actions/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,12 +21,14 @@ export enum ActionTypes {
PopulateTemplateSummaries = 'POPULATE_TEMPLATE_SUMMARIES',
SetTemplatesStatus = 'SET_TEMPLATES_STATUS',
SetExportTemplate = 'SET_EXPORT_TEMPLATE',
RemoveTemplateSummary = 'REMOVE_TEMPLATE_SUMMARY',
}

export type Actions =
| PopulateTemplateSummaries
| SetTemplatesStatus
| SetExportTemplate
| RemoveTemplateSummary

export interface PopulateTemplateSummaries {
type: ActionTypes.PopulateTemplateSummaries
Expand Down Expand Up @@ -72,8 +74,14 @@ export const getTemplatesForOrg = (orgName: string) => async dispatch => {
dispatch(populateTemplateSummaries(items))
}

export const createTemplate = async (template: DocumentCreate) => {
await client.templates.create(template)
export const createTemplate = (template: DocumentCreate) => async dispatch => {
try {
await client.templates.create(template)
dispatch(notify(copy.importTemplateSucceeded()))
} catch (e) {
console.error(e)
dispatch(notify(copy.importTemplateFailed(e)))
}
}

export const convertToTemplate = (id: string) => async (
Expand All @@ -95,3 +103,26 @@ export const convertToTemplate = (id: string) => async (
export const clearExportTemplate = () => async dispatch => {
dispatch(setExportTemplate(RemoteDataState.NotStarted, null))
}

interface RemoveTemplateSummary {
type: ActionTypes.RemoveTemplateSummary
payload: {templateID: string}
}

const removeTemplateSummary = (templateID: string): RemoveTemplateSummary => ({
type: ActionTypes.RemoveTemplateSummary,
payload: {templateID},
})

export const deleteTemplate = (templateID: string) => async (
dispatch
): Promise<void> => {
try {
await client.templates.delete(templateID)
dispatch(removeTemplateSummary(templateID))
dispatch(notify(copy.deleteTemplateSuccess()))
} catch (e) {
console.error(e)
dispatch(notify(copy.deleteTemplateFailed(e)))
}
}
43 changes: 39 additions & 4 deletions ui/src/templates/components/TemplateCard.tsx
Original file line number Diff line number Diff line change
@@ -1,23 +1,32 @@
// Libraries
import React, {PureComponent, MouseEvent} from 'react'
import {connect} from 'react-redux'
import {withRouter, WithRouterProps} from 'react-router'

// Components
import {ResourceList} from 'src/clockface'
import {ResourceList, Context, IconFont} from 'src/clockface'

// Actions
import {deleteTemplate} from 'src/templates/actions'

// Types
import {TemplateSummary} from '@influxdata/influx'
import {ComponentColor} from '@influxdata/clockface'

// Constants
import {DEFAULT_TEMPLATE_NAME} from 'src/templates/constants'

interface Props {
interface OwnProps {
template: TemplateSummary
onFilterChange: (searchTerm: string) => void
}

interface DispatchProps {
onDelete: typeof deleteTemplate
}

type Props = DispatchProps & OwnProps

export class TemplateCard extends PureComponent<Props & WithRouterProps> {
public render() {
const {template} = this.props
Expand Down Expand Up @@ -45,7 +54,26 @@ export class TemplateCard extends PureComponent<Props & WithRouterProps> {
private doNothing = () => {}

private get contextMenu(): JSX.Element {
return null
const {
template: {id},
onDelete,
} = this.props
return (
<Context>
<Context.Menu
icon={IconFont.Trash}
color={ComponentColor.Danger}
testID="context-delete-menu"
>
<Context.Item
label="Delete"
action={onDelete}
value={id}
testID="context-delete-task"
/>
</Context.Menu>
</Context>
)
}

private handleNameClick = (e: MouseEvent<HTMLAnchorElement>) => {
Expand All @@ -63,4 +91,11 @@ export class TemplateCard extends PureComponent<Props & WithRouterProps> {
}
}

export default withRouter<Props>(TemplateCard)
const mdtp: DispatchProps = {
onDelete: deleteTemplate,
}

export default connect<{}, DispatchProps, OwnProps>(
null,
mdtp
)(withRouter<Props>(TemplateCard))
20 changes: 5 additions & 15 deletions ui/src/templates/components/TemplateImportOverlay.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,12 +12,6 @@ import {
} from 'src/templates/actions'
import {notify as notifyAction} from 'src/shared/actions/notifications'

//Constants
import {
importTemplateSucceeded,
importTemplateFailed,
} from 'src/shared/copy/notifications'

// Types
import {AppState, Organization} from 'src/types/v2'
import {RemoteDataState} from 'src/types'
Expand Down Expand Up @@ -58,16 +52,12 @@ class TemplateImportOverlay extends PureComponent<Props> {
private handleImportTemplate = () => async (
importString: string
): Promise<void> => {
const {createTemplate, notify} = this.props
const {createTemplate} = this.props
const {setTemplatesStatus} = this.props
try {
const template = JSON.parse(importString)
await createTemplate(template)
notify(importTemplateSucceeded())
setTemplatesStatus(RemoteDataState.NotStarted)
} catch (error) {
notify(importTemplateFailed(error))
}

const template = JSON.parse(importString)
await createTemplate(template)
setTemplatesStatus(RemoteDataState.NotStarted)

this.onDismiss()
}
Expand Down
10 changes: 10 additions & 0 deletions ui/src/templates/reducers/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,16 @@ const templatesReducer = (
}
return
}

case ActionTypes.RemoveTemplateSummary: {
const {templateID} = action.payload
const {items} = draftState
draftState.items = items.filter(l => {
return l.id !== templateID
})

return
}
}
})

Expand Down

0 comments on commit 1e1f57d

Please sign in to comment.