@teambit/envs 0.0.674 → 0.0.677
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/environment.d.ts +29 -0
- package/dist/environment.js.map +1 -1
- package/dist/environments.main.runtime.d.ts +6 -1
- package/dist/environments.main.runtime.js +13 -0
- package/dist/environments.main.runtime.js.map +1 -1
- package/dist/envs.cmd.d.ts +2 -2
- package/dist/envs.cmd.js +40 -26
- package/dist/envs.cmd.js.map +1 -1
- package/envs.cmd.tsx +34 -31
- package/package-tar/teambit-envs-0.0.677.tgz +0 -0
- package/package.json +22 -21
- package/{preview-1647202499074.js → preview-1647401023351.js} +1 -1
- package/package-tar/teambit-envs-0.0.674.tgz +0 -0
package/dist/environment.d.ts
CHANGED
|
@@ -48,6 +48,29 @@ export interface DependenciesEnv extends Environment {
|
|
|
48
48
|
* Required for any task
|
|
49
49
|
*/
|
|
50
50
|
getDependencies?: () => EnvPolicyConfigObject | Promise<EnvPolicyConfigObject>;
|
|
51
|
+
/**
|
|
52
|
+
* Returns a list of additional host dependencies
|
|
53
|
+
* this list will be provided as globals on the window after bit preview bundle
|
|
54
|
+
* by default bit will merge this list with the peers from the getDependencies function
|
|
55
|
+
* If you want full control use the getHostDependencies function
|
|
56
|
+
*/
|
|
57
|
+
getAdditionalHostDependencies?: () => string[] | Promise<string[]>;
|
|
58
|
+
/**
|
|
59
|
+
* Returns a list of host dependencies
|
|
60
|
+
* this list will be provided as globals on the window after bit preview bundle
|
|
61
|
+
* If this is provided, bit won't merge getAdditionalHostDependencies and the peers from getDependencies
|
|
62
|
+
* but give you full control over the list
|
|
63
|
+
*
|
|
64
|
+
* The reason we provided both options is the following:
|
|
65
|
+
* in most cases when you override the deps from you env, you want bit to take your peers
|
|
66
|
+
* however, if we only provide the getHostDependencies, during the env composition, you will get the peers of the
|
|
67
|
+
* original env. which doesn't contain your peers.
|
|
68
|
+
* In that case you might think that we only need the first option of getAdditionalHostDependencies + getDependencies peers
|
|
69
|
+
* but there are cases when you want a peer to your component, but you don't want it as part of the bundle.
|
|
70
|
+
* such an example is react-native env which adds react-native as peer, but you don't want it in the bundle as it's not web compatible
|
|
71
|
+
* so you want full control over it
|
|
72
|
+
*/
|
|
73
|
+
getHostDependencies?: () => string[] | Promise<string[]>;
|
|
51
74
|
}
|
|
52
75
|
export declare type GetNpmIgnoreContext = {
|
|
53
76
|
capsule: Capsule;
|
|
@@ -98,6 +121,12 @@ export interface PreviewEnv extends Environment {
|
|
|
98
121
|
* Returns preview config like the strategy name to use when bundling the components for the preview
|
|
99
122
|
*/
|
|
100
123
|
getPreviewConfig?: () => EnvPreviewConfig;
|
|
124
|
+
/**
|
|
125
|
+
* Returns a bundler for the env template.
|
|
126
|
+
* this bundler will be used to bundle the docs/compositions (or other preview) apps
|
|
127
|
+
* Required for `bit build` & `bit tag`
|
|
128
|
+
*/
|
|
129
|
+
getTemplateBundler?: (context: BundlerContext, transformers?: any[]) => Promise<Bundler>;
|
|
101
130
|
}
|
|
102
131
|
export interface ElementsEnv extends Environment {
|
|
103
132
|
/**
|
package/dist/environment.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["environment.ts"],"names":["hasCompiler","obj","getCompiler"],"mappings":";;;;;;;AAAA;;AAoBA;AACA;AACA;AA+
|
|
1
|
+
{"version":3,"sources":["environment.ts"],"names":["hasCompiler","obj","getCompiler"],"mappings":";;;;;;;AAAA;;AAoBA;AACA;AACA;AA+LO,SAASA,WAAT,CAAqBC,GAArB,EAA2D;AAChE,SAAO,OAAOA,GAAG,CAACC,WAAX,KAA2B,UAAlC;AACD","sourcesContent":["// TODO: @gilad refactor to an abstract env.\nimport type { Linter, LinterContext } from '@teambit/linter';\nimport type { Formatter, FormatterContext } from '@teambit/formatter';\nimport type { Tester } from '@teambit/tester';\nimport type { Compiler } from '@teambit/compiler';\nimport type { Bundler, BundlerContext, DevServer, DevServerContext } from '@teambit/bundler';\nimport type { BuildTask } from '@teambit/builder';\nimport type { SchemaExtractor } from '@teambit/schema';\nimport type { WebpackConfigTransformer } from '@teambit/webpack';\nimport type { PackageJsonProps } from '@teambit/pkg';\nimport type { EnvPolicyConfigObject } from '@teambit/dependency-resolver';\nimport { ElementsWrapperContext } from '@teambit/elements';\nimport type { Capsule } from '@teambit/isolator';\nimport type { Component } from '@teambit/component';\nimport { EnvPreviewConfig } from '@teambit/preview';\n\nexport type EnvDescriptor = {\n type: string;\n};\n\n/**\n * add a custom type and include all properties from within the environment.\n */\nexport interface Environment {\n /**\n * name of the environment.\n */\n name?: string;\n\n /**\n * description of the environment.\n */\n description?: string;\n\n /**\n * icon of the environment.\n */\n icon?: string;\n\n [key: string]: any; // :TODO need to define an abstract type for service handlers (now using any)\n\n /**\n * Returns the Environment descriptor\n * Required for any task\n */\n __getDescriptor?: () => Promise<EnvDescriptor>;\n\n /**\n * Returns a schema generator instance\n */\n getSchemaExtractor?: (config?: any) => SchemaExtractor;\n}\n\nexport interface DependenciesEnv extends Environment {\n /**\n * Returns the list of dependencies\n * Required for any task\n */\n getDependencies?: () => EnvPolicyConfigObject | Promise<EnvPolicyConfigObject>;\n\n /**\n * Returns a list of additional host dependencies\n * this list will be provided as globals on the window after bit preview bundle\n * by default bit will merge this list with the peers from the getDependencies function\n * If you want full control use the getHostDependencies function\n */\n getAdditionalHostDependencies?: () => string[] | Promise<string[]>;\n\n /**\n * Returns a list of host dependencies\n * this list will be provided as globals on the window after bit preview bundle\n * If this is provided, bit won't merge getAdditionalHostDependencies and the peers from getDependencies\n * but give you full control over the list\n *\n * The reason we provided both options is the following:\n * in most cases when you override the deps from you env, you want bit to take your peers\n * however, if we only provide the getHostDependencies, during the env composition, you will get the peers of the\n * original env. which doesn't contain your peers.\n * In that case you might think that we only need the first option of getAdditionalHostDependencies + getDependencies peers\n * but there are cases when you want a peer to your component, but you don't want it as part of the bundle.\n * such an example is react-native env which adds react-native as peer, but you don't want it in the bundle as it's not web compatible\n * so you want full control over it\n */\n getHostDependencies?: () => string[] | Promise<string[]>;\n}\n\nexport type GetNpmIgnoreContext = {\n capsule: Capsule;\n component: Component;\n};\nexport interface PackageEnv extends Environment {\n /**\n * define the package json properties to add to each component.\n * Used by `bit link` to augment package.json with new properties\n */\n getPackageJsonProps?: () => PackageJsonProps;\n\n /**\n * return `.npmignore` entries to be written before packing the component\n */\n getNpmIgnore?: (npmIgnoreContext?: GetNpmIgnoreContext) => string[];\n}\n\nexport interface LinterEnv extends Environment {\n /**\n * Returns & configures the linter to use (ESLint, ...)\n * Required for `bit lint`\n */\n getLinter?: (context: LinterContext, transformers: any[]) => Linter;\n}\n\nexport interface FormatterEnv extends Environment {\n /**\n * Returns & configures the formatter to use (prettier, ...)\n * Required for `bit format`\n */\n getFormatter?: (context: FormatterContext, transformers: any[]) => Formatter;\n}\n\nexport interface PreviewEnv extends Environment {\n /**\n * Returns a paths to a function which mounts a given component to DOM\n * Required for `bit start` & `bit build`\n */\n getMounter?: () => string;\n\n /**\n * Returns a path to a docs template.\n * Required for `bit start` & `bit build`\n */\n getDocsTemplate?: () => string;\n\n /**\n * Returns a bundler for the preview.\n * Required for `bit build` & `bit start`\n */\n getBundler?: (context: BundlerContext, transformers: any[]) => Promise<Bundler>;\n\n /**\n * Returns preview config like the strategy name to use when bundling the components for the preview\n */\n getPreviewConfig?: () => EnvPreviewConfig;\n\n /**\n * Returns a bundler for the env template.\n * this bundler will be used to bundle the docs/compositions (or other preview) apps\n * Required for `bit build` & `bit tag`\n */\n getTemplateBundler?: (context: BundlerContext, transformers?: any[]) => Promise<Bundler>;\n}\n\nexport interface ElementsEnv extends Environment {\n /**\n * Returns a function that gets the context and wrap the component with a web component\n * Required for `bit build`\n */\n getElementsWrapper: (context: ElementsWrapperContext) => string;\n\n /**\n * Returns a bundler for elements.\n * Required for `bit build``\n */\n getElementsBundler: (context: BundlerContext, transformers: any[]) => Promise<Bundler>;\n}\n\nexport type PipeServiceModifiersMap = Record<string, PipeServiceModifier>;\n\nexport interface PipeServiceModifier {\n transformers?: Function[];\n module?: any;\n}\n\nexport interface BuilderEnv extends PreviewEnv {\n /**\n * @deprecated Fatal: a breaking API was introduced. Use getBuildPipe() instead.\n */\n getPipe?: () => BuildTask[];\n\n /**\n * Returns the component build pipeline\n * Either `getBuildPipe`, `getTagPipe`, or `getSnapPipe` is required for `bit build`\n */\n getBuildPipe?: (modifiersMap?: PipeServiceModifiersMap) => BuildTask[];\n\n /**\n * Returns the component tag pipeline\n * Either `getBuildPipe`, `getTagPipe`, or `getSnapPipe` is required for `bit build`\n */\n getTagPipe?: (modifiersMap?: PipeServiceModifiersMap) => BuildTask[];\n\n /**\n * Returns the component snap pipeline\n * Either `getBuildPipe`, `getTagPipe`, or `getSnapPipe` is required for `bit build`\n */\n getSnapPipe?: (modifiersMap?: PipeServiceModifiersMap) => BuildTask[];\n}\n\nexport interface TesterEnv extends Environment {\n /**\n * Returns a tester\n * Required for `bit start` & `bit test`\n */\n getTester?: (path: string, tester: any) => Tester;\n}\n\nexport interface CompilerEnv {\n /**\n * Returns a compiler\n * Required for making and reading dists, especially for `bit compile`\n */\n getCompiler: () => Compiler;\n}\n\nexport function hasCompiler(obj: Environment): obj is CompilerEnv {\n return typeof obj.getCompiler === 'function';\n}\n\nexport interface DevEnv extends PreviewEnv {\n /**\n * Required for `bit start`\n */\n getDevEnvId?: (context?: any) => string;\n\n /**\n * Returns and configures the dev server\n * Required for `bit start`\n */\n getDevServer?: (\n context: DevServerContext,\n transformers: WebpackConfigTransformer[]\n ) => DevServer | Promise<DevServer>;\n}\n"]}
|
|
@@ -116,6 +116,7 @@ export declare class EnvsMain {
|
|
|
116
116
|
* this method returns #1 if exists, otherwise, #2.
|
|
117
117
|
*/
|
|
118
118
|
getAllEnvsConfiguredOnComponent(component: Component): EnvDefinition[];
|
|
119
|
+
getAllRegisteredEnvs(): string[];
|
|
119
120
|
/**
|
|
120
121
|
* an env can be configured on a component in two ways:
|
|
121
122
|
* 1) explicitly inside "teambit.envs/envs". `{ "teambit.envs/envs": { "env": "my-env" } }`
|
|
@@ -137,9 +138,13 @@ export declare class EnvsMain {
|
|
|
137
138
|
*/
|
|
138
139
|
calculateEnvFromExtensions(extensions: ExtensionDataList): EnvDefinition;
|
|
139
140
|
private getEnvIdFromEnvsConfig;
|
|
140
|
-
|
|
141
|
+
getEnvDefinitionById(id: ComponentID): EnvDefinition | undefined;
|
|
141
142
|
private getEnvDefinitionByStringId;
|
|
142
143
|
getEnvFromComponent(envComponent: Component): EnvDefinition | undefined;
|
|
144
|
+
/**
|
|
145
|
+
* Return the env definition of teambit.envs/env
|
|
146
|
+
*/
|
|
147
|
+
getEnvsEnvDefinition(): EnvDefinition;
|
|
143
148
|
private printWarningIfFirstTime;
|
|
144
149
|
/**
|
|
145
150
|
* determines whether an env is registered.
|
|
@@ -453,6 +453,10 @@ class EnvsMain {
|
|
|
453
453
|
|
|
454
454
|
return this.getEnvsNotFromEnvsConfig(component);
|
|
455
455
|
}
|
|
456
|
+
|
|
457
|
+
getAllRegisteredEnvs() {
|
|
458
|
+
return this.envSlot.toArray().map(envData => envData[0]);
|
|
459
|
+
}
|
|
456
460
|
/**
|
|
457
461
|
* an env can be configured on a component in two ways:
|
|
458
462
|
* 1) explicitly inside "teambit.envs/envs". `{ "teambit.envs/envs": { "env": "my-env" } }`
|
|
@@ -592,6 +596,15 @@ class EnvsMain {
|
|
|
592
596
|
const env = this.getEnvDefinitionById(envComponent.id);
|
|
593
597
|
return env;
|
|
594
598
|
}
|
|
599
|
+
/**
|
|
600
|
+
* Return the env definition of teambit.envs/env
|
|
601
|
+
*/
|
|
602
|
+
|
|
603
|
+
|
|
604
|
+
getEnvsEnvDefinition() {
|
|
605
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
606
|
+
return this.getEnvDefinitionByStringId('teambit.envs/env');
|
|
607
|
+
}
|
|
595
608
|
|
|
596
609
|
printWarningIfFirstTime(envId, message) {
|
|
597
610
|
if (!this.alreadyShownWarning[envId]) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["environments.main.runtime.ts"],"names":["DEFAULT_ENV","EnvsMain","icon","constructor","config","context","envSlot","logger","serviceSlot","componentMain","createEnvironment","components","createRuntime","getDefaultEnv","defaultEnv","get","Error","EnvDefinition","getCoreEnvsIds","compose","targetEnv","envTransformers","a","reduce","acc","transformer","override","propsToOverride","env","merge","sourceEnv","allNames","Set","keys","o","Object","prototype","getPrototypeOf","name","getOwnPropertyNames","add","forEach","key","fn","includes","bind","getEnvData","component","envsData","state","aspects","EnvsAspect","id","toString","data","getEnvIdFromEnvsData","ignoreVersion","undefined","rawEnvId","envIdWithoutVersion","ComponentID","fromString","toStringWithoutVersion","getEnvId","envIdFromEnvData","withVersion","resolveEnv","withVersionMatch","toArray","find","envId","withVersionMatchId","exactMatch","exactMatchId","EnvNotConfiguredForComponent","getEnv","envDef","getEnvDefinitionByStringId","EnvNotFound","getDescriptor","services","matchedEntry","entries","aspectEntry","calculateEnv","envIdFromEnvsConfig","getEnvIdFromEnvsConfig","envIdFromEnvsConfigWithoutVersion","getEnvDefinitionById","printWarningIfFirstTime","errMsg","message","envDefFromList","getAllEnvsConfiguredOnComponent","getEnvFromEnvsConfig","getEnvsNotFromEnvsConfig","push","calculateEnvFromExtensions","extensions","envsAspect","findCoreExtension","getEnvDefinitionByLegacyExtension","extension","newExtensionId","stringId","getEnvFromComponent","envComponent","alreadyShownWarning","consoleWarning","isEnvRegistered","Boolean","isUsingAspectEnv","type","isUsingEnvEnv","registerService","envServices","register","getServices","allServices","currentServices","service","implements","EnvServiceList","registerEnv","Runtime","aggregateByDefs","throwForDuplicateComponents","envsMap","map","EnvRuntime","idsStr","c","duplications","length","join","provider","graphql","loggerAspect","cli","createLogger","envs","registerShowFragments","EnvFragment","envsCmd","EnvsCmd","commands","ListEnvsCmd","GetEnvCmd","MainRuntime","Slot","withType","GraphqlAspect","LoggerAspect","ComponentAspect","CLIAspect","addRuntime"],"mappings":"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","sourcesContent":["import { CLIAspect, CLIMain, MainRuntime } from '@teambit/cli';\nimport { Component, ComponentAspect, ComponentMain, ComponentID, AspectData } from '@teambit/component';\nimport { GraphqlAspect, GraphqlMain } from '@teambit/graphql';\nimport { Harmony, Slot, SlotRegistry } from '@teambit/harmony';\nimport { Logger, LoggerAspect, LoggerMain } from '@teambit/logger';\nimport { ExtensionDataList, ExtensionDataEntry } from '@teambit/legacy/dist/consumer/config/extension-data';\nimport findDuplications from '@teambit/legacy/dist/utils/array/find-duplications';\nimport { EnvService } from './services';\nimport { Environment } from './environment';\nimport { EnvsAspect } from './environments.aspect';\nimport { environmentsSchema } from './environments.graphql';\nimport { EnvRuntime, Runtime } from './runtime';\nimport { EnvDefinition } from './env-definition';\nimport { EnvServiceList } from './env-service-list';\nimport { EnvsCmd, GetEnvCmd, ListEnvsCmd } from './envs.cmd';\nimport { EnvFragment } from './env.fragment';\nimport { EnvNotFound, EnvNotConfiguredForComponent } from './exceptions';\n\nexport type EnvsRegistry = SlotRegistry<Environment>;\n\nexport type EnvsConfig = {\n env: string;\n options: EnvOptions;\n};\n\nexport type EnvOptions = {};\n\nexport type EnvTransformer = (env: Environment) => Environment;\n\nexport type ServiceSlot = SlotRegistry<Array<EnvService<any>>>;\n\nexport type Descriptor = {\n id: string;\n icon: string;\n services?: [];\n};\n\nexport const DEFAULT_ENV = 'teambit.harmony/node';\n\nexport class EnvsMain {\n static runtime = MainRuntime;\n\n private alreadyShownWarning = {};\n\n /**\n * icon of the extension.\n */\n icon() {\n return `<svg width=\"50\" height=\"50\" xmlns=\"http://www.w3.org/2000/svg\">\n <circle cx=\"25\" cy=\"25\" r=\"20\"/>\n </svg>`;\n }\n\n constructor(\n /**\n * environments extension configuration.\n */\n readonly config: EnvsConfig,\n\n /**\n * harmony context.\n */\n private context: Harmony,\n\n /**\n * slot for allowing extensions to register new environment.\n */\n private envSlot: EnvsRegistry,\n\n private logger: Logger,\n\n private serviceSlot: ServiceSlot,\n\n private componentMain: ComponentMain\n ) {}\n\n /**\n * creates a new runtime environments for a set of components.\n */\n async createEnvironment(components: Component[]): Promise<Runtime> {\n return this.createRuntime(components);\n }\n\n /**\n * get the configured default env.\n */\n getDefaultEnv(): EnvDefinition {\n const defaultEnv = this.envSlot.get(DEFAULT_ENV);\n if (!defaultEnv) throw new Error('default env must be set.');\n\n return new EnvDefinition(DEFAULT_ENV, defaultEnv);\n }\n\n getCoreEnvsIds(): string[] {\n return [\n 'teambit.harmony/aspect',\n 'teambit.react/react',\n 'teambit.harmony/node',\n 'teambit.react/react-native',\n 'teambit.html/html',\n 'teambit.mdx/mdx',\n 'teambit.envs/env',\n ];\n }\n\n /**\n * compose a new environment from a list of environment transformers.\n */\n compose(targetEnv: Environment, envTransformers: EnvTransformer[]) {\n const a = envTransformers.reduce((acc, transformer) => {\n acc = transformer(acc);\n return acc;\n }, targetEnv);\n\n return a;\n }\n\n /**\n * create an env transformer which overrides specific env properties.\n */\n override(propsToOverride: Environment): EnvTransformer {\n return (env: Environment) => {\n return this.merge(propsToOverride, env);\n };\n }\n\n /**\n * compose two environments into one.\n */\n merge<T extends Environment, S extends Environment>(targetEnv: Environment, sourceEnv: Environment): T & S {\n const allNames = new Set<string>();\n const keys = ['icon', 'name', 'description'];\n for (let o = sourceEnv; o !== Object.prototype; o = Object.getPrototypeOf(o)) {\n for (const name of Object.getOwnPropertyNames(o)) {\n allNames.add(name);\n }\n }\n\n allNames.forEach((key: string) => {\n const fn = sourceEnv[key];\n if (targetEnv[key]) return;\n if (keys.includes(key)) targetEnv[key] = fn;\n if (!fn || !fn.bind) {\n return;\n }\n targetEnv[key] = fn.bind(sourceEnv);\n });\n\n return targetEnv as T & S;\n }\n\n getEnvData(component: Component): AspectData {\n let envsData = component.state.aspects.get(EnvsAspect.id);\n if (!envsData) {\n // TODO: remove this once we re-export old components used to store the data here\n envsData = component.state.aspects.get('teambit.workspace/workspace');\n }\n if (!envsData) throw new Error(`env was not configured on component ${component.id.toString()}`);\n return envsData.data;\n }\n\n /**\n * Return the id of the env as configured in the envs data (without version by default)\n * The reason it's not contain version by default is that we want to take the version from the aspect defined on the component itself\n * As this version is stay up to date during tagging the env along with the component\n * @param component\n * @param ignoreVersion\n */\n private getEnvIdFromEnvsData(component: Component, ignoreVersion = true): string | undefined {\n const envsData = this.getEnvData(component);\n if (!envsData) return undefined;\n const rawEnvId = envsData.id;\n if (!rawEnvId) return undefined;\n if (!ignoreVersion) return rawEnvId;\n const envIdWithoutVersion = ComponentID.fromString(rawEnvId).toStringWithoutVersion();\n return envIdWithoutVersion;\n }\n\n /**\n * get the env id of the given component.\n */\n getEnvId(component: Component): string {\n const envIdFromEnvData = this.getEnvIdFromEnvsData(component);\n if (!envIdFromEnvData) {\n // This should never happen\n throw new Error(`no env found for ${component.id.toString()}`);\n }\n const withVersion = this.resolveEnv(component, envIdFromEnvData);\n const withVersionMatch = this.envSlot.toArray().find(([envId]) => {\n return withVersion?.toString() === envId;\n });\n const withVersionMatchId = withVersionMatch?.[0];\n if (withVersionMatchId) return withVersionMatchId;\n\n // Handle core envs\n const exactMatch = this.envSlot.toArray().find(([envId]) => {\n return envIdFromEnvData === envId;\n });\n\n const exactMatchId = exactMatch?.[0];\n if (exactMatchId) return exactMatchId;\n\n if (!withVersion) throw new EnvNotConfiguredForComponent(envIdFromEnvData, component.id.toString());\n return withVersion.toString();\n }\n\n /**\n * get the env of the given component.\n * In case you are asking for the env during on load you should use calculateEnv instead\n */\n getEnv(component: Component): EnvDefinition {\n const id = this.getEnvId(component);\n const envDef = this.getEnvDefinitionByStringId(id);\n if (envDef) {\n return envDef;\n }\n // Do not allow a non existing env\n throw new EnvNotFound(id, component.id.toString());\n }\n\n /**\n * get an environment Descriptor.\n */\n getDescriptor(component: Component): Descriptor | null {\n const envsData = this.getEnvData(component);\n return {\n id: envsData.id,\n icon: envsData.icon,\n services: envsData.services,\n };\n }\n\n resolveEnv(component: Component, id: string) {\n const matchedEntry = component.state.aspects.entries.find((aspectEntry) => {\n return id === aspectEntry.id.toString() || id === aspectEntry.id.toString({ ignoreVersion: true });\n });\n\n return matchedEntry?.id;\n }\n\n /**\n * This used to calculate the actual env during the component load.\n * Do not use it to get the env (use getEnv instead)\n * This should be used only during on load\n */\n calculateEnv(component: Component): EnvDefinition {\n // Search first for env configured via envs aspect itself\n const envIdFromEnvsConfig = this.getEnvIdFromEnvsConfig(component);\n let envIdFromEnvsConfigWithoutVersion;\n if (envIdFromEnvsConfig) {\n envIdFromEnvsConfigWithoutVersion = ComponentID.fromString(envIdFromEnvsConfig).toStringWithoutVersion();\n const envDef = this.getEnvDefinitionByStringId(envIdFromEnvsConfigWithoutVersion);\n if (envDef) {\n return envDef;\n }\n }\n\n // in some cases we have the id configured in the teambit.envs/envs but without the version\n // in such cases we won't find it in the slot\n // we search in the component aspect list a matching aspect which is match the id from the teambit.envs/envs\n if (envIdFromEnvsConfigWithoutVersion) {\n const matchedEntry = component.state.aspects.entries.find((aspectEntry) => {\n return (\n envIdFromEnvsConfigWithoutVersion === aspectEntry.id.toString() ||\n envIdFromEnvsConfigWithoutVersion === aspectEntry.id.toString({ ignoreVersion: true })\n );\n });\n if (matchedEntry) {\n // during the tag process, the version in the aspect-entry-id is changed and is not the\n // same as it was when it registered to the slot.\n const envDef = this.getEnvDefinitionById(matchedEntry.id);\n if (envDef) {\n return envDef;\n }\n // Do not allow a non existing env\n this.printWarningIfFirstTime(\n matchedEntry.id.toString(),\n `environment with ID: ${matchedEntry.id.toString()} configured on component ${component.id.toString()} was not found`\n );\n }\n // Do not allow configure teambit.envs/envs on the component without configure the env aspect itself\n const errMsg = new EnvNotConfiguredForComponent(envIdFromEnvsConfig as string, component.id.toString()).message;\n this.printWarningIfFirstTime(envIdFromEnvsConfig as string, errMsg);\n }\n\n // in case there is no config in teambit.envs/envs search the aspects for the first env that registered as env\n let envDefFromList;\n component.state.aspects.entries.find((aspectEntry) => {\n const envDef = this.getEnvDefinitionById(aspectEntry.id);\n if (envDef) {\n envDefFromList = envDef;\n }\n return !!envDef;\n });\n\n if (envDefFromList) {\n return envDefFromList;\n }\n return this.getDefaultEnv();\n }\n\n /**\n * an env can be configured on a component in two ways:\n * 1) explicitly inside \"teambit.envs/envs\". `{ \"teambit.envs/envs\": { \"env\": \"my-env\" } }`\n * 2) the env aspect is set on the variant as any other aspect, e.g. `{ \"my-env\": {} }`\n *\n * this method returns #1 if exists, otherwise, #2.\n */\n getAllEnvsConfiguredOnComponent(component: Component): EnvDefinition[] {\n // if a component has \"envs\" config, use it and ignore other components that are set up\n // in this components which happen to be envs.\n const envDef = this.getEnvFromEnvsConfig(component);\n if (envDef) {\n return [envDef];\n }\n\n return this.getEnvsNotFromEnvsConfig(component);\n }\n\n /**\n * an env can be configured on a component in two ways:\n * 1) explicitly inside \"teambit.envs/envs\". `{ \"teambit.envs/envs\": { \"env\": \"my-env\" } }`\n * 2) the env aspect is set on the variant as any other aspect, e.g. `{ \"my-env\": {} }`\n *\n * this method returns only #1\n */\n getEnvFromEnvsConfig(component: Component): EnvDefinition | undefined {\n const envIdFromEnvsConfig = this.getEnvIdFromEnvsConfig(component);\n if (!envIdFromEnvsConfig) {\n return undefined;\n }\n const envIdFromEnvsConfigWithoutVersion = ComponentID.fromString(envIdFromEnvsConfig).toStringWithoutVersion();\n const envDef = this.getEnvDefinitionByStringId(envIdFromEnvsConfigWithoutVersion);\n return envDef;\n }\n\n /**\n * an env can be configured on a component in two ways:\n * 1) explicitly inside \"teambit.envs/envs\". `{ \"teambit.envs/envs\": { \"env\": \"my-env\" } }`\n * 2) the env aspect is set on the variant as any other aspect, e.g. `{ \"my-env\": {} }`\n *\n * this method returns only #2\n */\n getEnvsNotFromEnvsConfig(component: Component): EnvDefinition[] {\n return component.state.aspects.entries.reduce((acc: EnvDefinition[], aspectEntry) => {\n const envDef = this.getEnvDefinitionById(aspectEntry.id);\n if (envDef) acc.push(envDef);\n return acc;\n }, []);\n }\n\n /**\n * @deprecated DO NOT USE THIS METHOD ANYMORE!!! (PLEASE USE .calculateEnv() instead!)\n */\n calculateEnvFromExtensions(extensions: ExtensionDataList): EnvDefinition {\n // Search first for env configured via envs aspect itself\n const envsAspect = extensions.findCoreExtension(EnvsAspect.id);\n const envIdFromEnvsConfig = envsAspect?.config.env;\n let envIdFromEnvsConfigWithoutVersion;\n\n if (envIdFromEnvsConfig) {\n envIdFromEnvsConfigWithoutVersion = ComponentID.fromString(envIdFromEnvsConfig).toStringWithoutVersion();\n const envDef = this.getEnvDefinitionByStringId(envIdFromEnvsConfigWithoutVersion);\n if (envDef) {\n return envDef;\n }\n }\n\n const getEnvDefinitionByLegacyExtension = (extension: ExtensionDataEntry): EnvDefinition | undefined => {\n const envDef = extension.newExtensionId\n ? this.getEnvDefinitionById(extension.newExtensionId)\n : this.getEnvDefinitionByStringId(extension.stringId);\n return envDef;\n };\n\n // in some cases we have the id configured in the teambit.envs/envs but without the version\n // in such cases we won't find it in the slot\n // we search in the component aspect list a matching aspect which is match the id from the teambit.envs/envs\n if (envIdFromEnvsConfigWithoutVersion) {\n const matchedEntry = extensions.find((extension) => {\n if (extension.newExtensionId) {\n return (\n envIdFromEnvsConfigWithoutVersion === extension.newExtensionId.toString() ||\n envIdFromEnvsConfigWithoutVersion === extension.newExtensionId.toString({ ignoreVersion: true })\n );\n }\n return envIdFromEnvsConfigWithoutVersion === extension.stringId;\n });\n if (matchedEntry) {\n // during the tag process, the version in the aspect-entry-id is changed and is not the\n // same as it was when it registered to the slot.\n const envDef = getEnvDefinitionByLegacyExtension(matchedEntry);\n if (envDef) {\n return envDef;\n }\n // Do not allow a non existing env\n this.printWarningIfFirstTime(\n matchedEntry.id.toString(),\n `environment with ID: ${matchedEntry.id.toString()} was not found`\n );\n }\n // Do not allow configure teambit.envs/envs on the component without configure the env aspect itself\n const errMsg = new EnvNotConfiguredForComponent(envIdFromEnvsConfig).message;\n this.printWarningIfFirstTime(envIdFromEnvsConfig, errMsg);\n }\n\n // in case there is no config in teambit.envs/envs search the aspects for the first env that registered as env\n let envDefFromList;\n extensions.find((extension: ExtensionDataEntry) => {\n const envDef = getEnvDefinitionByLegacyExtension(extension);\n if (envDef) {\n envDefFromList = envDef;\n }\n return !!envDef;\n });\n\n if (envDefFromList) {\n return envDefFromList;\n }\n return this.getDefaultEnv();\n }\n\n private getEnvIdFromEnvsConfig(component: Component): string | undefined {\n const envsAspect = component.state.aspects.get(EnvsAspect.id);\n return envsAspect?.config.env;\n }\n\n private getEnvDefinitionById(id: ComponentID): EnvDefinition | undefined {\n const envDef =\n this.getEnvDefinitionByStringId(id.toString()) ||\n this.getEnvDefinitionByStringId(id.toString({ ignoreVersion: true }));\n return envDef;\n }\n\n private getEnvDefinitionByStringId(envId: string): EnvDefinition | undefined {\n const env = this.envSlot.get(envId);\n if (env) {\n return new EnvDefinition(envId, env as Environment);\n }\n return undefined;\n }\n\n getEnvFromComponent(envComponent: Component) {\n const env = this.getEnvDefinitionById(envComponent.id);\n return env;\n }\n\n private printWarningIfFirstTime(envId: string, message: string) {\n if (!this.alreadyShownWarning[envId]) {\n this.alreadyShownWarning[envId] = true;\n this.logger.consoleWarning(message);\n }\n }\n\n /**\n * determines whether an env is registered.\n */\n isEnvRegistered(id: string) {\n return Boolean(this.envSlot.get(id));\n }\n\n isUsingAspectEnv(component: Component): boolean {\n const data = this.getEnvData(component);\n if (!data) return false;\n return data.type === 'aspect';\n }\n\n isUsingEnvEnv(component: Component): boolean {\n const data = this.getEnvData(component);\n if (!data) return false;\n return data.type === 'env';\n }\n\n /**\n * register a new environment service.\n */\n registerService(...envServices: EnvService<any>[]) {\n this.serviceSlot.register(envServices);\n return this;\n }\n\n /**\n * get list of services enabled on an env.\n */\n getServices(env: EnvDefinition): EnvServiceList {\n const allServices = this.serviceSlot.toArray();\n const services: [string, EnvService<any>][] = [];\n allServices.forEach(([id, currentServices]) => {\n currentServices.forEach((service) => {\n if (this.implements(env, service)) {\n services.push([id, service]);\n }\n });\n });\n return new EnvServiceList(env, services);\n }\n\n implements(env: EnvDefinition, service: EnvService<any>) {\n // TODO: remove this after refactoring everything and remove getDescriptor from being optional.\n if (!service.getDescriptor) return false;\n return !!service.getDescriptor(env);\n }\n\n /**\n * register an environment.\n */\n registerEnv(env: Environment) {\n return this.envSlot.register(env);\n }\n\n // refactor here\n private createRuntime(components: Component[]): Runtime {\n return new Runtime(this.aggregateByDefs(components), this.logger);\n }\n\n // :TODO can be refactored to few utilities who will make repeating this very easy.\n private aggregateByDefs(components: Component[]): EnvRuntime[] {\n this.throwForDuplicateComponents(components);\n const envsMap = {};\n components.forEach((component: Component) => {\n const envDef = this.getEnv(component);\n const envId = envDef.id;\n const env = envDef.env;\n // handle config as well when aggregating envs.\n if (envsMap[envId]) envsMap[envId].components.push(component);\n else\n envsMap[envId] = {\n components: [component],\n env,\n };\n });\n\n return Object.keys(envsMap).map((key) => {\n return new EnvRuntime(key, envsMap[key].env, envsMap[key].components);\n });\n }\n\n private throwForDuplicateComponents(components: Component[]) {\n const idsStr = components.map((c) => c.id.toString());\n const duplications = findDuplications(idsStr);\n if (duplications.length) {\n throw new Error(`found duplicated components: ${duplications.join(', ')}`);\n }\n }\n\n static slots = [Slot.withType<Environment>(), Slot.withType<EnvService<any>>()];\n\n static dependencies = [GraphqlAspect, LoggerAspect, ComponentAspect, CLIAspect];\n\n static async provider(\n [graphql, loggerAspect, component, cli]: [GraphqlMain, LoggerMain, ComponentMain, CLIMain],\n config: EnvsConfig,\n [envSlot, serviceSlot]: [EnvsRegistry, ServiceSlot],\n context: Harmony\n ) {\n const logger = loggerAspect.createLogger(EnvsAspect.id);\n const envs = new EnvsMain(config, context, envSlot, logger, serviceSlot, component);\n component.registerShowFragments([new EnvFragment(envs)]);\n const envsCmd = new EnvsCmd(envs, component);\n envsCmd.commands = [new ListEnvsCmd(envs, component), new GetEnvCmd(envs, component)];\n cli.register(envsCmd);\n graphql.register(environmentsSchema(envs));\n return envs;\n }\n}\n\nEnvsAspect.addRuntime(EnvsMain);\n"]}
|
|
1
|
+
{"version":3,"sources":["environments.main.runtime.ts"],"names":["DEFAULT_ENV","EnvsMain","icon","constructor","config","context","envSlot","logger","serviceSlot","componentMain","createEnvironment","components","createRuntime","getDefaultEnv","defaultEnv","get","Error","EnvDefinition","getCoreEnvsIds","compose","targetEnv","envTransformers","a","reduce","acc","transformer","override","propsToOverride","env","merge","sourceEnv","allNames","Set","keys","o","Object","prototype","getPrototypeOf","name","getOwnPropertyNames","add","forEach","key","fn","includes","bind","getEnvData","component","envsData","state","aspects","EnvsAspect","id","toString","data","getEnvIdFromEnvsData","ignoreVersion","undefined","rawEnvId","envIdWithoutVersion","ComponentID","fromString","toStringWithoutVersion","getEnvId","envIdFromEnvData","withVersion","resolveEnv","withVersionMatch","toArray","find","envId","withVersionMatchId","exactMatch","exactMatchId","EnvNotConfiguredForComponent","getEnv","envDef","getEnvDefinitionByStringId","EnvNotFound","getDescriptor","services","matchedEntry","entries","aspectEntry","calculateEnv","envIdFromEnvsConfig","getEnvIdFromEnvsConfig","envIdFromEnvsConfigWithoutVersion","getEnvDefinitionById","printWarningIfFirstTime","errMsg","message","envDefFromList","getAllEnvsConfiguredOnComponent","getEnvFromEnvsConfig","getEnvsNotFromEnvsConfig","getAllRegisteredEnvs","map","envData","push","calculateEnvFromExtensions","extensions","envsAspect","findCoreExtension","getEnvDefinitionByLegacyExtension","extension","newExtensionId","stringId","getEnvFromComponent","envComponent","getEnvsEnvDefinition","alreadyShownWarning","consoleWarning","isEnvRegistered","Boolean","isUsingAspectEnv","type","isUsingEnvEnv","registerService","envServices","register","getServices","allServices","currentServices","service","implements","EnvServiceList","registerEnv","Runtime","aggregateByDefs","throwForDuplicateComponents","envsMap","EnvRuntime","idsStr","c","duplications","length","join","provider","graphql","loggerAspect","cli","createLogger","envs","registerShowFragments","EnvFragment","envsCmd","EnvsCmd","commands","ListEnvsCmd","GetEnvCmd","MainRuntime","Slot","withType","GraphqlAspect","LoggerAspect","ComponentAspect","CLIAspect","addRuntime"],"mappings":"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","sourcesContent":["import { CLIAspect, CLIMain, MainRuntime } from '@teambit/cli';\nimport { Component, ComponentAspect, ComponentMain, ComponentID, AspectData } from '@teambit/component';\nimport { GraphqlAspect, GraphqlMain } from '@teambit/graphql';\nimport { Harmony, Slot, SlotRegistry } from '@teambit/harmony';\nimport { Logger, LoggerAspect, LoggerMain } from '@teambit/logger';\nimport { ExtensionDataList, ExtensionDataEntry } from '@teambit/legacy/dist/consumer/config/extension-data';\nimport findDuplications from '@teambit/legacy/dist/utils/array/find-duplications';\nimport { EnvService } from './services';\nimport { Environment } from './environment';\nimport { EnvsAspect } from './environments.aspect';\nimport { environmentsSchema } from './environments.graphql';\nimport { EnvRuntime, Runtime } from './runtime';\nimport { EnvDefinition } from './env-definition';\nimport { EnvServiceList } from './env-service-list';\nimport { EnvsCmd, GetEnvCmd, ListEnvsCmd } from './envs.cmd';\nimport { EnvFragment } from './env.fragment';\nimport { EnvNotFound, EnvNotConfiguredForComponent } from './exceptions';\n\nexport type EnvsRegistry = SlotRegistry<Environment>;\n\nexport type EnvsConfig = {\n env: string;\n options: EnvOptions;\n};\n\nexport type EnvOptions = {};\n\nexport type EnvTransformer = (env: Environment) => Environment;\n\nexport type ServiceSlot = SlotRegistry<Array<EnvService<any>>>;\n\nexport type Descriptor = {\n id: string;\n icon: string;\n services?: [];\n};\n\nexport const DEFAULT_ENV = 'teambit.harmony/node';\n\nexport class EnvsMain {\n static runtime = MainRuntime;\n\n private alreadyShownWarning = {};\n\n /**\n * icon of the extension.\n */\n icon() {\n return `<svg width=\"50\" height=\"50\" xmlns=\"http://www.w3.org/2000/svg\">\n <circle cx=\"25\" cy=\"25\" r=\"20\"/>\n </svg>`;\n }\n\n constructor(\n /**\n * environments extension configuration.\n */\n readonly config: EnvsConfig,\n\n /**\n * harmony context.\n */\n private context: Harmony,\n\n /**\n * slot for allowing extensions to register new environment.\n */\n private envSlot: EnvsRegistry,\n\n private logger: Logger,\n\n private serviceSlot: ServiceSlot,\n\n private componentMain: ComponentMain\n ) {}\n\n /**\n * creates a new runtime environments for a set of components.\n */\n async createEnvironment(components: Component[]): Promise<Runtime> {\n return this.createRuntime(components);\n }\n\n /**\n * get the configured default env.\n */\n getDefaultEnv(): EnvDefinition {\n const defaultEnv = this.envSlot.get(DEFAULT_ENV);\n if (!defaultEnv) throw new Error('default env must be set.');\n\n return new EnvDefinition(DEFAULT_ENV, defaultEnv);\n }\n\n getCoreEnvsIds(): string[] {\n return [\n 'teambit.harmony/aspect',\n 'teambit.react/react',\n 'teambit.harmony/node',\n 'teambit.react/react-native',\n 'teambit.html/html',\n 'teambit.mdx/mdx',\n 'teambit.envs/env',\n ];\n }\n\n /**\n * compose a new environment from a list of environment transformers.\n */\n compose(targetEnv: Environment, envTransformers: EnvTransformer[]) {\n const a = envTransformers.reduce((acc, transformer) => {\n acc = transformer(acc);\n return acc;\n }, targetEnv);\n\n return a;\n }\n\n /**\n * create an env transformer which overrides specific env properties.\n */\n override(propsToOverride: Environment): EnvTransformer {\n return (env: Environment) => {\n return this.merge(propsToOverride, env);\n };\n }\n\n /**\n * compose two environments into one.\n */\n merge<T extends Environment, S extends Environment>(targetEnv: Environment, sourceEnv: Environment): T & S {\n const allNames = new Set<string>();\n const keys = ['icon', 'name', 'description'];\n for (let o = sourceEnv; o !== Object.prototype; o = Object.getPrototypeOf(o)) {\n for (const name of Object.getOwnPropertyNames(o)) {\n allNames.add(name);\n }\n }\n\n allNames.forEach((key: string) => {\n const fn = sourceEnv[key];\n if (targetEnv[key]) return;\n if (keys.includes(key)) targetEnv[key] = fn;\n if (!fn || !fn.bind) {\n return;\n }\n targetEnv[key] = fn.bind(sourceEnv);\n });\n\n return targetEnv as T & S;\n }\n\n getEnvData(component: Component): AspectData {\n let envsData = component.state.aspects.get(EnvsAspect.id);\n if (!envsData) {\n // TODO: remove this once we re-export old components used to store the data here\n envsData = component.state.aspects.get('teambit.workspace/workspace');\n }\n if (!envsData) throw new Error(`env was not configured on component ${component.id.toString()}`);\n return envsData.data;\n }\n\n /**\n * Return the id of the env as configured in the envs data (without version by default)\n * The reason it's not contain version by default is that we want to take the version from the aspect defined on the component itself\n * As this version is stay up to date during tagging the env along with the component\n * @param component\n * @param ignoreVersion\n */\n private getEnvIdFromEnvsData(component: Component, ignoreVersion = true): string | undefined {\n const envsData = this.getEnvData(component);\n if (!envsData) return undefined;\n const rawEnvId = envsData.id;\n if (!rawEnvId) return undefined;\n if (!ignoreVersion) return rawEnvId;\n const envIdWithoutVersion = ComponentID.fromString(rawEnvId).toStringWithoutVersion();\n return envIdWithoutVersion;\n }\n\n /**\n * get the env id of the given component.\n */\n getEnvId(component: Component): string {\n const envIdFromEnvData = this.getEnvIdFromEnvsData(component);\n if (!envIdFromEnvData) {\n // This should never happen\n throw new Error(`no env found for ${component.id.toString()}`);\n }\n const withVersion = this.resolveEnv(component, envIdFromEnvData);\n const withVersionMatch = this.envSlot.toArray().find(([envId]) => {\n return withVersion?.toString() === envId;\n });\n const withVersionMatchId = withVersionMatch?.[0];\n if (withVersionMatchId) return withVersionMatchId;\n\n // Handle core envs\n const exactMatch = this.envSlot.toArray().find(([envId]) => {\n return envIdFromEnvData === envId;\n });\n\n const exactMatchId = exactMatch?.[0];\n if (exactMatchId) return exactMatchId;\n\n if (!withVersion) throw new EnvNotConfiguredForComponent(envIdFromEnvData, component.id.toString());\n return withVersion.toString();\n }\n\n /**\n * get the env of the given component.\n * In case you are asking for the env during on load you should use calculateEnv instead\n */\n getEnv(component: Component): EnvDefinition {\n const id = this.getEnvId(component);\n const envDef = this.getEnvDefinitionByStringId(id);\n if (envDef) {\n return envDef;\n }\n // Do not allow a non existing env\n throw new EnvNotFound(id, component.id.toString());\n }\n\n /**\n * get an environment Descriptor.\n */\n getDescriptor(component: Component): Descriptor | null {\n const envsData = this.getEnvData(component);\n return {\n id: envsData.id,\n icon: envsData.icon,\n services: envsData.services,\n };\n }\n\n resolveEnv(component: Component, id: string) {\n const matchedEntry = component.state.aspects.entries.find((aspectEntry) => {\n return id === aspectEntry.id.toString() || id === aspectEntry.id.toString({ ignoreVersion: true });\n });\n\n return matchedEntry?.id;\n }\n\n /**\n * This used to calculate the actual env during the component load.\n * Do not use it to get the env (use getEnv instead)\n * This should be used only during on load\n */\n calculateEnv(component: Component): EnvDefinition {\n // Search first for env configured via envs aspect itself\n const envIdFromEnvsConfig = this.getEnvIdFromEnvsConfig(component);\n let envIdFromEnvsConfigWithoutVersion;\n if (envIdFromEnvsConfig) {\n envIdFromEnvsConfigWithoutVersion = ComponentID.fromString(envIdFromEnvsConfig).toStringWithoutVersion();\n const envDef = this.getEnvDefinitionByStringId(envIdFromEnvsConfigWithoutVersion);\n if (envDef) {\n return envDef;\n }\n }\n\n // in some cases we have the id configured in the teambit.envs/envs but without the version\n // in such cases we won't find it in the slot\n // we search in the component aspect list a matching aspect which is match the id from the teambit.envs/envs\n if (envIdFromEnvsConfigWithoutVersion) {\n const matchedEntry = component.state.aspects.entries.find((aspectEntry) => {\n return (\n envIdFromEnvsConfigWithoutVersion === aspectEntry.id.toString() ||\n envIdFromEnvsConfigWithoutVersion === aspectEntry.id.toString({ ignoreVersion: true })\n );\n });\n if (matchedEntry) {\n // during the tag process, the version in the aspect-entry-id is changed and is not the\n // same as it was when it registered to the slot.\n const envDef = this.getEnvDefinitionById(matchedEntry.id);\n if (envDef) {\n return envDef;\n }\n // Do not allow a non existing env\n this.printWarningIfFirstTime(\n matchedEntry.id.toString(),\n `environment with ID: ${matchedEntry.id.toString()} configured on component ${component.id.toString()} was not found`\n );\n }\n // Do not allow configure teambit.envs/envs on the component without configure the env aspect itself\n const errMsg = new EnvNotConfiguredForComponent(envIdFromEnvsConfig as string, component.id.toString()).message;\n this.printWarningIfFirstTime(envIdFromEnvsConfig as string, errMsg);\n }\n\n // in case there is no config in teambit.envs/envs search the aspects for the first env that registered as env\n let envDefFromList;\n component.state.aspects.entries.find((aspectEntry) => {\n const envDef = this.getEnvDefinitionById(aspectEntry.id);\n if (envDef) {\n envDefFromList = envDef;\n }\n return !!envDef;\n });\n\n if (envDefFromList) {\n return envDefFromList;\n }\n return this.getDefaultEnv();\n }\n\n /**\n * an env can be configured on a component in two ways:\n * 1) explicitly inside \"teambit.envs/envs\". `{ \"teambit.envs/envs\": { \"env\": \"my-env\" } }`\n * 2) the env aspect is set on the variant as any other aspect, e.g. `{ \"my-env\": {} }`\n *\n * this method returns #1 if exists, otherwise, #2.\n */\n getAllEnvsConfiguredOnComponent(component: Component): EnvDefinition[] {\n // if a component has \"envs\" config, use it and ignore other components that are set up\n // in this components which happen to be envs.\n const envDef = this.getEnvFromEnvsConfig(component);\n if (envDef) {\n return [envDef];\n }\n\n return this.getEnvsNotFromEnvsConfig(component);\n }\n\n getAllRegisteredEnvs(): string[] {\n return this.envSlot.toArray().map((envData) => envData[0]);\n }\n\n /**\n * an env can be configured on a component in two ways:\n * 1) explicitly inside \"teambit.envs/envs\". `{ \"teambit.envs/envs\": { \"env\": \"my-env\" } }`\n * 2) the env aspect is set on the variant as any other aspect, e.g. `{ \"my-env\": {} }`\n *\n * this method returns only #1\n */\n getEnvFromEnvsConfig(component: Component): EnvDefinition | undefined {\n const envIdFromEnvsConfig = this.getEnvIdFromEnvsConfig(component);\n if (!envIdFromEnvsConfig) {\n return undefined;\n }\n const envIdFromEnvsConfigWithoutVersion = ComponentID.fromString(envIdFromEnvsConfig).toStringWithoutVersion();\n const envDef = this.getEnvDefinitionByStringId(envIdFromEnvsConfigWithoutVersion);\n return envDef;\n }\n\n /**\n * an env can be configured on a component in two ways:\n * 1) explicitly inside \"teambit.envs/envs\". `{ \"teambit.envs/envs\": { \"env\": \"my-env\" } }`\n * 2) the env aspect is set on the variant as any other aspect, e.g. `{ \"my-env\": {} }`\n *\n * this method returns only #2\n */\n getEnvsNotFromEnvsConfig(component: Component): EnvDefinition[] {\n return component.state.aspects.entries.reduce((acc: EnvDefinition[], aspectEntry) => {\n const envDef = this.getEnvDefinitionById(aspectEntry.id);\n if (envDef) acc.push(envDef);\n return acc;\n }, []);\n }\n\n /**\n * @deprecated DO NOT USE THIS METHOD ANYMORE!!! (PLEASE USE .calculateEnv() instead!)\n */\n calculateEnvFromExtensions(extensions: ExtensionDataList): EnvDefinition {\n // Search first for env configured via envs aspect itself\n const envsAspect = extensions.findCoreExtension(EnvsAspect.id);\n const envIdFromEnvsConfig = envsAspect?.config.env;\n let envIdFromEnvsConfigWithoutVersion;\n\n if (envIdFromEnvsConfig) {\n envIdFromEnvsConfigWithoutVersion = ComponentID.fromString(envIdFromEnvsConfig).toStringWithoutVersion();\n const envDef = this.getEnvDefinitionByStringId(envIdFromEnvsConfigWithoutVersion);\n if (envDef) {\n return envDef;\n }\n }\n\n const getEnvDefinitionByLegacyExtension = (extension: ExtensionDataEntry): EnvDefinition | undefined => {\n const envDef = extension.newExtensionId\n ? this.getEnvDefinitionById(extension.newExtensionId)\n : this.getEnvDefinitionByStringId(extension.stringId);\n return envDef;\n };\n\n // in some cases we have the id configured in the teambit.envs/envs but without the version\n // in such cases we won't find it in the slot\n // we search in the component aspect list a matching aspect which is match the id from the teambit.envs/envs\n if (envIdFromEnvsConfigWithoutVersion) {\n const matchedEntry = extensions.find((extension) => {\n if (extension.newExtensionId) {\n return (\n envIdFromEnvsConfigWithoutVersion === extension.newExtensionId.toString() ||\n envIdFromEnvsConfigWithoutVersion === extension.newExtensionId.toString({ ignoreVersion: true })\n );\n }\n return envIdFromEnvsConfigWithoutVersion === extension.stringId;\n });\n if (matchedEntry) {\n // during the tag process, the version in the aspect-entry-id is changed and is not the\n // same as it was when it registered to the slot.\n const envDef = getEnvDefinitionByLegacyExtension(matchedEntry);\n if (envDef) {\n return envDef;\n }\n // Do not allow a non existing env\n this.printWarningIfFirstTime(\n matchedEntry.id.toString(),\n `environment with ID: ${matchedEntry.id.toString()} was not found`\n );\n }\n // Do not allow configure teambit.envs/envs on the component without configure the env aspect itself\n const errMsg = new EnvNotConfiguredForComponent(envIdFromEnvsConfig).message;\n this.printWarningIfFirstTime(envIdFromEnvsConfig, errMsg);\n }\n\n // in case there is no config in teambit.envs/envs search the aspects for the first env that registered as env\n let envDefFromList;\n extensions.find((extension: ExtensionDataEntry) => {\n const envDef = getEnvDefinitionByLegacyExtension(extension);\n if (envDef) {\n envDefFromList = envDef;\n }\n return !!envDef;\n });\n\n if (envDefFromList) {\n return envDefFromList;\n }\n return this.getDefaultEnv();\n }\n\n private getEnvIdFromEnvsConfig(component: Component): string | undefined {\n const envsAspect = component.state.aspects.get(EnvsAspect.id);\n return envsAspect?.config.env;\n }\n\n getEnvDefinitionById(id: ComponentID): EnvDefinition | undefined {\n const envDef =\n this.getEnvDefinitionByStringId(id.toString()) ||\n this.getEnvDefinitionByStringId(id.toString({ ignoreVersion: true }));\n return envDef;\n }\n\n private getEnvDefinitionByStringId(envId: string): EnvDefinition | undefined {\n const env = this.envSlot.get(envId);\n if (env) {\n return new EnvDefinition(envId, env as Environment);\n }\n return undefined;\n }\n\n getEnvFromComponent(envComponent: Component) {\n const env = this.getEnvDefinitionById(envComponent.id);\n return env;\n }\n\n /**\n * Return the env definition of teambit.envs/env\n */\n getEnvsEnvDefinition(): EnvDefinition {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n return this.getEnvDefinitionByStringId('teambit.envs/env')!;\n }\n\n private printWarningIfFirstTime(envId: string, message: string) {\n if (!this.alreadyShownWarning[envId]) {\n this.alreadyShownWarning[envId] = true;\n this.logger.consoleWarning(message);\n }\n }\n\n /**\n * determines whether an env is registered.\n */\n isEnvRegistered(id: string) {\n return Boolean(this.envSlot.get(id));\n }\n\n isUsingAspectEnv(component: Component): boolean {\n const data = this.getEnvData(component);\n if (!data) return false;\n return data.type === 'aspect';\n }\n\n isUsingEnvEnv(component: Component): boolean {\n const data = this.getEnvData(component);\n if (!data) return false;\n return data.type === 'env';\n }\n\n /**\n * register a new environment service.\n */\n registerService(...envServices: EnvService<any>[]) {\n this.serviceSlot.register(envServices);\n return this;\n }\n\n /**\n * get list of services enabled on an env.\n */\n getServices(env: EnvDefinition): EnvServiceList {\n const allServices = this.serviceSlot.toArray();\n const services: [string, EnvService<any>][] = [];\n allServices.forEach(([id, currentServices]) => {\n currentServices.forEach((service) => {\n if (this.implements(env, service)) {\n services.push([id, service]);\n }\n });\n });\n return new EnvServiceList(env, services);\n }\n\n implements(env: EnvDefinition, service: EnvService<any>) {\n // TODO: remove this after refactoring everything and remove getDescriptor from being optional.\n if (!service.getDescriptor) return false;\n return !!service.getDescriptor(env);\n }\n\n /**\n * register an environment.\n */\n registerEnv(env: Environment) {\n return this.envSlot.register(env);\n }\n\n // refactor here\n private createRuntime(components: Component[]): Runtime {\n return new Runtime(this.aggregateByDefs(components), this.logger);\n }\n\n // :TODO can be refactored to few utilities who will make repeating this very easy.\n private aggregateByDefs(components: Component[]): EnvRuntime[] {\n this.throwForDuplicateComponents(components);\n const envsMap = {};\n components.forEach((component: Component) => {\n const envDef = this.getEnv(component);\n const envId = envDef.id;\n const env = envDef.env;\n // handle config as well when aggregating envs.\n if (envsMap[envId]) envsMap[envId].components.push(component);\n else\n envsMap[envId] = {\n components: [component],\n env,\n };\n });\n\n return Object.keys(envsMap).map((key) => {\n return new EnvRuntime(key, envsMap[key].env, envsMap[key].components);\n });\n }\n\n private throwForDuplicateComponents(components: Component[]) {\n const idsStr = components.map((c) => c.id.toString());\n const duplications = findDuplications(idsStr);\n if (duplications.length) {\n throw new Error(`found duplicated components: ${duplications.join(', ')}`);\n }\n }\n\n static slots = [Slot.withType<Environment>(), Slot.withType<EnvService<any>>()];\n\n static dependencies = [GraphqlAspect, LoggerAspect, ComponentAspect, CLIAspect];\n\n static async provider(\n [graphql, loggerAspect, component, cli]: [GraphqlMain, LoggerMain, ComponentMain, CLIMain],\n config: EnvsConfig,\n [envSlot, serviceSlot]: [EnvsRegistry, ServiceSlot],\n context: Harmony\n ) {\n const logger = loggerAspect.createLogger(EnvsAspect.id);\n const envs = new EnvsMain(config, context, envSlot, logger, serviceSlot, component);\n component.registerShowFragments([new EnvFragment(envs)]);\n const envsCmd = new EnvsCmd(envs, component);\n envsCmd.commands = [new ListEnvsCmd(envs, component), new GetEnvCmd(envs, component)];\n cli.register(envsCmd);\n graphql.register(environmentsSchema(envs));\n return envs;\n }\n}\n\nEnvsAspect.addRuntime(EnvsMain);\n"]}
|
package/dist/envs.cmd.d.ts
CHANGED
|
@@ -10,8 +10,7 @@ export declare class ListEnvsCmd implements Command {
|
|
|
10
10
|
options: never[];
|
|
11
11
|
group: string;
|
|
12
12
|
constructor(envs: EnvsMain, componentAspect: ComponentMain);
|
|
13
|
-
|
|
14
|
-
private getTable;
|
|
13
|
+
report(): Promise<string>;
|
|
15
14
|
}
|
|
16
15
|
export declare class GetEnvCmd implements Command {
|
|
17
16
|
private envs;
|
|
@@ -35,4 +34,5 @@ export declare class EnvsCmd implements Command {
|
|
|
35
34
|
commands: Command[];
|
|
36
35
|
constructor(envs: EnvsMain, componentAspect: ComponentMain);
|
|
37
36
|
render(): Promise<JSX.Element>;
|
|
37
|
+
private getTable;
|
|
38
38
|
}
|
package/dist/envs.cmd.js
CHANGED
|
@@ -41,6 +41,16 @@ function _ink() {
|
|
|
41
41
|
return data;
|
|
42
42
|
}
|
|
43
43
|
|
|
44
|
+
function _chalk() {
|
|
45
|
+
const data = _interopRequireDefault(require("chalk"));
|
|
46
|
+
|
|
47
|
+
_chalk = function () {
|
|
48
|
+
return data;
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
return data;
|
|
52
|
+
}
|
|
53
|
+
|
|
44
54
|
function _cliTable() {
|
|
45
55
|
const data = require("@teambit/cli-table");
|
|
46
56
|
|
|
@@ -67,37 +77,17 @@ class ListEnvsCmd {
|
|
|
67
77
|
this.envs = envs;
|
|
68
78
|
this.componentAspect = componentAspect;
|
|
69
79
|
(0, _defineProperty2().default)(this, "name", 'list');
|
|
70
|
-
(0, _defineProperty2().default)(this, "description", 'list all
|
|
80
|
+
(0, _defineProperty2().default)(this, "description", 'list all envs available in the workspace');
|
|
71
81
|
(0, _defineProperty2().default)(this, "options", []);
|
|
72
82
|
(0, _defineProperty2().default)(this, "group", 'development');
|
|
73
83
|
}
|
|
74
84
|
|
|
75
|
-
async
|
|
76
|
-
const
|
|
85
|
+
async report() {
|
|
86
|
+
const allEnvs = this.envs.getAllRegisteredEnvs().join('\n');
|
|
77
87
|
|
|
78
|
-
|
|
79
|
-
const components = await host.list(); // TODO: refactor to a react table
|
|
88
|
+
const title = _chalk().default.green('the following envs are available in the workspace:');
|
|
80
89
|
|
|
81
|
-
return
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
getTable(components) {
|
|
85
|
-
const tableData = components.map(component => {
|
|
86
|
-
const env = this.envs.getDescriptor(component);
|
|
87
|
-
return {
|
|
88
|
-
component: component.id.toString(),
|
|
89
|
-
env: env ? env.id : 'N/A'
|
|
90
|
-
};
|
|
91
|
-
});
|
|
92
|
-
const header = [{
|
|
93
|
-
value: 'component'
|
|
94
|
-
}, {
|
|
95
|
-
value: 'env'
|
|
96
|
-
}];
|
|
97
|
-
|
|
98
|
-
const table = _cliTable().CLITable.fromObject(header, tableData);
|
|
99
|
-
|
|
100
|
-
return table.render();
|
|
90
|
+
return `${title}\n${allEnvs}`;
|
|
101
91
|
}
|
|
102
92
|
|
|
103
93
|
}
|
|
@@ -164,7 +154,31 @@ class EnvsCmd {
|
|
|
164
154
|
}
|
|
165
155
|
|
|
166
156
|
async render() {
|
|
167
|
-
|
|
157
|
+
const host = this.componentAspect.getHost(); // TODO: think what to do re this line with gilad.
|
|
158
|
+
|
|
159
|
+
if (!host) throw new Error('error: workspace not found');
|
|
160
|
+
const components = await host.list(); // TODO: refactor to a react table
|
|
161
|
+
|
|
162
|
+
return /*#__PURE__*/_react().default.createElement(_ink().Text, null, this.getTable(components));
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
getTable(components) {
|
|
166
|
+
const tableData = components.map(component => {
|
|
167
|
+
const env = this.envs.getDescriptor(component);
|
|
168
|
+
return {
|
|
169
|
+
component: component.id.toString(),
|
|
170
|
+
env: env ? env.id : 'N/A'
|
|
171
|
+
};
|
|
172
|
+
});
|
|
173
|
+
const header = [{
|
|
174
|
+
value: 'component'
|
|
175
|
+
}, {
|
|
176
|
+
value: 'env'
|
|
177
|
+
}];
|
|
178
|
+
|
|
179
|
+
const table = _cliTable().CLITable.fromObject(header, tableData);
|
|
180
|
+
|
|
181
|
+
return table.render();
|
|
168
182
|
}
|
|
169
183
|
|
|
170
184
|
}
|
package/dist/envs.cmd.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["envs.cmd.tsx"],"names":["ListEnvsCmd","constructor","envs","componentAspect","
|
|
1
|
+
{"version":3,"sources":["envs.cmd.tsx"],"names":["ListEnvsCmd","constructor","envs","componentAspect","report","allEnvs","getAllRegisteredEnvs","join","title","chalk","green","GetEnvCmd","showEnv","id","host","component","get","resolveComponentId","Error","env","getEnv","envRuntime","createEnvironment","envExecutionContext","getEnvExecutionContext","services","getServices","allP","map","serviceId","service","render","all","Promise","item","name","getHost","EnvsCmd","components","list","getTable","tableData","getDescriptor","toString","header","value","table","CLITable","fromObject"],"mappings":"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","sourcesContent":["// eslint-disable-next-line max-classes-per-file\nimport React from 'react';\nimport { Text, Newline } from 'ink';\nimport chalk from 'chalk';\nimport { CLITable } from '@teambit/cli-table';\nimport { Command } from '@teambit/cli';\nimport { ComponentMain, ComponentFactory, Component } from '@teambit/component';\nimport { EnvsMain } from './environments.main.runtime';\nimport { EnvOverview } from './components/env-overview';\n\nexport class ListEnvsCmd implements Command {\n name = 'list';\n description = 'list all envs available in the workspace';\n options = [];\n group = 'development';\n\n constructor(private envs: EnvsMain, private componentAspect: ComponentMain) {}\n\n async report() {\n const allEnvs = this.envs.getAllRegisteredEnvs().join('\\n');\n const title = chalk.green('the following envs are available in the workspace:');\n return `${title}\\n${allEnvs}`;\n }\n}\n\nexport class GetEnvCmd implements Command {\n name = 'get <name>';\n description = \"show component's env details\";\n options = [];\n group = 'development';\n\n constructor(private envs: EnvsMain, private componentAspect: ComponentMain) {}\n\n async showEnv(id: string, host: ComponentFactory) {\n const component = await host.get(await host.resolveComponentId(id));\n if (!component) throw new Error(`component for env ${id} was not found`);\n const env = this.envs.getEnv(component);\n const envRuntime = await this.envs.createEnvironment([component]);\n const envExecutionContext = envRuntime.getEnvExecutionContext();\n const services = this.envs.getServices(env);\n const allP = services.services.map(async ([serviceId, service]) => {\n if (service.render)\n return (\n <Text>\n <Text bold underline color=\"cyan\">\n {serviceId}\n </Text>\n <Newline />\n <Newline />\n {await service.render(env, envExecutionContext)}\n </Text>\n );\n return (\n <Text key={serviceId}>\n <Text bold underline>\n {serviceId}\n </Text>\n </Text>\n );\n });\n\n const all = await Promise.all(allP);\n\n return (\n <Text>\n <EnvOverview envDef={env} />\n {all.map((item) => item)}\n </Text>\n );\n }\n\n async render([name]: [string]): Promise<JSX.Element> {\n const host = this.componentAspect.getHost();\n // TODO: think what to do re this line with gilad.\n if (!host) throw new Error('error: workspace not found');\n return this.showEnv(name, host);\n }\n}\n\nexport class EnvsCmd implements Command {\n name = 'envs';\n alias = 'env';\n description = 'list all components envs';\n options = [];\n group = 'development';\n commands: Command[] = [];\n\n constructor(private envs: EnvsMain, private componentAspect: ComponentMain) {}\n\n async render(): Promise<JSX.Element> {\n const host = this.componentAspect.getHost();\n // TODO: think what to do re this line with gilad.\n if (!host) throw new Error('error: workspace not found');\n const components = await host.list();\n // TODO: refactor to a react table\n return <Text>{this.getTable(components)}</Text>;\n }\n\n private getTable(components: Component[]) {\n const tableData = components.map((component) => {\n const env = this.envs.getDescriptor(component);\n return {\n component: component.id.toString(),\n env: env ? env.id : 'N/A',\n };\n });\n\n const header = [\n {\n value: 'component',\n },\n {\n value: 'env',\n },\n ];\n const table = CLITable.fromObject(header, tableData);\n return table.render();\n }\n}\n"]}
|
package/envs.cmd.tsx
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
// eslint-disable-next-line max-classes-per-file
|
|
2
2
|
import React from 'react';
|
|
3
3
|
import { Text, Newline } from 'ink';
|
|
4
|
+
import chalk from 'chalk';
|
|
4
5
|
import { CLITable } from '@teambit/cli-table';
|
|
5
6
|
import { Command } from '@teambit/cli';
|
|
6
7
|
import { ComponentMain, ComponentFactory, Component } from '@teambit/component';
|
|
@@ -9,40 +10,16 @@ import { EnvOverview } from './components/env-overview';
|
|
|
9
10
|
|
|
10
11
|
export class ListEnvsCmd implements Command {
|
|
11
12
|
name = 'list';
|
|
12
|
-
description = 'list all
|
|
13
|
+
description = 'list all envs available in the workspace';
|
|
13
14
|
options = [];
|
|
14
15
|
group = 'development';
|
|
15
16
|
|
|
16
17
|
constructor(private envs: EnvsMain, private componentAspect: ComponentMain) {}
|
|
17
18
|
|
|
18
|
-
async
|
|
19
|
-
const
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
const components = await host.list();
|
|
23
|
-
// TODO: refactor to a react table
|
|
24
|
-
return <Text>{this.getTable(components)}</Text>;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
private getTable(components: Component[]) {
|
|
28
|
-
const tableData = components.map((component) => {
|
|
29
|
-
const env = this.envs.getDescriptor(component);
|
|
30
|
-
return {
|
|
31
|
-
component: component.id.toString(),
|
|
32
|
-
env: env ? env.id : 'N/A',
|
|
33
|
-
};
|
|
34
|
-
});
|
|
35
|
-
|
|
36
|
-
const header = [
|
|
37
|
-
{
|
|
38
|
-
value: 'component',
|
|
39
|
-
},
|
|
40
|
-
{
|
|
41
|
-
value: 'env',
|
|
42
|
-
},
|
|
43
|
-
];
|
|
44
|
-
const table = CLITable.fromObject(header, tableData);
|
|
45
|
-
return table.render();
|
|
19
|
+
async report() {
|
|
20
|
+
const allEnvs = this.envs.getAllRegisteredEnvs().join('\n');
|
|
21
|
+
const title = chalk.green('the following envs are available in the workspace:');
|
|
22
|
+
return `${title}\n${allEnvs}`;
|
|
46
23
|
}
|
|
47
24
|
}
|
|
48
25
|
|
|
@@ -110,7 +87,33 @@ export class EnvsCmd implements Command {
|
|
|
110
87
|
|
|
111
88
|
constructor(private envs: EnvsMain, private componentAspect: ComponentMain) {}
|
|
112
89
|
|
|
113
|
-
async render() {
|
|
114
|
-
|
|
90
|
+
async render(): Promise<JSX.Element> {
|
|
91
|
+
const host = this.componentAspect.getHost();
|
|
92
|
+
// TODO: think what to do re this line with gilad.
|
|
93
|
+
if (!host) throw new Error('error: workspace not found');
|
|
94
|
+
const components = await host.list();
|
|
95
|
+
// TODO: refactor to a react table
|
|
96
|
+
return <Text>{this.getTable(components)}</Text>;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
private getTable(components: Component[]) {
|
|
100
|
+
const tableData = components.map((component) => {
|
|
101
|
+
const env = this.envs.getDescriptor(component);
|
|
102
|
+
return {
|
|
103
|
+
component: component.id.toString(),
|
|
104
|
+
env: env ? env.id : 'N/A',
|
|
105
|
+
};
|
|
106
|
+
});
|
|
107
|
+
|
|
108
|
+
const header = [
|
|
109
|
+
{
|
|
110
|
+
value: 'component',
|
|
111
|
+
},
|
|
112
|
+
{
|
|
113
|
+
value: 'env',
|
|
114
|
+
},
|
|
115
|
+
];
|
|
116
|
+
const table = CLITable.fromObject(header, tableData);
|
|
117
|
+
return table.render();
|
|
115
118
|
}
|
|
116
119
|
}
|
|
Binary file
|
package/package.json
CHANGED
|
@@ -1,38 +1,39 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@teambit/envs",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.677",
|
|
4
4
|
"homepage": "https://bit.dev/teambit/envs/envs",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"componentId": {
|
|
7
7
|
"scope": "teambit.envs",
|
|
8
8
|
"name": "envs",
|
|
9
|
-
"version": "0.0.
|
|
9
|
+
"version": "0.0.677"
|
|
10
10
|
},
|
|
11
11
|
"dependencies": {
|
|
12
12
|
"@teambit/harmony": "0.2.11",
|
|
13
13
|
"graphql-tag": "2.12.1",
|
|
14
|
+
"chalk": "2.4.2",
|
|
14
15
|
"ink": "3.0.8",
|
|
15
16
|
"lodash": "4.17.21",
|
|
16
17
|
"p-map-series": "2.1.0",
|
|
17
18
|
"@babel/runtime": "7.12.18",
|
|
18
19
|
"core-js": "^3.0.0",
|
|
19
|
-
"@teambit/component": "0.0.
|
|
20
|
-
"@teambit/builder": "0.0.
|
|
21
|
-
"@teambit/bundler": "0.0.
|
|
22
|
-
"@teambit/compiler": "0.0.
|
|
23
|
-
"@teambit/dependency-resolver": "0.0.
|
|
24
|
-
"@teambit/elements": "0.0.
|
|
25
|
-
"@teambit/formatter": "0.0.
|
|
26
|
-
"@teambit/isolator": "0.0.
|
|
27
|
-
"@teambit/linter": "0.0.
|
|
28
|
-
"@teambit/pkg": "0.0.
|
|
29
|
-
"@teambit/preview": "0.0.
|
|
30
|
-
"@teambit/schema": "0.0.
|
|
31
|
-
"@teambit/tester": "0.0.
|
|
32
|
-
"@teambit/webpack": "0.0.
|
|
33
|
-
"@teambit/graphql": "0.0.
|
|
34
|
-
"@teambit/cli": "0.0.
|
|
35
|
-
"@teambit/logger": "0.0.
|
|
20
|
+
"@teambit/component": "0.0.677",
|
|
21
|
+
"@teambit/builder": "0.0.677",
|
|
22
|
+
"@teambit/bundler": "0.0.677",
|
|
23
|
+
"@teambit/compiler": "0.0.677",
|
|
24
|
+
"@teambit/dependency-resolver": "0.0.677",
|
|
25
|
+
"@teambit/elements": "0.0.130",
|
|
26
|
+
"@teambit/formatter": "0.0.228",
|
|
27
|
+
"@teambit/isolator": "0.0.677",
|
|
28
|
+
"@teambit/linter": "0.0.677",
|
|
29
|
+
"@teambit/pkg": "0.0.677",
|
|
30
|
+
"@teambit/preview": "0.0.677",
|
|
31
|
+
"@teambit/schema": "0.0.677",
|
|
32
|
+
"@teambit/tester": "0.0.677",
|
|
33
|
+
"@teambit/webpack": "0.0.677",
|
|
34
|
+
"@teambit/graphql": "0.0.677",
|
|
35
|
+
"@teambit/cli": "0.0.453",
|
|
36
|
+
"@teambit/logger": "0.0.545",
|
|
36
37
|
"@teambit/cli-table": "0.0.33",
|
|
37
38
|
"@teambit/bit-error": "0.0.394"
|
|
38
39
|
},
|
|
@@ -47,7 +48,7 @@
|
|
|
47
48
|
"@teambit/envs.aspect-docs.envs": "0.0.134"
|
|
48
49
|
},
|
|
49
50
|
"peerDependencies": {
|
|
50
|
-
"@teambit/legacy": "1.0.
|
|
51
|
+
"@teambit/legacy": "1.0.232",
|
|
51
52
|
"react-dom": "^16.8.0 || ^17.0.0",
|
|
52
53
|
"react": "^16.8.0 || ^17.0.0"
|
|
53
54
|
},
|
|
@@ -75,7 +76,7 @@
|
|
|
75
76
|
"react": "-"
|
|
76
77
|
},
|
|
77
78
|
"peerDependencies": {
|
|
78
|
-
"@teambit/legacy": "1.0.
|
|
79
|
+
"@teambit/legacy": "1.0.232",
|
|
79
80
|
"react-dom": "^16.8.0 || ^17.0.0",
|
|
80
81
|
"react": "^16.8.0 || ^17.0.0"
|
|
81
82
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export const overview = [require('/home/circleci/Library/Caches/Bit/capsules/8891be5ad3d35bfc38b9cd90c0e05b598a5a55af/teambit.envs_envs@0.0.
|
|
1
|
+
export const overview = [require('/home/circleci/Library/Caches/Bit/capsules/8891be5ad3d35bfc38b9cd90c0e05b598a5a55af/teambit.envs_envs@0.0.677/dist/envs.docs.mdx')]
|
|
Binary file
|