2015年11月30日 星期一

Cloud9-RoR-加上關鍵字搜尋

參考文章:https://ihower.tw/rails4/restful-practices.html (下方處)
(上述參考文章有錯誤之處,請以本篇為主)

怎麼在頁面上加上keyword search呢?

先修改要加上keyword search的頁面,以events/index.html.erb當範例,在最上方加入下例程式
<%= form_tag events_path, :method => :get do %>
  <%= text_field_tag "keyword" %>
  <%= submit_tag "Search" %>
<% end %>

修改events_controller裡index的內容
  def index
    if params[:keyword]
      @events = Event.where(["title LIKE ? OR description LIKE ?", "%#{params[:keyword]}%", "%#{params[:keyword]}%"]).page(params[:page]).per(5)
    else
      @events = Event.page(params[:page]).per(5)
    end
  end

這麼一來就擁有keyword search的功能了。

2015年11月26日 星期四

Cloud9-RoR-export seeds.rb

seeds.rb檔---用來餵db table裡相關的(或範例)資料。

在ruby on rails中,我們知道可以利用bin/rake db:migrate可以快速的就建立好資料表,但資料內容呢?

每次都要重新建立,好像太麻煩了點,而且我有個迷思:寧願把時間花在寫程式上,也不想要花在key資料上。於是查了一下有沒有可以方便export seeds.rb檔的方法,因為seeds.rb檔不會自動產生,要手動編輯資料才行…不~~~

在這邊就提供兩個網路上現成的方法,一個比較笨但是很容易上手,另一個相反,方便可相對的前置動作也較繁雜。

笨拙上手容易
參考文章:http://www.xyzpub.com/en/ruby-on-rails/3.2/seed_rb.html
參考文章:http://railsguides.net/how-to-generate-rake-task/
我們只要準備好一個rake檔就行了,內容怎麼改呢?
namespace :export do
  desc "Prints xxxxs.all in a seeds.rb way."
  task :xxxxs_seeds_format => :environment do
    Xxxx.order(:id).all.each do |xxxx|
      puts "Xxxx.create(#{event.serializable_hash.delete_if {|key, value| ['created_at','updated_at','id'].include?(key)}.to_s.gsub(/[{}]/,'')})"
    end
  end
end
xxxx的部份就是資料表的名稱,像是event,還有要看清楚複數及單數的地方及需要大寫的部份。

不只一個table欸,那就在新增desc的部份。
namespace :export do
  desc "Prints xxxxs.all in a seeds.rb way."
  task :xxxxs_seeds_format => :environment do
    Xxxx.order(:id).all.each do |xxxx|
      puts "Xxxx.create(#{event.serializable_hash.delete_if {|key, value| ['created_at','updated_at','id'].include?(key)}.to_s.gsub(/[{}]/,'')})"
    end
  end

  desc "Prints yyys.all in a seeds.rb way."
  task :yyys_seeds_format => :environment do
    Yyy.order(:id).all.each do |event|
      puts "Yyy.create(#{yyy.serializable_hash.delete_if {|key, value| ['created_at','updated_at','id'].include?(key)}.to_s.gsub(/[{}]/,'')})"
    end
  end
end

接著就是下指令
$ rake export:xxxxs_seeds_format
$ rake export:yyys_seeds_format
會印出xxxxs及yyys table的資料。

很簡單吧!只不過每個table都要獨立寫出來,然後一一下指令執行,萬一table數量很多,感覺好像太不便民了一些是吧!所以才會又找另一個方法!

方便複雜度高
參考文章:https://github.com/kevTheDev/seed_dumper

這個方法要準備的檔案就比較多了,先把整個專案載下來,再一一放到我們的專案裡。基本上專案中沒有的檔案都能原封不動的複製過去,至於已經有的相關檔案,請copy來源檔的內容後,再貼到專案的同個檔案裡,不要直接覆蓋掉原本的檔案哦!就不在做詳細說明了,今天的我有點懶…

檔案都就緒後,就是下指令了
$ rake db:seed:dump

如果你也出現一堆WARN,嗯…我也是這樣,似乎是某個gem工具版本不符合,但檔案還是有正常輸出,既然不會造成問題就不跟他計較了。

可以檢查db folder裡新增了一個seed folder,只是輸出的檔案也跟我想的不大一樣,不是全部寫到seeds.rb,而是分別輸出各個table的rb檔,不過這樣也好,萬一我們只需要某個table的資料,就可以只針對想要的table做seed就好。

匯入資料庫
看來還是要把輸出得資料複製到seed.rb裡,目前研究的結果只能針對seed.rb檔做匯入,而且有個問題,如果table的欄位是使用date/datetime,匯出時是不包含雙引號的,但這樣匯入時會出錯,必需自行補上才行…oh my god!

匯入seed.rb檔指令的寫法
$ rake db:seed

怎麼分辨成功與否?沒有出現任何訊息就代表成功匯入資料了,如果下方出現一堆訊息就是有問題,訊息內會指出有錯誤的地方,修正後再重下指令就行了,希望大家匯入匯出都順利!

2015年11月24日 星期二

Cloud9-RoR-使用github create/rename a workspace

為什麼create/rename要寫一起呢,因為操作動作都一樣,cloud9無法rename專案名稱,所以需要先把想rename的專案上傳到github,再create一個新專案把檔案載下來。

