Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Replace toastr with Ant Notification #3610

Merged
merged 3 commits into from
Mar 24, 2019
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 10 additions & 0 deletions client/app/assets/less/ant.less
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@
@import "~antd/lib/card/style/index";
@import "~antd/lib/spin/style/index";
@import "~antd/lib/tabs/style/index";
@import "~antd/lib/notification/style/index";
@import 'inc/ant-variables';

// Remove bold in labels for Ant checkboxes and radio buttons
Expand Down Expand Up @@ -247,3 +248,12 @@
.ant-popover {
z-index: 1000; // make sure it doesn't cover drawer
}

// flexible width for notifications
.@{notification-prefix-cls} {
width: auto;

&-notice {
padding-right: 48px;
}
}
1 change: 0 additions & 1 deletion client/app/assets/less/main.less
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@
/** Load Vendors Dependencies **/
@import '~font-awesome/less/font-awesome';
@import '~ui-select/dist/select.css';
@import '~angular-toastr/src/toastr';
@import '~angular-resizable/src/angular-resizable.css';
@import '~material-design-iconic-font/dist/css/material-design-iconic-font.css';
@import '~pace-progress/themes/blue/pace-theme-minimal.css';
Expand Down
4 changes: 2 additions & 2 deletions client/app/components/QueryEditor.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import { react2angular } from 'react2angular';

import AceEditor from 'react-ace';
import ace from 'brace';
import toastr from 'angular-toastr';
import notification from '@/services/notification';

