/** * Copyright (c) 2021 OpenLens Authors * * Permission is hereby granted, free of charge, to any person obtaining a copy of * this software and associated documentation files (the "Software"), to deal in * the Software without restriction, including without limitation the rights to * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of * the Software, and to permit persons to whom the Software is furnished to do so, * subject to the following conditions: * * The above copyright notice and this permission notice shall be included in all * copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ 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"; interface Props { 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, }), }, );