mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
improve how extension-api is exposed/loaded
Signed-off-by: Jari Kolehmainen <jari.kolehmainen@gmail.com>
This commit is contained in:
parent
aa864fc199
commit
835b2e8916
3445
extensions/example-extension/package-lock.json
generated
3445
extensions/example-extension/package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@ -9,13 +9,17 @@
|
|||||||
"styles": []
|
"styles": []
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"build": "tsc",
|
"build": "npm run build:main && npm run build:renderer",
|
||||||
|
"build:main": "tsc",
|
||||||
|
"build:renderer": "webpack --config webpack.config.js",
|
||||||
"dev": "tsc --watch"
|
"dev": "tsc --watch"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"react-open-doodles": "^1.0.5"
|
"react-open-doodles": "^1.0.5"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"typescript": "^4.0.3"
|
"ts-loader": "^8.0.4",
|
||||||
|
"typescript": "^4.0.3",
|
||||||
|
"webpack": "^4.44.2"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,6 +1,7 @@
|
|||||||
import { Button, Icon, IconProps, LensRendererExtension, React } from "@lens/ui-extensions";
|
import { Button, Icon, IconProps, LensRendererExtension } from "@lens/ui-extensions";
|
||||||
import { CoffeeDoodle } from "react-open-doodles";
|
import { CoffeeDoodle } from "react-open-doodles";
|
||||||
import path from "path";
|
import path from "path";
|
||||||
|
import React from "react"
|
||||||
|
|
||||||
export function ExtensionIcon(props: IconProps) {
|
export function ExtensionIcon(props: IconProps) {
|
||||||
return <Icon {...props} material="pages" tooltip={path.basename(__filename)}/>
|
return <Icon {...props} material="pages" tooltip={path.basename(__filename)}/>
|
||||||
|
|||||||
@ -17,7 +17,6 @@
|
|||||||
},
|
},
|
||||||
"include": [
|
"include": [
|
||||||
"../../types",
|
"../../types",
|
||||||
"./renderer.ts",
|
|
||||||
"./main.ts"
|
"./main.ts"
|
||||||
],
|
],
|
||||||
"exclude": [
|
"exclude": [
|
||||||
|
|||||||
@ -17,13 +17,11 @@
|
|||||||
"dev:main": "yarn compile:main --watch",
|
"dev:main": "yarn compile:main --watch",
|
||||||
"dev:renderer": "yarn compile:renderer --watch",
|
"dev:renderer": "yarn compile:renderer --watch",
|
||||||
"dev:extension-rollup": "yarn compile:extension-rollup --watch",
|
"dev:extension-rollup": "yarn compile:extension-rollup --watch",
|
||||||
"dev:extension-api": "yarn compile:extension-api --watch",
|
|
||||||
"compile": "env NODE_ENV=production concurrently yarn:compile:*",
|
"compile": "env NODE_ENV=production concurrently yarn:compile:*",
|
||||||
"compile:main": "webpack --config webpack.main.ts",
|
"compile:main": "webpack --config webpack.main.ts",
|
||||||
"compile:renderer": "webpack --config webpack.renderer.ts",
|
"compile:renderer": "webpack --config webpack.renderer.ts",
|
||||||
"compile:i18n": "lingui compile",
|
"compile:i18n": "lingui compile",
|
||||||
"compile:extension-rollup": "rollup --config src/extensions/rollup.config.js",
|
"compile:extension-rollup": "rollup --config src/extensions/rollup.config.js",
|
||||||
"compile:extension-api": "webpack --config webpack.extensions.ts",
|
|
||||||
"build:linux": "yarn compile && electron-builder --linux --dir -c.productName=Lens",
|
"build:linux": "yarn compile && electron-builder --linux --dir -c.productName=Lens",
|
||||||
"build:mac": "yarn compile && electron-builder --mac --dir -c.productName=Lens",
|
"build:mac": "yarn compile && electron-builder --mac --dir -c.productName=Lens",
|
||||||
"build:win": "yarn compile && electron-builder --win --dir -c.productName=Lens",
|
"build:win": "yarn compile && electron-builder --win --dir -c.productName=Lens",
|
||||||
|
|||||||
@ -2,7 +2,6 @@
|
|||||||
import path from "path";
|
import path from "path";
|
||||||
import packageInfo from "../../package.json"
|
import packageInfo from "../../package.json"
|
||||||
import { defineGlobal } from "./utils/defineGlobal";
|
import { defineGlobal } from "./utils/defineGlobal";
|
||||||
import { addAlias } from "module-alias";
|
|
||||||
|
|
||||||
export const isMac = process.platform === "darwin"
|
export const isMac = process.platform === "darwin"
|
||||||
export const isWindows = process.platform === "win32"
|
export const isWindows = process.platform === "win32"
|
||||||
@ -37,15 +36,6 @@ defineGlobal("__static", {
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
// Special dynamic module aliases
|
|
||||||
if (isProduction && process.resourcesPath) {
|
|
||||||
addAlias("@lens/extensions", path.join(process.resourcesPath, "static", `build/${extensionsLibName}.js`))
|
|
||||||
addAlias("@lens/ui-extensions", path.join(process.resourcesPath, "static", `build/${extensionsRendererLibName}.js`))
|
|
||||||
} else {
|
|
||||||
addAlias("@lens/extensions", path.join(contextDir, "static", `build/${extensionsLibName}.js`))
|
|
||||||
addAlias("@lens/ui-extensions", path.join(contextDir, "static", `build/${extensionsRendererLibName}.js`))
|
|
||||||
}
|
|
||||||
|
|
||||||
// Apis
|
// Apis
|
||||||
export const apiPrefix = "/api" // local router apis
|
export const apiPrefix = "/api" // local router apis
|
||||||
export const apiKubePrefix = "/api-kube" // k8s cluster apis
|
export const apiKubePrefix = "/api-kube" // k8s cluster apis
|
||||||
|
|||||||
@ -89,21 +89,19 @@ export class ExtensionLoader {
|
|||||||
|
|
||||||
protected requireExtension(extension: InstalledExtension) {
|
protected requireExtension(extension: InstalledExtension) {
|
||||||
let extEntrypoint = ""
|
let extEntrypoint = ""
|
||||||
return withExtensionPackagesRoot(() => {
|
try {
|
||||||
try {
|
if (ipcRenderer && extension.manifest.renderer) {
|
||||||
if (ipcRenderer && extension.manifest.renderer) {
|
extEntrypoint = path.resolve(path.join(path.dirname(extension.manifestPath), extension.manifest.renderer))
|
||||||
extEntrypoint = path.resolve(path.join(path.dirname(extension.manifestPath), extension.manifest.renderer))
|
} else if (extension.manifest.main) {
|
||||||
} else if (extension.manifest.main) {
|
extEntrypoint = path.resolve(path.join(path.dirname(extension.manifestPath), extension.manifest.main))
|
||||||
extEntrypoint = path.resolve(path.join(path.dirname(extension.manifestPath), extension.manifest.main))
|
|
||||||
}
|
|
||||||
if (extEntrypoint !== "") {
|
|
||||||
return __non_webpack_require__(extEntrypoint)
|
|
||||||
}
|
|
||||||
} catch (err) {
|
|
||||||
console.error(`[EXTENSION-LOADER]: can't load extension main at ${extEntrypoint}: ${err}`, { extension });
|
|
||||||
console.trace(err)
|
|
||||||
}
|
}
|
||||||
})
|
if (extEntrypoint !== "") {
|
||||||
|
return __non_webpack_require__(extEntrypoint)
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
console.error(`[EXTENSION-LOADER]: can't load extension main at ${extEntrypoint}: ${err}`, { extension });
|
||||||
|
console.trace(err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
getById(id: ExtensionId): InstalledExtension {
|
getById(id: ExtensionId): InstalledExtension {
|
||||||
|
|||||||
@ -1,13 +1,12 @@
|
|||||||
// Lens-extensions api developer's kit
|
// Lens-extensions api developer's kit
|
||||||
export type { LensExtensionRuntimeEnv } from "./lens-renderer-runtime"
|
export type { LensExtensionRuntimeEnv } from "./lens-renderer-runtime"
|
||||||
export type { PageStore } from "./page-store"
|
|
||||||
|
|
||||||
// APIs
|
// APIs
|
||||||
|
export * from "./lens-extension"
|
||||||
export * from "./lens-renderer-extension"
|
export * from "./lens-renderer-extension"
|
||||||
export { DynamicPageType } from "./page-store"
|
export { DynamicPageType, PageStore } from "./page-store"
|
||||||
|
|
||||||
// TODO: add more common re-usable UI components + refactor interfaces (Props -> ComponentProps)
|
// TODO: add more common re-usable UI components + refactor interfaces (Props -> ComponentProps)
|
||||||
export { default as React } from "react"
|
|
||||||
export * from "../renderer/components/icon"
|
export * from "../renderer/components/icon"
|
||||||
export * from "../renderer/components/tooltip"
|
export * from "../renderer/components/tooltip"
|
||||||
export * from "../renderer/components/button"
|
export * from "../renderer/components/button"
|
||||||
|
|||||||
@ -2,7 +2,8 @@ import type { PageStore } from "./extension-renderer-api"
|
|||||||
import type { PageRegistration } from "./page-store"
|
import type { PageRegistration } from "./page-store"
|
||||||
import { LensExtension } from "./lens-extension"
|
import { LensExtension } from "./lens-extension"
|
||||||
|
|
||||||
export abstract class LensRendererExtension extends LensExtension {
|
export class LensRendererExtension extends LensExtension {
|
||||||
|
|
||||||
registerPages(pageStore: PageStore) {
|
registerPages(pageStore: PageStore) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|||||||
@ -17,11 +17,16 @@ import { clusterStore } from "../common/cluster-store"
|
|||||||
import { userStore } from "../common/user-store";
|
import { userStore } from "../common/user-store";
|
||||||
import { workspaceStore } from "../common/workspace-store";
|
import { workspaceStore } from "../common/workspace-store";
|
||||||
import { tracker } from "../common/tracker";
|
import { tracker } from "../common/tracker";
|
||||||
|
import * as LensExtensions from "../extensions/extension-api";
|
||||||
import { extensionManager } from "../extensions/extension-manager";
|
import { extensionManager } from "../extensions/extension-manager";
|
||||||
import { extensionLoader } from "../extensions/extension-loader";
|
import { extensionLoader } from "../extensions/extension-loader";
|
||||||
import { getLensRuntime } from "../extensions/lens-runtime";
|
import { getLensRuntime } from "../extensions/lens-runtime";
|
||||||
import logger from "./logger"
|
import logger from "./logger"
|
||||||
|
|
||||||
|
export {
|
||||||
|
LensExtensions
|
||||||
|
}
|
||||||
|
|
||||||
const workingDir = path.join(app.getPath("appData"), appName);
|
const workingDir = path.join(app.getPath("appData"), appName);
|
||||||
app.setName(appName);
|
app.setName(appName);
|
||||||
if (!process.env.CICD) {
|
if (!process.env.CICD) {
|
||||||
|
|||||||
@ -1,5 +1,7 @@
|
|||||||
import "./components/app.scss"
|
import "./components/app.scss"
|
||||||
import React from "react";
|
import React from "react";
|
||||||
|
import * as Mobx from "mobx"
|
||||||
|
import * as LensExtensions from "../extensions/extension-renderer-api"
|
||||||
import { render, unmountComponentAtNode } from "react-dom";
|
import { render, unmountComponentAtNode } from "react-dom";
|
||||||
import { isMac } from "../common/vars";
|
import { isMac } from "../common/vars";
|
||||||
import { userStore } from "../common/user-store";
|
import { userStore } from "../common/user-store";
|
||||||
@ -14,6 +16,12 @@ type AppComponent = React.ComponentType & {
|
|||||||
init?(): void;
|
init?(): void;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export {
|
||||||
|
React,
|
||||||
|
Mobx,
|
||||||
|
LensExtensions
|
||||||
|
}
|
||||||
|
|
||||||
export async function bootstrap(App: AppComponent) {
|
export async function bootstrap(App: AppComponent) {
|
||||||
const rootElem = document.getElementById("app")
|
const rootElem = document.getElementById("app")
|
||||||
rootElem.classList.toggle("is-mac", isMac);
|
rootElem.classList.toggle("is-mac", isMac);
|
||||||
|
|||||||
@ -1,50 +0,0 @@
|
|||||||
import { extensionsDir, extensionsLibName, extensionsRendererLibName } from "./src/common/vars";
|
|
||||||
import path from "path";
|
|
||||||
import webpack from "webpack";
|
|
||||||
import nodeExternals from "webpack-node-externals";
|
|
||||||
import { webpackLensRenderer } from "./webpack.renderer";
|
|
||||||
import ForkTsCheckerPlugin from "fork-ts-checker-webpack-plugin";
|
|
||||||
import ProgressBarPlugin from "progress-bar-webpack-plugin";
|
|
||||||
import MiniCssExtractPlugin from "mini-css-extract-plugin";
|
|
||||||
|
|
||||||
export default [
|
|
||||||
webpackExtensionsApi,
|
|
||||||
webpackExtensionsRendererApi
|
|
||||||
]
|
|
||||||
|
|
||||||
// todo: use common chunks/externals for "react", "react-dom", etc.
|
|
||||||
export function webpackExtensionsApi(): webpack.Configuration {
|
|
||||||
const config = webpackLensRenderer({ showVars: false })
|
|
||||||
config.name = "extensions-api"
|
|
||||||
config.entry = {
|
|
||||||
[extensionsLibName]: path.resolve(extensionsDir, "extension-api.ts")
|
|
||||||
}
|
|
||||||
config.externals = [
|
|
||||||
nodeExternals()
|
|
||||||
]
|
|
||||||
config.plugins = [
|
|
||||||
new ProgressBarPlugin(),
|
|
||||||
new ForkTsCheckerPlugin(),
|
|
||||||
]
|
|
||||||
config.output.libraryTarget = "commonjs2"
|
|
||||||
config.devtool = "nosources-source-map"
|
|
||||||
return config
|
|
||||||
}
|
|
||||||
|
|
||||||
export function webpackExtensionsRendererApi(): webpack.Configuration {
|
|
||||||
const config = webpackLensRenderer({ showVars: false })
|
|
||||||
config.name = "extensions-renderer-api"
|
|
||||||
config.entry = {
|
|
||||||
[extensionsRendererLibName]: path.resolve(extensionsDir, "extension-renderer-api.ts")
|
|
||||||
}
|
|
||||||
config.plugins = [
|
|
||||||
new ProgressBarPlugin(),
|
|
||||||
new ForkTsCheckerPlugin(),
|
|
||||||
new MiniCssExtractPlugin({
|
|
||||||
filename: "[name].css",
|
|
||||||
})
|
|
||||||
]
|
|
||||||
config.output.libraryTarget = "commonjs2"
|
|
||||||
config.devtool = "nosources-source-map"
|
|
||||||
return config
|
|
||||||
}
|
|
||||||
@ -17,16 +17,12 @@ export default function (): webpack.Configuration {
|
|||||||
main: path.resolve(mainDir, "index.ts"),
|
main: path.resolve(mainDir, "index.ts"),
|
||||||
},
|
},
|
||||||
output: {
|
output: {
|
||||||
|
libraryTarget: "global",
|
||||||
path: buildDir,
|
path: buildDir,
|
||||||
},
|
},
|
||||||
resolve: {
|
resolve: {
|
||||||
extensions: ['.json', '.js', '.ts']
|
extensions: ['.json', '.js', '.ts']
|
||||||
},
|
},
|
||||||
node: {
|
|
||||||
// webpack modifies node internals by default, keep as is for main-process
|
|
||||||
__dirname: false,
|
|
||||||
__filename: false,
|
|
||||||
},
|
|
||||||
externals: [
|
externals: [
|
||||||
nodeExternals()
|
nodeExternals()
|
||||||
],
|
],
|
||||||
|
|||||||
@ -26,6 +26,9 @@ export function webpackLensRenderer({ showVars = true } = {}): webpack.Configura
|
|||||||
[appName]: path.resolve(rendererDir, "bootstrap.tsx"),
|
[appName]: path.resolve(rendererDir, "bootstrap.tsx"),
|
||||||
},
|
},
|
||||||
output: {
|
output: {
|
||||||
|
libraryTarget: "global",
|
||||||
|
library: "",
|
||||||
|
globalObject: "this",
|
||||||
publicPath: publicPath,
|
publicPath: publicPath,
|
||||||
path: buildDir,
|
path: buildDir,
|
||||||
filename: '[name].js',
|
filename: '[name].js',
|
||||||
@ -43,7 +46,7 @@ export function webpackLensRenderer({ showVars = true } = {}): webpack.Configura
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
optimization: {
|
optimization: {
|
||||||
minimize: isProduction,
|
minimize: false,
|
||||||
minimizer: [
|
minimizer: [
|
||||||
new TerserPlugin({
|
new TerserPlugin({
|
||||||
cache: true,
|
cache: true,
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user