function DataTableCellUI(dataTableView, cell, rowIndex, cellIndex, td) { this._dataTableView = dataTableView; this._cell = cell; this._rowIndex = rowIndex; this._cellIndex = cellIndex; this._td = td; this._render(); }; DataTableCellUI.prototype._render = function() { var self = this; var cell = this._cell; var divContent = $('
') .addClass("data-table-cell-content"); var editLink = $('') .addClass("data-table-cell-edit") .text("edit") .appendTo(divContent) .click(function() { self._startEdit(this); }); $(this._td).empty() .unbind() .mouseenter(function() { editLink.css("visibility", "visible"); }) .mouseleave(function() { editLink.css("visibility", "hidden"); }); if (cell == null || ("v" in cell && cell.v == null)) { $('').html(" ").appendTo(divContent); } else if ("e" in cell) { $('').addClass("data-table-error").text(cell.e).appendTo(divContent); } else if (!("r" in cell) || cell.r == null) { $('').text(cell.v).appendTo(divContent); } else { var r = cell.r; if (r.j == "new") { $('').text(cell.v + " (new topic) ").appendTo(divContent); $('') .text("re\u2011match") .addClass("data-table-recon-action") .appendTo(divContent).click(function(evt) { self._doRematch(); }); } else if (r.j == "matched" && "m" in r && r.m != null) { var match = cell.r.m; $('') .text(match.name) .attr("href", "http://www.freebase.com/view" + match.id) .attr("target", "_blank") .appendTo(divContent); $(' ').appendTo(divContent); $('') .text("re\u2011match") .addClass("data-table-recon-action") .appendTo(divContent) .click(function(evt) { self._doRematch(); }); } else { $('').text(cell.v).appendTo(divContent); if (this._dataTableView._showRecon) { var ul = $('
').addClass("data-table-recon-candidates").appendTo(divContent); if ("c" in r && r.c.length > 0) { var candidates = r.c; var renderCandidate = function(candidate, index) { var li = $('
').addClass("data-table-recon-candidate").appendTo(ul); $(' ') .addClass("data-table-recon-match-similar") .attr("title", "Match this topic to this cell and other cells with the same content") .appendTo(li).click(function(evt) { self._doMatchTopicToSimilarCells(candidate); }); $(' ') .addClass("data-table-recon-match") .attr("title", "Match this topic to this cell") .appendTo(li).click(function(evt) { self._doMatchTopicToOneCell(candidate); }); $('') .addClass("data-table-recon-topic") .attr("href", "http://www.freebase.com/view" + candidate.id) .attr("target", "_blank") .click(function(evt) { self._previewCandidateTopic(candidate.id, this); evt.preventDefault(); return false; }) .text(candidate.name) .appendTo(li); $('').addClass("data-table-recon-score").text("(" + Math.round(candidate.score) + ")").appendTo(li); }; for (var i = 0; i < candidates.length; i++) { renderCandidate(candidates[i], i); } } var liNew = $('
').addClass("data-table-recon-candidate").appendTo(ul); $(' ') .addClass("data-table-recon-match-similar") .attr("title", "Create a new topic for this cell and other cells with the same content") .appendTo(liNew).click(function(evt) { self._doMatchNewTopicToSimilarCells(); }); $(' ') .addClass("data-table-recon-match") .attr("title", "Create a new topic for this cell") .appendTo(liNew).click(function(evt) { self._doMatchNewTopicToOneCell(); }); $('').text("(New topic)").appendTo(liNew); $('') .addClass("data-table-recon-search") .click(function(evt) { self._searchForMatch(); return false; }) .text("search for match") .appendTo($('
').appendTo(divContent)); } } } divContent.appendTo(this._td) }; DataTableCellUI.prototype._doRematch = function() { this._doJudgment("none"); }; DataTableCellUI.prototype._doMatchNewTopicToOneCell = function() { this._doJudgment("new"); }; DataTableCellUI.prototype._doMatchNewTopicToSimilarCells = function() { this._doJudgmentForSimilarCells("new", { shareNewTopics: true }, true); }; DataTableCellUI.prototype._doMatchTopicToOneCell = function(candidate) { this._doJudgment("matched", { topicID : candidate.id, topicGUID: candidate.guid, topicName: candidate.name, score: candidate.score, types: candidate.types.join(",") }); }; DataTableCellUI.prototype._doMatchTopicToSimilarCells = function(candidate) { this._doJudgmentForSimilarCells("matched", { topicID : candidate.id, topicGUID: candidate.guid, topicName: candidate.name, score: candidate.score, types: candidate.types.join(",") }, true); }; DataTableCellUI.prototype._doJudgment = function(judgment, params) { params = params || {}; params.row = this._rowIndex; params.cell = this._cellIndex; params.judgment = judgment; this._postProcessOneCell("recon-judge-one-cell", params, true); }; DataTableCellUI.prototype._doJudgmentForSimilarCells = function(judgment, params) { params = params || {}; params.columnName = Gridworks.cellIndexToColumn(this._cellIndex).name; params.similarValue = this._cell.v; params.judgment = judgment; this._postProcessSeveralCells("recon-judge-similar-cells", params, true); }; DataTableCellUI.prototype._searchForMatch = function() { var self = this; var frame = DialogSystem.createDialog(); frame.width("400px"); var header = $('
').addClass("dialog-header").text("Search for Match").appendTo(frame); var body = $('
').addClass("dialog-body").appendTo(frame); var footer = $('
').addClass("dialog-footer").appendTo(frame); var html = $( '
' + '' + '' + '' + '' + '' + '
Search Freebase for topic to match ' + this._cell.v + '
Match other cells with same content
' ).appendTo(body); var elmts = DOM.bind(html); var match = null; var commit = function() { if (match != null) { var params = { judgment: "matched", topicID: match.id, topicGUID: match.guid, topicName: match.name, types: $.map(match.type, function(elmt) { return elmt.id; }).join(",") }; if (elmts.checkSimilar[0].checked) { params.similarValue = self._cell.v; params.columnName = Gridworks.cellIndexToColumn(self._cellIndex).name; self._postProcessSeveralCells("recon-judge-similar-cells", params, true); } else { params.row = self._rowIndex; params.cell = self._cellIndex; self._postProcessOneCell("recon-judge-one-cell", params, true); } DialogSystem.dismissUntil(level - 1); } }; $('').text("Match").click(commit).appendTo(footer); $('').text("Cancel").click(function() { DialogSystem.dismissUntil(level - 1); }).appendTo(footer); var level = DialogSystem.showDialog(frame); elmts.input .attr("value", this._cell.v) .suggest({}) .bind("fb-select", function(e, data) { match = data; commit(); }) .focus() .data("suggest").textchange(); }; DataTableCellUI.prototype._postProcessOneCell = function(command, params, columnStatsChanged) { var self = this; Gridworks.postProcess( command, params, null, { columnStatsChanged: columnStatsChanged }, { onDone: function(o) { self._cell = o.cell; self._render(); } } ); }; DataTableCellUI.prototype._postProcessSeveralCells = function(command, params, columnStatsChanged) { Gridworks.postProcess( command, params, null, { cellsChanged: true, columnStatsChanged: columnStatsChanged } ); }; DataTableCellUI.prototype._previewCandidateTopic = function(id, elmt) { var url = "http://www.freebase.com/widget/topic" + id + '?mode=content&blocks=[{"block"%3A"image"}%2C{"block"%3A"full_info"}%2C{"block"%3A"article_props"}]'; var fakeMenu = MenuSystem.createMenu(); fakeMenu .width(700) .height(300) .css("background", "none") .css("border", "none"); var iframe = $('') .attr("width", "100%") .attr("height", "100%") .css("background", "none") .css("border", "none") .attr("src", url) .appendTo(fakeMenu); MenuSystem.showMenu(fakeMenu, function(){}); MenuSystem.positionMenuLeftRight(fakeMenu, $(elmt)); }; DataTableCellUI.prototype._startEdit = function(elmt) { self = this; var originalContent = this._cell == null || ("v" in this._cell && this._cell.v == null) ? "" : this._cell.v; var menu = MenuSystem.createMenu().addClass("data-table-cell-editor").width("400px"); menu.html( '' + '' + '
' + '