/** * Copyright (c) OpenLens Authors. All rights reserved. * Licensed under MIT License. See LICENSE in root directory for more information. */ import styles from "./install.module.scss"; import React from "react"; import { prevDefault } from "../../utils"; import { Button } from "../button"; import { Icon } from "../icon"; import { observer } from "mobx-react"; import { Input, InputValidators } from "../input"; import { SubTitle } from "../layout/sub-title"; import { TooltipPosition } from "../tooltip"; import type { ExtensionInstallationStateStore } from "../../../extensions/extension-installation-state-store/extension-installation-state-store"; import extensionInstallationStateStoreInjectable from "../../../extensions/extension-installation-state-store/extension-installation-state-store.injectable"; import { withInjectables } from "@ogre-tools/injectable-react"; import { unionInputValidatorsAsync } from "../input/input_validators"; export interface InstallProps { installPath: string; supportedFormats: string[]; onChange: (path: string) => void; installFromInput: () => void; installFromSelectFileDialog: () => void; } interface Dependencies { extensionInstallationStateStore: ExtensionInstallationStateStore; } const installInputValidator = unionInputValidatorsAsync( { message: "Invalid URL, absolute path, or extension name", }, InputValidators.isUrl, InputValidators.isExtensionNameInstall, InputValidators.isPath, ); const NonInjectedInstall: React.FC = ({ installPath, supportedFormats, onChange, installFromInput, installFromSelectFileDialog, extensionInstallationStateStore, }) => (
)} />
Pro-Tip : you can drag and drop a tarball file to this area
); export const Install = withInjectables( observer(NonInjectedInstall), { getProps: (di, props) => ({ extensionInstallationStateStore: di.inject( extensionInstallationStateStoreInjectable, ), ...props, }), }, );