github教學:https://www.dotblogs.com.tw/clark/archive/2014/02/12/143957.aspx
我是使用TortoiseGit,照著這篇文章的步驟做,很輕鬆就可以學會嘍!不過每次傳檔時就會讓我想到龜派氣功溜!

github官網:https://github.com/
官網也有做很詳細的操作教學哦!不過基本上我們不需要在github官網上做任何操作,只要網址就行了。

參考文章:https://docs.c9.io/v1.0/docs/create-a-workspace#section-git-source
參考來源:http://stackoverflow.com/questions/31574831/zsh-permission-denied-bin-rake

請先參考文章連結,才知道怎麼把github的檔案download到專案裡哦!
Clone from Git or Mercurial URL (optional)欄位的連結參考
https://github.com/uraccount/urworkspace

雖然用github可以很快速的把專案完整載下來,但是環境卻不完整,權限也不足…只好東補西補,感覺比開一個新專案更麻煩欸!

首先,因為環境不完整的關係,先把環境補強起來
$ bundle install

再來是權限不足的問題,讓github/master擁有bin/rake db:migrate指令的權限
$ chmod +x bin/*

在cloud9底下新建一個專案就等於重新使用一台新主機,所以要記住自己當初灌了哪些東西,記得在這邊也要全部重灌過哦!
$ mysql-ctl install
$ gem install -v 0.3.19 mysql2
$ gem install kaminari

Maybe不用做最後一行,因為我是先灌kaminari才執行bundle install,如果是倒過來做不知道會不會有差異,也許已經灌好了也說不定。

執行下列指令,把資料表建立起來
$ bin/rake db:migrate

cloud9的專案名稱不一定要跟github上的repository名稱一樣,至於在github上目錄的層級,我是把repository當成與workspace是同層目錄,所以只放了workspace底下的檔案,像醬
































希望大家操作順利嘍!

文章只花了短短1、2個小時就整理完畢,這背後其實是花了1、2天的時間不斷的再操作測試啊啊啊啊!

2015年11月22日 星期日

Cloud9-RoR-mysql2 & rails 版本衝途

參考來源:http://stackoverflow.com/questions/22932282/gemloaderror-for-mysql2-gem-but-its-already-in-gemfile

在開新專案時遇到了版本不相容的問題,mysql2 version 0.4.x 看來是無法在 rails version 4.x.x 底下使用。

所以只好安裝特定的mysql2版本,上網查了一下0.3.18幾乎大家都推這個版本,不過我發現我之前的專案是安裝0.3.19,所以決定安裝19這版。
gem install -v 0.3.19 mysql2

如果先前已經安裝過mysql2了,這時應該會出現兩個版本,怎麼查呢?
gem list

會列出所有已安裝的gem函式庫及其版本,然後記得在Gemfile裡指定版本哦!
# Use mysql2 as the database for Active Record
gem 'mysql2', '0.3.19'

如果只有安裝一個版本,'0.3.19'的部份就可以不用寫了。



2015年11月15日 星期日

Cloud9-RoR-where條件

參考文章:http://guides.rubyonrails.org/active_record_querying.html
連結內容說的還挺清楚的,我只用到一些比較簡單的部份而已。

修改routes.rb檔,在最前面加上
  root :to => "mains#index"
  resources :mains

新增一個mains_controller,當前台用
$ rails g controller mains

編輯mains_controller.rb,內容如下
  def index
    @mains = Event.where("public_date <= ?", Time.now)
  end
  
  def show
    @main = Event.find(params[:id])
  end  
  
  def origin
  end
  
  def service
  end
  
  def publ_index
    @mains = Event.where("cnttype = ?", 1)
  end
  
  def publ_content
    @main = Event.find(params[:id])
  end
  
  def case_index
    @mains = Event.where("cnttype = ?", 2)
  end
  
  def case_content
    @main = Event.find(params[:id])
  end

在view/mains/底下新增index.html.erb檔,內容如下
<ul>
<% @mains.each do |event| %>
  <li>
  <%= event.title %>
    <% event.categories.where(status: 1).each do |g| %>
      <%= g.cname %>
   <% end %>
  <%= link_to "Show", main_path(event) %>
  </li>
<% end %>
</ul>

再新增show.html.erb檔,內容如下
<p><%= @main.title %></p>
<p>
<% @main.categories.each do |g| %>
  <%= g.cname %>
<% end %>
</p>
<table border="0">
  <tr>
    <td><%= @main.public_date %></td>
    <td><%= @main.author %></td>
  </tr>
</table>
<p><%= simple_format(@main.description) %></p>

<p><%= link_to 'Back to index', mains_path %></p>

前台的首頁就大概草擬好了。

2015年11月12日 星期四

Cloud9-RoR-checkbox多對多

參考文章:https://ihower.tw/rails4/restful-practices.html

在這之前請先把categories model建立好哦,照著CRUD的方式就行了。

在_form.html.erb增加三行,放在自己想顯示的位置
<div>
<%= f.collection_check_boxes(:category_ids, Category.all, :id, :cname) %>
</div>

修改events_controller.rb的event_params
  def event_params
    params.require(:event).permit(:cnttype, :description, :author, :is_public, :public_date,
    :category_ids => [])
  end

在events/index.html.erb增加
  <% event.categories.each do |g| %>
    <%= g.cname %>
  <% end %>

在events/show.html.erb增加
<% @event.categories.each do |g| %>
  <%= g.cname %>
<% end %>

這樣就能在events表單中看到categories的checkbox清單嘍!