Skip to content

Commit

Permalink
#26 Make glitch() idempotent to allow successive glitch calls on the …
Browse files Browse the repository at this point in the history
…same query selector
  • Loading branch information
7PH committed May 30, 2024
1 parent c61233d commit 2fe91f3
Show file tree
Hide file tree
Showing 2 changed files with 41 additions and 12 deletions.
12 changes: 11 additions & 1 deletion src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -448,6 +448,7 @@ const glitchElement = (element: HTMLElement, layers: LayerDefinition[], options:

// Base layer
const baseLayer = glitched.cloneNode(true) as HTMLElement;
baseLayer.dataset.islayer = 'true';
// Stack this layer
baseLayer.style.gridArea = '1/1/-1/-1';
baseLayer.style.userSelect = 'none';
Expand Down Expand Up @@ -564,7 +565,16 @@ const glitch = (elOrSelector: GlitchableElement = '.powerglitch', userOptions: G
const layers = generateLayers(options);

// Animate each div element
const entries = elements.map(element => glitchElement(element, layers, options));
const entries = elements
/**
* When calling glitch(..) multiple times on the same element using query selector, glitch layers will also match the selector.
* Only the root-layer (base element) should be glitched, so we ensure we filter out non-root glitch layers.
*/
.filter(element => !element.dataset.islayer)
// Each element is glitched using the same layer definition.
.map((element) =>
glitchElement(element, layers, options)
);

// Return list of containers and glitch control functions
return {
Expand Down
41 changes: 30 additions & 11 deletions test/powerglitch.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -122,17 +122,36 @@ describe('Given one or multiple element(s) to glitch', () => {
});

describe('Given glitching more than once the same element', () => {
/**
* Glitching twice an element should reset its animation
*/
testAllElementTypes('overrides glitch on second call', async elementType => {
const { element } = init(ELEMENTS[elementType]);
const { containers: containers1 } = PowerGlitch.glitch(element, { ...baseOptions, slice: { count: 10 } });
expect(containers1.length).toBe(1);
expect(containers1[0].firstElementChild?.children.length).toBe(11);
const { containers: containers2 } = PowerGlitch.glitch(element, { ...baseOptions, slice: { count: 20 } });
expect(containers2.length).toBe(1);
expect(containers2[0].firstElementChild?.children.length).toBe(21);
describe('overrides options on successive call', () => {
testAllElementTypes('using element reference', async elementType => {
const { element } = init(ELEMENTS[elementType]);
const { containers: containers1 } = PowerGlitch.glitch(element, { ...baseOptions, slice: { count: 10 } });
expect(containers1.length).toBe(1);
expect(containers1[0].firstElementChild?.children.length).toBe(11);

const { containers: containers2 } = PowerGlitch.glitch(element, { ...baseOptions, slice: { count: 20 } });
expect(containers2.length).toBe(1);
expect(containers2[0].firstElementChild?.children.length).toBe(21);

const { containers: containers3 } = PowerGlitch.glitch(element, { ...baseOptions, slice: { count: 15 } });
expect(containers3.length).toBe(1);
expect(containers3[0].firstElementChild?.children.length).toBe(16);
});

testAllElementTypes('using query selector', async elementType => {
init(ELEMENTS[elementType]);
const { containers: containers1 } = PowerGlitch.glitch('.glitch', { ...baseOptions, slice: { count: 10 } });
expect(containers1.length).toBe(1);
expect(containers1[0].firstElementChild?.children.length).toBe(11);

const { containers: containers2 } = PowerGlitch.glitch('.glitch', { ...baseOptions, slice: { count: 20 } });
expect(containers2.length).toBe(1);
expect(containers2[0].firstElementChild?.children.length).toBe(21);

const { containers: containers3 } = PowerGlitch.glitch('.glitch', { ...baseOptions, slice: { count: 15 } });
expect(containers3.length).toBe(1);
expect(containers3[0].firstElementChild?.children.length).toBe(16);
});
});
});

Expand Down

0 comments on commit 2fe91f3

Please sign in to comment.