From a1748aa590ad7c0eb2a8fa507b39dfff1cffc1e0 Mon Sep 17 00:00:00 2001 From: Chuong Date: Tue, 31 Oct 2017 23:03:49 +0700 Subject: [PATCH] refactor: player.techGet_() (#4687) --- src/js/player.js | 48 ++++++++++++++++++++++++++---------------------- 1 file changed, 26 insertions(+), 22 deletions(-) diff --git a/src/js/player.js b/src/js/player.js index 7184a490ce..f207557ace 100644 --- a/src/js/player.js +++ b/src/js/player.js @@ -1587,34 +1587,38 @@ class Player extends Component { * @private */ techGet_(method) { - if (this.tech_ && this.tech_.isReady_) { + if (!this.tech_ || !this.tech_.isReady_) { + return; + } + + if (method in middleware.allowedGetters) { + return middleware.get(this.middleware_, this.tech_, method); + } - if (method in middleware.allowedGetters) { - return middleware.get(this.middleware_, this.tech_, method); + // Flash likes to die and reload when you hide or reposition it. + // In these cases the object methods go away and we get errors. + // When that happens we'll catch the errors and inform tech that it's not ready any more. + try { + return this.tech_[method](); + } catch (e) { + + // When building additional tech libs, an expected method may not be defined yet + if (this.tech_[method] === undefined) { + log(`Video.js: ${method} method not defined for ${this.techName_} playback technology.`, e); + throw e; } - // Flash likes to die and reload when you hide or reposition it. - // In these cases the object methods go away and we get errors. - // When that happens we'll catch the errors and inform tech that it's not ready any more. - try { - return this.tech_[method](); - } catch (e) { - // When building additional tech libs, an expected method may not be defined yet - if (this.tech_[method] === undefined) { - log(`Video.js: ${method} method not defined for ${this.techName_} playback technology.`, e); - - // When a method isn't available on the object it throws a TypeError - } else if (e.name === 'TypeError') { - log(`Video.js: ${method} unavailable on ${this.techName_} playback technology element.`, e); - this.tech_.isReady_ = false; - } else { - log(e); - } + // When a method isn't available on the object it throws a TypeError + if (e.name === 'TypeError') { + log(`Video.js: ${method} unavailable on ${this.techName_} playback technology element.`, e); + this.tech_.isReady_ = false; throw e; } - } - return; + // If error unknown, just log and throw + log(e); + throw e; + } } /**