@teambit/envs 0.0.676 → 0.0.679

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.
@@ -0,0 +1,2 @@
1
+ /// <reference types="react" />
2
+ export declare const Logo: () => JSX.Element;
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.Logo = void 0;
9
+
10
+ function _react() {
11
+ const data = _interopRequireDefault(require("react"));
12
+
13
+ _react = function () {
14
+ return data;
15
+ };
16
+
17
+ return data;
18
+ }
19
+
20
+ const Logo = () => /*#__PURE__*/_react().default.createElement("div", {
21
+ style: {
22
+ height: '100%',
23
+ display: 'flex',
24
+ justifyContent: 'center'
25
+ }
26
+ }, /*#__PURE__*/_react().default.createElement("img", {
27
+ style: {
28
+ width: 70
29
+ },
30
+ src: "https://static.bit.dev/extensions-icons/env.svg"
31
+ }));
32
+
33
+ exports.Logo = Logo;
34
+
35
+ //# sourceMappingURL=env.composition.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["env.composition.tsx"],"names":["Logo","height","display","justifyContent","width"],"mappings":";;;;;;;;;AAAA;AAAA;;AAAA;AAAA;AAAA;;AAAA;AAAA;;AAEO,MAAMA,IAAI,GAAG,mBAClB;AAAK,EAAA,KAAK,EAAE;AAAEC,IAAAA,MAAM,EAAE,MAAV;AAAkBC,IAAAA,OAAO,EAAE,MAA3B;AAAmCC,IAAAA,cAAc,EAAE;AAAnD;AAAZ,gBACE;AAAK,EAAA,KAAK,EAAE;AAAEC,IAAAA,KAAK,EAAE;AAAT,GAAZ;AAA2B,EAAA,GAAG,EAAC;AAA/B,EADF,CADK","sourcesContent":["import React from 'react';\n\nexport const Logo = () => (\n <div style={{ height: '100%', display: 'flex', justifyContent: 'center' }}>\n <img style={{ width: 70 }} src=\"https://static.bit.dev/extensions-icons/env.svg\" />\n </div>\n);\n"]}
@@ -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
  /**
@@ -1 +1 @@
1
- {"version":3,"sources":["environment.ts"],"names":["hasCompiler","obj","getCompiler"],"mappings":";;;;;;;AAAA;;AAoBA;AACA;AACA;AA+JO,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\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\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"]}
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
- private getEnvDefinitionById;
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"]}
@@ -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
- render(): Promise<JSX.Element>;
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 components envs');
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 render() {
76
- const host = this.componentAspect.getHost(); // TODO: think what to do re this line with gilad.
85
+ async report() {
86
+ const allEnvs = this.envs.getAllRegisteredEnvs().join('\n');
77
87
 
78
- if (!host) throw new Error('error: workspace not found');
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 /*#__PURE__*/_react().default.createElement(_ink().Text, null, this.getTable(components));
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
- return new ListEnvsCmd(this.envs, this.componentAspect).render();
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
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["envs.cmd.tsx"],"names":["ListEnvsCmd","constructor","envs","componentAspect","render","host","getHost","Error","components","list","getTable","tableData","map","component","env","getDescriptor","id","toString","header","value","table","CLITable","fromObject","GetEnvCmd","showEnv","get","resolveComponentId","getEnv","envRuntime","createEnvironment","envExecutionContext","getEnvExecutionContext","services","getServices","allP","serviceId","service","all","Promise","item","name","EnvsCmd"],"mappings":"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","sourcesContent":["// eslint-disable-next-line max-classes-per-file\nimport React from 'react';\nimport { Text, Newline } from 'ink';\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 components envs';\n options = [];\n group = 'development';\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\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() {\n return new ListEnvsCmd(this.envs, this.componentAspect).render();\n }\n}\n"]}
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"]}
@@ -1,5 +1,5 @@
1
1
  ---
2
- description: Manages Environments and Environment Services
2
+ description: A composable engine for creating and maintaining development environments.
3
3
  labels: ['environments', 'core aspect']
