Greasy Fork is available in English.

Old Roblox UWP UI (for website)

Mimics the old Windows 10 Roblox (Microsoft Store) UI, back when Roblox was better.

  1. // ==UserScript==
  2. // @name Old Roblox UWP UI (for website)
  3. // @namespace http://tampermonkey.net/
  4. // @version 1
  5. // @description Mimics the old Windows 10 Roblox (Microsoft Store) UI, back when Roblox was better.
  6. // @author NotRoblox
  7. // @match https://*.roblox.com/*
  8. // @grant GM_getValue
  9. // @grant GM_setValue
  10. // @grant GM_registerMenuCommand
  11. // @license MIT
  12. // @run-at document-start
  13. // ==/UserScript==
  14.  
  15. (function() {
  16. 'use strict';
  17.  
  18. const originalOpen = window.open;
  19. window.open = function(url, target, features) {
  20. if (target === '_blank') {
  21. window.location.href = url;
  22. } else {
  23. return originalOpen.apply(this, arguments);
  24. }
  25. };
  26.  
  27. let activeUserId = GM_getValue('cachedUserId', null);
  28. let isFetchingUserId = false;
  29.  
  30. async function getCurrentUserId() {
  31. isFetchingUserId = true;
  32. try {
  33. const response = await fetch('https://users.roblox.com/v1/users/authenticated', {
  34. credentials: 'include',
  35. headers: {
  36. 'Accept': 'application/json',
  37. 'X-CSRF-TOKEN': document.querySelector('meta[name="csrf-token"]')?.getAttribute('content')
  38. }
  39. });
  40. if (response.ok) {
  41. const data = await response.json();
  42. if (data && data.id) {
  43. if (data.id !== activeUserId) {
  44. activeUserId = data.id;
  45. GM_setValue('cachedUserId', activeUserId);
  46. }
  47. }
  48. } else {
  49. console.error('Unauthorized or error fetching user ID');
  50. }
  51. } catch (error) {
  52. console.error('Error fetching user ID:', error);
  53. } finally {
  54. isFetchingUserId = false;
  55. }
  56. return activeUserId;
  57. }
  58. const colors = {
  59. green: {
  60. topbar: 'rgba(3, 182, 87, 1)',
  61. searchBarBg: 'rgb(103, 213, 152)',
  62. searchBarBorder: 'rgb(59, 150, 95)',
  63. sidebarHighlight: 'rgba(128, 128, 128, 1)'
  64. },
  65. blue: {
  66. topbar: 'rgb(0, 102, 199)',
  67. searchBarBg: 'rgb(86, 163, 216)',
  68. searchBarBorder: 'rgb(22, 130, 208)',
  69. sidebarHighlight: 'rgba(0, 102, 199, 1)'
  70. }
  71. };
  72.  
  73. let useBlueTheme = GM_getValue('useBlueTheme', false);
  74. let iconsOnRight = GM_getValue('iconsOnRight', false);
  75. let studioButtonEnabled = GM_getValue('studioButtonEnabled', false);
  76.  
  77. GM_registerMenuCommand('Toggle Blue Theme', () => {
  78. useBlueTheme = !useBlueTheme;
  79. GM_setValue('useBlueTheme', useBlueTheme);
  80. location.reload();
  81. });
  82.  
  83. GM_registerMenuCommand('Toggle Icons Position', () => {
  84. iconsOnRight = !iconsOnRight;
  85. GM_setValue('iconsOnRight', iconsOnRight);
  86. location.reload();
  87. });
  88.  
  89. GM_registerMenuCommand('Toggle Studio Button', () => {
  90. studioButtonEnabled = !studioButtonEnabled;
  91. GM_setValue('studioButtonEnabled', studioButtonEnabled);
  92. location.reload();
  93. });
  94.  
  95.  
  96. function tryInit() {
  97. if (document.body) {
  98. init();
  99. } else {
  100. setTimeout(tryInit, 10);
  101. }
  102. }
  103.  
  104. tryInit();
  105.  
  106. document.addEventListener('DOMContentLoaded', function() {
  107. if (!document.body.querySelector('.sidebar-custom')) {
  108. init();
  109. }
  110. });
  111.  
  112. function init() {
  113. if (document.querySelector('.sidebar-custom')) return;
  114. if (window.top !== window.self) return;
  115.  
  116. getCurrentUserId().then(userId => {
  117. if (userId) {
  118. activeUserId = userId;
  119. buttonLinks['Inventory'] = `https://www.roblox.com/users/${activeUserId}/inventory`;
  120. buttonLinks['Profile'] = `https://www.roblox.com/users/${activeUserId}/profile`;
  121.  
  122. const currentUrl = window.location.href;
  123. const inventoryButton = document.querySelector('.sidebar-custom .inventory-button');
  124. if (inventoryButton && currentUrl.includes(`/users/${activeUserId}/inventory`)) {
  125. inventoryButton.classList.add('active');
  126. }
  127.  
  128. const profileButton = document.querySelector('.sidebar-custom .profile-button');
  129. if (profileButton && currentUrl.includes(`/users/${activeUserId}/profile`)) {
  130. profileButton.classList.add('active');
  131. }
  132. } else {
  133. console.error('Failed to retrieve user ID');
  134. }
  135. });
  136. function hideElements() {
  137. const header = document.getElementById('header');
  138. const leftNav = document.getElementById('left-navigation-container');
  139. if (header) header.style.display = 'none';
  140. if (leftNav) leftNav.style.display = 'none';
  141.  
  142. if (!window.location.pathname.includes('/inventory') && !window.location.pathname.includes('/transactions') && !window.location.pathname.includes('/catalog') && !window.location.pathname.includes('/games')) {
  143. const style = document.createElement('style');
  144. style.textContent = `
  145. @media (min-width: 1688px) {
  146. .no-gutter-ads.logged-in .content {
  147. margin-left: 0px !important; /* Ensure margin-left is 0px */
  148. display: flex; /* Center the content */
  149. justify-content: center; /* Center horizontally */
  150. align-items: center; /* Center vertically */
  151. }
  152. .no-gutter-ads.logged-in .content.six-column {
  153. width: 1104px; /* Maintain the specified width */
  154. display: flex; /* Center the content */
  155. justify-content: center; /* Center horizontally */
  156. align-items: center; /* Center vertically */
  157. }
  158. /* Only apply these styles if not on the /users/friends page */
  159. ${window.location.pathname !== '/users/friends' ? `
  160. .container-main.in-app .page-content,
  161. .container-main.content-no-ads .page-content {
  162. margin: 0;
  163. width: 100%; /* Maintain full width */
  164. display: flex; /* Center the content */
  165. justify-content: center; /* Center horizontally */
  166. }
  167. ` : ''}
  168. .content {
  169. max-width: 1338px; /* Maintain the specified max-width */
  170. background-color: #e6e7ea; /* Maintain background color */
  171. padding-top: 24px; /* Maintain padding */
  172. margin: 0 auto; /* Center the content */
  173. display: flex; /* Center the content */
  174. justify-content: center; /* Center horizontally */
  175. align-items: center; /* Center vertically */
  176. }
  177. }
  178. `;
  179. document.head.appendChild(style);
  180. }
  181. }
  182.  
  183. const universalStyle = document.createElement('style');
  184. if (!window.location.pathname.includes('/games')) {
  185. universalStyle.textContent = `
  186. @media (min-width: 1688px) {
  187. .no-gutter-ads.logged-in .content {
  188. margin-left: 0px !important; /* Ensure margin-left is 0px */
  189. }
  190. .container-main.in-app .page-content,
  191. .container-main.content-no-ads .page-content {
  192. margin: 0;
  193. }
  194. .content {
  195. padding-top: 24px; /* Maintain padding */
  196. }
  197. }
  198. `;
  199. }
  200. document.head.appendChild(universalStyle);
  201. hideElements();
  202.  
  203. const observer = new MutationObserver(() => {
  204. hideElements();
  205. });
  206.  
  207. observer.observe(document.body, { childList: true, subtree: true });
  208.  
  209. const buttonImages = {
  210. 'Home': {
  211. default: '',
  212. hover: ''
  213. },
  214. 'Games': {
  215. default: '',
  216. hover: ''
  217. },
  218. 'Friends': {
  219. default: '',
  220. hover: ''
  221. },
  222. 'Catalog': {
  223. default: '',
  224. hover: ''
  225. },
  226. 'Messages': {
  227. default: '',
  228. hover: ''
  229. },
  230. 'Profile': {
  231. default: '',
  232. hover: ''
  233. },
  234. 'Character': {
  235. default: '',
  236. hover: ''
  237. },
  238. 'Inventory': {
  239. default: '',
  240. hover: ''
  241. },
  242. 'Trade': {
  243. default: '',
  244. hover: ''
  245. },
  246. 'Groups': {
  247. default: '',
  248. hover: ''
  249. },
  250. 'Forum': {
  251. default: '',
  252. hover: ''
  253. }
  254. };
  255.  
  256. const searchImages = {
  257. 'Users': {
  258. default: '',
  259. hover: ''
  260. },
  261. 'Experiences': {
  262. default: '',
  263. hover: ''
  264. },
  265. 'Communities': {
  266. default: '',
  267. hover: ''
  268. }
  269. };
  270.  
  271.  
  272. const topbarImages = {
  273. 'Robux': {
  274. default: '',
  275. hover: ''
  276. },
  277. 'Premium': {
  278. default: '',
  279. hover: ''
  280. },
  281. 'Settings': {
  282. default: '',
  283. hover: ''
  284. }
  285. };
  286. const currentPage = window.location.href.toLowerCase();
  287.  
  288. const sidebar = document.createElement('div');
  289. sidebar.className = 'sidebar-custom';
  290. Object.assign(sidebar.style, {
  291. position: 'fixed',
  292. left: '0',
  293. top: '0',
  294. bottom: '0',
  295. width: '62px',
  296. backgroundColor: 'rgba(45, 45, 45, 1)',
  297. display: 'flex',
  298. flexDirection: 'column',
  299. alignItems: 'center',
  300. overflowY: 'auto',
  301. overflowX: 'hidden',
  302. zIndex: '999999'
  303. });
  304.  
  305. const style = document.createElement('style');
  306. style.textContent = `
  307. .sidebar-custom::-webkit-scrollbar {
  308. width: 6px;
  309. }
  310. .sidebar-custom::-webkit-scrollbar-track {
  311. background: transparent;
  312. }
  313. .sidebar-custom::-webkit-scrollbar-thumb {
  314. background: #888;
  315. border-radius: 3px;
  316. }
  317. .sidebar-custom::-webkit-scrollbar-thumb:hover {
  318. background: #555;
  319. }
  320. `;
  321. document.head.appendChild(style);
  322.  
  323. const buttonLinks = {
  324. 'Home': 'https://www.roblox.com/home',
  325. 'Games': 'https://www.roblox.com/charts',
  326. 'Friends': 'https://www.roblox.com/users/friends',
  327. 'Catalog': 'https://www.roblox.com/catalog',
  328. 'Messages': 'https://www.roblox.com/my/messages',
  329. 'Profile': 'https://www.roblox.com/users/profile',
  330. 'Character': 'https://www.roblox.com/my/avatar',
  331. 'Inventory': `https://www.roblox.com/users/${activeUserId}/inventory`,
  332. 'Trade': 'https://www.roblox.com/trades',
  333. 'Groups': 'https://www.roblox.com/groups',
  334. 'Forum': 'https://devforum.roblox.com/'
  335. };
  336.  
  337. Object.keys(buttonLinks).forEach((buttonName) => {
  338. const button = document.createElement('button');
  339. button.style.width = '100%';
  340. button.style.height = '56px';
  341. button.style.color = 'white';
  342. button.style.backgroundColor = 'transparent';
  343. button.style.border = 'none';
  344. button.style.textAlign = 'center';
  345. button.style.cursor = 'pointer';
  346. button.style.fontSize = '10px';
  347. button.style.position = 'relative';
  348. button.style.display = 'flex';
  349. button.style.flexDirection = 'column';
  350. button.style.alignItems = 'center';
  351. button.style.justifyContent = 'center';
  352.  
  353. const buttonImage = document.createElement('img');
  354. buttonImage.src = buttonImages[buttonName].default;
  355. buttonImage.style.width = '26px';
  356. buttonImage.style.height = '26px';
  357.  
  358. button.addEventListener('mouseover', () => buttonImage.src = buttonImages[buttonName].hover);
  359. button.addEventListener('mouseout', () => buttonImage.src = buttonImages[buttonName].default);
  360.  
  361. button.appendChild(buttonImage);
  362.  
  363. const buttonText = document.createElement('div');
  364. buttonText.innerText = buttonName;
  365. buttonText.style.fontSize = '10px';
  366. buttonText.style.marginTop = '4px';
  367. button.appendChild(buttonText);
  368.  
  369. if (currentPage.includes(buttonLinks[buttonName].toLowerCase()) || (buttonName === 'Profile' && currentPage.includes(`/users/${activeUserId}/profile`))) {
  370. button.style.backgroundColor = useBlueTheme ? colors.blue.sidebarHighlight : colors.green.sidebarHighlight;
  371. }
  372.  
  373. button.addEventListener('click', () => window.location.href = buttonLinks[buttonName]);
  374.  
  375. sidebar.appendChild(button);
  376. });
  377.  
  378. const topbar = document.createElement('div');
  379. topbar.className = 'topbar-custom';
  380. topbar.style.position = 'fixed';
  381. topbar.style.left = '62px';
  382. topbar.style.top = '0';
  383. topbar.style.width = 'calc(100% - 62px)';
  384. topbar.style.height = '48px';
  385. topbar.style.backgroundColor = useBlueTheme ? colors.blue.topbar : colors.green.topbar;
  386. topbar.style.zIndex = '999998';
  387. topbar.style.display = 'flex';
  388. topbar.style.alignItems = 'center';
  389. topbar.style.justifyContent = 'flex-end';
  390. topbar.style.paddingRight = '6px';
  391.  
  392. const searchContainer = document.createElement('div');
  393. searchContainer.style.position = 'relative';
  394. searchContainer.style.width = '256px';
  395. searchContainer.style.height = '32px';
  396. searchContainer.style.marginRight = '8px';
  397. searchContainer.style.marginLeft = '8px';
  398.  
  399. const searchInput = document.createElement('input');
  400. searchInput.type = 'text';
  401. searchInput.placeholder = 'Search';
  402. searchInput.style.width = '100%';
  403. searchInput.style.height = '100%';
  404. searchInput.style.backgroundColor = useBlueTheme ? colors.blue.searchBarBg : colors.green.searchBarBg;
  405. searchInput.style.border = `2px solid ${useBlueTheme ? colors.blue.searchBarBorder : colors.green.searchBarBorder}`;
  406. searchInput.style.borderRadius = '0';
  407. searchInput.style.padding = '0 80px 0 8px';
  408. searchInput.style.color = 'black';
  409. searchInput.style.fontSize = '14px';
  410. searchInput.style.outline = 'none';
  411. searchInput.style.boxSizing = 'border-box';
  412. searchInput.style.setProperty('::placeholder', 'color: rgba(59, 150, 95, 1)');
  413.  
  414. const premiumButton = document.createElement('button');
  415. premiumButton.style.width = '32px';
  416. premiumButton.style.height = '32px';
  417. premiumButton.style.padding = '0';
  418. premiumButton.style.border = 'none';
  419. premiumButton.style.backgroundColor = 'transparent';
  420. premiumButton.style.cursor = 'pointer';
  421. premiumButton.style.marginRight = '8px';
  422. premiumButton.style.marginLeft = '8px';
  423.  
  424. const premiumImg = document.createElement('img');
  425. premiumImg.src = topbarImages.Premium.default;
  426. premiumImg.style.width = '32px';
  427. premiumImg.style.height = '32px';
  428. premiumButton.appendChild(premiumImg);
  429.  
  430. premiumButton.addEventListener('mouseover', () => premiumImg.src = topbarImages.Premium.hover);
  431. premiumButton.addEventListener('mouseout', () => premiumImg.src = topbarImages.Premium.default);
  432. premiumButton.addEventListener('click', () => window.location.href = 'https://www.roblox.com/premium/membership');
  433.  
  434. const robuxButton = document.createElement('button');
  435. robuxButton.style.width = '32px';
  436. robuxButton.style.height = '32px';
  437. robuxButton.style.padding = '0';
  438. robuxButton.style.border = 'none';
  439. robuxButton.style.backgroundColor = 'transparent';
  440. robuxButton.style.cursor = 'pointer';
  441. robuxButton.style.marginRight = '8px';
  442. robuxButton.style.marginLeft = '8px';
  443. robuxButton.style.position = 'relative';
  444.  
  445. const robuxImg = document.createElement('img');
  446. robuxImg.src = topbarImages.Robux.default;
  447. robuxImg.style.width = '32px';
  448. robuxImg.style.height = '32px';
  449. robuxButton.appendChild(robuxImg);
  450.  
  451. async function getRobuxBalance() {
  452. try {
  453. const response = await fetch('https://economy.roblox.com/v1/user/currency', {
  454. credentials: 'include',
  455. headers: {
  456. 'Accept': 'application/json',
  457. 'X-CSRF-TOKEN': document.querySelector('meta[name="csrf-token"]')?.getAttribute('content')
  458. }
  459. });
  460. if (response.ok) {
  461. const data = await response.json();
  462. return data.robux;
  463. }
  464. return 0;
  465. } catch (error) {
  466. return 0;
  467. }
  468. }
  469.  
  470. const robuxDropdown = document.createElement('div');
  471. robuxDropdown.style.position = 'absolute';
  472. robuxDropdown.style.top = '100%';
  473. robuxDropdown.style.left = '0';
  474. robuxDropdown.style.backgroundColor = 'white';
  475. robuxDropdown.style.border = '1px solid #ddd';
  476. robuxDropdown.style.borderRadius = '4px';
  477. robuxDropdown.style.display = 'none';
  478. robuxDropdown.style.zIndex = '999999';
  479. robuxDropdown.style.width = '120px';
  480. robuxDropdown.style.boxShadow = '0 2px 4px rgba(0,0,0,0.1)';
  481. robuxDropdown.style.overflow = 'hidden';
  482.  
  483. const robuxBalance = document.createElement('div');
  484. robuxBalance.style.padding = '8px';
  485. robuxBalance.style.borderBottom = '1px solid #ddd';
  486. robuxBalance.innerHTML = 'Loading...';
  487.  
  488. robuxBalance.addEventListener('click', () => {
  489. window.location.href = 'https://www.roblox.com/transactions';
  490. });
  491.  
  492. robuxBalance.addEventListener('mouseover', () => {
  493. robuxBalance.style.backgroundColor = 'rgb(242,242,242)';
  494. robuxBalance.style.borderLeft = '4px solid rgb(0,162,255)';
  495. robuxBalance.style.paddingLeft = '8px';
  496. });
  497.  
  498. robuxBalance.addEventListener('mouseout', () => {
  499. robuxBalance.style.backgroundColor = '';
  500. robuxBalance.style.borderLeft = '';
  501. robuxBalance.style.paddingLeft = '12px';
  502. });
  503.  
  504. getRobuxBalance().then(balance => {
  505. robuxBalance.innerHTML = `${balance.toLocaleString()} Robux`;
  506. });
  507.  
  508. const buyRobux = document.createElement('a');
  509. buyRobux.href = 'https://www.roblox.com/upgrades/robux';
  510. buyRobux.style.display = 'block';
  511. buyRobux.style.padding = '8px';
  512. buyRobux.style.textDecoration = 'none';
  513. buyRobux.style.color = 'black';
  514. buyRobux.innerHTML = 'Buy Robux';
  515.  
  516. buyRobux.addEventListener('mouseover', () => {
  517. buyRobux.style.backgroundColor = 'rgb(242,242,242)';
  518. buyRobux.style.borderLeft = '4px solid rgb(0,162,255)';
  519. buyRobux.style.paddingLeft = '8px';
  520. });
  521.  
  522. buyRobux.addEventListener('mouseout', () => {
  523. buyRobux.style.backgroundColor = '';
  524. buyRobux.style.borderLeft = '';
  525. buyRobux.style.paddingLeft = '12px';
  526. });
  527.  
  528. robuxButton.appendChild(robuxDropdown);
  529. robuxDropdown.appendChild(robuxBalance);
  530. robuxDropdown.appendChild(buyRobux);
  531.  
  532. robuxButton.addEventListener('mouseover', () => robuxImg.src = topbarImages.Robux.hover);
  533. robuxButton.addEventListener('mouseout', () => robuxImg.src = topbarImages.Robux.default);
  534.  
  535. robuxButton.addEventListener('click', (e) => {
  536. e.stopPropagation();
  537. robuxDropdown.style.display = robuxDropdown.style.display === 'none' ? 'block' : 'none';
  538. });
  539.  
  540. document.addEventListener('click', () => {
  541. robuxDropdown.style.display = 'none';
  542. });
  543.  
  544. const searchTypeContainer = document.createElement('div');
  545. searchTypeContainer.style.position = 'absolute';
  546. searchTypeContainer.style.right = '4px';
  547. searchTypeContainer.style.top = '50%';
  548. searchTypeContainer.style.transform = 'translateY(-50%)';
  549. searchTypeContainer.style.display = 'flex';
  550. searchTypeContainer.style.alignItems = 'center';
  551. searchTypeContainer.style.gap = '4px';
  552.  
  553. let currentType = 'Users';
  554. const types = ['Users', 'Experiences', 'Communities'];
  555.  
  556. types.forEach(type => {
  557. const button = document.createElement('button');
  558. button.style.width = '26px';
  559. button.style.height = '26px';
  560. button.style.padding = '0';
  561. button.style.border = 'none';
  562. button.style.backgroundColor = 'transparent';
  563. button.style.cursor = 'pointer';
  564. button.style.display = 'flex';
  565. button.style.alignItems = 'center';
  566. button.style.justifyContent = 'center';
  567. button.title = type;
  568.  
  569. const img = document.createElement('img');
  570. img.src = searchImages[type].default;
  571. img.style.width = '26px';
  572. img.style.height = '26px';
  573. img.style.opacity = type === currentType ? '1' : '0.5';
  574.  
  575. button.appendChild(img);
  576.  
  577. button.addEventListener('mouseover', () => img.src = searchImages[type].hover);
  578. button.addEventListener('mouseout', () => img.src = searchImages[type].default);
  579.  
  580.  
  581. button.addEventListener('click', () => {
  582. currentType = type;
  583. searchTypeContainer.querySelectorAll('img').forEach(image => {
  584. image.style.opacity = '0.5';
  585. });
  586. img.style.opacity = '1';
  587. });
  588.  
  589. searchTypeContainer.appendChild(button);
  590. });
  591.  
  592. searchInput.addEventListener('keypress', function(e) {
  593. if (e.key === 'Enter') {
  594. const query = searchInput.value;
  595. let searchUrl;
  596.  
  597. switch(currentType) {
  598. case 'Users':
  599. searchUrl = `https://www.roblox.com/search/users?keyword=${encodeURIComponent(query)}`;
  600. break;
  601. case 'Experiences':
  602. searchUrl = `https://www.roblox.com/discover?Keyword=${encodeURIComponent(query)}`;
  603. break;
  604. case 'Communities':
  605. searchUrl = `https://www.roblox.com/search/groups?keyword=${encodeURIComponent(query)}`;
  606. break;
  607. }
  608.  
  609. if (searchUrl) {
  610. window.location.href = searchUrl;
  611. }
  612. }
  613. });
  614.  
  615. const settingsButton = document.createElement('button');
  616. settingsButton.style.width = '32px';
  617. settingsButton.style.height = '32px';
  618. settingsButton.style.padding = '0';
  619. settingsButton.style.border = 'none';
  620. settingsButton.style.backgroundColor = 'transparent';
  621. settingsButton.style.cursor = 'pointer';
  622. settingsButton.style.marginLeft = '8px';
  623. settingsButton.style.marginRight = '4px';
  624.  
  625. const settingsImg = document.createElement('img');
  626. settingsImg.src = topbarImages.Settings.default;
  627. settingsImg.style.width = '32px';
  628. settingsImg.style.height = '32px';
  629. settingsButton.appendChild(settingsImg);
  630.  
  631. settingsButton.addEventListener('mouseover', () => settingsImg.src = topbarImages.Settings.hover);
  632. settingsButton.addEventListener('mouseout', () => settingsImg.src = topbarImages.Settings.default);
  633.  
  634. const settingsDropdown = document.createElement('div');
  635. settingsDropdown.style.position = 'absolute';
  636. settingsDropdown.style.top = '100%';
  637. settingsDropdown.style.right = '0';
  638. settingsDropdown.style.backgroundColor = 'white';
  639. settingsDropdown.style.border = '1px solid #ddd';
  640. settingsDropdown.style.borderRadius = '4px';
  641. settingsDropdown.style.display = 'none';
  642. settingsDropdown.style.zIndex = '999999';
  643. settingsDropdown.style.boxShadow = '0 2px 4px rgba(0,0,0,0.1)';
  644. settingsDropdown.style.overflow = 'hidden';
  645.  
  646. const settingsLink = document.createElement('a');
  647. settingsLink.href = 'https://www.roblox.com/my/account';
  648. settingsLink.innerHTML = 'Settings';
  649. settingsLink.style.display = 'block';
  650. settingsLink.style.padding = '8px';
  651. settingsLink.style.textDecoration = 'none';
  652. settingsLink.style.color = 'black';
  653. settingsLink.style.borderBottom = '1px solid #ddd';
  654.  
  655. const helpLink = document.createElement('a');
  656. helpLink.href = 'https://www.roblox.com/help-safety';
  657. helpLink.innerHTML = 'Help & Safety';
  658. helpLink.style.display = 'block';
  659. helpLink.style.padding = '8px';
  660. helpLink.style.textDecoration = 'none';
  661. helpLink.style.color = 'black';
  662. helpLink.style.borderBottom = '1px solid #ddd';
  663.  
  664. const logoutLink = document.createElement('a');
  665. logoutLink.innerHTML = 'Log Out';
  666. logoutLink.style.display = 'block';
  667. logoutLink.style.padding = '8px';
  668. logoutLink.style.textDecoration = 'none';
  669. logoutLink.style.color = 'black';
  670. logoutLink.addEventListener('click', () => {
  671. const robloxCookies = ['ROBLOSECURITY', 'other_cookie_name'];
  672. robloxCookies.forEach(cookieName => {
  673. document.cookie = `${cookieName}=;expires=${new Date(0).toUTCString()};path=/;domain=.roblox.com`;
  674. });
  675. location.reload();
  676. });
  677.  
  678. settingsButton.appendChild(settingsDropdown);
  679.  
  680. settingsLink.addEventListener('mouseover', () => {
  681. settingsLink.style.backgroundColor = 'rgb(242,242,242)';
  682. settingsLink.style.borderLeft = '4px solid rgb(0,162,255)';
  683. settingsLink.style.paddingLeft = '8px';
  684. });
  685.  
  686. settingsLink.addEventListener('mouseout', () => {
  687. settingsLink.style.backgroundColor = '';
  688. settingsLink.style.borderLeft = '';
  689. settingsLink.style.paddingLeft = '12px';
  690. });
  691.  
  692. helpLink.addEventListener('mouseover', () => {
  693. helpLink.style.backgroundColor = 'rgb(242,242,242)';
  694. helpLink.style.borderLeft = '4px solid rgb(0,162,255)';
  695. helpLink.style.paddingLeft = '8px';
  696. });
  697.  
  698. helpLink.addEventListener('mouseout', () => {
  699. helpLink.style.backgroundColor = '';
  700. helpLink.style.borderLeft = '';
  701. helpLink.style.paddingLeft = '12px';
  702. });
  703.  
  704. logoutLink.addEventListener('mouseover', () => {
  705. logoutLink.style.backgroundColor = 'rgb(242,242,242)';
  706. logoutLink.style.borderLeft = '4px solid rgb(0,162,255)';
  707. logoutLink.style.paddingLeft = '8px';
  708. });
  709.  
  710. logoutLink.addEventListener('mouseout', () => {
  711. logoutLink.style.backgroundColor = '';
  712. logoutLink.style.borderLeft = '';
  713. logoutLink.style.paddingLeft = '12px';
  714. });
  715.  
  716. settingsButton.addEventListener('click', (e) => {
  717. e.stopPropagation();
  718. settingsDropdown.style.display = settingsDropdown.style.display === 'none' ? 'block' : 'none';
  719. });
  720.  
  721. document.addEventListener('click', () => {
  722. settingsDropdown.style.display = 'none';
  723. });
  724.  
  725. settingsDropdown.appendChild(settingsLink);
  726. settingsDropdown.appendChild(helpLink);
  727. settingsDropdown.appendChild(logoutLink);
  728.  
  729. if (studioButtonEnabled) {
  730. const studioButtonImages = {
  731. default: '',
  732. hover: ''
  733. };
  734.  
  735. const studioButton = document.createElement('button');
  736. studioButton.style.width = '100%';
  737. studioButton.style.height = '56px';
  738. studioButton.style.color = 'white';
  739. studioButton.style.backgroundColor = 'transparent';
  740. studioButton.style.border = 'none';
  741. studioButton.style.textAlign = 'center';
  742. studioButton.style.cursor = 'pointer';
  743. studioButton.style.fontSize = '10px';
  744. studioButton.style.position = 'relative';
  745. studioButton.style.display = 'flex';
  746. studioButton.style.flexDirection = 'column';
  747. studioButton.style.alignItems = 'center';
  748. studioButton.style.justifyContent = 'center';
  749.  
  750. const studioImg = document.createElement('img');
  751. studioImg.src = studioButtonImages.default;
  752. studioImg.style.width = '26px';
  753. studioImg.style.height = '26px';
  754. studioButton.appendChild(studioImg);
  755.  
  756. studioButton.addEventListener('mouseover', () => studioImg.src = studioButtonImages.hover);
  757. studioButton.addEventListener('mouseout', () => studioImg.src = studioButtonImages.default);
  758.  
  759. studioButton.addEventListener('click', () => {
  760. window.location.href = 'roblox-studio://';
  761. });
  762.  
  763. const studioLabel = document.createElement('div');
  764. studioLabel.innerText = 'Studio';
  765. studioLabel.style.fontSize = '10px';
  766. studioLabel.style.marginTop = '4px';
  767. studioButton.appendChild(studioLabel);
  768. sidebar.appendChild(studioButton);
  769. }
  770. if (iconsOnRight) {
  771. searchContainer.appendChild(searchInput);
  772. searchContainer.appendChild(searchTypeContainer);
  773. topbar.appendChild(searchContainer);
  774. topbar.appendChild(robuxButton);
  775. topbar.appendChild(premiumButton);
  776. topbar.appendChild(settingsButton);
  777. } else {
  778. topbar.appendChild(premiumButton);
  779. topbar.appendChild(robuxButton);
  780. searchContainer.appendChild(searchInput);
  781. searchContainer.appendChild(searchTypeContainer);
  782. topbar.appendChild(searchContainer);
  783. topbar.appendChild(settingsButton);
  784. }
  785.  
  786. document.body.appendChild(sidebar);
  787.  
  788. document.body.appendChild(sidebar);
  789. document.body.appendChild(topbar);
  790.  
  791. document.body.style.marginLeft = '62px';
  792. document.body.style.marginTop = '48px';
  793. document.body.style.width = 'calc(100% - 62px)';
  794. document.body.style.overflow = 'auto';
  795.  
  796. const pageContent = document.querySelector('.content-wrapper');
  797. if (pageContent) {
  798. pageContent.style.marginLeft = '62px';
  799. pageContent.style.marginTop = '48px';
  800. pageContent.style.width = 'calc(100% - 62px)';
  801. }
  802.  
  803. const containers = document.querySelectorAll('.container-main, .container, .content');
  804. containers.forEach(container => {
  805. container.style.width = '100%';
  806. container.style.maxWidth = 'calc(100% - 20px)';
  807. container.style.boxSizing = 'border-box';
  808. });
  809. }
  810.  
  811. if (document.body) {
  812. init();
  813. } else {
  814. document.addEventListener('DOMContentLoaded', init);
  815. }
  816. })();