@2112-lab/central-plant 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (54) hide show
  1. package/README.md +0 -0
  2. package/dist/bundle/index.js +14259 -0
  3. package/dist/cjs/_virtual/_rollupPluginBabelHelpers.js +353 -0
  4. package/dist/cjs/node_modules/three/examples/jsm/controls/OrbitControls.js +1292 -0
  5. package/dist/cjs/node_modules/three/examples/jsm/controls/TransformControls.js +1543 -0
  6. package/dist/cjs/node_modules/three/examples/jsm/loaders/GLTFLoader.js +4374 -0
  7. package/dist/cjs/node_modules/three/examples/jsm/loaders/RGBELoader.js +465 -0
  8. package/dist/cjs/node_modules/three/examples/jsm/utils/BufferGeometryUtils.js +117 -0
  9. package/dist/cjs/src/ConnectionManager.js +114 -0
  10. package/dist/cjs/src/Pathfinder.js +88 -0
  11. package/dist/cjs/src/animationManager.js +121 -0
  12. package/dist/cjs/src/componentManager.js +151 -0
  13. package/dist/cjs/src/debugLogger.js +176 -0
  14. package/dist/cjs/src/disposalManager.js +185 -0
  15. package/dist/cjs/src/environmentManager.js +1015 -0
  16. package/dist/cjs/src/hotReloadManager.js +252 -0
  17. package/dist/cjs/src/index.js +126 -0
  18. package/dist/cjs/src/keyboardControlsManager.js +206 -0
  19. package/dist/cjs/src/modelPreloader.js +360 -0
  20. package/dist/cjs/src/nameUtils.js +106 -0
  21. package/dist/cjs/src/pathfindingManager.js +321 -0
  22. package/dist/cjs/src/performanceMonitor.js +718 -0
  23. package/dist/cjs/src/sceneExportManager.js +292 -0
  24. package/dist/cjs/src/sceneInitializationManager.js +540 -0
  25. package/dist/cjs/src/sceneOperationsManager.js +560 -0
  26. package/dist/cjs/src/textureConfig.js +195 -0
  27. package/dist/cjs/src/transformControlsManager.js +851 -0
  28. package/dist/esm/_virtual/_rollupPluginBabelHelpers.js +328 -0
  29. package/dist/esm/node_modules/three/examples/jsm/controls/OrbitControls.js +1287 -0
  30. package/dist/esm/node_modules/three/examples/jsm/controls/TransformControls.js +1537 -0
  31. package/dist/esm/node_modules/three/examples/jsm/loaders/GLTFLoader.js +4370 -0
  32. package/dist/esm/node_modules/three/examples/jsm/loaders/RGBELoader.js +461 -0
  33. package/dist/esm/node_modules/three/examples/jsm/utils/BufferGeometryUtils.js +113 -0
  34. package/dist/esm/src/ConnectionManager.js +110 -0
  35. package/dist/esm/src/Pathfinder.js +84 -0
  36. package/dist/esm/src/animationManager.js +112 -0
  37. package/dist/esm/src/componentManager.js +123 -0
  38. package/dist/esm/src/debugLogger.js +167 -0
  39. package/dist/esm/src/disposalManager.js +155 -0
  40. package/dist/esm/src/environmentManager.js +989 -0
  41. package/dist/esm/src/hotReloadManager.js +244 -0
  42. package/dist/esm/src/index.js +117 -0
  43. package/dist/esm/src/keyboardControlsManager.js +196 -0
  44. package/dist/esm/src/modelPreloader.js +337 -0
  45. package/dist/esm/src/nameUtils.js +99 -0
  46. package/dist/esm/src/pathfindingManager.js +295 -0
  47. package/dist/esm/src/performanceMonitor.js +712 -0
  48. package/dist/esm/src/sceneExportManager.js +286 -0
  49. package/dist/esm/src/sceneInitializationManager.js +513 -0
  50. package/dist/esm/src/sceneOperationsManager.js +536 -0
  51. package/dist/esm/src/textureConfig.js +168 -0
  52. package/dist/esm/src/transformControlsManager.js +827 -0
  53. package/dist/index.d.ts +259 -0
  54. package/package.json +53 -0
