/// /// import SoopyTextElement from "../../../guimanager/GuiElement/SoopyTextElement"; import Feature from "../../featureClass/class"; import GuiPage from "../soopyGui/GuiPage"; import SoopyBoxElement from "../../../guimanager/GuiElement/SoopyBoxElement"; import SoopyMarkdownElement from "../../../guimanager/GuiElement/SoopyMarkdownElement"; import SoopyImageElement from "../../../guimanager/GuiElement/SoopyImageElement"; import SoopyGuiElement from "../../../guimanager/GuiElement/SoopyGuiElement"; import SoopyMouseClickEvent from "../../../guimanager/EventListener/SoopyMouseClickEvent"; import ButtonWithArrow from "../../../guimanager/GuiElement/ButtonWithArrow"; import BoxWithText from "../../../guimanager/GuiElement/BoxWithText"; import { drawBoxAtBlock } from "../../utils/renderUtils"; import { fetch } from "../../utils/networkUtils"; class StreamsGui extends Feature { constructor() { super() } onEnable(){ this.initVariables() this.GuiPage = new StreamPage() } initVariables(){ this.GuiPage = undefined } onDisable(){ this.initVariables() } } class StreamPage extends GuiPage { constructor(){ super(7) this.name = "Skyblock Streams" this.pages = [this.newPage()] this.pages[0].addChild(new SoopyTextElement().setText("§0Skyblock Streams").setMaxTextScale(3).setLocation(0.1, 0.05, 0.6, 0.1)) let button = new ButtonWithArrow().setText("§0Open in browser").setLocation(0.7, 0.05, 0.2, 0.1) this.pages[0].addChild(button) button.addEvent(new SoopyMouseClickEvent().setHandler(()=>{ java.awt.Desktop.getDesktop().browse( new java.net.URI("https://soopymc.my.to/skyblockstreams") ); })) this.streamsBox = new SoopyGuiElement().setLocation(0.1, 0.15, 0.8, 0.85) this.streamsBox.setScrollable(true) this.pages[0].addChild(this.streamsBox) this.finaliseLoading() } updateStreams(){ fetch("http://soopymc.my.to/api/skyblockstreams").json(streams=>{ this.streamsBox.clearChildren() let y = 0 Object.keys(streams.twitch).forEach((channel, i)=>{ let stream = streams.twitch[channel] if(i%2===0){ this.streamsBox.addChild(new StreamElement().setStream(stream, true).setLocation(0, y, 0.45, 0.55).setStreamPage(this)) } if(i%2===1){ this.streamsBox.addChild(new StreamElement().setStream(stream, true).setLocation(0.55, y, 0.45, 0.55).setStreamPage(this)) y+= 0.6 } }) }) } openStreamSidebar(data){ let sidebar = new SoopyGuiElement().setLocation(0,0,1,1) this.openSidebarPage(sidebar) sidebar.addChild(new SoopyTextElement().setText("§0"+data.user_name).setMaxTextScale(3).setLocation(0.1, 0.05, 0.8, 0.1)) let title = new SoopyMarkdownElement().setText(data.title).setLocation(0.1, 0.15, 0.8, 0.1) sidebar.addChild(title) let image = new SoopyImageElement().setImage(data.image).setLocation(0.1, 0.15+title.getHeight(), 0.8, 0.4) sidebar.addChild(image) image.loadHeightFromImage() let button = new ButtonWithArrow().setText("§0Watch on Twitch").setLocation(0.1, 0.15+image.location.size.y.get()+title.getHeight(), 0.8, 0.1) sidebar.addChild(button) button.addEvent(new SoopyMouseClickEvent().setHandler(()=>{ java.awt.Desktop.getDesktop().browse( new java.net.URI("https://twitch.tv/" + data.user_login) ); })) let language if(data.language){ language = new BoxWithText().setText("§0Language: "+data.language).setLocation(0.3, 0.25+image.location.size.y.get()+title.getHeight(), 0.4, 0.1) sidebar.addChild(language) } image.onImageHeightChange(()=>{ button.location.location.y.set(0.15+image.location.size.y.get()+title.getHeight()) if(language) language.location.location.y.set(0.25+image.location.size.y.get()+title.getHeight()) }, this) } onOpen(){ this.updateStreams() } } class StreamElement extends SoopyBoxElement { constructor(){ super() this.streamData = undefined this.channelElement = new SoopyTextElement().setLocation(0.1,0.025,0.8,0.1).setMaxTextScale(10) this.channelImg = new SoopyImageElement().setLocation(0.1,0.125,0.8,0.2) this.titleElement = new SoopyMarkdownElement().setLocation(0.1,0.45,0.8,0.1) this.channelImg.onImageHeightChange(()=>{ this.titleElement.location.location.y.set(0.15+this.channelImg.location.size.y.get()) },this) this.streamPage = undefined this.addEvent(new SoopyMouseClickEvent().setHandler(()=>{ this.streamPage.openStreamSidebar(this.streamData) })) this.addChild(this.channelElement) this.addChild(this.titleElement) this.addChild(this.channelImg) this.channelImg.loadHeightFromImage() } setStream(stream, twitch){ this.streamData = stream this.titleElement.setText(stream.title) this.channelElement.setText((twitch ? "§0"+stream.user_name : "§0"+stream.channelTitle) + (twitch?"&7 - " + stream.viewer_count + " viewer"+(stream.viewer_count!==1?"s":""):"")) this.streamData.image = twitch ? `https://static-cdn.jtvnw.net/previews-ttv/live_user_${stream.user_login}-640x360.jpg` : stream.thumbnails.high.url this.channelImg.setImage(this.streamData.image) this.channelImg.loadHeightFromImage() return this } setStreamPage(page){ this.streamPage = page return this } } module.exports = { class: new StreamsGui() }