diff --git a/assets/javascripts/discourse/components/query-result.js.es6 b/assets/javascripts/discourse/components/query-result.js.es6 index 116dd83..4c9a522 100644 --- a/assets/javascripts/discourse/components/query-result.js.es6 +++ b/assets/javascripts/discourse/components/query-result.js.es6 @@ -10,6 +10,11 @@ var defaultFallback = function(buffer, content, defaultRender) { defaultRender(b function isoYMD(date) { return date.getUTCFullYear() + "-" + date.getUTCMonth() + "-" + date.getUTCDate(); } +function randomIdShort() { + return 'xxxxxxxx'.replace(/[xy]/g, function() { + return (Math.random() * 16 | 0).toString(16); + }); +} const QueryResultComponent = Ember.Component.extend({ layoutName: 'explorer-query-result', @@ -25,10 +30,6 @@ const QueryResultComponent = Ember.Component.extend({ return this.get('content.columns').length; }.property('content.columns.length'), - downloadName: function() { - return this.get('query.name') + "@" + window.location.host + "-" + isoYMD(new Date()) + ".dcqresult.json"; - }.property(), - duration: function() { return I18n.t('explorer.run_time', {value: I18n.toNumber(this.get('content.duration'), {precision: 1})}); }.property('content.duration'), @@ -99,19 +100,45 @@ const QueryResultComponent = Ember.Component.extend({ }); }.property('content', 'columns.@each'), - _clickDownloadButton: function() { - const self = this; - const $button = this.$().find("#result-download"); - // use $.one to do once - $button.one('mouseover', function(e) { - const a = e.target; - let resultString = "data:text/plain;base64,"; - var jsonString = JSON.stringify(self.get('content')); - resultString += btoa(jsonString); + actions: { + downloadResult() { + const blankUrl = "about:blank"; + const windowName = randomIdShort(); - a.href = resultString; - }); - }.on('didInsertElement'), + let form = document.createElement("form"); + form.setAttribute('id', 'query-download-result'); + form.setAttribute('method', 'post'); + form.setAttribute('action', Discourse.getURL('/admin/plugins/explorer/queries/' + this.get('query.id') + '/run.json?download=1')); + form.setAttribute('target', windowName); + form.setAttribute('style', 'display:none;'); + + function addInput(form, name, value) { + let field; + field = document.createElement('input'); + field.setAttribute('name', name); + field.setAttribute('value', value); + form.appendChild(field); + } + + addInput(form, 'params', JSON.stringify(this.get('params'))); + addInput(form, 'explain', this.get('hasExplain')); + addInput(form, 'limit', '1000000'); + + const newWindow = window.open(blankUrl, windowName); + + Discourse.ajax('/session/csrf.json').then(function(csrf) { + addInput(form, 'authenticity_token', csrf.csrf); + + document.body.appendChild(form); + form.submit(); + + Em.run.next('afterRender', function() { + document.body.removeChild(form); + newWindow.close(); + }); + }); + } + }, parent: function() { return this; }.property() diff --git a/assets/javascripts/discourse/controllers/admin-plugins-explorer.js.es6 b/assets/javascripts/discourse/controllers/admin-plugins-explorer.js.es6 index f620c74..aa6762a 100644 --- a/assets/javascripts/discourse/controllers/admin-plugins-explorer.js.es6 +++ b/assets/javascripts/discourse/controllers/admin-plugins-explorer.js.es6 @@ -48,7 +48,7 @@ export default Ember.ArrayController.extend({ return this.get('selectedItem').save().then(function() { const query = self.get('selectedItem'); query.markNotDirty(); - self.set('editName', false); + self.set('editing', false); }).catch(function(x) { popupAjaxError(x); throw x; @@ -70,7 +70,7 @@ export default Ember.ArrayController.extend({ }, editName() { - this.set('editName', true); + this.set('editing', true); }, download() { @@ -112,7 +112,7 @@ export default Ember.ArrayController.extend({ const query = self.get('selectedItem'); query.setProperties(result.getProperties(Query.updatePropertyNames)); query.markNotDirty(); - self.set('editName', false); + self.set('editing', false); }).catch(popupAjaxError).finally(function() { self.set('loading', false); }); @@ -145,6 +145,9 @@ export default Ember.ArrayController.extend({ if (this.get('selectedItem.dirty')) { return; } + if (this.get('runDisabled')) { + return; + } this.set('loading', true); this.set('showResults', false); diff --git a/assets/javascripts/discourse/templates/admin/plugins-explorer.hbs b/assets/javascripts/discourse/templates/admin/plugins-explorer.hbs index 554dbcf..3a55a79 100644 --- a/assets/javascripts/discourse/templates/admin/plugins-explorer.hbs +++ b/assets/javascripts/discourse/templates/admin/plugins-explorer.hbs @@ -28,7 +28,7 @@