mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-01-17 01:25:36 -05:00
* fixed right click context menu bug in jobs view * added stepInfo and edit job WIP * show jobs in job edit * added schedule description on select schedule * fetch schedules during history and show in edit job * added alerts to job histories and show in edit * made history calls async * filter menus now close when esc is pressed * fixed bug where clicking on error row wouldnt populate job details
101 lines
3.5 KiB
TypeScript
101 lines
3.5 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
'use strict';
|
|
import * as nls from 'vscode-nls';
|
|
import * as sqlops from 'sqlops';
|
|
import * as vscode from 'vscode';
|
|
import { PickScheduleData } from '../data/pickScheduleData';
|
|
|
|
const localize = nls.loadMessageBundle();
|
|
|
|
export class PickScheduleDialog {
|
|
|
|
// TODO: localize
|
|
// Top level
|
|
private readonly DialogTitle: string = localize('pickSchedule.jobSchedules', 'Job Schedules');
|
|
private readonly OkButtonText: string = localize('pickSchedule.ok', 'OK');
|
|
private readonly CancelButtonText: string = localize('pickSchedule.cancel', 'Cancel');
|
|
private readonly SchedulesLabelText: string = localize('pickSchedule.availableSchedules', 'Available Schedules:');
|
|
public static readonly ScheduleNameLabelText: string = localize('pickSchedule.scheduleName', 'Name');
|
|
public static readonly SchedulesIDText: string = localize('pickSchedule.scheduleID','ID');
|
|
public static readonly ScheduleDescription: string = localize('pickSchedule.description','Description');
|
|
|
|
|
|
// UI Components
|
|
private dialog: sqlops.window.modelviewdialog.Dialog;
|
|
private schedulesTable: sqlops.TableComponent;
|
|
|
|
private model: PickScheduleData;
|
|
|
|
private _onSuccess: vscode.EventEmitter<PickScheduleData> = new vscode.EventEmitter<PickScheduleData>();
|
|
public readonly onSuccess: vscode.Event<PickScheduleData> = this._onSuccess.event;
|
|
|
|
constructor(ownerUri: string) {
|
|
this.model = new PickScheduleData(ownerUri);
|
|
}
|
|
|
|
public async showDialog() {
|
|
await this.model.initialize();
|
|
this.dialog = sqlops.window.modelviewdialog.createDialog(this.DialogTitle);
|
|
this.initializeContent();
|
|
this.dialog.okButton.onClick(async () => await this.execute());
|
|
this.dialog.cancelButton.onClick(async () => await this.cancel());
|
|
this.dialog.okButton.label = this.OkButtonText;
|
|
this.dialog.cancelButton.label = this.CancelButtonText;
|
|
sqlops.window.modelviewdialog.openDialog(this.dialog);
|
|
}
|
|
|
|
private initializeContent() {
|
|
this.dialog.registerContent(async view => {
|
|
this.schedulesTable = view.modelBuilder.table()
|
|
.withProperties({
|
|
columns: [
|
|
PickScheduleDialog.SchedulesIDText,
|
|
PickScheduleDialog.ScheduleNameLabelText,
|
|
PickScheduleDialog.ScheduleDescription
|
|
],
|
|
data: [],
|
|
height: 750,
|
|
width: 430
|
|
}).component();
|
|
|
|
let formModel = view.modelBuilder.formContainer()
|
|
.withFormItems([{
|
|
component: this.schedulesTable,
|
|
title: this.SchedulesLabelText
|
|
}]).withLayout({ width: '100%' }).component();
|
|
|
|
await view.initializeModel(formModel);
|
|
|
|
if (this.model.schedules) {
|
|
let data: any[][] = [];
|
|
for (let i = 0; i < this.model.schedules.length; ++i) {
|
|
let schedule = this.model.schedules[i];
|
|
console.log(schedule);
|
|
data[i] = [ schedule.id, schedule.name, schedule.description ];
|
|
}
|
|
this.schedulesTable.data = data;
|
|
}
|
|
});
|
|
}
|
|
|
|
private async execute() {
|
|
this.updateModel();
|
|
await this.model.save();
|
|
this._onSuccess.fire(this.model);
|
|
}
|
|
|
|
private async cancel() {
|
|
}
|
|
|
|
private updateModel() {
|
|
let selectedRows = this.schedulesTable.selectedRows;
|
|
if (selectedRows && selectedRows.length > 0) {
|
|
let selectedRow = selectedRows[0];
|
|
this.model.selectedSchedule = this.model.schedules[selectedRow];
|
|
}
|
|
}
|
|
} |