use canonical-url plugin to make view more clean
This commit is contained in:
parent
3bfdb2dd5b
commit
cab4d95eaf
|
@ -1,4 +1,5 @@
|
||||||
require 'current_user'
|
require 'current_user'
|
||||||
|
require 'canonical_url'
|
||||||
require_dependency 'discourse'
|
require_dependency 'discourse'
|
||||||
require_dependency 'custom_renderer'
|
require_dependency 'custom_renderer'
|
||||||
require 'archetype'
|
require 'archetype'
|
||||||
|
@ -6,6 +7,8 @@ require_dependency 'rate_limiter'
|
||||||
|
|
||||||
class ApplicationController < ActionController::Base
|
class ApplicationController < ActionController::Base
|
||||||
include CurrentUser
|
include CurrentUser
|
||||||
|
|
||||||
|
include CanonicalURL::ControllerExtensions
|
||||||
|
|
||||||
serialization_scope :guardian
|
serialization_scope :guardian
|
||||||
|
|
||||||
|
|
|
@ -30,6 +30,8 @@ class TopicsController < ApplicationController
|
||||||
track_visit_to_topic
|
track_visit_to_topic
|
||||||
perform_show_response
|
perform_show_response
|
||||||
end
|
end
|
||||||
|
|
||||||
|
canonical_url @topic_view.canonical_path
|
||||||
end
|
end
|
||||||
|
|
||||||
def destroy_timings
|
def destroy_timings
|
||||||
|
|
|
@ -1,10 +1,12 @@
|
||||||
require 'current_user'
|
require 'current_user'
|
||||||
|
require 'canonical_url'
|
||||||
require_dependency 'guardian'
|
require_dependency 'guardian'
|
||||||
require_dependency 'unread'
|
require_dependency 'unread'
|
||||||
require_dependency 'age_words'
|
require_dependency 'age_words'
|
||||||
|
|
||||||
module ApplicationHelper
|
module ApplicationHelper
|
||||||
include CurrentUser
|
include CurrentUser
|
||||||
|
include CanonicalURL::Helpers
|
||||||
|
|
||||||
def with_format(format, &block)
|
def with_format(format, &block)
|
||||||
old_formats = formats
|
old_formats = formats
|
||||||
|
|
|
@ -6,14 +6,8 @@
|
||||||
<meta name="viewport" content="target-densitydpi=device-dpi, width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0" />
|
<meta name="viewport" content="target-densitydpi=device-dpi, width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0" />
|
||||||
<meta content="" name="description">
|
<meta content="" name="description">
|
||||||
<meta content="" name="author">
|
<meta content="" name="author">
|
||||||
<%-
|
|
||||||
canonical = capture{yield :canonical}
|
<%= canonical_link_tag %>
|
||||||
if canonical
|
|
||||||
%>
|
|
||||||
<meta rel="canonical" href="<%= canonical %>">
|
|
||||||
<%-
|
|
||||||
end
|
|
||||||
%>
|
|
||||||
|
|
||||||
<link rel="icon" type="image/png" href=<%=SiteSetting.favicon_url%>>
|
<link rel="icon" type="image/png" href=<%=SiteSetting.favicon_url%>>
|
||||||
<%= javascript_include_tag "preload_store" %>
|
<%= javascript_include_tag "preload_store" %>
|
||||||
|
|
|
@ -19,8 +19,5 @@
|
||||||
</p>
|
</p>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
||||||
<%- content_for :canonical do %>
|
|
||||||
<%= "#{request.protocol}#{request.host_with_port}#{@topic_view.canonical_path}" %>
|
|
||||||
<%- end %>
|
|
||||||
|
|
||||||
<p>Powered by <a href="http://www.discourse.org">Discourse</a>, best viewed with JavaScript enabled</p>
|
<p>Powered by <a href="http://www.discourse.org">Discourse</a>, best viewed with JavaScript enabled</p>
|
|
@ -0,0 +1,43 @@
|
||||||
|
module CanonicalURL
|
||||||
|
module ControllerExtensions
|
||||||
|
def canonical_url(url_for_options = {})
|
||||||
|
case url_for_options
|
||||||
|
when Hash
|
||||||
|
@canonical_url = url_for(url_for_options)
|
||||||
|
else
|
||||||
|
@canonical_url = url_for_options
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
module Helpers
|
||||||
|
def canonical_link_tag(url = nil)
|
||||||
|
|
||||||
|
return '' unless url || @canonical_url
|
||||||
|
tag('link', :rel => 'canonical', :href => url || @canonical_url || request.url)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# https://github.com/mbleigh/canonical-url/blob/master/lib/canonical_url.rb
|
||||||
|
|
||||||
|
# Copyright (c) 2009 Michael Bleigh and Intridea, Inc.
|
||||||
|
#
|
||||||
|
# Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
# a copy of this software and associated documentation files (the
|
||||||
|
# "Software"), to deal in the Software without restriction, including
|
||||||
|
# without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
# distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
# permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
# the following conditions:
|
||||||
|
#
|
||||||
|
# The above copyright notice and this permission notice shall be
|
||||||
|
# included in all copies or substantial portions of the Software.
|
||||||
|
#
|
||||||
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.#
|
Loading…
Reference in New Issue