• Stars
    star
    144
  • Rank 255,590 (Top 6 %)
  • Language
    PHP
  • License
    Other
  • Created over 9 years ago
  • Updated over 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Full blown refactor of JpGraph v3.5. Distant cousin of current official package

JpGraph Community Edition v4.1.0

JpGraph Community Edition was created as a Composer friendly port of JpGraph v3.5. With time and through incremental refactorings, it became a whole different library, with PSR-1 and PSR-2 compliant codebase, namespaces and folder hierarchy enabling PSR-4 autoloading, and more.

We are now, at most, distant cousins with the current official release.

Refactoring is an ongoing effort and we ensure editions and additions don't hurt our (already poor) metrics

Scrutinizer Code Quality


What is JPGraph Community Edition?

As can be seen in their releases section, there was a six year pause in JPGraph release cycle, during which some of us had no choice but to code our way out of PHP 5.x. And thus "Community Edition" was born. From then on, this library evolved on its own and completely diverged from the official packages.

In general terms, JPGraph CE relies in PHP's thriving ecosystem. We aim to be a simple dependency you can seamlessly integrate in your app. JPGraph CE aligns with PHP Standards Reccomendations as published by the PHP Framework Interoperability Group, and when presented with the choice, will always pick an agnostic implementation over custom ones that reinvent the wheel. A lot of code has been trimmed and refactored with this purpose and a lot more is waiting to undergo such a change.

  • Distrbution through PHP's popular Packagist Registry
  • Relies in Composer, so you don't need to manually download or copy anything, nor check for platform and dependency requirements yourself.
  • PSR-4: Autoloader compliant structure. No need to resort to require or include in your code.
  • Sensible fallbacks to handle missing fonts or particular GD version features availability.
  • IDE friendly, allowing for autocompletion and go-to-definition where supported.
  • Integration pipelines checking new releases compatibility against different PHP versions
  • New or refactored code is expected to observe PSR-1 and PSR-2 coding standards (Eventually PSR-12 as well).

Comparing against the original v3.5 codebase, we also stripped examples or incomplete implementation of graph types exclusive to v3.5 pro (e.g. Barcodes).

Things that JPGraph CE is NOT

  • This library is NOT an official JPGraph package. The offcial package can be downloaded at JPGraph's downloads section of their website. They have a full featured free version with support for current and olver PHP versions.
  • Endorsed in any way by JPGraph's creator company Asial
  • A composer enabled wrapper for the official package
  • A drop-in replacement for the official package. We do not claim nor offer any kind of feature parity with the official package.

Requirements And Installation

This version requires PHP v7.2.0+. If you need to install this library package in older PHP environments please try

  • Upgrading your PHP installation. (No, really, even PHP 7.2 is past its EOL)
  • for PHP v7.0+ please try release v4.0.x
  • for PHP v5.6+ please check release v3.6.x

Install it Using composer

composer require amenadiel/jpgraph:^4

How to use

See the examples folder for working samples.

The examples work the same way you should use this library:

  • run composer install

  • require vendor/autoload.php it the top of your script

  • generate a graph with a snippet like the following

   require_once 'PATH/TO/vendor/autoload.php';

   use Amenadiel\JpGraph\Graph;
   use Amenadiel\JpGraph\Plot;

   // Create the Pie Graph.
   $graph = new Graph\PieGraph(350, 250);
   $graph->title->Set("A Simple Pie Plot");
   $graph->SetBox(true);

   $data = array(40, 21, 17, 14, 23);
   $p1   = new Plot\PiePlot($data);
   $p1->ShowBorder();
   $p1->SetColor('black');
   $p1->SetSliceColors(array('#1E90FF', '#2E8B57', '#ADFF2F', '#DC143C', '#BA55D3'));

   $graph->Add($p1);
   $graph->Stroke();
  • important make sure to instance the Graph (or Graph child class) before its content (for example, Plots). Doing this will load the global configuration to the global scope. Yeah, we know we are polluting the global scope with dozens of constants, but we are still refactoring 🀷 .

See the examples working by performing the following steps:

  • run composer install
  • run make start or php -S localhost:8000 -t Examples
  • Open your browser at http://localhost:8000

Change the config

You can override some configs set on config.inc.php by creating a .env file in your project root. See .env.example as a reference.

Contributors ✨

All Contributors

Thanks goes to these wonderful people (emoji key):


Sean Zhang

πŸ’»

Shawn McCool

πŸ’»

Vinicius Dias

πŸ’»

Paul van der Knaap

πŸ’»

Florent Morselli

πŸ’»

Tony Murray

πŸ’»

Andreas

πŸ’»

Corey Watts

πŸ’»

Alexander Rakushin

πŸ’»

Muhammad Abid

πŸ’»

WhileTrue

πŸ›

This project follows the all-contributors specification. Contributions of any kind welcome!


Wishlist

  • Get all the examples working (half of them have yet to be transformed from the old code to the new PSR-4 format)
  • Add more tests (We need to test more classes and methods besides the ones in the examples, as well as perform more assetions on the current tests)
  • Add alternative use of imagick

jpgraph_logo

Similar Projects

License

FOSSA Status

More Repositories

1

node-google-drive

Library to operate with Google Drive API v3 from Node.js, using system user tokens or personal keys
JavaScript
58
star
2

phpPgAdmin6

PHP7+ Based administration tool for PostgreSQL 9.3+
PHP
46
star
3

google-maps-documentation

in sync, versioned copy of google.maps API v3 documentation
JavaScript
22
star
4

systemjs-riot

jspm/systemjs plugin to load RiotJS tags and inline them in the bundle
JavaScript
18
star
5

pgadmin4_installer

Steps to install pgAdmin4 in any machine
Makefile
17
star
6

SlimPHPConsole

PHP-Console log writer for Slim Framework
PHP
12
star
7

systemjs-less-plugin

Translates less on the browser, builds less during build
JavaScript
9
star
8

backbone_es6

An ES6 build of Backbone, allowing for tree shaking
JavaScript
8
star
9

jquery.waitforChild

Uses mutation observer to detect when a certain child is appended to the container
JavaScript
8
star
10

turf-google-maps

A bridge to use turf along google maps API
JavaScript
7
star
11

front_screenshot

Mini library, with no dependencies, to output PNGs from maps and reports (or anything in the DOM)
JavaScript
4
star
12

ig_markerfactory

Uses canvas to dynamically generate marker images suitable for use with google maps
JavaScript
3
star
13

requirejs-riot

Deprecated: please use systemjs-riot
2
star
14

backgrid_es6

Backgrid as ES6 module, with plugins and extensions
JavaScript
1
star
15

cookiecutter-simple-python-project

A cookiecutter template for a simple python project
Python
1
star
16

jquery_helper

POC Implementation of jQuery bundled along jQuery UI and other plugins
JavaScript
1
star
17

googlemaps-loader

Loader plugin to add google maps API scripts asynchronously with AMD
JavaScript
1
star