@@ -0,0 +1,252 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var _rollupPluginBabelHelpers = require('../_virtual/_rollupPluginBabelHelpers.js');
6
+
7
+ /**
8
+ * Hot-Reload Manager Module
9
+ * Handles development environment hot-reload detection and cleanup
10
+ */
11
+
12
+ // Check if we're in a browser environment
13
+ var isBrowser = typeof window !== 'undefined';
14
+ var isDev = isBrowser && process.env.NODE_ENV === 'development';
15
+ var HotReloadManager = /*#__PURE__*/function () {
16
+ function HotReloadManager(componentInstance) {
17
+ _rollupPluginBabelHelpers.classCallCheck(this, HotReloadManager);
18
+ this.component = componentInstance;
19
+ this.isDev = isDev;
20
+ this.instanceId = Date.now() + Math.random();
21
+
22
+ // Event handlers
23
+ this.hotReloadCleanupHandler = null;
24
+ this.visibilityChangeHandler = null;
25
+ this.nuxtHotReloadHandler = null;
26
+ this.memoryCheckInterval = null;
27
+
28
+ // Async operation tracking
29
+ this.timeoutIds = new Set();
30
+ this.intervalIds = new Set();
31
+ }
32
+
33
+ /**
34
+ * Setup hot-reload handling for development environment
35
+ */
36
+ return _rollupPluginBabelHelpers.createClass(HotReloadManager, [{
37
+ key: "setupHotReloadHandling",
38
+ value: function setupHotReloadHandling() {
39
+ var _this = this;
40
+ if (!isBrowser || !this.isDev) {
41
+ console.log('Not in browser or development mode, skipping hot-reload setup');
42
+ return;
43
+ }
44
+ console.log('Setting up hot-reload handling...');
45
+
46
+ // Initialize global instance tracking
47
+ if (!window._sceneViewerInstances) {
48
+ window._sceneViewerInstances = new Set();
49
+ console.log('🔧 [Hot-Reload] Initialized global instance tracking');
50
+ }
51
+
52
+ // Add this instance to global tracking
53
+ window._sceneViewerInstances.add(this.component);
54
+ console.log('📍 [Hot-Reload] Instance registered:', {
55
+ instanceId: this.instanceId,
56
+ totalInstances: window._sceneViewerInstances.size
57
+ });
58
+
59
+ // Enhanced beforeunload handler for development
60
+ this.hotReloadCleanupHandler = function () {
61
+ console.log('🔄 [Hot-Reload] Page unload detected, performing enhanced cleanup');
62
+ if (_this.component && typeof _this.component.enhancedDisposal === 'function') {
63
+ _this.component.enhancedDisposal();
64
+ }
65
+ if (window._sceneViewerInstances) {
66
+ window._sceneViewerInstances.delete(_this.component);
67
+ }
68
+ };
69
+
70
+ // Add event listeners
71
+ window.addEventListener('beforeunload', this.hotReloadCleanupHandler);
72
+ window.addEventListener('pagehide', this.hotReloadCleanupHandler);
73
+ console.log('✅ [Hot-Reload] Hot-reload handling setup completed');
74
+ }
75
+
76
+ /**
77
+ * Cleanup hot-reload handlers (development only)
78
+ */
79
+ }, {
80
+ key: "cleanupHotReloadHandlers",
81
+ value: function cleanupHotReloadHandlers() {
82
+ if (!isBrowser || !this.isDev) return;
83
+
84
+ // Remove event listeners
85
+ if (this.hotReloadCleanupHandler) {
86
+ window.removeEventListener('beforeunload', this.hotReloadCleanupHandler);
87
+ window.removeEventListener('pagehide', this.hotReloadCleanupHandler);
88
+ this.hotReloadCleanupHandler = null;
89
+ }
90
+ if (this.visibilityChangeHandler) {
91
+ document.removeEventListener('visibilitychange', this.visibilityChangeHandler);
92
+ this.visibilityChangeHandler = null;
93
+ }
94
+
95
+ // Remove Nuxt hot-reload handlers
96
+ if (this.nuxtHotReloadHandler && window.$nuxt && window.$nuxt.$off) {
97
+ window.$nuxt.$off('routeChanged', this.nuxtHotReloadHandler);
98
+ window.$nuxt.$off('$nuxtReady', this.nuxtHotReloadHandler);
99
+ this.nuxtHotReloadHandler = null;
100
+ }
101
+
102
+ // Clear memory monitoring interval
103
+ if (this.memoryCheckInterval) {
104
+ clearInterval(this.memoryCheckInterval);
105
+ this.memoryCheckInterval = null;
106
+ }
107
+
108
+ // Remove from global instance tracking
109
+ if (window._sceneViewerInstances) {
110
+ window._sceneViewerInstances.delete(this.component);
111
+ console.log('📍 [Hot-Reload] Instance removed from tracking:', {
112
+ instanceId: this.instanceId,
113
+ remainingInstances: window._sceneViewerInstances.size
114
+ });
115
+ }
116
+ }
117
+
118
+ /**
119
+ * Track a timeout ID for cleanup on component destruction
120
+ */
121
+ }, {
122
+ key: "trackTimeout",
123
+ value: function trackTimeout(timeoutId) {
124
+ if (timeoutId) {
125
+ this.timeoutIds.add(timeoutId);
126
+ }
127
+ return timeoutId;
128
+ }
129
+
130
+ /**
131
+ * Track an interval ID for cleanup on component destruction
132
+ */
133
+ }, {
134
+ key: "trackInterval",
135
+ value: function trackInterval(intervalId) {
136
+ if (intervalId) {
137
+ this.intervalIds.add(intervalId);
138
+ }
139
+ return intervalId;
140
+ }
141
+
142
+ /**
143
+ * Clear a tracked timeout and remove from tracking
144
+ */
145
+ }, {
146
+ key: "clearTrackedTimeout",
147
+ value: function clearTrackedTimeout(timeoutId) {
148
+ if (this.timeoutIds.has(timeoutId)) {
149
+ clearTimeout(timeoutId);
150
+ this.timeoutIds.delete(timeoutId);
151
+ return true;
152
+ }
153
+ return false;
154
+ }
155
+
156
+ /**
157
+ * Clear a tracked interval and remove from tracking
158
+ */
159
+ }, {
160
+ key: "clearTrackedInterval",
161
+ value: function clearTrackedInterval(intervalId) {
162
+ if (this.intervalIds.has(intervalId)) {
163
+ clearInterval(intervalId);
164
+ this.intervalIds.delete(intervalId);
165
+ return true;
166
+ }
167
+ return false;
168
+ }
169
+
170
+ /**
171
+ * Clear all tracked timeouts and intervals
172
+ */
173
+ }, {
174
+ key: "clearAllTrackedTimers",
175
+ value: function clearAllTrackedTimers() {
176
+ // Clear all timeouts
177
+ this.timeoutIds.forEach(function (id) {
178
+ clearTimeout(id);
179
+ });
180
+ this.timeoutIds.clear();
181
+
182
+ // Clear all intervals
183
+ this.intervalIds.forEach(function (id) {
184
+ clearInterval(id);
185
+ });
186
+ this.intervalIds.clear();
187
+ console.log('🧹 [Hot-Reload] Cleared all tracked timers');
188
+ }
189
+ }]);
190
+ }();
191
+
192
+ /**
193
+ * Simple utility to handle hot-reload for componentId
194
+ * @param {string} instanceId - Unique instance identifier for the component
195
+ * @param {Function} cleanupMethod - Method to call to clean up resources
196
+ */
197
+ function handleHotReload(instanceId, cleanupMethod) {
198
+ if (!isBrowser || !isDev) return;
199
+
200
+ // Initialize registry if needed
201
+ if (!window._hotReloadRegistry) {
202
+ window._hotReloadRegistry = new Map();
203
+ }
204
+
205
+ // If we're reloading and have a previous instance with the same ID, clean it up
206
+ var existingInstance = window._hotReloadRegistry.get(instanceId);
207
+ if (existingInstance) {
208
+ console.log("\uD83D\uDD25 [Hot-Reload] Detected hot reload for instance: ".concat(instanceId));
209
+ if (typeof existingInstance.cleanup === 'function') {
210
+ existingInstance.cleanup();
211
+ }
212
+ }
213
+
214
+ // Register new instance
215
+ window._hotReloadRegistry.set(instanceId, {
216
+ timestamp: Date.now(),
217
+ cleanup: cleanupMethod
218
+ });
219
+ }
220
+
221
+ /**
222
+ * Check if we're currently hot-reloading
223
+ */
224
+ function isHotReloading() {
225
+ return isDev && isBrowser && window._hotReloadRegistry && window._hotReloadRegistry.size > 0;
226
+ }
227
+
228
+ /**
229
+ * Clean up resources for a component before hot-reload
230
+ * @param {string} instanceId - ID of the component instance to clean up
231
+ */
232
+ function cleanupForHotReload(instanceId) {
233
+ if (!isBrowser || !isDev || !window._hotReloadRegistry) return;
234
+ var instance = window._hotReloadRegistry.get(instanceId);
235
+ if (instance && typeof instance.cleanup === 'function') {
236
+ instance.cleanup();
237
+ window._hotReloadRegistry.delete(instanceId);
238
+ console.log("\uD83E\uDDF9 [Hot-Reload] Cleaned up instance: ".concat(instanceId));
239
+ }
240
+ }
241
+ var hotReloadManager = {
242
+ HotReloadManager: HotReloadManager,
243
+ handleHotReload: handleHotReload,
244
+ isHotReloading: isHotReloading,
245
+ cleanupForHotReload: cleanupForHotReload
246
+ };
247
+
248
+ exports.HotReloadManager = HotReloadManager;
249
+ exports.cleanupForHotReload = cleanupForHotReload;
250
+ exports["default"] = hotReloadManager;
251
+ exports.handleHotReload = handleHotReload;
252
+ exports.isHotReloading = isHotReloading;
@@ -0,0 +1,126 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var animationManager = require('./animationManager.js');
6
+ var componentManager = require('./componentManager.js');
7
+ var debugLogger = require('./debugLogger.js');
8
+ var disposalManager = require('./disposalManager.js');
9
+ var environmentManager = require('./environmentManager.js');
10
+ var hotReloadManager = require('./hotReloadManager.js');
11
+ var keyboardControlsManager = require('./keyboardControlsManager.js');
12
+ var modelPreloader = require('./modelPreloader.js');
13
+ var nameUtils = require('./nameUtils.js');
14
+ var pathfindingManager = require('./pathfindingManager.js');
15
+ var performanceMonitor = require('./performanceMonitor.js');
16
+ var sceneExportManager = require('./sceneExportManager.js');
17
+ var sceneInitializationManager = require('./sceneInitializationManager.js');
18
+ var sceneOperationsManager = require('./sceneOperationsManager.js');
19
+ var textureConfig = require('./textureConfig.js');
20
+ var transformControlsManager = require('./transformControlsManager.js');
21
+ var Pathfinder = require('./Pathfinder.js');
22
+ var ConnectionManager = require('./ConnectionManager.js');
23
+
24
+ /**
25
+ * @module CentralPlant/Utils
26
+ * @description Central Plant Utilities Module
27
+ *
28
+ * This is the main entry point for all utility functions and classes
29
+ * used in the Central Plant application. Import this module to access
30
+ * all utility functions through a single interface.
31
+ *
32
+ * @example
33
+ * // Import the entire utilities module
34
+ * import CentralPlant from 'central-plant';
35
+ *
36
+ * // Use a specific utility
37
+ * CentralPlant.modelPreloader.preloadAllModels(...);
38
+ *
39
+ * @example
40
+ * // Import specific modules
41
+ * import { modelPreloader, nameUtils } from 'CentralPlant';
42
+ *
43
+ * // Use them directly
44
+ * modelPreloader.preloadAllModels(...);
45
+ *
46
+ * @example
47
+ * // Import common functions directly
48
+ * import { getHardcodedUuid, logger } from 'CentralPlant';
49
+ *
50
+ * // Use functions directly
51
+ * const uuid = getHardcodedUuid(object);
52
+ * logger.info('Operation completed');
53
+ */
54
+
55
+ /**
56
+ * Central API object that provides access to all utility modules
57
+ * @type {Object}
58
+ * @property {Object} animation - Animation management utilities
59
+ * @property {Object} component - Component management utilities
60
+ * @property {Object} debug - Debugging and logging utilities
61
+ * @property {Object} disposal - Resource disposal utilities
62
+ * @property {Object} environment - 3D environment management utilities
63
+ * @property {Object} hotReload - Hot reload handling utilities
64
+ * @property {Object} keyboardControls - Keyboard controls management
65
+ * @property {Object} modelPreloader - Model preloading utilities
66
+ * @property {Object} name - Name and UUID management utilities
67
+ * @property {Object} pathfinding - Pathfinding utilities
68
+ * @property {Object} performance - Performance monitoring utilities
69
+ * @property {Object} sceneExport - Scene export utilities
70
+ * @property {Object} sceneInitialization - Scene initialization utilities
71
+ * @property {Object} sceneOperations - Scene operations utilities
72
+ * @property {Object} texture - Texture management utilities
73
+ * @property {Object} transformControls - Transform controls utilities
74
+ * @property {Object} pathfinder - Pathfinder utilities
75
+ * @property {Object} connectionManager - Connection management utilities
76
+ */
77
+ var CentralPlantUtils = {
78
+ animation: animationManager,
79
+ component: componentManager,
80
+ debug: debugLogger,
81
+ disposal: disposalManager,
82
+ environment: environmentManager,
83
+ hotReload: hotReloadManager,
84
+ keyboardControls: keyboardControlsManager,
85
+ modelPreloader: modelPreloader,
86
+ name: nameUtils,
87
+ pathfinding: pathfindingManager,
88
+ performance: performanceMonitor,
89
+ sceneExport: sceneExportManager,
90
+ sceneInitialization: sceneInitializationManager,
91
+ sceneOperations: sceneOperationsManager,
92
+ texture: textureConfig,
93
+ transformControls: transformControlsManager,
94
+ pathfinder: Pathfinder,
95
+ connectionManager: ConnectionManager
96
+ };
97
+
98
+ exports.animationManager = animationManager;
99
+ exports.componentManager = componentManager;
100
+ exports.debugLogger = debugLogger;
101
+ exports.logger = debugLogger.logger;
102
+ exports.modelLogger = debugLogger.modelLogger;
103
+ exports.pathfinderLogger = debugLogger.pathfinderLogger;
104
+ exports.transformLogger = debugLogger.transformLogger;
105
+ exports.disposalManager = disposalManager;
106
+ exports.environmentManager = environmentManager;
107
+ exports.hotReloadManager = hotReloadManager;
108
+ exports.keyboardControlsManager = keyboardControlsManager;
109
+ exports.modelPreloader = modelPreloader;
110
+ exports.findObjectByHardcodedUuid = nameUtils.findObjectByHardcodedUuid;
111
+ exports.generateUuidFromName = nameUtils.generateUuidFromName;
112
+ exports.getHardcodedUuid = nameUtils.getHardcodedUuid;
113
+ exports.nameUtils = nameUtils;
114
+ exports.pathfindingManager = pathfindingManager;
115
+ exports.performanceMonitor = performanceMonitor;
116
+ exports.getSceneExportManager = sceneExportManager.getSceneExportManager;
117
+ exports.sceneExportManager = sceneExportManager;
118
+ exports.sceneInitializationManager = sceneInitializationManager;
119
+ exports.getSceneOperationsManager = sceneOperationsManager.getSceneOperationsManager;
120
+ exports.sceneOperationsManager = sceneOperationsManager;
121
+ exports.textureConfig = textureConfig;
122
+ exports.getTransformControlsManager = transformControlsManager.getTransformControlsManager;
123
+ exports.transformControlsManager = transformControlsManager;
124
+ exports.Pathfinder = Pathfinder;
125
+ exports.ConnectionManager = ConnectionManager;
126
+ exports["default"] = CentralPlantUtils;
@@ -0,0 +1,206 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var debugLogger = require('./debugLogger.js');
6
+
7
+ /**
8
+ * Keyboard Controls Manager
9
+ * Manages keyboard shortcuts and controls
10
+ */
11
+
12
+ // Store registered key handlers
13
+ var keyHandlers = new Map();
14
+ var isListening = false;
15
+
16
+ /**
17
+ * Initialize keyboard controls
18
+ */
19
+ function initKeyboardControls() {
20
+ if (typeof window === 'undefined') {
21
+ debugLogger.logger.warn('Cannot initialize keyboard controls: window is not defined');
22
+ return;
23
+ }
24
+
25
+ // Only add event listener once
26
+ if (isListening) return;
27
+
28
+ // Handle keydown events
29
+ window.addEventListener('keydown', handleKeyDown);
30
+ window.addEventListener('keyup', handleKeyUp);
31
+ isListening = true;
32
+ debugLogger.logger.info('Keyboard controls initialized');
33
+ }
34
+
35
+ /**
36
+ * Clean up keyboard controls
37
+ */
38
+ function cleanupKeyboardControls() {
39
+ if (typeof window === 'undefined' || !isListening) {
40
+ return;
41
+ }
42
+ window.removeEventListener('keydown', handleKeyDown);
43
+ window.removeEventListener('keyup', handleKeyUp);
44
+ keyHandlers.clear();
45
+ isListening = false;
46
+ debugLogger.logger.info('Keyboard controls cleaned up');
47
+ }
48
+
49
+ /**
50
+ * Handler for keydown events
51
+ */
52
+ function handleKeyDown(event) {
53
+ // Get key or combination
54
+ var keyCombo = getKeyCombo(event);
55
+
56
+ // Get handler for this key
57
+ var handler = keyHandlers.get(keyCombo);
58
+ if (handler) {
59
+ event.preventDefault();
60
+ handler.callback(event);
61
+ }
62
+ }
63
+
64
+ /**
65
+ * Handler for keyup events
66
+ */
67
+ function handleKeyUp(event) {
68
+ var keyCombo = getKeyCombo(event);
69
+
70
+ // Get handler for this key
71
+ var handler = keyHandlers.get(keyCombo);
72
+ if (handler && handler.onKeyUp) {
73
+ event.preventDefault();
74
+ handler.onKeyUp(event);
75
+ }
76
+ }
77
+
78
+ /**
79
+ * Register a key handler
80
+ */
81
+ function registerKeyHandler(key, callback) {
82
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
83
+ // Normalize key format
84
+ var normalizedKey = normalizeKey(key);
85
+
86
+ // Register handler
87
+ keyHandlers.set(normalizedKey, {
88
+ callback: callback,
89
+ onKeyUp: options.onKeyUp || null,
90
+ description: options.description || ''
91
+ });
92
+
93
+ // Initialize controls if not already done
94
+ if (!isListening) {
95
+ initKeyboardControls();
96
+ }
97
+ return normalizedKey;
98
+ }
99
+
100
+ /**
101
+ * Unregister a key handler
102
+ */
103
+ function unregisterKeyHandler(key) {
104
+ var normalizedKey = normalizeKey(key);
105
+ return keyHandlers.delete(normalizedKey);
106
+ }
107
+
108
+ /**
109
+ * Get all registered key handlers
110
+ */
111
+ function getRegisteredKeyHandlers() {
112
+ var handlers = [];
113
+ keyHandlers.forEach(function (handler, key) {
114
+ handlers.push({
115
+ key: key,
116
+ description: handler.description
117
+ });
118
+ });
119
+ return handlers;
120
+ }
121
+
122
+ /**
123
+ * Helper function to normalize key format
124
+ */
125
+ function normalizeKey(key) {
126
+ return key.toLowerCase();
127
+ }
128
+
129
+ /**
130
+ * Helper function to get key combo string from event
131
+ */
132
+ function getKeyCombo(event) {
133
+ var combo = '';
134
+ if (event.ctrlKey) combo += 'ctrl+';
135
+ if (event.altKey) combo += 'alt+';
136
+ if (event.shiftKey) combo += 'shift+';
137
+ if (event.metaKey) combo += 'meta+';
138
+ combo += event.key.toLowerCase();
139
+ return combo;
140
+ }
141
+
142
+ /**
143
+ * Setup common keyboard controls for a Three.js scene
144
+ */
145
+ function setupCommonControls(component) {
146
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
147
+ // Reset view
148
+ registerKeyHandler('r', function () {
149
+ if (component.camera && component.controls) {
150
+ component.camera.position.set(-10, 10, 10);
151
+ component.controls.target.set(0, 0, 0);
152
+ component.controls.update();
153
+ debugLogger.logger.info('Camera reset');
154
+ }
155
+ }, {
156
+ description: 'Reset camera view'
157
+ });
158
+
159
+ // Toggle wireframe mode
160
+ registerKeyHandler('w', function () {
161
+ if (component.scene) {
162
+ var wireframeEnabled = !options.wireframeEnabled;
163
+ options.wireframeEnabled = wireframeEnabled;
164
+ component.scene.traverse(function (object) {
165
+ if (object.isMesh && object.material) {
166
+ if (Array.isArray(object.material)) {
167
+ object.material.forEach(function (mat) {
168
+ mat.wireframe = wireframeEnabled;
169
+ });
170
+ } else {
171
+ object.material.wireframe = wireframeEnabled;
172
+ }
173
+ }
174
+ });
175
+ debugLogger.logger.info("Wireframe mode: ".concat(wireframeEnabled ? 'enabled' : 'disabled'));
176
+ }
177
+ }, {
178
+ description: 'Toggle wireframe mode'
179
+ });
180
+
181
+ // Toggle performance monitor
182
+ registerKeyHandler('p', function () {
183
+ if (component.performanceUI) {
184
+ component.performanceUI.toggle();
185
+ }
186
+ }, {
187
+ description: 'Toggle performance monitor'
188
+ });
189
+ debugLogger.logger.info('Common keyboard controls setup');
190
+ }
191
+ var keyboardControlsManager = {
192
+ initKeyboardControls: initKeyboardControls,
193
+ cleanupKeyboardControls: cleanupKeyboardControls,
194
+ registerKeyHandler: registerKeyHandler,
195
+ unregisterKeyHandler: unregisterKeyHandler,
196
+ getRegisteredKeyHandlers: getRegisteredKeyHandlers,
197
+ setupCommonControls: setupCommonControls
198
+ };
199
+
200
+ exports.cleanupKeyboardControls = cleanupKeyboardControls;
201
+ exports["default"] = keyboardControlsManager;
202
+ exports.getRegisteredKeyHandlers = getRegisteredKeyHandlers;
203
+ exports.initKeyboardControls = initKeyboardControls;
204
+ exports.registerKeyHandler = registerKeyHandler;
205
+ exports.setupCommonControls = setupCommonControls;
206
+ exports.unregisterKeyHandler = unregisterKeyHandler;