From b1a1e5230d6c430d572dd4501f95f69b461e019c Mon Sep 17 00:00:00 2001 From: bonjinnorenka <32708102+bonjinnorenka@users.noreply.github.com> Date: Wed, 6 Sep 2023 23:54:18 +0900 Subject: [PATCH] better iframe size and use forEach on playerVars --- assets/js/invidious_iframe_api.js | 30 ++++++++++++++++++++---------- 1 file changed, 20 insertions(+), 10 deletions(-) diff --git a/assets/js/invidious_iframe_api.js b/assets/js/invidious_iframe_api.js index cbbd0963..eee8d29b 100644 --- a/assets/js/invidious_iframe_api.js +++ b/assets/js/invidious_iframe_api.js @@ -160,11 +160,23 @@ class invidious_embed { let no_start_parameter = true; if (typeof options.playerVars === 'object') { this.option_playerVars = options.playerVars; - for (let x in options.playerVars) { - if (typeof x === 'string' && typeof options.playerVars[x] === 'string') { - search_params.append(x, options.playerVars[x]); + Object.keys(options.playerVars).forEach(key=>{ + if (typeof key === 'string') { + let keyValue = options.playerVars[key]; + switch (typeof keyValue) { + case 'number': + keyValue = keyValue.toString(); + break; + case 'string': + break; + default : + console.warn('player vars key value must be string or number'); + } + search_params.append(key, keyValue); + } else { + console.warn('player vars key must be string'); } - } + }) if (options.playerVars.start !== undefined) { no_start_parameter = false; } @@ -191,11 +203,8 @@ class invidious_embed { if (typeof options.width === 'number') { this.player_iframe.width = options.width; } else { - if (document.body.clientWidth < 640) { - this.player_iframe.width = document.body.clientWidth; - } else { - this.player_iframe.width = 640; - } + this.player_iframe.width = 640; + this.player_iframe.style.maxWidth = '100%'; } if (typeof options.width === 'number') { this.player_iframe.width = options.width; @@ -225,7 +234,8 @@ class invidious_embed { } receiveMessage(message) { - if (message.data.from === 'invidious_control' && message.data.widgetid === String(this.widgetid)) { + const onControlAndHasWidgetId = message.data.from==='invidious_control' && message.data.widgetid===this.widgetid.toString(); + if (onControlAndHasWidgetId) { switch (message.data.message_kind) { case 'info_return': const promise_array = this.message_wait[message.data.command];