npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@imgly/psd-importer

v0.0.4-rc.0

Published

Import PSD files into the Creative Editor Ecosystem

Downloads

2,237

Readme

Photoshop Importer for the CE.SDK

Overview

The Photoshop Importer for the CE.SDK allows you to seamlessly integrate Photoshop files into the editor while retaining essential design attributes.

Here’s an overview of the main features:

  • File Format Translation: The importer converts PSD files from Adobe Photoshop into the CE.SDK scene file format. The resulting scene archive includes all required assets for immediate use.
  • Bulk Importing: The codebase is adaptable for bulk importing, streamlining large-scale projects.

The following Photoshop design elements will be preserved by the import:

  • Element grouping: grouped elements will be preserved if possible and enabled.
  • Positioning and Rotation: Elements’ positioning and rotation are accurately transferred.
  • Image Elements: Images are supported, while image cropping is not yet available.
  • Text Elements: Font family continuity is maintained, with options to supply font URIs or use Google fonts. Only bold and italic styles are currently supported.
  • Shapes: Rect, Oval, Polygon, and Line shapes are supported, along with custom shapes that might experience minor distortion.
  • Colors and Strokes: Solid colors, stroke weight, color, and alignment are faithfully reproduced. Gradient fills are not yet supported.
  • Transparency: Transparency is preserved for seamless integration.

This Photoshop Importer bridges the gap between Photoshop files and CE.SDK scenes, enabling efficient transitions while retaining crucial design details. Your input is invaluable as we continue to refine and improve the importer’s capabilities.

Installation

You can install @imgly/psd-importer via npm or yarn. Use the following commands to install the package:

npm install @imgly/psd-importer
yarn add @imgly/psd-importer

Browser Quick-Start Example

import CreativeEngine from "@cesdk/engine";
import { PSDParser, createWebEncodeBufferToPNG } from "@imgly/psd-importer";

const blob = await fetch(
  "https://img.ly/showcases/cesdk/cases/photoshop-template-import/socialmedia.psd"
).then((res) => res.blob());
const buffer = await blob.arrayBuffer();
const engine = await CreativeEngine.init({
  license: "YOUR_LICENSE",
});
const parser = await PSDParser.fromFile(
  engine,
  buffer,
  createWebEncodeBufferToPNG()
);

await parser.parse();

const image = await engine.block.export(
  engine.block.findByType("//ly.img.ubq/page")[0],
  "image/png"
);
const sceneExportUrl = window.URL.createObjectURL(image);
console.log("The imported PSD file looks like:", sceneExportUrl);
// You can now e.g export the scene as archive with engine.scene.saveToArchive()

NodeJS Quick-Start Example

Here is a sample code for using the psd-importer in NodeJS.

// index.mjs
// We currently only support ES Modules in NodeJS
import CreativeEngine from "@cesdk/node";
import { promises as fs } from "fs";
import { PNG } from "pngjs";
import { PSDParser, createPNGJSEncodeBufferToPNG } from "@imgly/psd-importer";

async function main() {
  const engine = await CreativeEngine.init({
    license: "YOUR_LICENSE",
  });

  const psdSampleUrl =
    "https://img.ly/showcases/cesdk/cases/photoshop-template-import/socialmedia.psd";
  const psdSample = await fetch(psdSampleUrl).then((res) => res.blob());
  const psdSampleBuffer = await psdSample.arrayBuffer();
  const parser = await PSDParser.fromFile(
    engine,
    psdSampleBuffer,
    createPNGJSEncodeBufferToPNG(PNG)
  );
  await parser.parse();

  const image = await engine.block.export(
    engine.block.findByType("//ly.img.ubq/page")[0],
    "image/png"
  );
  const imageBuffer = await image.arrayBuffer();
  await fs.writeFile("./example.png", Buffer.from(imageBuffer));

  engine.dispose();
}
main();

Current Limitations

The following features are either not supported by our engine yet or have limited support:

Limitations

Descriptions of specific limitations in areas such as group handling and text formatting:

  • Support for Groups is limited, especially for groups with single members.
  • Multiple font sizes within different parts of a text layer are not supported.
  • Using multiple font families within a single text layer is not supported.
  • Text justification is not supported.

Unsupported Style Sheet Features:

Details on the unsupported advanced text styling and formatting features:

  • Diacritic Positioning: Adjusting the position of diacritical marks.
  • Kashida Length: Customizing the length of Kashida in Arabic scripts.
  • Hindi Numerals: Enabling or disabling the use of Hindi numerals.
  • Character Direction: Setting the text direction (e.g., left-to-right, right-to-left).
  • Underline Positioning: Adjusting the vertical position of the underline.
  • Fill and Stroke Order: Determining whether the fill is applied before the stroke.
  • No-Break Text: Preventing line breaks within the text.
  • Character Spacing Adjustment (Tsume): Adjusting spacing between characters.
  • Baseline Direction: Setting the direction of the text baseline (horizontal or vertical).
  • Discretionary Ligatures: Enabling or disabling discretionary ligatures.
  • Standard Ligatures: Enabling or disabling standard ligatures.
  • Strikethrough: Applying a strikethrough to the text.
  • Underline: Applying an underline to the text.
  • Font Baseline Positioning: Adjusting the baseline position of the font.
  • Baseline Shift: Vertically shifting the text baseline.
  • Kerning: Adjusting spacing between specific pairs of characters.
  • Automatic Kerning: Enabling or disabling automatic kerning.
  • Automatic Leading: Enabling or disabling automatic line spacing.

Unsupported Paragraph Features:

An outline of the unsupported paragraph-level formatting and alignment options:

  • Every Line Composer: Optimizes line breaks across the entire paragraph for better text flow.
  • Kinsoku Shori Order: Customizes character handling for Japanese text at line ends.
  • Hanging Punctuation: Allows punctuation to hang outside text margins for improved alignment.
  • Auto Leading: Automatically adjusts line spacing based on font size.
  • Glyph Spacing: Adjusts spacing between individual glyphs.
  • Word Spacing: Adjusts spacing between words.
  • Paragraph Zone: Controls alignment and indentation relative to the text frame.
  • Consecutive Hyphens Limit: Sets the maximum number of consecutive hyphens allowed.
  • Hyphenation Control: Specifies the minimum number of characters before and after a hyphen in hyphenated words.
  • Minimum Hyphenated Word Size: Defines the minimum length of a word that can be hyphenated.
  • Automatic Hyphenation: Enables or disables automatic hyphenation.
  • Space Adjustment: Adds space before and after paragraphs.
  • Paragraph Indentation: Customizes indentation for the start, end, and first line of paragraphs.

Unsupported Blend Modes:

List of blend modes not currently supported by the engine:

  • PassThrough
  • Dissolve
  • LinearBurn
  • DarkerColor
  • LinearDodge
  • LighterColor
  • VividLight
  • LinearLight
  • PinLight
  • HardMix
  • Subtract
  • Divide

License

The software is free for use under the AGPL License.