2018-10-10 07:56:23 -04:00
|
|
|
import showModal from "discourse/lib/show-modal";
|
|
|
|
import Query from "discourse/plugins/discourse-data-explorer/discourse/models/query";
|
|
|
|
import { popupAjaxError } from "discourse/lib/ajax-error";
|
|
|
|
import { ajax } from "discourse/lib/ajax";
|
2019-07-16 06:46:32 -04:00
|
|
|
import {
|
|
|
|
default as computed,
|
|
|
|
observes
|
2020-02-19 11:57:59 -05:00
|
|
|
} from "discourse-common/utils/decorators";
|
2015-06-25 17:53:03 -04:00
|
|
|
|
2019-10-16 06:43:10 -04:00
|
|
|
const NoQuery = Query.create({ name: "No queries", fake: true, group_ids: [] });
|
2015-07-02 12:15:55 -04:00
|
|
|
|
2016-11-09 11:58:18 -05:00
|
|
|
export default Ember.Controller.extend({
|
2015-06-30 18:56:09 -04:00
|
|
|
queryParams: { selectedQueryId: "id" },
|
2015-06-30 13:20:22 -04:00
|
|
|
selectedQueryId: null,
|
2018-10-10 07:29:13 -04:00
|
|
|
editDisabled: false,
|
2015-06-30 18:12:12 -04:00
|
|
|
showResults: false,
|
2015-07-14 12:44:42 -04:00
|
|
|
hideSchema: false,
|
2015-06-30 12:07:33 -04:00
|
|
|
loading: false,
|
2015-07-08 19:46:36 -04:00
|
|
|
explain: false,
|
2015-06-25 17:53:03 -04:00
|
|
|
|
2018-10-10 07:56:23 -04:00
|
|
|
saveDisabled: Ember.computed.not("selectedItem.dirty"),
|
2019-10-16 06:43:35 -04:00
|
|
|
runDisabled: Ember.computed.reads("selectedItem.dirty"),
|
|
|
|
results: Ember.computed.reads("selectedItem.results"),
|
2015-07-14 13:34:23 -04:00
|
|
|
|
2018-08-31 14:11:33 -04:00
|
|
|
asc: null,
|
|
|
|
order: null,
|
2015-07-14 13:34:23 -04:00
|
|
|
editing: false,
|
|
|
|
everEditing: false,
|
2018-08-12 12:08:25 -04:00
|
|
|
showRecentQueries: true,
|
2018-10-10 07:56:23 -04:00
|
|
|
sortBy: ["last_run_at:desc"],
|
2019-01-22 06:49:01 -05:00
|
|
|
sortedQueries: Ember.computed.sort("model", "sortBy"),
|
2015-06-30 13:20:22 -04:00
|
|
|
|
2018-12-28 04:28:28 -05:00
|
|
|
@computed("search", "sortBy")
|
2019-07-16 06:46:32 -04:00
|
|
|
filteredContent(search) {
|
|
|
|
const regexp = new RegExp(search, "i");
|
2019-10-16 06:43:35 -04:00
|
|
|
return this.sortedQueries.filter(
|
|
|
|
result => regexp.test(result.name) || regexp.test(result.description)
|
|
|
|
);
|
2018-11-02 08:41:20 -04:00
|
|
|
},
|
|
|
|
|
2019-07-16 06:46:32 -04:00
|
|
|
@computed("newQueryName")
|
|
|
|
createDisabled(newQueryName) {
|
|
|
|
return (newQueryName || "").trim().length === 0;
|
|
|
|
},
|
2018-05-09 16:22:39 -04:00
|
|
|
|
2019-07-16 06:46:32 -04:00
|
|
|
@computed("selectedQueryId")
|
|
|
|
selectedItem(selectedQueryId) {
|
2019-10-16 06:43:10 -04:00
|
|
|
const id = parseInt(selectedQueryId, 10);
|
|
|
|
const item = this.model.findBy("id", id);
|
|
|
|
|
2018-10-10 07:56:23 -04:00
|
|
|
!isNaN(id)
|
|
|
|
? this.set("showRecentQueries", false)
|
|
|
|
: this.set("showRecentQueries", true);
|
2019-10-16 06:43:10 -04:00
|
|
|
|
|
|
|
if (id < 0) {
|
|
|
|
this.set("editDisabled", true);
|
|
|
|
}
|
|
|
|
|
2015-07-02 12:15:55 -04:00
|
|
|
return item || NoQuery;
|
2019-07-16 06:46:32 -04:00
|
|
|
},
|
2015-06-25 17:53:03 -04:00
|
|
|
|
2019-09-11 10:09:41 -04:00
|
|
|
@computed("selectedItem", "editing")
|
2019-09-11 11:30:39 -04:00
|
|
|
selectedGroupNames() {
|
2019-09-11 10:09:41 -04:00
|
|
|
const groupIds = this.selectedItem.group_ids || [];
|
|
|
|
const groupNames = groupIds.map(id => {
|
2019-09-11 11:30:39 -04:00
|
|
|
return this.groupOptions.find(groupOption => groupOption.id === id).name;
|
2019-09-11 10:09:41 -04:00
|
|
|
});
|
|
|
|
return groupNames.join(", ");
|
|
|
|
},
|
|
|
|
|
|
|
|
@computed("groups")
|
|
|
|
groupOptions(groups) {
|
2019-11-14 13:39:55 -05:00
|
|
|
return groups.map(g => {
|
2019-09-11 10:09:41 -04:00
|
|
|
return { id: g.id.toString(), name: g.name };
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
2019-07-16 06:46:32 -04:00
|
|
|
@computed("selectedItem", "selectedItem.dirty")
|
|
|
|
othersDirty(selectedItem) {
|
|
|
|
return !!this.model.find(q => q !== selectedItem && q.dirty);
|
|
|
|
},
|
2015-07-14 13:34:23 -04:00
|
|
|
|
2019-07-16 06:46:32 -04:00
|
|
|
@observes("editing")
|
|
|
|
setEverEditing() {
|
|
|
|
if (this.editing && !this.everEditing) {
|
2018-10-10 07:56:23 -04:00
|
|
|
this.set("everEditing", true);
|
2015-07-14 13:34:23 -04:00
|
|
|
}
|
2019-07-16 06:46:32 -04:00
|
|
|
},
|
2015-06-30 18:12:12 -04:00
|
|
|
|
2015-06-30 15:52:17 -04:00
|
|
|
addCreatedRecord(record) {
|
2019-07-16 06:46:32 -04:00
|
|
|
this.model.pushObject(record);
|
2018-10-10 07:56:23 -04:00
|
|
|
this.set("selectedQueryId", Ember.get(record, "id"));
|
2019-07-16 06:46:32 -04:00
|
|
|
this.selectedItem.set("dirty", false);
|
|
|
|
this.setProperties({
|
|
|
|
showResults: false,
|
|
|
|
results: null,
|
|
|
|
editing: true
|
|
|
|
});
|
2015-06-30 15:52:17 -04:00
|
|
|
},
|
|
|
|
|
2015-07-08 19:46:36 -04:00
|
|
|
save() {
|
2018-10-10 07:56:23 -04:00
|
|
|
this.set("loading", true);
|
|
|
|
if (this.get("selectedItem.description") === "")
|
|
|
|
this.set("selectedItem.description", "");
|
2019-09-11 11:30:39 -04:00
|
|
|
|
2019-07-16 06:46:32 -04:00
|
|
|
return this.selectedItem
|
2018-10-10 07:56:23 -04:00
|
|
|
.save()
|
2019-07-16 06:46:32 -04:00
|
|
|
.then(() => {
|
|
|
|
const query = this.selectedItem;
|
2018-10-10 07:56:23 -04:00
|
|
|
query.markNotDirty();
|
2019-07-16 06:46:32 -04:00
|
|
|
this.set("editing", false);
|
2018-10-10 07:56:23 -04:00
|
|
|
})
|
2019-07-16 06:46:32 -04:00
|
|
|
.catch(x => {
|
2018-10-10 07:56:23 -04:00
|
|
|
popupAjaxError(x);
|
|
|
|
throw x;
|
|
|
|
})
|
2019-07-16 06:46:32 -04:00
|
|
|
.finally(() => this.set("loading", false));
|
2015-07-08 19:46:36 -04:00
|
|
|
},
|
|
|
|
|
2015-06-30 13:20:22 -04:00
|
|
|
actions: {
|
2015-06-25 17:53:03 -04:00
|
|
|
dummy() {},
|
2019-04-07 02:05:43 -04:00
|
|
|
|
|
|
|
expandSchema() {
|
|
|
|
this.set("hideSchema", false);
|
|
|
|
},
|
2015-06-25 17:53:03 -04:00
|
|
|
|
|
|
|
importQuery() {
|
2018-10-10 07:56:23 -04:00
|
|
|
showModal("import-query");
|
|
|
|
this.set("showCreate", false);
|
2015-06-30 13:37:48 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
showCreate() {
|
2018-10-10 07:56:23 -04:00
|
|
|
this.set("showCreate", true);
|
2015-06-25 17:53:03 -04:00
|
|
|
},
|
|
|
|
|
2015-06-30 12:07:33 -04:00
|
|
|
editName() {
|
2018-10-10 07:56:23 -04:00
|
|
|
this.set("editing", true);
|
2015-06-30 12:07:33 -04:00
|
|
|
},
|
|
|
|
|
2015-06-30 15:52:17 -04:00
|
|
|
download() {
|
2018-10-10 07:56:23 -04:00
|
|
|
window.open(this.get("selectedItem.downloadUrl"), "_blank");
|
2015-06-30 15:52:17 -04:00
|
|
|
},
|
|
|
|
|
2018-08-14 07:06:28 -04:00
|
|
|
scrollTop() {
|
2018-10-10 07:56:23 -04:00
|
|
|
window.scrollTo(0, 0);
|
2019-07-16 06:46:32 -04:00
|
|
|
this.setProperties({ editing: false, everEditing: false });
|
2018-08-16 13:44:07 -04:00
|
|
|
},
|
|
|
|
|
2018-08-17 06:00:07 -04:00
|
|
|
goHome() {
|
2018-08-31 14:11:33 -04:00
|
|
|
this.setProperties({
|
|
|
|
asc: null,
|
|
|
|
order: null,
|
2018-09-12 09:28:54 -04:00
|
|
|
showResults: false,
|
2018-10-10 07:29:13 -04:00
|
|
|
editDisabled: false,
|
2018-08-31 14:11:33 -04:00
|
|
|
selectedQueryId: null,
|
2018-10-10 07:56:23 -04:00
|
|
|
sortBy: ["last_run_at:desc"]
|
2018-08-31 14:11:33 -04:00
|
|
|
});
|
2018-10-10 07:56:23 -04:00
|
|
|
this.send("refreshModel");
|
|
|
|
this.transitionToRoute("adminPlugins.explorer");
|
2018-08-14 07:06:28 -04:00
|
|
|
},
|
|
|
|
|
2015-06-30 18:12:12 -04:00
|
|
|
resetParams() {
|
2019-07-16 06:46:32 -04:00
|
|
|
this.selectedItem.resetParams();
|
2015-06-30 18:12:12 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
saveDefaults() {
|
2019-07-16 06:46:32 -04:00
|
|
|
this.selectedItem.saveDefaults();
|
2015-06-30 18:12:12 -04:00
|
|
|
},
|
|
|
|
|
2015-07-08 19:46:36 -04:00
|
|
|
save() {
|
|
|
|
this.save();
|
|
|
|
},
|
|
|
|
|
|
|
|
saverun() {
|
2018-10-10 07:56:23 -04:00
|
|
|
this.save().then(() => this.send("run"));
|
2015-07-08 19:46:36 -04:00
|
|
|
},
|
|
|
|
|
2018-08-30 07:13:15 -04:00
|
|
|
sortByProperty(property) {
|
2018-08-30 11:38:12 -04:00
|
|
|
if (this.sortBy[0] === `${property}:desc`) {
|
2018-10-10 07:56:23 -04:00
|
|
|
this.set("sortBy", [`${property}:asc`]);
|
2018-08-30 11:38:12 -04:00
|
|
|
} else {
|
2018-10-10 07:56:23 -04:00
|
|
|
this.set("sortBy", [`${property}:desc`]);
|
2018-08-30 11:38:12 -04:00
|
|
|
}
|
|
|
|
},
|
2018-08-30 07:13:15 -04:00
|
|
|
|
2015-06-30 15:52:17 -04:00
|
|
|
create() {
|
2019-07-16 06:46:32 -04:00
|
|
|
const name = this.newQueryName.trim();
|
|
|
|
this.setProperties({
|
|
|
|
loading: true,
|
|
|
|
showCreate: false,
|
|
|
|
showRecentQueries: false
|
|
|
|
});
|
2018-05-09 16:22:39 -04:00
|
|
|
this.store
|
2018-10-10 07:56:23 -04:00
|
|
|
.createRecord("query", { name })
|
2018-05-09 16:22:39 -04:00
|
|
|
.save()
|
2018-10-10 07:56:23 -04:00
|
|
|
.then(result => this.addCreatedRecord(result.target))
|
2018-05-09 16:22:39 -04:00
|
|
|
.catch(popupAjaxError)
|
2018-10-10 07:56:23 -04:00
|
|
|
.finally(() => this.set("loading", false));
|
2015-06-30 15:52:17 -04:00
|
|
|
},
|
|
|
|
|
2015-06-30 12:07:33 -04:00
|
|
|
discard() {
|
2018-10-10 07:56:23 -04:00
|
|
|
this.set("loading", true);
|
|
|
|
this.store
|
|
|
|
.find("query", this.get("selectedItem.id"))
|
2019-07-16 06:46:32 -04:00
|
|
|
.then(result => {
|
|
|
|
const query = this.get("selectedItem");
|
2018-10-10 07:56:23 -04:00
|
|
|
query.setProperties(result.getProperties(Query.updatePropertyNames));
|
2019-09-11 10:09:41 -04:00
|
|
|
if (!query.group_ids || !Array.isArray(query.group_ids))
|
|
|
|
query.set("group_ids", []);
|
2018-10-10 07:56:23 -04:00
|
|
|
query.markNotDirty();
|
2019-07-16 06:46:32 -04:00
|
|
|
this.set("editing", false);
|
2018-10-10 07:56:23 -04:00
|
|
|
})
|
|
|
|
.catch(popupAjaxError)
|
2019-07-16 06:46:32 -04:00
|
|
|
.finally(() => this.set("loading", false));
|
2015-06-30 15:52:17 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
destroy() {
|
2019-07-16 06:46:32 -04:00
|
|
|
const query = this.selectedItem;
|
|
|
|
this.setProperties({ loading: true, showResults: false });
|
2018-10-10 07:56:23 -04:00
|
|
|
this.store
|
|
|
|
.destroyRecord("query", query)
|
2019-07-16 06:46:32 -04:00
|
|
|
.then(() => query.set("destroyed", true))
|
2018-10-10 07:56:23 -04:00
|
|
|
.catch(popupAjaxError)
|
2019-07-16 06:46:32 -04:00
|
|
|
.finally(() => this.set("loading", false));
|
2015-06-30 15:52:17 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
recover() {
|
2019-07-16 06:46:32 -04:00
|
|
|
const query = this.selectedItem;
|
|
|
|
this.setProperties({ loading: true, showResults: true });
|
2018-10-10 07:56:23 -04:00
|
|
|
query
|
|
|
|
.save()
|
2019-07-16 06:46:32 -04:00
|
|
|
.then(() => query.set("destroyed", false))
|
2018-10-10 07:56:23 -04:00
|
|
|
.catch(popupAjaxError)
|
2019-07-16 06:46:32 -04:00
|
|
|
.finally(() => {
|
|
|
|
this.set("loading", false);
|
2018-10-10 07:56:23 -04:00
|
|
|
});
|
2015-06-30 12:07:33 -04:00
|
|
|
},
|
|
|
|
|
2015-06-25 17:53:03 -04:00
|
|
|
run() {
|
2018-10-10 07:56:23 -04:00
|
|
|
if (this.get("selectedItem.dirty")) {
|
2015-06-30 12:07:33 -04:00
|
|
|
return;
|
|
|
|
}
|
2019-07-16 06:46:32 -04:00
|
|
|
if (this.runDisabled) {
|
2015-07-09 15:02:47 -04:00
|
|
|
return;
|
|
|
|
}
|
2015-06-30 18:12:12 -04:00
|
|
|
|
2019-07-16 06:46:32 -04:00
|
|
|
this.setProperties({ loading: true, showResults: false });
|
2018-10-10 07:56:23 -04:00
|
|
|
ajax(
|
|
|
|
"/admin/plugins/explorer/queries/" +
|
|
|
|
this.get("selectedItem.id") +
|
|
|
|
"/run",
|
|
|
|
{
|
|
|
|
type: "POST",
|
|
|
|
data: {
|
|
|
|
params: JSON.stringify(this.get("selectedItem.params")),
|
2019-07-16 06:46:32 -04:00
|
|
|
explain: this.explain
|
2018-10-10 07:56:23 -04:00
|
|
|
}
|
2015-06-25 17:53:03 -04:00
|
|
|
}
|
2018-10-10 07:56:23 -04:00
|
|
|
)
|
2019-07-16 06:46:32 -04:00
|
|
|
.then(result => {
|
|
|
|
this.set("results", result);
|
2018-10-10 07:56:23 -04:00
|
|
|
if (!result.success) {
|
2019-07-16 06:46:32 -04:00
|
|
|
this.set("showResults", false);
|
2018-10-10 07:56:23 -04:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2019-07-16 06:46:32 -04:00
|
|
|
this.set("showResults", true);
|
2018-10-10 07:56:23 -04:00
|
|
|
})
|
2019-07-16 06:46:32 -04:00
|
|
|
.catch(err => {
|
|
|
|
this.set("showResults", false);
|
2018-10-10 07:56:23 -04:00
|
|
|
if (err.jqXHR && err.jqXHR.status === 422 && err.jqXHR.responseJSON) {
|
2019-07-16 06:46:32 -04:00
|
|
|
this.set("results", err.jqXHR.responseJSON);
|
2018-10-10 07:56:23 -04:00
|
|
|
} else {
|
|
|
|
popupAjaxError(err);
|
|
|
|
}
|
|
|
|
})
|
2019-07-16 06:46:32 -04:00
|
|
|
.finally(() => this.set("loading", false));
|
2015-06-25 17:53:03 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|