戻る

Rails5.0


民泊サイトの構築 Rails5.0

  (0)
2,000円

タスク3-9   Googleマップ

このタスクについて


タスクの内容を一部抜粋します。
プロジェクトを購入していただくとこのタスクの内容の全てを読みやすい表示で見ることができます。
プログラムコードが色分けされて見やすくなります。
プログラムコードに行番号が付きます。
本文が色分けされて見やすくなります。
そしてこのアプリケーションのフルコードをダウンロードすることが可能になります。




Google Cloud PlatformにGoogleアカウントでログインしてAPIキーを取得してください。
手順は以下の通りにお願いします。
mrradiology.hatenablog.jp


記述追加 GemFile(69行目)
 #googleマップ 
gem 'geocoder', '~> 1.4' 



GemFile
 
source 'https://rubygems.org' 
git_source(:github) do |repo_name| 
  repo_name = "#{repo_name}/#{repo_name}" unless repo_name.include?("/") 
  "https://github.com/#{repo_name}.git" 
end 
# Bundle edge Rails instead: gem 'rails', github: 'rails/rails' 
gem 'rails', '~> 5.0.7', '>= 5.0.7.1' 
# Use postgresql as the database for Active Record 
gem 'pg', '>= 0.18', '< 2.0' 
# Use Puma as the app server 
gem 'puma', '~> 3.0' 
# Use SCSS for stylesheets 
gem 'sass-rails', '~> 5.0' 
# Use Uglifier as compressor for JavaScript assets 
gem 'uglifier', '>= 1.3.0' 
# Use CoffeeScript for .coffee assets and views 
gem 'coffee-rails', '~> 4.2' 
# See https://github.com/rails/execjs#readme for more supported runtimes 
# gem 'therubyracer', platforms: :ruby 
# Use jquery as the JavaScript library 
gem 'jquery-rails' 
# Turbolinks makes navigating your web application faster. Read more: https://github.com/turbolinks/turbolinks 
gem 'turbolinks', '~> 5' 
# Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder 
gem 'jbuilder', '~> 2.5' 
# Use Redis adapter to run Action Cable in production 
# gem 'redis', '~> 3.0' 
# Use ActiveModel has_secure_password 
# gem 'bcrypt', '~> 3.1.7' 
# Use Capistrano for deployment 
# gem 'capistrano-rails', group: :development 
group :development, :test do 
  # Call 'byebug' anywhere in the code to stop execution and get a debugger console 
  gem 'byebug', platform: :mri 
end 
group :development do 
  # Access an IRB console on exception pages or by using <%= console %> anywhere in the code. 
  gem 'web-console', '>= 3.3.0' 
end 
# Windows does not include zoneinfo files, so bundle the tzinfo-data gem 
gem 'tzinfo-data', platforms: [:mingw, :mswin, :x64_mingw, :jruby] 

#bootstrap 
gem 'bootstrap-sass', '~> 3.4.1'
 
#デバイス 
gem 'devise', '~>4.2'
 
#Gravatar 
gem 'gravtastic'
 
#フラッシュメッセージ 
gem 'toastr-rails', '~> 1.0'
 
#日本語化 
gem 'rails-i18n'
 
#画像アップロード 
gem 'paperclip', '~> 5.1.0'
 
#googleマップ 
gem 'geocoder', '~> 1.4' 



コマンド
bundle


コマンド
rails g migration AddFieldsToRoom latitude:float longitude:float


コマンド マイグレーション
rails db:migrate


記述追加 app\models\room.rb(5行目)
   geocoded_by :address 
  after_validation :geocode, if: :address_changed? 



app\models\room.rb
 
class Room < ApplicationRecord 

  belongs_to :user 

  has_many :photos 

  geocoded_by :address 

  after_validation :geocode, if: :address_changed? 

  validates :home_type, presence: true 
  validates :room_type, presence: true 
  validates :accommodate, presence: true 
  validates :bed_room, presence: true 
  validates :bath_room, presence: true 

  def cover_photo(size) 
    if self.photos.length > 0 
      self.photos[0].image.url(size) 
    else 
      "blank.jpg" 
    end 
  end 

end 



GoogleマップAPIの埋め込み
取得したキーを「key=」から「&callback」の間に埋め込んで下さい。
<script async defer src="https://maps.googleapis.com/maps/api/js?key=ご自分のAPIキー&callback=initMap" type="text/javascript"></script>



このscriptタグをサイトに埋め込みます。


記述追加 app\views\rooms\show.html.erb(126行目)
 
    <!-- GOOGLE マップ --> 
    <div class="row"> 
      <div id="map" style="width: 100%; height: 400px"></div> 
      <script src="https://maps.googleapis.com/maps/api/js"></script> 
      <script> 
          function initialize() { 
            var location = {lat: <%= @room.latitude %>, lng: <%= @room.longitude %>}; 
            var map = new google.maps.Map(document.getElementById('map'), { 
              center: location, 
              zoom: 14 
            }); 
            var marker = new google.maps.Marker({ 
              position: location, 
              map: map 
            }); 
            var infoWindow = new google.maps.InfoWindow({ 
              content: '<div id="content"><%= image_tag @room.cover_photo(:medium) %></div>' 
            }); 
            infoWindow.open(map, marker); 
          } 
          google.maps.event.addDomListener(window, 'load', initialize); 
      </script> 
      <script async defer src="https://maps.googleapis.com/maps/api/js?key=ご自分のAPIキー&callback=initMap" type="text/javascript"></script> 
    </div> 
    <hr/> 
    <!-- 近くのお部屋を検索 --> 
    <div class="row"> 
      <h3>お近くのお部屋</h3> 
      <% for room in @room.nearbys(10) %> 
          <div class="col-md-4"> 
            <div class="panel panel-default"> 
              <div class="panel-heading preview"> 
                <%= image_tag room.cover_photo(:medium) %> 
              </div> 
              <div class="panel-body"> 
                <%= link_to room.listing_name, room %><br/> 
                (距離:<%= room.distance.round(2) %> Km) 
              </div> 
            </div> 
          </div> 
      <% end %> 
   </div> 



この続きはプロジェクトを購入していただくことで見ることができます。
プロジェクトを購入していただくとこのタスクの内容の全てを読みやすい表示で見ることができます。
プログラムコードが色分けされて見やすくなります。
プログラムコードに行番号が付きます。
本文が色分けされて見やすくなります。
そしてプロジェクトを購入するとこのアプリケーションのフルコードをダウンロードすることができます。

まだレビューはありません。

民泊サイトの構築 Rails5.0

2,000円

民泊サイトを構築します。
ホストは部屋を登録し、ゲストは宿泊予約できます。
ゲストはクレジットカードで支払いをし、ホストには料金の80%が自動で口座に振り込まれます。
Googleマップによる表示、AJAX検索、日付カレンダーによる予約、フルカレンダーによる部屋管理ができます。
リアルタイムメッセージにより連絡がとれます。
予約確認メールの送信も可能。
写真のアップロード機能、アマゾンS3の利用方法も解説。
レビュー機能の実装、電話番号認証の実装方法解説。
HEROKUへのデプロイ方法を解説。
フルコードのダウンロード可能。

タスク数: 136