|
|
@@ -0,0 +1,153 @@
|
|
|
+import React from 'react';
|
|
|
+import { inject, observer } from 'mobx-react';
|
|
|
+import { toJS } from 'mobx';
|
|
|
+import PageHeader from 'app/core/components/PageHeader/PageHeader';
|
|
|
+import IContainerProps from 'app/containers/IContainerProps';
|
|
|
+import { getSnapshot } from 'mobx-state-tree';
|
|
|
+import appEvents from 'app/core/app_events';
|
|
|
+
|
|
|
+@inject('nav', 'folder', 'view')
|
|
|
+@observer
|
|
|
+export class FolderSettings extends React.Component<IContainerProps, any> {
|
|
|
+ formSnapshot: any;
|
|
|
+ dashboard: any;
|
|
|
+
|
|
|
+ constructor(props) {
|
|
|
+ super(props);
|
|
|
+ this.loadStore();
|
|
|
+ }
|
|
|
+
|
|
|
+ loadStore() {
|
|
|
+ const { nav, folder, view } = this.props;
|
|
|
+
|
|
|
+ return folder.load(view.routeParams.get('slug') as string).then(res => {
|
|
|
+ this.formSnapshot = getSnapshot(folder);
|
|
|
+ this.dashboard = res.dashboard;
|
|
|
+
|
|
|
+ return nav.initFolderNav(toJS(folder.folder), 'manage-folder-settings');
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ onTitleChange(evt) {
|
|
|
+ this.props.folder.setTitle(this.getFormSnapshot().folder.title, evt.target.value);
|
|
|
+ }
|
|
|
+
|
|
|
+ getFormSnapshot() {
|
|
|
+ if (!this.formSnapshot) {
|
|
|
+ this.formSnapshot = getSnapshot(this.props.folder);
|
|
|
+ }
|
|
|
+
|
|
|
+ return this.formSnapshot;
|
|
|
+ }
|
|
|
+
|
|
|
+ save(evt) {
|
|
|
+ if (evt) {
|
|
|
+ evt.stopPropagation();
|
|
|
+ evt.preventDefault();
|
|
|
+ }
|
|
|
+
|
|
|
+ const { nav, folder, view } = this.props;
|
|
|
+
|
|
|
+ folder
|
|
|
+ .saveDashboard(this.dashboard, { overwrite: false })
|
|
|
+ .then(newUrl => {
|
|
|
+ view.updatePathAndQuery(newUrl, '', '');
|
|
|
+
|
|
|
+ appEvents.emit('dashboard-saved');
|
|
|
+ appEvents.emit('alert-success', ['Folder saved']);
|
|
|
+ })
|
|
|
+ .then(() => {
|
|
|
+ return nav.initFolderNav(toJS(folder.folder), 'manage-folder-settings');
|
|
|
+ })
|
|
|
+ .catch(this.handleSaveFolderError);
|
|
|
+ }
|
|
|
+
|
|
|
+ delete(evt) {
|
|
|
+ if (evt) {
|
|
|
+ evt.stopPropagation();
|
|
|
+ evt.preventDefault();
|
|
|
+ }
|
|
|
+
|
|
|
+ const { folder, view } = this.props;
|
|
|
+ const title = folder.folder.title;
|
|
|
+
|
|
|
+ appEvents.emit('confirm-modal', {
|
|
|
+ title: 'Delete',
|
|
|
+ text: `Do you want to delete this folder and all its dashboards?`,
|
|
|
+ icon: 'fa-trash',
|
|
|
+ yesText: 'Delete',
|
|
|
+ onConfirm: () => {
|
|
|
+ return this.props.folder.deleteFolder().then(() => {
|
|
|
+ appEvents.emit('alert-success', ['Folder Deleted', `${title} has been deleted`]);
|
|
|
+ view.updatePathAndQuery('dashboards', '', '');
|
|
|
+ });
|
|
|
+ },
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ handleSaveFolderError(err) {
|
|
|
+ if (err.data && err.data.status === 'version-mismatch') {
|
|
|
+ err.isHandled = true;
|
|
|
+
|
|
|
+ appEvents.emit('confirm-modal', {
|
|
|
+ title: 'Conflict',
|
|
|
+ text: 'Someone else has updated this folder.',
|
|
|
+ text2: 'Would you still like to save this folder?',
|
|
|
+ yesText: 'Save & Overwrite',
|
|
|
+ icon: 'fa-warning',
|
|
|
+ onConfirm: () => {
|
|
|
+ this.props.folder.saveDashboard(this.dashboard, { overwrite: true });
|
|
|
+ },
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ if (err.data && err.data.status === 'name-exists') {
|
|
|
+ err.isHandled = true;
|
|
|
+
|
|
|
+ appEvents.emit('alert-error', ['A folder or dashboard with this name exists already.']);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ render() {
|
|
|
+ const { nav, folder } = this.props;
|
|
|
+
|
|
|
+ if (!folder.folder || !nav.main) {
|
|
|
+ return <h2>Loading</h2>;
|
|
|
+ }
|
|
|
+
|
|
|
+ return (
|
|
|
+ <div>
|
|
|
+ <PageHeader model={nav as any} />
|
|
|
+ <div className="page-container page-body">
|
|
|
+ <h2 className="page-sub-heading">Folder Settings</h2>
|
|
|
+
|
|
|
+ <div className="section gf-form-group">
|
|
|
+ <form name="folderSettingsForm" onSubmit={this.save.bind(this)}>
|
|
|
+ <div className="gf-form">
|
|
|
+ <label className="gf-form-label width-7">Name</label>
|
|
|
+ <input
|
|
|
+ type="text"
|
|
|
+ className="gf-form-input width-30"
|
|
|
+ value={folder.folder.title}
|
|
|
+ onChange={this.onTitleChange.bind(this)}
|
|
|
+ />
|
|
|
+ </div>
|
|
|
+ <div className="gf-form-button-row">
|
|
|
+ <button
|
|
|
+ type="submit"
|
|
|
+ className="btn btn-success"
|
|
|
+ disabled={!folder.folder.canSave || !folder.folder.hasChanged}
|
|
|
+ >
|
|
|
+ <i className="fa fa-trash" /> Save
|
|
|
+ </button>
|
|
|
+ <button className="btn btn-danger" onClick={this.delete.bind(this)} disabled={!folder.folder.canSave}>
|
|
|
+ <i className="fa fa-trash" /> Delete
|
|
|
+ </button>
|
|
|
+ </div>
|
|
|
+ </form>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ );
|
|
|
+ }
|
|
|
+}
|