FEATURE: education panel on pinning at bottom of topics
This commit is contained in:
parent
cfc1444177
commit
97269fc918
|
@ -1,29 +0,0 @@
|
||||||
/**
|
|
||||||
A button for clearing a pinned topic
|
|
||||||
|
|
||||||
@class ClearPinButton
|
|
||||||
@extends Discourse.ButtonView
|
|
||||||
@namespace Discourse
|
|
||||||
@module Discourse
|
|
||||||
**/
|
|
||||||
Discourse.ClearPinButton = Discourse.ButtonView.extend({
|
|
||||||
textKey: 'topic.clear_pin.title',
|
|
||||||
helpKey: 'topic.clear_pin.help',
|
|
||||||
classNameBindings: ['unpinned'],
|
|
||||||
|
|
||||||
// Hide the button if it becomes unpinned
|
|
||||||
unpinned: function() {
|
|
||||||
// When not logged in don't show the button
|
|
||||||
if (!Discourse.User.current()) return 'hidden';
|
|
||||||
return this.get('controller.pinned') ? null : 'hidden';
|
|
||||||
}.property('controller.pinned'),
|
|
||||||
|
|
||||||
click: function() {
|
|
||||||
this.get('controller').send('clearPin');
|
|
||||||
},
|
|
||||||
|
|
||||||
renderIcon: function(buffer) {
|
|
||||||
buffer.push("<i class='fa fa-thumb-tack'></i>");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
|
@ -29,6 +29,8 @@ Discourse.DropdownButtonView = Discourse.View.extend({
|
||||||
|
|
||||||
render: function(buffer) {
|
render: function(buffer) {
|
||||||
var self = this;
|
var self = this;
|
||||||
|
var descriptionKey = self.get('descriptionKey') || 'description';
|
||||||
|
|
||||||
buffer.push("<h4 class='title'>" + self.get('title') + "</h4>");
|
buffer.push("<h4 class='title'>" + self.get('title') + "</h4>");
|
||||||
buffer.push("<button class='btn standard dropdown-toggle' data-toggle='dropdown'>");
|
buffer.push("<button class='btn standard dropdown-toggle' data-toggle='dropdown'>");
|
||||||
buffer.push(self.get('text'));
|
buffer.push(self.get('text'));
|
||||||
|
@ -40,7 +42,7 @@ Discourse.DropdownButtonView = Discourse.View.extend({
|
||||||
textKey = row[1],
|
textKey = row[1],
|
||||||
iconClass = row[2],
|
iconClass = row[2],
|
||||||
title = I18n.t(textKey + ".title"),
|
title = I18n.t(textKey + ".title"),
|
||||||
description = I18n.t(textKey + ".description"),
|
description = I18n.t(textKey + "." + descriptionKey),
|
||||||
className = (self.get('activeItem') === id? 'disabled': '');
|
className = (self.get('activeItem') === id? 'disabled': '');
|
||||||
|
|
||||||
buffer.push("<li data-id=\"" + id + "\" class=\"" + className + "\"><a href='#'>");
|
buffer.push("<li data-id=\"" + id + "\" class=\"" + className + "\"><a href='#'>");
|
||||||
|
|
|
@ -0,0 +1,58 @@
|
||||||
|
/**
|
||||||
|
A button to display pinned options.
|
||||||
|
|
||||||
|
@class PinnedButton
|
||||||
|
@extends Discourse.DropdownButtonView
|
||||||
|
@namespace Discourse
|
||||||
|
@module Discourse
|
||||||
|
**/
|
||||||
|
Discourse.PinnedButton = Discourse.DropdownButtonView.extend({
|
||||||
|
descriptionKey: 'help',
|
||||||
|
classNames: ['pinned-options'],
|
||||||
|
title: '',
|
||||||
|
longDescription: function(){
|
||||||
|
var topic = this.get('topic');
|
||||||
|
var globally = topic.get('pinned_globally') ? '_globally' : '';
|
||||||
|
|
||||||
|
var key = 'topic_statuses.' + (topic.get('pinned') ? 'pinned' + globally : 'unpinned') + '.help';
|
||||||
|
return I18n.t(key);
|
||||||
|
}.property('topic.pinned'),
|
||||||
|
|
||||||
|
topic: Em.computed.alias('controller.model'),
|
||||||
|
|
||||||
|
hidden: function(){
|
||||||
|
var topic = this.get('topic');
|
||||||
|
return topic.get('deleted') || (!topic.get('pinned') && !topic.get('unpinned'));
|
||||||
|
}.property('topic.pinned', 'topic.deleted', 'topic.unpinned'),
|
||||||
|
|
||||||
|
activeItem: function(){
|
||||||
|
return this.get('topic.pinned') ? 'pinned' : 'unpinned';
|
||||||
|
}.property('topic.pinned'),
|
||||||
|
|
||||||
|
dropDownContent: function() {
|
||||||
|
var globally = this.get('topic.pinned_globally') ? '_globally' : '';
|
||||||
|
return [
|
||||||
|
['pinned', 'topic_statuses.pinned' + globally, 'fa fa-thumb-tack'],
|
||||||
|
['unpinned', 'topic_statuses.unpinned', 'fa fa-thumb-tack unpinned']
|
||||||
|
];
|
||||||
|
}.property(),
|
||||||
|
|
||||||
|
text: function() {
|
||||||
|
var globally = this.get('topic.pinned_globally') ? '_globally' : '';
|
||||||
|
var state = this.get('topic.pinned') ? 'pinned' + globally : 'unpinned';
|
||||||
|
|
||||||
|
return '<span class="fa fa-thumb-tack' + (state === 'unpinned' ? ' unpinned' : "") + '"></span> ' +
|
||||||
|
I18n.t('topic_statuses.' + state + '.title') + "<span class='caret'></span>";
|
||||||
|
}.property('topic.pinned', 'topic.unpinned'),
|
||||||
|
|
||||||
|
clicked: function(id) {
|
||||||
|
var topic = this.get('topic');
|
||||||
|
if(id==='unpinned'){
|
||||||
|
topic.clearPin();
|
||||||
|
} else {
|
||||||
|
topic.rePin();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
|
@ -26,7 +26,6 @@ Discourse.TopicFooterButtonsView = Discourse.ContainerView.extend({
|
||||||
}
|
}
|
||||||
this.attachViewClass(Discourse.StarButton);
|
this.attachViewClass(Discourse.StarButton);
|
||||||
this.attachViewClass(Discourse.ShareButton);
|
this.attachViewClass(Discourse.ShareButton);
|
||||||
this.attachViewClass(Discourse.ClearPinButton);
|
|
||||||
if (this.get('topic.details.can_flag_topic')) {
|
if (this.get('topic.details.can_flag_topic')) {
|
||||||
this.attachViewClass(Discourse.FlagTopicButton);
|
this.attachViewClass(Discourse.FlagTopicButton);
|
||||||
}
|
}
|
||||||
|
@ -34,6 +33,7 @@ Discourse.TopicFooterButtonsView = Discourse.ContainerView.extend({
|
||||||
if (this.get('topic.details.can_create_post')) {
|
if (this.get('topic.details.can_create_post')) {
|
||||||
this.attachViewClass(Discourse.ReplyButton);
|
this.attachViewClass(Discourse.ReplyButton);
|
||||||
}
|
}
|
||||||
|
this.attachViewClass(Discourse.PinnedButton);
|
||||||
this.attachViewClass(Discourse.NotificationsButton);
|
this.attachViewClass(Discourse.NotificationsButton);
|
||||||
|
|
||||||
this.trigger('additionalButtons', this);
|
this.trigger('additionalButtons', this);
|
||||||
|
|
|
@ -32,6 +32,7 @@ class TopicViewSerializer < ApplicationSerializer
|
||||||
:starred,
|
:starred,
|
||||||
:posted,
|
:posted,
|
||||||
:unpinned,
|
:unpinned,
|
||||||
|
:pinned_globally,
|
||||||
:pinned, # Is topic pinned and viewer hasn't cleared the pin?
|
:pinned, # Is topic pinned and viewer hasn't cleared the pin?
|
||||||
:pinned_at, # Ignores clear pin
|
:pinned_at, # Ignores clear pin
|
||||||
:details,
|
:details,
|
||||||
|
@ -145,6 +146,10 @@ class TopicViewSerializer < ApplicationSerializer
|
||||||
end
|
end
|
||||||
alias_method :include_posted?, :has_topic_user?
|
alias_method :include_posted?, :has_topic_user?
|
||||||
|
|
||||||
|
def pinned_globally
|
||||||
|
object.topic.pinned_globally
|
||||||
|
end
|
||||||
|
|
||||||
def pinned
|
def pinned
|
||||||
PinnedCheck.pinned?(object.topic, object.topic_user)
|
PinnedCheck.pinned?(object.topic, object.topic_user)
|
||||||
end
|
end
|
||||||
|
|
|
@ -1144,15 +1144,20 @@ en:
|
||||||
|
|
||||||
topic_statuses:
|
topic_statuses:
|
||||||
locked:
|
locked:
|
||||||
help: "this topic is closed; it no longer accepts new replies"
|
help: "This topic is closed; it no longer accepts new replies"
|
||||||
unpinned:
|
unpinned:
|
||||||
help: "this topic is unpinned; it will displayed in default ordering"
|
title: "Unpinned"
|
||||||
|
help: "This topic is unpinned; it will displayed in default ordering"
|
||||||
|
pinned_globally:
|
||||||
|
title: "Pinned Globally"
|
||||||
|
help: "This topic is pinned globally; it will display at the top of all lists"
|
||||||
pinned:
|
pinned:
|
||||||
help: "this topic is pinned; it will display at the top of its category"
|
title: "Pinned"
|
||||||
|
help: "This topic is pinned; it will display at the top of its category"
|
||||||
archived:
|
archived:
|
||||||
help: "this topic is archived; it is frozen and cannot be changed"
|
help: "This topic is archived; it is frozen and cannot be changed"
|
||||||
invisible:
|
invisible:
|
||||||
help: "this topic is invisible; it will not be displayed in topic lists, and can only be accessed via a direct link"
|
help: "This topic is invisible; it will not be displayed in topic lists, and can only be accessed via a direct link"
|
||||||
|
|
||||||
posts: "Posts"
|
posts: "Posts"
|
||||||
posts_long: "there are {{number}} posts in this topic"
|
posts_long: "there are {{number}} posts in this topic"
|
||||||
|
|
Loading…
Reference in New Issue