Skip to content

Commit

Permalink
Change openURL by OpenURI, accepting URI instead of string
Browse files Browse the repository at this point in the history
  • Loading branch information
feloy committed Jan 29, 2024
1 parent ff1fecd commit 94234d4
Show file tree
Hide file tree
Showing 6 changed files with 13 additions and 7 deletions.
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@
"typecheck": "npm run typecheck:shared && npm run typecheck:frontend && npm run typecheck:backend"
},
"devDependencies": {
"@podman-desktop/api": "1.7.0",
"@typescript-eslint/eslint-plugin": "^6.16.0",
"@typescript-eslint/parser": "^6.16.0",
"@vitest/coverage-v8": "^1.1.0",
Expand Down
4 changes: 2 additions & 2 deletions packages/backend/src/studio-api-impl.ts
Original file line number Diff line number Diff line change
Expand Up @@ -44,8 +44,8 @@ export class StudioApiImpl implements StudioAPI {
return 'pong';
}

async openURL(url: string): Promise<boolean> {
return await podmanDesktopApi.env.openExternal(podmanDesktopApi.Uri.parse(url));
async openURI(uri: podmanDesktopApi.Uri): Promise<boolean> {
return await podmanDesktopApi.env.openExternal(uri);
}

async getPullingStatus(recipeId: string): Promise<RecipeStatus> {
Expand Down
3 changes: 2 additions & 1 deletion packages/frontend/src/lib/markdown/LinkComponent.svelte
Original file line number Diff line number Diff line change
@@ -1,12 +1,13 @@
<script lang="ts">
import { studioClient } from '/@/utils/client.js';
import { Uri } from '@podman-desktop/api';
export let href: string = "";
export let title: string | undefined = undefined;
export let text: string = "";
const onClick = () => {
studioClient.openURL(href);
studioClient.openURI(Uri.parse(href));
}
</script>
<!-- href set to void operator to avoid any redirect -->
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@ import ListItemButtonIcon from "../../button/ListItemButtonIcon.svelte";
import { studioClient } from "/@/utils/client";
import Modal from "../../Modal.svelte";
import Button from "../../button/Button.svelte";
import { Uri } from '@podman-desktop/api';
export let object: ModelInfo;
let deleteConfirmVisible: boolean = false;
Expand All @@ -21,7 +23,7 @@ async function goDeleteModel() {
function openModelFolder() {
if (object && object.file) {
studioClient.openURL('file://'+object.file.path);
studioClient.openURI(Uri.file(object.file.path));
}
}
</script>
Expand Down
5 changes: 3 additions & 2 deletions packages/frontend/src/pages/Recipe.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,8 @@ import { getDisplayName } from '/@/utils/versionControlUtils';
import { getIcon } from '/@/utils/categoriesUtils';
import RecipeModels from './RecipeModels.svelte';
import { catalog } from '/@/stores/catalog';
import { recipes } from '/@/stores/recipe';
import { recipes } from '/@/stores/recipe';
import { Uri } from '@podman-desktop/api';
export let recipeId: string;
Expand All @@ -31,7 +32,7 @@ const onPullingRequest = async () => {
const onClickRepository = () => {
if (recipe) {
studioClient.openURL(recipe.repository);
studioClient.openURI(Uri.parse(recipe.repository));
}
}
</script>
Expand Down
3 changes: 2 additions & 1 deletion packages/shared/src/StudioAPI.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,15 @@ import type { ModelInfo } from './models/IModelInfo';
import type { QueryState } from './models/IPlaygroundQueryState';
import type { Catalog } from './models/ICatalog';
import type { PlaygroundState } from './models/IPlaygroundState';
import type { Uri } from '@podman-desktop/api';

export abstract class StudioAPI {
abstract ping(): Promise<string>;
abstract getCatalog(): Promise<Catalog>;
abstract getPullingStatus(recipeId: string): Promise<RecipeStatus>;
abstract getPullingStatuses(): Promise<Map<string, RecipeStatus>>;
abstract pullApplication(recipeId: string): Promise<void>;
abstract openURL(url: string): Promise<boolean>;
abstract openURI(uri: Uri): Promise<boolean>;
/**
* Get the information of models saved locally into the user's directory
*/
Expand Down

0 comments on commit 94234d4

Please sign in to comment.