url-customizerでtweetを展開する際に絵文字が入っているとバグる
色んなものを展開しようとこのサイトのポストで試していたら再現
> 🚨 New Desktop Feature: Channel Status
> Let the rest of the server know what you're up to in voice so people can join in. <3 Enjoy!
> data:image/s3,"s3://crabby-images/7df78/7df78a59f27a3def46434b3c9ae0c280d1d531ea" alt=""
最後の行に Y
が入っている
これ例としてよくないな...
data:image/s3,"s3://crabby-images/f38f5/f38f5cd3809badb9de1ffe15628d1894a7d9b938" alt="wogikaze wogikaze"
<
が展開できていないのも含んでいる
後で調べる
期待する展開
> 🚨 New Desktop Feature: Channel Status
> Let the rest of the server know what you're up to in voice so people can join in. <3 Enjoy!
> data:image/s3,"s3://crabby-images/7df78/7df78a59f27a3def46434b3c9ae0c280d1d531ea" alt=""
原因
tweet.text
はツイートの文章(短縮リンクやハッシュタグを含む)
text.slice()
で要素ごとに分割しているが絵文字が含まれると正しく取り出せない
jsconst unicodeSubstring `` = (str, start, end) => {
const reg = new RegExp(`^[\\s\\S]{${start}}([\\s\\S]{0,${end - start}})`, 'u')
return str.match(reg)?.[1]
}
unicodeSubstring(tweet.text,indices[0] - offset,tweet.text.length)
誤
before
: "🚨 New Desktop Feature: Channel Status\n\nLet the rest of the server know what you're up to in voice so people can join in. <3 Enjoy! "
text
: 'Y'
正
before
: "🚨 New Desktop Feature: Channel Status\n\nLet the rest of the server know what you're up to in voice so people can join in. <3 Enjoy!"
text
: ''
あっ………………………………………………………………………………………………………………………………………………………
data:image/s3,"s3://crabby-images/007fb/007fb26aba7bd42527d35eb4bfa3e1cdb1ab656c" alt="takker takker"
こっちのほうがスマートでGOOD
data:image/s3,"s3://crabby-images/f38f5/f38f5cd3809badb9de1ffe15628d1894a7d9b938" alt="wogikaze wogikaze"
こんな文字は「しらんがな」です
> 🚨 New Desktop Feature: Channel Status
> Let the rest of the server know what you're up to in voice so people can join in. <3 Enjoy!
> data:image/s3,"s3://crabby-images/7df78/7df78a59f27a3def46434b3c9ae0c280d1d531ea" alt=""
オマケ: <
について
便利そうなので取り込みます
data:image/s3,"s3://crabby-images/007fb/007fb26aba7bd42527d35eb4bfa3e1cdb1ab656c" alt="takker takker"
旧
> &quot;"""クォーテーション&amp;"&"アンパサンド&lt;"<"小なり&gt;">"大なり&nbsp;" "空白&copy;"©"コピーライト
新
> """"クォーテーション&"&"アンパサンド<"<"小なり>">"大なり " "空白©"©"コピーライト
テスト
>
data:image/s3,"s3://crabby-images/5bc9a/5bc9a4282424b1d65fff7c6814f568f8c9670847" alt=""
動画が表示できなくなってる...
js...tweet.entities.media?.map?.((media) => ({
type: "media",
indices: media.indices,
media: tweet.mediaDetails?.flatMap?.((detail) => detail.url === media.url ? [{
type: detail.type,
//url: new URL(detail.video_info?.variants?.sort?.((a, b) => b.bitrate - a.bitrate)?.[0].url ?? detail.media_url_https)
url: new URL(detail.video_info?.variants.filter(variant => variant.bitrate)?.sort?.((a, b) => b.bitrate - a.bitrate)?.[0].url ?? detail.media_url_https)
}] : []) ?? []
})) ?? []
これも入れました
data:image/s3,"s3://crabby-images/007fb/007fb26aba7bd42527d35eb4bfa3e1cdb1ab656c" alt="takker takker"
bitrateが0のやつ見つけたけど眠いので今日はやらない
data:image/s3,"s3://crabby-images/f38f5/f38f5cd3809badb9de1ffe15628d1894a7d9b938" alt="wogikaze wogikaze"
variants.filter(variant => variant.content_type.startsWith("video"))
でいけそう
data:image/s3,"s3://crabby-images/007fb/007fb26aba7bd42527d35eb4bfa3e1cdb1ab656c" alt="takker takker"
オマケ2
メディアがあったときに入る謎の空行
これはメディアの後にテキストがあるのかどうか判定するときにミスっているぽい
なんかミスってる気がするので訂正
なんかうまいこと単体テスト入れてPR書いてくれるとうれし~
data:image/s3,"s3://crabby-images/007fb/007fb26aba7bd42527d35eb4bfa3e1cdb1ab656c" alt="takker takker"
自分はもうおやすみする時間なので
おやすも
data:image/s3,"s3://crabby-images/f38f5/f38f5cd3809badb9de1ffe15628d1894a7d9b938" alt="wogikaze wogikaze"
snapshot testは
$ deno test --allow-read --allow-write -- -u
で更新できる
生成されたsnapshot通りになるかどうかは
$ deno test --allow-read
で確認できる
修正助かります!
data:image/s3,"s3://crabby-images/c606d/c606d74861d1c6de08f997eec00993c71651d32c" alt="yosider yosider"