Compare commits

...

22 Commits

Author SHA1 Message Date
5ce92130b4 2.3.2 2025-02-01 00:32:57 +01:00
b0774b0cba fix(scroller): Rename method from scrollToElement to toElement for consistency 2025-02-01 00:32:56 +01:00
c44e19f3e0 2.3.1 2025-01-31 23:57:07 +01:00
07f09b4457 fix(scroller): Removed passive option from scroll event listener 2025-01-31 23:57:07 +01:00
10ea4ca265 2.3.0 2025-01-31 23:10:33 +01:00
dfd61ce744 feat(scroller): Enhance Scroller class with callback execution and adaptive scroll listener 2025-01-31 23:10:33 +01:00
3093ccd4f6 2.2.0 2025-01-31 23:03:10 +01:00
eb1ac75e49 feat(core): Enhance scrolling capabilities by integrating Scroller class and adding lenis support 2025-01-31 23:03:10 +01:00
0683378e39 2.1.1 2025-01-09 00:33:46 +01:00
25a813d35f fix(themamanager): Fixed automatic global theme change subscription for background updates. 2025-01-09 00:33:46 +01:00
916fd48858 2.1.0 2025-01-09 00:24:17 +01:00
90bb1eb432 feat(themeManager): Exposed method to enable automatic global theme change. 2025-01-09 00:24:17 +01:00
126e0fc900 2.0.65 2024-10-21 17:25:08 +02:00
a20b321bb0 fix(ThemeManager): Refactor ThemeManager class to separate global style setting logic 2024-10-21 17:25:08 +02:00
33721f86ab 2.0.64 2024-10-06 23:37:21 +02:00
987c821eed fix(pluginexports): Add missing import for smartrouter in pluginexports. 2024-10-06 23:37:21 +02:00
b0bed44810 2.0.63 2024-10-06 23:31:45 +02:00
0a7da5132d fix(dependencies): Update @push.rocks/smartrouter to version ^1.3.2 for better compatibility 2024-10-06 23:31:44 +02:00
b0bb8e9e2b 2.0.62 2024-10-06 21:42:11 +02:00
1f346e24db fix(dependencies): Update dependencies to resolve potential issues and improve stability 2024-10-06 21:42:10 +02:00
c34cca7eb6 2.0.61 2024-10-04 15:28:01 +02:00
15e58fbf5d fix(core): Correct import statement for SweetScroll. 2024-10-04 15:28:01 +02:00
9 changed files with 4308 additions and 984 deletions

View File

@ -1,5 +1,65 @@
# Changelog
## 2025-02-01 - 2.3.2 - fix(scroller)
Rename method from scrollToElement to toElement for consistency
- Updated method name in Scroller class for better coherence with existing naming conventions.
## 2025-01-31 - 2.3.1 - fix(scroller)
Removed passive option from scroll event listener
- The 'passive: true' option was removed from the native scroll event listener attachment.
## 2025-01-31 - 2.3.0 - feat(scroller)
Enhance Scroller class with callback execution and adaptive scroll listener
- Added support for executing scroll callbacks in the Scroller class.
- Integrated adaptive scrolling mechanism using Lenis, with native smooth scrolling detection.
- Ensured seamless switching between native scroll listener and Lenis scroll listener.
## 2025-01-31 - 2.2.0 - feat(core)
Enhance scrolling capabilities by integrating Scroller class and adding lenis support
- Replaced SweetScroll setup in domtools.classes.domtools.ts with Scroller class.
- Moved SweetScroll initialization and methods to new Scroller class.
- Added lenis support in the Scroller class for enhanced scrolling capabilities.
- Updated dev and dependencies versions in package.json.
## 2025-01-09 - 2.1.1 - fix(themamanager)
Fixed automatic global theme change subscription for background updates.
- Corrected the logic for updating the document's background color upon theme changes using themeObservable subscription.
## 2025-01-09 - 2.1.0 - feat(themeManager)
Exposed method to enable automatic global theme change.
- Enable easier application of dark and bright themes by exposing a method.
- Updated devDependencies and dependencies in package.json to latest versions.
## 2024-10-21 - 2.0.65 - fix(ThemeManager)
Refactor ThemeManager class to separate global style setting logic
- Moved logic to set global styles into a dedicated function setGlobalStylesOnPurpose in ThemeManager.
## 2024-10-06 - 2.0.64 - fix(pluginexports)
Add missing import for smartrouter in pluginexports.
- Fixed a missing import for smartrouter in ts/domtools.pluginexports.ts.
## 2024-10-06 - 2.0.63 - fix(dependencies)
Update @push.rocks/smartrouter to version ^1.3.2 for better compatibility
- Updated @push.rocks/smartrouter from version ^1.2.1 to ^1.3.2 in package.json.
## 2024-10-06 - 2.0.62 - fix(dependencies)
Update dependencies to resolve potential issues and improve stability
## 2024-10-04 - 2.0.61 - fix(core)
Correct import statement for SweetScroll.
- Fix import syntax for SweetScroll in domtools.pluginexports.ts
## 2024-10-02 - 2.0.60 - fix(dependencies)
Update dependencies to latest versions

