From 6fe23623d3cec80a42028ff03b4435c0074640c4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alex=20S=C3=A1nchez?= Date: Tue, 25 Jun 2024 16:10:36 +0200 Subject: [PATCH 1/5] refactor --- .../{ => libraries}/ComponentLibrary.ts | 0 plugin-src/{ => libraries}/ImageLibrary.ts | 0 .../{ => libraries}/OverridesLibrary.ts | 0 .../{ => libraries}/RemoteComponentLibrary.ts | 0 plugin-src/{ => libraries}/StyleLibrary.ts | 0 plugin-src/{ => libraries}/TextLibrary.ts | 0 plugin-src/libraries/index.ts | 6 + plugin-src/processors/index.ts | 4 + plugin-src/processors/processImages.ts | 40 ++++ plugin-src/processors/processPages.ts | 50 +++++ plugin-src/processors/processPaintStyles.ts | 53 +++++ plugin-src/processors/processTextStyles.ts | 53 +++++ .../partials/transformOverrides.ts | 2 +- .../transformers/transformComponentNode.ts | 2 +- .../transformers/transformDocumentNode.ts | 198 ++---------------- .../transformers/transformInstanceNode.ts | 3 +- .../translators/fills/translateFills.ts | 2 +- .../translators/fills/translateImageFill.ts | 2 +- .../translators/text/translateTextSegments.ts | 2 +- plugin-src/translators/translateChildren.ts | 2 +- ui-src/parser/creators/buildFile.ts | 3 +- ui-src/parser/creators/createColorsLibrary.ts | 2 +- ui-src/parser/creators/createComponent.ts | 2 +- .../creators/createComponentsLibrary.ts | 2 +- ui-src/parser/creators/createText.ts | 2 +- ui-src/parser/creators/createTextLibrary.ts | 2 +- ui-src/parser/creators/symbols/symbolFills.ts | 3 +- ui-src/parser/index.ts | 1 - ui-src/parser/{ => libraries}/IdLibrary.ts | 0 ui-src/parser/libraries/index.ts | 4 +- ui-src/parser/parse.ts | 13 +- ui-src/parser/parseFigmaId.ts | 3 +- ui-src/types/penpotDocument.ts | 4 +- 33 files changed, 248 insertions(+), 212 deletions(-) rename plugin-src/{ => libraries}/ComponentLibrary.ts (100%) rename plugin-src/{ => libraries}/ImageLibrary.ts (100%) rename plugin-src/{ => libraries}/OverridesLibrary.ts (100%) rename plugin-src/{ => libraries}/RemoteComponentLibrary.ts (100%) rename plugin-src/{ => libraries}/StyleLibrary.ts (100%) rename plugin-src/{ => libraries}/TextLibrary.ts (100%) create mode 100644 plugin-src/libraries/index.ts create mode 100644 plugin-src/processors/index.ts create mode 100644 plugin-src/processors/processImages.ts create mode 100644 plugin-src/processors/processPages.ts create mode 100644 plugin-src/processors/processPaintStyles.ts create mode 100644 plugin-src/processors/processTextStyles.ts rename ui-src/parser/{ => libraries}/IdLibrary.ts (100%) diff --git a/plugin-src/ComponentLibrary.ts b/plugin-src/libraries/ComponentLibrary.ts similarity index 100% rename from plugin-src/ComponentLibrary.ts rename to plugin-src/libraries/ComponentLibrary.ts diff --git a/plugin-src/ImageLibrary.ts b/plugin-src/libraries/ImageLibrary.ts similarity index 100% rename from plugin-src/ImageLibrary.ts rename to plugin-src/libraries/ImageLibrary.ts diff --git a/plugin-src/OverridesLibrary.ts b/plugin-src/libraries/OverridesLibrary.ts similarity index 100% rename from plugin-src/OverridesLibrary.ts rename to plugin-src/libraries/OverridesLibrary.ts diff --git a/plugin-src/RemoteComponentLibrary.ts b/plugin-src/libraries/RemoteComponentLibrary.ts similarity index 100% rename from plugin-src/RemoteComponentLibrary.ts rename to plugin-src/libraries/RemoteComponentLibrary.ts diff --git a/plugin-src/StyleLibrary.ts b/plugin-src/libraries/StyleLibrary.ts similarity index 100% rename from plugin-src/StyleLibrary.ts rename to plugin-src/libraries/StyleLibrary.ts diff --git a/plugin-src/TextLibrary.ts b/plugin-src/libraries/TextLibrary.ts similarity index 100% rename from plugin-src/TextLibrary.ts rename to plugin-src/libraries/TextLibrary.ts diff --git a/plugin-src/libraries/index.ts b/plugin-src/libraries/index.ts new file mode 100644 index 00000000..9a6df247 --- /dev/null +++ b/plugin-src/libraries/index.ts @@ -0,0 +1,6 @@ +export * from './ComponentLibrary'; +export * from './ImageLibrary'; +export * from './OverridesLibrary'; +export * from './RemoteComponentLibrary'; +export * from './StyleLibrary'; +export * from './TextLibrary'; diff --git a/plugin-src/processors/index.ts b/plugin-src/processors/index.ts new file mode 100644 index 00000000..dcbdeacf --- /dev/null +++ b/plugin-src/processors/index.ts @@ -0,0 +1,4 @@ +export * from './processImages'; +export * from './processPaintStyles'; +export * from './processTextStyles'; +export * from './processPages'; diff --git a/plugin-src/processors/processImages.ts b/plugin-src/processors/processImages.ts new file mode 100644 index 00000000..eb73126c --- /dev/null +++ b/plugin-src/processors/processImages.ts @@ -0,0 +1,40 @@ +import { imagesLibrary } from '@plugin/libraries'; +import { sleep } from '@plugin/utils'; + +export const processImages = async (): Promise> => { + const imageToDownload = Object.entries(imagesLibrary.all()); + const images: Record = {}; + + if (imageToDownload.length === 0) return images; + + let currentImage = 1; + + figma.ui.postMessage({ + type: 'PROGRESS_TOTAL_ITEMS', + data: imageToDownload.length + }); + + figma.ui.postMessage({ + type: 'PROGRESS_STEP', + data: 'images' + }); + + for (const [key, image] of imageToDownload) { + const bytes = await image?.getBytesAsync(); + + if (bytes) { + images[key] = bytes; + } + + figma.ui.postMessage({ + type: 'PROGRESS_PROCESSED_ITEMS', + data: currentImage++ + }); + + await sleep(0); + } + + await sleep(20); + + return images; +}; diff --git a/plugin-src/processors/processPages.ts b/plugin-src/processors/processPages.ts new file mode 100644 index 00000000..2789d9d4 --- /dev/null +++ b/plugin-src/processors/processPages.ts @@ -0,0 +1,50 @@ +import { remoteComponentLibrary } from '@plugin/libraries'; +import { transformPageNode } from '@plugin/transformers'; +import { translateRemoteChildren } from '@plugin/translators'; +import { sleep } from '@plugin/utils'; + +import { PenpotPage } from '@ui/lib/types/penpotPage'; + +export const processPages = async (node: DocumentNode): Promise => { + const children = await processLocalDocument(node); + const remoteComponents = await processRemoteComponents(); + if (remoteComponents) { + children.push(remoteComponents); + } + + return children; +}; + +const processRemoteComponents = async (): Promise => { + if (remoteComponentLibrary.remaining() > 0) { + return { + name: 'External Components', + children: await translateRemoteChildren() + }; + } +}; + +const processLocalDocument = async (node: DocumentNode): Promise => { + const children = []; + let currentPage = 1; + + figma.ui.postMessage({ + type: 'PROGRESS_TOTAL_ITEMS', + data: node.children.length + }); + + for (const page of node.children) { + await page.loadAsync(); + + children.push(await transformPageNode(page)); + + figma.ui.postMessage({ + type: 'PROGRESS_PROCESSED_ITEMS', + data: currentPage++ + }); + + await sleep(0); + } + + return children; +}; diff --git a/plugin-src/processors/processPaintStyles.ts b/plugin-src/processors/processPaintStyles.ts new file mode 100644 index 00000000..75660e39 --- /dev/null +++ b/plugin-src/processors/processPaintStyles.ts @@ -0,0 +1,53 @@ +import { styleLibrary } from '@plugin/libraries'; +import { translatePaintStyle } from '@plugin/translators/styles'; +import { sleep } from '@plugin/utils'; + +import { FillStyle } from '@ui/lib/types/utils/fill'; + +const isPaintStyle = (style: BaseStyle): style is PaintStyle => { + return style.type === 'PAINT'; +}; + +export const registerPaintStyles = async () => { + const localPaintStyles = await figma.getLocalPaintStylesAsync(); + localPaintStyles.forEach(style => { + styleLibrary.register(style.id, style); + }); +}; + +export const processPaintStyles = async (): Promise> => { + const stylesToFetch = Object.entries(styleLibrary.all()); + const styles: Record = {}; + + if (stylesToFetch.length === 0) return styles; + + let currentStyle = 1; + + figma.ui.postMessage({ + type: 'PROGRESS_TOTAL_ITEMS', + data: stylesToFetch.length + }); + + figma.ui.postMessage({ + type: 'PROGRESS_STEP', + data: 'fills' + }); + + for (const [styleId, paintStyle] of stylesToFetch) { + const figmaStyle = paintStyle ?? (await figma.getStyleByIdAsync(styleId)); + if (figmaStyle && isPaintStyle(figmaStyle)) { + styles[styleId] = translatePaintStyle(figmaStyle); + } + + figma.ui.postMessage({ + type: 'PROGRESS_PROCESSED_ITEMS', + data: currentStyle++ + }); + + await sleep(0); + } + + await sleep(20); + + return styles; +}; diff --git a/plugin-src/processors/processTextStyles.ts b/plugin-src/processors/processTextStyles.ts new file mode 100644 index 00000000..9394f3bb --- /dev/null +++ b/plugin-src/processors/processTextStyles.ts @@ -0,0 +1,53 @@ +import { textLibrary } from '@plugin/libraries'; +import { translateTextStyle } from '@plugin/translators/styles'; +import { sleep } from '@plugin/utils'; + +import { TypographyStyle } from '@ui/lib/types/shapes/textShape'; + +const isTextStyle = (style: BaseStyle): style is TextStyle => { + return style.type === 'TEXT'; +}; + +export const registerTextStyles = async () => { + const localTextStyles = await figma.getLocalTextStylesAsync(); + localTextStyles.forEach(style => { + textLibrary.register(style.id, style); + }); +}; + +export const processTextStyles = async (): Promise> => { + const stylesToFetch = Object.entries(textLibrary.all()); + const styles: Record = {}; + + if (stylesToFetch.length === 0) return styles; + + let currentStyle = 1; + + figma.ui.postMessage({ + type: 'PROGRESS_TOTAL_ITEMS', + data: stylesToFetch.length + }); + + figma.ui.postMessage({ + type: 'PROGRESS_STEP', + data: 'typographies' + }); + + for (const [styleId, style] of stylesToFetch) { + const figmaStyle = style ?? (await figma.getStyleByIdAsync(styleId)); + if (figmaStyle && isTextStyle(figmaStyle)) { + styles[styleId] = translateTextStyle(figmaStyle); + } + + figma.ui.postMessage({ + type: 'PROGRESS_PROCESSED_ITEMS', + data: currentStyle++ + }); + + await sleep(0); + } + + await sleep(20); + + return styles; +}; diff --git a/plugin-src/transformers/partials/transformOverrides.ts b/plugin-src/transformers/partials/transformOverrides.ts index dd9cbd09..fc09a495 100644 --- a/plugin-src/transformers/partials/transformOverrides.ts +++ b/plugin-src/transformers/partials/transformOverrides.ts @@ -1,4 +1,4 @@ -import { overridesLibrary } from '@plugin/OverridesLibrary'; +import { overridesLibrary } from '@plugin/libraries'; import { syncAttributes } from '@plugin/utils/syncAttributes'; import { SyncGroups } from '@ui/lib/types/utils/syncGroups'; diff --git a/plugin-src/transformers/transformComponentNode.ts b/plugin-src/transformers/transformComponentNode.ts index 311d872e..07b90407 100644 --- a/plugin-src/transformers/transformComponentNode.ts +++ b/plugin-src/transformers/transformComponentNode.ts @@ -1,4 +1,4 @@ -import { componentsLibrary } from '@plugin/ComponentLibrary'; +import { componentsLibrary } from '@plugin/libraries'; import { transformAutoLayout, transformBlend, diff --git a/plugin-src/transformers/transformDocumentNode.ts b/plugin-src/transformers/transformDocumentNode.ts index d8aff132..5ecc51e9 100644 --- a/plugin-src/transformers/transformDocumentNode.ts +++ b/plugin-src/transformers/transformDocumentNode.ts @@ -1,196 +1,30 @@ -import { componentsLibrary } from '@plugin/ComponentLibrary'; -import { imagesLibrary } from '@plugin/ImageLibrary'; -import { remoteComponentLibrary } from '@plugin/RemoteComponentLibrary'; -import { styleLibrary } from '@plugin/StyleLibrary'; -import { textLibrary } from '@plugin/TextLibrary'; -import { translateRemoteChildren } from '@plugin/translators'; -import { translatePaintStyle, translateTextStyle } from '@plugin/translators/styles'; -import { sleep } from '@plugin/utils'; +import { componentsLibrary } from '@plugin/libraries'; +import { + processImages, + processPages, + processPaintStyles, + processTextStyles, + registerPaintStyles, + registerTextStyles +} from '@plugin/processors'; -import { PenpotPage } from '@ui/lib/types/penpotPage'; -import { TypographyStyle } from '@ui/lib/types/shapes/textShape'; -import { FillStyle } from '@ui/lib/types/utils/fill'; import { PenpotDocument } from '@ui/types'; -import { transformPageNode } from '.'; - -const isPaintStyle = (style: BaseStyle): style is PaintStyle => { - return style.type === 'PAINT'; -}; - -const isTextStyle = (style: BaseStyle): style is TextStyle => { - return style.type === 'TEXT'; -}; - -const downloadImages = async (): Promise> => { - const imageToDownload = Object.entries(imagesLibrary.all()); - const images: Record = {}; - - if (imageToDownload.length === 0) return images; - - let currentImage = 1; - - figma.ui.postMessage({ - type: 'PROGRESS_TOTAL_ITEMS', - data: imageToDownload.length - }); - - figma.ui.postMessage({ - type: 'PROGRESS_STEP', - data: 'images' - }); - - for (const [key, image] of imageToDownload) { - const bytes = await image?.getBytesAsync(); - - if (bytes) { - images[key] = bytes; - } - - figma.ui.postMessage({ - type: 'PROGRESS_PROCESSED_ITEMS', - data: currentImage++ - }); - - await sleep(0); - } - - await sleep(20); - - return images; -}; - -const getFillStyles = async (): Promise> => { - const stylesToFetch = Object.entries(styleLibrary.all()); - const styles: Record = {}; - - if (stylesToFetch.length === 0) return styles; - - let currentStyle = 1; - - figma.ui.postMessage({ - type: 'PROGRESS_TOTAL_ITEMS', - data: stylesToFetch.length - }); - - figma.ui.postMessage({ - type: 'PROGRESS_STEP', - data: 'fills' - }); - - for (const [styleId, paintStyle] of stylesToFetch) { - const figmaStyle = paintStyle ?? (await figma.getStyleByIdAsync(styleId)); - if (figmaStyle && isPaintStyle(figmaStyle)) { - styles[styleId] = translatePaintStyle(figmaStyle); - } - - figma.ui.postMessage({ - type: 'PROGRESS_PROCESSED_ITEMS', - data: currentStyle++ - }); - - await sleep(0); - } - - await sleep(20); - - return styles; -}; - -const getTextStyles = async (): Promise> => { - const stylesToFetch = Object.entries(textLibrary.all()); - const styles: Record = {}; - - if (stylesToFetch.length === 0) return styles; - - let currentStyle = 1; - - figma.ui.postMessage({ - type: 'PROGRESS_TOTAL_ITEMS', - data: stylesToFetch.length - }); - - figma.ui.postMessage({ - type: 'PROGRESS_STEP', - data: 'typographies' - }); - - for (const [styleId, style] of stylesToFetch) { - const figmaStyle = style ?? (await figma.getStyleByIdAsync(styleId)); - if (figmaStyle && isTextStyle(figmaStyle)) { - styles[styleId] = translateTextStyle(figmaStyle); - } - - figma.ui.postMessage({ - type: 'PROGRESS_PROCESSED_ITEMS', - data: currentStyle++ - }); - - await sleep(0); - } - - await sleep(20); - - return styles; -}; - -const processPages = async (node: DocumentNode): Promise => { - const children = []; - let currentPage = 1; - - figma.ui.postMessage({ - type: 'PROGRESS_TOTAL_ITEMS', - data: node.children.length - }); - - for (const page of node.children) { - await page.loadAsync(); - - children.push(await transformPageNode(page)); - - figma.ui.postMessage({ - type: 'PROGRESS_PROCESSED_ITEMS', - data: currentPage++ - }); - - await sleep(0); - } - - return children; -}; - export const transformDocumentNode = async (node: DocumentNode): Promise => { - const localPaintStyles = await figma.getLocalPaintStylesAsync(); - localPaintStyles.forEach(style => { - styleLibrary.register(style.id, style); - }); - - const localTextStyles = await figma.getLocalTextStylesAsync(); - localTextStyles.forEach(style => { - textLibrary.register(style.id, style); - }); + await registerPaintStyles(); + await registerTextStyles(); const children = await processPages(node); - - if (remoteComponentLibrary.remaining() > 0) { - children.push({ - name: 'External Components', - children: await translateRemoteChildren() - }); - } - - const styles = await getFillStyles(); - - const images = await downloadImages(); - - const typographies = await getTextStyles(); + const paintStyles = await processPaintStyles(); + const images = await processImages(); + const textStyles = await processTextStyles(); return { name: node.name, children, components: componentsLibrary.all(), images, - styles, - typographies + paintStyles, + textStyles }; }; diff --git a/plugin-src/transformers/transformInstanceNode.ts b/plugin-src/transformers/transformInstanceNode.ts index 2843d5c2..a04b93ed 100644 --- a/plugin-src/transformers/transformInstanceNode.ts +++ b/plugin-src/transformers/transformInstanceNode.ts @@ -1,5 +1,4 @@ -import { overridesLibrary } from '@plugin/OverridesLibrary'; -import { remoteComponentLibrary } from '@plugin/RemoteComponentLibrary'; +import { overridesLibrary, remoteComponentLibrary } from '@plugin/libraries'; import { transformAutoLayout, transformBlend, diff --git a/plugin-src/translators/fills/translateFills.ts b/plugin-src/translators/fills/translateFills.ts index 1ab56e4a..4c1beb29 100644 --- a/plugin-src/translators/fills/translateFills.ts +++ b/plugin-src/translators/fills/translateFills.ts @@ -1,4 +1,4 @@ -import { styleLibrary } from '@plugin/StyleLibrary'; +import { styleLibrary } from '@plugin/libraries'; import { translateImageFill, translateSolidFill } from '@plugin/translators/fills'; import { translateGradientLinearFill, diff --git a/plugin-src/translators/fills/translateImageFill.ts b/plugin-src/translators/fills/translateImageFill.ts index 43f03006..4a097d1d 100644 --- a/plugin-src/translators/fills/translateImageFill.ts +++ b/plugin-src/translators/fills/translateImageFill.ts @@ -1,4 +1,4 @@ -import { imagesLibrary } from '@plugin/ImageLibrary'; +import { imagesLibrary } from '@plugin/libraries'; import { Fill } from '@ui/lib/types/utils/fill'; import { PartialImageColor } from '@ui/lib/types/utils/imageColor'; diff --git a/plugin-src/translators/text/translateTextSegments.ts b/plugin-src/translators/text/translateTextSegments.ts index fee84cc1..30b415cd 100644 --- a/plugin-src/translators/text/translateTextSegments.ts +++ b/plugin-src/translators/text/translateTextSegments.ts @@ -1,4 +1,4 @@ -import { textLibrary } from '@plugin/TextLibrary'; +import { textLibrary } from '@plugin/libraries'; import { transformFills } from '@plugin/transformers/partials'; import { translateFontName } from '@plugin/translators/text/font'; import { TextSegment, translateParagraphProperties } from '@plugin/translators/text/paragraph'; diff --git a/plugin-src/translators/translateChildren.ts b/plugin-src/translators/translateChildren.ts index 43e103ca..2a92042e 100644 --- a/plugin-src/translators/translateChildren.ts +++ b/plugin-src/translators/translateChildren.ts @@ -1,4 +1,4 @@ -import { remoteComponentLibrary } from '@plugin/RemoteComponentLibrary'; +import { remoteComponentLibrary } from '@plugin/libraries'; import { transformGroupNodeLike, transformSceneNode } from '@plugin/transformers'; import { transformMaskFigmaIds } from '@plugin/transformers/partials'; import { sleep } from '@plugin/utils'; diff --git a/ui-src/parser/creators/buildFile.ts b/ui-src/parser/creators/buildFile.ts index a259f429..de348bbd 100644 --- a/ui-src/parser/creators/buildFile.ts +++ b/ui-src/parser/creators/buildFile.ts @@ -3,14 +3,13 @@ import { sleep } from '@plugin/utils/sleep'; import { sendMessage } from '@ui/context'; import { PenpotFile } from '@ui/lib/types/penpotFile'; import { PenpotPage } from '@ui/lib/types/penpotPage'; -import { idLibrary } from '@ui/parser'; import { createColorsLibrary, createComponentsLibrary, createPage, createTextLibrary } from '@ui/parser/creators'; -import { uiComponents } from '@ui/parser/libraries'; +import { idLibrary, uiComponents } from '@ui/parser/libraries'; export const buildFile = async (file: PenpotFile, children: PenpotPage[]) => { let pagesBuilt = 1; diff --git a/ui-src/parser/creators/createColorsLibrary.ts b/ui-src/parser/creators/createColorsLibrary.ts index 25c96ad4..bf37b8ca 100644 --- a/ui-src/parser/creators/createColorsLibrary.ts +++ b/ui-src/parser/creators/createColorsLibrary.ts @@ -2,7 +2,7 @@ import { sleep } from '@plugin/utils/sleep'; import { sendMessage } from '@ui/context'; import { PenpotFile } from '@ui/lib/types/penpotFile'; -import { uiColorLibraries } from '@ui/parser/libraries/UiColorLibraries'; +import { uiColorLibraries } from '@ui/parser/libraries'; export const createColorsLibrary = async (file: PenpotFile) => { let librariesBuilt = 1; diff --git a/ui-src/parser/creators/createComponent.ts b/ui-src/parser/creators/createComponent.ts index 47293f59..4ab742bf 100644 --- a/ui-src/parser/creators/createComponent.ts +++ b/ui-src/parser/creators/createComponent.ts @@ -1,4 +1,4 @@ -import { componentsLibrary } from '@plugin/ComponentLibrary'; +import { componentsLibrary } from '@plugin/libraries/ComponentLibrary'; import { PenpotFile } from '@ui/lib/types/penpotFile'; import { uiComponents } from '@ui/parser/libraries'; diff --git a/ui-src/parser/creators/createComponentsLibrary.ts b/ui-src/parser/creators/createComponentsLibrary.ts index a00837f2..c38c64e9 100644 --- a/ui-src/parser/creators/createComponentsLibrary.ts +++ b/ui-src/parser/creators/createComponentsLibrary.ts @@ -1,4 +1,4 @@ -import { componentsLibrary } from '@plugin/ComponentLibrary'; +import { componentsLibrary } from '@plugin/libraries/ComponentLibrary'; import { sleep } from '@plugin/utils/sleep'; import { sendMessage } from '@ui/context'; diff --git a/ui-src/parser/creators/createText.ts b/ui-src/parser/creators/createText.ts index e71117dc..9d2a676f 100644 --- a/ui-src/parser/creators/createText.ts +++ b/ui-src/parser/creators/createText.ts @@ -2,7 +2,7 @@ import { PenpotFile } from '@ui/lib/types/penpotFile'; import { Paragraph, TextContent, TextNode, TextShape } from '@ui/lib/types/shapes/textShape'; import { parseFigmaId } from '@ui/parser'; import { symbolFills, symbolStrokes } from '@ui/parser/creators/symbols'; -import { uiTextLibraries } from '@ui/parser/libraries/UiTextLibraries'; +import { uiTextLibraries } from '@ui/parser/libraries'; export const createText = ( file: PenpotFile, diff --git a/ui-src/parser/creators/createTextLibrary.ts b/ui-src/parser/creators/createTextLibrary.ts index b9fa30f8..ae1b3399 100644 --- a/ui-src/parser/creators/createTextLibrary.ts +++ b/ui-src/parser/creators/createTextLibrary.ts @@ -2,7 +2,7 @@ import { sleep } from '@plugin/utils/sleep'; import { sendMessage } from '@ui/context'; import { PenpotFile } from '@ui/lib/types/penpotFile'; -import { uiTextLibraries } from '@ui/parser/libraries/UiTextLibraries'; +import { uiTextLibraries } from '@ui/parser/libraries'; export const createTextLibrary = async (file: PenpotFile) => { let librariesBuilt = 1; diff --git a/ui-src/parser/creators/symbols/symbolFills.ts b/ui-src/parser/creators/symbols/symbolFills.ts index 46b26ec5..1edd8f7e 100644 --- a/ui-src/parser/creators/symbols/symbolFills.ts +++ b/ui-src/parser/creators/symbols/symbolFills.ts @@ -1,7 +1,6 @@ import { Fill } from '@ui/lib/types/utils/fill'; import { ImageColor, PartialImageColor } from '@ui/lib/types/utils/imageColor'; -import { uiImages } from '@ui/parser/libraries'; -import { uiColorLibraries } from '@ui/parser/libraries/UiColorLibraries'; +import { uiColorLibraries, uiImages } from '@ui/parser/libraries'; export const symbolFills = (fillStyleId?: string, fills?: Fill[]): Fill[] | undefined => { const nodeFills = fillStyleId ? uiColorLibraries.get(fillStyleId)?.fills : fills; diff --git a/ui-src/parser/index.ts b/ui-src/parser/index.ts index 6d8e38fb..d23bd25d 100644 --- a/ui-src/parser/index.ts +++ b/ui-src/parser/index.ts @@ -1,4 +1,3 @@ -export * from './IdLibrary'; export * from './parse'; export * from './parseImage'; export * from './parseFigmaId'; diff --git a/ui-src/parser/IdLibrary.ts b/ui-src/parser/libraries/IdLibrary.ts similarity index 100% rename from ui-src/parser/IdLibrary.ts rename to ui-src/parser/libraries/IdLibrary.ts diff --git a/ui-src/parser/libraries/index.ts b/ui-src/parser/libraries/index.ts index 588c5f31..6dc12e89 100644 --- a/ui-src/parser/libraries/index.ts +++ b/ui-src/parser/libraries/index.ts @@ -1,3 +1,5 @@ +export * from './IdLibrary'; +export * from './UiColorLibraries'; export * from './UiComponents'; export * from './UiImages'; -export * from './UiColorLibraries'; +export * from './UiTextLibraries'; diff --git a/ui-src/parser/parse.ts b/ui-src/parser/parse.ts index 9ccf5076..fcbffdf3 100644 --- a/ui-src/parser/parse.ts +++ b/ui-src/parser/parse.ts @@ -1,4 +1,4 @@ -import { componentsLibrary } from '@plugin/ComponentLibrary'; +import { componentsLibrary } from '@plugin/libraries/ComponentLibrary'; // @TODO: Direct import on purpose, to avoid problems with the tsc linting import { sleep } from '@plugin/utils/sleep'; @@ -8,8 +8,7 @@ import { PenpotFile } from '@ui/lib/types/penpotFile'; import { TypographyStyle } from '@ui/lib/types/shapes/textShape'; import { FillStyle } from '@ui/lib/types/utils/fill'; import { buildFile } from '@ui/parser/creators'; -import { uiColorLibraries, uiImages } from '@ui/parser/libraries'; -import { uiTextLibraries } from '@ui/parser/libraries/UiTextLibraries'; +import { uiColorLibraries, uiImages, uiTextLibraries } from '@ui/parser/libraries'; import { PenpotDocument } from '@ui/types'; import { parseImage } from '.'; @@ -124,16 +123,16 @@ export const parse = async ({ children = [], components, images, - styles, - typographies + paintStyles, + textStyles }: PenpotDocument) => { componentsLibrary.init(components); const file = createFile(name); await optimizeImages(images); - await prepareColorLibraries(file, styles); - await prepareTypographyLibraries(file, typographies); + await prepareColorLibraries(file, paintStyles); + await prepareTypographyLibraries(file, textStyles); return buildFile(file, children); }; diff --git a/ui-src/parser/parseFigmaId.ts b/ui-src/parser/parseFigmaId.ts index 5a248ac7..20e2b360 100644 --- a/ui-src/parser/parseFigmaId.ts +++ b/ui-src/parser/parseFigmaId.ts @@ -1,7 +1,6 @@ import { PenpotFile } from '@ui/lib/types/penpotFile'; import { Uuid } from '@ui/lib/types/utils/uuid'; - -import { idLibrary } from '.'; +import { idLibrary } from '@ui/parser/libraries'; export const parseFigmaId = ( file: PenpotFile, diff --git a/ui-src/types/penpotDocument.ts b/ui-src/types/penpotDocument.ts index 0bdc3173..4057960c 100644 --- a/ui-src/types/penpotDocument.ts +++ b/ui-src/types/penpotDocument.ts @@ -8,6 +8,6 @@ export type PenpotDocument = { children?: PenpotPage[]; components: Record; images: Record; - styles: Record; - typographies: Record; + paintStyles: Record; + textStyles: Record; }; From a39283ff29724633d21a0c7bc0e8292d654e7ca8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alex=20S=C3=A1nchez?= Date: Tue, 25 Jun 2024 16:29:38 +0200 Subject: [PATCH 2/5] fixes --- .../libraries/{StyleLibrary.ts => PaintStyleLibrary.ts} | 4 ++-- .../libraries/{TextLibrary.ts => TextStyleLibrary.ts} | 4 ++-- plugin-src/libraries/index.ts | 4 ++-- plugin-src/translators/styles/translateTextStyle.ts | 6 +++--- 4 files changed, 9 insertions(+), 9 deletions(-) rename plugin-src/libraries/{StyleLibrary.ts => PaintStyleLibrary.ts} (85%) rename plugin-src/libraries/{TextLibrary.ts => TextStyleLibrary.ts} (85%) diff --git a/plugin-src/libraries/StyleLibrary.ts b/plugin-src/libraries/PaintStyleLibrary.ts similarity index 85% rename from plugin-src/libraries/StyleLibrary.ts rename to plugin-src/libraries/PaintStyleLibrary.ts index 1cfe1129..4a8800e2 100644 --- a/plugin-src/libraries/StyleLibrary.ts +++ b/plugin-src/libraries/PaintStyleLibrary.ts @@ -1,4 +1,4 @@ -class StyleLibrary { +class PaintStyleLibrary { private styles: Map = new Map(); public register(id: string, styles?: PaintStyle | undefined) { @@ -18,4 +18,4 @@ class StyleLibrary { } } -export const styleLibrary = new StyleLibrary(); +export const styleLibrary = new PaintStyleLibrary(); diff --git a/plugin-src/libraries/TextLibrary.ts b/plugin-src/libraries/TextStyleLibrary.ts similarity index 85% rename from plugin-src/libraries/TextLibrary.ts rename to plugin-src/libraries/TextStyleLibrary.ts index 647c6113..93f191d5 100644 --- a/plugin-src/libraries/TextLibrary.ts +++ b/plugin-src/libraries/TextStyleLibrary.ts @@ -1,4 +1,4 @@ -class TextLibrary { +class TextStyleLibrary { private styles: Map = new Map(); public register(id: string, styles?: TextStyle | undefined) { @@ -18,4 +18,4 @@ class TextLibrary { } } -export const textLibrary = new TextLibrary(); +export const textLibrary = new TextStyleLibrary(); diff --git a/plugin-src/libraries/index.ts b/plugin-src/libraries/index.ts index 9a6df247..a0559398 100644 --- a/plugin-src/libraries/index.ts +++ b/plugin-src/libraries/index.ts @@ -2,5 +2,5 @@ export * from './ComponentLibrary'; export * from './ImageLibrary'; export * from './OverridesLibrary'; export * from './RemoteComponentLibrary'; -export * from './StyleLibrary'; -export * from './TextLibrary'; +export * from './PaintStyleLibrary'; +export * from './TextStyleLibrary'; diff --git a/plugin-src/translators/styles/translateTextStyle.ts b/plugin-src/translators/styles/translateTextStyle.ts index fa17754f..933c213b 100644 --- a/plugin-src/translators/styles/translateTextStyle.ts +++ b/plugin-src/translators/styles/translateTextStyle.ts @@ -10,7 +10,7 @@ import { import { TypographyStyle } from '@ui/lib/types/shapes/textShape'; export const translateTextStyle = (figmaStyle: TextStyle): TypographyStyle => { - const path = figmaStyle.remote ? 'Remote / ' : ''; + const name = (figmaStyle.remote ? 'Remote / ' : '') + figmaStyle.name; return { name: figmaStyle.name, @@ -25,8 +25,8 @@ export const translateTextStyle = (figmaStyle: TextStyle): TypographyStyle => { lineHeight: translateLineHeight(figmaStyle) }, typography: { - path, - name: figmaStyle.name + path: '', + name } }; }; From 99a9bad1e46c79bc87be39b4a7fddd3cc44260c7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alex=20S=C3=A1nchez?= Date: Tue, 25 Jun 2024 16:40:24 +0200 Subject: [PATCH 3/5] rename libraries --- .../libraries/{ComponentLibrary.ts => Components.ts} | 4 ++-- plugin-src/libraries/{ImageLibrary.ts => Images.ts} | 4 ++-- .../libraries/{OverridesLibrary.ts => Overrides.ts} | 4 ++-- .../{PaintStyleLibrary.ts => PaintStyles.ts} | 4 ++-- ...RemoteComponentLibrary.ts => RemoteComponents.ts} | 2 +- .../libraries/{TextStyleLibrary.ts => TextStyles.ts} | 4 ++-- plugin-src/libraries/index.ts | 12 ++++++------ plugin-src/processors/processImages.ts | 2 +- plugin-src/processors/processPages.ts | 4 ++-- plugin-src/processors/processPaintStyles.ts | 6 +++--- plugin-src/processors/processTextStyles.ts | 6 +++--- .../transformers/partials/transformOverrides.ts | 2 +- plugin-src/transformers/transformComponentNode.ts | 4 ++-- plugin-src/transformers/transformDocumentNode.ts | 4 ++-- plugin-src/transformers/transformInstanceNode.ts | 12 +++++------- plugin-src/translators/fills/translateFills.ts | 6 +++--- plugin-src/translators/fills/translateImageFill.ts | 6 +++--- plugin-src/translators/text/translateTextSegments.ts | 6 +++--- plugin-src/translators/translateChildren.ts | 8 ++++---- ui-src/parser/creators/buildFile.ts | 4 ++-- ui-src/parser/creators/createColorsLibrary.ts | 4 ++-- ui-src/parser/creators/createComponent.ts | 4 ++-- ui-src/parser/creators/createComponentsLibrary.ts | 4 ++-- ui-src/parser/creators/createText.ts | 4 ++-- ui-src/parser/creators/createTextLibrary.ts | 4 ++-- ui-src/parser/creators/symbols/symbolFills.ts | 4 ++-- .../libraries/{IdLibrary.ts => Identifiers.ts} | 4 ++-- .../libraries/{UiColorLibraries.ts => UiColors.ts} | 4 ++-- .../{UiTextLibraries.ts => UiTypographies.ts} | 4 ++-- ui-src/parser/libraries/index.ts | 6 +++--- ui-src/parser/parse.ts | 8 ++++---- ui-src/parser/parseFigmaId.ts | 6 +++--- 32 files changed, 79 insertions(+), 81 deletions(-) rename plugin-src/libraries/{ComponentLibrary.ts => Components.ts} (86%) rename plugin-src/libraries/{ImageLibrary.ts => Images.ts} (85%) rename plugin-src/libraries/{OverridesLibrary.ts => Overrides.ts} (78%) rename plugin-src/libraries/{PaintStyleLibrary.ts => PaintStyles.ts} (85%) rename plugin-src/libraries/{RemoteComponentLibrary.ts => RemoteComponents.ts} (92%) rename plugin-src/libraries/{TextStyleLibrary.ts => TextStyles.ts} (85%) rename ui-src/parser/libraries/{IdLibrary.ts => Identifiers.ts} (83%) rename ui-src/parser/libraries/{UiColorLibraries.ts => UiColors.ts} (82%) rename ui-src/parser/libraries/{UiTextLibraries.ts => UiTypographies.ts} (84%) diff --git a/plugin-src/libraries/ComponentLibrary.ts b/plugin-src/libraries/Components.ts similarity index 86% rename from plugin-src/libraries/ComponentLibrary.ts rename to plugin-src/libraries/Components.ts index 7caf425f..b1d9c0d6 100644 --- a/plugin-src/libraries/ComponentLibrary.ts +++ b/plugin-src/libraries/Components.ts @@ -1,6 +1,6 @@ import { ComponentShape } from '@ui/lib/types/shapes/componentShape'; -class ComponentLibrary { +class Components { private components: Record = {}; public register(id: string, component: ComponentShape) { @@ -20,4 +20,4 @@ class ComponentLibrary { } } -export const componentsLibrary = new ComponentLibrary(); +export const components = new Components(); diff --git a/plugin-src/libraries/ImageLibrary.ts b/plugin-src/libraries/Images.ts similarity index 85% rename from plugin-src/libraries/ImageLibrary.ts rename to plugin-src/libraries/Images.ts index c8e0a83d..7f159a1c 100644 --- a/plugin-src/libraries/ImageLibrary.ts +++ b/plugin-src/libraries/Images.ts @@ -1,4 +1,4 @@ -class ImageLibrary { +class Images { private images: Record = {}; public register(hash: string, image: Image | null) { @@ -18,4 +18,4 @@ class ImageLibrary { } } -export const imagesLibrary = new ImageLibrary(); +export const images = new Images(); diff --git a/plugin-src/libraries/OverridesLibrary.ts b/plugin-src/libraries/Overrides.ts similarity index 78% rename from plugin-src/libraries/OverridesLibrary.ts rename to plugin-src/libraries/Overrides.ts index c633d327..4be0d7c2 100644 --- a/plugin-src/libraries/OverridesLibrary.ts +++ b/plugin-src/libraries/Overrides.ts @@ -1,4 +1,4 @@ -class OverridesLibrary { +class Overrides { private overrides: Map = new Map(); public register(nodeId: string, overrides: NodeChangeProperty[]): void { @@ -10,4 +10,4 @@ class OverridesLibrary { } } -export const overridesLibrary = new OverridesLibrary(); +export const overrides = new Overrides(); diff --git a/plugin-src/libraries/PaintStyleLibrary.ts b/plugin-src/libraries/PaintStyles.ts similarity index 85% rename from plugin-src/libraries/PaintStyleLibrary.ts rename to plugin-src/libraries/PaintStyles.ts index 4a8800e2..a231f2e2 100644 --- a/plugin-src/libraries/PaintStyleLibrary.ts +++ b/plugin-src/libraries/PaintStyles.ts @@ -1,4 +1,4 @@ -class PaintStyleLibrary { +class PaintStyles { private styles: Map = new Map(); public register(id: string, styles?: PaintStyle | undefined) { @@ -18,4 +18,4 @@ class PaintStyleLibrary { } } -export const styleLibrary = new PaintStyleLibrary(); +export const paintStyles = new PaintStyles(); diff --git a/plugin-src/libraries/RemoteComponentLibrary.ts b/plugin-src/libraries/RemoteComponents.ts similarity index 92% rename from plugin-src/libraries/RemoteComponentLibrary.ts rename to plugin-src/libraries/RemoteComponents.ts index fd537703..6e1eedab 100644 --- a/plugin-src/libraries/RemoteComponentLibrary.ts +++ b/plugin-src/libraries/RemoteComponents.ts @@ -31,4 +31,4 @@ class RemoteComponentsLibrary { } } -export const remoteComponentLibrary = new RemoteComponentsLibrary(); +export const remoteComponents = new RemoteComponentsLibrary(); diff --git a/plugin-src/libraries/TextStyleLibrary.ts b/plugin-src/libraries/TextStyles.ts similarity index 85% rename from plugin-src/libraries/TextStyleLibrary.ts rename to plugin-src/libraries/TextStyles.ts index 93f191d5..8d3366d3 100644 --- a/plugin-src/libraries/TextStyleLibrary.ts +++ b/plugin-src/libraries/TextStyles.ts @@ -1,4 +1,4 @@ -class TextStyleLibrary { +class TextStyles { private styles: Map = new Map(); public register(id: string, styles?: TextStyle | undefined) { @@ -18,4 +18,4 @@ class TextStyleLibrary { } } -export const textLibrary = new TextStyleLibrary(); +export const textStyles = new TextStyles(); diff --git a/plugin-src/libraries/index.ts b/plugin-src/libraries/index.ts index a0559398..dea9da35 100644 --- a/plugin-src/libraries/index.ts +++ b/plugin-src/libraries/index.ts @@ -1,6 +1,6 @@ -export * from './ComponentLibrary'; -export * from './ImageLibrary'; -export * from './OverridesLibrary'; -export * from './RemoteComponentLibrary'; -export * from './PaintStyleLibrary'; -export * from './TextStyleLibrary'; +export * from './Components'; +export * from './Images'; +export * from './Overrides'; +export * from './RemoteComponents'; +export * from './PaintStyles'; +export * from './TextStyles'; diff --git a/plugin-src/processors/processImages.ts b/plugin-src/processors/processImages.ts index eb73126c..d1122693 100644 --- a/plugin-src/processors/processImages.ts +++ b/plugin-src/processors/processImages.ts @@ -1,4 +1,4 @@ -import { imagesLibrary } from '@plugin/libraries'; +import { images as imagesLibrary } from '@plugin/libraries'; import { sleep } from '@plugin/utils'; export const processImages = async (): Promise> => { diff --git a/plugin-src/processors/processPages.ts b/plugin-src/processors/processPages.ts index 2789d9d4..0af22fdc 100644 --- a/plugin-src/processors/processPages.ts +++ b/plugin-src/processors/processPages.ts @@ -1,4 +1,4 @@ -import { remoteComponentLibrary } from '@plugin/libraries'; +import { remoteComponents } from '@plugin/libraries'; import { transformPageNode } from '@plugin/transformers'; import { translateRemoteChildren } from '@plugin/translators'; import { sleep } from '@plugin/utils'; @@ -16,7 +16,7 @@ export const processPages = async (node: DocumentNode): Promise => }; const processRemoteComponents = async (): Promise => { - if (remoteComponentLibrary.remaining() > 0) { + if (remoteComponents.remaining() > 0) { return { name: 'External Components', children: await translateRemoteChildren() diff --git a/plugin-src/processors/processPaintStyles.ts b/plugin-src/processors/processPaintStyles.ts index 75660e39..2d449f31 100644 --- a/plugin-src/processors/processPaintStyles.ts +++ b/plugin-src/processors/processPaintStyles.ts @@ -1,4 +1,4 @@ -import { styleLibrary } from '@plugin/libraries'; +import { paintStyles } from '@plugin/libraries'; import { translatePaintStyle } from '@plugin/translators/styles'; import { sleep } from '@plugin/utils'; @@ -11,12 +11,12 @@ const isPaintStyle = (style: BaseStyle): style is PaintStyle => { export const registerPaintStyles = async () => { const localPaintStyles = await figma.getLocalPaintStylesAsync(); localPaintStyles.forEach(style => { - styleLibrary.register(style.id, style); + paintStyles.register(style.id, style); }); }; export const processPaintStyles = async (): Promise> => { - const stylesToFetch = Object.entries(styleLibrary.all()); + const stylesToFetch = Object.entries(paintStyles.all()); const styles: Record = {}; if (stylesToFetch.length === 0) return styles; diff --git a/plugin-src/processors/processTextStyles.ts b/plugin-src/processors/processTextStyles.ts index 9394f3bb..c3a2596e 100644 --- a/plugin-src/processors/processTextStyles.ts +++ b/plugin-src/processors/processTextStyles.ts @@ -1,4 +1,4 @@ -import { textLibrary } from '@plugin/libraries'; +import { textStyles } from '@plugin/libraries'; import { translateTextStyle } from '@plugin/translators/styles'; import { sleep } from '@plugin/utils'; @@ -11,12 +11,12 @@ const isTextStyle = (style: BaseStyle): style is TextStyle => { export const registerTextStyles = async () => { const localTextStyles = await figma.getLocalTextStylesAsync(); localTextStyles.forEach(style => { - textLibrary.register(style.id, style); + textStyles.register(style.id, style); }); }; export const processTextStyles = async (): Promise> => { - const stylesToFetch = Object.entries(textLibrary.all()); + const stylesToFetch = Object.entries(textStyles.all()); const styles: Record = {}; if (stylesToFetch.length === 0) return styles; diff --git a/plugin-src/transformers/partials/transformOverrides.ts b/plugin-src/transformers/partials/transformOverrides.ts index fc09a495..9845a833 100644 --- a/plugin-src/transformers/partials/transformOverrides.ts +++ b/plugin-src/transformers/partials/transformOverrides.ts @@ -1,4 +1,4 @@ -import { overridesLibrary } from '@plugin/libraries'; +import { overrides as overridesLibrary } from '@plugin/libraries'; import { syncAttributes } from '@plugin/utils/syncAttributes'; import { SyncGroups } from '@ui/lib/types/utils/syncGroups'; diff --git a/plugin-src/transformers/transformComponentNode.ts b/plugin-src/transformers/transformComponentNode.ts index 07b90407..bd76d852 100644 --- a/plugin-src/transformers/transformComponentNode.ts +++ b/plugin-src/transformers/transformComponentNode.ts @@ -1,4 +1,4 @@ -import { componentsLibrary } from '@plugin/libraries'; +import { components } from '@plugin/libraries'; import { transformAutoLayout, transformBlend, @@ -19,7 +19,7 @@ import { import { ComponentRoot } from '@ui/types'; export const transformComponentNode = async (node: ComponentNode): Promise => { - componentsLibrary.register(node.id, { + components.register(node.id, { type: 'component', name: node.name, path: node.parent?.type === 'COMPONENT_SET' ? node.parent.name : '', diff --git a/plugin-src/transformers/transformDocumentNode.ts b/plugin-src/transformers/transformDocumentNode.ts index 5ecc51e9..43cbf430 100644 --- a/plugin-src/transformers/transformDocumentNode.ts +++ b/plugin-src/transformers/transformDocumentNode.ts @@ -1,4 +1,4 @@ -import { componentsLibrary } from '@plugin/libraries'; +import { components } from '@plugin/libraries'; import { processImages, processPages, @@ -22,7 +22,7 @@ export const transformDocumentNode = async (node: DocumentNode): Promise 0) { - node.overrides.forEach(override => - overridesLibrary.register(override.id, override.overriddenFields) - ); + node.overrides.forEach(override => overrides.register(override.id, override.overriddenFields)); } return { @@ -77,11 +75,11 @@ const getPrimaryComponent = (mainComponent: ComponentNode): ComponentNode | Comp }; const registerExternalComponents = (primaryComponent: ComponentNode | ComponentSetNode): void => { - if (remoteComponentLibrary.get(primaryComponent.id) !== undefined) { + if (remoteComponents.get(primaryComponent.id) !== undefined) { return; } - remoteComponentLibrary.register(primaryComponent.id, primaryComponent); + remoteComponents.register(primaryComponent.id, primaryComponent); }; const getComponentTextPropertyOverrides = ( @@ -130,7 +128,7 @@ const registerTextVariableOverrides = ( }); textNodes.forEach(textNode => { - overridesLibrary.register(textNode.id, ['text']); + overrides.register(textNode.id, ['text']); }); } }; diff --git a/plugin-src/translators/fills/translateFills.ts b/plugin-src/translators/fills/translateFills.ts index 4c1beb29..b0ea7e37 100644 --- a/plugin-src/translators/fills/translateFills.ts +++ b/plugin-src/translators/fills/translateFills.ts @@ -1,4 +1,4 @@ -import { styleLibrary } from '@plugin/libraries'; +import { paintStyles } from '@plugin/libraries'; import { translateImageFill, translateSolidFill } from '@plugin/translators/fills'; import { translateGradientLinearFill, @@ -47,8 +47,8 @@ export const translateFillStyleId = ( ): string | undefined => { if (fillStyleId === figma.mixed || fillStyleId === undefined) return; - if (!styleLibrary.has(fillStyleId)) { - styleLibrary.register(fillStyleId); + if (!paintStyles.has(fillStyleId)) { + paintStyles.register(fillStyleId); } return fillStyleId; diff --git a/plugin-src/translators/fills/translateImageFill.ts b/plugin-src/translators/fills/translateImageFill.ts index 4a097d1d..a2854e55 100644 --- a/plugin-src/translators/fills/translateImageFill.ts +++ b/plugin-src/translators/fills/translateImageFill.ts @@ -1,4 +1,4 @@ -import { imagesLibrary } from '@plugin/libraries'; +import { images } from '@plugin/libraries'; import { Fill } from '@ui/lib/types/utils/fill'; import { PartialImageColor } from '@ui/lib/types/utils/imageColor'; @@ -16,8 +16,8 @@ export const translateImageFill = (fill: ImagePaint): Fill | undefined => { const translateImage = (imageHash: string | null): PartialImageColor | undefined => { if (!imageHash) return; - if (imagesLibrary.get(imageHash) === undefined) { - imagesLibrary.register(imageHash, figma.getImageByHash(imageHash)); + if (images.get(imageHash) === undefined) { + images.register(imageHash, figma.getImageByHash(imageHash)); } return { diff --git a/plugin-src/translators/text/translateTextSegments.ts b/plugin-src/translators/text/translateTextSegments.ts index 30b415cd..5efd4ab8 100644 --- a/plugin-src/translators/text/translateTextSegments.ts +++ b/plugin-src/translators/text/translateTextSegments.ts @@ -1,4 +1,4 @@ -import { textLibrary } from '@plugin/libraries'; +import { textStyles } from '@plugin/libraries'; import { transformFills } from '@plugin/transformers/partials'; import { translateFontName } from '@plugin/translators/text/font'; import { TextSegment, translateParagraphProperties } from '@plugin/translators/text/paragraph'; @@ -67,8 +67,8 @@ const hasTextStyle = (segment: TextSegment): boolean => { const translateTextStyleId = (textStyleId: string | undefined): string | undefined => { if (textStyleId === undefined) return; - if (!textLibrary.has(textStyleId)) { - textLibrary.register(textStyleId); + if (!textStyles.has(textStyleId)) { + textStyles.register(textStyleId); } return textStyleId; diff --git a/plugin-src/translators/translateChildren.ts b/plugin-src/translators/translateChildren.ts index 2a92042e..c532d4ff 100644 --- a/plugin-src/translators/translateChildren.ts +++ b/plugin-src/translators/translateChildren.ts @@ -1,4 +1,4 @@ -import { remoteComponentLibrary } from '@plugin/libraries'; +import { remoteComponents } from '@plugin/libraries'; import { transformGroupNodeLike, transformSceneNode } from '@plugin/transformers'; import { transformMaskFigmaIds } from '@plugin/transformers/partials'; import { sleep } from '@plugin/utils'; @@ -71,13 +71,13 @@ export const translateRemoteChildren = async (): Promise => { data: 'remote' }); - while (remoteComponentLibrary.remaining() > 0) { + while (remoteComponents.remaining() > 0) { figma.ui.postMessage({ type: 'PROGRESS_TOTAL_ITEMS', - data: remoteComponentLibrary.total() + data: remoteComponents.total() }); - const child = remoteComponentLibrary.next(); + const child = remoteComponents.next(); const penpotNode = await transformSceneNode(child); diff --git a/ui-src/parser/creators/buildFile.ts b/ui-src/parser/creators/buildFile.ts index de348bbd..a827f8d4 100644 --- a/ui-src/parser/creators/buildFile.ts +++ b/ui-src/parser/creators/buildFile.ts @@ -9,13 +9,13 @@ import { createPage, createTextLibrary } from '@ui/parser/creators'; -import { idLibrary, uiComponents } from '@ui/parser/libraries'; +import { identifiers, uiComponents } from '@ui/parser/libraries'; export const buildFile = async (file: PenpotFile, children: PenpotPage[]) => { let pagesBuilt = 1; uiComponents.init(); - idLibrary.init(); + identifiers.init(); sendMessage({ type: 'PROGRESS_TOTAL_ITEMS', diff --git a/ui-src/parser/creators/createColorsLibrary.ts b/ui-src/parser/creators/createColorsLibrary.ts index bf37b8ca..10edd6e0 100644 --- a/ui-src/parser/creators/createColorsLibrary.ts +++ b/ui-src/parser/creators/createColorsLibrary.ts @@ -2,11 +2,11 @@ import { sleep } from '@plugin/utils/sleep'; import { sendMessage } from '@ui/context'; import { PenpotFile } from '@ui/lib/types/penpotFile'; -import { uiColorLibraries } from '@ui/parser/libraries'; +import { uiColors } from '@ui/parser/libraries'; export const createColorsLibrary = async (file: PenpotFile) => { let librariesBuilt = 1; - const libraries = uiColorLibraries.all(); + const libraries = uiColors.all(); sendMessage({ type: 'PROGRESS_TOTAL_ITEMS', diff --git a/ui-src/parser/creators/createComponent.ts b/ui-src/parser/creators/createComponent.ts index 4ab742bf..ad7def6d 100644 --- a/ui-src/parser/creators/createComponent.ts +++ b/ui-src/parser/creators/createComponent.ts @@ -1,4 +1,4 @@ -import { componentsLibrary } from '@plugin/libraries/ComponentLibrary'; +import { components } from '@plugin/libraries/Components'; import { PenpotFile } from '@ui/lib/types/penpotFile'; import { uiComponents } from '@ui/parser/libraries'; @@ -7,7 +7,7 @@ import { ComponentRoot } from '@ui/types'; import { createArtboard } from '.'; export const createComponent = (file: PenpotFile, { figmaId }: ComponentRoot) => { - const component = componentsLibrary.get(figmaId); + const component = components.get(figmaId); if (!component) { return; diff --git a/ui-src/parser/creators/createComponentsLibrary.ts b/ui-src/parser/creators/createComponentsLibrary.ts index c38c64e9..7b76ecf9 100644 --- a/ui-src/parser/creators/createComponentsLibrary.ts +++ b/ui-src/parser/creators/createComponentsLibrary.ts @@ -1,4 +1,4 @@ -import { componentsLibrary } from '@plugin/libraries/ComponentLibrary'; +import { components } from '@plugin/libraries/Components'; import { sleep } from '@plugin/utils/sleep'; import { sendMessage } from '@ui/context'; @@ -35,7 +35,7 @@ export const createComponentsLibrary = async (file: PenpotFile) => { }; const createComponentLibrary = async (file: PenpotFile, uiComponent: UiComponent) => { - const component = componentsLibrary.get(uiComponent.componentFigmaId); + const component = components.get(uiComponent.componentFigmaId); if (!component) { return; diff --git a/ui-src/parser/creators/createText.ts b/ui-src/parser/creators/createText.ts index 9d2a676f..cdb40173 100644 --- a/ui-src/parser/creators/createText.ts +++ b/ui-src/parser/creators/createText.ts @@ -2,7 +2,7 @@ import { PenpotFile } from '@ui/lib/types/penpotFile'; import { Paragraph, TextContent, TextNode, TextShape } from '@ui/lib/types/shapes/textShape'; import { parseFigmaId } from '@ui/parser'; import { symbolFills, symbolStrokes } from '@ui/parser/creators/symbols'; -import { uiTextLibraries } from '@ui/parser/libraries'; +import { uiTypographies } from '@ui/parser/libraries'; export const createText = ( file: PenpotFile, @@ -36,7 +36,7 @@ const parseTextStyle = (text: Paragraph | TextNode, textStyleId?: string): Parag let textStyle = text; textStyle.fills = symbolFills(text.fillStyleId, text.fills); - const libraryStyle = textStyleId ? uiTextLibraries.get(textStyleId) : undefined; + const libraryStyle = textStyleId ? uiTypographies.get(textStyleId) : undefined; if (libraryStyle) { textStyle = { diff --git a/ui-src/parser/creators/createTextLibrary.ts b/ui-src/parser/creators/createTextLibrary.ts index ae1b3399..a88f0641 100644 --- a/ui-src/parser/creators/createTextLibrary.ts +++ b/ui-src/parser/creators/createTextLibrary.ts @@ -2,11 +2,11 @@ import { sleep } from '@plugin/utils/sleep'; import { sendMessage } from '@ui/context'; import { PenpotFile } from '@ui/lib/types/penpotFile'; -import { uiTextLibraries } from '@ui/parser/libraries'; +import { uiTypographies } from '@ui/parser/libraries'; export const createTextLibrary = async (file: PenpotFile) => { let librariesBuilt = 1; - const libraries = uiTextLibraries.all(); + const libraries = uiTypographies.all(); sendMessage({ type: 'PROGRESS_TOTAL_ITEMS', diff --git a/ui-src/parser/creators/symbols/symbolFills.ts b/ui-src/parser/creators/symbols/symbolFills.ts index 1edd8f7e..bc506323 100644 --- a/ui-src/parser/creators/symbols/symbolFills.ts +++ b/ui-src/parser/creators/symbols/symbolFills.ts @@ -1,9 +1,9 @@ import { Fill } from '@ui/lib/types/utils/fill'; import { ImageColor, PartialImageColor } from '@ui/lib/types/utils/imageColor'; -import { uiColorLibraries, uiImages } from '@ui/parser/libraries'; +import { uiColors, uiImages } from '@ui/parser/libraries'; export const symbolFills = (fillStyleId?: string, fills?: Fill[]): Fill[] | undefined => { - const nodeFills = fillStyleId ? uiColorLibraries.get(fillStyleId)?.fills : fills; + const nodeFills = fillStyleId ? uiColors.get(fillStyleId)?.fills : fills; if (!nodeFills) return; diff --git a/ui-src/parser/libraries/IdLibrary.ts b/ui-src/parser/libraries/Identifiers.ts similarity index 83% rename from ui-src/parser/libraries/IdLibrary.ts rename to ui-src/parser/libraries/Identifiers.ts index a6d40207..3d08f5c9 100644 --- a/ui-src/parser/libraries/IdLibrary.ts +++ b/ui-src/parser/libraries/Identifiers.ts @@ -1,6 +1,6 @@ import { Uuid } from '@ui/lib/types/utils/uuid'; -class IdLibrary { +class Identifiers { private idMap: Map = new Map(); public init() { @@ -16,4 +16,4 @@ class IdLibrary { } } -export const idLibrary = new IdLibrary(); +export const identifiers = new Identifiers(); diff --git a/ui-src/parser/libraries/UiColorLibraries.ts b/ui-src/parser/libraries/UiColors.ts similarity index 82% rename from ui-src/parser/libraries/UiColorLibraries.ts rename to ui-src/parser/libraries/UiColors.ts index 76b5ee5c..ca864b9c 100644 --- a/ui-src/parser/libraries/UiColorLibraries.ts +++ b/ui-src/parser/libraries/UiColors.ts @@ -1,6 +1,6 @@ import { FillStyle } from '@ui/lib/types/utils/fill'; -class UiColorLibraries { +class UiColors { private libraries: Map = new Map(); public register(id: string, fillStyle: FillStyle) { @@ -16,4 +16,4 @@ class UiColorLibraries { } } -export const uiColorLibraries = new UiColorLibraries(); +export const uiColors = new UiColors(); diff --git a/ui-src/parser/libraries/UiTextLibraries.ts b/ui-src/parser/libraries/UiTypographies.ts similarity index 84% rename from ui-src/parser/libraries/UiTextLibraries.ts rename to ui-src/parser/libraries/UiTypographies.ts index 208ac571..81028654 100644 --- a/ui-src/parser/libraries/UiTextLibraries.ts +++ b/ui-src/parser/libraries/UiTypographies.ts @@ -1,6 +1,6 @@ import { TypographyStyle } from '@ui/lib/types/shapes/textShape'; -class UiTextLibraries { +class UiTypographies { private libraries: Map = new Map(); public register(id: string, textStyle: TypographyStyle) { @@ -16,4 +16,4 @@ class UiTextLibraries { } } -export const uiTextLibraries = new UiTextLibraries(); +export const uiTypographies = new UiTypographies(); diff --git a/ui-src/parser/libraries/index.ts b/ui-src/parser/libraries/index.ts index 6dc12e89..94a633b9 100644 --- a/ui-src/parser/libraries/index.ts +++ b/ui-src/parser/libraries/index.ts @@ -1,5 +1,5 @@ -export * from './IdLibrary'; -export * from './UiColorLibraries'; +export * from './Identifiers'; +export * from './UiColors'; export * from './UiComponents'; export * from './UiImages'; -export * from './UiTextLibraries'; +export * from './UiTypographies'; diff --git a/ui-src/parser/parse.ts b/ui-src/parser/parse.ts index fcbffdf3..a2b39559 100644 --- a/ui-src/parser/parse.ts +++ b/ui-src/parser/parse.ts @@ -1,4 +1,4 @@ -import { componentsLibrary } from '@plugin/libraries/ComponentLibrary'; +import { components as componentsLibrary } from '@plugin/libraries/Components'; // @TODO: Direct import on purpose, to avoid problems with the tsc linting import { sleep } from '@plugin/utils/sleep'; @@ -8,7 +8,7 @@ import { PenpotFile } from '@ui/lib/types/penpotFile'; import { TypographyStyle } from '@ui/lib/types/shapes/textShape'; import { FillStyle } from '@ui/lib/types/utils/fill'; import { buildFile } from '@ui/parser/creators'; -import { uiColorLibraries, uiImages, uiTextLibraries } from '@ui/parser/libraries'; +import { uiColors, uiImages, uiTypographies } from '@ui/parser/libraries'; import { PenpotDocument } from '@ui/types'; import { parseImage } from '.'; @@ -70,7 +70,7 @@ const prepareTypographyLibraries = async ( style.textStyle.typographyRefFile = file.getId(); style.typography.id = typographyId; - uiTextLibraries.register(key, style); + uiTypographies.register(key, style); sendMessage({ type: 'PROGRESS_PROCESSED_ITEMS', @@ -107,7 +107,7 @@ const prepareColorLibraries = async (file: PenpotFile, styles: Record Date: Tue, 25 Jun 2024 16:59:29 +0200 Subject: [PATCH 4/5] refactor libraries --- plugin-src/libraries/Components.ts | 10 +++++----- plugin-src/libraries/Images.ts | 14 +++++++++----- plugin-src/libraries/RemoteComponents.ts | 17 ++++++++++++----- .../transformers/transformInstanceNode.ts | 2 +- .../translators/fills/translateImageFill.ts | 2 +- ui-src/parser/libraries/UiComponents.ts | 10 +++++----- ui-src/parser/libraries/UiImages.ts | 10 +++++----- 7 files changed, 38 insertions(+), 27 deletions(-) diff --git a/plugin-src/libraries/Components.ts b/plugin-src/libraries/Components.ts index b1d9c0d6..dd701058 100644 --- a/plugin-src/libraries/Components.ts +++ b/plugin-src/libraries/Components.ts @@ -1,22 +1,22 @@ import { ComponentShape } from '@ui/lib/types/shapes/componentShape'; class Components { - private components: Record = {}; + private components: Map = new Map(); public register(id: string, component: ComponentShape) { - this.components[id] = component; + this.components.set(id, component); } public get(id: string): ComponentShape | undefined { - return this.components[id]; + return this.components.get(id); } public all(): Record { - return this.components; + return Object.fromEntries(this.components.entries()); } public init(components: Record): void { - this.components = components; + this.components = new Map(Object.entries(components)); } } diff --git a/plugin-src/libraries/Images.ts b/plugin-src/libraries/Images.ts index 7f159a1c..d4db39de 100644 --- a/plugin-src/libraries/Images.ts +++ b/plugin-src/libraries/Images.ts @@ -1,20 +1,24 @@ class Images { - private images: Record = {}; + private images: Map = new Map(); public register(hash: string, image: Image | null) { - this.images[hash] = image; + this.images.set(hash, image); } public get(hash: string): Image | null | undefined { - return this.images[hash]; + return this.images.get(hash); + } + + public has(hash: string): boolean { + return this.images.has(hash); } public all(): Record { - return this.images; + return Object.fromEntries(this.images.entries()); } public init(images: Record): void { - this.images = images; + this.images = new Map(Object.entries(images)); } } diff --git a/plugin-src/libraries/RemoteComponents.ts b/plugin-src/libraries/RemoteComponents.ts index 6e1eedab..f3ca10ad 100644 --- a/plugin-src/libraries/RemoteComponents.ts +++ b/plugin-src/libraries/RemoteComponents.ts @@ -1,5 +1,5 @@ class RemoteComponentsLibrary { - private components: Record = {}; + private components: Map = new Map(); private queue: string[] = []; public register(id: string, component: ComponentNode | ComponentSetNode) { @@ -7,11 +7,15 @@ class RemoteComponentsLibrary { this.queue.push(id); } - this.components[id] = component; + this.components.set(id, component); } public get(id: string): ComponentNode | ComponentSetNode | undefined { - return this.components[id]; + return this.components.get(id); + } + + public has(id: string): boolean { + return this.components.has(id); } public next(): ComponentNode | ComponentSetNode { @@ -19,7 +23,10 @@ class RemoteComponentsLibrary { if (!lastKey) throw new Error('No components to pop'); - return this.components[lastKey]; + const component = this.components.get(lastKey); + if (!component) throw new Error('Component not found'); + + return component; } public remaining(): number { @@ -27,7 +34,7 @@ class RemoteComponentsLibrary { } public total(): number { - return Object.keys(this.components).length; + return this.components.size; } } diff --git a/plugin-src/transformers/transformInstanceNode.ts b/plugin-src/transformers/transformInstanceNode.ts index fc8e94be..7db5ed22 100644 --- a/plugin-src/transformers/transformInstanceNode.ts +++ b/plugin-src/transformers/transformInstanceNode.ts @@ -75,7 +75,7 @@ const getPrimaryComponent = (mainComponent: ComponentNode): ComponentNode | Comp }; const registerExternalComponents = (primaryComponent: ComponentNode | ComponentSetNode): void => { - if (remoteComponents.get(primaryComponent.id) !== undefined) { + if (remoteComponents.has(primaryComponent.id)) { return; } diff --git a/plugin-src/translators/fills/translateImageFill.ts b/plugin-src/translators/fills/translateImageFill.ts index a2854e55..70813ee2 100644 --- a/plugin-src/translators/fills/translateImageFill.ts +++ b/plugin-src/translators/fills/translateImageFill.ts @@ -16,7 +16,7 @@ export const translateImageFill = (fill: ImagePaint): Fill | undefined => { const translateImage = (imageHash: string | null): PartialImageColor | undefined => { if (!imageHash) return; - if (images.get(imageHash) === undefined) { + if (!images.has(imageHash)) { images.register(imageHash, figma.getImageByHash(imageHash)); } diff --git a/ui-src/parser/libraries/UiComponents.ts b/ui-src/parser/libraries/UiComponents.ts index cb95a467..97b4a879 100644 --- a/ui-src/parser/libraries/UiComponents.ts +++ b/ui-src/parser/libraries/UiComponents.ts @@ -8,22 +8,22 @@ export type UiComponent = { }; class UiComponents { - private components: Record = {}; + private components: Map = new Map(); public register(id: string, component: UiComponent) { - this.components[id] = component; + this.components.set(id, component); } public get(id: string): UiComponent | undefined { - return this.components[id]; + return this.components.get(id); } public all(): UiComponent[] { - return Object.values(this.components); + return Array.from(this.components.values()); } public init() { - this.components = {}; + this.components.clear(); } } diff --git a/ui-src/parser/libraries/UiImages.ts b/ui-src/parser/libraries/UiImages.ts index ed819ff4..8c6f1348 100644 --- a/ui-src/parser/libraries/UiImages.ts +++ b/ui-src/parser/libraries/UiImages.ts @@ -1,22 +1,22 @@ import { ImageColor } from '@ui/lib/types/utils/imageColor'; class UiImages { - private images: Record = {}; + private images: Map = new Map(); public register(id: string, image: ImageColor) { - this.images[id] = image; + this.images.set(id, image); } public get(id: string): ImageColor | undefined { - return this.images[id]; + return this.images.get(id); } public all(): ImageColor[] { - return Object.values(this.images); + return Array.from(this.images.values()); } public init() { - this.images = {}; + this.images.clear(); } } From 0e5f9f3ab6f77eba3efa23294952d77c7a75316e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alex=20S=C3=A1nchez?= Date: Tue, 25 Jun 2024 17:10:44 +0200 Subject: [PATCH 5/5] fixes --- ui-src/parser/creators/buildFile.ts | 4 ++-- ui-src/parser/creators/createColorsLibrary.ts | 4 ++-- ui-src/parser/creators/createComponent.ts | 2 +- ui-src/parser/creators/createComponentInstance.ts | 6 +++--- ui-src/parser/creators/createComponentsLibrary.ts | 2 +- ui-src/parser/creators/createText.ts | 4 ++-- ui-src/parser/creators/createTextLibrary.ts | 4 ++-- ui-src/parser/creators/symbols/symbolFills.ts | 6 +++--- ui-src/parser/libraries/{UiColors.ts => Colors.ts} | 4 ++-- .../parser/libraries/{UiComponents.ts => Components.ts} | 4 ++-- ui-src/parser/libraries/{UiImages.ts => Images.ts} | 4 ++-- .../libraries/{UiTypographies.ts => Typographies.ts} | 4 ++-- ui-src/parser/libraries/index.ts | 8 ++++---- ui-src/parser/parse.ts | 6 +++--- 14 files changed, 31 insertions(+), 31 deletions(-) rename ui-src/parser/libraries/{UiColors.ts => Colors.ts} (87%) rename ui-src/parser/libraries/{UiComponents.ts => Components.ts} (89%) rename ui-src/parser/libraries/{UiImages.ts => Images.ts} (88%) rename ui-src/parser/libraries/{UiTypographies.ts => Typographies.ts} (84%) diff --git a/ui-src/parser/creators/buildFile.ts b/ui-src/parser/creators/buildFile.ts index a827f8d4..c26ab807 100644 --- a/ui-src/parser/creators/buildFile.ts +++ b/ui-src/parser/creators/buildFile.ts @@ -9,12 +9,12 @@ import { createPage, createTextLibrary } from '@ui/parser/creators'; -import { identifiers, uiComponents } from '@ui/parser/libraries'; +import { components, identifiers } from '@ui/parser/libraries'; export const buildFile = async (file: PenpotFile, children: PenpotPage[]) => { let pagesBuilt = 1; - uiComponents.init(); + components.init(); identifiers.init(); sendMessage({ diff --git a/ui-src/parser/creators/createColorsLibrary.ts b/ui-src/parser/creators/createColorsLibrary.ts index 10edd6e0..75409303 100644 --- a/ui-src/parser/creators/createColorsLibrary.ts +++ b/ui-src/parser/creators/createColorsLibrary.ts @@ -2,11 +2,11 @@ import { sleep } from '@plugin/utils/sleep'; import { sendMessage } from '@ui/context'; import { PenpotFile } from '@ui/lib/types/penpotFile'; -import { uiColors } from '@ui/parser/libraries'; +import { colors } from '@ui/parser/libraries'; export const createColorsLibrary = async (file: PenpotFile) => { let librariesBuilt = 1; - const libraries = uiColors.all(); + const libraries = colors.all(); sendMessage({ type: 'PROGRESS_TOTAL_ITEMS', diff --git a/ui-src/parser/creators/createComponent.ts b/ui-src/parser/creators/createComponent.ts index ad7def6d..e869582c 100644 --- a/ui-src/parser/creators/createComponent.ts +++ b/ui-src/parser/creators/createComponent.ts @@ -1,7 +1,7 @@ import { components } from '@plugin/libraries/Components'; import { PenpotFile } from '@ui/lib/types/penpotFile'; -import { uiComponents } from '@ui/parser/libraries'; +import { components as uiComponents } from '@ui/parser/libraries'; import { ComponentRoot } from '@ui/types'; import { createArtboard } from '.'; diff --git a/ui-src/parser/creators/createComponentInstance.ts b/ui-src/parser/creators/createComponentInstance.ts index 44bcf9a7..c7fdd00e 100644 --- a/ui-src/parser/creators/createComponentInstance.ts +++ b/ui-src/parser/creators/createComponentInstance.ts @@ -1,6 +1,6 @@ import { PenpotFile } from '@ui/lib/types/penpotFile'; import { parseFigmaId } from '@ui/parser'; -import { uiComponents } from '@ui/parser/libraries'; +import { components } from '@ui/parser/libraries'; import { ComponentInstance } from '@ui/types'; import { createArtboard } from '.'; @@ -17,7 +17,7 @@ export const createComponentInstance = ( }: ComponentInstance ) => { const uiComponent = - uiComponents.get(mainComponentFigmaId) ?? createUiComponent(file, mainComponentFigmaId); + components.get(mainComponentFigmaId) ?? createUiComponent(file, mainComponentFigmaId); if (!uiComponent) { return; @@ -43,7 +43,7 @@ const createUiComponent = (file: PenpotFile, mainComponentFigmaId: string) => { mainInstanceId }; - uiComponents.register(mainComponentFigmaId, uiComponent); + components.register(mainComponentFigmaId, uiComponent); return uiComponent; }; diff --git a/ui-src/parser/creators/createComponentsLibrary.ts b/ui-src/parser/creators/createComponentsLibrary.ts index 7b76ecf9..9ff8c1cb 100644 --- a/ui-src/parser/creators/createComponentsLibrary.ts +++ b/ui-src/parser/creators/createComponentsLibrary.ts @@ -4,7 +4,7 @@ import { sleep } from '@plugin/utils/sleep'; import { sendMessage } from '@ui/context'; import { PenpotFile } from '@ui/lib/types/penpotFile'; import { symbolFills, symbolStrokes } from '@ui/parser/creators/symbols'; -import { UiComponent, uiComponents } from '@ui/parser/libraries'; +import { UiComponent, components as uiComponents } from '@ui/parser/libraries'; import { createItems } from '.'; diff --git a/ui-src/parser/creators/createText.ts b/ui-src/parser/creators/createText.ts index cdb40173..c6e8f43d 100644 --- a/ui-src/parser/creators/createText.ts +++ b/ui-src/parser/creators/createText.ts @@ -2,7 +2,7 @@ import { PenpotFile } from '@ui/lib/types/penpotFile'; import { Paragraph, TextContent, TextNode, TextShape } from '@ui/lib/types/shapes/textShape'; import { parseFigmaId } from '@ui/parser'; import { symbolFills, symbolStrokes } from '@ui/parser/creators/symbols'; -import { uiTypographies } from '@ui/parser/libraries'; +import { typographies } from '@ui/parser/libraries'; export const createText = ( file: PenpotFile, @@ -36,7 +36,7 @@ const parseTextStyle = (text: Paragraph | TextNode, textStyleId?: string): Parag let textStyle = text; textStyle.fills = symbolFills(text.fillStyleId, text.fills); - const libraryStyle = textStyleId ? uiTypographies.get(textStyleId) : undefined; + const libraryStyle = textStyleId ? typographies.get(textStyleId) : undefined; if (libraryStyle) { textStyle = { diff --git a/ui-src/parser/creators/createTextLibrary.ts b/ui-src/parser/creators/createTextLibrary.ts index a88f0641..d655c5db 100644 --- a/ui-src/parser/creators/createTextLibrary.ts +++ b/ui-src/parser/creators/createTextLibrary.ts @@ -2,11 +2,11 @@ import { sleep } from '@plugin/utils/sleep'; import { sendMessage } from '@ui/context'; import { PenpotFile } from '@ui/lib/types/penpotFile'; -import { uiTypographies } from '@ui/parser/libraries'; +import { typographies } from '@ui/parser/libraries'; export const createTextLibrary = async (file: PenpotFile) => { let librariesBuilt = 1; - const libraries = uiTypographies.all(); + const libraries = typographies.all(); sendMessage({ type: 'PROGRESS_TOTAL_ITEMS', diff --git a/ui-src/parser/creators/symbols/symbolFills.ts b/ui-src/parser/creators/symbols/symbolFills.ts index bc506323..b09c8995 100644 --- a/ui-src/parser/creators/symbols/symbolFills.ts +++ b/ui-src/parser/creators/symbols/symbolFills.ts @@ -1,9 +1,9 @@ import { Fill } from '@ui/lib/types/utils/fill'; import { ImageColor, PartialImageColor } from '@ui/lib/types/utils/imageColor'; -import { uiColors, uiImages } from '@ui/parser/libraries'; +import { colors, images } from '@ui/parser/libraries'; export const symbolFills = (fillStyleId?: string, fills?: Fill[]): Fill[] | undefined => { - const nodeFills = fillStyleId ? uiColors.get(fillStyleId)?.fills : fills; + const nodeFills = fillStyleId ? colors.get(fillStyleId)?.fills : fills; if (!nodeFills) return; @@ -21,7 +21,7 @@ export const symbolFillImage = ( ): ImageColor | undefined => { if (!isPartialFillColor(fillImage)) return fillImage; - return uiImages.get(fillImage.imageHash); + return images.get(fillImage.imageHash); }; const isPartialFillColor = ( diff --git a/ui-src/parser/libraries/UiColors.ts b/ui-src/parser/libraries/Colors.ts similarity index 87% rename from ui-src/parser/libraries/UiColors.ts rename to ui-src/parser/libraries/Colors.ts index ca864b9c..6d482e0c 100644 --- a/ui-src/parser/libraries/UiColors.ts +++ b/ui-src/parser/libraries/Colors.ts @@ -1,6 +1,6 @@ import { FillStyle } from '@ui/lib/types/utils/fill'; -class UiColors { +class Colors { private libraries: Map = new Map(); public register(id: string, fillStyle: FillStyle) { @@ -16,4 +16,4 @@ class UiColors { } } -export const uiColors = new UiColors(); +export const colors = new Colors(); diff --git a/ui-src/parser/libraries/UiComponents.ts b/ui-src/parser/libraries/Components.ts similarity index 89% rename from ui-src/parser/libraries/UiComponents.ts rename to ui-src/parser/libraries/Components.ts index 97b4a879..fd071e5e 100644 --- a/ui-src/parser/libraries/UiComponents.ts +++ b/ui-src/parser/libraries/Components.ts @@ -7,7 +7,7 @@ export type UiComponent = { componentFigmaId: string; }; -class UiComponents { +class Components { private components: Map = new Map(); public register(id: string, component: UiComponent) { @@ -27,4 +27,4 @@ class UiComponents { } } -export const uiComponents = new UiComponents(); +export const components = new Components(); diff --git a/ui-src/parser/libraries/UiImages.ts b/ui-src/parser/libraries/Images.ts similarity index 88% rename from ui-src/parser/libraries/UiImages.ts rename to ui-src/parser/libraries/Images.ts index 8c6f1348..47907f08 100644 --- a/ui-src/parser/libraries/UiImages.ts +++ b/ui-src/parser/libraries/Images.ts @@ -1,6 +1,6 @@ import { ImageColor } from '@ui/lib/types/utils/imageColor'; -class UiImages { +class Images { private images: Map = new Map(); public register(id: string, image: ImageColor) { @@ -20,4 +20,4 @@ class UiImages { } } -export const uiImages = new UiImages(); +export const images = new Images(); diff --git a/ui-src/parser/libraries/UiTypographies.ts b/ui-src/parser/libraries/Typographies.ts similarity index 84% rename from ui-src/parser/libraries/UiTypographies.ts rename to ui-src/parser/libraries/Typographies.ts index 81028654..e4ae4ef2 100644 --- a/ui-src/parser/libraries/UiTypographies.ts +++ b/ui-src/parser/libraries/Typographies.ts @@ -1,6 +1,6 @@ import { TypographyStyle } from '@ui/lib/types/shapes/textShape'; -class UiTypographies { +class Typographies { private libraries: Map = new Map(); public register(id: string, textStyle: TypographyStyle) { @@ -16,4 +16,4 @@ class UiTypographies { } } -export const uiTypographies = new UiTypographies(); +export const typographies = new Typographies(); diff --git a/ui-src/parser/libraries/index.ts b/ui-src/parser/libraries/index.ts index 94a633b9..ff701b27 100644 --- a/ui-src/parser/libraries/index.ts +++ b/ui-src/parser/libraries/index.ts @@ -1,5 +1,5 @@ export * from './Identifiers'; -export * from './UiColors'; -export * from './UiComponents'; -export * from './UiImages'; -export * from './UiTypographies'; +export * from './Colors'; +export * from './Components'; +export * from './Images'; +export * from './Typographies'; diff --git a/ui-src/parser/parse.ts b/ui-src/parser/parse.ts index a2b39559..7dc41b26 100644 --- a/ui-src/parser/parse.ts +++ b/ui-src/parser/parse.ts @@ -8,7 +8,7 @@ import { PenpotFile } from '@ui/lib/types/penpotFile'; import { TypographyStyle } from '@ui/lib/types/shapes/textShape'; import { FillStyle } from '@ui/lib/types/utils/fill'; import { buildFile } from '@ui/parser/creators'; -import { uiColors, uiImages, uiTypographies } from '@ui/parser/libraries'; +import { colors, typographies, images as uiImages } from '@ui/parser/libraries'; import { PenpotDocument } from '@ui/types'; import { parseImage } from '.'; @@ -70,7 +70,7 @@ const prepareTypographyLibraries = async ( style.textStyle.typographyRefFile = file.getId(); style.typography.id = typographyId; - uiTypographies.register(key, style); + typographies.register(key, style); sendMessage({ type: 'PROGRESS_PROCESSED_ITEMS', @@ -107,7 +107,7 @@ const prepareColorLibraries = async (file: PenpotFile, styles: Record