Add logger dependency and replace console logging
- Import LoggerComponent from ior:gitea:gitea.metatrom.net:universal-components/logger@1.0.0 - Replace console.warn and console.info with appropriate logger methods - Use warn level for fallback scenarios when native implementations fail - Use info level for polyfill installation notifications 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
@@ -6,6 +6,7 @@
|
|||||||
* @module text-encoding@1.0.0
|
* @module text-encoding@1.0.0
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
import { LoggerComponent } from 'ior:gitea:gitea.metatrom.net:universal-components/logger@1.0.0';
|
||||||
import { TextDecoderPolyfill } from './TextDecoderPolyfill';
|
import { TextDecoderPolyfill } from './TextDecoderPolyfill';
|
||||||
import { TextEncoderPolyfill } from './TextEncoderPolyfill';
|
import { TextEncoderPolyfill } from './TextEncoderPolyfill';
|
||||||
import type {
|
import type {
|
||||||
@@ -17,6 +18,7 @@ import type {
|
|||||||
|
|
||||||
export class TextEncodingFactory implements ITextEncodingFactory {
|
export class TextEncodingFactory implements ITextEncodingFactory {
|
||||||
private static instance: TextEncodingFactory;
|
private static instance: TextEncodingFactory;
|
||||||
|
private static logger = new LoggerComponent('TextEncodingFactory');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get factory singleton instance
|
* Get factory singleton instance
|
||||||
@@ -40,7 +42,7 @@ export class TextEncodingFactory implements ITextEncodingFactory {
|
|||||||
return new TextEncoder();
|
return new TextEncoder();
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
// Fall back to polyfill if native fails
|
// Fall back to polyfill if native fails
|
||||||
console.warn('[TextEncodingFactory] Native TextEncoder failed, using polyfill:', e);
|
TextEncodingFactory.logger.warn('Native TextEncoder failed, using polyfill:', e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -59,7 +61,7 @@ export class TextEncodingFactory implements ITextEncodingFactory {
|
|||||||
return new TextDecoder(label, options);
|
return new TextDecoder(label, options);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
// Fall back to polyfill if native fails
|
// Fall back to polyfill if native fails
|
||||||
console.warn('[TextEncodingFactory] Native TextDecoder failed, using polyfill:', e);
|
TextEncodingFactory.logger.warn('Native TextDecoder failed, using polyfill:', e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -113,20 +115,22 @@ export function createTextDecoder(label?: string, options?: TextDecoderOptions):
|
|||||||
* This makes TextEncoder/TextDecoder available everywhere
|
* This makes TextEncoder/TextDecoder available everywhere
|
||||||
*/
|
*/
|
||||||
export function installTextEncodingPolyfills(): void {
|
export function installTextEncodingPolyfills(): void {
|
||||||
|
const logger = new LoggerComponent('TextEncodingPolyfills');
|
||||||
|
|
||||||
// @ts-expect-error
|
// @ts-expect-error
|
||||||
if (typeof global !== 'undefined') {
|
if (typeof global !== 'undefined') {
|
||||||
// @ts-expect-error
|
// @ts-expect-error
|
||||||
if (typeof global.TextEncoder === 'undefined') {
|
if (typeof global.TextEncoder === 'undefined') {
|
||||||
// @ts-expect-error
|
// @ts-expect-error
|
||||||
global.TextEncoder = TextEncoderPolyfill;
|
global.TextEncoder = TextEncoderPolyfill;
|
||||||
console.info('[TextEncodingFactory] Installed TextEncoder polyfill globally');
|
logger.info('Installed TextEncoder polyfill globally');
|
||||||
}
|
}
|
||||||
|
|
||||||
// @ts-expect-error
|
// @ts-expect-error
|
||||||
if (typeof global.TextDecoder === 'undefined') {
|
if (typeof global.TextDecoder === 'undefined') {
|
||||||
// @ts-expect-error
|
// @ts-expect-error
|
||||||
global.TextDecoder = TextDecoderPolyfill;
|
global.TextDecoder = TextDecoderPolyfill;
|
||||||
console.info('[TextEncodingFactory] Installed TextDecoder polyfill globally');
|
logger.info('Installed TextDecoder polyfill globally');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user