- You can also integrate with Azure OpenAI by enabling the "Use Azure OpenAI" checkbox
- and setting the Resource URL to your Azure OpenAI resource (e.g.,
- https://your-resource.openai.azure.com). Set the deployment name in the Model field
- and specify the appropriate API version for your Azure deployment.
+ You can also integrate with Azure OpenAI by enabling the Use Azure OpenAI{" "}
+ checkbox and setting the Resource URL to your Azure OpenAI resource:{" "}
+ https://your-resource.openai.azure.com. Set the deployment name in the
+ Model field and specify the appropriate API version for your Azure deployment.
@@ -136,8 +153,8 @@ export const OpenAISettings = () => {
You can also integrate with Ollama simply by setting the API key to
sk-1234567890abcdef and the Base URL to your Ollama URL, i.e.
- http://localhost:11434/v1. You can also pick and choose models and set the max tokens
- as per your preference.
+ http://localhost:11434/v1. You can also pick and choose models and set the
+ max tokens as per your preference.
@@ -163,10 +180,7 @@ export const OpenAISettings = () => {
render={({ field }) => (
- {form.watch("isAzure")
- ? t`Azure OpenAI Resource URL`
- : t`Base URL`
- }
+ {form.watch("isAzure") ? t`Azure OpenAI Resource URL` : t`Base URL`}
{
control={form.control}
render={({ field }) => (
-
- {form.watch("isAzure")
- ? t`Deployment Name`
- : t`Model`
- }
-
+ {form.watch("isAzure") ? t`Deployment Name` : t`Model`}
@@ -228,7 +237,7 @@ export const OpenAISettings = () => {
{
field.onChange(Boolean(value));
}}
diff --git a/apps/client/src/services/openai/client.ts b/apps/client/src/services/openai/client.ts
index 5bbb6ef5..7e290abe 100644
--- a/apps/client/src/services/openai/client.ts
+++ b/apps/client/src/services/openai/client.ts
@@ -13,40 +13,25 @@ export const openai = () => {
}
if (isAzure) {
- if (!baseURL) {
- throw new Error(t`Azure OpenAI Base URL is required when using Azure OpenAI.`);
+ if (!baseURL || !model || !azureApiVersion) {
+ throw new Error(
+ t`Azure OpenAI Base URL, deployment name (model), and API version are required when using Azure OpenAI.`,
+ );
}
- if (!model) {
- throw new Error(t`Azure OpenAI deployment name (model) is required when using Azure OpenAI.`);
- }
-
- if (!azureApiVersion) {
- throw new Error(t`Azure OpenAI API version is required when using Azure OpenAI.`);
- }
-
- // Construct Azure OpenAI URL: https://your-resource.openai.azure.com/openai/deployments/your-deployment
- const azureBaseURL = baseURL.endsWith('/') ? baseURL.slice(0, -1) : baseURL;
- const constructedURL = `${azureBaseURL}/openai/deployments/${model}`;
+ const azureBaseURL = baseURL.replace(/\/$/, "");
return new OpenAI({
apiKey,
- baseURL: constructedURL,
- defaultQuery: { "api-version": azureApiVersion ?? undefined },
- dangerouslyAllowBrowser: true,
- });
- }
-
- if (baseURL) {
- return new OpenAI({
- apiKey,
- baseURL,
+ baseURL: `${azureBaseURL}/openai/deployments/${model}`,
+ defaultQuery: { "api-version": azureApiVersion },
dangerouslyAllowBrowser: true,
});
}
return new OpenAI({
apiKey,
+ baseURL,
dangerouslyAllowBrowser: true,
});
};
diff --git a/apps/client/src/stores/openai.ts b/apps/client/src/stores/openai.ts
index 0286afb2..09afdf77 100644
--- a/apps/client/src/stores/openai.ts
+++ b/apps/client/src/stores/openai.ts
@@ -1,7 +1,7 @@
import { create } from "zustand";
import { persist } from "zustand/middleware";
-import { DEFAULT_MAX_TOKENS, DEFAULT_MODEL, DEFAULT_AZURE_API_VERSION } from "../constants/llm";
+import { DEFAULT_AZURE_API_VERSION, DEFAULT_MAX_TOKENS, DEFAULT_MODEL } from "../constants/llm";
type OpenAIStore = {
baseURL: string | null;
diff --git a/apps/server/src/printer/printer.service.ts b/apps/server/src/printer/printer.service.ts
index dfebf7aa..92076d7b 100644
--- a/apps/server/src/printer/printer.service.ts
+++ b/apps/server/src/printer/printer.service.ts
@@ -145,7 +145,7 @@ export class PrinterService {
Promise.all(
// eslint-disable-next-line unicorn/prefer-spread
Array.from(document.images).map((img) => {
- if (img.complete) return;
+ if (img.complete) return Promise.resolve();
return new Promise((resolve) => {
// eslint-disable-next-line unicorn/prefer-add-event-listener
img.onload = img.onerror = resolve;
diff --git a/package.json b/package.json
index bd3a124a..d91c8844 100644
--- a/package.json
+++ b/package.json
@@ -1,7 +1,7 @@
{
"name": "@reactive-resume/source",
"description": "A free and open-source resume builder that simplifies the process of creating, updating, and sharing your resume.",
- "version": "4.4.7",
+ "version": "4.4.8",
"license": "MIT",
"private": true,
"packageManager": "pnpm@10.17.1+sha512.17c560fca4867ae9473a3899ad84a88334914f379be46d455cbf92e5cf4b39d34985d452d2583baf19967fa76cb5c17bc9e245529d0b98745721aa7200ecaf7a",