376 lines
13 KiB
JavaScript
376 lines
13 KiB
JavaScript
|
/*
|
||
|
|
||
|
Copyright 2011, Google Inc.
|
||
|
All rights reserved.
|
||
|
|
||
|
Redistribution and use in source and binary forms, with or without
|
||
|
modification, are permitted provided that the following conditions are
|
||
|
met:
|
||
|
|
||
|
* Redistributions of source code must retain the above copyright
|
||
|
notice, this list of conditions and the following disclaimer.
|
||
|
* Redistributions in binary form must reproduce the above
|
||
|
copyright notice, this list of conditions and the following disclaimer
|
||
|
in the documentation and/or other materials provided with the
|
||
|
distribution.
|
||
|
* Neither the name of Google Inc. nor the names of its
|
||
|
contributors may be used to endorse or promote products derived from
|
||
|
this software without specific prior written permission.
|
||
|
|
||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||
|
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||
|
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||
|
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||
|
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||
|
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||
|
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||
|
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||
|
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||
|
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||
|
|
||
|
*/
|
||
|
|
||
|
//Internationalization init
|
||
|
var lang = navigator.language.split("-")[0]
|
||
|
|| navigator.userLanguage.split("-")[0];
|
||
|
var dictionary = "";
|
||
|
$.ajax({
|
||
|
url : "command/core/load-language?",
|
||
|
type : "POST",
|
||
|
async : false,
|
||
|
data : {
|
||
|
module : "database",
|
||
|
},
|
||
|
success : function(data) {
|
||
|
dictionary = data;
|
||
|
}
|
||
|
});
|
||
|
$.i18n.setDictionary(dictionary);
|
||
|
// End internationalization
|
||
|
|
||
|
Refine.DatabaseImportController = function(createProjectUI) {
|
||
|
this._createProjectUI = createProjectUI;
|
||
|
|
||
|
this._parsingPanel = createProjectUI.addCustomPanel();
|
||
|
|
||
|
createProjectUI.addSourceSelectionUI({
|
||
|
label: "Database",
|
||
|
id: "database-source",
|
||
|
ui: new Refine.DatabaseSourceUI(this)
|
||
|
});
|
||
|
|
||
|
};
|
||
|
Refine.CreateProjectUI.controllers.push(Refine.DatabaseImportController);
|
||
|
|
||
|
Refine.DatabaseImportController.prototype.startImportingDocument = function(queryInfo) {
|
||
|
var dismiss = DialogSystem.showBusy($.i18n._('database-import')["preparing"]);
|
||
|
//alert(queryInfo.query);
|
||
|
var self = this;
|
||
|
|
||
|
$.post(
|
||
|
"command/core/create-importing-job",
|
||
|
null,
|
||
|
function(data) {
|
||
|
$.post(
|
||
|
"command/core/importing-controller?" + $.param({
|
||
|
"controller": "database/database-import-controller",
|
||
|
"subCommand": "initialize-parser-ui"
|
||
|
}),
|
||
|
queryInfo,
|
||
|
|
||
|
function(data2) {
|
||
|
dismiss();
|
||
|
|
||
|
if (data2.status == 'ok') {
|
||
|
self._queryInfo = queryInfo;
|
||
|
self._jobID = data.jobID;
|
||
|
self._options = data2.options;
|
||
|
|
||
|
self._showParsingPanel();
|
||
|
|
||
|
} else {
|
||
|
alert(data2.message);
|
||
|
}
|
||
|
},
|
||
|
"json"
|
||
|
);
|
||
|
},
|
||
|
"json"
|
||
|
);
|
||
|
};
|
||
|
|
||
|
Refine.DatabaseImportController.prototype.getOptions = function() {
|
||
|
var options = {
|
||
|
|
||
|
};
|
||
|
|
||
|
var parseIntDefault = function(s, def) {
|
||
|
try {
|
||
|
var n = parseInt(s);
|
||
|
if (!isNaN(n)) {
|
||
|
return n;
|
||
|
}
|
||
|
} catch (e) {
|
||
|
// Ignore
|
||
|
}
|
||
|
return def;
|
||
|
};
|
||
|
|
||
|
|
||
|
if (this._parsingPanelElmts.skipCheckbox[0].checked) {
|
||
|
options.skipDataLines = parseIntDefault(this._parsingPanelElmts.skipInput[0].value, 0);
|
||
|
} else {
|
||
|
options.skipDataLines = 0;
|
||
|
}
|
||
|
if (this._parsingPanelElmts.limitCheckbox[0].checked) {
|
||
|
options.limit = parseIntDefault(this._parsingPanelElmts.limitInput[0].value, -1);
|
||
|
} else {
|
||
|
options.limit = -1;
|
||
|
}
|
||
|
options.storeBlankRows = this._parsingPanelElmts.storeBlankRowsCheckbox[0].checked;
|
||
|
options.storeBlankCellsAsNulls = this._parsingPanelElmts.storeBlankCellsAsNullsCheckbox[0].checked;
|
||
|
|
||
|
return options;
|
||
|
};
|
||
|
|
||
|
Refine.DatabaseImportController.prototype._showParsingPanel = function() {
|
||
|
var self = this;
|
||
|
|
||
|
this._parsingPanel.unbind().empty().html(
|
||
|
DOM.loadHTML("database",'scripts/index/database-parsing-panel.html'));
|
||
|
|
||
|
this._parsingPanelElmts = DOM.bind(this._parsingPanel);
|
||
|
|
||
|
this._parsingPanelElmts.startOverButton.html($.i18n._('database-parsing')["start-over"]);
|
||
|
this._parsingPanelElmts.database_conf_pars.html($.i18n._('database-parsing')["conf-pars"]);
|
||
|
this._parsingPanelElmts.database_proj_name.html($.i18n._('database-parsing')["proj-name"]);
|
||
|
this._parsingPanelElmts.createProjectButton.html($.i18n._('database-parsing')["create-proj"]);
|
||
|
this._parsingPanelElmts.database_options.html($.i18n._('database-parsing')["option"]);
|
||
|
this._parsingPanelElmts.previewButton.html($.i18n._('database-parsing')["preview-button"]);
|
||
|
this._parsingPanelElmts.database_updating.html($.i18n._('database-parsing')["updating-preview"]);
|
||
|
this._parsingPanelElmts.database_discard_next.html($.i18n._('database-parsing')["discard-next"]);
|
||
|
this._parsingPanelElmts.database_discard.html($.i18n._('database-parsing')["discard"]);
|
||
|
this._parsingPanelElmts.database_limit_next.html($.i18n._('database-parsing')["limit-next"]);
|
||
|
this._parsingPanelElmts.database_limit.html($.i18n._('database-parsing')["limit"]);
|
||
|
this._parsingPanelElmts.database_store_row.html($.i18n._('database-parsing')["store-row"]);
|
||
|
this._parsingPanelElmts.database_store_cell.html($.i18n._('database-parsing')["store-cell"]);
|
||
|
|
||
|
if (this._parsingPanelResizer) {
|
||
|
$(window).unbind('resize', this._parsingPanelResizer);
|
||
|
}
|
||
|
|
||
|
this._parsingPanelResizer = function() {
|
||
|
var elmts = self._parsingPanelElmts;
|
||
|
var width = self._parsingPanel.width();
|
||
|
var height = self._parsingPanel.height();
|
||
|
var headerHeight = elmts.wizardHeader.outerHeight(true);
|
||
|
var controlPanelHeight = 250;
|
||
|
|
||
|
elmts.dataPanel
|
||
|
.css("left", "0px")
|
||
|
.css("top", headerHeight + "px")
|
||
|
.css("width", (width - DOM.getHPaddings(elmts.dataPanel)) + "px")
|
||
|
.css("height", (height - headerHeight - controlPanelHeight - DOM.getVPaddings(elmts.dataPanel)) + "px");
|
||
|
elmts.progressPanel
|
||
|
.css("left", "0px")
|
||
|
.css("top", headerHeight + "px")
|
||
|
.css("width", (width - DOM.getHPaddings(elmts.progressPanel)) + "px")
|
||
|
.css("height", (height - headerHeight - controlPanelHeight - DOM.getVPaddings(elmts.progressPanel)) + "px");
|
||
|
|
||
|
elmts.controlPanel
|
||
|
.css("left", "0px")
|
||
|
.css("top", (height - controlPanelHeight) + "px")
|
||
|
.css("width", (width - DOM.getHPaddings(elmts.controlPanel)) + "px")
|
||
|
.css("height", (controlPanelHeight - DOM.getVPaddings(elmts.controlPanel)) + "px");
|
||
|
};
|
||
|
|
||
|
$(window).resize(this._parsingPanelResizer);
|
||
|
this._parsingPanelResizer();
|
||
|
|
||
|
this._parsingPanelElmts.startOverButton.click(function() {
|
||
|
// explicitly cancel the import job
|
||
|
Refine.CreateProjectUI.cancelImportingJob(self._jobID);
|
||
|
|
||
|
delete self._jobID;
|
||
|
delete self._options;
|
||
|
|
||
|
self._createProjectUI.showSourceSelectionPanel();
|
||
|
});
|
||
|
|
||
|
this._parsingPanelElmts.createProjectButton.click(function() { self._createProject(); });
|
||
|
this._parsingPanelElmts.previewButton.click(function() { self._updatePreview(); });
|
||
|
//alert("datetime::" + $.now());
|
||
|
//this._parsingPanelElmts.projectNameInput[0].value = this._queryInfo.connectionName + "_" + this._queryInfo.databaseUser + "_" + $.now();
|
||
|
this._parsingPanelElmts.projectNameInput[0].value = this._queryInfo.databaseServer + "_" + this._queryInfo.initialDatabase + "_" + $.now();
|
||
|
|
||
|
|
||
|
if (this._options.limit > 0) {
|
||
|
this._parsingPanelElmts.limitCheckbox.prop("checked", true);
|
||
|
this._parsingPanelElmts.limitInput[0].value = this._options.limit.toString();
|
||
|
}
|
||
|
if (this._options.skipDataLines > 0) {
|
||
|
this._parsingPanelElmts.skipCheckbox.prop("checked", true);
|
||
|
this._parsingPanelElmts.skipInput.value[0].value = this._options.skipDataLines.toString();
|
||
|
}
|
||
|
if (this._options.storeBlankRows) {
|
||
|
this._parsingPanelElmts.storeBlankRowsCheckbox.prop("checked", true);
|
||
|
}
|
||
|
if (this._options.storeBlankCellsAsNulls) {
|
||
|
this._parsingPanelElmts.storeBlankCellsAsNullsCheckbox.prop("checked", true);
|
||
|
}
|
||
|
|
||
|
var onChange = function() {
|
||
|
self._scheduleUpdatePreview();
|
||
|
};
|
||
|
this._parsingPanel.find("input").bind("change", onChange);
|
||
|
this._parsingPanel.find("select").bind("change", onChange);
|
||
|
|
||
|
this._createProjectUI.showCustomPanel(this._parsingPanel);
|
||
|
this._updatePreview();
|
||
|
};
|
||
|
|
||
|
Refine.DatabaseImportController.prototype._scheduleUpdatePreview = function() {
|
||
|
if (this._timerID != null) {
|
||
|
window.clearTimeout(this._timerID);
|
||
|
this._timerID = null;
|
||
|
}
|
||
|
|
||
|
var self = this;
|
||
|
this._timerID = window.setTimeout(function() {
|
||
|
self._timerID = null;
|
||
|
self._updatePreview();
|
||
|
}, 500); // 0.5 second
|
||
|
};
|
||
|
|
||
|
Refine.DatabaseImportController.prototype._updatePreview = function() {
|
||
|
var self = this;
|
||
|
// alert("query::" + this._queryInfo.query);
|
||
|
this._parsingPanelElmts.dataPanel.hide();
|
||
|
this._parsingPanelElmts.progressPanel.show();
|
||
|
this._queryInfo.options = JSON.stringify(this.getOptions());
|
||
|
//alert("options:" + this._queryInfo.options);
|
||
|
|
||
|
$.post(
|
||
|
"command/core/importing-controller?" + $.param({
|
||
|
"controller": "database/database-import-controller",
|
||
|
"jobID": this._jobID,
|
||
|
"subCommand": "parse-preview"
|
||
|
}),
|
||
|
|
||
|
this._queryInfo,
|
||
|
|
||
|
function(result) {
|
||
|
if (result.status == "ok") {
|
||
|
self._getPreviewData(function(projectData) {
|
||
|
self._parsingPanelElmts.progressPanel.hide();
|
||
|
self._parsingPanelElmts.dataPanel.show();
|
||
|
|
||
|
new Refine.PreviewTable(projectData, self._parsingPanelElmts.dataPanel.unbind().empty());
|
||
|
});
|
||
|
} else {
|
||
|
alert(result.message);
|
||
|
//self._parsingPanelElmts.progressPanel.hide();
|
||
|
alert('Errors:\n' +
|
||
|
(result.message) ? result.message : Refine.CreateProjectUI.composeErrorMessage(job));
|
||
|
|
||
|
}
|
||
|
},
|
||
|
"json"
|
||
|
);
|
||
|
};
|
||
|
|
||
|
Refine.DatabaseImportController.prototype._getPreviewData = function(callback, numRows) {
|
||
|
var self = this;
|
||
|
var result = {};
|
||
|
|
||
|
$.post(
|
||
|
"command/core/get-models?" + $.param({ "importingJobID" : this._jobID }),
|
||
|
null,
|
||
|
function(data) {
|
||
|
for (var n in data) {
|
||
|
if (data.hasOwnProperty(n)) {
|
||
|
result[n] = data[n];
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$.post(
|
||
|
"command/core/get-rows?" + $.param({
|
||
|
"importingJobID" : self._jobID,
|
||
|
"start" : 0,
|
||
|
"limit" : numRows || 100 // More than we parse for preview anyway
|
||
|
}),
|
||
|
null,
|
||
|
function(data) {
|
||
|
result.rowModel = data;
|
||
|
callback(result);
|
||
|
},
|
||
|
"jsonp"
|
||
|
);
|
||
|
},
|
||
|
"json"
|
||
|
);
|
||
|
};
|
||
|
|
||
|
Refine.DatabaseImportController.prototype._createProject = function() {
|
||
|
var projectName = $.trim(this._parsingPanelElmts.projectNameInput[0].value);
|
||
|
if (projectName.length == 0) {
|
||
|
window.alert("Please name the project.");
|
||
|
this._parsingPanelElmts.projectNameInput.focus();
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
var self = this;
|
||
|
var options = this.getOptions();
|
||
|
options.projectName = projectName;
|
||
|
|
||
|
this._queryInfo.options = JSON.stringify(options);
|
||
|
$.post(
|
||
|
"command/core/importing-controller?" + $.param({
|
||
|
"controller": "database/database-import-controller",
|
||
|
"jobID": this._jobID,
|
||
|
"subCommand": "create-project"
|
||
|
}),
|
||
|
this._queryInfo,
|
||
|
function(o) {
|
||
|
if (o.status == 'error') {
|
||
|
alert(o.message);
|
||
|
} else {
|
||
|
var start = new Date();
|
||
|
var timerID = window.setInterval(
|
||
|
function() {
|
||
|
self._createProjectUI.pollImportJob(
|
||
|
start,
|
||
|
self._jobID,
|
||
|
timerID,
|
||
|
function(job) {
|
||
|
return "projectID" in job.config;
|
||
|
},
|
||
|
function(jobID, job) {
|
||
|
//alert("jobID::" + jobID + " job :" + job);
|
||
|
window.clearInterval(timerID);
|
||
|
Refine.CreateProjectUI.cancelImportingJob(jobID);
|
||
|
document.location = "project?project=" + job.config.projectID;
|
||
|
},
|
||
|
function(job) {
|
||
|
alert(Refine.CreateProjectUI.composeErrorMessage(job));
|
||
|
}
|
||
|
);
|
||
|
},
|
||
|
1000
|
||
|
);
|
||
|
self._createProjectUI.showImportProgressPanel($.i18n._('database-import')["creating"], function() {
|
||
|
// stop the timed polling
|
||
|
window.clearInterval(timerID);
|
||
|
|
||
|
// explicitly cancel the import job
|
||
|
Refine.CreateProjectUI.cancelImportingJob(jobID);
|
||
|
|
||
|
self._createProjectUI.showSourceSelectionPanel();
|
||
|
});
|
||
|
}
|
||
|
},
|
||
|
"json"
|
||
|
);
|
||
|
};
|