diff --git a/changelog.md b/changelog.md index 6a734144..f200130f 100644 --- a/changelog.md +++ b/changelog.md @@ -1,4 +1,7 @@ # Changelog +## Oct 16, 2023 +Added dependencies information to generated ini/txt + ## Jul 15, 2023 ### Fixed the bug that background color cannot be changed in 'Controller Input Display' ### Ported 'FastForward', 'InstantRestart', 'SpawnYoshi', 'StageIntroSkip' to all versions diff --git a/site/.vuepress/components/CodeList.vue b/site/.vuepress/components/CodeList.vue index 4aed5b28..44b6fc61 100644 --- a/site/.vuepress/components/CodeList.vue +++ b/site/.vuepress/components/CodeList.vue @@ -114,7 +114,7 @@ export default { const selectedCodes = this.availableCodes.filter((c) => c.selected); // add dependencies const deps = new Set(selectedCodes.flatMap(c => c.dependencies)); - selectedCodes.push(...this.codes.filter(c => deps.has(c.id))); + selectedCodes.push(...this.availableCodes.filter(c => !c.selected && deps.has(c.id))); // emit this.onSelectionChanged(selectedCodes); }, diff --git a/site/.vuepress/components/DownloadButton.vue b/site/.vuepress/components/DownloadButton.vue index 110143a2..145d5b29 100644 --- a/site/.vuepress/components/DownloadButton.vue +++ b/site/.vuepress/components/DownloadButton.vue @@ -35,7 +35,39 @@ export default { if ((!this.codes || !this.codes.length) && !this.stageLoaderCode) { return; } - const codeList = this.codes.map((c) => ({ ...c })); + + const codeList = this.codes.map((c) => ({ + ...c, + // for recording previous downloaded code + titleEN: c.title.find(o => o.lang === 'en-US').content, + // for generated txt, ini + title: translateCode(c, this.$lang).title, + })); + + // add dependencies information to title + const id2code = Object.fromEntries(codeList.map(c => [c.id, c])); + const depBys = {}; + /* depends on */ + for (const c of codeList) { + if (c.dependencies.length) { + c.dependencies.forEach(id => { + depBys[id] ??= []; + depBys[id].push(c.title); + }); + const depList = c.dependencies.map(id => id2code[id].title).join(', '); + c.title += ` **(REQUIRES: ${depList})**`; + } + } + /* used by */ + for (const [id, depBy] of Object.entries(depBys)) { + id2code[id].title += ` (Used by: ${depBy.join(', ')})`; + } + + // save downloaded code list + try { + const codeTitles = codeList.map(c => c.titleEN); + localStorage.setItem(lskeyLDC, JSON.stringify(codeTitles)); + } catch {} if (this.stageLoaderCode) codeList.push({ @@ -93,7 +125,10 @@ export default { // download GCI Loader + GCT only code as remaining format const {codes} = gameVersions.find((v) => v.identifier === this.versionIdentifier); const gciLoader = codes.find(code => code.id === 'GCILoader'); - codeList.push(gciLoader, ...codeListGCT); + codeList.push({ + ...gciLoader, + title: translateCode(gciLoader, this.$lang).title, + }, ...codeListGCT); if (!format && codeListGCT.length) { const list = codeListGCT.map(c => ( c.title.find(o => o.lang === this.$lang) ?? @@ -163,10 +198,7 @@ export default { let data = 'Paste the following on top of your games .ini file:\r\n[Gecko]'; codes.forEach((code) => { - const codeTitle = - typeof code.title === 'string' ? code.title : translateCode(code, this.$lang).title; - - data += `\r\n$${codeTitle} (${code.date}) [${code.author}]\r\n`; + data += `\r\n$${code.title} (${code.date}) [${code.author}]\r\n`; data += code.source .match(/.{8}/g) .join(' ') @@ -182,7 +214,7 @@ export default { const codeTitle = typeof code.title === 'string' ? code.title : translateCode(code, this.$lang).title; - data += `\r\n\r\n${codeTitle} (${code.date}) [${code.author}]\r\n`; + data += `\r\n\r\n${code.title} (${code.date}) [${code.author}]\r\n`; data += code.source .match(/.{8}/g) .join(' ')