Skip to content

Commit

Permalink
fix: hide stroke highlight if it gets canceled rather than leaving it…
Browse files Browse the repository at this point in the history
… halfway (chanind#294)
  • Loading branch information
chanind authored Feb 8, 2023
1 parent 99c6f93 commit 13852e7
Show file tree
Hide file tree
Showing 2 changed files with 42 additions and 1 deletion.
38 changes: 38 additions & 0 deletions src/__tests__/HanziWriter-test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -708,6 +708,44 @@ describe('HanziWriter', () => {
expect(onComplete).toHaveBeenCalledTimes(1);
expect(onComplete).toHaveBeenCalledWith({ canceled: false });
});

it("doesn't freeze and leave the highlight showing if another highlight happens before the first finishes", async () => {
document.body.innerHTML = '<div id="target"></div>';
const writer = HanziWriter.create('target', '人', {
showCharacter: true,
charDataLoader,
});
await writer._withDataPromise;

let stroke1Resolved = false;
let stroke1ResolvedVal;
const onComplete1 = jest.fn();

// start highlighting the first stroke
writer.highlightStroke(0, { onComplete: onComplete1 }).then((result) => {
stroke1Resolved = true;
stroke1ResolvedVal = result;
});

await resolvePromises();
clock.tick(200);
await resolvePromises();
expect(writer._renderState!.state.character.highlight.strokes[0].opacity).not.toBe(
0,
);

expect(stroke1Resolved).toBe(false);

// starting another stroke highlight cancels the first one
// NOTE: In the future this may not be the case, there's no reason we can't have strokes animate independently
writer.highlightStroke(1);

await resolvePromises();
expect(stroke1Resolved).toBe(true);
expect(stroke1ResolvedVal).toEqual({ canceled: true });

expect(writer._renderState!.state.character.highlight.strokes[0].opacity).toBe(0);
});
});

describe('loopCharacterAnimation', () => {
Expand Down
5 changes: 4 additions & 1 deletion src/characterActions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,10 @@ export const highlightStroke = (
},
{ duration },
),
new Mutation(`character.highlight.strokes.${strokeNum}.opacity`, 0, { duration }),
new Mutation(`character.highlight.strokes.${strokeNum}.opacity`, 0, {
duration,
force: true,
}),
];
};

Expand Down

0 comments on commit 13852e7

Please sign in to comment.