1 openerp.web.data_export = function(openerp) {
2 var QWeb = openerp.web.qweb,
4 openerp.web.DataExport = openerp.web.Dialog.extend({
5 template: 'ExportTreeView',
6 dialog_title: {toString: function () { return _t("Export Data"); }},
7 init: function(parent, dataset) {
10 this.dataset = dataset;
11 this.exports = new openerp.web.DataSetSearch(
12 this, 'ir.exports', this.dataset.get_context());
16 this._super.apply(this, arguments);
23 {text: _t("Close"), click: function() { self.close(); }},
24 {text: _t("Export To File"), click: function() { self.on_click_export_data(); }}
26 close: function(event, ui){ self.close();}
28 self.$element.removeClass('ui-dialog-content ui-widget-content');
29 self.$element.find('#add_field').click(function() {
30 if ($('#field-tree-structure tr.ui-selected')) {
31 var fld = self.$element.find('#field-tree-structure tr.ui-selected').find('a');
32 for (var i = 0; i < fld.length; i++) {
33 var id = $(fld[i]).attr('id').split('-')[1];
34 var string = $(fld[i]).attr('string');
35 self.add_field(id, string);
37 self.$element.find('#field-tree-structure tr').removeClass('ui-selected');
40 self.$element.find('#remove_field').click(function() {
41 self.$element.find('#fields_list option:selected').remove();
43 self.$element.find('#remove_all_field').click(function() {
44 self.$element.find('#fields_list').empty();
46 this.$element.find('#export_new_list').click(this.on_show_save_list);
48 var got_fields = new $.Deferred();
49 this.$element.find('#import_compat').change(function() {
50 self.$element.find('#fields_list').empty();
51 self.$element.find('#field-tree-structure').remove();
52 var import_comp = self.$element.find("#import_compat").val();
53 self.rpc("/web/export/get_fields", {
54 model: self.dataset.model,
55 import_compat: Boolean(import_comp)
56 }, function (records) {
58 self.on_show_data(records);
64 this.rpc('/web/export/formats', {}, this.do_setup_export_formats),
65 this.show_exports_list());
67 do_setup_export_formats: function (formats) {
68 var $fmts = this.$element.find('#export_format');
69 _(formats).each(function (format) {
70 $fmts.append(new Option(format[1], format[0]));
73 show_exports_list: function() {
75 if (self.$element.find('#saved_export_list').is(':hidden')) {
76 self.$element.find('#ExistsExportList').show();
79 return this.exports.read_slice(['name'], {
80 domain: [['resource', '=', this.dataset.model]]
81 }, function (export_list) {
82 if (!export_list.length) {
85 self.$element.find('#ExistsExportList').append(QWeb.render('Exists.ExportList', {'existing_exports': export_list}));
86 self.$element.find('#saved_export_list').change(function() {
87 self.$element.find('#fields_list option').remove();
88 var export_id = self.$element.find('#saved_export_list option:selected').val();
90 self.rpc('/web/export/namelist', {'model': self.dataset.model, export_id: parseInt(export_id)}, self.do_load_export_field);
93 self.$element.find('#delete_export_list').click(function() {
94 var select_exp = self.$element.find('#saved_export_list option:selected');
95 if (select_exp.val()) {
96 self.exports.unlink([parseInt(select_exp.val(), 10)]);
98 if (self.$element.find('#saved_export_list option').length <= 1) {
99 self.$element.find('#ExistsExportList').hide();
105 do_load_export_field: function(field_list) {
106 var export_node = this.$element.find("#fields_list");
107 _(field_list).each(function (field) {
108 export_node.append(new Option(field.label, field.name));
111 on_show_save_list: function() {
113 var current_node = self.$element.find("#savenewlist");
114 if (!(current_node.find("label")).length) {
115 current_node.append(QWeb.render('ExportNewList'));
116 current_node.find("#add_export_list").click(function() {
117 var value = current_node.find("#savelist_name").val();
119 self.do_save_export_list(value);
121 alert("Pleae Enter Save Field List Name");
125 if (current_node.is(':hidden')) {
127 current_node.find("#savelist_name").val("");
133 do_save_export_list: function(value) {
135 var fields = self.get_fields();
136 if (!fields.length) {
139 this.exports.create({
141 resource: this.dataset.model,
142 export_fields: _(fields).map(function (field) {
143 return [0, 0, {name: field}];
145 }, function (export_list_id) {
146 if (!export_list_id.result) {
149 self.$element.find("#saved_export_list").append(
150 new Option(value, export_list_id.result));
151 if (self.$element.find("#saved_export_list").is(":hidden")) {
152 self.show_exports_list();
155 this.on_show_save_list();
156 this.$element.find("#fields_list option").remove();
158 on_click: function(id, record) {
160 if (!record['children']) {
163 var model = record['params']['model'],
164 prefix = record['params']['prefix'],
165 name = record['params']['name'],
167 if (record['relation_field']) {
168 exclude_fields.push(record['relation_field']);
171 if (!record.loaded) {
172 var import_comp = self.$element.find("#import_compat").val();
173 self.rpc("/web/export/get_fields", {
177 import_compat: Boolean(import_comp),
178 parent_field_type : record['field_type'],
179 exclude: exclude_fields
180 }, function(results) {
181 record.loaded = true;
182 self.on_show_data(results, record.id);
185 self.showcontent(record.id);
188 on_show_data: function(result, after) {
190 var imp_cmpt = Boolean(self.$element.find("#import_compat").val());
193 var current_tr = self.$element.find("tr[id='treerow-" + after + "']");
194 current_tr.addClass('open');
195 current_tr.find('img').attr('src','/web/static/src/img/collapse.gif');
196 current_tr.after(QWeb.render('ExportTreeView-Secondary.children', {'fields': result}));
198 self.$element.find('#left_field_panel').append(QWeb.render('ExportTreeView-Secondary', {'fields': result}));
200 _.each(result, function(record) {
201 self.records[record.id] = record.value;
202 if (record.required) {
203 var required_fld = self.$element.find("tr[id='treerow-" + record.id + "']").find('#tree-column');
204 required_fld.addClass("oe_export_requiredfield");
206 self.$element.find("img[id='parentimg-" + record.id +"']").click(function() {
207 self.on_click(this.id, record);
210 self.$element.find("tr[id='treerow-" + record.id + "']").click(function(e) {
212 var frst_click, scnd_click = '';
213 if (self.row_index == 0) {
214 self.row_index = this.rowIndex;
215 frst_click = self.$element.find("tr[id^='treerow-']")[self.row_index-1];
216 $(frst_click).addClass("ui-selected");
218 if (this.rowIndex >=self.row_index) {
219 for (var i = (self.row_index-1); i < this.rowIndex; i++) {
220 scnd_click = self.$element.find("tr[id^='treerow-']")[i];
221 if (!$(scnd_click).find('#tree-column').hasClass("oe_export_readonlyfield")) {
222 $(scnd_click).addClass("ui-selected");
226 for (var i = (self.row_index-1); i >= (this.rowIndex-1); i--) {
227 scnd_click = self.$element.find("tr[id^='treerow-']")[i];
228 if (!$(scnd_click).find('#tree-column').hasClass("oe_export_readonlyfield")) {
229 $(scnd_click).addClass("ui-selected");
235 self.row_index = this.rowIndex;
237 self.$element.find("tr[id='treerow-" + record.id + "']").keyup(function() {
240 var o2m_selection = self.$element.find("tr[id='treerow-" + record.id + "']").find('#tree-column');
241 if ($(o2m_selection).hasClass("oe_export_readonlyfield")) {
245 if ($(this).hasClass('ui-selected')) {
246 $(this).removeClass('ui-selected').find('a').blur();
248 $(this).addClass('ui-selected').find('a').focus();
250 } else if (!e.shiftKey) {
251 self.$element.find("tr.ui-selected")
252 .removeClass("ui-selected").find('a').blur();
253 $(this).addClass("ui-selected").find('a').focus();
258 self.$element.find("tr[id='treerow-" + record.id + "']").keydown(function(e) {
259 var keyCode = e.keyCode || e.which;
260 var arrow = {left: 37, up: 38, right: 39, down: 40 };
263 if ($(this).hasClass('open')) {
264 self.on_click(this.id, record);
268 if (!$(this).hasClass('open')) {
269 self.on_click(this.id, record);
274 $(elem).removeClass("ui-selected");
275 while (!$(elem).prev().is(":visible")) {
276 elem = $(elem).prev();
278 if (!$(elem).prev().find('#tree-column').hasClass("oe_export_readonlyfield")) {
279 $(elem).prev().addClass("ui-selected");
281 $(elem).prev().find('a').focus();
285 $(elem).removeClass("ui-selected");
286 while(!$(elem).next().is(":visible")) {
287 elem = $(elem).next();
289 if (!$(elem).next().find('#tree-column').hasClass("oe_export_readonlyfield")) {
290 $(elem).next().addClass("ui-selected");
292 $(elem).next().find('a').focus();
296 self.$element.find("tr[id='treerow-" + record.id + "']").dblclick(function() {
297 var $o2m_selection = self.$element.find("tr[id^='treerow-" + record.id + "']").find('#tree-column');
298 if (!$o2m_selection.hasClass("oe_export_readonlyfield")) {
299 self.add_field(record.id, $(this).find("a").attr("string"));
303 self.$element.find('#fields_list').mouseover(function(event) {
304 if (event.relatedTarget) {
305 if (event.relatedTarget.attributes['id'] && event.relatedTarget.attributes['string']) {
306 var field_id = event.relatedTarget.attributes["id"]["value"];
307 if (field_id && field_id.split("-")[0] === 'export') {
308 if (!self.$element.find("tr[id='treerow-" + field_id.split("-")[1] + "']").find('#tree-column').hasClass("oe_export_readonlyfield")) {
309 self.add_field(field_id.split("-")[1], event.relatedTarget.attributes["string"]["value"]);
316 showcontent: function(id) {
317 // show & hide the contents
318 var $this = this.$element.find("tr[id='treerow-" + id + "']");
319 var is_open = $this.hasClass('open');
320 $this.toggleClass('open');
322 var first_child = $this.find('img');
324 first_child.attr('src', '/web/static/src/img/expand.gif');
326 first_child.attr('src', '/web/static/src/img/collapse.gif');
328 var child_field = this.$element.find("tr[id^='treerow-" + id +"/']");
329 var child_len = (id.split("/")).length + 1;
330 for (var i = 0; i < child_field.length; i++) {
331 var $child = $(child_field[i]);
334 } else if (child_len == (child_field[i].id.split("/")).length) {
335 if ($child.hasClass('open')) {
336 $child.removeClass('open');
337 $child.find('img').attr('src', '/web/static/src/img/expand.gif');
343 add_field: function(field_id, string) {
344 var field_list = this.$element.find('#fields_list');
345 if (this.$element.find("#fields_list option[value='" + field_id + "']")
346 && !this.$element.find("#fields_list option[value='" + field_id + "']").length) {
347 field_list.append(new Option(string, field_id));
350 get_fields: function() {
351 var export_field = [];
352 this.$element.find("#fields_list option").each(function() {
353 export_field.push($(this).val());
355 if (!export_field.length) {
356 alert('Please select fields to save export list...');
360 on_click_export_data: function() {
361 $.blockUI(this.$element);
362 var exported_fields = [], self = this;
363 this.$element.find("#fields_list option").each(function() {
364 var fieldname = self.records[$(this).val()];
365 exported_fields.push({name: fieldname, label: $(this).text()});
367 if (_.isEmpty(exported_fields)) {
368 alert('Please select fields to export...');
372 exported_fields.unshift({name: 'id', label: 'External ID'});
373 var export_format = this.$element.find("#export_format").val();
374 this.session.get_file({
375 url: '/web/export/' + export_format,
376 data: {data: JSON.stringify({
377 model: this.dataset.model,
378 fields: exported_fields,
379 ids: this.dataset.ids,
380 domain: this.dataset.domain,
381 import_compat: Boolean(
382 this.$element.find("#import_compat").val())
384 complete: $.unblockUI
388 $(this.$dialog).remove();