2019-10-23 13:06:54 -04:00
|
|
|
import Controller from "@ember/controller";
|
2023-10-10 14:38:59 -04:00
|
|
|
import { action } from "@ember/object";
|
2015-08-20 13:43:12 -04:00
|
|
|
import { popupAjaxError } from "discourse/lib/ajax-error";
|
2023-10-10 14:38:59 -04:00
|
|
|
import discourseComputed from "discourse-common/utils/decorators";
|
2015-08-20 13:43:12 -04:00
|
|
|
|
2023-03-15 05:42:12 -04:00
|
|
|
export default class AdminEmbeddingController extends Controller {
|
|
|
|
saved = false;
|
|
|
|
embedding = null;
|
2015-08-18 17:15:46 -04:00
|
|
|
|
2015-08-20 13:43:12 -04:00
|
|
|
// show settings if we have at least one created host
|
2019-11-07 16:38:28 -05:00
|
|
|
@discourseComputed("embedding.embeddable_hosts.@each.isCreated")
|
2015-08-20 13:43:12 -04:00
|
|
|
showSecondary() {
|
|
|
|
const hosts = this.get("embedding.embeddable_hosts");
|
2016-10-26 15:44:36 -04:00
|
|
|
return hosts.length && hosts.findBy("isCreated");
|
2023-03-15 05:42:12 -04:00
|
|
|
}
|
2015-08-20 13:43:12 -04:00
|
|
|
|
2019-11-07 16:38:28 -05:00
|
|
|
@discourseComputed("embedding.base_url")
|
2015-08-20 13:43:12 -04:00
|
|
|
embeddingCode(baseUrl) {
|
|
|
|
const html = `<div id='discourse-comments'></div>
|
2023-02-28 07:31:59 -05:00
|
|
|
<meta name='discourse-username' content='DISCOURSE_USERNAME'>
|
2015-08-20 13:43:12 -04:00
|
|
|
|
|
|
|
<script type="text/javascript">
|
2023-02-28 07:31:59 -05:00
|
|
|
DiscourseEmbed = {
|
|
|
|
discourseUrl: '${baseUrl}/',
|
|
|
|
discourseEmbedUrl: 'EMBED_URL',
|
|
|
|
// className: 'CLASS_NAME',
|
|
|
|
};
|
2015-08-20 13:43:12 -04:00
|
|
|
|
|
|
|
(function() {
|
|
|
|
var d = document.createElement('script'); d.type = 'text/javascript'; d.async = true;
|
|
|
|
d.src = DiscourseEmbed.discourseUrl + 'javascripts/embed.js';
|
|
|
|
(document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(d);
|
|
|
|
})();
|
|
|
|
</script>`;
|
|
|
|
|
|
|
|
return html;
|
2023-03-15 05:42:12 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
@action
|
|
|
|
saveChanges() {
|
|
|
|
const embedding = this.embedding;
|
|
|
|
const updates = embedding.getProperties(embedding.get("fields"));
|
|
|
|
|
|
|
|
this.set("saved", false);
|
|
|
|
this.embedding
|
|
|
|
.update(updates)
|
|
|
|
.then(() => this.set("saved", true))
|
|
|
|
.catch(popupAjaxError);
|
|
|
|
}
|
|
|
|
|
|
|
|
@action
|
|
|
|
addHost() {
|
|
|
|
const host = this.store.createRecord("embeddable-host");
|
|
|
|
this.get("embedding.embeddable_hosts").pushObject(host);
|
|
|
|
}
|
|
|
|
|
|
|
|
@action
|
|
|
|
deleteHost(host) {
|
|
|
|
this.get("embedding.embeddable_hosts").removeObject(host);
|
|
|
|
}
|
|
|
|
}
|