Skip to content

Commit

Permalink
Feature: Refresh schedule - save/cancel actions
Browse files Browse the repository at this point in the history
  • Loading branch information
ranbena committed Jan 3, 2019
1 parent da6a596 commit 8d83459
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 8 deletions.
1 change: 1 addition & 0 deletions client/app/assets/less/redash/ant.less
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
@import '~antd/lib/modal/style/index.less';
@import '~antd/lib/tooltip/style/index.less';
@import '~antd/lib/select/style/index.less';
@import '~antd/lib/button/style/index.less';

// Overwritting Ant Design defaults to fit into Redash current style
@font-family-no-number : @redash-font;
Expand Down
35 changes: 27 additions & 8 deletions client/app/components/queries/ScheduleDialog.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import React from 'react';
import PropTypes from 'prop-types';
import Modal from 'antd/lib/modal';
import DatePicker from 'antd/lib/date-picker';
import { range, padStart } from 'lodash';
import { range, padStart, clone, isEqual } from 'lodash';
import moment from 'moment';
import { secondsToInterval, intervalToSeconds, IntervalEnum } from '@/filters';

Expand Down Expand Up @@ -46,17 +46,22 @@ class ScheduleDialog extends React.Component {

constructor(props) {
super(props);
this.state = this.initState;
}

const { time, interval: secs, day_of_week: day } = props.query.schedule;
get initState() {
const newSchedule = clone(this.props.query.schedule);
const { time, interval: secs, day_of_week: day } = newSchedule;
const interval = secs ? secondsToInterval(secs) : {};
const [hour, minute] = time ? localizeTime(time).split(':') : [null, null];

this.state = {
return {
hour,
minute,
count: interval.count ? String(interval.count) : '1',
interval: interval.interval || IntervalEnum.NEVER,
dayOfWeek: day ? WEEKDAYS_SHORT[WEEKDAYS_FULL.indexOf(day)] : null,
newSchedule,
};
}

Expand All @@ -82,8 +87,8 @@ class ScheduleDialog extends React.Component {
}

set newSchedule(newProps) {
this.props.updateQuery({
schedule: Object.assign({}, this.props.query.schedule, newProps),
this.setState({
newSchedule: Object.assign(this.state.newSchedule, newProps),
});
}

Expand All @@ -107,7 +112,7 @@ class ScheduleDialog extends React.Component {

setInterval = (e) => {
const newInterval = e.target.value;
const newSchedule = Object.assign({}, this.props.query.schedule);
const { newSchedule } = this.state;

// resets to defaults
if (newInterval === IntervalEnum.NEVER) {
Expand Down Expand Up @@ -173,6 +178,20 @@ class ScheduleDialog extends React.Component {
};
};

save() {
// save if changed
if (!isEqual(this.state.newSchedule, this.props.query.schedule)) {
this.props.updateQuery({ schedule: clone(this.state.newSchedule) });
}
this.props.onClose();
}

cancel() {
// reset changes
this.setState(this.initState);
this.props.onClose();
}

render() {
const {
interval, minute, hour, until, count,
Expand All @@ -183,8 +202,8 @@ class ScheduleDialog extends React.Component {
title="Refresh Schedule"
className="schedule"
visible={this.props.show}
onCancel={this.props.onClose}
footer={null}
onCancel={() => this.cancel()}
onOk={() => this.save()}
>
<div className="schedule-component">
<div>Refresh every</div>
Expand Down

0 comments on commit 8d83459

Please sign in to comment.