From 24cae93de8ea7413b924c1b5df7539cf72ec9339 Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Tue, 6 Feb 2024 23:13:52 +0900 Subject: [PATCH 01/26] feat: add location and gauge color at config --- package.json | 18 ++++++++++++++++++ src/core/modes/walk-mode.ts | 36 +++++++++++++++++++++++++++++------- 2 files changed, 47 insertions(+), 7 deletions(-) diff --git a/package.json b/package.json index cd54012..08b38ba 100644 --- a/package.json +++ b/package.json @@ -92,6 +92,24 @@ "items": "string", "default": [], "markdownDescription": "mode test" + }, + "junbae-mode.location": { + "type": "string", + "default": "top", + "enum": [ + "top", + "bottom" + ], + "markdownDescription": "Junbae is located on the screen" + }, + "junbae-mode.gaugeColor": { + "type": "string", + "default": "white", + "enum": [ + "white", + "#C54B65" + ], + "markdownDescription": "gauge color change" } } } diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index 784eb1f..27b7001 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -59,18 +59,39 @@ export class WalkMode implements Mode { return; } - const position = firstVisibleRange.start; - const range = new vscode.Range(position, position); + let visibleStartLine = firstVisibleRange.start; + let visibleEndLine = firstVisibleRange.start; + const junbaeLocation = { top: '5%' }; + const location = vscode.workspace.getConfiguration('junbae-mode').get('location'); + + if (location === 'top') { + visibleStartLine = firstVisibleRange.start; + visibleEndLine = firstVisibleRange.start; + } + if (location === 'bottom') { + visibleStartLine = firstVisibleRange.end; + visibleEndLine = firstVisibleRange.end; + junbaeLocation.top = '-100px'; + } + + // const position = firstVisibleRange.start; + // const range = new vscode.Range(position, position); + + const range = new vscode.Range(visibleStartLine, visibleEndLine); if (this.combo !== this.renderedComboCount || !range.isEqual(this.renderedRange!)) { this.renderedComboCount = this.combo; this.renderedRange = range; - this.createWalkMotionDecorator([range], editor); + this.createWalkMotionDecorator([range], editor, junbaeLocation); this.createTimerDecoration([range], editor); } } - private createWalkMotionDecorator = (ranges: vscode.Range[], editor: vscode.TextEditor) => { + private createWalkMotionDecorator = ( + ranges: vscode.Range[], + editor: vscode.TextEditor, + junbaeLocation: { top: string }, + ) => { const timeLeft = this.expiredAt - new Date().getTime(); if (timeLeft <= 0) { @@ -92,7 +113,8 @@ export class WalkMode implements Mode { 'background-image': `url("${motions[this.combo % motions.length]}")`, position: 'absolute', right: '5vw', - top: '5%', + // top: '5%', + ...junbaeLocation, 'font-size': '100px', 'font-family': 'monospace', 'font-weight': '900', @@ -125,14 +147,14 @@ export class WalkMode implements Mode { this.dispose(); return; } - + const gaugeColor = vscode.workspace.getConfiguration('junbae-mode').get('gaugeColor'); const timerWidth = (timeLeft / this.timerDuration) * 1.5; this.timerDecorator?.dispose(); this.timerDecorator = vscode.window.createTextEditorDecorationType({ before: { contentText: '', - backgroundColor: 'white', + backgroundColor: `${gaugeColor}`, width: `${timerWidth}em`, color: 'white', height: '8px', From 5fc349da8261a8c0beec7a986f3f6ec81e477445 Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Tue, 6 Feb 2024 23:47:46 +0900 Subject: [PATCH 02/26] fix: css of detail location --- src/core/modes/walk-mode.ts | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index 27b7001..238388b 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -61,7 +61,7 @@ export class WalkMode implements Mode { let visibleStartLine = firstVisibleRange.start; let visibleEndLine = firstVisibleRange.start; - const junbaeLocation = { top: '5%' }; + const junbaeLocation = { top: '5%', 'font-size': '50px' }; const location = vscode.workspace.getConfiguration('junbae-mode').get('location'); if (location === 'top') { @@ -72,6 +72,7 @@ export class WalkMode implements Mode { visibleStartLine = firstVisibleRange.end; visibleEndLine = firstVisibleRange.end; junbaeLocation.top = '-100px'; + junbaeLocation['font-size'] = '100px'; } // const position = firstVisibleRange.start; @@ -115,7 +116,7 @@ export class WalkMode implements Mode { right: '5vw', // top: '5%', ...junbaeLocation, - 'font-size': '100px', + // 'font-size': '50px', 'font-family': 'monospace', 'font-weight': '900', 'z-index': 1, From b8981f24f6cae3727466bdd35543ff4d90adf417 Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Tue, 6 Feb 2024 23:59:14 +0900 Subject: [PATCH 03/26] fix: change hex color code to color name --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 08b38ba..0718e51 100644 --- a/package.json +++ b/package.json @@ -107,7 +107,7 @@ "default": "white", "enum": [ "white", - "#C54B65" + "red" ], "markdownDescription": "gauge color change" } From 455fc9bbd95fa46a82b3cb5352fdd54cf411e235 Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Wed, 7 Feb 2024 00:04:18 +0900 Subject: [PATCH 04/26] fix: Delete unnecessary code and change gauge color --- src/core/modes/walk-mode.ts | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index 238388b..ce54781 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -75,9 +75,6 @@ export class WalkMode implements Mode { junbaeLocation['font-size'] = '100px'; } - // const position = firstVisibleRange.start; - // const range = new vscode.Range(position, position); - const range = new vscode.Range(visibleStartLine, visibleEndLine); if (this.combo !== this.renderedComboCount || !range.isEqual(this.renderedRange!)) { @@ -114,9 +111,7 @@ export class WalkMode implements Mode { 'background-image': `url("${motions[this.combo % motions.length]}")`, position: 'absolute', right: '5vw', - // top: '5%', ...junbaeLocation, - // 'font-size': '50px', 'font-family': 'monospace', 'font-weight': '900', 'z-index': 1, @@ -148,7 +143,12 @@ export class WalkMode implements Mode { this.dispose(); return; } - const gaugeColor = vscode.workspace.getConfiguration('junbae-mode').get('gaugeColor'); + const gaugeColorName = vscode.workspace.getConfiguration('junbae-mode').get('gaugeColor'); + let gaugeColor = 'white'; + if (gaugeColorName === 'red') { + gaugeColor = '#C54B65'; + } + const timerWidth = (timeLeft / this.timerDuration) * 1.5; this.timerDecorator?.dispose(); From ca1796d7cc54d2b2f4f1de06e11db74ede6fb12f Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Thu, 8 Feb 2024 18:54:21 +0900 Subject: [PATCH 05/26] fix: add font size property --- src/core/modes/walk-mode.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index ce54781..1b0d810 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -88,7 +88,7 @@ export class WalkMode implements Mode { private createWalkMotionDecorator = ( ranges: vscode.Range[], editor: vscode.TextEditor, - junbaeLocation: { top: string }, + junbaeLocation: { top: string; ['font-size']: string }, ) => { const timeLeft = this.expiredAt - new Date().getTime(); From 9f0c9c594cc5141b6e20f883082f543e8ce732f0 Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Thu, 8 Feb 2024 18:55:08 +0900 Subject: [PATCH 06/26] fix: remove top case --- src/core/modes/walk-mode.ts | 4 ---- 1 file changed, 4 deletions(-) diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index 1b0d810..fb26494 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -64,10 +64,6 @@ export class WalkMode implements Mode { const junbaeLocation = { top: '5%', 'font-size': '50px' }; const location = vscode.workspace.getConfiguration('junbae-mode').get('location'); - if (location === 'top') { - visibleStartLine = firstVisibleRange.start; - visibleEndLine = firstVisibleRange.start; - } if (location === 'bottom') { visibleStartLine = firstVisibleRange.end; visibleEndLine = firstVisibleRange.end; From dfbfbb84318146a3c067662f083a04ae39ef68a3 Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Thu, 8 Feb 2024 23:18:00 +0900 Subject: [PATCH 07/26] fix: add order property at package --- package.json | 3 +++ 1 file changed, 3 insertions(+) diff --git a/package.json b/package.json index 0718e51..aea0789 100644 --- a/package.json +++ b/package.json @@ -88,12 +88,14 @@ "order": 1, "properties": { "junbae-mode.mode": { + "order": 0, "type": "array", "items": "string", "default": [], "markdownDescription": "mode test" }, "junbae-mode.location": { + "order": 1, "type": "string", "default": "top", "enum": [ @@ -103,6 +105,7 @@ "markdownDescription": "Junbae is located on the screen" }, "junbae-mode.gaugeColor": { + "order": 2, "type": "string", "default": "white", "enum": [ From 7e332d33129069dcc909a3aa876f8600e7727291 Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Thu, 8 Feb 2024 23:19:07 +0900 Subject: [PATCH 08/26] fix: fix variable name --- package.json | 4 ++-- src/core/modes/walk-mode.ts | 10 +++++----- 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/package.json b/package.json index aea0789..8907f42 100644 --- a/package.json +++ b/package.json @@ -104,7 +104,7 @@ ], "markdownDescription": "Junbae is located on the screen" }, - "junbae-mode.gaugeColor": { + "junbae-mode.timerColor": { "order": 2, "type": "string", "default": "white", @@ -112,7 +112,7 @@ "white", "red" ], - "markdownDescription": "gauge color change" + "markdownDescription": "timer color change" } } } diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index fb26494..641a782 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -139,10 +139,10 @@ export class WalkMode implements Mode { this.dispose(); return; } - const gaugeColorName = vscode.workspace.getConfiguration('junbae-mode').get('gaugeColor'); - let gaugeColor = 'white'; - if (gaugeColorName === 'red') { - gaugeColor = '#C54B65'; + const timerColorName = vscode.workspace.getConfiguration('junbae-mode').get('timerColor'); + let timerColor = 'white'; + if (timerColorName === 'red') { + timerColor = '#C54B65'; } const timerWidth = (timeLeft / this.timerDuration) * 1.5; @@ -151,7 +151,7 @@ export class WalkMode implements Mode { this.timerDecorator = vscode.window.createTextEditorDecorationType({ before: { contentText: '', - backgroundColor: `${gaugeColor}`, + backgroundColor: `${timerColor}`, width: `${timerWidth}em`, color: 'white', height: '8px', From 0ddf0593fbf2dde629ffcd867679e8828e65933b Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Thu, 8 Feb 2024 23:29:03 +0900 Subject: [PATCH 09/26] fix: change order at package --- package.json | 20 +++++++------------- 1 file changed, 7 insertions(+), 13 deletions(-) diff --git a/package.json b/package.json index 26cdf75..1271470 100644 --- a/package.json +++ b/package.json @@ -92,12 +92,14 @@ "title": "Mode", "order": 1, "properties": { - "junbae-mode.mode": { + "junbae-mode.Mode": { "order": 0, - "type": "array", - "items": "string", - "default": [], - "markdownDescription": "mode test" + "type": "string", + "default": "Walk", + "enum": [ + "Walk" + ], + "markdownDescription": "You can choose the mode of Junbae." }, "junbae-mode.location": { "order": 1, @@ -118,14 +120,6 @@ "red" ], "markdownDescription": "timer color change" - }, - "junbae-mode.Mode": { - "type": "string", - "default": "Walk", - "enum": [ - "Walk" - ], - "markdownDescription": "You can choose the mode of Junbae." } } } From 5758440813788de0ad4564382d42c8bd66cf8d5c Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Tue, 13 Feb 2024 19:33:34 +0900 Subject: [PATCH 10/26] feat: add timer shadow color --- package.json | 10 ++++++++++ src/core/modes/walk-mode.ts | 8 +++++++- 2 files changed, 17 insertions(+), 1 deletion(-) diff --git a/package.json b/package.json index 1271470..4929bf5 100644 --- a/package.json +++ b/package.json @@ -120,6 +120,16 @@ "red" ], "markdownDescription": "timer color change" + }, + "junbae-mode.timerShadowColor": { + "order": 3, + "type": "string", + "default": "blue", + "enum": [ + "blue", + "purple" + ], + "markdownDescription": "timer shadow color change" } } } diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index 96613b7..c813d36 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -141,11 +141,17 @@ export class WalkMode implements Mode { return; } const timerColorName = vscode.workspace.getConfiguration('junbae-mode').get('timerColor'); + const timerShadowColorName = vscode.workspace.getConfiguration('junbae-mode').get('timerShadowColor'); let timerColor = 'white'; + let timerShadowColor = '015dee'; if (timerColorName === 'red') { timerColor = '#C54B65'; } + if (timerShadowColorName === 'purple') { + timerShadowColor = '#A485B3'; + } + const timerWidth = (timeLeft / this.timerDuration) * 1.5; this.timerDecorator?.dispose(); @@ -158,7 +164,7 @@ export class WalkMode implements Mode { height: '8px', margin: '0.25em 0 0 0', textDecoration: `none; ${objectToCssString({ - 'box-shadow': `0px 0px 15px #015dee`, + 'box-shadow': `0px 0px 15px ${timerShadowColor}`, position: 'absolute', right: '5vw', top: '5%', From 86038541f0ea01325bdba734245951c9bc02046b Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Tue, 13 Feb 2024 20:09:49 +0900 Subject: [PATCH 11/26] fix: change timer bottom location --- src/core/modes/walk-mode.ts | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index c813d36..ffbf3eb 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -63,6 +63,7 @@ export class WalkMode implements Mode { let visibleStartLine = firstVisibleRange.start; let visibleEndLine = firstVisibleRange.start; const junbaeLocation = { top: '5%', 'font-size': '50px' }; + const timerLocation = { top: '5%' }; const location = vscode.workspace.getConfiguration('junbae-mode').get('location'); if (location === 'bottom') { @@ -70,6 +71,7 @@ export class WalkMode implements Mode { visibleEndLine = firstVisibleRange.end; junbaeLocation.top = '-100px'; junbaeLocation['font-size'] = '100px'; + timerLocation.top = '-75px'; } const range = new vscode.Range(visibleStartLine, visibleEndLine); @@ -78,7 +80,7 @@ export class WalkMode implements Mode { this.renderedComboCount = this.combo; this.renderedRange = range; this.createWalkMotionDecorator([range], editor, junbaeLocation); - this.createTimerDecoration([range], editor); + this.createTimerDecoration([range], editor, timerLocation); } } @@ -128,7 +130,7 @@ export class WalkMode implements Mode { clearTimeout(this.decorationTimer); } - private createTimerDecoration(ranges: vscode.Range[], editor: vscode.TextEditor) { + private createTimerDecoration(ranges: vscode.Range[], editor: vscode.TextEditor, timerLocation: { top: string }) { if (this.decorationTimer) { clearTimeout(this.decorationTimer); } @@ -142,18 +144,18 @@ export class WalkMode implements Mode { } const timerColorName = vscode.workspace.getConfiguration('junbae-mode').get('timerColor'); const timerShadowColorName = vscode.workspace.getConfiguration('junbae-mode').get('timerShadowColor'); + let timerColor = 'white'; - let timerShadowColor = '015dee'; + let timerShadowColor = '#015dee'; + if (timerColorName === 'red') { timerColor = '#C54B65'; } - if (timerShadowColorName === 'purple') { timerShadowColor = '#A485B3'; } const timerWidth = (timeLeft / this.timerDuration) * 1.5; - this.timerDecorator?.dispose(); this.timerDecorator = vscode.window.createTextEditorDecorationType({ before: { @@ -167,7 +169,7 @@ export class WalkMode implements Mode { 'box-shadow': `0px 0px 15px ${timerShadowColor}`, position: 'absolute', right: '5vw', - top: '5%', + ...timerLocation, 'font-size': '40px', 'font-family': 'monospace', 'font-weight': '900', From af443af634f9bf476160d3a45199bbd18a075f95 Mon Sep 17 00:00:00 2001 From: myunggyuns <61381189+myunggyuns@users.noreply.github.com> Date: Tue, 13 Feb 2024 21:50:41 +0900 Subject: [PATCH 12/26] fix: config description change to sentence Co-authored-by: Arthur Hwang --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 4929bf5..62004de 100644 --- a/package.json +++ b/package.json @@ -109,7 +109,7 @@ "top", "bottom" ], - "markdownDescription": "Junbae is located on the screen" + "markdownDescription": "�You can choose location of junbae on the screen." }, "junbae-mode.timerColor": { "order": 2, From ec80db4ad192b6a892a578f967a5231114d1694f Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Tue, 13 Feb 2024 21:57:17 +0900 Subject: [PATCH 13/26] fix: change location property --- src/core/modes/walk-mode.ts | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index ffbf3eb..cb70a31 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -62,16 +62,18 @@ export class WalkMode implements Mode { let visibleStartLine = firstVisibleRange.start; let visibleEndLine = firstVisibleRange.start; - const junbaeLocation = { top: '5%', 'font-size': '50px' }; - const timerLocation = { top: '5%' }; + const junbaeLocation = { top: '5%', 'font-size': '50px', bottom: 'none' }; + const timerLocation = { top: '5%', bottom: 'none' }; const location = vscode.workspace.getConfiguration('junbae-mode').get('location'); if (location === 'bottom') { visibleStartLine = firstVisibleRange.end; visibleEndLine = firstVisibleRange.end; - junbaeLocation.top = '-100px'; + junbaeLocation.top = 'none'; + junbaeLocation.bottom = '10px'; junbaeLocation['font-size'] = '100px'; - timerLocation.top = '-75px'; + timerLocation.top = 'none'; + timerLocation.bottom = '70px'; } const range = new vscode.Range(visibleStartLine, visibleEndLine); @@ -87,7 +89,7 @@ export class WalkMode implements Mode { private createWalkMotionDecorator = ( ranges: vscode.Range[], editor: vscode.TextEditor, - junbaeLocation: { top: string; ['font-size']: string }, + junbaeLocation: { top: string; ['font-size']: string; bottom: string }, ) => { const timeLeft = this.expiredAt - new Date().getTime(); @@ -130,7 +132,11 @@ export class WalkMode implements Mode { clearTimeout(this.decorationTimer); } - private createTimerDecoration(ranges: vscode.Range[], editor: vscode.TextEditor, timerLocation: { top: string }) { + private createTimerDecoration( + ranges: vscode.Range[], + editor: vscode.TextEditor, + timerLocation: { top: string; bottom: string }, + ) { if (this.decorationTimer) { clearTimeout(this.decorationTimer); } From 660c274d4411d61ba66ac949200fe093f3f44c7d Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Tue, 13 Feb 2024 22:00:44 +0900 Subject: [PATCH 14/26] fix: remove code about font css --- src/core/modes/walk-mode.ts | 9 --------- 1 file changed, 9 deletions(-) diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index cb70a31..6a805ee 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -103,7 +103,6 @@ export class WalkMode implements Mode { after: { contentText: ``, margin: '0.5em 0 0 0', - color: '#FFFFFF', textDecoration: `none; ${objectToCssString({ width: '50px', height: '50px', @@ -113,11 +112,8 @@ export class WalkMode implements Mode { position: 'absolute', right: '5vw', ...junbaeLocation, - 'font-family': 'monospace', - 'font-weight': '900', 'z-index': 1, 'pointer-events': 'none', - 'text-align': 'center', })}`, }, rangeBehavior: vscode.DecorationRangeBehavior.ClosedClosed, @@ -168,7 +164,6 @@ export class WalkMode implements Mode { contentText: '', backgroundColor: `${timerColor}`, width: `${timerWidth}em`, - color: 'white', height: '8px', margin: '0.25em 0 0 0', textDecoration: `none; ${objectToCssString({ @@ -176,12 +171,8 @@ export class WalkMode implements Mode { position: 'absolute', right: '5vw', ...timerLocation, - 'font-size': '40px', - 'font-family': 'monospace', - 'font-weight': '900', 'z-index': 1, 'pointer-events': 'none', - 'text-align': 'center', })}`, }, rangeBehavior: vscode.DecorationRangeBehavior.ClosedClosed, From 5279ad8a2e939ab90d6e24b856ca1f8488ca416b Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Tue, 13 Feb 2024 22:03:42 +0900 Subject: [PATCH 15/26] fix: colors config description change to sentence --- package.json | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/package.json b/package.json index 62004de..a61f26b 100644 --- a/package.json +++ b/package.json @@ -109,7 +109,7 @@ "top", "bottom" ], - "markdownDescription": "�You can choose location of junbae on the screen." + "markdownDescription": "You can choose location of junbae on the screen." }, "junbae-mode.timerColor": { "order": 2, @@ -119,7 +119,7 @@ "white", "red" ], - "markdownDescription": "timer color change" + "markdownDescription": "You can choose timer color." }, "junbae-mode.timerShadowColor": { "order": 3, @@ -129,7 +129,7 @@ "blue", "purple" ], - "markdownDescription": "timer shadow color change" + "markdownDescription": "You can choose timer shadow color." } } } From 6e5800b0d376c6a2b6a732be4e4fa8c6fed3fa34 Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Tue, 13 Feb 2024 22:38:48 +0900 Subject: [PATCH 16/26] fix: use default value --- src/core/modes/walk-mode.ts | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index 6a805ee..ce4cdad 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -144,16 +144,18 @@ export class WalkMode implements Mode { this.dispose(); return; } - const timerColorName = vscode.workspace.getConfiguration('junbae-mode').get('timerColor'); - const timerShadowColorName = vscode.workspace.getConfiguration('junbae-mode').get('timerShadowColor'); - let timerColor = 'white'; - let timerShadowColor = '#015dee'; + let timerColor = vscode.workspace.getConfiguration('junbae-mode').get('timerColor'); - if (timerColorName === 'red') { + if (timerColor === 'red') { timerColor = '#C54B65'; } - if (timerShadowColorName === 'purple') { + + let timerShadowColor = vscode.workspace.getConfiguration('junbae-mode').get('timerShadowColor'); + + if (timerShadowColor === 'blue') { + timerShadowColor = '#015dee'; + } else if (timerShadowColor === 'purple') { timerShadowColor = '#A485B3'; } From ebed9c695b6c0c9f8565da9b319fb42565efde82 Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Tue, 13 Feb 2024 23:00:41 +0900 Subject: [PATCH 17/26] fix: seperate with private method --- src/core/modes/walk-mode.ts | 37 ++++++++++++++++++++++--------------- 1 file changed, 22 insertions(+), 15 deletions(-) diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index ce4cdad..46e790b 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -60,21 +60,7 @@ export class WalkMode implements Mode { return; } - let visibleStartLine = firstVisibleRange.start; - let visibleEndLine = firstVisibleRange.start; - const junbaeLocation = { top: '5%', 'font-size': '50px', bottom: 'none' }; - const timerLocation = { top: '5%', bottom: 'none' }; - const location = vscode.workspace.getConfiguration('junbae-mode').get('location'); - - if (location === 'bottom') { - visibleStartLine = firstVisibleRange.end; - visibleEndLine = firstVisibleRange.end; - junbaeLocation.top = 'none'; - junbaeLocation.bottom = '10px'; - junbaeLocation['font-size'] = '100px'; - timerLocation.top = 'none'; - timerLocation.bottom = '70px'; - } + const { junbaeLocation, timerLocation, visibleStartLine, visibleEndLine } = this.getLocation(firstVisibleRange); const range = new vscode.Range(visibleStartLine, visibleEndLine); @@ -185,4 +171,25 @@ export class WalkMode implements Mode { this.decorationTimer = setInterval(updateComboTimerDecoration, 50); } + + private getLocation(firstVisibleRange: vscode.Range) { + const location = vscode.workspace.getConfiguration('junbae-mode').get('location'); + + let visibleStartLine = firstVisibleRange.start; + let visibleEndLine = firstVisibleRange.start; + const junbaeLocation = { top: '5%', 'font-size': '50px', bottom: 'none' }; + const timerLocation = { top: '5%', bottom: 'none' }; + + if (location === 'bottom') { + visibleStartLine = firstVisibleRange.end; + visibleEndLine = firstVisibleRange.end; + junbaeLocation.top = 'none'; + junbaeLocation.bottom = '10px'; + junbaeLocation['font-size'] = '100px'; + timerLocation.top = 'none'; + timerLocation.bottom = '70px'; + } + + return { junbaeLocation, timerLocation, visibleStartLine, visibleEndLine }; + } } From 8fc98239d7b5c6bd73a31233902a7158bbe72057 Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Wed, 14 Feb 2024 00:17:05 +0900 Subject: [PATCH 18/26] fix: seperate with private color method and add range in location method --- package.json | 10 ---------- src/core/modes/walk-mode.ts | 39 ++++++++++++++++++++++--------------- 2 files changed, 23 insertions(+), 26 deletions(-) diff --git a/package.json b/package.json index a61f26b..5ca0036 100644 --- a/package.json +++ b/package.json @@ -120,16 +120,6 @@ "red" ], "markdownDescription": "You can choose timer color." - }, - "junbae-mode.timerShadowColor": { - "order": 3, - "type": "string", - "default": "blue", - "enum": [ - "blue", - "purple" - ], - "markdownDescription": "You can choose timer shadow color." } } } diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index 46e790b..6b81755 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -60,9 +60,9 @@ export class WalkMode implements Mode { return; } - const { junbaeLocation, timerLocation, visibleStartLine, visibleEndLine } = this.getLocation(firstVisibleRange); + const { junbaeLocation, timerLocation, range } = this.getLocation(firstVisibleRange); - const range = new vscode.Range(visibleStartLine, visibleEndLine); + // const range = new vscode.Range(visibleStartLine, visibleEndLine); if (this.combo !== this.renderedComboCount || !range.isEqual(this.renderedRange!)) { this.renderedComboCount = this.combo; @@ -131,19 +131,7 @@ export class WalkMode implements Mode { return; } - let timerColor = vscode.workspace.getConfiguration('junbae-mode').get('timerColor'); - - if (timerColor === 'red') { - timerColor = '#C54B65'; - } - - let timerShadowColor = vscode.workspace.getConfiguration('junbae-mode').get('timerShadowColor'); - - if (timerShadowColor === 'blue') { - timerShadowColor = '#015dee'; - } else if (timerShadowColor === 'purple') { - timerShadowColor = '#A485B3'; - } + const { timerColor, timerShadowColor } = this.getTimerColor(); const timerWidth = (timeLeft / this.timerDuration) * 1.5; this.timerDecorator?.dispose(); @@ -190,6 +178,25 @@ export class WalkMode implements Mode { timerLocation.bottom = '70px'; } - return { junbaeLocation, timerLocation, visibleStartLine, visibleEndLine }; + const range = new vscode.Range(visibleStartLine, visibleEndLine); + + return { junbaeLocation, timerLocation, range }; + } + + private getTimerColor() { + const timerColorName = vscode.workspace.getConfiguration('junbae-mode').get('timerColor'); + const timerColor = { + timerColor: 'white', + timerShadowColor: '#015dee', + }; + + if (timerColorName === 'white') { + timerColor.timerColor = 'white'; + timerColor.timerShadowColor = '#015dee'; + } else if (timerColorName === 'red') { + timerColor.timerColor = '#C54B65'; + timerColor.timerShadowColor = '#FFC0CB'; + } + return timerColor; } } From 92f5939368ec913ec736c3e24ab5a8923a6eb38e Mon Sep 17 00:00:00 2001 From: myunggyuns <61381189+myunggyuns@users.noreply.github.com> Date: Wed, 14 Feb 2024 08:03:31 +0900 Subject: [PATCH 19/26] fix: remove comment --- src/core/modes/walk-mode.ts | 2 -- 1 file changed, 2 deletions(-) diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index 6b81755..8a55d9f 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -62,8 +62,6 @@ export class WalkMode implements Mode { const { junbaeLocation, timerLocation, range } = this.getLocation(firstVisibleRange); - // const range = new vscode.Range(visibleStartLine, visibleEndLine); - if (this.combo !== this.renderedComboCount || !range.isEqual(this.renderedRange!)) { this.renderedComboCount = this.combo; this.renderedRange = range; From 9f75a825d90f9e537b89e7956aa5c1bd68c015c0 Mon Sep 17 00:00:00 2001 From: myunggyuns <61381189+myunggyuns@users.noreply.github.com> Date: Wed, 14 Feb 2024 08:08:22 +0900 Subject: [PATCH 20/26] refactor: change variable --- src/core/modes/walk-mode.ts | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index 8a55d9f..2237b95 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -183,18 +183,18 @@ export class WalkMode implements Mode { private getTimerColor() { const timerColorName = vscode.workspace.getConfiguration('junbae-mode').get('timerColor'); - const timerColor = { + const timerColors = { timerColor: 'white', timerShadowColor: '#015dee', }; if (timerColorName === 'white') { - timerColor.timerColor = 'white'; - timerColor.timerShadowColor = '#015dee'; + timerColors.timerColor = 'white'; + timerColors.timerShadowColor = '#015dee'; } else if (timerColorName === 'red') { - timerColor.timerColor = '#C54B65'; - timerColor.timerShadowColor = '#FFC0CB'; + timerColors.timerColor = '#C54B65'; + timerColors.timerShadowColor = '#FFC0CB'; } - return timerColor; + return timerColors; } } From 3b3c39aa18d575a5e11f02d9b41e184bfc06efcf Mon Sep 17 00:00:00 2001 From: myunggyuns <61381189+myunggyuns@users.noreply.github.com> Date: Wed, 14 Feb 2024 08:12:33 +0900 Subject: [PATCH 21/26] fix: remove duplicate property assignments --- src/core/modes/walk-mode.ts | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index 2237b95..0a85610 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -188,13 +188,11 @@ export class WalkMode implements Mode { timerShadowColor: '#015dee', }; - if (timerColorName === 'white') { - timerColors.timerColor = 'white'; - timerColors.timerShadowColor = '#015dee'; - } else if (timerColorName === 'red') { + if (timerColorName === 'red') { timerColors.timerColor = '#C54B65'; timerColors.timerShadowColor = '#FFC0CB'; } + return timerColors; } } From 414803d1b2bd34bb5f13ef8f8a67bb488fb30536 Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Wed, 14 Feb 2024 22:08:14 +0900 Subject: [PATCH 22/26] fix: the if statement changes to a switch statement. --- src/core/modes/walk-mode.ts | 32 ++++++++++++++------------------ 1 file changed, 14 insertions(+), 18 deletions(-) diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index 0a85610..902e06f 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -161,24 +161,20 @@ export class WalkMode implements Mode { private getLocation(firstVisibleRange: vscode.Range) { const location = vscode.workspace.getConfiguration('junbae-mode').get('location'); - let visibleStartLine = firstVisibleRange.start; - let visibleEndLine = firstVisibleRange.start; - const junbaeLocation = { top: '5%', 'font-size': '50px', bottom: 'none' }; - const timerLocation = { top: '5%', bottom: 'none' }; - - if (location === 'bottom') { - visibleStartLine = firstVisibleRange.end; - visibleEndLine = firstVisibleRange.end; - junbaeLocation.top = 'none'; - junbaeLocation.bottom = '10px'; - junbaeLocation['font-size'] = '100px'; - timerLocation.top = 'none'; - timerLocation.bottom = '70px'; + switch (location) { + case 'bottom': + return { + range: new vscode.Range(firstVisibleRange.end, firstVisibleRange.end), + junbaeLocation: { top: 'none', 'font-size': '100px', bottom: '10px' }, + timerLocation: { top: 'none', bottom: '70px' }, + }; + default: + return { + range: new vscode.Range(firstVisibleRange.start, firstVisibleRange.start), + junbaeLocation: { top: '5%', 'font-size': '50px', bottom: 'none' }, + timerLocation: { top: '5%', bottom: 'none' }, + }; } - - const range = new vscode.Range(visibleStartLine, visibleEndLine); - - return { junbaeLocation, timerLocation, range }; } private getTimerColor() { @@ -192,7 +188,7 @@ export class WalkMode implements Mode { timerColors.timerColor = '#C54B65'; timerColors.timerShadowColor = '#FFC0CB'; } - + return timerColors; } } From e351fbc9ac80aed9db2585895ef4d54bf8a01f2a Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Wed, 14 Feb 2024 22:40:40 +0900 Subject: [PATCH 23/26] fix: the if statement changes to a switch statement in timer method --- src/core/modes/walk-mode.ts | 20 +++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index 902e06f..8470a93 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -179,16 +179,18 @@ export class WalkMode implements Mode { private getTimerColor() { const timerColorName = vscode.workspace.getConfiguration('junbae-mode').get('timerColor'); - const timerColors = { - timerColor: 'white', - timerShadowColor: '#015dee', - }; - if (timerColorName === 'red') { - timerColors.timerColor = '#C54B65'; - timerColors.timerShadowColor = '#FFC0CB'; + switch (timerColorName) { + case 'red': + return { + timerColor: '#C54B65', + timerShadowColor: '#FFC0CB', + }; + default: + return { + timerColor: 'white', + timerShadowColor: '#015dee', + }; } - - return timerColors; } } From 36c7c002cd1e633430485c39db2c1d6ac6d0d488 Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Thu, 15 Feb 2024 00:27:28 +0900 Subject: [PATCH 24/26] refactor: add type --- src/@types/index.d.ts | 2 ++ src/core/modes/walk-mode.ts | 30 ++++++++++++++++++++++-------- 2 files changed, 24 insertions(+), 8 deletions(-) create mode 100644 src/@types/index.d.ts diff --git a/src/@types/index.d.ts b/src/@types/index.d.ts new file mode 100644 index 0000000..61320d8 --- /dev/null +++ b/src/@types/index.d.ts @@ -0,0 +1,2 @@ +type Without = { [P in Exclude]?: never }; +type XOR = T extends object ? Without> & T : T; diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index 8470a93..6f67770 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -3,6 +3,20 @@ import { TextEditorDecorationType } from 'vscode'; import { Mode } from './mode.interface'; import { objectToCssString } from '../../utils'; +type JunbaeLocation = { 'font-size': string } & XOR<{ top: string }, { bottom: string }>; +type TimerLocation = XOR<{ top: string }, { bottom: string }>; + +type Location = { + range: vscode.Range; + junbaeLocation: JunbaeLocation; + timerLocation: TimerLocation; +}; + +type TimerColor = { + timerColor: string; + timerShadowColor: string; +}; + const motions = [ '', '', @@ -73,7 +87,7 @@ export class WalkMode implements Mode { private createWalkMotionDecorator = ( ranges: vscode.Range[], editor: vscode.TextEditor, - junbaeLocation: { top: string; ['font-size']: string; bottom: string }, + junbaeLocation: Location['junbaeLocation'], ) => { const timeLeft = this.expiredAt - new Date().getTime(); @@ -115,7 +129,7 @@ export class WalkMode implements Mode { private createTimerDecoration( ranges: vscode.Range[], editor: vscode.TextEditor, - timerLocation: { top: string; bottom: string }, + timerLocation: Location['timerLocation'], ) { if (this.decorationTimer) { clearTimeout(this.decorationTimer); @@ -158,26 +172,26 @@ export class WalkMode implements Mode { this.decorationTimer = setInterval(updateComboTimerDecoration, 50); } - private getLocation(firstVisibleRange: vscode.Range) { + private getLocation(firstVisibleRange: vscode.Range): Location { const location = vscode.workspace.getConfiguration('junbae-mode').get('location'); switch (location) { case 'bottom': return { range: new vscode.Range(firstVisibleRange.end, firstVisibleRange.end), - junbaeLocation: { top: 'none', 'font-size': '100px', bottom: '10px' }, - timerLocation: { top: 'none', bottom: '70px' }, + junbaeLocation: { 'font-size': '100px', bottom: '10px' }, + timerLocation: { bottom: '70px' }, }; default: return { range: new vscode.Range(firstVisibleRange.start, firstVisibleRange.start), - junbaeLocation: { top: '5%', 'font-size': '50px', bottom: 'none' }, - timerLocation: { top: '5%', bottom: 'none' }, + junbaeLocation: { top: '5%', 'font-size': '50px' }, + timerLocation: { top: '5%' }, }; } } - private getTimerColor() { + private getTimerColor(): TimerColor { const timerColorName = vscode.workspace.getConfiguration('junbae-mode').get('timerColor'); switch (timerColorName) { From 6b25fd23cabde04fe1fce15dd88f52fab519a514 Mon Sep 17 00:00:00 2001 From: myunggyuns Date: Thu, 15 Feb 2024 00:37:43 +0900 Subject: [PATCH 25/26] fix: change timer width ratio --- src/core/modes/walk-mode.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index 6f67770..f17fa65 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -145,7 +145,7 @@ export class WalkMode implements Mode { const { timerColor, timerShadowColor } = this.getTimerColor(); - const timerWidth = (timeLeft / this.timerDuration) * 1.5; + const timerWidth = (timeLeft / this.timerDuration) * 4; this.timerDecorator?.dispose(); this.timerDecorator = vscode.window.createTextEditorDecorationType({ before: { From 655bc68f935be163079fd947f7b9c0303fd5f286 Mon Sep 17 00:00:00 2001 From: changhwan hwang Date: Thu, 15 Feb 2024 01:09:50 +0900 Subject: [PATCH 26/26] refactor: add comment, remove useless types --- src/core/modes/walk-mode.ts | 26 ++++++++++++++++---------- 1 file changed, 16 insertions(+), 10 deletions(-) diff --git a/src/core/modes/walk-mode.ts b/src/core/modes/walk-mode.ts index f17fa65..3e7b44d 100644 --- a/src/core/modes/walk-mode.ts +++ b/src/core/modes/walk-mode.ts @@ -3,13 +3,17 @@ import { TextEditorDecorationType } from 'vscode'; import { Mode } from './mode.interface'; import { objectToCssString } from '../../utils'; -type JunbaeLocation = { 'font-size': string } & XOR<{ top: string }, { bottom: string }>; -type TimerLocation = XOR<{ top: string }, { bottom: string }>; +const motions = [ + '', + '', + '', + '', +]; type Location = { range: vscode.Range; - junbaeLocation: JunbaeLocation; - timerLocation: TimerLocation; + junbaeLocation: { 'font-size': string } & XOR<{ top: string }, { bottom: string }>; + timerLocation: XOR<{ top: string }, { bottom: string }>; }; type TimerColor = { @@ -17,12 +21,6 @@ type TimerColor = { timerShadowColor: string; }; -const motions = [ - '', - '', - '', - '', -]; export class WalkMode implements Mode { private combo = 0; @@ -108,6 +106,10 @@ export class WalkMode implements Mode { 'background-repeat': 'no-repeat', 'background-image': `url("${motions[this.combo % motions.length]}")`, position: 'absolute', + /** + * NOTE: Junbae go out of screen when horizontal scroll + * If you want to limit position of Junbae, use `%` + */ right: '5vw', ...junbaeLocation, 'z-index': 1, @@ -157,6 +159,10 @@ export class WalkMode implements Mode { textDecoration: `none; ${objectToCssString({ 'box-shadow': `0px 0px 15px ${timerShadowColor}`, position: 'absolute', + /** + * NOTE: Junbae go out of screen when horizontal scroll + * If you want to limit position of Junbae, use `%` + */ right: '5vw', ...timerLocation, 'z-index': 1,