FEATURE: Add better TikTok onebox support (#19934)

This commit is contained in:
Jan Cernik 2023-01-23 09:49:02 -03:00 committed by GitHub
parent 641e94fc3c
commit d0c820e816
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 59 additions and 0 deletions

View File

@ -210,3 +210,4 @@ require_relative "engine/google_drive_onebox"
require_relative "engine/facebook_media_onebox"
require_relative "engine/hackernews_onebox"
require_relative "engine/motoko_onebox"
require_relative "engine/tiktok_onebox"

View File

@ -0,0 +1,58 @@
# frozen_string_literal: true
module Onebox
module Engine
class TiktokOnebox
include Engine
include StandardEmbed
matches_regexp(%r{^https?://((?:m|www)\.)?tiktok\.com(?:/@(.+)\/video/|/v/)\d+(/\w+)?/?})
requires_iframe_origins "https://www.tiktok.com"
always_https
def placeholder_html
<<-HTML
<img
src="#{oembed_data.thumbnail_url}"
title="#{oembed_data.title}"
style="
max-width: #{oembed_data.thumbnail_width / 2}px;
max-height: #{oembed_data.thumbnail_height / 2}px;"
>
HTML
end
def to_html
height = oembed_data.thumbnail_width >= oembed_data.thumbnail_height ? 727 : 742
<<-HTML
<iframe
class="tiktok-onebox"
src="https://www.tiktok.com/embed/v2/#{oembed_data.embed_product_id}"
sandbox="allow-popups allow-popups-to-escape-sandbox allow-scripts allow-top-navigation allow-same-origin"
frameborder="0"
seamless="seamless"
scrolling="no"
style="
min-width: 332px;
height: #{height}px;
border-top: 3px solid #fff;
border-radius: 9px;
background-color: #fff;
"
></iframe>
HTML
end
private
def oembed_data
@oembed_data = get_oembed
end
def get_oembed_url
"https://www.tiktok.com/oembed?url=#{url}"
end
end
end
end