Agile UI is a high-level PHP framework for creating User Interfaces in Web Apps
Regardless of which full-stack framework you are using - with Agile UI you won't need to write or know HTML, CSS or JavaScript for the basic tasks, such as creating the CRUD or the Form. Agile UI abstracts interaction between the browser and your application into a next-gen Object-Oriented interface with powerful abstraction.
Agile UI does not impose on you how you must write the code, it focuses on building UI. Here are few examples that show you what you can do.
$app = new \atk4\ui\App('My App');
$app->initLayout(new \atk4\ui\Layout\Admin());
$db = \atk4\data\Persistence::connect($DSN);
class User extends \atk4\data\Model {
public $table = 'user';
function init() {
parent::init();
$this->addField('name');
$this->addField('email', ['required'=>true]);
$this->addField('password', ['type'=>'password']);
}
}
$app->layout->add(new \atk4\ui\CRUD())
->setModel(new User($db));
A total of 15 lines to create a fully working Admin system with a CRUD:
Agile UI is not for admin systems only. It can be used to render your front-end UI too. Lets look at how to create a simple user registration page in.
$app = new \atk4\ui\App('My App');
$app->initLayout(new \atk4\ui\Layout\Centered());
$db = \atk4\data\Persistence::connect($DSN);
$form = $app->layout->add(new \atk4\ui\Form());
$form->setModel(new User($db));
$form->buttonSave->set(['Register', 'icon'=>'right arrow']);
$form->onSubmit(function($form){
$u = $form->model->newInstance()->tryLoadBy('email', $form->model['email']);
if ($u->loaded()) {
return $form->error('email', 'There is already account with this email.');
}
$form->model->save();
return $form->success('Thank you. You may login now.');
});
Again - the result is beautiful and interractive:
With some knowledge and training you will be able to build entire business-class applications just within few hours.
- Warehouse app - source: https://github.com/atk4/warehouse
- Warehouse app - demo: https://atk-warehouse.herokuapp.com (free hosting, so wait 5 seconds)
WARNING: this specification is intentionally kept simple for demonstration purposes.
Conventionally you have to work with ORMs or direct data queries. Agile UI relies on a entirely different class framework for database persistence - Agile Data. Not only it has all the benefits of ORM, but it also addresses all the faults and shortcomings to deliver powerful features like:
- Aggregation, scoping, behaviours, audit and custom actions
- NoSQL and RestAPI persistence support for Cloud Databases and Services
- SQL Expressions, Deep traversal and working with multiple persistences
Through tight integration with Agile Data it makes it possible for your Forms to automatically explore relations and provide values for drop-downs:
Agile UI has been developed from ground-up to be extensible in a whole new way. Each add-on delivers wide range of classes you can incorporate into your application without worrying about UI and Data compatibility.
Components present a UI element which you can place anywhere in your layout. How about a UI for performing all user management operations - reset password, block account or edit user data:
$user_admin = $app->layout->add(new \atk4\login\UserAdmin(new User($db)));
What about also adding a button for a popup to send a custom message to a user implemented in entirely different add-on?
$user_admin->addAction(\atk4\sendgrid\Actions\SendUserMessage());
Even entire parts of your applications can be provided by add-on. The following code adds Log-in, Registration and Password reminder for your application:
$app->add(new \atk4\login\Auth([
new User($db),
'reminder'=>true, 'register'=>true
'outbox' = new \atk4\sendgrid\Outbox(['key'=>$apiKey])
]));
An add-on can add new menu items. It does not happen automatically but through a very simple line of code:
$auth->addChangePassword($app->layout->menu_user);
There are many other things you can extend:
- application layouts (e.g. Admin and Centered)
- form fields (e.g. CheckBox and Calendar)
- table columns (e.g. Status and Links)
- action-column actions (e.g. Button, Expander)
- data types (e.g. money, date)
- persistences (APIs and Services)
- models (e.g. User, Country)
Because Agile UI takes care of the hard work, each add-on is very minimalistic and does not contain anything unnecessary. Your application will remain lean and you always have option to customize.
Agile UI comes with many built-in components;
Component | Description | Introduced |
---|---|---|
View | Template, Render Tree and various patterns | 0.1 |
Button | Button in various variations including icons, labels, styles and tags | 0.1 |
Input | Decoration of input fields, integration with buttons. | 0.2 |
JS | Assign JS events and abstraction of PHP callbacks. | 0.2 |
Header | Simple view for header. | 0.3 |
Menu | Horizontal and vertical multi-dimensional menus with icons. | 0.4 |
Form | Validation, Interactivity, Feedback, Layouts, Field types. | 0.4 |
Layouts | Admin, Centered. | 0.4 |
Table | Formatting, Columns, Status, Link, Template, Delete. | 1.0 |
Grid | Toolbar, Paginator, Quick-search, Expander, Actions. | 1.1 |
Message | Such as "Info", "Error", "Warning" or "Tip" for easy use. | 1.1 |
Modal | Modal dialog with dynamically loaded content. | 1.1 |
Reloading | Dynamically re-render part of the UI. | 1.1 |
Actions | Extended buttons with various interactions | 1.1 |
CRUD | Create, List, Edit and Delete records (based on Advanced Grid) | 1.1 |
Tabs | 4 Responsive: Admin, Centered, Site, Wide. | 1.2 * |
Breadcrumb | Push links to pages for navigation. Wizard. | 1.3 * |
Items, Cards | Responsive Items and Card implementaiton. | 1.4 * |
Wizard | Multi-step, wizard with temporary data storing. | 1.5 * |
-- * Component is not implemented yet.
All bundled components are free and licensed under MIT license. They are installed together with Agile UI.
External and 3rd party components may be subject to different licensing terms.
In your command line type composer require atk4/ui
.
Afterwards, use this code to see a Hello World message:
require "vendor/autoload.php";
$app = new \atk4\ui\App('My First App');
$app->initLayout('Centered');
$app->layout->add('HelloWorld');
That's right! We have Hello World component!! When you are ready to do something bit more advanced:
require "vendor/autoload.php";
$db = new \atk4\data\Persistence_SQL('mysql:dbname=test;host=localhost','root','root');
$app = new \atk4\ui\App('My Second App');
$app->initLayout('Admin');
$m_comp = $app->layout->menu->addMenu(['Layouts', 'icon'=>'puzzle']);
$m_comp->addItem('Centered', 'centered');
$m_comp->addItem('Admin', 'admin');
$m_comp = $app->layout->menu->addMenu(['Component Demo', 'icon'=>'puzzle']);
$m_form = $m_comp->addMenu('Forms');
$m_form->addItem('Form Elements', 'from');
$m_form->addItem('Form Layouts', 'layout');
$m_comp->addItem('CRUD', 'crud');
$app->layout->leftMenu->addItem(['Home', 'icon'=>'home']);
$app->layout->leftMenu->addItem(['Topics', 'icon'=>'block layout']);
$app->layout->leftMenu->addItem(['Friends', 'icon'=>'smile']);
$app->layout->leftMenu->addItem(['Historty', 'icon'=>'calendar']);
$app->layout->leftMenu->addItem(['Settings', 'icon'=>'cogs']);
$f = $app->layout->add(new \atk4\ui\Form(['segment']));
$f_group = $f->addGroup('Name');
$f_group->addField('first_name', ['width'=>'eight']);
$f_group->addField('middle_name', ['width'=>'three']);
$f_group->addField('last_name', ['width'=>'five']);
$f_group = $f->addGroup('Address');
$f_group->addField('address', ['width'=>'twelve']);
$f_group->addField('zip', ['Post Code', 'width'=>'four']);
$f->onSubmit(function ($f) {
$errors = [];
foreach (['first_name', 'last_name', 'address'] as $field) {
if (!$f->model[$field]) {
$errors[] = $f->error($field, 'Field '.$field.' is mandatory');
}
}
return $errors ?: $f->success('No more errors', 'so we have saved everything into the database');
});
For more examples simply look into demo folder.
If you need to render only one component without boilerplate HTML, use render() method.
<head>
<link rel="stylesheet" type="text/css" href="http://semantic-ui.com/dist/semantic.css">
<script src="https://code.jquery.com/jquery-3.1.1.js"></script>
<script src="http://semantic-ui.com/dist/semantic.js"></script>
</head>
<body>
<?php
$component = new \atk4\ui\HelloWorld();
echo $component->render();
?>
</body>
Because Agile UI makes active use of Agile Core and Agile data, I'm linking all related documentation here:
If anything is unclear or you want to get in touch with other awesome people who use Agile UI:
- Forum - use label Agile UI or Agile Data.
- Developer Gitter Live Chat - if you wish to say Thanks to those who created Agile UI (for free!)
What makes this UI toolkit stand out from the others UI libraries is a commitment to bring rich and interractive web components that can be used for 90% of web applications without any custom-HTML/JS. Additionally, Agile UI provides a very controlled and consistent ways to develop "add-ons" that include visual components and other re-usable elements.
To achieve its goal, Agile UI offers both the tools for creating components and a wide selection of built-in components that provides the "minimum standard Web UI":
Agile UI follows 'best development practices' and looks to create an eco-system of 3rd party "UI components" that follow the Web UI standard solving issues such as:
- Incompatible HTML code produced by and excessive CSS/JS assets
- Differences in UI styles between your main theme and add-on UI
- Extensibility standard of all UI components based on principles of Dependency Injection, Template Injection and Inheritance
- Full control over JavaScript events and integration with jQuery and its plugins
- Controlled access between UI componets and domain model data with persistence abstraction
- And most importantly: a responsive and modern interface based on Semantic UI CSS
Q: HTML-generating frameworks are lame and inefficient, real coders prefer to manually write HTML/CSS in Twig or Smarty.
Agile UI was created for those who are in a hurry and not immediately concerned about the shades of their UI buttons. We have created a solid looking UI and diverse set of components that, like all applications, can be adapted and released with any UI.
Our goal was to create an out-of-the-box UI which you can "use", not "reinvent".
Q: What about Angular-JS, VueJS and all the other JS frameworks?
We went with the default pattern that allows you to write the entire application in ONE language: PHP.
However, the "component" in Agile UI does not conflict if you choose to use a different JavaScript framework. We found that jQuery and its plug-ins are most suitable for our design patterns. However, you can build a highly interractive component that relies on a different JavaScript frameworks or principles.
Q: I used "X" component framework and found it extremely limiting.
In the past, many UI / Component frameworks have been unable to find a good balance between flexiblity and convenience. Some out-of-the-box CRUD systems are too generic while other Form-builders are just too overengineered and unattractive.
Agile UI follows these core principles in it's design:
- Instead of focusing on generic HTML, create HTML for a specific CSS framework (Semantic UI)
- Allow developers to use all the features of CSS framework without leaving PHP
- No custom proprietary JS code. Keep all the HTML simple
- Allow developers to customise or extend components
- Keep Agile UI as a open-source project under MIT license
Following those principles gives us the perfect combination of flexibility, elegance and performance.
Q: I prefer Bootstrap CSS (or other CSS) over Semantic UI
We considered several CSS frameworks. We decided to focus on Semantic UI implementation as our primary framework for the following reasons:
- Great theming and customisation variables
- Clear patterns in class definitions
- Extensive selection of core components
- jQuery and JavaScript API integrations
Bearing in mind the popularity of Bootstrap CSS, we are working towards an extension that will allow you to switch your entire UI between Semantic UI and Bootstrap in the future.
While many UI toolkits focus on giving you ready-to-use advance components, we produced a foundation of basic ones as building blocks then create more advanced components that are easily integrated.
- Rendering HTML - Agile UI is about initializing UI objects then rendering them. Each component is driven by the UI logic and all play a vital part in the Render Tree.
- Templates - We know that as developer you want control. We offer the ability to create custom templates for custom Views to improve performance and memory usage.
- Composite Views - This allows View object to implement itself by relying on other Views.
- JavaScript actions - This technique is designed to bind PHP Views with generic JavaScript routines and also to eliminate the need for you to write custom JavaScript code (e.g.
('#myid').dropdown();
). - JavaScript events - JS actions can be asigned to events. For instance, you can instruct a "Button" object to refresh your "Grid" object in a single line of PHP.
- Buttons, Fields, Dropdown, Boxes, Panels, Icons, Messages - All those basic Views can be used 'out-of-the-box' and are utilising principles described above to remain flexible and configurable.
- Callbacks - A concept where a client-side component's rendering can execute an AJAX request to its PHP code triggering a server-side event. Agile UI ensures full isolation and robustness with this approach.
- Agile Data - Integration with data and business logic framework allows you to structure your growing PHP application's business logic properly and conforming to best practices of web development.
- Form - Culmination of concepts "callbacks", "composite views" and reliance on a dozen basic views creates a very simple way to create a modern and flexible Form implementation. Capable of rendering, submitting it's own data back, handling errors and server-side validation just in a few lines of PHP code - Form is the most elegant "Form Builder" you will find for PHP.
- Grid and Lister - An interractive and extensible UI component for outputing your data as a table or as a formatted list. When you have a lot of records to render, those components will prove to be very performance efficient.
- Dialogs - Introduces ability for you to use pop-ups and JavaScript dialog frame to reveal underlying UI.
- CRUD - A composite view that combines Form, Dialogs and Grids to create a fully interractive interface for managing your Model Entity data. Extensible and compatible with various add-ons, you will find CRUD to be a most efficient way to build your Admin system.
- Layouts, Menus, Pages, Tabs, Accordion - Several objects to create a bigger picture and link together the entire UI of your application.
- Application - This is an abstract interface that can be implemented using your full-stack framework of choice. The "App" class is built for stand-alone applications. For any other framework, a custom application class can be provided to make the entire UI section adjust accordingly.