Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/crazko/post-social-image
Creates images suitable for social sharing
https://github.com/crazko/post-social-image
command image open-graph social
Last synced: about 2 months ago
JSON representation
Creates images suitable for social sharing
- Host: GitHub
- URL: https://github.com/crazko/post-social-image
- Owner: crazko
- License: mit
- Created: 2019-02-11T20:47:17.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2019-08-03T07:29:21.000Z (over 5 years ago)
- Last Synced: 2024-08-13T03:05:47.712Z (5 months ago)
- Topics: command, image, open-graph, social
- Language: PHP
- Homepage:
- Size: 304 KB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
![Example Image](./docs/post-social-image.png)
A simple command line tool to generate images suitable for sharing on social media sites.
[![Travis (.org)](https://img.shields.io/travis/crazko/post-social-image.svg)](https://travis-ci.org/crazko/post-social-image)
## Installation
```
composer require crazko/post-social-images
```## Usage
```php
text($title, 120, '#E6FAFF'); // First text is always wrapped and centered
$image->text('example.com', 25, '#33F88A', Position::BOTTOM | Position::RIGHT);// More texts can be placed into image
$image->text('John Doe', 50, '#660012', Position::TOP | Position::LEFT);$path = $image->save($title, './assests/img'); // ./assets/img/my-amazing-post.png
```![Example Image](./docs/my-amazing-post.png)
### API
#### `new Image(int $width, string $background, string $font, int $padding)`
Creates new `Image` instance.
- `$width` - width of the image in px, height is calculated proportionaly 16:9
- `$background` - HEX color of the image background, e.g.: `ff8800` or `#ff8800`
- `$fontPath` - path to the font used in the image
- `$padding` - free space around the image in px#### `Image::text(string $text, int $size, string $color, ?int $position = null)`
Adds text to the image. Can be used multiple times. First one is always centered, wrapped when the text is too long and resized to always fit the image - considered as a main title.
- `$text` - given text
- `$size` - size of the text in px
- `$color` - HEX color of the text, e.g.: `ff8800` or `#ff8800`
- `$position` - position of the text in the image, use combination of `Position::TOP`, `Position::BOTTOM`, `Position::LEFT`, `Position::RIGHT`, e.g.: `Position::TOP | Position::RIGHT`#### `Image::save(string $name, string $destination)`
Saves generated image to the `$destination` with given ([webalized](https://doc.nette.org/en/2.4/strings#toc-webalize)) `$name` and returns resulting path.
#### `Image::get()`
Returns generated image.
### CLI
```
vendor/bin/create-image -o example.com ./assets/img "My amazing post"
```Resulting success message:
> Image was created in ./assets/img/my-amazing-post.png
#### Composer command
You can also [define a new command](https://getcomposer.org/doc/articles/scripts.md#writing-custom-commands) in your `composer.json` to avoid constantly typing every option:
```json
{
"scripts": {
"image": "vendor/bin/create-image --ansi -b E6FAFF -f 1E9682 -c E1738A -o example.com ./assets/img"
},
}
```and use it to create new images more easily:
```
composer image "My amazing post"
```#### Available options
Type `vendor/bin/create-image --help` to see all available options.
```
Description:
Creates a new social image.Usage:
create [options] [--]Arguments:
destination Where to save the image?
title Title of the post the image should be generated for.Options:
-w, --width=WIDTH The width of the image in px. Height is calculated proportionaly 16:9. [default: 1200]
-p, --padding=PADDING The padding of the image in px. [default: 50]
-s, --size=SIZE The size of the image title in px. [default: 100]
-b, --colorBackground=COLORBACKGROUND HEX color of the title. [default: "ffffff"]
-f, --colorForeground=COLORFOREGROUND HEX color of the image background. [default: "000000"]
-o, --origin=ORIGIN E.g. your name or the name of your blog.
-c, --colorOrigin=COLORORIGIN HEX color of the origin. [default: "000000"]
-h, --help Display this help message
-q, --quiet Do not output any message
-V, --version Display this application version
--ansi Force ANSI output
--no-ansi Disable ANSI output
-n, --no-interaction Do not ask any interactive question
-v|vv|vvv, --verbose Increase the verbosity of messages: 1 for normal output, 2 for more verbose output and 3 for debugHelp:
Creates a new social image with a defined title and optional signature.
```## Development
Fork and clone the repository, install dependencies.
```
git clone [email protected]:/post-social-images.git
cd post-social-images
composer install
```Testing commands:
- `composer ecs` - checks coding standards with [EasyCodingStandard](https://github.com/Symplify/EasyCodingStandard) library
- `composer phpstan` - runs static analysis with [phpstan](https://github.com/phpstan/phpstan)
- `composer tester` - runs tests from `./tests` with [nette/tester](https://tester.nette.org/)- `composer test` - runs all above together
- `composer fix` - fixes coding standard violations automatically## Tips
### How to add image to the site
Add following meta tags to the `` element of your page:
```html
```
All recommended tags:
```html
```
See [The Open Graph protocol](http://ogp.me/) and [Twitter Cards](https://developer.twitter.com/en/docs/tweets/optimize-with-cards/overview/abouts-cards) for more info about other meta tags.
#### Preview
Try to add your page to the https://metatags.io/ to see how would it look like with your amazing new social image when shared on Facebook, Twitter, Linkedin and others.