View File

@ -1,6 +1,6 @@
{
"name": "@design.estate/dees-domtools",
"version": "2.0.60",
"version": "2.3.2",
"private": false,
"description": "A package providing tools to simplify complex CSS structures and web development tasks, featuring TypeScript support and integration with various web technologies.",
"main": "dist_ts/index.js",
@ -15,29 +15,30 @@
"buildDocs": "tsdoc"
},
"devDependencies": {
"@git.zone/tsbuild": "^2.1.84",
"@git.zone/tsbundle": "^2.0.15",
"@git.zone/tstest": "^1.0.90",
"@push.rocks/tapbundle": "^5.3.0",
"@types/node": "^22.7.4"
"@git.zone/tsbuild": "^2.2.1",
"@git.zone/tsbundle": "^2.2.5",
"@git.zone/tstest": "^1.0.96",
"@push.rocks/tapbundle": "^5.5.6",
"@types/node": "^22.12.0"
},
"dependencies": {
"@api.global/typedrequest": "^3.0.32",
"@api.global/typedrequest": "^3.1.10",
"@design.estate/dees-comms": "^1.0.27",
"@push.rocks/lik": "^6.0.15",
"@push.rocks/lik": "^6.1.0",
"@push.rocks/smartdelay": "^3.0.5",
"@push.rocks/smartjson": "^5.0.20",
"@push.rocks/smartmarkdown": "^3.0.3",
"@push.rocks/smartpromise": "^4.0.4",
"@push.rocks/smartrouter": "^1.0.16",
"@push.rocks/smartpromise": "^4.2.2",
"@push.rocks/smartrouter": "^1.3.2",
"@push.rocks/smartrx": "^3.0.7",
"@push.rocks/smartstate": "^2.0.18",
"@push.rocks/smartstate": "^2.0.19",
"@push.rocks/smartstring": "^4.0.15",
"@push.rocks/smarturl": "^3.0.6",
"@push.rocks/smarturl": "^3.1.0",
"@push.rocks/webrequest": "^3.0.37",
"@push.rocks/websetup": "^3.0.19",
"@push.rocks/webstore": "^2.0.20",
"lit": "^3.2.0",
"lenis": "^1.1.20",
"lit": "^3.2.1",
"sweet-scroll": "^4.0.0"
},
"files": [

5007
pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff

View File

@ -3,6 +3,6 @@
*/
export const commitinfo = {
name: '@design.estate/dees-domtools',
version: '2.0.60',
version: '2.3.2',
description: 'A package providing tools to simplify complex CSS structures and web development tasks, featuring TypeScript support and integration with various web technologies.'
}

View File

@ -93,9 +93,7 @@ export class DomTools {
};
public deesComms = new plugins.deesComms.DeesComms();
public scroller = new plugins.SweetScroll({
/* some options */
}); // TODO: switch to scroller class
public scroller = new Scroller(this);
public themeManager = new ThemeManager(this);
public keyboard = new Keyboard(document.body);

View File

@ -1,5 +1,175 @@
import type { DomTools } from './domtools.classes.domtools.js';
import * as plugins from './domtools.plugins.js';
export class Scroller {
// TODO: move sweet scroll over to here;
}
public domtoolsInstance: DomTools;
// Array to store scroll callback functions.
private scrollCallbacks: Array<() => void> = [];
// Lenis instance (if activated) or null.
private lenisInstance: plugins.Lenis | null = null;
// Bound handlers to allow removal from event listeners.
private handleNativeScroll = (event: Event): void => {
this.executeScrollCallbacks();
};
private handleLenisScroll = (info: any): void => {
this.executeScrollCallbacks();
};
constructor(domtoolsInstanceArg: DomTools) {
this.domtoolsInstance = domtoolsInstanceArg;
// Attach the native scroll listener by default.
this.attachNativeScrollListener();
}
private sweetScroller = new plugins.SweetScroll({});
/**
* Scrolls to a given element with options.
*/
public async toElement(
elementArg: HTMLElement,
optionsArg: Parameters<typeof this.sweetScroller.toElement>[1]
) {
this.sweetScroller.toElement(elementArg, optionsArg);
await plugins.smartdelay.delayFor(optionsArg.duration);
}
/**
* Detects whether native smooth scrolling is enabled.
*/
public async detectNativeSmoothScroll() {
const done = plugins.smartpromise.defer<boolean>();
const sampleSize = 100;
const acceptableDeltaDifference = 3;
const minimumSmoothRatio = 0.75;
const eventDeltas: number[] = [];
function onWheel(event: WheelEvent) {
eventDeltas.push(event.deltaY);
if (eventDeltas.length >= sampleSize) {
window.removeEventListener('wheel', onWheel);
analyzeEvents();
}
}
function analyzeEvents() {
const totalDiffs = eventDeltas.length - 1;
let smallDiffCount = 0;
for (let i = 0; i < totalDiffs; i++) {
const diff = Math.abs(eventDeltas[i + 1] - eventDeltas[i]);
if (diff <= acceptableDeltaDifference) {
smallDiffCount++;
}
}
const smoothRatio = smallDiffCount / totalDiffs;
if (smoothRatio >= minimumSmoothRatio) {
console.log('Smooth scrolling detected.');
done.resolve(true);
} else {
console.log('Smooth scrolling NOT detected.');
done.resolve(false);
}
}
window.addEventListener('wheel', onWheel);
return done.promise;
}
/**
* Enables Lenis scrolling.
* If optionsArg.disableOnNativeSmoothScroll is true and native smooth scrolling is detected,
* Lenis will be destroyed immediately.
*/
public async enableLenisScroll(optionsArg?: { disableOnNativeSmoothScroll?: boolean }) {
const lenis = new plugins.Lenis({
autoRaf: true,
});
if (optionsArg?.disableOnNativeSmoothScroll) {
if (await this.detectNativeSmoothScroll()) {
lenis.destroy();
return;
}
}
// Activate Lenis scrolling.
this.lenisInstance = lenis;
// Switch from native scroll listener to Lenis scroll listener.
this.detachNativeScrollListener();
this.attachLenisScrollListener();
// Monkey-patch the destroy method so that when Lenis is destroyed,
// the native scroll listener is reattached.
const originalDestroy = lenis.destroy.bind(lenis);
lenis.destroy = () => {
originalDestroy();
this.detachLenisScrollListener();
this.attachNativeScrollListener();
this.lenisInstance = null;
};
}
/**
* Registers a callback to be executed on scroll.
* @param callback A function to execute on each scroll event.
*/
public onScroll(callback: () => void): void {
this.scrollCallbacks.push(callback);
}
/**
* Executes all registered scroll callbacks concurrently.
*/
private executeScrollCallbacks(): void {
// Execute all callbacks in parallel.
this.scrollCallbacks.forEach((callback) => {
try {
callback();
} catch (error) {
console.error('Error in scroll callback:', error);
}
});
}
/**
* Attaches the native scroll event listener.
*/
private attachNativeScrollListener(): void {
window.addEventListener('scroll', this.handleNativeScroll);
}
/**
* Detaches the native scroll event listener.
*/
private detachNativeScrollListener(): void {
window.removeEventListener('scroll', this.handleNativeScroll);
}
/**
* Attaches the Lenis scroll event listener.
*/
private attachLenisScrollListener(): void {
if (this.lenisInstance) {
// Assuming that Lenis exposes an `on` method to listen to scroll events.
this.lenisInstance.on('scroll', this.handleLenisScroll);
}
}
/**
* Detaches the Lenis scroll event listener.
*/
private detachLenisScrollListener(): void {
if (this.lenisInstance) {
// Assuming that Lenis exposes an `off` method to remove scroll event listeners.
this.lenisInstance.off('scroll', this.handleLenisScroll);
}
}
}

