@teambit/workspace 1.0.795 → 1.0.796
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/aspects-merger.d.ts
CHANGED
|
@@ -40,14 +40,6 @@ export declare class AspectsMerger {
|
|
|
40
40
|
* 2. force: false, which gets saved into the data.dependencies later on. see the workspace.getAutoDetectOverrides()
|
|
41
41
|
*/
|
|
42
42
|
private removeAutoDepsFromConfig;
|
|
43
|
-
/**
|
|
44
|
-
* this is needed because if the mergeConfig has a policy, it will be used, and any other policy along the line will be ignored.
|
|
45
|
-
* in case the model has some dependencies that were set explicitly they're gonna be ignored.
|
|
46
|
-
* this makes sure to add them to the policy of the mergeConfig.
|
|
47
|
-
* in a way, this is similar to what we do when a user is running `bit deps set` and the component had previous dependencies set,
|
|
48
|
-
* we copy those dependencies along with the current one to the .bitmap file, so they won't get lost.
|
|
49
|
-
*/
|
|
50
|
-
private addConfigDepsFromModelToConfigMerge;
|
|
51
43
|
private getUnmergedData;
|
|
52
44
|
private filterEnvsFromExtensionsIfNeeded;
|
|
53
45
|
/**
|
package/dist/aspects-merger.js
CHANGED
|
@@ -11,13 +11,6 @@ function _envs() {
|
|
|
11
11
|
};
|
|
12
12
|
return data;
|
|
13
13
|
}
|
|
14
|
-
function _dependencyResolver() {
|
|
15
|
-
const data = require("@teambit/dependency-resolver");
|
|
16
|
-
_dependencyResolver = function () {
|
|
17
|
-
return data;
|
|
18
|
-
};
|
|
19
|
-
return data;
|
|
20
|
-
}
|
|
21
14
|
function _legacy() {
|
|
22
15
|
const data = require("@teambit/legacy.extension-data");
|
|
23
16
|
_legacy = function () {
|
|
@@ -53,8 +46,6 @@ function _mergeConflictFile() {
|
|
|
53
46
|
};
|
|
54
47
|
return data;
|
|
55
48
|
}
|
|
56
|
-
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
57
|
-
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
58
49
|
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
59
50
|
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
|
|
60
51
|
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
@@ -121,7 +112,11 @@ class AspectsMerger {
|
|
|
121
112
|
const [specific, nonSpecific] = (0, _lodash().partition)(scopeExtensions, entry => entry.config[_workspace().AspectSpecificField] === true);
|
|
122
113
|
const scopeExtensionsNonSpecific = new (_legacy().ExtensionDataList)(...nonSpecific);
|
|
123
114
|
const scopeExtensionsSpecific = new (_legacy().ExtensionDataList)(...specific);
|
|
124
|
-
|
|
115
|
+
|
|
116
|
+
// Note: mergeConfigCombined (which includes unmergedData.mergedConfig) has already been processed
|
|
117
|
+
// in merging.main.runtime.ts:applyVersion() with scope-specific policy merged and deletion markers filtered.
|
|
118
|
+
// No need to process it again here.
|
|
119
|
+
|
|
125
120
|
const componentConfigFile = await this.workspace.componentConfigFile(componentId);
|
|
126
121
|
if (componentConfigFile) {
|
|
127
122
|
configFileExtensions = componentConfigFile.aspects.toLegacy();
|
|
@@ -254,28 +249,6 @@ class AspectsMerger {
|
|
|
254
249
|
this.mergeConfigDepsResolverDataCache[componentId.toString()] = (0, _lodash().merge)(this.mergeConfigDepsResolverDataCache[componentId.toString()], autoDepsObj);
|
|
255
250
|
}
|
|
256
251
|
}
|
|
257
|
-
|
|
258
|
-
/**
|
|
259
|
-
* this is needed because if the mergeConfig has a policy, it will be used, and any other policy along the line will be ignored.
|
|
260
|
-
* in case the model has some dependencies that were set explicitly they're gonna be ignored.
|
|
261
|
-
* this makes sure to add them to the policy of the mergeConfig.
|
|
262
|
-
* in a way, this is similar to what we do when a user is running `bit deps set` and the component had previous dependencies set,
|
|
263
|
-
* we copy those dependencies along with the current one to the .bitmap file, so they won't get lost.
|
|
264
|
-
*/
|
|
265
|
-
addConfigDepsFromModelToConfigMerge(scopeExtensionsSpecific, mergeConfig) {
|
|
266
|
-
const mergeConfigPolicy = mergeConfig?.[_dependencyResolver().DependencyResolverAspect.id]?.policy;
|
|
267
|
-
if (!mergeConfigPolicy) return;
|
|
268
|
-
const scopePolicy = scopeExtensionsSpecific.findCoreExtension(_dependencyResolver().DependencyResolverAspect.id)?.config.policy;
|
|
269
|
-
if (!scopePolicy) return;
|
|
270
|
-
Object.keys(scopePolicy).forEach(key => {
|
|
271
|
-
if (!mergeConfigPolicy[key]) {
|
|
272
|
-
mergeConfigPolicy[key] = scopePolicy[key];
|
|
273
|
-
return;
|
|
274
|
-
}
|
|
275
|
-
// mergeConfigPolicy should take precedence over scopePolicy
|
|
276
|
-
mergeConfigPolicy[key] = _objectSpread(_objectSpread({}, scopePolicy[key]), mergeConfigPolicy[key]);
|
|
277
|
-
});
|
|
278
|
-
}
|
|
279
252
|
getUnmergedData(componentId) {
|
|
280
253
|
return this.workspace.scope.legacyScope.objects.unmergedComponents.getEntry(componentId);
|
|
281
254
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_envs","data","require","_dependencyResolver","_legacy","_lodash","_mergeConfigConflict","_workspace","_mergeConflictFile","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","_toPropertyKey","value","configurable","writable","i","_toPrimitive","Symbol","toPrimitive","call","TypeError","String","Number","AspectsMerger","constructor","workspace","harmony","mergeConflictFile","MergeConflictFile","path","getDepsDataOfMergeConfig","id","mergeConfigDepsResolverDataCache","toString","merge","componentId","componentFromScope","excludeOrigins","configFileExtensions","variantsExtensions","mergeFromScope","errors","bitMapEntry","consumer","bitMap","getComponentIfExist","bitMapExtensions","config","configMerge","getConflictParsed","toStringWithoutVersion","err","MergeConfigConflict","logger","error","unmergedData","getUnmergedData","unmergedDataMergeConf","mergedConfig","cloneDeep","undefined","getMergeConfigCombined","mergeWith","objValue","srcValue","Array","isArray","concat","mergeConfigCombined","ExtensionDataList","adjustEnvsOnConfigObject","configMergeExtensions","fromConfigObject","removeAutoDepsFromConfig","scopeExtensionsBeforeClone","getComponentFromScopeWithoutDuplications","scopeExtensions","fromArray","map","clone","specific","nonSpecific","partition","entry","AspectSpecificField","scopeExtensionsNonSpecific","scopeExtensionsSpecific","addConfigDepsFromModelToConfigMerge","componentConfigFile","aspects","toLegacy","relativeComponentDir","componentDir","ignoreVersion","relative","variantConfig","variants","byRootDirAndName","fullName","extensions","extensionsToMerge","envWasFoundPreviously","removedExtensionIds","addExtensionsToMerge","origin","extraData","extData","isRemoved","stringId","extsWithoutRemoved","filterRemovedExtensions","selfInMergedExtensions","findExtension","extsWithoutSelf","extensionId","remove","preferWorkspaceVersion","extsWithUpdatedIds","resolveExtensionListIds","extensionDataListFiltered","envIsCurrentlySet","filterEnvsFromExtensionsIfNeeded","setDataListAsSpecific","dataEntry","includes","extensionDataList","continuePropagating","propagate","appliedRules","sortedMatches","pattern","specificity","afterMerge","mergeConfigs","ext","withoutRemoved","beforeMerge","scopeExtIds","ids","scopeExtHasDuplications","uniq","arr","uniqWith","getCompareExtPredicate","conf","fromScope","autoDepsObj","extractAutoDepsFromConfig","mergeConfig","mergeConfigPolicy","DependencyResolverAspect","policy","scopePolicy","findCoreExtension","key","scope","legacyScope","objects","unmergedComponents","getEntry","envAspect","EnvsAspect","envFromEnvsAspect","env","aspectsRegisteredAsEnvs","aspect","envs","getEnvDefinitionByStringId","newExtensionId","nonEnvs","clonedEnvAspect","compact","envAspectExt","find","listIds","envAspectId","found","isEqualWithoutVersion","Boolean","extensionList","promises","resolveComponentId","idFromWorkspace","getIdIfExist","Promise","all","exports"],"sources":["aspects-merger.ts"],"sourcesContent":["import type { Harmony } from '@teambit/harmony';\nimport type { Component } from '@teambit/component';\nimport type { UnmergedComponent } from '@teambit/legacy.scope';\nimport type { ComponentID } from '@teambit/component-id';\nimport { EnvsAspect } from '@teambit/envs';\nimport type { VariantPolicyConfigArr } from '@teambit/dependency-resolver';\nimport { DependencyResolverAspect } from '@teambit/dependency-resolver';\nimport { ExtensionDataList, getCompareExtPredicate } from '@teambit/legacy.extension-data';\nimport { partition, mergeWith, merge, uniq, uniqWith, compact, cloneDeep } from 'lodash';\nimport { MergeConfigConflict } from './exceptions/merge-config-conflict';\nimport type { ExtensionsOrigin, Workspace } from './workspace';\nimport { AspectSpecificField } from './workspace';\nimport { MergeConflictFile } from './merge-conflict-file';\n\nexport class AspectsMerger {\n readonly mergeConflictFile: MergeConflictFile;\n private mergeConfigDepsResolverDataCache: { [compIdStr: string]: VariantPolicyConfigArr } = {};\n constructor(\n private workspace: Workspace,\n private harmony: Harmony\n ) {\n this.mergeConflictFile = new MergeConflictFile(workspace.path);\n }\n\n getDepsDataOfMergeConfig(id: ComponentID): VariantPolicyConfigArr {\n return this.mergeConfigDepsResolverDataCache[id.toString()];\n }\n\n /**\n * Calculate the component config based on:\n * the config property in the .bitmap file\n * the component.json file in the component folder\n * matching pattern in the variants config\n * defaults extensions from workspace config\n * extensions from the model.\n */\n async merge(\n componentId: ComponentID,\n componentFromScope?: Component,\n excludeOrigins: ExtensionsOrigin[] = []\n ): Promise<{\n extensions: ExtensionDataList;\n beforeMerge: Array<{ extensions: ExtensionDataList; origin: ExtensionsOrigin; extraData: any }>; // useful for debugging\n errors?: Error[];\n }> {\n // TODO: consider caching this result\n let configFileExtensions: ExtensionDataList | undefined;\n let variantsExtensions: ExtensionDataList | undefined;\n const mergeFromScope = true;\n const errors: Error[] = [];\n\n const bitMapEntry = this.workspace.consumer.bitMap.getComponentIfExist(componentId);\n const bitMapExtensions = bitMapEntry?.config;\n\n let configMerge: Record<string, any> | undefined;\n try {\n configMerge = this.mergeConflictFile.getConflictParsed(componentId.toStringWithoutVersion());\n } catch (err) {\n if (!(err instanceof MergeConfigConflict)) {\n throw err;\n }\n this.workspace.logger.error(`unable to parse the config file for ${componentId.toString()} due to conflicts`);\n errors.push(err);\n }\n\n const unmergedData = this.getUnmergedData(componentId);\n const unmergedDataMergeConf = unmergedData?.mergedConfig ? cloneDeep(unmergedData.mergedConfig) : undefined;\n const getMergeConfigCombined = () => {\n if (!configMerge && !unmergedDataMergeConf) return undefined;\n if (!configMerge) return unmergedDataMergeConf;\n if (!unmergedDataMergeConf) return configMerge;\n\n return mergeWith(configMerge, unmergedDataMergeConf, (objValue, srcValue) => {\n if (Array.isArray(objValue)) {\n // critical for dependencyResolver.policy.*dependencies. otherwise, it will override the array\n return objValue.concat(srcValue);\n }\n return undefined;\n });\n };\n const mergeConfigCombined = getMergeConfigCombined();\n ExtensionDataList.adjustEnvsOnConfigObject(mergeConfigCombined || {});\n\n const configMergeExtensions = mergeConfigCombined\n ? ExtensionDataList.fromConfigObject(mergeConfigCombined)\n : undefined;\n\n this.removeAutoDepsFromConfig(componentId, configMergeExtensions);\n const scopeExtensionsBeforeClone = this.getComponentFromScopeWithoutDuplications(componentFromScope);\n const scopeExtensions = ExtensionDataList.fromArray(scopeExtensionsBeforeClone.map((e) => e.clone()));\n // backward compatibility. previously, it was saved as an array into the model (when there was merge-config)\n this.removeAutoDepsFromConfig(componentId, scopeExtensions, true);\n const [specific, nonSpecific] = partition(scopeExtensions, (entry) => entry.config[AspectSpecificField] === true);\n const scopeExtensionsNonSpecific = new ExtensionDataList(...nonSpecific);\n const scopeExtensionsSpecific = new ExtensionDataList(...specific);\n\n this.addConfigDepsFromModelToConfigMerge(scopeExtensions, mergeConfigCombined);\n\n const componentConfigFile = await this.workspace.componentConfigFile(componentId);\n if (componentConfigFile) {\n configFileExtensions = componentConfigFile.aspects.toLegacy();\n }\n const relativeComponentDir = this.workspace.componentDir(componentId, { ignoreVersion: true }, { relative: true });\n const variantConfig = this.workspace.variants.byRootDirAndName(relativeComponentDir, componentId.fullName);\n if (variantConfig) {\n variantsExtensions = variantConfig.extensions.clone();\n // Do not merge from scope when there is specific variant (which is not *) that match the component\n // if (variantConfig.maxSpecificity > 0) {\n // mergeFromScope = false;\n // }\n }\n // We don't stop on each step because we want to merge the default scope even if propagate=false but the default scope is not defined\n // in the case the same extension pushed twice, the former takes precedence (opposite of Object.assign)\n const extensionsToMerge: Array<{ origin: ExtensionsOrigin; extensions: ExtensionDataList; extraData: any }> = [];\n let envWasFoundPreviously = false;\n const removedExtensionIds: string[] = [];\n\n const addExtensionsToMerge = async (extensions: ExtensionDataList, origin: ExtensionsOrigin, extraData?: any) => {\n if (!extensions.length) {\n return;\n }\n removedExtensionIds.push(...extensions.filter((extData) => extData.isRemoved).map((extData) => extData.stringId));\n const extsWithoutRemoved = extensions.filterRemovedExtensions();\n const selfInMergedExtensions = extsWithoutRemoved.findExtension(componentId.toStringWithoutVersion(), true);\n const extsWithoutSelf = selfInMergedExtensions?.extensionId\n ? extsWithoutRemoved.remove(selfInMergedExtensions.extensionId)\n : extsWithoutRemoved;\n const preferWorkspaceVersion = origin !== 'BitmapFile' && origin !== 'ComponentJsonFile';\n // it's important to do this resolution before the merge, otherwise we have issues with extensions\n // coming from scope with local scope name, as opposed to the same extension comes from the workspace with default scope name\n // also, it's important to do it before filtering the env, because when the env was not exported, it's saved with scope-name\n // inside the \"env\" prop of teambit.envs/env, but without scope-name in the root.\n const extsWithUpdatedIds = await this.resolveExtensionListIds(extsWithoutSelf, preferWorkspaceVersion);\n const { extensionDataListFiltered, envIsCurrentlySet } = await this.filterEnvsFromExtensionsIfNeeded(\n extsWithUpdatedIds,\n envWasFoundPreviously,\n origin\n );\n if (envIsCurrentlySet) {\n envWasFoundPreviously = true;\n }\n\n extensionsToMerge.push({ origin, extensions: extensionDataListFiltered, extraData });\n };\n const setDataListAsSpecific = (extensions: ExtensionDataList) => {\n extensions.forEach((dataEntry) => (dataEntry.config[AspectSpecificField] = true));\n };\n if (bitMapExtensions && !excludeOrigins.includes('BitmapFile')) {\n const extensionDataList = ExtensionDataList.fromConfigObject(bitMapExtensions);\n setDataListAsSpecific(extensionDataList);\n await addExtensionsToMerge(extensionDataList, 'BitmapFile');\n }\n // config-merge is after the .bitmap. because normally if you have config set in .bitmap, you won't\n // be able to lane-merge. (unless you specify --ignore-config-changes).\n // so, if there is config in .bitmap, it probably happened after lane-merge.\n if (configMergeExtensions && !excludeOrigins.includes('ConfigMerge')) {\n await addExtensionsToMerge(ExtensionDataList.fromArray(configMergeExtensions), 'ConfigMerge');\n }\n if (configFileExtensions && !excludeOrigins.includes('ComponentJsonFile')) {\n setDataListAsSpecific(configFileExtensions);\n await addExtensionsToMerge(configFileExtensions, 'ComponentJsonFile');\n }\n if (!excludeOrigins.includes('ModelSpecific')) {\n await addExtensionsToMerge(ExtensionDataList.fromArray(scopeExtensionsSpecific), 'ModelSpecific');\n }\n let continuePropagating = componentConfigFile?.propagate ?? true;\n if (variantsExtensions && continuePropagating && !excludeOrigins.includes('WorkspaceVariants')) {\n const appliedRules = variantConfig?.sortedMatches.map(({ pattern, specificity }) => ({ pattern, specificity }));\n await addExtensionsToMerge(variantsExtensions, 'WorkspaceVariants', { appliedRules });\n }\n continuePropagating = continuePropagating && (variantConfig?.propagate ?? true);\n if (mergeFromScope && continuePropagating && !excludeOrigins.includes('ModelNonSpecific')) {\n await addExtensionsToMerge(scopeExtensionsNonSpecific, 'ModelNonSpecific');\n }\n\n const afterMerge = ExtensionDataList.mergeConfigs(extensionsToMerge.map((ext) => ext.extensions));\n const withoutRemoved = afterMerge.filter((extData) => !removedExtensionIds.includes(extData.stringId));\n // clone the extension data to avoid mutating the original data (specifically, we don't want to mutate the scope data)\n const extensions = ExtensionDataList.fromArray(withoutRemoved);\n return {\n extensions,\n beforeMerge: extensionsToMerge,\n errors,\n };\n }\n\n /**\n * before version 0.0.882 it was possible to save Version object with the same extension twice.\n */\n private getComponentFromScopeWithoutDuplications(componentFromScope?: Component) {\n if (!componentFromScope) return new ExtensionDataList();\n const scopeExtensions = componentFromScope.config.extensions;\n const scopeExtIds = scopeExtensions.ids;\n const scopeExtHasDuplications = scopeExtIds.length !== uniq(scopeExtIds).length;\n if (!scopeExtHasDuplications) {\n return scopeExtensions;\n }\n // let's remove this duplicated extension blindly without trying to merge. (no need to merge coz it's old data from scope\n // which will be overridden anyway by the workspace or other config strategies).\n const arr = uniqWith(scopeExtensions, getCompareExtPredicate(true));\n return ExtensionDataList.fromArray(arr);\n }\n\n /**\n * from the merge-config we get the dep-resolver policy as an array, because it needs to support \"force\" prop.\n * however, when we save the config, we want to save it as an object, so we need split the data into two:\n * 1. force: true, which gets saved into the config.\n * 2. force: false, which gets saved into the data.dependencies later on. see the workspace.getAutoDetectOverrides()\n */\n private removeAutoDepsFromConfig(componentId: ComponentID, conf?: ExtensionDataList, fromScope = false) {\n if (!conf) return;\n const autoDepsObj = conf.extractAutoDepsFromConfig();\n if (!autoDepsObj) return;\n if (!fromScope) {\n if (!this.mergeConfigDepsResolverDataCache[componentId.toString()]) {\n this.mergeConfigDepsResolverDataCache[componentId.toString()] = {};\n }\n this.mergeConfigDepsResolverDataCache[componentId.toString()] = merge(\n this.mergeConfigDepsResolverDataCache[componentId.toString()],\n autoDepsObj\n );\n }\n }\n\n /**\n * this is needed because if the mergeConfig has a policy, it will be used, and any other policy along the line will be ignored.\n * in case the model has some dependencies that were set explicitly they're gonna be ignored.\n * this makes sure to add them to the policy of the mergeConfig.\n * in a way, this is similar to what we do when a user is running `bit deps set` and the component had previous dependencies set,\n * we copy those dependencies along with the current one to the .bitmap file, so they won't get lost.\n */\n private addConfigDepsFromModelToConfigMerge(\n scopeExtensionsSpecific: ExtensionDataList,\n mergeConfig?: Record<string, any>\n ) {\n const mergeConfigPolicy = mergeConfig?.[DependencyResolverAspect.id]?.policy;\n if (!mergeConfigPolicy) return;\n const scopePolicy = scopeExtensionsSpecific.findCoreExtension(DependencyResolverAspect.id)?.config.policy;\n if (!scopePolicy) return;\n Object.keys(scopePolicy).forEach((key) => {\n if (!mergeConfigPolicy[key]) {\n mergeConfigPolicy[key] = scopePolicy[key];\n return;\n }\n // mergeConfigPolicy should take precedence over scopePolicy\n mergeConfigPolicy[key] = { ...scopePolicy[key], ...mergeConfigPolicy[key] };\n });\n }\n\n private getUnmergedData(componentId: ComponentID): UnmergedComponent | undefined {\n return this.workspace.scope.legacyScope.objects.unmergedComponents.getEntry(componentId);\n }\n\n private async filterEnvsFromExtensionsIfNeeded(\n extensionDataList: ExtensionDataList,\n envWasFoundPreviously: boolean,\n origin: ExtensionsOrigin\n ) {\n const envAspect = extensionDataList.findExtension(EnvsAspect.id);\n const envFromEnvsAspect: string | undefined = envAspect?.config.env || envAspect?.data.id;\n const aspectsRegisteredAsEnvs = extensionDataList\n .filter((aspect) =>\n this.workspace.envs.getEnvDefinitionByStringId(aspect.newExtensionId?.toString() || aspect.stringId)\n )\n .map((aspect) => aspect.stringId);\n if (envWasFoundPreviously && (envAspect || aspectsRegisteredAsEnvs.length)) {\n const nonEnvs = extensionDataList.map((e) => {\n // normally the env-id inside the envs aspect doesn't have a version, but the aspect itself has a version.\n // also, the env-id inside the envs aspect includes the default-scope, but the aspect itself doesn't.\n if (\n (envFromEnvsAspect && e.stringId === envFromEnvsAspect) ||\n (envFromEnvsAspect && e.extensionId?.toStringWithoutVersion() === envFromEnvsAspect) ||\n aspectsRegisteredAsEnvs.includes(e.stringId)\n ) {\n return undefined;\n }\n if (e.stringId === envAspect?.stringId) {\n // must clone the env aspect to avoid mutating the original data\n const clonedEnvAspect = e.clone();\n delete clonedEnvAspect.config.env; // aspect env may have other data other then config.env.\n return clonedEnvAspect;\n }\n return e;\n });\n\n return { extensionDataListFiltered: new ExtensionDataList(...compact(nonEnvs)), envIsCurrentlySet: true };\n }\n if (envFromEnvsAspect && (origin === 'ModelNonSpecific' || origin === 'ModelSpecific')) {\n // if env was found, search for this env in the workspace and if found, replace the env-id with the one from the workspace\n const envAspectExt = extensionDataList.find((e) => e.extensionId?.toStringWithoutVersion() === envFromEnvsAspect);\n const ids = this.workspace.listIds();\n const envAspectId = envAspectExt?.extensionId;\n const found = envAspectId && ids.find((id) => id.isEqualWithoutVersion(envAspectId));\n if (found) {\n envAspectExt.extensionId = found;\n }\n }\n return { extensionDataListFiltered: extensionDataList, envIsCurrentlySet: Boolean(envFromEnvsAspect) };\n }\n\n /**\n * This will mutate the entries with extensionId prop to have resolved legacy id\n * This should be worked on the extension data list not the new aspect list\n * @param extensionList\n */\n private async resolveExtensionListIds(\n extensionList: ExtensionDataList,\n preferWorkspaceVersion = false\n ): Promise<ExtensionDataList> {\n const promises = extensionList.map(async (entry) => {\n if (entry.extensionId) {\n // don't pass `entry.extensionId` (as ComponentID) to `resolveComponentId` because then it'll use the optimization\n // of parsing it to ComponentID without checking the workspace. Normally, this optimization is good, but here\n // in case the extension wasn't exported, the ComponentID is wrong, it has the scope-name due to incorrect ComponentID.fromString\n // in configEntryToDataEntry() function. It'd be ideal to fix it from there but it's not easy.\n const componentId = await this.workspace.resolveComponentId(entry.extensionId.toString());\n const idFromWorkspace = preferWorkspaceVersion ? this.workspace.getIdIfExist(componentId) : undefined;\n const id = idFromWorkspace || componentId;\n entry.extensionId = id;\n entry.newExtensionId = id;\n }\n\n return entry;\n });\n await Promise.all(promises);\n return extensionList;\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["_envs","data","require","_legacy","_lodash","_mergeConfigConflict","_workspace","_mergeConflictFile","_defineProperty","e","r","t","_toPropertyKey","Object","defineProperty","value","enumerable","configurable","writable","i","_toPrimitive","Symbol","toPrimitive","call","TypeError","String","Number","AspectsMerger","constructor","workspace","harmony","mergeConflictFile","MergeConflictFile","path","getDepsDataOfMergeConfig","id","mergeConfigDepsResolverDataCache","toString","merge","componentId","componentFromScope","excludeOrigins","configFileExtensions","variantsExtensions","mergeFromScope","errors","bitMapEntry","consumer","bitMap","getComponentIfExist","bitMapExtensions","config","configMerge","getConflictParsed","toStringWithoutVersion","err","MergeConfigConflict","logger","error","push","unmergedData","getUnmergedData","unmergedDataMergeConf","mergedConfig","cloneDeep","undefined","getMergeConfigCombined","mergeWith","objValue","srcValue","Array","isArray","concat","mergeConfigCombined","ExtensionDataList","adjustEnvsOnConfigObject","configMergeExtensions","fromConfigObject","removeAutoDepsFromConfig","scopeExtensionsBeforeClone","getComponentFromScopeWithoutDuplications","scopeExtensions","fromArray","map","clone","specific","nonSpecific","partition","entry","AspectSpecificField","scopeExtensionsNonSpecific","scopeExtensionsSpecific","componentConfigFile","aspects","toLegacy","relativeComponentDir","componentDir","ignoreVersion","relative","variantConfig","variants","byRootDirAndName","fullName","extensions","extensionsToMerge","envWasFoundPreviously","removedExtensionIds","addExtensionsToMerge","origin","extraData","length","filter","extData","isRemoved","stringId","extsWithoutRemoved","filterRemovedExtensions","selfInMergedExtensions","findExtension","extsWithoutSelf","extensionId","remove","preferWorkspaceVersion","extsWithUpdatedIds","resolveExtensionListIds","extensionDataListFiltered","envIsCurrentlySet","filterEnvsFromExtensionsIfNeeded","setDataListAsSpecific","forEach","dataEntry","includes","extensionDataList","continuePropagating","propagate","appliedRules","sortedMatches","pattern","specificity","afterMerge","mergeConfigs","ext","withoutRemoved","beforeMerge","scopeExtIds","ids","scopeExtHasDuplications","uniq","arr","uniqWith","getCompareExtPredicate","conf","fromScope","autoDepsObj","extractAutoDepsFromConfig","scope","legacyScope","objects","unmergedComponents","getEntry","envAspect","EnvsAspect","envFromEnvsAspect","env","aspectsRegisteredAsEnvs","aspect","envs","getEnvDefinitionByStringId","newExtensionId","nonEnvs","clonedEnvAspect","compact","envAspectExt","find","listIds","envAspectId","found","isEqualWithoutVersion","Boolean","extensionList","promises","resolveComponentId","idFromWorkspace","getIdIfExist","Promise","all","exports"],"sources":["aspects-merger.ts"],"sourcesContent":["import type { Harmony } from '@teambit/harmony';\nimport type { Component } from '@teambit/component';\nimport type { UnmergedComponent } from '@teambit/legacy.scope';\nimport type { ComponentID } from '@teambit/component-id';\nimport { EnvsAspect } from '@teambit/envs';\nimport type { VariantPolicyConfigArr } from '@teambit/dependency-resolver';\nimport { ExtensionDataList, getCompareExtPredicate } from '@teambit/legacy.extension-data';\nimport { partition, mergeWith, merge, uniq, uniqWith, compact, cloneDeep } from 'lodash';\nimport { MergeConfigConflict } from './exceptions/merge-config-conflict';\nimport type { ExtensionsOrigin, Workspace } from './workspace';\nimport { AspectSpecificField } from './workspace';\nimport { MergeConflictFile } from './merge-conflict-file';\n\nexport class AspectsMerger {\n readonly mergeConflictFile: MergeConflictFile;\n private mergeConfigDepsResolverDataCache: { [compIdStr: string]: VariantPolicyConfigArr } = {};\n constructor(\n private workspace: Workspace,\n private harmony: Harmony\n ) {\n this.mergeConflictFile = new MergeConflictFile(workspace.path);\n }\n\n getDepsDataOfMergeConfig(id: ComponentID): VariantPolicyConfigArr {\n return this.mergeConfigDepsResolverDataCache[id.toString()];\n }\n\n /**\n * Calculate the component config based on:\n * the config property in the .bitmap file\n * the component.json file in the component folder\n * matching pattern in the variants config\n * defaults extensions from workspace config\n * extensions from the model.\n */\n async merge(\n componentId: ComponentID,\n componentFromScope?: Component,\n excludeOrigins: ExtensionsOrigin[] = []\n ): Promise<{\n extensions: ExtensionDataList;\n beforeMerge: Array<{ extensions: ExtensionDataList; origin: ExtensionsOrigin; extraData: any }>; // useful for debugging\n errors?: Error[];\n }> {\n // TODO: consider caching this result\n let configFileExtensions: ExtensionDataList | undefined;\n let variantsExtensions: ExtensionDataList | undefined;\n const mergeFromScope = true;\n const errors: Error[] = [];\n\n const bitMapEntry = this.workspace.consumer.bitMap.getComponentIfExist(componentId);\n const bitMapExtensions = bitMapEntry?.config;\n\n let configMerge: Record<string, any> | undefined;\n try {\n configMerge = this.mergeConflictFile.getConflictParsed(componentId.toStringWithoutVersion());\n } catch (err) {\n if (!(err instanceof MergeConfigConflict)) {\n throw err;\n }\n this.workspace.logger.error(`unable to parse the config file for ${componentId.toString()} due to conflicts`);\n errors.push(err);\n }\n\n const unmergedData = this.getUnmergedData(componentId);\n const unmergedDataMergeConf = unmergedData?.mergedConfig ? cloneDeep(unmergedData.mergedConfig) : undefined;\n const getMergeConfigCombined = () => {\n if (!configMerge && !unmergedDataMergeConf) return undefined;\n if (!configMerge) return unmergedDataMergeConf;\n if (!unmergedDataMergeConf) return configMerge;\n\n return mergeWith(configMerge, unmergedDataMergeConf, (objValue, srcValue) => {\n if (Array.isArray(objValue)) {\n // critical for dependencyResolver.policy.*dependencies. otherwise, it will override the array\n return objValue.concat(srcValue);\n }\n return undefined;\n });\n };\n const mergeConfigCombined = getMergeConfigCombined();\n ExtensionDataList.adjustEnvsOnConfigObject(mergeConfigCombined || {});\n\n const configMergeExtensions = mergeConfigCombined\n ? ExtensionDataList.fromConfigObject(mergeConfigCombined)\n : undefined;\n\n this.removeAutoDepsFromConfig(componentId, configMergeExtensions);\n const scopeExtensionsBeforeClone = this.getComponentFromScopeWithoutDuplications(componentFromScope);\n const scopeExtensions = ExtensionDataList.fromArray(scopeExtensionsBeforeClone.map((e) => e.clone()));\n // backward compatibility. previously, it was saved as an array into the model (when there was merge-config)\n this.removeAutoDepsFromConfig(componentId, scopeExtensions, true);\n const [specific, nonSpecific] = partition(scopeExtensions, (entry) => entry.config[AspectSpecificField] === true);\n const scopeExtensionsNonSpecific = new ExtensionDataList(...nonSpecific);\n const scopeExtensionsSpecific = new ExtensionDataList(...specific);\n\n // Note: mergeConfigCombined (which includes unmergedData.mergedConfig) has already been processed\n // in merging.main.runtime.ts:applyVersion() with scope-specific policy merged and deletion markers filtered.\n // No need to process it again here.\n\n const componentConfigFile = await this.workspace.componentConfigFile(componentId);\n if (componentConfigFile) {\n configFileExtensions = componentConfigFile.aspects.toLegacy();\n }\n const relativeComponentDir = this.workspace.componentDir(componentId, { ignoreVersion: true }, { relative: true });\n const variantConfig = this.workspace.variants.byRootDirAndName(relativeComponentDir, componentId.fullName);\n if (variantConfig) {\n variantsExtensions = variantConfig.extensions.clone();\n // Do not merge from scope when there is specific variant (which is not *) that match the component\n // if (variantConfig.maxSpecificity > 0) {\n // mergeFromScope = false;\n // }\n }\n // We don't stop on each step because we want to merge the default scope even if propagate=false but the default scope is not defined\n // in the case the same extension pushed twice, the former takes precedence (opposite of Object.assign)\n const extensionsToMerge: Array<{ origin: ExtensionsOrigin; extensions: ExtensionDataList; extraData: any }> = [];\n let envWasFoundPreviously = false;\n const removedExtensionIds: string[] = [];\n\n const addExtensionsToMerge = async (extensions: ExtensionDataList, origin: ExtensionsOrigin, extraData?: any) => {\n if (!extensions.length) {\n return;\n }\n removedExtensionIds.push(...extensions.filter((extData) => extData.isRemoved).map((extData) => extData.stringId));\n const extsWithoutRemoved = extensions.filterRemovedExtensions();\n const selfInMergedExtensions = extsWithoutRemoved.findExtension(componentId.toStringWithoutVersion(), true);\n const extsWithoutSelf = selfInMergedExtensions?.extensionId\n ? extsWithoutRemoved.remove(selfInMergedExtensions.extensionId)\n : extsWithoutRemoved;\n const preferWorkspaceVersion = origin !== 'BitmapFile' && origin !== 'ComponentJsonFile';\n // it's important to do this resolution before the merge, otherwise we have issues with extensions\n // coming from scope with local scope name, as opposed to the same extension comes from the workspace with default scope name\n // also, it's important to do it before filtering the env, because when the env was not exported, it's saved with scope-name\n // inside the \"env\" prop of teambit.envs/env, but without scope-name in the root.\n const extsWithUpdatedIds = await this.resolveExtensionListIds(extsWithoutSelf, preferWorkspaceVersion);\n const { extensionDataListFiltered, envIsCurrentlySet } = await this.filterEnvsFromExtensionsIfNeeded(\n extsWithUpdatedIds,\n envWasFoundPreviously,\n origin\n );\n if (envIsCurrentlySet) {\n envWasFoundPreviously = true;\n }\n\n extensionsToMerge.push({ origin, extensions: extensionDataListFiltered, extraData });\n };\n const setDataListAsSpecific = (extensions: ExtensionDataList) => {\n extensions.forEach((dataEntry) => (dataEntry.config[AspectSpecificField] = true));\n };\n if (bitMapExtensions && !excludeOrigins.includes('BitmapFile')) {\n const extensionDataList = ExtensionDataList.fromConfigObject(bitMapExtensions);\n setDataListAsSpecific(extensionDataList);\n await addExtensionsToMerge(extensionDataList, 'BitmapFile');\n }\n // config-merge is after the .bitmap. because normally if you have config set in .bitmap, you won't\n // be able to lane-merge. (unless you specify --ignore-config-changes).\n // so, if there is config in .bitmap, it probably happened after lane-merge.\n if (configMergeExtensions && !excludeOrigins.includes('ConfigMerge')) {\n await addExtensionsToMerge(ExtensionDataList.fromArray(configMergeExtensions), 'ConfigMerge');\n }\n if (configFileExtensions && !excludeOrigins.includes('ComponentJsonFile')) {\n setDataListAsSpecific(configFileExtensions);\n await addExtensionsToMerge(configFileExtensions, 'ComponentJsonFile');\n }\n if (!excludeOrigins.includes('ModelSpecific')) {\n await addExtensionsToMerge(ExtensionDataList.fromArray(scopeExtensionsSpecific), 'ModelSpecific');\n }\n let continuePropagating = componentConfigFile?.propagate ?? true;\n if (variantsExtensions && continuePropagating && !excludeOrigins.includes('WorkspaceVariants')) {\n const appliedRules = variantConfig?.sortedMatches.map(({ pattern, specificity }) => ({ pattern, specificity }));\n await addExtensionsToMerge(variantsExtensions, 'WorkspaceVariants', { appliedRules });\n }\n continuePropagating = continuePropagating && (variantConfig?.propagate ?? true);\n if (mergeFromScope && continuePropagating && !excludeOrigins.includes('ModelNonSpecific')) {\n await addExtensionsToMerge(scopeExtensionsNonSpecific, 'ModelNonSpecific');\n }\n\n const afterMerge = ExtensionDataList.mergeConfigs(extensionsToMerge.map((ext) => ext.extensions));\n const withoutRemoved = afterMerge.filter((extData) => !removedExtensionIds.includes(extData.stringId));\n // clone the extension data to avoid mutating the original data (specifically, we don't want to mutate the scope data)\n const extensions = ExtensionDataList.fromArray(withoutRemoved);\n return {\n extensions,\n beforeMerge: extensionsToMerge,\n errors,\n };\n }\n\n /**\n * before version 0.0.882 it was possible to save Version object with the same extension twice.\n */\n private getComponentFromScopeWithoutDuplications(componentFromScope?: Component) {\n if (!componentFromScope) return new ExtensionDataList();\n const scopeExtensions = componentFromScope.config.extensions;\n const scopeExtIds = scopeExtensions.ids;\n const scopeExtHasDuplications = scopeExtIds.length !== uniq(scopeExtIds).length;\n if (!scopeExtHasDuplications) {\n return scopeExtensions;\n }\n // let's remove this duplicated extension blindly without trying to merge. (no need to merge coz it's old data from scope\n // which will be overridden anyway by the workspace or other config strategies).\n const arr = uniqWith(scopeExtensions, getCompareExtPredicate(true));\n return ExtensionDataList.fromArray(arr);\n }\n\n /**\n * from the merge-config we get the dep-resolver policy as an array, because it needs to support \"force\" prop.\n * however, when we save the config, we want to save it as an object, so we need split the data into two:\n * 1. force: true, which gets saved into the config.\n * 2. force: false, which gets saved into the data.dependencies later on. see the workspace.getAutoDetectOverrides()\n */\n private removeAutoDepsFromConfig(componentId: ComponentID, conf?: ExtensionDataList, fromScope = false) {\n if (!conf) return;\n const autoDepsObj = conf.extractAutoDepsFromConfig();\n if (!autoDepsObj) return;\n if (!fromScope) {\n if (!this.mergeConfigDepsResolverDataCache[componentId.toString()]) {\n this.mergeConfigDepsResolverDataCache[componentId.toString()] = {};\n }\n this.mergeConfigDepsResolverDataCache[componentId.toString()] = merge(\n this.mergeConfigDepsResolverDataCache[componentId.toString()],\n autoDepsObj\n );\n }\n }\n\n private getUnmergedData(componentId: ComponentID): UnmergedComponent | undefined {\n return this.workspace.scope.legacyScope.objects.unmergedComponents.getEntry(componentId);\n }\n\n private async filterEnvsFromExtensionsIfNeeded(\n extensionDataList: ExtensionDataList,\n envWasFoundPreviously: boolean,\n origin: ExtensionsOrigin\n ) {\n const envAspect = extensionDataList.findExtension(EnvsAspect.id);\n const envFromEnvsAspect: string | undefined = envAspect?.config.env || envAspect?.data.id;\n const aspectsRegisteredAsEnvs = extensionDataList\n .filter((aspect) =>\n this.workspace.envs.getEnvDefinitionByStringId(aspect.newExtensionId?.toString() || aspect.stringId)\n )\n .map((aspect) => aspect.stringId);\n if (envWasFoundPreviously && (envAspect || aspectsRegisteredAsEnvs.length)) {\n const nonEnvs = extensionDataList.map((e) => {\n // normally the env-id inside the envs aspect doesn't have a version, but the aspect itself has a version.\n // also, the env-id inside the envs aspect includes the default-scope, but the aspect itself doesn't.\n if (\n (envFromEnvsAspect && e.stringId === envFromEnvsAspect) ||\n (envFromEnvsAspect && e.extensionId?.toStringWithoutVersion() === envFromEnvsAspect) ||\n aspectsRegisteredAsEnvs.includes(e.stringId)\n ) {\n return undefined;\n }\n if (e.stringId === envAspect?.stringId) {\n // must clone the env aspect to avoid mutating the original data\n const clonedEnvAspect = e.clone();\n delete clonedEnvAspect.config.env; // aspect env may have other data other then config.env.\n return clonedEnvAspect;\n }\n return e;\n });\n\n return { extensionDataListFiltered: new ExtensionDataList(...compact(nonEnvs)), envIsCurrentlySet: true };\n }\n if (envFromEnvsAspect && (origin === 'ModelNonSpecific' || origin === 'ModelSpecific')) {\n // if env was found, search for this env in the workspace and if found, replace the env-id with the one from the workspace\n const envAspectExt = extensionDataList.find((e) => e.extensionId?.toStringWithoutVersion() === envFromEnvsAspect);\n const ids = this.workspace.listIds();\n const envAspectId = envAspectExt?.extensionId;\n const found = envAspectId && ids.find((id) => id.isEqualWithoutVersion(envAspectId));\n if (found) {\n envAspectExt.extensionId = found;\n }\n }\n return { extensionDataListFiltered: extensionDataList, envIsCurrentlySet: Boolean(envFromEnvsAspect) };\n }\n\n /**\n * This will mutate the entries with extensionId prop to have resolved legacy id\n * This should be worked on the extension data list not the new aspect list\n * @param extensionList\n */\n private async resolveExtensionListIds(\n extensionList: ExtensionDataList,\n preferWorkspaceVersion = false\n ): Promise<ExtensionDataList> {\n const promises = extensionList.map(async (entry) => {\n if (entry.extensionId) {\n // don't pass `entry.extensionId` (as ComponentID) to `resolveComponentId` because then it'll use the optimization\n // of parsing it to ComponentID without checking the workspace. Normally, this optimization is good, but here\n // in case the extension wasn't exported, the ComponentID is wrong, it has the scope-name due to incorrect ComponentID.fromString\n // in configEntryToDataEntry() function. It'd be ideal to fix it from there but it's not easy.\n const componentId = await this.workspace.resolveComponentId(entry.extensionId.toString());\n const idFromWorkspace = preferWorkspaceVersion ? this.workspace.getIdIfExist(componentId) : undefined;\n const id = idFromWorkspace || componentId;\n entry.extensionId = id;\n entry.newExtensionId = id;\n }\n\n return entry;\n });\n await Promise.all(promises);\n return extensionList;\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import * as compositions_0 from '/home/circleci/Library/Caches/Bit/capsules/8891be5ad/teambit.workspace_workspace@1.0.
|
|
2
|
-
import * as overview_0 from '/home/circleci/Library/Caches/Bit/capsules/8891be5ad/teambit.workspace_workspace@1.0.
|
|
1
|
+
import * as compositions_0 from '/home/circleci/Library/Caches/Bit/capsules/8891be5ad/teambit.workspace_workspace@1.0.796/dist/workspace.composition.js';
|
|
2
|
+
import * as overview_0 from '/home/circleci/Library/Caches/Bit/capsules/8891be5ad/teambit.workspace_workspace@1.0.796/dist/workspace.docs.mdx';
|
|
3
3
|
|
|
4
4
|
export const compositions = [compositions_0];
|
|
5
5
|
export const overview = [overview_0];
|
package/package.json
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@teambit/workspace",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.796",
|
|
4
4
|
"homepage": "https://bit.cloud/teambit/workspace/workspace",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"componentId": {
|
|
7
7
|
"scope": "teambit.workspace",
|
|
8
8
|
"name": "workspace",
|
|
9
|
-
"version": "1.0.
|
|
9
|
+
"version": "1.0.796"
|
|
10
10
|
},
|
|
11
11
|
"dependencies": {
|
|
12
12
|
"lodash": "4.17.21",
|
|
@@ -102,23 +102,23 @@
|
|
|
102
102
|
"@teambit/scopes.scope-id": "0.0.9",
|
|
103
103
|
"@teambit/workspace.ui.empty-workspace": "0.0.509",
|
|
104
104
|
"@teambit/workspace.ui.workspace-component-card": "0.0.563",
|
|
105
|
-
"@teambit/component": "1.0.
|
|
106
|
-
"@teambit/dependency-resolver": "1.0.
|
|
107
|
-
"@teambit/envs": "1.0.
|
|
108
|
-
"@teambit/objects": "0.0.
|
|
109
|
-
"@teambit/scope": "1.0.
|
|
110
|
-
"@teambit/graph": "1.0.
|
|
111
|
-
"@teambit/isolator": "1.0.
|
|
112
|
-
"@teambit/component-tree": "1.0.
|
|
113
|
-
"@teambit/watcher": "1.0.
|
|
114
|
-
"@teambit/aspect-loader": "1.0.
|
|
115
|
-
"@teambit/graphql": "1.0.
|
|
116
|
-
"@teambit/bundler": "1.0.
|
|
117
|
-
"@teambit/ui": "1.0.
|
|
118
|
-
"@teambit/command-bar": "1.0.
|
|
119
|
-
"@teambit/sidebar": "1.0.
|
|
120
|
-
"@teambit/pubsub": "1.0.
|
|
121
|
-
"@teambit/deprecation": "1.0.
|
|
105
|
+
"@teambit/component": "1.0.796",
|
|
106
|
+
"@teambit/dependency-resolver": "1.0.796",
|
|
107
|
+
"@teambit/envs": "1.0.796",
|
|
108
|
+
"@teambit/objects": "0.0.303",
|
|
109
|
+
"@teambit/scope": "1.0.796",
|
|
110
|
+
"@teambit/graph": "1.0.796",
|
|
111
|
+
"@teambit/isolator": "1.0.796",
|
|
112
|
+
"@teambit/component-tree": "1.0.796",
|
|
113
|
+
"@teambit/watcher": "1.0.796",
|
|
114
|
+
"@teambit/aspect-loader": "1.0.796",
|
|
115
|
+
"@teambit/graphql": "1.0.796",
|
|
116
|
+
"@teambit/bundler": "1.0.796",
|
|
117
|
+
"@teambit/ui": "1.0.796",
|
|
118
|
+
"@teambit/command-bar": "1.0.796",
|
|
119
|
+
"@teambit/sidebar": "1.0.796",
|
|
120
|
+
"@teambit/pubsub": "1.0.796",
|
|
121
|
+
"@teambit/deprecation": "1.0.796"
|
|
122
122
|
},
|
|
123
123
|
"devDependencies": {
|
|
124
124
|
"@types/lodash": "4.14.165",
|