-
-
Notifications
You must be signed in to change notification settings - Fork 213
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix: [#1161] Implement DOMReact and DOMReactReadOnly interfaces
- Loading branch information
Showing
6 changed files
with
341 additions
and
23 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,30 +1,46 @@ | ||
import DOMRectReadOnly, { IDOMRectInit, IDOMRectInit } from './DOMRectReadOnly.js'; | ||
|
||
/* eslint-disable jsdoc/require-jsdoc */ | ||
|
||
/** | ||
* Bounding rect object. | ||
* | ||
* @see https://developer.mozilla.org/en-US/docs/Web/API/DOMRect | ||
*/ | ||
export default class DOMRect { | ||
public x = 0; | ||
public y = 0; | ||
public width = 0; | ||
public height = 0; | ||
public top = 0; | ||
public right = 0; | ||
public bottom = 0; | ||
public left = 0; | ||
|
||
/** | ||
* Constructor. | ||
* | ||
* @param [x] X position. | ||
* @param [y] Y position. | ||
* @param [width] Width. | ||
* @param [height] Height. | ||
*/ | ||
constructor(x?, y?, width?, height?) { | ||
this.x = x || 0; | ||
this.y = y || 0; | ||
this.width = width || 0; | ||
this.height = height || 0; | ||
export default class DOMRect extends DOMRectReadOnly { | ||
public set x(value: number) { | ||
this._x = value; | ||
} | ||
|
||
public get x(): number { | ||
return this._x; | ||
} | ||
|
||
public set y(value: number) { | ||
this._y = value; | ||
} | ||
|
||
public get y(): number { | ||
return this._y; | ||
} | ||
|
||
public set width(value: number) { | ||
this._width = value; | ||
} | ||
|
||
public get width(): number { | ||
return this._width; | ||
} | ||
|
||
public set height(value: number) { | ||
this._height = value; | ||
} | ||
|
||
public get height(): number { | ||
return this._height; | ||
} | ||
|
||
public static fromRect(other: IDOMRectInit): DOMRect { | ||
return new DOMRect(other.x, other.y, other.width, other.height); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,84 @@ | ||
/* eslint-disable jsdoc/require-jsdoc */ | ||
|
||
/** | ||
* Bounding rect readonly object. | ||
* | ||
* @see https://drafts.fxtf.org/geometry/#DOMRect | ||
*/ | ||
export default class DOMRectReadOnly implements IDOMRectInit { | ||
protected _x: number = 0; | ||
protected _y: number = 0; | ||
protected _width: number = 0; | ||
protected _height: number = 0; | ||
|
||
/** | ||
* Constructor. | ||
* | ||
* @param [x] X position. | ||
* @param [y] Y position. | ||
* @param [width] Width. | ||
* @param [height] Height. | ||
*/ | ||
constructor(x?: number, y?: number, width?: number, height?: number) { | ||
this._x = x || 0; | ||
this._y = y || 0; | ||
this._width = width || 0; | ||
this._height = height || 0; | ||
} | ||
|
||
public get x(): number { | ||
return this._x; | ||
} | ||
|
||
public get y(): number { | ||
return this._y; | ||
} | ||
|
||
public get width(): number { | ||
return this._width; | ||
} | ||
|
||
public get height(): number { | ||
return this._height; | ||
} | ||
|
||
public get top(): number { | ||
return Math.min(this._y, this._y + this._height); | ||
} | ||
|
||
public get right(): number { | ||
return Math.max(this._x, this._x + this._width); | ||
} | ||
|
||
public get bottom(): number { | ||
return Math.max(this._y, this._y + this._height); | ||
} | ||
|
||
public get left(): number { | ||
return Math.min(this._x, this._x + this._width); | ||
} | ||
|
||
public toJSON(): object { | ||
return { | ||
x: this.x, | ||
y: this.y, | ||
width: this.width, | ||
height: this.height, | ||
top: this.top, | ||
right: this.right, | ||
bottom: this.bottom, | ||
left: this.left | ||
}; | ||
} | ||
|
||
public static fromRect(other: IDOMRectInit): DOMRectReadOnly { | ||
return new DOMRectReadOnly(other.x, other.y, other.width, other.height); | ||
} | ||
} | ||
|
||
export interface IDOMRectInit { | ||
readonly x: number; | ||
readonly y: number; | ||
readonly width: number; | ||
readonly height: number; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,123 @@ | ||
import { afterEach, describe, it, expect, vi } from 'vitest'; | ||
import DOMRect from '../../../src/nodes/element/DOMRect'; | ||
|
||
describe('DOMRect', () => { | ||
afterEach(() => { | ||
vi.restoreAllMocks(); | ||
}); | ||
|
||
describe('set x()', () => { | ||
it('Sets rect x property.', () => { | ||
const rect = new DOMRect(1, 2, 3, 4); | ||
rect.x = 2; | ||
expect(rect.x).toBe(2); | ||
}); | ||
}); | ||
|
||
describe('get x()', () => { | ||
it('Returns rect x property.', () => { | ||
const rect = new DOMRect(1, 2, 3, 4); | ||
expect(rect.x).toBe(1); | ||
}); | ||
}); | ||
|
||
describe('set y()', () => { | ||
it('Sets rect y property.', () => { | ||
const rect = new DOMRect(1, 2, 3, 4); | ||
rect.y = 3; | ||
expect(rect.y).toBe(3); | ||
}); | ||
}); | ||
|
||
describe('get y()', () => { | ||
it('Returns rect y property.', () => { | ||
const rect = new DOMRect(1, 2, 3, 4); | ||
expect(rect.y).toBe(2); | ||
}); | ||
}); | ||
|
||
describe('set width()', () => { | ||
it('Sets rect y property.', () => { | ||
const rect = new DOMRect(1, 2, 3, 4); | ||
rect.width = 4; | ||
expect(rect.width).toBe(4); | ||
}); | ||
}); | ||
|
||
describe('get width()', () => { | ||
it('Returns rect y property.', () => { | ||
const rect = new DOMRect(1, 2, 3, 4); | ||
expect(rect.width).toBe(3); | ||
}); | ||
}); | ||
|
||
describe('set height()', () => { | ||
it('Sets rect height property.', () => { | ||
const rect = new DOMRect(1, 2, 3, 4); | ||
rect.height = 5; | ||
expect(rect.height).toBe(5); | ||
}); | ||
}); | ||
|
||
describe('get height()', () => { | ||
it('Returns rect height property.', () => { | ||
const rect = new DOMRect(1, 2, 3, 4); | ||
expect(rect.height).toBe(4); | ||
}); | ||
}); | ||
|
||
describe('get top()', () => { | ||
it('Returns rect top property.', () => { | ||
const rect = new DOMRect(1, 2, 3, 4); | ||
expect(rect.top).toBe(2); | ||
}); | ||
}); | ||
|
||
describe('get right()', () => { | ||
it('Returns rect right property.', () => { | ||
const rect = new DOMRect(1, 2, 3, 4); | ||
expect(rect.right).toBe(4); | ||
}); | ||
}); | ||
|
||
describe('get bottom()', () => { | ||
it('Returns rect bottom property.', () => { | ||
const rect = new DOMRect(1, 2, 3, 4); | ||
expect(rect.bottom).toBe(6); | ||
}); | ||
}); | ||
|
||
describe('get left()', () => { | ||
it('Returns rect left property.', () => { | ||
const rect = new DOMRect(1, 2, 3, 4); | ||
expect(rect.left).toBe(1); | ||
}); | ||
}); | ||
|
||
describe('fromRect()', () => { | ||
it('Creates DOMRect instance', () => { | ||
const rect = DOMRect.fromRect({ x: 1, y: 2, width: 3, height: 4 }); | ||
expect(rect instanceof DOMRect).toBe(true); | ||
expect(rect.x).toBe(1); | ||
expect(rect.y).toBe(2); | ||
expect(rect.width).toBe(3); | ||
expect(rect.height).toBe(4); | ||
}); | ||
}); | ||
|
||
describe('toJSON()', () => { | ||
it('Returns rect as JSON.', () => { | ||
const rect = new DOMRect(1, 2, 3, 4); | ||
expect(rect.toJSON()).toEqual({ | ||
x: 1, | ||
y: 2, | ||
width: 3, | ||
height: 4, | ||
top: 2, | ||
right: 4, | ||
bottom: 6, | ||
left: 1 | ||
}); | ||
}); | ||
}); | ||
}); |
Oops, something went wrong.