Skip to content

Latest commit

 

History

History
48 lines (35 loc) · 1.23 KB

README.md

File metadata and controls

48 lines (35 loc) · 1.23 KB

README

Useful Snippets

Find all teams without participations

teams = Team.where.missing(:participations)

Find all kenshis without participations and purchases

kenshis = Kenshi.where.missing(:participations, :purchases)

Find all clubs without kenshis and users

clubs = Club.where.missing(:kenshis, :users)

Find shinpans in a category

# Show shinpans with grade and team name or pool number (for Individual Category)
cup = Cup.last
individual_categories = cup.individual_categories
team_categories = cup.team_categories

(individual_categories + team_categories).each do |category|
  shinpans = Kenshi.joins(:participations).merge(category.participations).where(grade: %w[5Dan 6Dan 7Dan])

  CSV.open("/Users/yannis/Dropbox/kendo/kasaharacup/2023/Shinpans/#{category.name.parameterize}.csv", "wb") do |csv|
    csv << ["Name", "Grade", "Team"]
    shinpans.each do |shinpan|
      participation = shinpan.participations.find { |p| p.category == category }
      csv << [shinpan.full_name, shinpan.grade, participation.team&.name.presence || participation.pool_number.presence]
    end
  end
end

Reset pools for an IndividualCategory

SmartPooler.new(category).set_pools