Download the PHP package prosopo/views without Composer

On this page you can find all versions of the php package prosopo/views. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package views

PHP Views

PHP Views is a Composer package designed to simplify templating in PHP. It introduces a model-driven approach, supports multiple namespaces, and includes a custom Blade implementation as the default template engine.

Table of Contents

1. Introduction
2. Installation and minimal usage
3. Model-driven approach
4. Views Manager
5. View Renderer
6. Contribution
7. Credits

1. Introduction

While many PHP frameworks come with their own solutions for views, there are countless PHP projects without a templating system (including CMS, like WordPress). Writing pure PHP templates can be cumbersome and error-prone. PHP Views aims to make templating simple, flexible, and accessible to anyone.

Freedom to choose your template engine

This package includes a custom Blade compiler and uses it as the default template engine. However, flexibility is key. You can integrate Twig, or any other template engine, with just a few lines of code while still enjoying the benefits of the model-driven approach and other features that PHP Views brings to the table.

Package Benefits

Usage flexibility

The strength of this package lies in its flexibility. With PHP Views, you’re free to use it in a way that best fits your project:

Benchmark

We conducted a PHP performance benchmark to compare this package with the Laravel's Blade (mocked using jenssegers/blade) and Twig. Here are the results for 1000x renders:

Contestant First Rendering, MS Cached Rendering, MS
prosopo/views (without models) 19.75 19.75 (no cache atm)
prosopo/views (with models) 43.78 43.78 (no cache atm)
illuminate/view (Blade from Laravel) 181.24 56.77 ms
twig/twig 441.13 9.47 ms

The numbers speak for themselves. In uncached rendering, even with model class-related overhead, PHP Views’ implementation significantly outperforms all competitors. While Twig offers a robust caching solution, PHP Views still delivers better performance even than Laravel's Blade engine with caching.

We used the following package versions:

Since the benchmark is included in this repository, you can easily run it locally to verify the results.

  1. git clone https://github.com/prosopo/php-views.git
  2. composer install; cd benchmark; composer install
  3. php benchmark {1000} - pass your renders count

2. Installation and minimal usage

2.1) Installation

PHP Views is distributed as a Composer package, making installation straightforward:

composer require prosopo/views

After installation, ensure that your application includes the Composer autoloader (if it hasn’t been included already):

require __DIR__ . '/vendor/autoload.php';

2.2) Minimal setup

To get started, you’ll need to create three instances: ViewTemplateRenderer, ViewNamespaceConfig, and ViewsManager.

The main configuration takes place in ViewNamespaceConfig, where you define the folder for your templates and the root namespace for the associated models.

2.3) Model definition

Now you're ready to create your first model. Similar to many frameworks, such as Laravel, this package embraces a model-driven approach to templates.

Each template is paired with its own Model, where the Model's public properties and methods act as arguments available within the template.

Model class must extend the BaseTemplateModel class or implement the TemplateModelInterface:

Model template (Blade is used in this example):

As you can see, all the public properties of the model are accessible within the template, including nested models like $company. This also enables you to call their public methods directly within the template.

The BaseTemplateModel class which we inherited overrides the __toString() method, allowing inner models to be rendered as strings using Blade echo statements with the HTML support. For instance:

{!! $innerModel !!} part of the template will render the model and print the result.

Naming clarification: this package does not require the Model suffix in the names of model classes. In this document, we use the Model suffix for class names purely for demonstration purposes.

2.4) Automated templates matching

The built-in ModelTemplateResolver automatically matches templates based on the Model names and their relative namespaces. This automates the process of associating templates with their corresponding Models.

Example:

We define the root templates folder along with the models root namespace in the ViewsNamespaceConfig (as we already did above):

Naming Note: Use dashes in template names, as camelCase in Model names is automatically converted to dash-separated names.

2.5) Usage

The ViewsManager instance (which we created during the setup) provides the createModel and renderModel methods.

You can create, set values, and render a Model in a single step using the callback argument of the renderView method, as shown below:

This approach enables a functional programming style when working with Models.

Multi-step creation and rendering

When you need split creation, call the makeModel method to create the model, and then render later when you need it.

References Advice

The ViewsManager class implements three interfaces: ViewNamespaceManagerInterface for registerNamespace, ModelFactoryInterface for createModel, and ModelRendererInterface for renderModel.

When passing the ViewsManager instance to your methods, use one of these interfaces as the argument type instead of the ViewsManager class itself.

