Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Junbae config #13

Merged
merged 29 commits into from
Feb 14, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
24cae93
feat: add location and gauge color at config
myunggyuns Feb 6, 2024
5fc349d
fix: css of detail location
myunggyuns Feb 6, 2024
b8981f2
fix: change hex color code to color name
myunggyuns Feb 6, 2024
455fc9b
fix: Delete unnecessary code and change gauge color
myunggyuns Feb 6, 2024
ca1796d
fix: add font size property
myunggyuns Feb 8, 2024
9f0c9c5
fix: remove top case
myunggyuns Feb 8, 2024
dfbfbb8
fix: add order property at package
myunggyuns Feb 8, 2024
7e332d3
fix: fix variable name
myunggyuns Feb 8, 2024
efaf953
fix: resolve conflict
myunggyuns Feb 8, 2024
0ddf059
fix: change order at package
myunggyuns Feb 8, 2024
5758440
feat: add timer shadow color
myunggyuns Feb 13, 2024
8603854
fix: change timer bottom location
myunggyuns Feb 13, 2024
af443af
fix: config description change to sentence
myunggyuns Feb 13, 2024
ec80db4
fix: change location property
myunggyuns Feb 13, 2024
fe9c666
Merge remote-tracking branch 'origin/junbae-config' into junbae-config
myunggyuns Feb 13, 2024
660c274
fix: remove code about font css
myunggyuns Feb 13, 2024
5279ad8
fix: colors config description change to sentence
myunggyuns Feb 13, 2024
6e5800b
fix: use default value
myunggyuns Feb 13, 2024
ebed9c6
fix: seperate with private method
myunggyuns Feb 13, 2024
8fc9823
fix: seperate with private color method and add range in location method
myunggyuns Feb 13, 2024
92f5939
fix: remove comment
myunggyuns Feb 13, 2024
9f75a82
refactor: change variable
myunggyuns Feb 13, 2024
3b3c39a
fix: remove duplicate property assignments
myunggyuns Feb 13, 2024
7819d14
Merge remote-tracking branch 'origin/junbae-config' into junbae-config
myunggyuns Feb 14, 2024
414803d
fix: the if statement changes to a switch statement.
myunggyuns Feb 14, 2024
e351fbc
fix: the if statement changes to a switch statement in timer method
myunggyuns Feb 14, 2024
36c7c00
refactor: add type
myunggyuns Feb 14, 2024
6b25fd2
fix: change timer width ratio
myunggyuns Feb 14, 2024
655bc68
refactor: add comment, remove useless types
changchanghwang Feb 14, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
21 changes: 21 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -93,12 +93,33 @@
"order": 1,
"properties": {
"junbae-mode.Mode": {
"order": 0,
"type": "string",
"default": "Walk",
"enum": [
"Walk"
],
"markdownDescription": "You can choose the mode of Junbae."
},
"junbae-mode.location": {
"order": 1,
"type": "string",
"default": "top",
"enum": [
"top",
"bottom"
],
"markdownDescription": "You can choose location of junbae on the screen."
},
"junbae-mode.timerColor": {
"order": 2,
"type": "string",
"default": "white",
"enum": [
"white",
"red"
],
"markdownDescription": "You can choose timer color."
}
}
}
Expand Down
2 changes: 2 additions & 0 deletions src/@types/index.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
type Without<T, U> = { [P in Exclude<keyof T, keyof U>]?: never };
type XOR<T, U> = T extends object ? Without<Exclude<U, T>> & T : T;
96 changes: 75 additions & 21 deletions src/core/modes/walk-mode.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,18 @@
'',
'',
];

type Location = {
range: vscode.Range;
junbaeLocation: { 'font-size': string } & XOR<{ top: string }, { bottom: string }>;
timerLocation: XOR<{ top: string }, { bottom: string }>;
};

type TimerColor = {
timerColor: string;
timerShadowColor: string;
};

export class WalkMode implements Mode {
private combo = 0;

Expand All @@ -35,7 +47,7 @@
});
}

