valtech-components 2.0.323 → 2.0.325
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.
- package/esm2022/lib/services/content-loader.service.mjs +89 -28
- package/fesm2022/valtech-components.mjs +87 -26
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/components/organisms/article/article.component.d.ts +2 -2
- package/lib/services/content-loader.service.d.ts +26 -9
- package/package.json +1 -1
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
1
|
+
import { Injectable, inject } from '@angular/core';
|
|
2
2
|
import { TextContent } from './lang-provider/types';
|
|
3
|
+
import { ValtechConfigService } from './types';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "./lang-provider/lang-provider.service";
|
|
5
5
|
/**
|
|
6
6
|
* ContentLoader Service - Dynamic content loading system.
|
|
7
7
|
*
|
|
8
|
-
*
|
|
9
|
-
*
|
|
8
|
+
* REFACTORED: Now uses ValtechConfigService properly instead of hacking LangService.
|
|
9
|
+
* This provides a clean, maintainable way to register content dynamically.
|
|
10
10
|
*
|
|
11
11
|
* @example Basic usage:
|
|
12
12
|
* ```typescript
|
|
@@ -16,30 +16,36 @@ import * as i1 from "./lang-provider/lang-provider.service";
|
|
|
16
16
|
* en: { title: 'My User Page', welcome: 'Welcome {{name}}' }
|
|
17
17
|
* };
|
|
18
18
|
*
|
|
19
|
-
* // In component
|
|
19
|
+
* // In component
|
|
20
20
|
* import { UserPageContent } from './user-page.content';
|
|
21
|
-
*
|
|
21
|
+
* registerContent('UserPage', UserPageContent);
|
|
22
22
|
* ```
|
|
23
23
|
*/
|
|
24
24
|
export class ContentLoaderService {
|
|
25
|
-
constructor(
|
|
26
|
-
this.
|
|
25
|
+
constructor() {
|
|
26
|
+
this.valtechConfig = inject(ValtechConfigService);
|
|
27
27
|
this.registeredContent = new Map();
|
|
28
28
|
}
|
|
29
29
|
/**
|
|
30
30
|
* Register content for a specific component/page class.
|
|
31
|
+
* ✅ CLEAN: Uses proper ValtechConfigService API instead of hacking LangService
|
|
31
32
|
*/
|
|
32
33
|
registerContent(className, content) {
|
|
34
|
+
// Store locally for tracking
|
|
33
35
|
this.registeredContent.set(className, content);
|
|
34
|
-
|
|
36
|
+
// Update the configuration properly
|
|
37
|
+
this.addContentToProvider(className, content);
|
|
38
|
+
console.log(`✅ ContentLoader: Registered content for "${className}"`);
|
|
35
39
|
}
|
|
36
40
|
/**
|
|
37
41
|
* Register multiple content modules at once.
|
|
38
42
|
*/
|
|
39
43
|
loadContent(contentModules) {
|
|
44
|
+
console.log(`🔄 ContentLoader: Loading ${contentModules.length} content modules...`);
|
|
40
45
|
contentModules.forEach(module => {
|
|
41
46
|
this.registerContent(module.className, module.content);
|
|
42
47
|
});
|
|
48
|
+
console.log('✅ ContentLoader: All content modules loaded successfully');
|
|
43
49
|
}
|
|
44
50
|
/**
|
|
45
51
|
* Check if content is registered for a class.
|
|
@@ -65,6 +71,13 @@ export class ContentLoaderService {
|
|
|
65
71
|
unregisterContent(className) {
|
|
66
72
|
const existed = this.registeredContent.has(className);
|
|
67
73
|
this.registeredContent.delete(className);
|
|
74
|
+
// Also remove from the provider
|
|
75
|
+
if (existed && this.valtechConfig.content) {
|
|
76
|
+
const updatedContent = { ...this.valtechConfig.content };
|
|
77
|
+
delete updatedContent[className];
|
|
78
|
+
this.valtechConfig.content = updatedContent;
|
|
79
|
+
console.log(`🗑️ ContentLoader: Unregistered content for "${className}"`);
|
|
80
|
+
}
|
|
68
81
|
return existed;
|
|
69
82
|
}
|
|
70
83
|
/**
|
|
@@ -72,26 +85,39 @@ export class ContentLoaderService {
|
|
|
72
85
|
*/
|
|
73
86
|
clearAllContent() {
|
|
74
87
|
this.registeredContent.clear();
|
|
88
|
+
console.log('🧹 ContentLoader: Cleared all registered content');
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Get current content provider state.
|
|
92
|
+
* Useful for debugging.
|
|
93
|
+
*/
|
|
94
|
+
getContentProvider() {
|
|
95
|
+
return this.valtechConfig.content;
|
|
75
96
|
}
|
|
76
97
|
/**
|
|
77
|
-
* Add content to
|
|
98
|
+
* ✅ CLEAN: Add content to provider using proper API
|
|
78
99
|
* @private
|
|
79
100
|
*/
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
101
|
+
addContentToProvider(className, content) {
|
|
102
|
+
try {
|
|
103
|
+
// Get current content provider
|
|
104
|
+
const currentContent = this.valtechConfig.content || {};
|
|
105
|
+
// Create TextContent instance
|
|
83
106
|
const textContent = new TextContent(content);
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
107
|
+
// Update the content provider properly
|
|
108
|
+
const updatedContent = {
|
|
109
|
+
...currentContent,
|
|
110
|
+
[className]: textContent,
|
|
111
|
+
};
|
|
112
|
+
// Set the updated content - this is the clean way
|
|
113
|
+
this.valtechConfig.content = updatedContent;
|
|
114
|
+
console.log(`📝 ContentLoader: Added "${className}" to content provider`);
|
|
89
115
|
}
|
|
90
|
-
|
|
91
|
-
console.error(
|
|
116
|
+
catch (error) {
|
|
117
|
+
console.error(`❌ ContentLoader: Error adding content for "${className}":`, error);
|
|
92
118
|
}
|
|
93
119
|
}
|
|
94
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ContentLoaderService, deps: [
|
|
120
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ContentLoaderService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
95
121
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ContentLoaderService, providedIn: 'root' }); }
|
|
96
122
|
}
|
|
97
123
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ContentLoaderService, decorators: [{
|
|
@@ -99,26 +125,61 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
99
125
|
args: [{
|
|
100
126
|
providedIn: 'root',
|
|
101
127
|
}]
|
|
102
|
-
}]
|
|
128
|
+
}] });
|
|
103
129
|
/**
|
|
104
130
|
* Helper function to create a content module.
|
|
105
131
|
*/
|
|
106
132
|
export function createContentModule(className, content) {
|
|
107
133
|
return { className, content };
|
|
108
134
|
}
|
|
135
|
+
/**
|
|
136
|
+
* ✅ CLEAN: Global registry using proper array instead of globalThis hack
|
|
137
|
+
*/
|
|
138
|
+
const globalContentRegistry = [];
|
|
109
139
|
/**
|
|
110
140
|
* Simple function to register content directly.
|
|
141
|
+
* ✅ IMPROVED: Cleaner global registry management
|
|
111
142
|
*/
|
|
112
143
|
export function registerContent(className, content) {
|
|
113
|
-
|
|
114
|
-
|
|
144
|
+
// Add to global registry
|
|
145
|
+
globalContentRegistry.push({ className, content });
|
|
146
|
+
console.log(`📝 registerContent: Queued "${className}" for registration`);
|
|
115
147
|
}
|
|
116
148
|
/**
|
|
117
149
|
* Load all content from the global registry.
|
|
150
|
+
* ✅ IMPROVED: Better error handling and logging
|
|
118
151
|
*/
|
|
119
152
|
export function loadRegisteredContent(contentLoader) {
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
153
|
+
if (globalContentRegistry.length === 0) {
|
|
154
|
+
console.log('ℹ️ ContentLoader: No content registered to load');
|
|
155
|
+
return;
|
|
156
|
+
}
|
|
157
|
+
console.log(`🚀 ContentLoader: Loading ${globalContentRegistry.length} registered content modules...`);
|
|
158
|
+
try {
|
|
159
|
+
// Load all content
|
|
160
|
+
contentLoader.loadContent([...globalContentRegistry]);
|
|
161
|
+
// Clear the registry after loading
|
|
162
|
+
globalContentRegistry.length = 0;
|
|
163
|
+
console.log('🎉 ContentLoader: All registered content loaded and registry cleared');
|
|
164
|
+
}
|
|
165
|
+
catch (error) {
|
|
166
|
+
console.error('❌ ContentLoader: Error loading registered content:', error);
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
/**
|
|
170
|
+
* ✅ NEW: Debugging helper
|
|
171
|
+
* Get current global registry state
|
|
172
|
+
*/
|
|
173
|
+
export function getRegisteredContentQueue() {
|
|
174
|
+
return [...globalContentRegistry];
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* ✅ NEW: Debugging helper
|
|
178
|
+
* Clear the global registry without loading
|
|
179
|
+
*/
|
|
180
|
+
export function clearRegisteredContentQueue() {
|
|
181
|
+
const count = globalContentRegistry.length;
|
|
182
|
+
globalContentRegistry.length = 0;
|
|
183
|
+
console.log(`🧹 ContentLoader: Cleared ${count} items from registration queue`);
|
|
123
184
|
}
|
|
124
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"content-loader.service.js","sourceRoot":"","sources":["../../../../../projects/valtech-components/src/lib/services/content-loader.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { LangService } from './lang-provider/lang-provider.service';\nimport { LanguagesContent, TextContent } from './lang-provider/types';\n/**\n * ContentLoader Service - Dynamic content loading system.\n *\n * Allows loading content from distributed .content.ts files throughout the project,\n * keeping content close to where it's used instead of centralizing everything in main.ts.\n *\n * @example Basic usage:\n * ```typescript\n * // user-page.content.ts\n * export const UserPageContent = {\n *   es: { title: 'Mi Página de Usuario', welcome: 'Bienvenido {{name}}' },\n *   en: { title: 'My User Page', welcome: 'Welcome {{name}}' }\n * };\n *\n * // In component or main.ts\n * import { UserPageContent } from './user-page.content';\n * contentLoader.registerContent('UserPage', UserPageContent);\n * ```\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class ContentLoaderService {\n  private registeredContent = new Map<string, LanguagesContent>();\n\n  constructor(private langService: LangService) {}\n\n  /**\n   * Register content for a specific component/page class.\n   */\n  registerContent(className: string, content: LanguagesContent): void {\n    this.registeredContent.set(className, content);\n    this.addContentToLangService(className, content);\n  }\n\n  /**\n   * Register multiple content modules at once.\n   */\n  loadContent(contentModules: ContentModule[]): void {\n    contentModules.forEach(module => {\n      this.registerContent(module.className, module.content);\n    });\n  }\n\n  /**\n   * Check if content is registered for a class.\n   */\n  hasContentFor(className: string): boolean {\n    return this.registeredContent.has(className);\n  }\n\n  /**\n   * Get all registered class names.\n   */\n  getRegisteredClasses(): string[] {\n    return Array.from(this.registeredContent.keys());\n  }\n\n  /**\n   * Get registered content for a specific class.\n   */\n  getContentFor(className: string): LanguagesContent | undefined {\n    return this.registeredContent.get(className);\n  }\n\n  /**\n   * Remove content registration for a class.\n   */\n  unregisterContent(className: string): boolean {\n    const existed = this.registeredContent.has(className);\n    this.registeredContent.delete(className);\n    return existed;\n  }\n\n  /**\n   * Clear all registered content.\n   */\n  clearAllContent(): void {\n    this.registeredContent.clear();\n  }\n\n  /**\n   * Add content to the LangService content provider.\n   * @private\n   */\n  private addContentToLangService(className: string, content: LanguagesContent): void {\n    const langServiceAny = this.langService as any;\n\n    if (langServiceAny.content) {\n      const textContent = new TextContent(content);\n      langServiceAny.content[className] = textContent;\n\n      if (langServiceAny.detectAvailableLanguages) {\n        langServiceAny.detectAvailableLanguages();\n      }\n\n      console.log(`ContentLoader: Registered content for \"${className}\"`);\n    } else {\n      console.error('ContentLoader: Unable to access LangService content provider');\n    }\n  }\n}\n\n/**\n * Interface for content module registration.\n */\nexport interface ContentModule {\n  className: string;\n  content: LanguagesContent;\n}\n\n/**\n * Helper function to create a content module.\n */\nexport function createContentModule(className: string, content: LanguagesContent): ContentModule {\n  return { className, content };\n}\n\n/**\n * Simple function to register content directly.\n */\nexport function registerContent(className: string, content: LanguagesContent): void {\n  (globalThis as any).__valtechContentRegistry = (globalThis as any).__valtechContentRegistry || [];\n  (globalThis as any).__valtechContentRegistry.push({ className, content });\n}\n\n/**\n * Load all content from the global registry.\n */\nexport function loadRegisteredContent(contentLoader: ContentLoaderService): void {\n  const registeredContent = (globalThis as any).__valtechContentRegistry || [];\n  contentLoader.loadContent(registeredContent);\n  (globalThis as any).__valtechContentRegistry = [];\n}\n"]}
|
|
185
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"content-loader.service.js","sourceRoot":"","sources":["../../../../../projects/valtech-components/src/lib/services/content-loader.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, inject } from '@angular/core';\nimport { Provider } from './lang-provider/content';\nimport { LanguagesContent, TextContent } from './lang-provider/types';\nimport { ValtechConfigService } from './types';\n/**\n * ContentLoader Service - Dynamic content loading system.\n *\n * REFACTORED: Now uses ValtechConfigService properly instead of hacking LangService.\n * This provides a clean, maintainable way to register content dynamically.\n *\n * @example Basic usage:\n * ```typescript\n * // user-page.content.ts\n * export const UserPageContent = {\n *   es: { title: 'Mi Página de Usuario', welcome: 'Bienvenido {{name}}' },\n *   en: { title: 'My User Page', welcome: 'Welcome {{name}}' }\n * };\n *\n * // In component\n * import { UserPageContent } from './user-page.content';\n * registerContent('UserPage', UserPageContent);\n * ```\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class ContentLoaderService {\n  private valtechConfig = inject(ValtechConfigService);\n  private registeredContent = new Map<string, LanguagesContent>();\n\n  /**\n   * Register content for a specific component/page class.\n   * ✅ CLEAN: Uses proper ValtechConfigService API instead of hacking LangService\n   */\n  registerContent(className: string, content: LanguagesContent): void {\n    // Store locally for tracking\n    this.registeredContent.set(className, content);\n\n    // Update the configuration properly\n    this.addContentToProvider(className, content);\n\n    console.log(`✅ ContentLoader: Registered content for \"${className}\"`);\n  }\n\n  /**\n   * Register multiple content modules at once.\n   */\n  loadContent(contentModules: ContentModule[]): void {\n    console.log(`🔄 ContentLoader: Loading ${contentModules.length} content modules...`);\n\n    contentModules.forEach(module => {\n      this.registerContent(module.className, module.content);\n    });\n\n    console.log('✅ ContentLoader: All content modules loaded successfully');\n  }\n\n  /**\n   * Check if content is registered for a class.\n   */\n  hasContentFor(className: string): boolean {\n    return this.registeredContent.has(className);\n  }\n\n  /**\n   * Get all registered class names.\n   */\n  getRegisteredClasses(): string[] {\n    return Array.from(this.registeredContent.keys());\n  }\n\n  /**\n   * Get registered content for a specific class.\n   */\n  getContentFor(className: string): LanguagesContent | undefined {\n    return this.registeredContent.get(className);\n  }\n\n  /**\n   * Remove content registration for a class.\n   */\n  unregisterContent(className: string): boolean {\n    const existed = this.registeredContent.has(className);\n    this.registeredContent.delete(className);\n\n    // Also remove from the provider\n    if (existed && this.valtechConfig.content) {\n      const updatedContent = { ...this.valtechConfig.content };\n      delete updatedContent[className];\n      this.valtechConfig.content = updatedContent;\n      console.log(`🗑️ ContentLoader: Unregistered content for \"${className}\"`);\n    }\n\n    return existed;\n  }\n\n  /**\n   * Clear all registered content.\n   */\n  clearAllContent(): void {\n    this.registeredContent.clear();\n    console.log('🧹 ContentLoader: Cleared all registered content');\n  }\n\n  /**\n   * Get current content provider state.\n   * Useful for debugging.\n   */\n  getContentProvider(): Provider | undefined {\n    return this.valtechConfig.content;\n  }\n\n  /**\n   * ✅ CLEAN: Add content to provider using proper API\n   * @private\n   */\n  private addContentToProvider(className: string, content: LanguagesContent): void {\n    try {\n      // Get current content provider\n      const currentContent = this.valtechConfig.content || {};\n\n      // Create TextContent instance\n      const textContent = new TextContent(content);\n\n      // Update the content provider properly\n      const updatedContent: Provider = {\n        ...currentContent,\n        [className]: textContent,\n      };\n\n      // Set the updated content - this is the clean way\n      this.valtechConfig.content = updatedContent;\n\n      console.log(`📝 ContentLoader: Added \"${className}\" to content provider`);\n    } catch (error) {\n      console.error(`❌ ContentLoader: Error adding content for \"${className}\":`, error);\n    }\n  }\n}\n\n/**\n * Interface for content module registration.\n */\nexport interface ContentModule {\n  className: string;\n  content: LanguagesContent;\n}\n\n/**\n * Helper function to create a content module.\n */\nexport function createContentModule(className: string, content: LanguagesContent): ContentModule {\n  return { className, content };\n}\n\n/**\n * ✅ CLEAN: Global registry using proper array instead of globalThis hack\n */\nconst globalContentRegistry: ContentModule[] = [];\n\n/**\n * Simple function to register content directly.\n * ✅ IMPROVED: Cleaner global registry management\n */\nexport function registerContent(className: string, content: LanguagesContent): void {\n  // Add to global registry\n  globalContentRegistry.push({ className, content });\n  console.log(`📝 registerContent: Queued \"${className}\" for registration`);\n}\n\n/**\n * Load all content from the global registry.\n * ✅ IMPROVED: Better error handling and logging\n */\nexport function loadRegisteredContent(contentLoader: ContentLoaderService): void {\n  if (globalContentRegistry.length === 0) {\n    console.log('ℹ️ ContentLoader: No content registered to load');\n    return;\n  }\n\n  console.log(\n    `🚀 ContentLoader: Loading ${globalContentRegistry.length} registered content modules...`\n  );\n\n  try {\n    // Load all content\n    contentLoader.loadContent([...globalContentRegistry]);\n\n    // Clear the registry after loading\n    globalContentRegistry.length = 0;\n\n    console.log('🎉 ContentLoader: All registered content loaded and registry cleared');\n  } catch (error) {\n    console.error('❌ ContentLoader: Error loading registered content:', error);\n  }\n}\n\n/**\n * ✅ NEW: Debugging helper\n * Get current global registry state\n */\nexport function getRegisteredContentQueue(): ContentModule[] {\n  return [...globalContentRegistry];\n}\n\n/**\n * ✅ NEW: Debugging helper\n * Clear the global registry without loading\n */\nexport function clearRegisteredContentQueue(): void {\n  const count = globalContentRegistry.length;\n  globalContentRegistry.length = 0;\n  console.log(`🧹 ContentLoader: Cleared ${count} items from registration queue`);\n}\n"]}
|
|
@@ -8112,8 +8112,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
8112
8112
|
/**
|
|
8113
8113
|
* ContentLoader Service - Dynamic content loading system.
|
|
8114
8114
|
*
|
|
8115
|
-
*
|
|
8116
|
-
*
|
|
8115
|
+
* REFACTORED: Now uses ValtechConfigService properly instead of hacking LangService.
|
|
8116
|
+
* This provides a clean, maintainable way to register content dynamically.
|
|
8117
8117
|
*
|
|
8118
8118
|
* @example Basic usage:
|
|
8119
8119
|
* ```typescript
|
|
@@ -8123,30 +8123,36 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
8123
8123
|
* en: { title: 'My User Page', welcome: 'Welcome {{name}}' }
|
|
8124
8124
|
* };
|
|
8125
8125
|
*
|
|
8126
|
-
* // In component
|
|
8126
|
+
* // In component
|
|
8127
8127
|
* import { UserPageContent } from './user-page.content';
|
|
8128
|
-
*
|
|
8128
|
+
* registerContent('UserPage', UserPageContent);
|
|
8129
8129
|
* ```
|
|
8130
8130
|
*/
|
|
8131
8131
|
class ContentLoaderService {
|
|
8132
|
-
constructor(
|
|
8133
|
-
this.
|
|
8132
|
+
constructor() {
|
|
8133
|
+
this.valtechConfig = inject(ValtechConfigService);
|
|
8134
8134
|
this.registeredContent = new Map();
|
|
8135
8135
|
}
|
|
8136
8136
|
/**
|
|
8137
8137
|
* Register content for a specific component/page class.
|
|
8138
|
+
* ✅ CLEAN: Uses proper ValtechConfigService API instead of hacking LangService
|
|
8138
8139
|
*/
|
|
8139
8140
|
registerContent(className, content) {
|
|
8141
|
+
// Store locally for tracking
|
|
8140
8142
|
this.registeredContent.set(className, content);
|
|
8141
|
-
|
|
8143
|
+
// Update the configuration properly
|
|
8144
|
+
this.addContentToProvider(className, content);
|
|
8145
|
+
console.log(`✅ ContentLoader: Registered content for "${className}"`);
|
|
8142
8146
|
}
|
|
8143
8147
|
/**
|
|
8144
8148
|
* Register multiple content modules at once.
|
|
8145
8149
|
*/
|
|
8146
8150
|
loadContent(contentModules) {
|
|
8151
|
+
console.log(`🔄 ContentLoader: Loading ${contentModules.length} content modules...`);
|
|
8147
8152
|
contentModules.forEach(module => {
|
|
8148
8153
|
this.registerContent(module.className, module.content);
|
|
8149
8154
|
});
|
|
8155
|
+
console.log('✅ ContentLoader: All content modules loaded successfully');
|
|
8150
8156
|
}
|
|
8151
8157
|
/**
|
|
8152
8158
|
* Check if content is registered for a class.
|
|
@@ -8172,6 +8178,13 @@ class ContentLoaderService {
|
|
|
8172
8178
|
unregisterContent(className) {
|
|
8173
8179
|
const existed = this.registeredContent.has(className);
|
|
8174
8180
|
this.registeredContent.delete(className);
|
|
8181
|
+
// Also remove from the provider
|
|
8182
|
+
if (existed && this.valtechConfig.content) {
|
|
8183
|
+
const updatedContent = { ...this.valtechConfig.content };
|
|
8184
|
+
delete updatedContent[className];
|
|
8185
|
+
this.valtechConfig.content = updatedContent;
|
|
8186
|
+
console.log(`🗑️ ContentLoader: Unregistered content for "${className}"`);
|
|
8187
|
+
}
|
|
8175
8188
|
return existed;
|
|
8176
8189
|
}
|
|
8177
8190
|
/**
|
|
@@ -8179,26 +8192,39 @@ class ContentLoaderService {
|
|
|
8179
8192
|
*/
|
|
8180
8193
|
clearAllContent() {
|
|
8181
8194
|
this.registeredContent.clear();
|
|
8195
|
+
console.log('🧹 ContentLoader: Cleared all registered content');
|
|
8196
|
+
}
|
|
8197
|
+
/**
|
|
8198
|
+
* Get current content provider state.
|
|
8199
|
+
* Useful for debugging.
|
|
8200
|
+
*/
|
|
8201
|
+
getContentProvider() {
|
|
8202
|
+
return this.valtechConfig.content;
|
|
8182
8203
|
}
|
|
8183
8204
|
/**
|
|
8184
|
-
* Add content to
|
|
8205
|
+
* ✅ CLEAN: Add content to provider using proper API
|
|
8185
8206
|
* @private
|
|
8186
8207
|
*/
|
|
8187
|
-
|
|
8188
|
-
|
|
8189
|
-
|
|
8208
|
+
addContentToProvider(className, content) {
|
|
8209
|
+
try {
|
|
8210
|
+
// Get current content provider
|
|
8211
|
+
const currentContent = this.valtechConfig.content || {};
|
|
8212
|
+
// Create TextContent instance
|
|
8190
8213
|
const textContent = new TextContent(content);
|
|
8191
|
-
|
|
8192
|
-
|
|
8193
|
-
|
|
8194
|
-
|
|
8195
|
-
|
|
8214
|
+
// Update the content provider properly
|
|
8215
|
+
const updatedContent = {
|
|
8216
|
+
...currentContent,
|
|
8217
|
+
[className]: textContent,
|
|
8218
|
+
};
|
|
8219
|
+
// Set the updated content - this is the clean way
|
|
8220
|
+
this.valtechConfig.content = updatedContent;
|
|
8221
|
+
console.log(`📝 ContentLoader: Added "${className}" to content provider`);
|
|
8196
8222
|
}
|
|
8197
|
-
|
|
8198
|
-
console.error(
|
|
8223
|
+
catch (error) {
|
|
8224
|
+
console.error(`❌ ContentLoader: Error adding content for "${className}":`, error);
|
|
8199
8225
|
}
|
|
8200
8226
|
}
|
|
8201
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ContentLoaderService, deps: [
|
|
8227
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ContentLoaderService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
8202
8228
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ContentLoaderService, providedIn: 'root' }); }
|
|
8203
8229
|
}
|
|
8204
8230
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ContentLoaderService, decorators: [{
|
|
@@ -8206,27 +8232,62 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
8206
8232
|
args: [{
|
|
8207
8233
|
providedIn: 'root',
|
|
8208
8234
|
}]
|
|
8209
|
-
}]
|
|
8235
|
+
}] });
|
|
8210
8236
|
/**
|
|
8211
8237
|
* Helper function to create a content module.
|
|
8212
8238
|
*/
|
|
8213
8239
|
function createContentModule(className, content) {
|
|
8214
8240
|
return { className, content };
|
|
8215
8241
|
}
|
|
8242
|
+
/**
|
|
8243
|
+
* ✅ CLEAN: Global registry using proper array instead of globalThis hack
|
|
8244
|
+
*/
|
|
8245
|
+
const globalContentRegistry = [];
|
|
8216
8246
|
/**
|
|
8217
8247
|
* Simple function to register content directly.
|
|
8248
|
+
* ✅ IMPROVED: Cleaner global registry management
|
|
8218
8249
|
*/
|
|
8219
8250
|
function registerContent(className, content) {
|
|
8220
|
-
|
|
8221
|
-
|
|
8251
|
+
// Add to global registry
|
|
8252
|
+
globalContentRegistry.push({ className, content });
|
|
8253
|
+
console.log(`📝 registerContent: Queued "${className}" for registration`);
|
|
8222
8254
|
}
|
|
8223
8255
|
/**
|
|
8224
8256
|
* Load all content from the global registry.
|
|
8257
|
+
* ✅ IMPROVED: Better error handling and logging
|
|
8225
8258
|
*/
|
|
8226
8259
|
function loadRegisteredContent(contentLoader) {
|
|
8227
|
-
|
|
8228
|
-
|
|
8229
|
-
|
|
8260
|
+
if (globalContentRegistry.length === 0) {
|
|
8261
|
+
console.log('ℹ️ ContentLoader: No content registered to load');
|
|
8262
|
+
return;
|
|
8263
|
+
}
|
|
8264
|
+
console.log(`🚀 ContentLoader: Loading ${globalContentRegistry.length} registered content modules...`);
|
|
8265
|
+
try {
|
|
8266
|
+
// Load all content
|
|
8267
|
+
contentLoader.loadContent([...globalContentRegistry]);
|
|
8268
|
+
// Clear the registry after loading
|
|
8269
|
+
globalContentRegistry.length = 0;
|
|
8270
|
+
console.log('🎉 ContentLoader: All registered content loaded and registry cleared');
|
|
8271
|
+
}
|
|
8272
|
+
catch (error) {
|
|
8273
|
+
console.error('❌ ContentLoader: Error loading registered content:', error);
|
|
8274
|
+
}
|
|
8275
|
+
}
|
|
8276
|
+
/**
|
|
8277
|
+
* ✅ NEW: Debugging helper
|
|
8278
|
+
* Get current global registry state
|
|
8279
|
+
*/
|
|
8280
|
+
function getRegisteredContentQueue() {
|
|
8281
|
+
return [...globalContentRegistry];
|
|
8282
|
+
}
|
|
8283
|
+
/**
|
|
8284
|
+
* ✅ NEW: Debugging helper
|
|
8285
|
+
* Clear the global registry without loading
|
|
8286
|
+
*/
|
|
8287
|
+
function clearRegisteredContentQueue() {
|
|
8288
|
+
const count = globalContentRegistry.length;
|
|
8289
|
+
globalContentRegistry.length = 0;
|
|
8290
|
+
console.log(`🧹 ContentLoader: Cleared ${count} items from registration queue`);
|
|
8230
8291
|
}
|
|
8231
8292
|
|
|
8232
8293
|
const text = {
|
|
@@ -8403,5 +8464,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
8403
8464
|
* Generated bundle index. Do not edit.
|
|
8404
8465
|
*/
|
|
8405
8466
|
|
|
8406
|
-
export { ARTICLE_SPACING, ActionType, AlertBoxComponent, ArticleBuilder, ArticleComponent, AvatarComponent, BannerComponent, BaseDefault, BoxComponent, ButtonComponent, ButtonGroupComponent, CardComponent, CardSection, CardType, CheckInputComponent, ClearDefault, ClearDefaultBlock, ClearDefaultFull, ClearDefaultRound, ClearDefaultRoundBlock, ClearDefaultRoundFull, CommentInputComponent, ComponentContentHelper, ComponentStates, ContentLoaderComponent, ContentLoaderService, ContentService, DateInputComponent, DisplayComponent, DividerComponent, DownloadService, EmailInputComponent, ExpandableTextComponent, FileInputComponent, FooterComponent, FormComponent, FormFooterComponent, GlobalContent, HeaderComponent, HintComponent, HourInputComponent, HrefComponent, Icon, IconComponent, IconService, ImageComponent, InAppBrowserService, InputType, ItemListComponent, LANGUAGES, LangService, LanguageSelectorComponent, LayeredCardComponent, LayoutComponent, LinkComponent, LinkProcessorService, LinksCakeComponent, ListContentHelper, LocalStorageService, MOTION, NavigationService, NoContentComponent, NotesBoxComponent, NumberInputComponent, OutlineDefault, OutlineDefaultBlock, OutlineDefaultFull, OutlineDefaultRound, OutlineDefaultRoundBlock, OutlineDefaultRoundFull, PasswordInputComponent, PinInputComponent, PopoverSelectorComponent, PrimarySolidBlockButton, PrimarySolidBlockHrefButton, PrimarySolidBlockIconButton, PrimarySolidBlockIconHrefButton, PrimarySolidDefaultRoundButton, PrimarySolidDefaultRoundHrefButton, PrimarySolidDefaultRoundIconButton, PrimarySolidDefaultRoundIconHrefButton, PrimarySolidFullButton, PrimarySolidFullHrefButton, PrimarySolidFullIconButton, PrimarySolidFullIconHrefButton, PrimarySolidLargeRoundButton, PrimarySolidLargeRoundHrefButton, PrimarySolidLargeRoundIconButton, PrimarySolidLargeRoundIconHrefButton, PrimarySolidSmallRoundButton, PrimarySolidSmallRoundHrefButton, PrimarySolidSmallRoundIconButton, PrimarySolidSmallRoundIconHrefButton, ProcessLinksPipe, ProgressBarComponent, ProgressStatusComponent, PrompterComponent, RadioInputComponent, SearchSelectorComponent, SearchbarComponent, SecondarySolidBlockButton, SecondarySolidBlockHrefButton, SecondarySolidBlockIconButton, SecondarySolidBlockIconHrefButton, SecondarySolidDefaultRoundButton, SecondarySolidDefaultRoundHrefButton, SecondarySolidDefaultRoundIconButton, SecondarySolidDefaultRoundIconHrefButton, SecondarySolidFullButton, SecondarySolidFullHrefButton, SecondarySolidFullIconButton, SecondarySolidFullIconHrefButton, SecondarySolidLargeRoundButton, SecondarySolidLargeRoundHrefButton, SecondarySolidLargeRoundIconButton, SecondarySolidLargeRoundIconHrefButton, SecondarySolidSmallRoundButton, SecondarySolidSmallRoundHrefButton, SecondarySolidSmallRoundIconButton, SecondarySolidSmallRoundIconHrefButton, SelectSearchComponent, SimpleComponent, SolidBlockButton, SolidDefault, SolidDefaultBlock, SolidDefaultButton, SolidDefaultFull, SolidDefaultRound, SolidDefaultRoundBlock, SolidDefaultRoundButton, SolidDefaultRoundFull, SolidFullButton, SolidLargeButton, SolidLargeRoundButton, SolidSmallButton, SolidSmallRoundButton, TextComponent, TextContent, TextInputComponent, ThemeOption, ThemeService, TitleBlockComponent, TitleComponent, ToastService, ToolbarActionType, ToolbarComponent, ValtechConfigService, WizardComponent, WizardFooterComponent, applyDefaultValueToControl, content, createButtonProps, createComponentContentHelper, createContentHelper, createContentModule, createDisplayProps, createReactiveProps, createTextProps, createTitleProps, fromContent, fromContentWithInterpolation, fromMultipleContent, globalContentData, goToTop, interpolateContent, isAtEnd, loadRegisteredContent, maxLength, registerContent, replaceSpecialChars, resolveColor, resolveInputDefaultValue, shouldUseReactiveContent };
|
|
8467
|
+
export { ARTICLE_SPACING, ActionType, AlertBoxComponent, ArticleBuilder, ArticleComponent, AvatarComponent, BannerComponent, BaseDefault, BoxComponent, ButtonComponent, ButtonGroupComponent, CardComponent, CardSection, CardType, CheckInputComponent, ClearDefault, ClearDefaultBlock, ClearDefaultFull, ClearDefaultRound, ClearDefaultRoundBlock, ClearDefaultRoundFull, CommentInputComponent, ComponentContentHelper, ComponentStates, ContentLoaderComponent, ContentLoaderService, ContentService, DateInputComponent, DisplayComponent, DividerComponent, DownloadService, EmailInputComponent, ExpandableTextComponent, FileInputComponent, FooterComponent, FormComponent, FormFooterComponent, GlobalContent, HeaderComponent, HintComponent, HourInputComponent, HrefComponent, Icon, IconComponent, IconService, ImageComponent, InAppBrowserService, InputType, ItemListComponent, LANGUAGES, LangService, LanguageSelectorComponent, LayeredCardComponent, LayoutComponent, LinkComponent, LinkProcessorService, LinksCakeComponent, ListContentHelper, LocalStorageService, MOTION, NavigationService, NoContentComponent, NotesBoxComponent, NumberInputComponent, OutlineDefault, OutlineDefaultBlock, OutlineDefaultFull, OutlineDefaultRound, OutlineDefaultRoundBlock, OutlineDefaultRoundFull, PasswordInputComponent, PinInputComponent, PopoverSelectorComponent, PrimarySolidBlockButton, PrimarySolidBlockHrefButton, PrimarySolidBlockIconButton, PrimarySolidBlockIconHrefButton, PrimarySolidDefaultRoundButton, PrimarySolidDefaultRoundHrefButton, PrimarySolidDefaultRoundIconButton, PrimarySolidDefaultRoundIconHrefButton, PrimarySolidFullButton, PrimarySolidFullHrefButton, PrimarySolidFullIconButton, PrimarySolidFullIconHrefButton, PrimarySolidLargeRoundButton, PrimarySolidLargeRoundHrefButton, PrimarySolidLargeRoundIconButton, PrimarySolidLargeRoundIconHrefButton, PrimarySolidSmallRoundButton, PrimarySolidSmallRoundHrefButton, PrimarySolidSmallRoundIconButton, PrimarySolidSmallRoundIconHrefButton, ProcessLinksPipe, ProgressBarComponent, ProgressStatusComponent, PrompterComponent, RadioInputComponent, SearchSelectorComponent, SearchbarComponent, SecondarySolidBlockButton, SecondarySolidBlockHrefButton, SecondarySolidBlockIconButton, SecondarySolidBlockIconHrefButton, SecondarySolidDefaultRoundButton, SecondarySolidDefaultRoundHrefButton, SecondarySolidDefaultRoundIconButton, SecondarySolidDefaultRoundIconHrefButton, SecondarySolidFullButton, SecondarySolidFullHrefButton, SecondarySolidFullIconButton, SecondarySolidFullIconHrefButton, SecondarySolidLargeRoundButton, SecondarySolidLargeRoundHrefButton, SecondarySolidLargeRoundIconButton, SecondarySolidLargeRoundIconHrefButton, SecondarySolidSmallRoundButton, SecondarySolidSmallRoundHrefButton, SecondarySolidSmallRoundIconButton, SecondarySolidSmallRoundIconHrefButton, SelectSearchComponent, SimpleComponent, SolidBlockButton, SolidDefault, SolidDefaultBlock, SolidDefaultButton, SolidDefaultFull, SolidDefaultRound, SolidDefaultRoundBlock, SolidDefaultRoundButton, SolidDefaultRoundFull, SolidFullButton, SolidLargeButton, SolidLargeRoundButton, SolidSmallButton, SolidSmallRoundButton, TextComponent, TextContent, TextInputComponent, ThemeOption, ThemeService, TitleBlockComponent, TitleComponent, ToastService, ToolbarActionType, ToolbarComponent, ValtechConfigService, WizardComponent, WizardFooterComponent, applyDefaultValueToControl, clearRegisteredContentQueue, content, createButtonProps, createComponentContentHelper, createContentHelper, createContentModule, createDisplayProps, createReactiveProps, createTextProps, createTitleProps, fromContent, fromContentWithInterpolation, fromMultipleContent, getRegisteredContentQueue, globalContentData, goToTop, interpolateContent, isAtEnd, loadRegisteredContent, maxLength, registerContent, replaceSpecialChars, resolveColor, resolveInputDefaultValue, shouldUseReactiveContent };
|
|
8407
8468
|
//# sourceMappingURL=valtech-components.mjs.map
|