This approach ensures that only the specific actions you expect are accessible, promoting cleaner and more maintainable code.

That's it! You’re now ready to start using the package. In the sections below, we'll dive deeper into its configuration and implementation details.

3. Model-driven approach

This package embraces a model-driven approach to templates. Each template is paired with its own Model, where the Model's public properties and methods act as arguments available within the template.

Model class must extend the BaseTemplateModel class or implement the TemplateModelInterface:

Public model properties intended for use in the template must have a defined type. By default, any public properties without a type will be ignored.

Naming clarification: This package does not require the Model suffix in the names of model classes. In this document, we use the Model suffix for class names purely for demonstration purposes.

3.1) Benefits

  1. Typed variables: Eliminate the hassle of type matching and renaming associated with array-driven variables.
  2. Reduced Routine: During object creation, public fields of the model without default values are automatically initialized with default values.
  3. Enhanced Access: Public methods are made available to the template alongside the variables.
  4. Unified Interface: Use the TemplateModelInterface in your application when accepting or returning a Model to maintain flexibility and avoid specifying the exact component.

3.2) Inner models

Model can contain one or more nested models or even an array of models. To allow flexibility in deciding the model type later, define its type as TemplateModelInterface.

This approach enables you to assign any model to this field during data loading. However, if you want to restrict the field to a specific model, you can define its exact class type:

By default, inner models are passed to templates as objects, enabling you to call their public methods directly. For example:

{{ $$innerModel->calc($localVar) }}.

The BaseTemplateModel class overrides the __toString() method, allowing inner models to be rendered as strings using echo statements, which supports HTML output. For instance:

{!! $innerModel !!} will render the model and print the result.

If you prefer, you can configure the ViewsManager to pass models as strings instead of objects. Refer to the ViewsManager section for details.

3.3) Custom property defaults

Note: In the TemplateModel class, in order to satisfy the Model factory, the constructor is marked as final. If you need to set custom default values, consider using one of the following approaches:

Tip: If your app Models require additional object dependencies, you can override the PropertyValueProvider module to integrate with a Dependency Injection container like PHP-DI. This allows model properties to be automatically resolved while object creation by your application's DI system.

3.4) Custom Model implementation (advanced usage)

The only requirement for a Model is to implement the TemplateModelInterface. This means you can transform any class into a Model without needing to extend a specific base class, or even define public properties:

Note: If you plan to define inner models, remember that the default __toString() implementation is not provided. You will need to either implement it yourself or enable the option to pass models as strings in the ViewsManager configuration:

When this option is enabled, the renderer will automatically convert objects implementing TemplateModelInterface into strings before passing them to the template.

4. Views Manager

The ViewsManager class provides the registerNamespace, createModel and renderModel methods. It acts as a namespace manager and brings together different namespace configurations.

Each ViewNamespace has its own independent setup and set of modules. E.g. among these modules is the ModelTemplateProvider, which automates the process of linking models to their corresponding templates.

4.1) Setup

4.2) Single-step Model creation and rendering

You can create, set values, and render a Model in a single step using the callback argument of the renderView method, as shown below:

This approach enables a functional programming style when working with Models.

4.3) Multi-step creation and rendering

When you need split creation, use the factory to create the model, and then render later when you need it.

Advice: The ViewsManager class implements three interfaces: ViewNamespaceManagerInterface (for registerNamespace), ModelFactoryInterface (for createModel), and ModelRendererInterface (for renderModel).

When passing the ViewsManager instance to your methods, use one of these interfaces as the argument type instead of the ViewsManager class itself.

This approach ensures that only the specific actions you expect are accessible, promoting cleaner and more maintainable code.

4.4) Automated templates matching

The built-in ModelTemplateResolver automatically matches templates based on the Model names and their relative namespaces. This automates the process of associating templates with their corresponding Models.

Example:

We define the root templates folder along with the models root namespace in the ViewsNamespaceConfig:

Naming Note: Use dashes in template names, as camelCase in Model names is automatically converted to dash-separated names.

Tip: In case this approach doesn't work for your setup, you can override the ModelTemplateResolver module to implement your own logic. In case the reason is the name-specific only, consider overriding the ModelNameResolver module instead.

4.5) Custom modules

By default, the registerNamespace class creates module instances for the namespace using classes from the current package.

If you need to override the default module behavior, you can define a custom implementation in the configuration and the package will use the specified implementation.

Tip: You can see the full list of the modules in the ViewNamespaceModules class.