import 'brace/ext/language_tools';
import 'brace/mode/json';
Expand Down Expand Up @@ -209,7 +209,7 @@ class QueryEditor extends React.Component {
formatQuery = () => {
Query.format(this.props.dataSource.syntax || 'sql', this.props.queryText)
.then(this.updateQuery)
.catch(error => toastr.error(error));
.catch(error => notification.error(error));
};

toggleAutocomplete = (state) => {
Expand Down
4 changes: 2 additions & 2 deletions client/app/components/QuerySelector.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import { debounce, find } from 'lodash';
import Input from 'antd/lib/input';
import Select from 'antd/lib/select';
import { Query } from '@/services/query';
import { toastr } from '@/services/ng';
import notification from '@/services/notification';
import { QueryTagsControl } from '@/components/tags-control/TagsControl';

const SEARCH_DEBOUNCE_DURATION = 200;
Expand Down Expand Up @@ -94,7 +94,7 @@ export function QuerySelector(props) {
if (queryId) {
query = find(searchResults, { id: queryId });
if (!query) { // shouldn't happen
toastr.error('Something went wrong... Couldn\'t select query');
notification.error('Something went wrong...', 'Couldn\'t select query');
}
}

Expand Down
4 changes: 2 additions & 2 deletions client/app/components/SelectItemsDialog.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import { wrap as wrapDialog, DialogPropType } from '@/components/DialogWrapper';
import { BigMessage } from '@/components/BigMessage';

import LoadingState from '@/components/items-list/components/LoadingState';
import { toastr } from '@/services/ng';
import notification from '@/services/notification';

class SelectItemsDialog extends React.Component {
static propTypes = {
Expand Down Expand Up @@ -100,7 +100,7 @@ class SelectItemsDialog extends React.Component {
})
.catch(() => {
this.setState({ saveInProgress: false });
toastr.error('Failed to save some of selected items.');
notification.error('Failed to save some of selected items.');
});
});
}
Expand Down
11 changes: 6 additions & 5 deletions client/app/components/alerts/alert-subscriptions/index.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
import { includes, without, compact } from 'lodash';
import notification from '@/services/notification';
import template from './alert-subscriptions.html';

function controller($scope, $q, $sce, currentUser, AlertSubscription, Destination, toastr) {
function controller($scope, $q, $sce, currentUser, AlertSubscription, Destination) {
'ngInject';

$scope.newSubscription = {};
Expand Down Expand Up @@ -60,7 +61,7 @@ function controller($scope, $q, $sce, currentUser, AlertSubscription, Destinatio

sub.$save(
() => {
toastr.success('Subscribed.');
notification.success('Subscribed.');
$scope.subscribers.push(sub);
$scope.destinations = without($scope.destinations, $scope.newSubscription.destination);
if ($scope.destinations.length > 0) {
Expand All @@ -70,7 +71,7 @@ function controller($scope, $q, $sce, currentUser, AlertSubscription, Destinatio
}
},
() => {
toastr.error('Failed saving subscription.');
notification.error('Failed saving subscription.');
},
);
};
Expand All @@ -81,7 +82,7 @@ function controller($scope, $q, $sce, currentUser, AlertSubscription, Destinatio

subscriber.$delete(
() => {
toastr.success('Unsubscribed');
notification.success('Unsubscribed');
$scope.subscribers = without($scope.subscribers, subscriber);
if (destination) {
$scope.destinations.push(destination);
Expand All @@ -94,7 +95,7 @@ function controller($scope, $q, $sce, currentUser, AlertSubscription, Destinatio
}
},
() => {
toastr.error('Failed unsubscribing.');
notification.error('Failed unsubscribing.');
},
);
};
Expand Down
4 changes: 2 additions & 2 deletions client/app/components/dashboards/AddTextboxDialog.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import Input from 'antd/lib/input';
import Tooltip from 'antd/lib/tooltip';
import Divider from 'antd/lib/divider';
import { wrap as wrapDialog, DialogPropType } from '@/components/DialogWrapper';
import { toastr } from '@/services/ng';
import notification from '@/services/notification';

import './AddTextboxDialog.less';

Expand Down Expand Up @@ -44,7 +44,7 @@ class AddTextboxDialog extends React.Component {
this.props.dialog.close();
})
.catch(() => {
toastr.error('Widget could not be added');
notification.error('Widget could not be added');
})
.finally(() => {
this.setState({ saveInProgress: false });
Expand Down
4 changes: 2 additions & 2 deletions client/app/components/dashboards/AddWidgetDialog.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import {
} from '@/components/ParameterMappingInput';
import { QuerySelector } from '@/components/QuerySelector';

import { toastr } from '@/services/ng';
import notification from '@/services/notification';

import { Query } from '@/services/query';

Expand Down Expand Up @@ -84,7 +84,7 @@ class AddWidgetDialog extends React.Component {
this.props.dialog.close();
})
.catch(() => {
toastr.error('Widget could not be added');
notification.error('Widget could not be added');
})
.finally(() => {
this.setState({ saveInProgress: false });
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import {
editableMappingsToParameterMappings,
synchronizeWidgetTitles,
} from '@/components/ParameterMappingInput';
import notification from '@/services/notification';

export function getParamValuesSnapshot(mappings, dashboardParameters) {
return map(
Expand Down Expand Up @@ -61,7 +62,6 @@ class EditParameterMappingsDialog extends React.Component {
}

saveWidget() {
const toastr = this.props.toastr; // eslint-disable-line react/prop-types
const widget = this.props.widget;

this.setState({ saveInProgress: true });
Expand All @@ -84,7 +84,7 @@ class EditParameterMappingsDialog extends React.Component {
this.props.dialog.close(valuesChanged);
})
.catch(() => {
toastr.error('Widget cannot be updated');
notification.error('Widget cannot be updated');
})
.finally(() => {
this.setState({ saveInProgress: false });
Expand Down
5 changes: 3 additions & 2 deletions client/app/components/dashboards/widget.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import template from './widget.html';
import editTextBoxTemplate from './edit-text-box.html';
import widgetDialogTemplate from './widget-dialog.html';
import EditParameterMappingsDialog from '@/components/dashboards/EditParameterMappingsDialog';
import notification from '@/services/notification';
import './widget.less';
import './widget-dialog.less';

Expand All @@ -25,7 +26,7 @@ const EditTextBoxComponent = {
close: '&',
dismiss: '&',
},
controller(toastr) {
controller() {
'ngInject';

this.saveInProgress = false;
Expand All @@ -40,7 +41,7 @@ const EditTextBoxComponent = {
this.close();
})
.catch(() => {
toastr.error('Widget can not be updated');
notification.error('Widget can not be updated');
})
.finally(() => {
this.saveInProgress = false;
Expand Down
6 changes: 3 additions & 3 deletions client/app/components/dynamic-form/DynamicForm.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,9 @@ import Checkbox from 'antd/lib/checkbox';
import Button from 'antd/lib/button';
import Upload from 'antd/lib/upload';
import Icon from 'antd/lib/icon';
import notification from '@/services/notification';
import { includes } from 'lodash';
import { react2angular } from 'react2angular';
import { toastr } from '@/services/ng';
import { Field, Action, AntdForm } from '../proptypes';
import helper from './dynamicFormHelper';

Expand Down Expand Up @@ -83,11 +83,11 @@ export const DynamicForm = Form.create()(class DynamicForm extends React.Compone
const { setFieldsValue, getFieldsValue } = this.props.form;
this.setState({ isSubmitting: false });
setFieldsValue(getFieldsValue()); // reset form touched state
toastr.success(msg);
notification.success(msg);
},
(msg) => {
this.setState({ isSubmitting: false });
toastr.error(msg);
notification.error(msg);
},
);
} else this.setState({ isSubmitting: false });
Expand Down
4 changes: 2 additions & 2 deletions client/app/components/groups/DeleteGroupButton.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import PropTypes from 'prop-types';
import Button from 'antd/lib/button';
import Modal from 'antd/lib/modal';
import Tooltip from 'antd/lib/tooltip';
import { toastr } from '@/services/ng';
import notification from '@/services/notification';

function deleteGroup(event, group, onGroupDeleted) {
Modal.confirm({
Expand All @@ -15,7 +15,7 @@ function deleteGroup(event, group, onGroupDeleted) {
cancelText: 'No',
onOk: () => {
group.$delete(() => {
toastr.success('Group deleted successfully.');
notification.success('Group deleted successfully.');
onGroupDeleted();
});
},
Expand Down
7 changes: 4 additions & 3 deletions client/app/components/permissions-editor/index.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { includes, each, filter } from 'lodash';
import notification from '@/services/notification';
import template from './permissions-editor.html';

const PermissionsEditorComponent = {
Expand All @@ -8,7 +9,7 @@ const PermissionsEditorComponent = {
close: '&',
dismiss: '&',
},
controller($http, User, toastr) {
controller($http, User) {
'ngInject';

this.grantees = [];
Expand Down Expand Up @@ -58,9 +59,9 @@ const PermissionsEditorComponent = {
loadGrantees();
}).catch((error) => {
if (error.status === 403) {
toastr.error('You cannot add a user to this dashboard. Ask the dashboard owner to grant them permissions.');
notification.error('You cannot add a user to this dashboard.', 'Ask the dashboard owner to grant them permissions.');
} else {
toastr.error('Something went wrong.');
notification.error('Something went wrong.');
}
});
};
Expand Down
6 changes: 3 additions & 3 deletions client/app/components/users/ChangePasswordDialog.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import Modal from 'antd/lib/modal';
import Input from 'antd/lib/input';
import { isFunction } from 'lodash';
import { User } from '@/services/user';
import { toastr } from '@/services/ng';
import notification from '@/services/notification';
import { UserProfile } from '../proptypes';
import { wrap as wrapDialog, DialogPropType } from '@/components/DialogWrapper';

Expand Down Expand Up @@ -68,10 +68,10 @@ class ChangePasswordDialog extends React.Component {
this.setState({ updatingPassword: true });

User.save(userData, () => {
toastr.success('Saved.');
notification.success('Saved.');
this.props.dialog.close({ success: true });
}, (error = {}) => {
toastr.error(error.data && error.data.message || 'Failed saving.');
notification.error(error.data && error.data.message || 'Failed saving.');
this.setState({ updatingPassword: false });
});
} else {
Expand Down
2 changes: 0 additions & 2 deletions client/app/config/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,6 @@ import ngResource from 'angular-resource';
import uiBootstrap from 'angular-ui-bootstrap';
import uiSelect from 'ui-select';
import ngMessages from 'angular-messages';
import toastr from 'angular-toastr';
import ngUpload from 'angular-base64-upload';
import vsRepeat from 'angular-vs-repeat';
import 'brace';
Expand Down Expand Up @@ -49,7 +48,6 @@ const requirements = [
uiBootstrap,
ngMessages,
uiSelect,
toastr,
'ui.ace',
ngUpload,
'angularResizable',
Expand Down
7 changes: 1 addition & 6 deletions client/app/index.js
Original file line number Diff line number Diff line change
@@ -1,15 +1,10 @@
import ngModule from '@/config';

ngModule.config(($locationProvider, $compileProvider, uiSelectConfig, toastrConfig) => {
ngModule.config(($locationProvider, $compileProvider, uiSelectConfig) => {
$compileProvider.debugInfoEnabled(false);
$compileProvider.aHrefSanitizationWhitelist(/^\s*(https?|data|tel|sms|mailto):/);
$locationProvider.html5Mode(true);
uiSelectConfig.theme = 'bootstrap';

Object.assign(toastrConfig, {
positionClass: 'toast-bottom-right',
timeOut: 2000,
});
});

// Update ui-select's template to use Font-Awesome instead of glyphicon.
Expand Down
11 changes: 6 additions & 5 deletions client/app/pages/alert/index.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
import { template as templateBuilder } from 'lodash';
import notification from '@/services/notification';
import template from './alert.html';

function AlertCtrl($scope, $routeParams, $location, $sce, toastr, currentUser, Query, Events, Alert) {
function AlertCtrl($scope, $routeParams, $location, $sce, currentUser, Query, Events, Alert) {
this.alertId = $routeParams.alertId;

if (this.alertId === 'new') {
Expand Down Expand Up @@ -61,13 +62,13 @@ function AlertCtrl($scope, $routeParams, $location, $sce, toastr, currentUser, Q
}
this.alert.$save(
(alert) => {
toastr.success('Saved.');
notification.success('Saved.');
if (this.alertId === 'new') {
$location.path(`/alerts/${alert.id}`).replace();
}
},
() => {
toastr.error('Failed saving alert.');
notification.error('Failed saving alert.');
},
);
};
Expand All @@ -76,10 +77,10 @@ function AlertCtrl($scope, $routeParams, $location, $sce, toastr, currentUser, Q
this.alert.$delete(
() => {
$location.path('/alerts');
toastr.success('Alert deleted.');
notification.success('Alert deleted.');
},
() => {
toastr.error('Failed deleting alert.');
notification.error('Failed deleting alert.');
},
);
};
Expand Down
Loading