import PostView from "discourse/views/post"; function createPollView(container, post, poll, vote) { const controller = container.lookup("controller:poll", { singleton: false }), view = container.lookup("view:poll"); controller.set("vote", vote); controller.setProperties({ model: Em.Object.create(poll), post: post, }); view.set("controller", controller); return view; } export default { name: "extend-for-poll", initialize(container) { const messageBus = container.lookup("message-bus:main"); // listen for back-end to tell us when a post has a poll messageBus.subscribe("/polls", data => { const post = container.lookup("controller:topic").get("postStream").findLoadedPost(data.post_id); // HACK to trigger the "postViewUpdated" event post.set("cooked", post.get("cooked") + " "); }); // overwrite polls PostView.reopen({ _createPollViews: function($post) { const self = this, post = this.get("post"), polls = post.get("polls"), votes = post.get("polls_votes") || {}; // don't even bother when there's no poll if (!polls) { return; } // clean-up if needed this._cleanUpPollViews(); const pollViews = {}; // iterate over all polls $(".poll", $post).each(function() { const $div = $("