Example: Using Twig as a Template Renderer (instead of the built-in Blade)

You can override any namespace module in the following way:

Note: The package includes only the Blade implementation. If you wish to use a different template engine, like Twig, you need to install its Composer package and create a facade object, as demonstrated above.

4.6) Namespace mixing

The ViewsManager class not only supporting multiple namespaces, but also enabling you to use Models from one namespace within another, preserving their individual setup.

Example of multi-namespace usage:

Suppose you have registered a namespace for Twig templates:

This namespace includes a Button model and a button.twig template:

Button's model:

Button's template:

Additionally, you registered a namespace for Blade templates:

with a Popup model:

Popup's model:

Now is the cool part: you can safely use the App\Twig\ButtonModel class as a property of the App\Blade\PopupModel class, so it looks like this:

Popup's model:

Now you can use the buttonModel in the popup's template:

When you call ViewsManager->makeModel() for the PopupModel class:

  1. The App\Blade\PopupModel instance will be created using the ModelFactory from the App\Blade namespace.
  2. During automated property initialization, an instance of App\Twig\ButtonModel will be created using the ModelFactory from for the App\Twig namespace.

This design allows you to seamlessly reuse models across different namespaces while respecting the specific configuration of each namespace.

Namespace resolution also occurs when you call ViewsManager->renderModel(). In this example:

5. View Renderer

ViewTemplateRenderer is the class responsible for rendering templates in this package. By default, it integrates the Blade compiler, but it is fully customizable. You can replace the Blade compiler with your own implementation or use a simple stub to enable support for plain PHP template files.

5.1) Built-in Blade integration

Blade is an elegant and powerful template engine originally developed for Laravel. Unlike Twig, Blade embraces PHP usage rather than restricting it. It enhances templates with syntax sugar (which we all love), making them clean and easy to read.

Blade introduces special shorthand tokens that simplify the most cumbersome syntax constructions, while still being fully-fledged PHP with access to all its functions and capabilities.

Unfortunately, Blade isn't available as a standalone package, so this package includes its own Blade compiler. It provides full support for Blade's key features while remaining completely independent of Laravel.

The following Blade tokens are supported:

  1. Displaying: {{ $var }} and {!! $var }}
  2. IF Conditions: @if, @else, @elseif, @endif
  3. Switch conditions: @switch, @case, @break, @default, @endswitch.
  4. Loops: @foreach, @endforeach, @for, @endfor, @break.
  5. Helpers: @selected, @checked, @class.
  6. PHP-related: @use, @php, @endphp.

Visit the official Blade docs to learn about their usage.

Notes on the standalone Blade implementation

You may have come across packages that attempt to adapt the official Blade engine by creating stubs for its Laravel dependencies, such as the jenssegers/blade package. However, we chose not to adopt this approach for several reasons:

Thanks to great Blade's conceptual design, our compiler implementation required fewer than 200 lines of code.

5.2) View Renderer setup

Tip #1: by default, BladeTemplateRenderer is configured to work with files, but you can also switch it to work with plain strings:

Tip #2: As you see, the built-in TemplateRenderer implementation is fully standalone and independent of the Views class. This means that even if you can't or don't want to use the model-driven approach, you can still utilize it as an independent Blade compiler.

5.3) Available View Renderer settings

The ViewTemplateRenderer supports a variety of settings that let you customize features such as escaping, error handling, and more:

5.4) Custom View Renderer modules

By default, the ViewTemplateRenderer creates module instances using classes from the current package, including the Blade compiler.

If you need to override the default module behavior, you can define a custom implementation in the configuration. The ViewTemplateRenderer will use the specified implementation.

Tip: You can see the full list of the modules in the ViewTemplateRendererModules.

Example: Overriding the default Blade compiler to use plain PHP views

Now this namespace is configured to deal with plain PHP template files, while having all the package features, including model-driven approach and template error handling.

6. Contribution

We would be excited if you decide to contribute 🤝

Please read the for-devs.md file for project guidelines and agreements.

7. Credits

This package was created by Maxim Akimov during the development of the WordPress integration for Prosopo Procaptcha.

Procaptcha is a privacy-friendly and cost-effective alternative to Google reCaptcha.

Consider using the Procaptcha service to protect your privacy and support the Prosopo team.


All versions of views with dependencies

PHP Build Version
Package Version
Requires php Version ^7.4|^8.0
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package prosopo/views contains the following files

Loading the files please wait ....