From 1a94d1e19aa58bd3ea9a2fd8b98325101badd4eb Mon Sep 17 00:00:00 2001 From: Adam Bradley Date: Wed, 5 Aug 2020 11:00:43 -0500 Subject: [PATCH] feat(collection): remove deprecated collection parsing --- .../parse-collection-components.ts | 3 - .../parse-collection-deprecated.ts | 466 ------------------ src/declarations/stencil-private.ts | 84 ---- 3 files changed, 553 deletions(-) delete mode 100644 src/compiler/transformers/collections/parse-collection-deprecated.ts diff --git a/src/compiler/transformers/collections/parse-collection-components.ts b/src/compiler/transformers/collections/parse-collection-components.ts index e6252fa8b8f..11810af0e54 100644 --- a/src/compiler/transformers/collections/parse-collection-components.ts +++ b/src/compiler/transformers/collections/parse-collection-components.ts @@ -1,6 +1,5 @@ import * as d from '../../../declarations'; import { join } from 'path'; -import { parseComponentsDeprecated } from './parse-collection-deprecated'; import { updateModule } from '../static-to-meta/parse-static'; import ts from 'typescript'; @@ -12,8 +11,6 @@ export const parseCollectionComponents = ( collectionManifest: d.CollectionManifest, collection: d.CollectionCompilerMeta, ) => { - parseComponentsDeprecated(config, compilerCtx, collection, collectionDir, collectionManifest); - if (collectionManifest.entries) { collectionManifest.entries.forEach(entryPath => { const componentPath = join(collectionDir, entryPath); diff --git a/src/compiler/transformers/collections/parse-collection-deprecated.ts b/src/compiler/transformers/collections/parse-collection-deprecated.ts deleted file mode 100644 index 958169b2d41..00000000000 --- a/src/compiler/transformers/collections/parse-collection-deprecated.ts +++ /dev/null @@ -1,466 +0,0 @@ -import * as d from '../../../declarations'; -import { getModuleLegacy } from '../../build/compiler-ctx'; -import { dirname, join, relative } from 'path'; -import { normalizePath } from '@utils'; -import { setComponentBuildConditionals } from '../component-build-conditionals'; - -export const parseComponentsDeprecated = ( - config: d.Config, - compilerCtx: d.CompilerCtx, - collection: d.CollectionCompilerMeta, - collectionDir: string, - collectionManifest: d.CollectionManifest, -) => { - if (collectionManifest.components) { - collectionManifest.components.forEach(cmpData => { - parseComponentDeprecated(config, compilerCtx, collection, collectionDir, cmpData); - }); - } -}; - -function parseComponentDeprecated(config: d.Config, compilerCtx: d.CompilerCtx, collection: d.CollectionCompilerMeta, collectionDir: string, cmpData: d.ComponentDataDeprecated) { - const sourceFilePath = normalizePath(join(collectionDir, cmpData.componentPath)); - const moduleFile = getModuleLegacy(config, compilerCtx, sourceFilePath); - - moduleFile.isCollectionDependency = true; - moduleFile.isLegacy = true; - moduleFile.collectionName = collection.collectionName; - moduleFile.excludeFromCollection = excludeFromCollection(config, cmpData); - moduleFile.originalCollectionComponentPath = cmpData.componentPath; - moduleFile.jsFilePath = parseJsFilePath(collectionDir, cmpData); - - const cmpMeta: d.ComponentCompilerMeta = { - isLegacy: moduleFile.isLegacy, - excludeFromCollection: moduleFile.excludeFromCollection, - isCollectionDependency: moduleFile.isCollectionDependency, - - tagName: parseTag(cmpData), - componentClassName: parseComponentClass(cmpData), - virtualProperties: [], - docs: { - text: '', - tags: [], - }, - internal: false, - jsFilePath: moduleFile.jsFilePath, - sourceFilePath: '', - styleDocs: [], - assetsDirs: parseAssetsDir(collectionDir, cmpData), - styles: parseStyles(collectionDir, cmpData), - properties: parseProps(cmpData), - states: parseStates(cmpData), - listeners: parseListeners(cmpData), - methods: parseMethods(cmpData), - elementRef: parseHostElementMember(cmpData), - events: parseEvents(cmpData), - encapsulation: parseEncapsulation(cmpData), - shadowDelegatesFocus: null, - watchers: parseWatchers(cmpData), - legacyConnect: parseConnectProps(cmpData), - legacyContext: parseContextProps(cmpData), - - hasAttributeChangedCallbackFn: false, - hasComponentWillLoadFn: true, - hasComponentDidLoadFn: true, - hasComponentShouldUpdateFn: true, - hasComponentWillUpdateFn: true, - hasComponentDidUpdateFn: true, - hasComponentWillRenderFn: false, - hasComponentDidRenderFn: false, - hasComponentDidUnloadFn: true, - hasConnectedCallbackFn: false, - hasDisconnectedCallbackFn: false, - hasElement: false, - hasEvent: false, - hasLifecycle: false, - hasListener: false, - hasListenerTarget: false, - hasListenerTargetWindow: false, - hasListenerTargetDocument: false, - hasListenerTargetBody: false, - hasMember: false, - hasMethod: false, - hasMode: false, - hasAttribute: false, - hasProp: false, - hasPropNumber: false, - hasPropBoolean: false, - hasPropString: false, - hasPropMutable: false, - hasReflect: false, - hasRenderFn: false, - hasState: false, - hasStyle: false, - hasVdomAttribute: true, - hasVdomClass: true, - hasVdomFunctional: true, - hasVdomKey: true, - hasVdomListener: true, - hasVdomPropOrAttr: true, - hasVdomRef: true, - hasVdomRender: false, - hasVdomStyle: true, - hasVdomText: true, - hasVdomXlink: true, - hasWatchCallback: false, - isPlain: false, - htmlAttrNames: [], - htmlTagNames: [], - htmlParts: [], - isUpdateable: false, - potentialCmpRefs: [], - }; - setComponentBuildConditionals(cmpMeta); - - moduleFile.cmps = [cmpMeta]; - - // parseComponentDependencies(cmpData, cmpMeta); - // parseContextMember(cmpData, cmpMeta); - // parseConnectMember(cmpData, cmpMeta); - collection.moduleFiles.push(moduleFile); -} - -function excludeFromCollection(config: d.Config, cmpData: d.ComponentDataDeprecated) { - // this is a component from a collection dependency - // however, this project may also become a collection - // for example, "ionicons" is a dependency of "ionic" - // and "ionic" is it's own stand-alone collection, so within - // ionic's collection we want ionicons to just work - - // cmpData is a component from a collection dependency - // if this component is listed in this config's bundles - // then we'll need to ensure it also becomes apart of this collection - const isInBundle = - config.bundles && - config.bundles.some(bundle => { - return bundle.components && bundle.components.some(tag => tag === cmpData.tag); - }); - - // if it's not in the config bundle then it's safe to exclude - // this component from going into this build's collection - return !isInBundle; -} - -function parseTag(cmpData: d.ComponentDataDeprecated) { - return cmpData.tag; -} - -function parseJsFilePath(collectionDir: string, cmpData: d.ComponentDataDeprecated) { - // convert the path that's relative to the collection file - // into an absolute path to the component's js file path - if (typeof cmpData.componentPath !== 'string') { - throw new Error(`parseModuleJsFilePath, "componentPath" missing on cmpData: ${cmpData.tag}`); - } - return normalizePath(join(collectionDir, cmpData.componentPath)); -} - -// function parseComponentDependencies(cmpData: d.ComponentDataDeprecated, cmpMeta: d.ComponentCompilerMeta) { -// if (invalidArrayData(cmpData.dependencies)) { -// cmpMeta.dependencies = []; -// } else { -// cmpMeta.dependencies = cmpData.dependencies.sort(); -// } -// } - -function parseComponentClass(cmpData: d.ComponentDataDeprecated) { - return cmpData.componentClass; -} - -function parseStyles(collectionDir: string, cmpData: d.ComponentDataDeprecated) { - const stylesData = cmpData.styles; - - if (stylesData) { - const modeNames = Object.keys(stylesData); - - return modeNames.map(modeName => { - return parseStyle(collectionDir, cmpData, stylesData[modeName], modeName.toLowerCase()); - }); - } else { - return []; - } -} - -function parseAssetsDir(collectionDir: string, cmpData: d.ComponentDataDeprecated) { - if (invalidArrayData(cmpData.assetPaths)) { - return []; - } - - return cmpData.assetPaths - .map(assetsPath => { - const assetsMeta: d.AssetsMeta = { - absolutePath: normalizePath(join(collectionDir, assetsPath)), - cmpRelativePath: normalizePath(relative(dirname(cmpData.componentPath), assetsPath)), - originalComponentPath: normalizePath(assetsPath), - }; - return assetsMeta; - }) - .sort((a, b) => { - if (a.cmpRelativePath < b.cmpRelativePath) return -1; - if (a.cmpRelativePath > b.cmpRelativePath) return 1; - return 0; - }); -} - -function parseStyle(collectionDir: string, cmpData: d.ComponentDataDeprecated, modeStyleData: d.StyleDataDeprecated, modeName: string) { - const modeStyle: d.StyleCompiler = { - modeName: modeName, - styleId: cmpData.tag, - styleStr: modeStyleData.style, - styleIdentifier: null, - externalStyles: [], - compiledStyleText: null, - compiledStyleTextScoped: null, - compiledStyleTextScopedCommented: null, - }; - - if (Array.isArray(modeStyleData.stylePaths)) { - modeStyleData.stylePaths.forEach(stylePath => { - const externalStyle: d.ExternalStyleCompiler = { - absolutePath: normalizePath(join(collectionDir, stylePath)), - relativePath: normalizePath(relative(dirname(cmpData.componentPath), stylePath)), - originalComponentPath: stylePath, - }; - - modeStyle.externalStyles.push(externalStyle); - }); - } - - return modeStyle; -} - -function parseProps(cmpData: d.ComponentDataDeprecated) { - const propsData = cmpData.props; - - if (invalidArrayData(propsData)) { - return []; - } - - return propsData.map(propData => { - const type = convertType(propData.type); - const prop: d.ComponentCompilerProperty = { - name: propData.name, - attribute: typeof propData.attr === 'string' ? propData.attr : null, - mutable: !!propData.mutable, - optional: true, - required: false, - reflect: !!propData.reflectToAttr, - type, - internal: false, - complexType: { - original: type === 'unknown' ? 'any' : type, - resolved: type, - references: {}, - }, - docs: { - text: '', - tags: [], - }, - }; - return prop; - }); -} - -function parseConnectProps(cmpData: d.ComponentDataDeprecated) { - const connectData = cmpData.connect; - - if (invalidArrayData(connectData)) { - return []; - } - - return connectData.map(propData => { - const prop: d.ComponentCompilerLegacyConnect = { - name: propData.name, - connect: propData.tag, - }; - return prop; - }); -} - -function parseContextProps(cmpData: d.ComponentDataDeprecated): d.ComponentCompilerLegacyContext[] { - const contextData = cmpData.context; - - if (invalidArrayData(contextData)) { - return []; - } - - return contextData.map(propData => { - return { - name: propData.name, - context: propData.id, - }; - }); -} - -function parseStates(cmpData: d.ComponentDataDeprecated) { - if (invalidArrayData(cmpData.states)) { - return []; - } - - return cmpData.states.map(state => { - return { - name: state.name, - }; - }); -} - -function parseWatchers(cmpData: d.ComponentDataDeprecated) { - if (invalidArrayData(cmpData.props)) { - return []; - } - const watchers: d.ComponentCompilerWatch[] = []; - - cmpData.props - .filter(prop => prop.watch && prop.watch.length > 0) - .forEach(prop => { - prop.watch.forEach(watch => { - watchers.push({ - propName: prop.name, - methodName: watch, - }); - }); - }); - return watchers; -} - -function parseListeners(cmpData: d.ComponentDataDeprecated) { - const listenersData = cmpData.listeners; - - if (invalidArrayData(listenersData)) { - return []; - } - - return listenersData.map(listenerData => { - const listener: d.ComponentCompilerListener = { - name: listenerData.event, - method: listenerData.method, - target: undefined, // TODO - passive: listenerData.passive !== false, - capture: listenerData.capture !== false, - }; - return listener; - }); -} - -function parseMethods(cmpData: d.ComponentDataDeprecated) { - if (invalidArrayData(cmpData.methods)) { - return []; - } - - return cmpData.methods.map(methodData => { - const method: d.ComponentCompilerMethod = { - name: methodData.name, - internal: false, - complexType: { - signature: '(...args: any[]) => Promise', - parameters: [], - return: 'Promise', - references: {}, - }, - docs: { - text: '', - tags: [], - }, - }; - return method; - }); -} - -function convertType(type: string): d.ComponentCompilerPropertyType { - switch (type) { - case 'String': - return 'string'; - case 'Any': - return 'any'; - case 'Number': - return 'number'; - case 'Boolean': - return 'boolean'; - default: - return 'unknown'; - } -} - -// function parseContextMember(cmpData: d.ComponentDataDeprecated, cmpMeta: d.ComponentCompilerMeta) { -// if (invalidArrayData(cmpData.context)) { -// return; -// } - -// cmpData.context.forEach(methodData => { -// if (methodData.id) { -// cmpMeta.membersMeta = cmpMeta.membersMeta || {}; - -// cmpMeta.membersMeta[methodData.name] = { -// memberType: MEMBER_FLAGS.PropContext, -// ctrlId: methodData.id -// }; -// } -// }); -// } - -// function parseConnectMember(cmpData: d.ComponentDataDeprecated, cmpMeta: d.ComponentCompilerMeta) { -// if (invalidArrayData(cmpData.connect)) { -// return; -// } - -// cmpData.connect.forEach(methodData => { -// if (methodData.tag) { -// cmpMeta.membersMeta = cmpMeta.membersMeta || {}; - -// cmpMeta.membersMeta[methodData.name] = { -// memberType: MEMBER_FLAGS.PropConnect, -// ctrlId: methodData.tag -// }; -// } -// }); -// } - -function parseHostElementMember(cmpData: d.ComponentDataDeprecated) { - if (!cmpData.hostElement) { - return undefined; - } - - return cmpData.hostElement.name; -} - -function parseEvents(cmpData: d.ComponentDataDeprecated) { - const eventsData = cmpData.events; - - if (invalidArrayData(eventsData)) { - return []; - } - - return eventsData.map(eventData => { - const event: d.ComponentCompilerEvent = { - name: eventData.event, - method: eventData.method ? eventData.method : eventData.event, - bubbles: eventData.bubbles !== false, - cancelable: eventData.cancelable !== false, - composed: eventData.composed !== false, - internal: false, - docs: { - text: '', - tags: [], - }, - complexType: { - original: 'any', - resolved: 'any', - references: {}, - }, - }; - return event; - }); -} - -function parseEncapsulation(cmpData: d.ComponentDataDeprecated) { - if (cmpData.shadow === true) { - return 'shadow'; - } else if (cmpData.scoped === true) { - return 'scoped'; - } else { - return 'none'; - } -} - -function invalidArrayData(arr: any[]) { - return !arr || !Array.isArray(arr) || arr.length === 0; -} diff --git a/src/declarations/stencil-private.ts b/src/declarations/stencil-private.ts index 7f4e9106aed..b0bc0c2bd15 100644 --- a/src/declarations/stencil-private.ts +++ b/src/declarations/stencil-private.ts @@ -399,11 +399,6 @@ export interface CollectionManifest { global?: string; compiler?: CollectionCompilerVersion; bundles?: CollectionBundleManifest[]; - - /** - * DEPRECATED - */ - components?: ComponentDataDeprecated[]; } export type CollectionComponentEntryPath = string; @@ -417,85 +412,6 @@ export interface CollectionDependencyManifest { tags: string[]; } -/**** DEPRECATED *****/ -export interface ComponentDataDeprecated { - tag?: string; - componentPath?: string; - componentClass?: string; - dependencies?: string[]; - styles?: StylesDataDeprecated; - props?: PropManifestDeprecated[]; - states?: StateManifestDeprecated[]; - listeners?: ListenerManifestDeprecated[]; - methods?: MethodManifestDeprecated[]; - events?: EventManifestDeprecated[]; - connect?: ConnectManifestDeprecated[]; - context?: ContextManifestDeprecated[]; - hostElement?: HostElementManifestDeprecated; - host?: any; - assetPaths?: string[]; - slot?: 'hasSlots' | 'hasNamedSlots'; - shadow?: boolean; - scoped?: boolean; - priority?: 'low'; -} - -export interface StylesDataDeprecated { - [modeName: string]: StyleDataDeprecated; -} - -export interface StyleDataDeprecated { - stylePaths?: string[]; - style?: string; -} - -export interface PropManifestDeprecated { - name?: string; - type?: 'Boolean' | 'Number' | 'String' | 'Any'; - mutable?: boolean; - attr?: string; - reflectToAttr?: boolean; - watch?: string[]; -} - -export interface StateManifestDeprecated { - name: string; -} - -export interface ListenerManifestDeprecated { - event: string; - method: string; - capture?: boolean; - passive?: boolean; - enabled?: boolean; -} - -export interface MethodManifestDeprecated { - name: string; -} - -export interface EventManifestDeprecated { - event: string; - method?: string; - bubbles?: boolean; - cancelable?: boolean; - composed?: boolean; -} - -export interface ConnectManifestDeprecated { - name: string; - tag?: string; -} - -export interface ContextManifestDeprecated { - name: string; - id?: string; -} - -export interface HostElementManifestDeprecated { - name: string; -} - /** OLD WAY */ export interface Collection { collectionName?: string;