Skip to content

Commit

Permalink
Added some CategoryCSGO options
Browse files Browse the repository at this point in the history
  • Loading branch information
lukflug committed Oct 3, 2021
1 parent c5f27d5 commit 990ce83
Show file tree
Hide file tree
Showing 4 changed files with 45 additions and 10 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@
public class ExampleMod {
public static final String MODID="example-mod12";
public static final String NAME="PanelStudio-MC12 Example Mod";
public static final String VERSION="0.2.0";
public static final String VERSION="0.2.1";
public static Logger logger;
private static ClickGUI gui;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@
public class ExampleMod {
public static final String MODID="example-mod8-forge";
public static final String NAME="PanelStudio-MC8-Forge Example Mod";
public static final String VERSION="0.2.0";
public static final String VERSION="0.2.1";
public static Logger logger;
private static ClickGUI gui;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,10 @@ public class CSGOLayout implements ILayout,IScrollSize {
* Whether settings are in a separate column.
*/
protected boolean moduleColumn;
/**
* The width of the category column.
*/
protected int columnWidth;
/**
* The weight of the settings column.
*/
Expand Down Expand Up @@ -90,13 +94,33 @@ public class CSGOLayout implements ILayout,IScrollSize {
* @param popupType child util instance
*/
public CSGOLayout (ILabeled label, Point position, int width, int popupWidth, Supplier<Animation> animation, String enabledButton, boolean horizontal, boolean moduleColumn, int weight, ChildMode colorType, PopupTuple popupType) {
this(label,position,width,popupWidth,animation,enabledButton,horizontal,moduleColumn,-1,weight,colorType,popupType);
}

/**
* Constructor.
* @param label panel label
* @param position panel position
* @param width panel width
* @param popupWidth pop-up width
* @param animation animation supplier
* @param enabledButton title for module toggles
* @param horizontal whether tab list is horizontal
* @param moduleColumn whether settings are in a separate column
* @param columnWidth the width of the category column
* @param weight weight of the module column
* @param colorType child mode to use for setting components that are containers (e.g. color components)
* @param popupType child util instance
*/
public CSGOLayout (ILabeled label, Point position, int width, int popupWidth, Supplier<Animation> animation, String enabledButton, boolean horizontal, boolean moduleColumn, int columnWidth, int weight, ChildMode colorType, PopupTuple popupType) {
this.label=label;
this.position=position;
this.width=width;
this.animation=animation;
this.enabledButton=enabledButton;
this.horizontal=horizontal;
this.moduleColumn=moduleColumn;
this.columnWidth=columnWidth;
this.weight=weight;
this.colorType=colorType;
util=new ChildUtil(popupWidth,animation,popupType);
Expand All @@ -113,15 +137,15 @@ public void populateGUI (IComponentAdder gui, IComponentGenerator components, IC
container.addComponent(window);
gui.addComponent(title,container,new ThemeTuple(theme,0,0),position,width,animation);
} else {
catSelect=addContainer(label,client.getCategories().map(cat->cat),window,new ThemeTuple(theme,0,1),false,button->wrapColumn(button,new ThemeTuple(theme,0,1),1),()->true);
catSelect=addContainer(label,client.getCategories().map(cat->cat),window,new ThemeTuple(theme,0,1),false,button->wrapColumn(button,new ThemeTuple(theme,0,1),columnWidth>0?columnWidth:0,columnWidth>0?0:1),()->true);
gui.addComponent(title,window,new ThemeTuple(theme,0,0),position,width,animation);
}
client.getCategories().forEach(category->{
if (moduleColumn) {
IEnumSetting modSelect=addContainer(category,category.getModules().map(mod->mod),window,new ThemeTuple(theme,1,1),false,button->wrapColumn(button,new ThemeTuple(theme,0,1),1),()->catSelect.getValueName()==category.getDisplayName());
IEnumSetting modSelect=addContainer(category,category.getModules().map(mod->mod),window,new ThemeTuple(theme,1,1),false,button->wrapColumn(button,new ThemeTuple(theme,0,1),0,1),()->catSelect.getValueName()==category.getDisplayName());
category.getModules().forEach(module->{
VerticalContainer container=new VerticalContainer(module,theme.getContainerRenderer(1,1,false));
window.addComponent(wrapColumn(container,new ThemeTuple(theme,1,1),weight),()->catSelect.getValueName()==category.getDisplayName()&&modSelect.getValueName()==module.getDisplayName());
window.addComponent(wrapColumn(container,new ThemeTuple(theme,1,1),0,weight),()->catSelect.getValueName()==category.getDisplayName()&&modSelect.getValueName()==module.getDisplayName());
if (module.isEnabled()!=null) container.addComponent(components.getComponent(new IBooleanSetting() {
@Override
public String getDisplayName() {
Expand All @@ -142,7 +166,7 @@ public boolean isOn() {
});
} else {
VerticalContainer categoryContent=new VerticalContainer(category,theme.getContainerRenderer(0,1,false));
window.addComponent(wrapColumn(categoryContent,new ThemeTuple(theme,0,1),1),()->catSelect.getValueName()==category.getDisplayName());
window.addComponent(wrapColumn(categoryContent,new ThemeTuple(theme,0,1),0,weight),()->catSelect.getValueName()==category.getDisplayName());
category.getModules().forEach(module->{
int graphicalLevel=1;
FocusableComponent moduleTitle;
Expand Down Expand Up @@ -268,10 +292,11 @@ protected boolean isDownKey (int key) {
* Wrap content in a scrollable horizontal component to be added as a column.
* @param button the content container
* @param theme the theme to be used
* @param width the horizontal width
* @param weight the horizontal weight
* @return a horizontal component
*/
protected HorizontalComponent<ScrollBarComponent<Void,IComponent>> wrapColumn (IComponent button, ThemeTuple theme, int weight) {
protected HorizontalComponent<ScrollBarComponent<Void,IComponent>> wrapColumn (IComponent button, ThemeTuple theme, int width, int weight) {
return new HorizontalComponent<ScrollBarComponent<Void,IComponent>>(new ScrollBarComponent<Void,IComponent>(button,theme.getScrollBarRenderer(Void.class),theme.getEmptySpaceRenderer(Void.class,false),theme.getEmptySpaceRenderer(Void.class,true)) {
@Override
public int getScrollHeight (Context context, int componentHeight) {
Expand All @@ -282,7 +307,7 @@ public int getScrollHeight (Context context, int componentHeight) {
protected Void getState() {
return null;
}
},0,weight);
},width,weight);
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -63,13 +63,13 @@ public ChildUtil (int width, Supplier<Animation> animation, PopupTuple popupType
* @param theme the theme to be used
* @param mode the child mode to be used
*/
protected <T> void addContainer (ILabeled label, IComponent title, IComponent container, Supplier<T> state, Class<T> stateClass, VerticalContainer parent, IComponentAdder gui, ThemeTuple theme, ChildMode mode) {
public <T> void addContainer (ILabeled label, IComponent title, IComponent container, Supplier<T> state, Class<T> stateClass, VerticalContainer parent, IComponentAdder gui, ThemeTuple theme, ChildMode mode) {
IFixedComponent popup;
IToggleable toggle;
boolean drawTitle=mode==ChildMode.DRAG_POPUP;
switch (mode) {
case DOWN:
parent.addComponent(new ClosableComponent<>(title,container,state,new AnimatedToggleable(new SimpleToggleable(false),animation.get()),theme.getPanelRenderer(stateClass),false));
parent.addComponent(new ClosableComponent<>(title,container,state,getAnimatedToggleable(animation.get()),theme.getPanelRenderer(stateClass),false));
break;
case POPUP:
case DRAG_POPUP:
Expand All @@ -92,6 +92,16 @@ public void handleButton (Context context, int button) {
}
}

/**
* Get animated toggleable.
* @param animation the animation to be used
* @return the animated toggleable to be used
*/
protected AnimatedToggleable getAnimatedToggleable (Animation animation) {
return new AnimatedToggleable(new SimpleToggleable(false),animation);
}


/**
* Enum listing the ways a child component can be added.
* @author lukflug
Expand Down

0 comments on commit 990ce83

Please sign in to comment.