View File

@ -21,10 +21,17 @@ export class ThemeManager {
this.updateAllConnectedElements();
}
private async updateAllConnectedElements() {
public async enableAutomaticGlobalThemeChange() {
if (document.body && document.body.style) {
document.body.style.background = this.goBrightBoolean ? '#fff' : '#000';
this.themeObservable.subscribe({
next: (goBright) => {
document.body.style.background = goBright ? '#fff' : '#000';
}
});
}
}
private async updateAllConnectedElements() {
this.themeObservable.next(this.goBrightBoolean);
}

View File

@ -1,8 +1,9 @@
import * as smartdelay from '@push.rocks/smartdelay';
import * as smartmarkdown from '@push.rocks/smartmarkdown';
import * as smartpromise from '@push.rocks/smartpromise';
import * as SweetScroll from 'sweet-scroll';
import SweetScroll from 'sweet-scroll';
import * as smartstate from '@push.rocks/smartstate';
import * as smartrouter from '@push.rocks/smartrouter';
import * as smartrx from '@push.rocks/smartrx';
import * as smartstring from '@push.rocks/smartstring';
import * as smarturl from '@push.rocks/smarturl';
@ -14,6 +15,7 @@ export {
smartpromise,
SweetScroll,
smartstate,
smartrouter,
smartrx,
smartstring,
smarturl,

View File

@ -49,6 +49,7 @@ export {
};
// third party scope
import Lenis from 'lenis'
import SweetScroll from 'sweet-scroll';
export { SweetScroll };
export { Lenis, SweetScroll };