Add config panel for XloveCam
This commit is contained in:
parent
3c71624f38
commit
804d7b0f52
|
@ -0,0 +1,51 @@
|
||||||
|
package ctbrec.ui.sites.xlovecam;
|
||||||
|
|
||||||
|
import ctbrec.Config;
|
||||||
|
import ctbrec.sites.xlovecam.XloveCam;
|
||||||
|
import ctbrec.ui.DesktopIntegration;
|
||||||
|
import ctbrec.ui.settings.SettingsTab;
|
||||||
|
import ctbrec.ui.sites.AbstractConfigUI;
|
||||||
|
import javafx.geometry.Insets;
|
||||||
|
import javafx.scene.Parent;
|
||||||
|
import javafx.scene.control.Button;
|
||||||
|
import javafx.scene.control.CheckBox;
|
||||||
|
import javafx.scene.control.Label;
|
||||||
|
import javafx.scene.layout.GridPane;
|
||||||
|
|
||||||
|
public class XloveCamConfigUI extends AbstractConfigUI {
|
||||||
|
private XloveCam site;
|
||||||
|
|
||||||
|
public XloveCamConfigUI(XloveCam site) {
|
||||||
|
this.site = site;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Parent createConfigPanel() {
|
||||||
|
GridPane layout = SettingsTab.createGridLayout();
|
||||||
|
var settings = Config.getInstance().getSettings();
|
||||||
|
|
||||||
|
var row = 0;
|
||||||
|
var l = new Label("Active");
|
||||||
|
layout.add(l, 0, row);
|
||||||
|
var enabled = new CheckBox();
|
||||||
|
enabled.setSelected(!settings.disabledSites.contains(site.getName()));
|
||||||
|
enabled.setOnAction(e -> {
|
||||||
|
if(enabled.isSelected()) {
|
||||||
|
settings.disabledSites.remove(site.getName());
|
||||||
|
} else {
|
||||||
|
settings.disabledSites.add(site.getName());
|
||||||
|
}
|
||||||
|
save();
|
||||||
|
});
|
||||||
|
GridPane.setMargin(enabled, new Insets(0, 0, 0, SettingsTab.CHECKBOX_MARGIN));
|
||||||
|
layout.add(enabled, 1, row++);
|
||||||
|
|
||||||
|
var createAccount = new Button("Create new Account");
|
||||||
|
createAccount.setOnAction(e -> DesktopIntegration.open(site.getAffiliateLink()));
|
||||||
|
layout.add(createAccount, 1, row);
|
||||||
|
GridPane.setColumnSpan(createAccount, 2);
|
||||||
|
GridPane.setMargin(createAccount, new Insets(0, 0, 0, SettingsTab.CHECKBOX_MARGIN));
|
||||||
|
return layout;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -11,10 +11,12 @@ public class XloveCamSiteUi extends AbstractSiteUi {
|
||||||
|
|
||||||
private final XloveCamTabProvider tabProvider;
|
private final XloveCamTabProvider tabProvider;
|
||||||
private final XloveCam site;
|
private final XloveCam site;
|
||||||
|
private final XloveCamConfigUI configUi;
|
||||||
|
|
||||||
public XloveCamSiteUi(XloveCam xloveCam) {
|
public XloveCamSiteUi(XloveCam xloveCam) {
|
||||||
this.site = xloveCam;
|
this.site = xloveCam;
|
||||||
tabProvider = new XloveCamTabProvider(xloveCam);
|
tabProvider = new XloveCamTabProvider(xloveCam);
|
||||||
|
configUi = new XloveCamConfigUI(xloveCam);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -24,7 +26,7 @@ public class XloveCamSiteUi extends AbstractSiteUi {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ConfigUI getConfigUI() {
|
public ConfigUI getConfigUI() {
|
||||||
return null;
|
return configUi;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -33,12 +33,12 @@ public class XloveCam extends AbstractSite {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getAffiliateLink() {
|
public String getAffiliateLink() {
|
||||||
return getBaseUrl();
|
return getBaseUrl() + "/en/register/";
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getBuyTokensLink() {
|
public String getBuyTokensLink() {
|
||||||
return getAffiliateLink();
|
return getBaseUrl();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
Loading…
Reference in New Issue