2019-07-16 06:46:32 -04:00
|
|
|
import { on, observes } from "ember-addons/ember-computed-decorators";
|
2018-10-10 07:56:23 -04:00
|
|
|
import debounce from "discourse/lib/debounce";
|
|
|
|
import highlightSyntax from "discourse/lib/highlight-syntax";
|
|
|
|
import { bufferedRender } from "discourse-common/lib/buffered-render";
|
2015-07-14 13:34:23 -04:00
|
|
|
|
2018-10-10 07:56:23 -04:00
|
|
|
export default Ember.Component.extend(
|
|
|
|
bufferedRender({
|
|
|
|
buildBuffer(buffer) {
|
2019-07-16 06:46:32 -04:00
|
|
|
buffer.push("<pre><code class='" + this.codeClass + "'>");
|
|
|
|
buffer.push(Handlebars.Utils.escapeExpression(this.value));
|
2018-10-10 07:56:23 -04:00
|
|
|
buffer.push("</code></pre>");
|
|
|
|
},
|
2015-07-14 13:34:23 -04:00
|
|
|
|
2019-07-16 06:46:32 -04:00
|
|
|
@observes("value")
|
2018-10-10 07:56:23 -04:00
|
|
|
_refreshHighlight: debounce(function() {
|
|
|
|
this.rerenderBuffer();
|
2019-07-16 06:46:32 -04:00
|
|
|
}, 50),
|
2015-07-14 13:34:23 -04:00
|
|
|
|
2019-07-16 06:46:32 -04:00
|
|
|
@on("didInsertElement")
|
|
|
|
_applyHighlight() {
|
|
|
|
highlightSyntax($(this.element));
|
|
|
|
}
|
2018-10-10 07:56:23 -04:00
|
|
|
})
|
|
|
|
);
|