use canonical-url plugin to make view more clean

This commit is contained in:
xdite 2013-02-13 19:04:43 +08:00
parent 3bfdb2dd5b
commit cab4d95eaf
6 changed files with 52 additions and 11 deletions

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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" %>

View File

@ -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>

43
lib/canonical_url.rb Normal file
View File

@ -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.#