mirror of
https://github.com/amix/vimrc
synced 2024-12-26 20:03:12 +00:00
878 lines
21 KiB
Text
878 lines
21 KiB
Text
priority -50
|
|
|
|
snippet anaf "accepts_nested_attributes_for"
|
|
accepts_nested_attributes_for :${1:association_name}${2:${3:, allow_destroy: true}${4:, reject_if: proc \{ |obj| ${5:obj.blank?} \}}}
|
|
|
|
endsnippet
|
|
|
|
snippet tcbi "Create binary column"
|
|
t.binary :${1:title}${2:, limit: ${3:2}.megabytes}
|
|
$0
|
|
endsnippet
|
|
|
|
snippet tcb "Create boolean column"
|
|
t.boolean :${1:title}
|
|
$0
|
|
endsnippet
|
|
|
|
snippet clac "Create controller class"
|
|
class ${1:Model}Controller < ApplicationController
|
|
before_action :find_${2:model}
|
|
|
|
$0
|
|
|
|
private
|
|
def find_$2
|
|
@$2 = ${3:$1}.find(params[:id]) if params[:id]
|
|
end
|
|
end
|
|
endsnippet
|
|
|
|
snippet tcda "Create date column"
|
|
t.date :${1:title}
|
|
$0
|
|
endsnippet
|
|
|
|
snippet tcdt "Create datetime column"
|
|
t.datetime :${1:title}
|
|
$0
|
|
endsnippet
|
|
|
|
snippet tcd "Create decimal column"
|
|
t.decimal :${1:title}${2:${3:, precision: ${4:10}}${5:, scale: ${6:2}}}
|
|
$0
|
|
endsnippet
|
|
|
|
snippet tcf "Create float column"
|
|
t.float :${1:title}
|
|
$0
|
|
endsnippet
|
|
|
|
snippet clact "Create functional test class"
|
|
require 'test_helper'
|
|
|
|
class ${1:Model}ControllerTest < ActionController::TestCase
|
|
test$0
|
|
end
|
|
|
|
endsnippet
|
|
|
|
snippet tci "Create integer column"
|
|
t.integer :${1:title}
|
|
$0
|
|
endsnippet
|
|
|
|
snippet tcl "Create lock_version column"
|
|
t.integer :lock_version, null: false, default: 0
|
|
$0
|
|
endsnippet
|
|
|
|
# FIXME: handling literal bracket pair inside of nested tab groups?
|
|
snippet tcr "Create references column"
|
|
t.references :${1:taggable}${2:, polymorphic: ${3:{ default: '${4:Photo}' }}}
|
|
$0
|
|
endsnippet
|
|
|
|
snippet resources "Create resources controller class"
|
|
class ${1:Model}sController < ApplicationController
|
|
before_action :find_${1/./\l$0/}, only: [:show, :edit, :update, :destroy]
|
|
|
|
# GET /${1/./\l$0/}s
|
|
# GET /${1/./\l$0/}s.json
|
|
def index
|
|
@${1/./\l$0/}s = ${1:Model}.all
|
|
|
|
respond_to do |wants|
|
|
wants.html # index.html.erb
|
|
wants.json { render json: @${1/./\l$0/}s }
|
|
end
|
|
end
|
|
|
|
# GET /${1/./\l$0/}s/1
|
|
# GET /${1/./\l$0/}s/1.json
|
|
def show
|
|
respond_to do |wants|
|
|
wants.html # show.html.erb
|
|
wants.json { render json: @${1/./\l$0/} }
|
|
end
|
|
end
|
|
|
|
# GET /${1/./\l$0/}s/new
|
|
# GET /${1/./\l$0/}s/new.json
|
|
def new
|
|
@${1/./\l$0/} = ${1:Model}.new
|
|
|
|
respond_to do |wants|
|
|
wants.html # new.html.erb
|
|
wants.json { render json: @${1/./\l$0/} }
|
|
end
|
|
end
|
|
|
|
# GET /${1/./\l$0/}s/1/edit
|
|
def edit
|
|
end
|
|
|
|
# POST /${1/./\l$0/}s
|
|
# POST /${1/./\l$0/}s.json
|
|
def create
|
|
@${1/./\l$0/} = ${1:Model}.new(params[:${1/./\l$0/}])
|
|
|
|
respond_to do |wants|
|
|
if @${1/./\l$0/}.save
|
|
flash[:notice] = '${1:Model} was successfully created.'
|
|
wants.html { redirect_to(@${1/./\l$0/}) }
|
|
wants.json { render json: @${1/./\l$0/}, status: :created, location: @${1/./\l$0/} }
|
|
else
|
|
wants.html { render action: "new" }
|
|
wants.json { render json: @${1/./\l$0/}.errors, status: :unprocessable_entity }
|
|
end
|
|
end
|
|
end
|
|
|
|
# PUT /${1/./\l$0/}s/1
|
|
# PUT /${1/./\l$0/}s/1.json
|
|
def update
|
|
respond_to do |wants|
|
|
if @${1/./\l$0/}.update(params[:${1/./\l$0/}])
|
|
flash[:notice] = '${1:Model} was successfully updated.'
|
|
wants.html { redirect_to(@${1/./\l$0/}) }
|
|
wants.json { head :ok }
|
|
else
|
|
wants.html { render action: "edit" }
|
|
wants.json { render json: @${1/./\l$0/}.errors, status: :unprocessable_entity }
|
|
end
|
|
end
|
|
end
|
|
|
|
# DELETE /${1/./\l$0/}s/1
|
|
# DELETE /${1/./\l$0/}s/1.json
|
|
def destroy
|
|
@${1/./\l$0/}.destroy
|
|
|
|
respond_to do |wants|
|
|
wants.html { redirect_to(${1/./\l$0/}s_url) }
|
|
wants.json { head :ok }
|
|
end
|
|
end
|
|
|
|
private
|
|
def find_${1/./\l$0/}
|
|
@${1/./\l$0/} = ${1:Model}.find(params[:id])
|
|
end
|
|
|
|
end
|
|
|
|
endsnippet
|
|
|
|
snippet tcs "Create string column"
|
|
t.string :${1:title}
|
|
$0
|
|
endsnippet
|
|
|
|
snippet tct "Create text column"
|
|
t.text :${1:title}
|
|
$0
|
|
endsnippet
|
|
|
|
snippet tcti "Create time column"
|
|
t.time :${1:title}
|
|
$0
|
|
endsnippet
|
|
|
|
snippet tcts "Create timestamp column"
|
|
t.timestamp :${1:title}
|
|
$0
|
|
endsnippet
|
|
|
|
snippet tctss "Create timestamps columns"
|
|
t.timestamps
|
|
$0
|
|
endsnippet
|
|
|
|
snippet mcol "Migration Create Column (mcc)"
|
|
t.column ${1:title}, :${2:string}
|
|
$0
|
|
endsnippet
|
|
|
|
snippet mccc "Migration Create Column Continue (mccc)"
|
|
t.column ${1:title}, :${2:string}
|
|
mccc$0
|
|
endsnippet
|
|
|
|
snippet mtab "Migration Drop Create Table (mdct)"
|
|
drop_table :${1:table}${2: [press tab twice to generate create_table]}
|
|
endsnippet
|
|
|
|
snippet mcol "Migration Remove and Add Column (mrac)"
|
|
remove_column :${1:table}, :${2:column}${3: [press tab twice to generate add_column]}
|
|
endsnippet
|
|
|
|
snippet rdb "RAILS_DEFAULT_LOGGER.debug (rdb)"
|
|
RAILS_DEFAULT_LOGGER.debug "${1:message}"$0
|
|
endsnippet
|
|
|
|
snippet tre "Table column(s) rename"
|
|
t.rename(:${1:old_column_name}, :${2:new_column_name})
|
|
$0
|
|
endsnippet
|
|
|
|
snippet art "Test Assert Redirected To (art)"
|
|
assert_redirected_to ${2:action: "${1:index}"}
|
|
endsnippet
|
|
|
|
snippet asre "Test Assert Response (are)"
|
|
assert_response :${1:success}, @response.body$0
|
|
endsnippet
|
|
|
|
snippet aftc "after_create"
|
|
after_create $0
|
|
endsnippet
|
|
|
|
snippet aftd "after_destroy"
|
|
after_destroy $0
|
|
endsnippet
|
|
|
|
snippet afts "after_save"
|
|
after_save $0
|
|
endsnippet
|
|
|
|
snippet aftu "after_update"
|
|
after_update $0
|
|
endsnippet
|
|
|
|
snippet aftv "after_validation"
|
|
after_validation $0
|
|
endsnippet
|
|
|
|
snippet aftvoc "after_validation_on_create"
|
|
after_validation_on_create $0
|
|
endsnippet
|
|
|
|
snippet aftvou "after_validation_on_update"
|
|
after_validation_on_update $0
|
|
endsnippet
|
|
|
|
snippet asg "assert(var = assigns(:var))"
|
|
assert(${1:var} = assigns(:$1), "Cannot find @$1")
|
|
$0
|
|
endsnippet
|
|
|
|
snippet asd "assert_difference"
|
|
assert_difference "${1:Model}.${2:count}", ${3:1} do
|
|
$0
|
|
end
|
|
endsnippet
|
|
|
|
snippet asnd "assert_no_difference"
|
|
assert_no_difference "${1:Model}.${2:count}" do
|
|
$0
|
|
end
|
|
endsnippet
|
|
|
|
snippet artnpp "assert_redirected_to (nested path plural)"
|
|
assert_redirected_to ${10:${2:parent}_${3:child}_path(${4:@}${5:$2})}
|
|
endsnippet
|
|
|
|
snippet artnp "assert_redirected_to (nested path)"
|
|
assert_redirected_to ${2:${12:parent}_${13:child}_path(${14:@}${15:$12}, ${16:@}${17:$13})}
|
|
endsnippet
|
|
|
|
snippet artpp "assert_redirected_to (path plural)"
|
|
assert_redirected_to ${10:${2:model}s_path}
|
|
endsnippet
|
|
|
|
snippet artp "assert_redirected_to (path)"
|
|
assert_redirected_to ${2:${12:model}_path(${13:@}${14:$12})}
|
|
endsnippet
|
|
|
|
snippet asrj "assert_rjs"
|
|
assert_rjs :${1:replace}, ${2:"${3:dom id}"}
|
|
endsnippet
|
|
|
|
snippet ass "assert_select"
|
|
assert_select '${1:path}'${2:, ${3:text}: ${4:'${5:inner_html}'}}${6: do
|
|
$0
|
|
end}
|
|
endsnippet
|
|
|
|
snippet befc "before_create"
|
|
before_create $0
|
|
endsnippet
|
|
|
|
snippet befd "before_destroy"
|
|
before_destroy $0
|
|
endsnippet
|
|
|
|
snippet befs "before_save"
|
|
before_save $0
|
|
endsnippet
|
|
|
|
snippet befu "before_update"
|
|
before_update $0
|
|
endsnippet
|
|
|
|
snippet befv "before_validation"
|
|
before_validation $0
|
|
endsnippet
|
|
|
|
snippet befvoc "before_validation_on_create"
|
|
before_validation_on_create $0
|
|
endsnippet
|
|
|
|
snippet befvou "before_validation_on_update"
|
|
before_validation_on_update
|
|
endsnippet
|
|
|
|
snippet bt "belongs_to (bt)"
|
|
belongs_to :${1:object}${2:, class_name: "${3:${1/[[:alpha:]]+|(_)/(?1::\u$0)/g}}", foreign_key: "${4:$1_id}"}
|
|
endsnippet
|
|
|
|
snippet crw "cattr_accessor"
|
|
cattr_accessor :${0:attr_names}
|
|
endsnippet
|
|
|
|
snippet defcreate "def create - resource"
|
|
def create
|
|
@${1:model} = ${2:${1/[[:alpha:]]+|(_)/(?1::\u$0)/g}}.new(params[:$1])
|
|
$0
|
|
respond_to do |wants|
|
|
if @$1.save
|
|
flash[:notice] = '$2 was successfully created.'
|
|
wants.html { redirect_to(@$1) }
|
|
wants.json { render json: @$1, status: :created, location: @$1 }
|
|
else
|
|
wants.html { render action: "new" }
|
|
wants.json { render json: @$1.errors, status: :unprocessable_entity }
|
|
end
|
|
end
|
|
end
|
|
|
|
endsnippet
|
|
|
|
snippet test "test do..end"
|
|
test "${1:something interesting}" do
|
|
$0
|
|
end
|
|
endsnippet
|
|
|
|
snippet deftg "def get request"
|
|
def test_should_get_${1:action}
|
|
${2:@${3:model} = ${4:$3s}(:${5:fixture_name})
|
|
}get :$1${6:, id: @$3.to_param}
|
|
assert_response :success
|
|
$0
|
|
end
|
|
endsnippet
|
|
|
|
snippet deftp "def post request"
|
|
def test_should_post_${1:action}
|
|
${3:@$2 = ${4:$2s}(:${5:fixture_name})
|
|
}post :$1${6:, id: @$2.to_param}, ${2:model}: { $0 }
|
|
assert_response :redirect
|
|
|
|
end
|
|
endsnippet
|
|
|
|
snippet fina "find(:all)"
|
|
find(:all${1:, conditions: ['${2:${3:field} = ?}', ${5:true}]})
|
|
endsnippet
|
|
|
|
snippet finf "find(:first)"
|
|
find(:first${1:, conditions: ['${2:${3:field} = ?}', ${5:true}]})
|
|
endsnippet
|
|
|
|
snippet fini "find(id)"
|
|
find(${1:id})
|
|
endsnippet
|
|
|
|
snippet fine "find_each"
|
|
find_each(${1conditions: {:${2:field}: ${3:true}\}}) do |${4:${TM_CURRENT_WORD/(\w+)\./\L$1/g}}|
|
|
$0
|
|
end
|
|
endsnippet
|
|
|
|
snippet finb "find_in_batches"
|
|
find_in_batches(${1conditions: {:${2:field}: ${3:true}\}}) do |${4:${TM_CURRENT_WORD/(\w+)\./\L$1/g}}s|
|
|
$4s.each do |$4|
|
|
$0
|
|
end
|
|
end
|
|
endsnippet
|
|
|
|
snippet habtm "has_and_belongs_to_many (habtm)"
|
|
has_and_belongs_to_many :${1:object}${2:, join_table: "${3:table_name}", foreign_key: "${4:$1_id}"}
|
|
endsnippet
|
|
|
|
snippet hm "has_many (hm)"
|
|
has_many :${1:object}s${2:, class_name: "$1", foreign_key: "${4:reference}_id"}
|
|
endsnippet
|
|
|
|
snippet hmt "has_many (through)"
|
|
has_many :${1:objects}, through: :${2:join_association}${3:, source: :${4:$2_table_foreign_key_to_$1_table}}
|
|
endsnippet
|
|
|
|
snippet hmd "has_many dependent: :destroy"
|
|
has_many :${1:object}s${2:, class_name: "$1", foreign_key: "${4:reference}_id"}, dependent: :destroy$0
|
|
endsnippet
|
|
|
|
snippet ho "has_one (ho)"
|
|
has_one :${1:object}${2:, class_name: "${3:${1/[[:alpha:]]+|(_)/(?1::\u$0)/g}}", foreign_key: "${4:$1_id}"}
|
|
endsnippet
|
|
|
|
snippet logd "logger.debug"
|
|
${1:Rails.}logger.debug { "${1:message}" }$0
|
|
endsnippet
|
|
|
|
snippet loge "logger.error"
|
|
logger.error { "${1:message}" }$0
|
|
endsnippet
|
|
|
|
snippet logf "logger.fatal"
|
|
logger.fatal { "${1:message}" }$0
|
|
endsnippet
|
|
|
|
snippet logi "logger.info"
|
|
logger.info { "${1:message}" }$0
|
|
endsnippet
|
|
|
|
snippet logw "logger.warn"
|
|
logger.warn { "${1:message}" }$0
|
|
endsnippet
|
|
|
|
snippet mp "map(&:sym_proc)"
|
|
map(&:${1:id})
|
|
endsnippet
|
|
|
|
snippet mapca "map.catch_all"
|
|
${1:map}.catch_all "*${2:anything}", controller: "${3:default}", action: "${4:error}"
|
|
|
|
endsnippet
|
|
|
|
snippet map "map.named_route"
|
|
${1:map}.${2:connect} '${3::controller/:action/:id}'
|
|
endsnippet
|
|
|
|
snippet mapr "map.resource"
|
|
${1:map}.resource :${2:resource}${10: do |${11:$2}|
|
|
$0
|
|
end}
|
|
endsnippet
|
|
|
|
snippet maprs "map.resources"
|
|
${1:map}.resources :${2:resource}${10: do |${11:$2}|
|
|
$0
|
|
end}
|
|
endsnippet
|
|
|
|
snippet mapwo "map.with_options"
|
|
${1map}.with_options :${2:controller}: '${3:thing}' do |${4:$3}|
|
|
$0
|
|
end
|
|
|
|
endsnippet
|
|
|
|
snippet mrw "mattr_accessor"
|
|
mattr_accessor :${0:attr_names}
|
|
endsnippet
|
|
|
|
snippet ncl "named_scope lambda"
|
|
named_scope :name, lambda { |${1param}| { :conditions: ${3:['${4:${5:field} = ?}', ${6:$1}]} } }
|
|
|
|
endsnippet
|
|
|
|
snippet nc "named_scope"
|
|
named_scope :name${1:, joins: :${2:table}}, conditions: ${3:['${4:${5:field} = ?}', ${6:true}]}
|
|
|
|
endsnippet
|
|
|
|
snippet dscope "default_scope"
|
|
default_scope ${1:order(${2:'${3:created_at DESC}'})}
|
|
endsnippet
|
|
|
|
snippet flash "flash[...]"
|
|
flash[:${1:notice}] = "${2:Successfully created...}"$0
|
|
endsnippet
|
|
|
|
snippet rea "redirect_to (action)"
|
|
redirect_to action: "${1:index}"
|
|
endsnippet
|
|
|
|
snippet reai "redirect_to (action, id)"
|
|
redirect_to action: "${1:show}", id: ${0:@item}
|
|
endsnippet
|
|
|
|
snippet rec "redirect_to (controller)"
|
|
redirect_to controller: "${1:items}"
|
|
endsnippet
|
|
|
|
snippet reca "redirect_to (controller, action)"
|
|
redirect_to controller: "${1:items}", action: "${2:list}"
|
|
endsnippet
|
|
|
|
snippet recai "redirect_to (controller, action, id)"
|
|
redirect_to controller: "${1:items}", action: "${2:show}", id: ${0:@item}
|
|
endsnippet
|
|
|
|
snippet renpp "redirect_to (nested path plural)"
|
|
redirect_to(${2:${10:parent}_${11:child}_path(${12:@}${13:$10})})
|
|
endsnippet
|
|
|
|
snippet renp "redirect_to (nested path)"
|
|
redirect_to(${2:${12:parent}_${13:child}_path(${14:@}${15:$12}, ${16:@}${17:$13})})
|
|
endsnippet
|
|
|
|
snippet repp "redirect_to (path plural)"
|
|
redirect_to(${2:${10:model}s_path})
|
|
endsnippet
|
|
|
|
snippet rep "redirect_to (path)"
|
|
redirect_to(${2:${12:model}_path(${13:@}${14:$12})})
|
|
endsnippet
|
|
|
|
snippet reb "redirect_to :back"
|
|
redirect_to :back
|
|
endsnippet
|
|
|
|
snippet ra "render (action)... (ra)"
|
|
render action: "${1:action}"
|
|
endsnippet
|
|
|
|
snippet ral "render (action,layout) (ral)"
|
|
render action: "${1:action}", layout: "${2:layoutname}"
|
|
endsnippet
|
|
|
|
snippet rf "render (file) (rf)"
|
|
render file: "${1:filepath}"
|
|
endsnippet
|
|
|
|
snippet rfu "render (file,use_full_path) (rfu)"
|
|
render file: "${1:filepath}", use_full_path: ${2:false}
|
|
endsnippet
|
|
|
|
snippet ri "render (inline) (ri)"
|
|
render inline: "${1:<%= 'hello' %>}"
|
|
endsnippet
|
|
|
|
snippet ril "render (inline,locals) (ril)"
|
|
render inline: "${1:<%= 'hello' %>}", locals { ${2::name}: "${3:value}"$4 }
|
|
endsnippet
|
|
|
|
snippet rit "render (inline,type) (rit)"
|
|
render inline: "${1:<%= 'hello' %>}", type: ${2::rjson}
|
|
endsnippet
|
|
|
|
snippet rl "render (layout) (rl)"
|
|
render layout: "${1:layoutname}"
|
|
endsnippet
|
|
|
|
snippet rn "render (nothing) (rn)"
|
|
render nothing: ${1:true}
|
|
endsnippet
|
|
|
|
snippet rns "render (nothing,status) (rns)"
|
|
render nothing: ${1:true}, status: ${2:401}
|
|
endsnippet
|
|
|
|
snippet rt "render (text) (rt)"
|
|
render text: "${1:text to render...}"
|
|
endsnippet
|
|
|
|
snippet rtl "render (text,layout) (rtl)"
|
|
render text: "${1:text to render...}", layout: "${2:layoutname}"
|
|
endsnippet
|
|
|
|
snippet rtlt "render (text,layout => true) (rtlt)"
|
|
render text: "${1:text to render...}", layout: ${2:true}
|
|
endsnippet
|
|
|
|
snippet rts "render (text,status) (rts)"
|
|
render text: "${1:text to render...}", status: ${2:401}
|
|
endsnippet
|
|
|
|
snippet ru "render (update)"
|
|
render :update do |${2:page}|
|
|
$2.$0
|
|
end
|
|
endsnippet
|
|
|
|
snippet rest "respond_to"
|
|
respond_to do |wants|
|
|
wants.${1:html}${2: { $0 }}
|
|
end
|
|
endsnippet
|
|
|
|
# FIXME
|
|
snippet returning "returning do |variable| ... end"
|
|
returning ${1:variable} do${2/(^(?<var>\s*[a-z_][a-zA-Z0-9_]*\s*)(,\g<var>)*,?\s*$)|.*/(?1: |)/}${2:v}${2/(^(?<var>\s*[a-z_][a-zA-Z0-9_]*\s*)(,\g<var>)*,?\s*$)|.*/(?1:|)/}
|
|
$0
|
|
end
|
|
endsnippet
|
|
|
|
snippet cmm "Create Migration Model Class"
|
|
class Migration${1/(?:^|_)(\w)/\u$1/g} < ApplicationRecord
|
|
self.table_name = :${1:model_name}s
|
|
end
|
|
endsnippet
|
|
|
|
snippet t. "t.binary (tcbi)"
|
|
t.binary :${1:title}${2:, limit: ${3:2}.megabytes}
|
|
t.$0
|
|
endsnippet
|
|
|
|
snippet t. "t.boolean (tcb)"
|
|
t.boolean :${1:title}
|
|
t.$0
|
|
endsnippet
|
|
|
|
snippet t. "t.date (tcda)"
|
|
t.date :${1:title}
|
|
t.$0
|
|
endsnippet
|
|
|
|
snippet t. "t.datetime (tcdt)"
|
|
t.datetime :${1:title}
|
|
t.$0
|
|
endsnippet
|
|
|
|
snippet t. "t.decimal (tcd)"
|
|
t.decimal :${1:title}${2:${3:, precision: ${4:10}}${5:, scale: ${6:2}}}
|
|
t.$0
|
|
endsnippet
|
|
|
|
snippet t. "t.float (tcf)"
|
|
t.float :${1:title}
|
|
t.$0
|
|
endsnippet
|
|
|
|
snippet t. "t.integer (tci)"
|
|
t.integer :${1:title}
|
|
t.$0
|
|
endsnippet
|
|
|
|
snippet t. "t.lock_version (tcl)"
|
|
t.integer :lock_version, null: false, default: 0
|
|
t.$0
|
|
endsnippet
|
|
|
|
snippet t. "t.references (tcr)"
|
|
t.references :${1:taggable}${2:, polymorphic: ${3:{ default: '${4:Photo}' }}}
|
|
t.$0
|
|
endsnippet
|
|
|
|
snippet t. "t.rename (tre)"
|
|
t.rename(:${1:old_column_name}, :${2:new_column_name})
|
|
t.$0
|
|
endsnippet
|
|
|
|
snippet t. "t.string (tcs)"
|
|
t.string :${1:title}
|
|
t.$0
|
|
endsnippet
|
|
|
|
snippet t. "t.text (tct)"
|
|
t.text :${1:title}
|
|
t.$0
|
|
endsnippet
|
|
|
|
snippet t. "t.time (tcti)"
|
|
t.time :${1:title}
|
|
t.$0
|
|
endsnippet
|
|
|
|
snippet t. "t.timestamp (tcts)"
|
|
t.timestamp :${1:title}
|
|
t.$0
|
|
endsnippet
|
|
|
|
snippet t. "t.timestamps (tctss)"
|
|
t.timestamps
|
|
t.$0
|
|
endsnippet
|
|
|
|
snippet vaoif "validates_acceptance_of if"
|
|
validates_acceptance_of :${1:terms}${2:${3:, accept: "${4:1}"}${5:, message: "${6:You must accept the terms of service}"}}, if: proc { |obj| ${7:obj.condition?} }}
|
|
endsnippet
|
|
|
|
snippet vao "validates_acceptance_of"
|
|
validates :${1:terms}${2:, acceptance: ${3:{ accept: "${4:1}"${5:, message: "${6:You must accept the terms of service}"}}} }
|
|
endsnippet
|
|
|
|
snippet va "validates_associated (va)"
|
|
validates_associated :${1:attribute}${2:, on: :${3:create}}
|
|
endsnippet
|
|
|
|
snippet vaif "validates_associated if (vaif)"
|
|
validates_associated :${1:attribute}${2:, on: :${3:create}, if: proc { |obj| ${5:obj.condition?} }}
|
|
endsnippet
|
|
|
|
snippet vc "validates_confirmation_of (vc)"
|
|
validates_confirmation_of :${1:attribute}${2:, on: :${3:create}, message: "${4:should match confirmation}"}
|
|
endsnippet
|
|
|
|
snippet vcif "validates_confirmation_of if (vcif)"
|
|
validates_confirmation_of :${1:attribute}${2:, on: :${3:create}, message: "${4:should match confirmation}", if: proc { |obj| ${5:obj.condition?} }}
|
|
endsnippet
|
|
|
|
snippet ve "validates_exclusion_of (ve)"
|
|
validates_exclusion_of :${1:attribute}${2:, in: ${3:%w( ${4:mov avi} )}, on: :${5:create}, message: "${6:extension %s is not allowed}"}
|
|
endsnippet
|
|
|
|
snippet veif "validates_exclusion_of if (veif)"
|
|
validates_exclusion_of :${1:attribute}${2:, in: ${3:%w( ${4:mov avi} )}, on: :${5:create}, message: "${6:extension %s is not allowed}"}, if: proc { |obj| ${7:obj.condition?} }}
|
|
endsnippet
|
|
|
|
snippet vfif "validates_format_of if"
|
|
validates_format_of :${1:attribute}, with: /${2:^[${3:\w\d}]+\$}/${4:, on: :${5:create}, message: "${6:is invalid}"}, if: proc { |obj| ${7:obj.condition?} }}
|
|
endsnippet
|
|
|
|
snippet vf "validates_format_of"
|
|
validates_format_of :${1:attribute}, with: /${2:^[${3:\w\d}]+\$}/${4:, on: :${5:create}, message: "${6:is invalid}"}
|
|
endsnippet
|
|
|
|
snippet viif "validates_inclusion_of if"
|
|
validates_inclusion_of :${1:attribute}${2:, in: ${3:%w( ${4:mov avi} )}, on: :${5:create}, message: "${6:extension %s is not included in the list}"}, if: proc { |obj| ${7:obj.condition?} }}
|
|
endsnippet
|
|
|
|
snippet vi "validates_inclusion_of"
|
|
validates_inclusion_of :${1:attribute}${2:, in: ${3:%w( ${4:mov avi} )}, on: :${5:create}, message: "${6:extension %s is not included in the list}"}
|
|
endsnippet
|
|
|
|
snippet vl "validates_length_of (vl)"
|
|
validates_length_of :${1:attribute}, within: ${2:3..20}${3:, on: :${4:create}, message: "${5:must be present}"}
|
|
endsnippet
|
|
|
|
snippet vlif "validates_length_of if"
|
|
validates_length_of :${1:attribute}, within: ${2:3..20}${3:, on: :${4:create}, message: "${5:must be present}"}, if: proc { |obj| ${6:obj.condition?} }}
|
|
endsnippet
|
|
|
|
snippet vnif "validates_numericality_of if"
|
|
validates_numericality_of :${1:attribute}${2:, on: :${3:create}, message: "${4:is not a number}"}, if: proc { |obj| ${5:obj.condition?} }}
|
|
endsnippet
|
|
|
|
snippet vn "validates_numericality_of"
|
|
validates_numericality_of :${1:attribute}${2:, on: :${3:create}, message: "${4:is not a number}"}
|
|
endsnippet
|
|
|
|
snippet vp "validates_presence_of (vp)"
|
|
validates_presence_of :${1:attribute}${2:, on: :${3:create}, message: "${4:can't be blank}"}
|
|
endsnippet
|
|
|
|
snippet vpif "validates_presence_of if (vpif) 2"
|
|
validates_presence_of :${1:attribute}${2:, on: :${3:create}, message: "${4:can't be blank}"}, if: proc { |obj| ${5:obj.condition?} }}
|
|
endsnippet
|
|
|
|
snippet vu "validates_uniqueness_of (vu)"
|
|
validates_uniqueness_of :${1:attribute}${2:, on: :${3:create}, message: "${4:must be unique}"}
|
|
endsnippet
|
|
|
|
snippet vuif "validates_uniqueness_of if (vuif)"
|
|
validates_uniqueness_of :${1:attribute}${2:, on: :${3:create}, message: "${4:must be unique}", if: proc { |obj| ${6:obj.condition?} }}
|
|
endsnippet
|
|
|
|
snippet verify "verify -- render"
|
|
verify only: [:$1], method: :post, render {:status: 500, text: "use HTTP-POST"}
|
|
|
|
endsnippet
|
|
|
|
snippet verify "verify -- redirect"
|
|
verify only: [:$1], session: :user, params: :id, redirect_to {:action: '${2:index}'}
|
|
|
|
endsnippet
|
|
|
|
snippet wants "wants_format"
|
|
wants.${1:js|json|html}${2: { $0 }}
|
|
endsnippet
|
|
|
|
snippet xdelete "xhr delete"
|
|
xhr :delete, :${1:destroy}, id: ${2:1}$0
|
|
endsnippet
|
|
|
|
snippet xget "xhr get"
|
|
xhr :get, :${1:show}${2:, id: ${3:1}}$0
|
|
endsnippet
|
|
|
|
snippet xpost "xhr post"
|
|
xhr :post, :${1:create}, ${2:object}: { $3 }
|
|
endsnippet
|
|
|
|
snippet xput "xhr put"
|
|
xhr :put, :${1:update}, id: ${2:1}, ${3:object}: { $4 }$0
|
|
endsnippet
|
|
|
|
snippet col "collection routes"
|
|
collection do
|
|
${1:get :${2:action}}
|
|
${3:put :${4:action}}
|
|
${5:post :${6:action}}
|
|
${7:delete :${8:action}}
|
|
end
|
|
endsnippet
|
|
|
|
snippet format "format (respond_with)"
|
|
format.${1:html|xml|json|js|any} { $0 }
|
|
endsnippet
|
|
|
|
snippet gem "gem"
|
|
gem '${1:name}'${2:${3:, "${4:1.0}"}${5:${6:, require: ${7:"${8:$1}"}}${9:, group: :${10:test}}}}
|
|
endsnippet
|
|
|
|
snippet gemg "gem :git"
|
|
gem '${1:paperclip}', git: "${2:git://github.com/thoughtbot/paperclip.git}"${3:, branch: "${4:rails3}"}
|
|
endsnippet
|
|
|
|
snippet match "match"
|
|
match '${1:${2::controller}${3:/${4::action}${5:/${6::id}${7:(.:format)}}}}'${8: '${9:$2}#${10:$4}'${11:, as: :${12:$10}}}
|
|
endsnippet
|
|
|
|
snippet member "member routes"
|
|
member do
|
|
${1:get :${2:action}}
|
|
${3:put :${4:action}}
|
|
${5:post :${6:action}}
|
|
${7:delete :${8:action}}
|
|
end
|
|
endsnippet
|
|
|
|
snippet res "resources"
|
|
resources :${1:posts}${2: do
|
|
$3
|
|
end}
|
|
endsnippet
|
|
|
|
snippet scope "scope"
|
|
scope :${1:name}, { ${2:joins(:${3:table}).}where(${4:'${5:$3.${6:field}} = ?', ${7:'${8:value}'}}) }
|
|
endsnippet
|
|
|
|
snippet scopel "scope lambda"
|
|
scope :${1:name}, lambda { |${2:param}| ${3:where(${4::${5:field}: ${6:"${7:value}"}})} }
|
|
endsnippet
|
|
|
|
snippet scopee "scope with extension"
|
|
scope :${1:name}, { ${2:where(${3::${4:field}: ${5:'${6:value}'}})} } do
|
|
def ${7:method_name}
|
|
$0
|
|
end
|
|
end
|
|
endsnippet
|
|
|
|
snippet sb "scoped_by"
|
|
scoped_by_${1:attribute}(${2:id})
|
|
endsnippet
|
|
|
|
snippet setup "setup do..end"
|
|
setup do
|
|
$0
|
|
end
|
|
endsnippet
|
|
|
|
snippet trans "Translation snippet"
|
|
I18n.t('`!v substitute(substitute(substitute(@%, substitute(getcwd() . "/", "\/", "\\\\/", "g"), "", ""), "\\(\\.\\(html\\|js\\)\\.\\(haml\\|erb\\)\\|\\(_controller\\)\\?\\.rb\\)$", "", ""), "/", ".", "g")`.${2:${1/[^\w]/_/g}}$3', default: "${1:some_text}"$4)${5:$0}
|
|
endsnippet
|
|
|
|
snippet route_spec
|
|
it 'routes to #${1:action}' do
|
|
${2:get}('/${3:url}').should route_to('`!v substitute(expand('%:t:r'), '_routing_spec$', '', '')`#$1'${4:, ${5:params}})$6
|
|
end
|
|
endsnippet
|
|
|
|
# vim:ft=snippets:
|