Files
YouTube.js/lib/parser/contents/classes/ToggleButton.js
Bob Varioa 0a851bde31 refactor: remove confusing code practices (#87)
* Prefer `c ? x : y` over `c && x || y`

* Avoid unnecessary asssignment expressions

* Prefer switch statements over object lookup tables

* Add an .editorconfig

* Fix style issues

* Fix mentioned issues

Co-authored-by: bob <bob.varioa@gmail.com>
2022-07-01 19:37:59 -03:00

41 lines
1.3 KiB
JavaScript

'use strict';
const Text = require('./Text');
const NavigationEndpoint = require('./NavigationEndpoint');
class ToggleButton {
type = 'ToggleButton';
constructor(data) {
this.text = new Text(data.defaultText);
this.toggled_text = new Text(data.toggledText);
this.tooltip = data.defaultTooltip;
this.toggled_tooltip = data.toggledTooltip;
this.is_toggled = data.isToggled;
this.is_disabled = data.isDisabled;
this.icon_type = data.defaultIcon.iconType;
const acc_label =
data.defaultText?.accessibility?.accessibilityData.label ||
data?.accessibility?.label;
if (this.icon_type == 'LIKE') {
this.like_count = parseInt(acc_label.replace(/\D/g, ''))
if (this.like_count) {
this.short_like_count = new Text(data.defaultText).toString()
}
}
this.endpoint =
data.defaultServiceEndpoint?.commandExecutorCommand?.commands &&
new NavigationEndpoint(data.defaultServiceEndpoint.commandExecutorCommand.commands.pop()) ||
new NavigationEndpoint(data.defaultServiceEndpoint);
this.toggled_endpoint = new NavigationEndpoint(data.toggledServiceEndpoint);
this.button_id = data.toggleButtonSupportedData?.toggleButtonIdData?.id || null;
this.target_id = data.targetId || null;
}
}
module.exports = ToggleButton;