/// @description init event_inherited(); #region data destroy_on_click_out = true; dialog_w = ui(960); dialog_h = ui(600); pages = ["Welcome Files"]; if(STEAM_ENABLED) array_push(pages, "Workshop"); project_page = 0; thumbnail_retriever = 0; recent_thumbnail = false; show_autosaves = false; recent_width = PREFERENCES.splash_expand_recent? ui(576) : ui(288); clip_surf = surface_create(1, 1); #endregion #region content function resize() { var x0 = dialog_x + ui(16); var x1 = x0 + recent_width; var y0 = dialog_y + ui(48); var y1 = dialog_y + dialog_h - ui(16); sp_recent.resize(x1 - x0 - ui(12), y1 - y0); x0 = x1 + ui(16); x1 = dialog_x + dialog_w - ui(16); sp_sample.resize( x1 - x0 - ui(12), y1 - y0 - 1); sp_contest.resize(x1 - x0 - ui(12), y1 - y0 - 2); } var x0 = dialog_x + ui(16); var x1 = x0 + recent_width; var y0 = dialog_y + ui(128); var y1 = dialog_y + dialog_h - ui(16); sp_recent = new scrollPane(x1 - x0 - ui(12), y1 - y0, function(_y, _m) { #region draw_clear_alpha(COLORS.panel_bg_clear_inner, 0); var expand = PREFERENCES.splash_expand_recent; var ww = ui(264); var hh = ui(8); var pad = ui(6); var hgt = ui(14) + line_get_height(f_p0b) + line_get_height(f_p2); _y += pad; var col = expand? 2 : 1; var row = ceil(ds_list_size(RECENT_FILES) / col); var hg = recent_thumbnail? ui(100) : hgt; for(var i = 0; i < row; i++) { if(_y > -(hg + pad) && _y < sp_recent.surface_h) for(var j = 0; j < col; j++) { var ind = i * col + j; if(ind >= ds_list_size(RECENT_FILES)) break; var _rec = RECENT_FILES[| ind]; var _dat = RECENT_FILE_DATA[| ind]; if(!file_exists_empty(_rec)) continue; var thmb = recent_thumbnail? _dat.getThumbnail() : noone; var fx = j * (ww + ui(8)); draw_sprite_stretched(THEME.ui_panel_bg, 1, fx, _y, ww, hg); if(thmb && _y + hg > 0 && _y < sp_recent.h) { var sw = surface_get_width_safe(thmb); var sh = surface_get_height_safe(thmb); var ss = (ww - ui(8)) / sw; var sy = (((sh * ss) - hg) * clamp((_y + hg) / (sp_recent.h + hg), 0, 1)) / ss; draw_surface_part_ext(thmb, 0, sy, sw, (hg - ui(8)) / ss, fx + ui(4), _y + ui(4), ss, ss, COLORS._main_icon_light, 0.9); draw_sprite_stretched_ext(s_fade_up, 0, fx + ui(4), _y + hg - ui(64), ww - ui(8), ui(64), COLORS._main_icon_dark, 1); } if(sHOVER && sp_recent.hover && point_in_rectangle(_m[0], _m[1], fx, _y, fx + ww, _y + hg)) { sp_recent.hover_content = true; TOOLTIP = [ _dat.getThumbnail(), VALUE_TYPE.surface ]; draw_sprite_stretched_ext(THEME.node_bg, 1, fx, _y, ww, hg, COLORS._main_accent, 1); if(mouse_press(mb_left, sFOCUS)) { LOAD_PATH(_rec); instance_destroy(); } } var ly = recent_thumbnail? _y + hg - (line_get_height(f_p0b) + line_get_height(f_p2)) - ui(8) : _y + ui(6); draw_set_text(f_p0b, fa_left, fa_top, COLORS._main_text_inner); draw_text(fx + ui(12), ly, filename_name_only(_rec)); ly += line_get_height() + ui(2); draw_set_text(f_p2, fa_left, fa_top, COLORS._main_text_sub); draw_text_cut(fx + ui(12), ly, _rec, ww - ui(24)); } hh += hg + pad; _y += hg + pad; } return hh; }); #endregion x0 = x1 + ui(16); x1 = dialog_x + dialog_w - ui(16); meta_filter = []; sp_sample = new scrollPane(x1 - x0 - ui(12), y1 - y0 - 1, function(_y, _m) { #region draw_clear_alpha(COLORS.panel_bg_clear, 0); var txt = pages[project_page]; var list, _group_label; var ww = sp_sample.surface_w; var hh = ui(20); var yy = _y + hh; switch(txt) { case "Welcome Files" : list = SAMPLE_PROJECTS; _group_label = true; break; case "Workshop" : list = STEAM_PROJECTS; _group_label = false; hh = ui(8); yy = _y + hh; var mth = ui(24); var mtx = ui(4); var mty = yy; for (var i = 0, n = array_length(STEAM_TAGS); i < n; i++) { var tg = STEAM_TAGS[i]; var _sel = array_exists(meta_filter, tg); draw_set_text(f_p2, fa_left, fa_center, _sel? COLORS._main_text : COLORS._main_text_sub); var mtw = string_width(tg) + ui(16); var _hov = sHOVER && point_in_rectangle(_m[0], _m[1], mtx, mty, mtx + mtw, mty + mth); BLEND_OVERRIDE draw_sprite_stretched_ext(THEME.s_box_r5_clr, _hov, mtx, mty, mtw, mth, _sel? c_white : COLORS._main_icon, 1); BLEND_NORMAL if(_hov) { sp_sample.hover_content = true; if(mouse_press(mb_left)) { if(_sel) array_remove(meta_filter, tg); else array_push(meta_filter, tg); } } draw_text(mtx + ui(8), mty + mth / 2, tg); mtx += mtw + ui(4); } hh += mth + ui(8); yy += mth + ui(8); break; } var grid_width = ui(104); var grid_heigh = txt == "Workshop"? grid_width : grid_width * 0.75; var grid_space = grid_width / 8; var grid_line = ui(4); var node_count = ds_list_size(list); var col = floor(ww / (grid_width + grid_space)); var row = ceil(node_count / col); var xx = grid_space; var name_height = 0; grid_space = (ww - col * grid_width) / (col + 1); var group_labels = []; var _curr_tag = ""; var _cur_col = 0; var _nx, _boxx; var _meta; for(var i = 0; i < node_count; i++) { var _project = list[| i]; if(_group_label) { if(_curr_tag != _project.tag) { if(name_height) { var hght = grid_heigh + name_height + grid_line; hh += hght; yy += hght; } array_push(group_labels, { y: yy, text: _project.tag }); hh += ui(24 + 6); yy += ui(24 + 6); if(!array_exists(PREFERENCES.welcome_file_closed, _project.tag)) { hh += ui(6); yy += ui(6); } _nx = xx; _curr_tag = _project.tag; _cur_col = 0; name_height = 0; } if(array_exists(PREFERENCES.welcome_file_closed, _project.tag)) continue; } if(txt == "Workshop" && !array_empty(meta_filter)) { var _meta = _project.getMetadata(); if(array_empty(array_intersection(_meta.tags, meta_filter))) continue; } _nx = xx + (grid_width + grid_space) * _cur_col; _boxx = _nx; if(yy > -grid_heigh && yy < sp_sample.surface_h) { draw_sprite_stretched(THEME.node_bg, 0, _boxx, yy, grid_width, grid_heigh); if(sHOVER && sp_sample.hover && point_in_rectangle(_m[0], _m[1], _nx, yy, _nx + grid_width, yy + grid_heigh)) { sp_sample.hover_content = true; if(txt == "Workshop") { _meta = _project.getMetadata(); TOOLTIP = _meta; } draw_sprite_stretched_ext(THEME.node_bg, 1, _boxx, yy, grid_width, grid_heigh, COLORS._main_accent, 1); if(mouse_press(mb_left, sFOCUS)) { LOAD_PATH(_project.path, true); PROJECT.thumbnail = array_safe_get_fast(_project.spr_path, 0); instance_destroy(); } } var spr = _project.getSpr(); if(spr) { var gw = grid_width - ui(4); var gh = grid_heigh - ui(4); // print($"{gw}, {gh}"); var sw = sprite_get_width(spr); var sh = sprite_get_height(spr); var s = min(gw / sw, gh / sh); if(abs(s - 1) < 0.1) s = 1; var ox = (sprite_get_xoffset(spr) - sw / 2) * s; var oy = (sprite_get_yoffset(spr) - sh / 2) * s; var _sx = _boxx + grid_width / 2 + ox; var _sy = yy + grid_heigh / 2 + oy; var _spw = sw * s; var _sph = sh * s; if(txt == "Workshop") { clip_surf = surface_verify(clip_surf, _spw, _sph); surface_set_target(clip_surf); DRAW_CLEAR draw_sprite_uniform(spr, 0, 0, 0, s); gpu_set_blendmode_ext(bm_dest_colour, bm_zero); draw_sprite_stretched(THEME.ui_panel_bg, 4, 0, 0, _spw, _sph); BLEND_NORMAL surface_reset_target(); draw_surface(clip_surf, _sx, _sy); } else { draw_sprite_uniform(spr, 0, _sx, _sy, s); } } } var tx = _boxx + grid_width / 2; var ty = yy + grid_heigh + ui(4); var _name = _project.name; if(string_digits(string_char_at(_name, 1)) != "") _name = string_copy(_name, string_pos(" ", _name), string_length(_name) - string_pos(" ", _name) + 1); draw_set_text(f_p2, fa_center, fa_top, COLORS._main_text); name_height = max(name_height, string_height_ext(_name, -1, grid_width) + ui(8)); draw_text_ext_add(tx, ty - ui(2), _name, -1, grid_width); if(++_cur_col >= col) { if(name_height) { var hght = grid_heigh + name_height + grid_line; hh += hght; yy += hght; } name_height = 0; _cur_col = 0; } } if(name_height) { var hght = grid_heigh + name_height + grid_line; hh += hght; yy += hght; } if(_group_label) { var len = array_length(group_labels); if(len) { gpu_set_blendmode(bm_subtract); draw_set_color(c_white); draw_rectangle(0, 0, ww, ui(36), false); gpu_set_blendmode(bm_normal); } var pd = grid_space / 2; for( var i = 0; i < len; i++ ) { var lb = group_labels[i]; var _yy = max(lb.y, i == len - 1? ui(8) : min(ui(8), group_labels[i + 1].y - ui(32))); var _hov = sHOVER && point_in_rectangle(_m[0], _m[1], pd, _yy, pd + ww, _yy + ui(24)); BLEND_OVERRIDE draw_sprite_stretched_ext(THEME.s_box_r5_clr, _hov, pd, _yy, ww - pd * 2, ui(24), c_white, 0.3 + _hov * 0.2); BLEND_NORMAL var _coll = array_exists(PREFERENCES.welcome_file_closed, lb.text); draw_sprite_ui(THEME.arrow, _coll? 0 : 3, pd + ui(16), _yy + ui(12), 1, 1, 0, CDEF.main_ltgrey, 1); if(_hov) { sp_sample.hover_content = true; if(mouse_press(mb_left)) { if(_coll) array_remove(PREFERENCES.welcome_file_closed, lb.text); else array_push(PREFERENCES.welcome_file_closed, lb.text); } } draw_set_text(f_p2, fa_left, fa_center, CDEF.main_ltgrey); draw_text_add(pd + ui(32), _yy + ui(12), string_titlecase(lb.text)); if(lb.text == "Sample Projects") { draw_set_text(f_p2, fa_right, fa_center, CDEF.main_grey); draw_text_add(pd + ww - ui(20), _yy + ui(12), __txt("Art by Kenney")); } } } return hh + ui(20); }); #endregion #endregion #region contest discord_map = ds_map_create(); discord_map[? "Authorization"] = "Bot " + get_discord_bot_token(); contest_req = noone; contest_message_req = []; if(os_is_network_connected()) { var url = "https://discord.com/api/v10/guilds/953634069646835773/threads/active"; contest_req = http_request(url, "GET", discord_map, ""); } nicknames = ds_map_create(); attachment = ds_map_create(); contests = []; grid_surface = surface_create(1, 1); banner = noone; banner_alpha = 0; contest_viewing = noone; sp_contest = new scrollPane(x1 - x0 - ui(12), y1 - y0 - 2, function(_y, _m) { draw_clear_alpha(COLORS.panel_bg_clear, 0); var hh = 0; if(contest_viewing == noone) { var amo = array_length(contests); var bx = sp_contest.surface_w / 2; var sy = ui(16); var spr_w = sprite_get_width(s_contest_banner); var spr_h = sprite_get_height(s_contest_banner); var ss = (sp_contest.surface_w - 40) / spr_w; draw_sprite_ext(s_contest_banner, 0, bx, _y + sy, ss, ss, 0, c_white, 1); spr_w *= ss; spr_h *= ss; if(sHOVER && sp_contest.hover && point_in_rectangle(_m[0], _m[1], bx - spr_w / 2, _y + sy, bx + spr_w / 2, _y + sy + spr_h)) { sp_contest.hover_content = true; TOOLTIP = "Go to Pixel Composer Discord server"; if(mouse_press(mb_left, sFOCUS)) url_open("https://discord.gg/aHGbYjQh63"); } sy += spr_h - ui(4); var tx, ty, _col, _row; var grid_heigh = ui(128); var grid_width = ui(276); var grid_space = ui(20); var grid_hspac = ui(40); var col = floor(sp_contest.surface_w / (grid_width + grid_space)); grid_surface = surface_verify(grid_surface, grid_width, grid_heigh); for( var i = 0; i < amo; i++ ) { var contest = contests[i]; _col = i % col; _row = floor(i / col); tx = grid_space + (grid_width + grid_space) * _col; ty = sy + grid_space + (grid_heigh + grid_hspac + grid_space) * _row; hh = max(hh, ty + grid_heigh + grid_hspac + grid_space + ui(32)); ty = _y + ty; draw_sprite_stretched(THEME.node_bg, 0, tx, ty, grid_width, grid_heigh); var att = contest.title.attachments; if(att != noone) { var attSurf = attachment[? att.id]; if(!is_array(attSurf) && sprite_exists(attSurf)) { var _sw = sprite_get_width(attSurf); var _sh = sprite_get_height(attSurf); var ss = max(grid_width / _sw, grid_heigh / _sh); surface_set_target(grid_surface); DRAW_CLEAR draw_sprite_stretched(THEME.node_bg, 0, 0, 0, grid_width, grid_heigh); gpu_set_colorwriteenable(1, 1, 1, 0); draw_sprite_ext(attSurf, 0, grid_width / 2, grid_heigh / 2, ss, ss, 0, c_white, 1); gpu_set_colorwriteenable(1, 1, 1, 1); surface_reset_target(); draw_surface_ext_safe(grid_surface, tx, ty, 1, 1, 0, c_white, 0.85); } } if(sHOVER && sp_contest.hover && point_in_rectangle(_m[0], _m[1], tx, ty, tx + grid_width, ty + grid_heigh)) { sp_contest.hover_content = true; draw_sprite_stretched_ext(THEME.node_bg, 1, tx, ty, grid_width, grid_heigh, COLORS._main_accent, 1); if(mouse_press(mb_left, sFOCUS)) contest_viewing = contest; } else draw_sprite_stretched_ext(THEME.node_bg, 1, tx, ty, grid_width, grid_heigh, COLORS._main_icon, 0.75); //draw_set_text(f_h5, fa_left, fa_top, COLORS._main_text); //draw_text_ext_add(tx + ui(12), ty + ui(8), contest.name, -1, grid_width - ui(24)); var ch_x = tx + grid_width - ui(8); var ch_y = ty + grid_heigh + ui(4); draw_set_text(f_p0b, fa_left, fa_top, COLORS._main_text); draw_text_ext_add(tx + ui(8), ch_y, contest.name, -1, grid_width - ui(8)); var nm_h = string_height_ext(contest.name, -1, grid_width - ui(8)); draw_set_text(f_p2, fa_right, fa_top, COLORS._main_text); draw_text_add(ch_x, ch_y, contest.message_count); var _w = string_width(contest.message_count); draw_sprite_ui(THEME.chat, 0, ch_x - _w - ui(16), ch_y + ui(12), 0.75, 0.75,, COLORS._main_icon); var auth_msg = contest.title; var auth_nam = ds_map_try_get(nicknames, auth_msg.author.id, auth_msg.author.username); draw_set_text(f_p2, fa_left, fa_top, COLORS._main_text_sub); draw_text_add(tx + ui(8), ch_y + nm_h - ui(0), auth_nam); if(!struct_has(contest.title.meta, "theme")) continue; var _thm = __txt("Theme") + ": "; var txt = _thm + contest.title.meta.theme; draw_set_text(f_p1, fa_left, fa_bottom, COLORS._main_text); var ww = string_width(txt); var thx = tx + grid_width - ui(12) - ww; var thy = ty + grid_heigh - ui(8); draw_set_color(COLORS._main_text_sub); draw_text_ext_add(thx, thy, _thm, -1, grid_width - ui(12 + 8)); draw_set_color(COLORS._main_text); draw_text_ext_add(thx + string_width(_thm), thy, contest.title.meta.theme, -1, grid_width - ui(12 + 8)); } } else { var con_name = contest_viewing.name; var con_title = contest_viewing.title; var con_author = ds_map_try_get(nicknames, con_title.author.id, con_title.author.username); var con_thumb = con_title.attachments; if(con_thumb != noone) con_thumb = attachment[? con_thumb.id]; var tx = ui(8); var ty = _y + ui(68); hh = ui(68); var tw = sp_contest.surface_w - ui(16); var th = 0; var pad = ui(12); draw_set_text(f_p0, fa_left, fa_top, COLORS._main_text); th = string_height_ext(con_title.content, -1, tw - pad * 2) + pad * 2; if(sprite_exists(con_thumb)) { var spr_w = sprite_get_width(con_thumb); var spr_h = sprite_get_height(con_thumb); ss = (tw - pad * 2) / spr_w; spr_w *= ss; spr_h *= ss; th += pad + spr_h; } var txt_y = ty + pad; draw_sprite_stretched_ext(THEME.node_bg, 0, tx, ty, tw, th, c_white, 0.8); draw_text_ext_add(tx + pad, txt_y, con_title.content, -1, tw - pad * 2); txt_y += string_height_ext(con_title.content, -1, tw - pad * 2) + pad; if(sprite_exists(con_thumb)) draw_sprite_ext(con_thumb, 0, sp_contest.surface_w / 2, txt_y + spr_h / 2, ss, ss, 0, c_white, 1); hh += th + pad; var submissions = contest_viewing.messages; var amo = 0, col = 0; var grid_space = ui(20); var grid_width = (sp_contest.surface_w - grid_space - ui(16)) / 2; var _yy = txt_y + spr_h + pad * 2; var cx = sp_contest.surface_w / 2; draw_set_text(f_p1, fa_center, fa_center, COLORS._main_text_sub); draw_text(cx, _yy + ui(8), __txt("Submissions")); var txt_w = string_width(__txt("Submissions")); draw_line(cx - txt_w / 2 - ui(8), _yy + ui(8), cx - ui(200), _yy + ui(8)); draw_line(cx + txt_w / 2 + ui(8), _yy + ui(8), cx + ui(200), _yy + ui(8)); _yy += ui(32); var grid_ys = [ _yy, _yy ]; for( var i = 0, n = array_length(submissions) - 1; i < n; i++ ) { var _sub = submissions[i]; var _att = _sub.attachments; if(array_length(_att) == 0) continue; amo++; var _att_first = _att[0]; if(!ds_map_exists(attachment, _att_first.id)) { var path = TEMPDIR + _att_first.id + ".png"; attachment[? _att_first.id] = [ http_get_file(_att_first.url, path), path ]; } else if(!is_array(attachment[? _att_first.id]) && sprite_exists(attachment[? _att_first.id])) { var sub = attachment[? _att_first.id]; var spr_w = sprite_get_width(sub); var spr_h = sprite_get_height(sub); var ss = (grid_width - ui(16)) / spr_w; if(ss > 1) ss = floor(ss); spr_w *= ss; spr_h *= ss; var _col = grid_ys[0] > grid_ys[1]; var grid_x = ui(8) + (grid_width + grid_space) * _col; var grid_y = grid_ys[_col]; var grid_h = spr_h + ui(8) * 2; draw_sprite_stretched_ext(THEME.node_bg, 0, grid_x, grid_y, grid_width, grid_h, c_white, 0.8); draw_sprite_ext(sub, 0, grid_x + grid_width / 2, grid_y + grid_h / 2, ss, ss, 0, c_white, 1); var label_h = ui(32); var sub_author = ds_map_try_get(nicknames, _sub.author.id, _sub.author.username); draw_set_text(f_p1, fa_left, fa_top, COLORS._main_text); draw_text_add(grid_x + ui(8), grid_y + grid_h + ui(4), sub_author); var react = _sub.reactions; var hearts = 0; for( var j = 0; j < array_length(react); j++ ) { if(react[i].emoji.name != "💖") return; hearts = react[i].count_details.normal; } var ch_x = grid_x + grid_width - ui(8); var ch_y = grid_y + grid_h + ui(4); draw_set_text(f_p2, fa_right, fa_top, COLORS._main_text); draw_text_add(ch_x, ch_y, hearts); var _w = string_width(hearts); draw_sprite_ui(THEME.heart, 0, ch_x - _w - ui(16), ch_y + ui(10),,,, COLORS._main_icon_light); grid_ys[_col] += grid_h + label_h + ui(8); } } hh = max(grid_ys[0] - _y, grid_ys[1] - _y); //banner banner_alpha = lerp_float(banner_alpha, _y < 0, 3); draw_sprite_stretched_ext(THEME.shadow_drop_down_24, 0, 0, ui(56), sp_contest.surface_w, ui(20), c_white, banner_alpha); draw_set_color(COLORS.panel_bg_clear); draw_rectangle(0, 0, sp_contest.surface_w, ui(64), false); draw_set_text(f_h5, fa_left, fa_top, COLORS._main_text); draw_text_add(ui(32 + 8), ui(8 + 4), con_name); draw_set_text(f_p2, fa_left, fa_top, COLORS._main_text_sub); draw_text_add(ui(32 + 8), ui(8 + 30), __txt("By") + " " + con_author); draw_set_text(f_p0b, fa_right, fa_top, COLORS._main_text_accent); draw_text_add(sp_contest.surface_w - ui(44), ui(8 + 8), amo); draw_set_text(f_p2, fa_right, fa_top, COLORS._main_text_sub); draw_text_add(sp_contest.surface_w - ui(44), ui(8 + 28), __txt("Submissions")); if(sHOVER && sp_contest.hover && point_in_rectangle(_m[0], _m[1], ui(20 - 16), ui(36 - 16), ui(20 + 16), ui(36 + 16))) { sp_contest.hover_content = true; draw_sprite_ui(THEME.arrow_back_32, 0, ui(20), ui(36),,,, c_white); if(mouse_press(mb_left, sFOCUS)) contest_viewing = noone; } else draw_sprite_ui(THEME.arrow_back_32, 0, ui(20), ui(36),,,, COLORS._main_icon); var bx = sp_contest.surface_w - ui(20); var by = ui(36); if(sHOVER && sp_contest.hover && point_in_rectangle(_m[0], _m[1], bx - ui(16), by - ui(16), bx + ui(16), by + ui(16))) { sp_contest.hover_content = true; TOOLTIP = __txtx("contest_open_discord", "Open in Discord"); draw_sprite_ui(THEME.discord, 0, bx, by,,,, c_white); if(mouse_press(mb_left, sFOCUS)) url_open($"https://discord.com/channels/953634069646835773/{contest_viewing.id}"); } else draw_sprite_ui(THEME.discord, 0, bx, by,,,, COLORS._main_icon); } return hh; }); #endregion