-- Deploy camper:translate_campsite_carousel_slide to pg -- requires: roles -- requires: schema_camper -- requires: campsite -- requires: campsite_carousel_i18n begin; set search_path to camper, public; create or replace function translate_campsite_carousel_slide(company_id integer, label text, media_id integer, lang_tag text, caption text) returns void as $$ insert into campsite_carousel_i18n (campsite_id, media_id, lang_tag, caption) select campsite_id, translate_campsite_carousel_slide.media_id, lang_tag, case trim(caption) when '' then null else caption end from campsite where label = translate_campsite_carousel_slide.label and company_id = translate_campsite_carousel_slide.company_id on conflict (campsite_id, media_id, lang_tag) do update set caption = excluded.caption ; $$ language sql ; revoke execute on function translate_campsite_carousel_slide(integer, text, integer, text, text) from public; grant execute on function translate_campsite_carousel_slide(integer, text, integer, text, text) to admin; commit;