diff --git a/src/Services/InfoProviderSystem/Providers/AIInfoExtractor.php b/src/Services/InfoProviderSystem/Providers/AIInfoExtractor.php
index d5be0267..c8eff0a4 100644
--- a/src/Services/InfoProviderSystem/Providers/AIInfoExtractor.php
+++ b/src/Services/InfoProviderSystem/Providers/AIInfoExtractor.php
@@ -60,7 +60,7 @@ final class AIInfoExtractor implements InfoProviderInterface
return [
'name' => 'AI Information Extractor',
'description' => 'Extract part info from any URL using OpenRouter LLM',
- 'url' => 'https://openrouter.ai',
+ //'url' => 'https://openrouter.ai',
'disabled_help' => 'Configure OpenRouter API key in settings',
'settings_class' => AIExtractorSettings::class,
];
@@ -73,7 +73,7 @@ final class AIInfoExtractor implements InfoProviderInterface
public function isActive(): bool
{
- return $this->settings->platform !== null && $this->settings->model !== '';
+ return $this->settings->platform !== null && $this->settings->model !== null && $this->settings->model !== '';
}
public function searchByKeyword(string $keyword): array
@@ -171,7 +171,7 @@ final class AIInfoExtractor implements InfoProviderInterface
$aiPlatform = $this->AIPlatformRegistry->getPlatform($this->settings->platform ?? throw new \RuntimeException('No AI platform selected') );
//'openai/gpt-5-mini'
- $result = $aiPlatform->invoke($this->settings->model, $input, [
+ $result = $aiPlatform->invoke($this->settings->model ?? throw new \RuntimeException('No model selected'), $input, [
'response_format' => [
'type' => 'json_schema',
'json_schema' => $this->jsonSchemaConverter->getJSONSchema(),
diff --git a/src/Settings/AISettings/AISettings.php b/src/Settings/AISettings/AISettings.php
index 0e99d6fc..732eb597 100644
--- a/src/Settings/AISettings/AISettings.php
+++ b/src/Settings/AISettings/AISettings.php
@@ -29,7 +29,7 @@ use Jbtronics\SettingsBundle\Settings\Settings;
use Jbtronics\SettingsBundle\Settings\SettingsTrait;
use Symfony\Component\Translation\TranslatableMessage as TM;
-#[Settings(label: new TM("settings.ai"), description: "settings.ai.help")]
+#[Settings(label: new TM("settings.ai"))]
#[SettingsIcon("fa-brain")]
class AISettings
{
diff --git a/src/Settings/AISettings/LMStudioSettings.php b/src/Settings/AISettings/LMStudioSettings.php
index ea6b9681..627961a9 100644
--- a/src/Settings/AISettings/LMStudioSettings.php
+++ b/src/Settings/AISettings/LMStudioSettings.php
@@ -33,8 +33,8 @@ use Jbtronics\SettingsBundle\Settings\SettingsTrait;
use Symfony\Component\Form\Extension\Core\Type\UrlType;
use Symfony\Component\Translation\TranslatableMessage as TM;
-#[Settings(name: 'ai_lmstudio', label: new TM("settings.ai.openrouter"), description: "settings.ai.lmstudio.help")]
-#[SettingsIcon("fa-brain")]
+#[Settings(name: 'ai_lmstudio', label: new TM("settings.ai.lmstudio"))]
+#[SettingsIcon("fa-robot")]
class LMStudioSettings implements AIPlatformSettingsInterface
{
use SettingsTrait;
diff --git a/src/Settings/AISettings/OpenRouterSettings.php b/src/Settings/AISettings/OpenRouterSettings.php
index 7b96c1d9..e083513a 100644
--- a/src/Settings/AISettings/OpenRouterSettings.php
+++ b/src/Settings/AISettings/OpenRouterSettings.php
@@ -33,7 +33,7 @@ use Jbtronics\SettingsBundle\Settings\SettingsTrait;
use Symfony\Component\Translation\TranslatableMessage as TM;
#[Settings(name: 'ai_openrouter', label: new TM("settings.ai.openrouter"), description: "settings.ai.openrouter.help")]
-#[SettingsIcon("fa-brain")]
+#[SettingsIcon("fa-robot")]
class OpenRouterSettings implements AIPlatformSettingsInterface
{
use SettingsTrait;
diff --git a/src/Settings/InfoProviderSystem/AIExtractorSettings.php b/src/Settings/InfoProviderSystem/AIExtractorSettings.php
index 2efd6717..876c687f 100644
--- a/src/Settings/InfoProviderSystem/AIExtractorSettings.php
+++ b/src/Settings/InfoProviderSystem/AIExtractorSettings.php
@@ -35,32 +35,25 @@ use Symfony\AI\Platform\Capability;
use Symfony\Component\Translation\TranslatableMessage as TM;
#[Settings(name: "ai_extractor", label: new TM("settings.ips.ai_extractor"), description: new TM("settings.ips.ai_extractor.description"))]
-#[SettingsIcon("fa-robot")]
+#[SettingsIcon("fa-plug")]
class AIExtractorSettings
{
private const MODEL_SELECTOR_LABEL = 'ai_extractor';
use SettingsTrait;
- #[SettingsParameter(label: new TM("settings.ips.ai_extractor.ai_platform"), description: new TM("settings.ips.ai_extractor.ai_platform.help"),
+ #[SettingsParameter(label: new TM("settings.ips.ai_extractor.ai_platform"),
formType: AiPlatformChoiceType::class, formOptions: ['platform_selector_label' => self::MODEL_SELECTOR_LABEL],
- envVar: "string:PROVIDER_AI_EXTRACTOR_API_KEY", envVarMode: EnvVarMode::OVERWRITE
)]
public ?AIPlatforms $platform = null;
- #[SettingsParameter(label: new TM("settings.ips.ai_extractor.model"), description: new TM("settings.ips.ai_extractor.model.description"),
+ #[SettingsParameter(label: new TM("settings.ips.ai_extractor.model"), description: new TM("settings.ips.ai_extractor.model.help"),
formType: AiModelsType::class, formOptions: ['platform_selector' => self::MODEL_SELECTOR_LABEL, 'filter_capability' => Capability::OUTPUT_STRUCTURED],
- envVar: "string:PROVIDER_AI_EXTRACTOR_MODEL", envVarMode: EnvVarMode::OVERWRITE
)]
- public string $model = 'z-ai/glm-4.7';
+ public ?string $model = null;
- #[SettingsParameter(label: new TM("settings.ips.ai_extractor.enabled"), description: new TM("settings.ips.ai_extractor.enabled.description"),
- envVar: "bool:PROVIDER_AI_EXTRACTOR_ENABLED", envVarMode: EnvVarMode::OVERWRITE
- )]
- public bool $enabled = false;
-
- #[SettingsParameter(label: new TM("settings.ips.ai_extractor.max_content_length"), description: new TM("settings.ips.ai_extractor.max_content_length.description"),
- envVar: "int:PROVIDER_AI_EXTRACTOR_MAX_CONTENT_LENGTH", envVarMode: EnvVarMode::OVERWRITE
+ #[SettingsParameter(label: new TM("settings.ips.ai_extractor.max_content_length"),
+ description: new TM("settings.ips.ai_extractor.max_content_length.description"),
)]
public int $maxContentLength = 50000;
}
diff --git a/translations/messages.en.xlf b/translations/messages.en.xlf
index 4da88512..e16a6d69 100644
--- a/translations/messages.en.xlf
+++ b/translations/messages.en.xlf
@@ -2780,7 +2780,7 @@ If you have done this incorrectly or if a computer is no longer trusted, you can
Name
-
+ part.table.si_valueSI Value
@@ -7218,13 +7218,13 @@ Element 1 -> Element 1.2
Subprojects
-
+ project.info.total_build_priceTotal build price
-
+ project.info.per_unit_priceper unit
@@ -7254,7 +7254,7 @@ Element 1 -> Element 1.2
Price
-
+ project.bom.ext_priceExtended Price
@@ -10053,85 +10053,85 @@ Please note, that you can not impersonate a disabled user. If you try you will g
When enabled, the datasheet field in KiCad will link to the actual PDF file (if found). When disabled, it will link to the Part-DB page instead. The Part-DB page link is always available as a separate "Part-DB URL" field.
-
+ settings.misc.kicad_eda.editor.titleKiCad autocomplete lists
-
+ settings.misc.kicad_eda.editor.linkAutocomplete settings
-
+ settings.misc.kicad_eda.editor.descriptionConfigure whether KiCad autocomplete uses the autogenerated default lists or your custom override files. The custom files are editable here, while the default files are shown read-only for reference.
-
+ settings.misc.kicad_eda.editor.footprintsFootprints list
-
+ settings.misc.kicad_eda.editor.footprints.helpOne entry per line. Used as autocomplete suggestions for KiCad footprint fields.
-
+ settings.misc.kicad_eda.editor.symbolsSymbols list
-
+ settings.misc.kicad_eda.editor.symbols.helpOne entry per line. Used as autocomplete suggestions for KiCad symbol fields.
-
+ settings.misc.kicad_eda.use_custom_listUse custom autocomplete lists
-
+ settings.misc.kicad_eda.use_custom_list.helpWhen enabled, KiCad autocomplete uses public/kicad/footprints_custom.txt and public/kicad/symbols_custom.txt instead of the autogenerated default files.
-
+ settings.misc.kicad_eda.editor.custom_footprintsCustom footprints list
-
+ settings.misc.kicad_eda.editor.custom_symbolsCustom symbols list
-
+ settings.misc.kicad_eda.editor.default_footprintsDefault footprints list
-
+ settings.misc.kicad_eda.editor.default_symbolsDefault symbols list
-
+ settings.misc.kicad_eda.editor.default_files_helpAutogenerated file shown for reference only. Changes must be made in the custom list.
@@ -13067,5 +13067,41 @@ Buerklin-API Authentication server:
Mapping error: Check if you have selected the right delimiter!
+
+
+ settings.ai
+ AI
+
+
+
+
+ settings.ai.openrouter
+ OpenRouter
+
+
+
+
+ settings.ai.lmstudio
+ LMStudio
+
+
+
+
+ settings.ips.ai_extractor.model
+ AI Model
+
+
+
+
+ settings.ips.ai_extractor.ai_platform
+ AI Platform
+
+
+
+
+ settings.ips.ai_extractor.model.help
+ The AI model that should be used for extraction. Must support structured output.
+
+