Files
baclight/db/seeds.rb
T

219 lines
6.6 KiB
Ruby
Raw Normal View History

def determine_id_card_templates(pl_plan_key)
2026-03-16 12:09:45 -04:00
case pl_plan_key
2026-03-20 10:46:53 -04:00
when "2"
2026-03-16 12:09:45 -04:00
"SmartIDCard"
2026-03-20 10:46:53 -04:00
when "3"
2026-03-19 00:42:27 -04:00
"TandemlocIDCard"
2026-03-20 10:46:53 -04:00
when "56"
2026-03-19 00:42:27 -04:00
"QRCodeIDCard"
else
2026-03-19 00:42:27 -04:00
"FairosRxIDCard"
end
end
def determine_id_card_rx(pl_plan_key)
2026-03-20 10:46:53 -04:00
if pl_plan_key == "56"
2026-03-19 00:42:27 -04:00
"TheHealthBus"
else
"FairosRx"
end
2026-03-16 12:09:45 -04:00
end
2026-03-16 12:09:45 -04:00
def determine_id_card_network(pl_plan_key)
2026-03-20 10:46:53 -04:00
cigna_groups = ["13","20","39","48","49","51","53","54","56","58","60","61","62","65","67","68","69"]
medcost_groups = ["4","5","16","23","33","55","57","59","63","66"]
old_cigna_groups = ["19","21"]
smart_medcost = ["2"]
tan_medcost = ["3"]
2026-03-16 12:09:45 -04:00
case
2026-03-20 10:46:53 -04:00
when cigna_groups.include?(pl_plan_key) || pl_plan_key.blank?
2026-03-16 12:09:45 -04:00
{ provider: "Cigna", network_logo: "CignaLogo.png", provider_section: "Cigna" }
when medcost_groups.include?(pl_plan_key)
{ provider: "MedCost", network_logo: "MedcostLogo.png", provider_section: "MedCost" }
when old_cigna_groups.include?(pl_plan_key)
{ provider: "Cigna", network_logo: "CignaLogo.png", provider_section: "Cigna (Beam/Stevens)" }
when smart_medcost.include?(pl_plan_key)
{ provider: "MedCost", network_logo: "MedcostLogo.png", provider_section: "MedCost (smART)" }
when tan_medcost.include?(pl_plan_key)
{ provider: "MedCost", network_logo: "MedcostLogo.png", provider_section: "MedCost (Tandemloc)" }
end
end
2026-03-20 10:46:53 -04:00
def determine_divisions(pl_plan_key)
if pl_plan_key == "16"
true
else
false
end
end
def determine_card_color(pl_plan_key)
if pl_plan_key == "3"
"blue"
else
"white"
end
end
2026-03-19 00:42:27 -04:00
puts "[**** IMPORT ID CARD TABLES ****]"
2026-03-19 00:42:27 -04:00
## SET UP DEFAULT LEVEL360 PLANS FOR PLAN PICKER
# temp_1 = IdCardBenefitsTemplate.create(title: "Rebekah's Template")
# (1..14).each do |seq|
# IdCardBenefit.create(sequence: seq, benefit: "greatest hits vol #{seq}", id_card_benefits_template: temp_1)
# end
2026-03-19 00:42:27 -04:00
##---------------- Provider/Claims Setup------------------------------------
2026-03-19 00:42:27 -04:00
puts "Importing Card Provider/Claims Information"
2026-03-16 12:09:45 -04:00
default_provider_codes = ["5", "2"]
needed_codes_mapping = {
"0": "MedCost VA Plus Network",
"2": "MedCost",
"3": "AHA Preferred",
"5": "Cigna",
"6": "Cigna (Beam/Stevens)",
A: "AHA",
M: "MedCost (smART)",
T: "MedCost (Tandemloc)"
}.stringify_keys
needed_codes = needed_codes_mapping.keys
vhcs_cp = Vhcs::HlidCardProvider.where(provider_code: needed_codes)
2026-03-13 08:47:13 -04:00
vhcs_cp.each do |vhcs|
attributes_hash = vhcs.attributes.except(:provider_code, :group_number)
attributes_hash.delete_if { |key, value| !key.to_s.include?("_") }
2026-03-16 12:09:45 -04:00
if default_provider_codes.include?(vhcs.provider_code)
attributes_hash[:default] = true
2026-03-13 08:47:13 -04:00
end
2026-03-16 12:09:45 -04:00
attributes_hash[:title] = needed_codes_mapping[vhcs.provider_code]
2026-03-13 08:47:13 -04:00
2026-03-19 00:42:27 -04:00
puts "-- #{attributes_hash[:title]}"
2026-03-16 12:09:45 -04:00
IdCard::ProviderSection.find_or_create_by(attributes_hash)
2026-03-13 08:47:13 -04:00
end
2026-03-19 00:42:27 -04:00
##---------------- Rx info Setup------------------------------------
puts "Importing Card Rx Information"
Vhcs::HlrxCrosRef.all.each do |vhcs|
2026-03-13 08:47:13 -04:00
rx = IdCard::RxSection.find_or_create_by(help_desk: vhcs.help_desk, customer_service: vhcs.customer_service, web_url: vhcs.web_url)
title = rx.web_url.gsub(/^www\./, '').gsub(/\.com\Z/, '')
unless title.match?(/\A[A-Z]/)
title = title.capitalize
end
2026-03-13 08:47:13 -04:00
2026-03-19 00:42:27 -04:00
puts "-- #{title}"
2026-03-13 08:47:13 -04:00
rx.title = title
rx.save
end
2026-03-19 00:42:27 -04:00
##---------------- Network Logos Setup------------------------------------
puts "Importing Network Logos"
folder_path = Rails.root.join('logo_files', 'network')
file_names = Dir.children(folder_path)
default_network_logos = ["CignaLogo.png", "MedCostLogo.png"]
file_names.each do |logo_upload|
puts "-- #{logo_upload}"
2026-03-20 10:46:53 -04:00
new_logo = ImageProcessorService.new("logo_files/network/#{logo_upload}", "Network").call
2026-03-19 00:42:27 -04:00
if default_network_logos.include?(logo_upload)
new_logo.default = true
end
new_logo.active = true
new_logo.save
end
##---------------- Active Employer Logo Setup------------------------------------
puts "Importing Employer Logos"
folder_path = Rails.root.join('logo_files', 'employer')
file_names = Dir.children(folder_path)
file_names.each do |logo_upload|
puts "-- #{logo_upload}"
2026-03-20 10:46:53 -04:00
new_logo = ImageProcessorService.new("logo_files/employer/#{logo_upload}", "Employer").call
2026-03-13 08:47:13 -04:00
new_logo.active = true
new_logo.save
end
2026-03-19 00:42:27 -04:00
puts "[**** IMPORT EMPLOYERS ****]"
2026-03-20 10:46:53 -04:00
##---------------- Import Employer/Member (VHCS) ------------------------------------
puts "Importing Employers From VHCS"
2026-03-19 00:42:27 -04:00
Rake::Task["employer:vhcs_sync_all"].invoke
# acentria = Carrier.find_or_create_by!(name: 'Acentria')
# mcswain_broker = Broker.find_or_create_by!(name: 'Tom McSwain') do |mc|
# mc.carrier = acentria
# end
# mcswain_employers = HebWeb::BrokerXRef.where(pl_plan_key: 99).pluck(:employer_pl_plan_key)
# Imports employers and members from VHCS
# use rake tasks
2026-03-20 10:46:53 -04:00
##---------------- Import Employers (Word Docs) ------------------------------------
puts "Importing Employers From Word Docs"
folder_path = Rails.root.join('employer_word_docs')
file_names = Dir.children(folder_path)
file_names.each do |word_doc|
puts "-- Processing #{word_doc}"
new_employer = BenefitsWordDocService::WordDocProcessor.new("employer_word_docs/#{word_doc}").call
if new_employer.save
puts "Imported #{new_employer.name}"
end
end
##---------------- Update ID Card Setups------------------------------------
2026-03-16 12:09:45 -04:00
2026-03-20 10:46:53 -04:00
puts "[**** UPDATE EMPLOYER ID CARD SETUPS ****]"
IdCard::Setup.all.each do |setup|
setup.card_template = determine_id_card_templates(setup.pl_plan_key)
setup.card_color = determine_card_color(setup.pl_plan_key)
setup.has_divisions = determine_divisions(setup.pl_plan_key)
network_information = determine_id_card_network(setup.pl_plan_key)
setup.network_provider = network_information[:provider]
2026-03-19 00:42:27 -04:00
ps = IdCard::ProviderSection.find_by(title: network_information[:provider_section])
2026-03-20 10:46:53 -04:00
setup.provider_section_id = ps.id
2026-03-19 00:42:27 -04:00
nl = IdCard::NetworkLogo.find_by(filename: network_information[:network_logo])
2026-03-20 10:46:53 -04:00
setup.network_logo_id = nl.id
2026-03-19 00:42:27 -04:00
2026-03-20 10:46:53 -04:00
rx_title = determine_id_card_rx(setup.pl_plan_key)
2026-03-19 00:42:27 -04:00
rs = IdCard::RxSection.find_by(title: rx_title)
2026-03-20 10:46:53 -04:00
setup.rx_section_id = rs.id
2026-03-19 00:42:27 -04:00
2026-03-20 10:46:53 -04:00
employer_name = setup.employer.employer_trim_name
2026-03-19 00:42:27 -04:00
name_segments = employer_name.titleize.split
name_segments.each do |segment|
logo = IdCard::EmployerLogo.where("filename LIKE ?", "%#{segment}%")
if logo&.first
2026-03-20 10:46:53 -04:00
setup.employer_logo = logo.first
2026-03-19 00:42:27 -04:00
break
end
2026-03-16 12:09:45 -04:00
end
2026-03-19 00:42:27 -04:00
2026-03-20 10:46:53 -04:00
if setup.pl_plan_key.present?
setup.active = true
end
setup.save
2026-03-16 12:09:45 -04:00
end
2026-03-19 00:42:27 -04:00
# 15, 18, 19, 20, 13, 21
2025-11-24 08:22:44 -05:00