bitandblack / idml-json-converter
Convert Adobe InDesign Markup Language Files (IDML) into JSON and JSON into IDML.
Fund package maintenance!
Buymeacoffee
Requires
- php: >=8.2
- ext-dom: *
- ext-json: *
- ext-zip: *
- bitandblack/composer-helper: ^1.0
- bitandblack/helpers: ^1.8 || ^2.0
- maennchen/zipstream-php: ^3.0
- symfony/console: ^6.0 || ^7.0
Requires (Dev)
- phpstan/phpstan: ^1.0
- phpunit/phpunit: ^11.0
- rector/rector: ^1.0
- symplify/easy-coding-standard: ^12.0
README
Bit&Black IDML-JSON Converter
Convert Adobe InDesign Markup Language Files (IDML) into JSON and JSON into IDML.
Motivation
Using this converter allows a simple handling of IDML files in PHP.
- Extracting information is easy, because you only need to navigate through an array, that holds the whole content of an IDML file.
- Manipulating information is easy, because you can change all values by your needs. This allows handling of placeholders, that have been added in Adobe InDesign.
Example
If you want to have a quick look at how the JSON looks like, navigate to the example folder and take the output.json file.
Installation
This library is written in PHP and made for the use with Composer. Be sure to have both of them installed on your system.
Add the library then to your project by running $ composer require bitandblack/idml-json-converter
.
Usage
From command line
This library comes with two commands that allow the conversion of IDML into JSON and JSON into IDML via CLI.
The CLI is located under bin/idml-json-converter
or, if you installed the library as Composer dependency, under vendor/bin/idml-json-converter
.
Use the command
idml:convert:json
to convert an IDML file into JSON.json:convert:idml
to convert a JSON file into IDML.
Add option -h
to get more information about the usage of a command.
Custom
Instead of using the CLI, it is also possible to convert the contents manually.
Converting an IDML file
Use the IDML class and initialize it with the path to an IDML. Calling the getContent()
method will return its content as an array.
<?php use BitAndBlack\IdmlJsonConverter\File\IDML; $idml = new IDML('/path/to/file.idml'); $idmlContent = $idml->getContent();
The array contains the name of each file and its content then. For example:
[
'mimetype' => 'application/vnd.adobe.indesign-idml-package',
'designmap.xml' => [
'@name' => 'Document',
'@attributes' => [
'DOMVersion' => 18.0,
'Self' => 'd',
'StoryList' => [
0 => 'ufa',
1 => 'u126',
2 => 'u97',
],
'Name' => 'file.indd',
[...]
You can use the getJSON()
method to return the content converted into a JSON string.
The JSON content will be prettified per default. You can disable that behaviour, for example, to save space on your file system: $idml->setPrettifyOutput(false)
.
Converting JSON content
Use the JSON class and initialize it with an array of your content. The array needs to have the same structure a shown above. Calling the getIDML()
method will return its content as an string, that can be saved as IDML file (for example by using file_put_contents()
).
<?php use BitAndBlack\IdmlJsonConverter\File\JSON; $content = [ 'mimetype' => 'application/vnd.adobe.indesign-idml-package', 'designmap.xml' => [ '@name' => 'Document', '@attributes' => [ 'DOMVersion' => 18.0, 'Self' => 'd', 'StoryList' => [ 0 => 'ufa', 1 => 'u126', 2 => 'u97', ], 'Name' => 'file.indd', [...] ]; $json = new JSON($content); $idmlContent = $json->getIDML(); file_put_contents( '/path/to/file.idml', $idmlContent );
Other Tools
Bit&Black offers some more tools to handle IDML files:
- The IDML-Creator library that allows creating IDML content natively in PHP in an object-oriented way. (A demo is available here.)
- The IDML-Writer library that can write IDML content into a valid IDML file.
- The IDML-Validator library that allows validating IDML files against the official schema from Adobe.
Feel free to visit www.idml.dev for more information!
Help
If you have any questions feel free to contact us under hello@bitandblack.com
.
Further information about Bit&Black can be found under www.bitandblack.com.