onDidChangeTextDocument(event: vscode.TextDocumentChangeEvent): void {

Check warning on line 50 in src/core/modes/walk-mode.ts

View workflow job for this annotation

GitHub Actions / release (20.11.x)

'event' is defined but never used. Allowed unused args must match /^_/u
if (!this.enabled) {
return;
}
Expand All @@ -60,18 +72,21 @@
return;
}

const position = firstVisibleRange.start;
const range = new vscode.Range(position, position);
const { junbaeLocation, timerLocation, range } = this.getLocation(firstVisibleRange);

if (this.combo !== this.renderedComboCount || !range.isEqual(this.renderedRange!)) {
this.renderedComboCount = this.combo;
this.renderedRange = range;
this.createWalkMotionDecorator([range], editor);
this.createTimerDecoration([range], editor);
this.createWalkMotionDecorator([range], editor, junbaeLocation);
this.createTimerDecoration([range], editor, timerLocation);
}
}

private createWalkMotionDecorator = (ranges: vscode.Range[], editor: vscode.TextEditor) => {
private createWalkMotionDecorator = (
ranges: vscode.Range[],
editor: vscode.TextEditor,
junbaeLocation: Location['junbaeLocation'],
) => {
const timeLeft = this.expiredAt - new Date().getTime();

if (timeLeft <= 0) {
Expand All @@ -84,22 +99,21 @@
after: {
contentText: ``,
margin: '0.5em 0 0 0',
color: '#FFFFFF',
textDecoration: `none; ${objectToCssString({
width: '50px',
height: '50px',
'background-size': 'contain',
'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',
top: '5%',
'font-size': '100px',
'font-family': 'monospace',
'font-weight': '900',
...junbaeLocation,
'z-index': 1,
'pointer-events': 'none',
'text-align': 'center',
})}`,
},
rangeBehavior: vscode.DecorationRangeBehavior.ClosedClosed,
Expand All @@ -114,7 +128,11 @@
clearTimeout(this.decorationTimer);
}

private createTimerDecoration(ranges: vscode.Range[], editor: vscode.TextEditor) {
private createTimerDecoration(
ranges: vscode.Range[],
editor: vscode.TextEditor,
timerLocation: Location['timerLocation'],
) {
if (this.decorationTimer) {
clearTimeout(this.decorationTimer);
}
Expand All @@ -127,28 +145,28 @@
return;
}

const timerWidth = (timeLeft / this.timerDuration) * 1.5;
const { timerColor, timerShadowColor } = this.getTimerColor();

const timerWidth = (timeLeft / this.timerDuration) * 4;
this.timerDecorator?.dispose();
this.timerDecorator = vscode.window.createTextEditorDecorationType({
before: {
contentText: '',
backgroundColor: 'white',
backgroundColor: `${timerColor}`,
width: `${timerWidth}em`,
color: 'white',
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',
/**
* NOTE: Junbae go out of screen when horizontal scroll
* If you want to limit position of Junbae, use `%`
*/
right: '5vw',
top: '5%',
'font-size': '40px',
'font-family': 'monospace',
'font-weight': '900',
...timerLocation,
'z-index': 1,
'pointer-events': 'none',
'text-align': 'center',
})}`,
},
rangeBehavior: vscode.DecorationRangeBehavior.ClosedClosed,
Expand All @@ -159,4 +177,40 @@

this.decorationTimer = setInterval(updateComboTimerDecoration, 50);
}

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: { 'font-size': '100px', bottom: '10px' },
timerLocation: { bottom: '70px' },
};
default:
return {
range: new vscode.Range(firstVisibleRange.start, firstVisibleRange.start),
junbaeLocation: { top: '5%', 'font-size': '50px' },
timerLocation: { top: '5%' },
};
}
}

private getTimerColor(): TimerColor {
const timerColorName = vscode.workspace.getConfiguration('junbae-mode').get('timerColor');

switch (timerColorName) {
case 'red':
return {
timerColor: '#C54B65',
timerShadowColor: '#FFC0CB',
};
default:
return {
timerColor: 'white',
timerShadowColor: '#015dee',
};
}
}
}
Loading