/** * 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, InputValidator, 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"; export interface InstallProps { installPath: string; supportedFormats: string[]; onChange: (path: string) => void; installFromInput: () => void; installFromSelectFileDialog: () => void; } interface Dependencies { extensionInstallationStateStore: ExtensionInstallationStateStore; } const installInputValidators = [ InputValidators.isUrl, InputValidators.isPath, InputValidators.isExtensionNameInstall, ]; const installInputValidator: InputValidator = { message: "Invalid URL, absolute path, or extension name", validate: (value: string) => ( installInputValidators.some(({ validate }) => validate(value)) ), }; const NonInjectedInstall: React.FC = ({ installPath, supportedFormats, onChange, installFromInput, installFromSelectFileDialog, extensionInstallationStateStore, }) => (
} />
Pro-Tip: you can drag-n-drop tarball-file to this area
); export const Install = withInjectables( observer(NonInjectedInstall), { getProps: (di, props) => ({ extensionInstallationStateStore: di.inject( extensionInstallationStateStoreInjectable, ), ...props, }), }, );