4
4
  ---
5
5
 
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+
3
+ export const Logo = () => (
4
+ <div style={{ height: '100%', display: 'flex', justifyContent: 'center' }}>
5
+ <img style={{ width: 70 }} src="https://static.bit.dev/extensions-icons/env.svg" />
6
+ </div>
7
+ );
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 components envs';
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 render(): Promise<JSX.Element> {
19
- const host = this.componentAspect.getHost();
20
- // TODO: think what to do re this line with gilad.
21
- if (!host) throw new Error('error: workspace not found');
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
- return new ListEnvsCmd(this.envs, this.componentAspect).render();
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
  }
package/envs.docs.mdx CHANGED
@@ -1,5 +1,5 @@
1
1
  ---
2
- description: Manages Environments and Environment Services
2
+ description: A composable engine for creating and maintaining development environments.
3
3
  labels: ['environments', 'core aspect']
4
4
  ---
5
5
 
package/package.json CHANGED
@@ -1,38 +1,39 @@
1
1
  {
2
2
  "name": "@teambit/envs",
3
- "version": "0.0.676",
3
+ "version": "0.0.679",
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.676"
9
+ "version": "0.0.679"
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.676",
20
- "@teambit/builder": "0.0.676",
21
- "@teambit/bundler": "0.0.676",
22
- "@teambit/compiler": "0.0.676",
23
- "@teambit/dependency-resolver": "0.0.676",
24
- "@teambit/elements": "0.0.129",
25
- "@teambit/formatter": "0.0.227",
26
- "@teambit/isolator": "0.0.676",
27
- "@teambit/linter": "0.0.676",
28
- "@teambit/pkg": "0.0.676",
29
- "@teambit/preview": "0.0.676",
30
- "@teambit/schema": "0.0.676",
31
- "@teambit/tester": "0.0.676",
32
- "@teambit/webpack": "0.0.676",
33
- "@teambit/graphql": "0.0.676",
34
- "@teambit/cli": "0.0.453",
35
- "@teambit/logger": "0.0.545",
20
+ "@teambit/component": "0.0.679",
21
+ "@teambit/builder": "0.0.679",
22
+ "@teambit/bundler": "0.0.679",
23
+ "@teambit/compiler": "0.0.679",
24
+ "@teambit/dependency-resolver": "0.0.679",
25
+ "@teambit/elements": "0.0.132",
26
+ "@teambit/formatter": "0.0.230",
27
+ "@teambit/isolator": "0.0.679",
28
+ "@teambit/linter": "0.0.679",
29
+ "@teambit/pkg": "0.0.679",
30
+ "@teambit/preview": "0.0.679",
31
+ "@teambit/schema": "0.0.679",
32
+ "@teambit/tester": "0.0.679",
33
+ "@teambit/webpack": "0.0.679",
34
+ "@teambit/graphql": "0.0.679",
35
+ "@teambit/cli": "0.0.454",
36
+ "@teambit/logger": "0.0.546",
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.232",
51
+ "@teambit/legacy": "1.0.233",
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.232",
79
+ "@teambit/legacy": "1.0.233",
79
80
  "react-dom": "^16.8.0 || ^17.0.0",
80
81
  "react": "^16.8.0 || ^17.0.0"
81
82
  }
@@ -0,0 +1,2 @@
1
+ export const compositions = [require('/home/circleci/Library/Caches/Bit/capsules/8891be5ad3d35bfc38b9cd90c0e05b598a5a55af/teambit.envs_envs@0.0.679/dist/env.composition.js')]
2
+ export const overview = [require('/home/circleci/Library/Caches/Bit/capsules/8891be5ad3d35bfc38b9cd90c0e05b598a5a55af/teambit.envs_envs@0.0.679/dist/envs.docs.mdx')]
@@ -1 +0,0 @@
1
- export const overview = [require('/home/circleci/Library/Caches/Bit/capsules/8891be5ad3d35bfc38b9cd90c0e05b598a5a55af/teambit.envs_envs@0.0.676/dist/envs.docs.mdx')]