Book Image

concrete5 Cookbook

Book Image

concrete5 Cookbook

Overview of this book

concrete5 is an increasingly popular open source content management system because of its incredible and easy-to-use interface. But, it also comes complete with a robust PHP framework, allowing web developers to create custom websites and applications with ease. "concrete5 Cookbook" is a practical collection of solutions to tasks that both novice and experienced concrete5 developers face on a regular basis. Readers will learn multiple subjects, including full blueprints for developing an event calendar add-on and an image gallery block. Developers new to concrete5 will quickly learn how to customize concrete5 to their needs, and seasoned pros will find it an excellent quick reference for performing specific tasks. "concrete5 Cookbook" will transform ordinary PHP developers into concrete5 experts capable of bending concrete5 to their will and unleashing the true power of this up-and-coming content management system. Throughout the course of over 140 recipes and 3 bonus project blueprint chapters, PHP developers will learn how to create custom blocks and dashboard interfaces as well as programmatically work with pages, files, users, permissions, and more. Discover the built-in Active Record support that makes working with databases simple and maintainable. Readers will also learn how to take advantage of the numerous helper classes included in concrete5, and will dive deep into the concrete5 MVC framework to create powerful custom websites and applications. Tie together all of the concepts learned in the recipes with 3 bonus chapters featuring complete blueprints to create a calendar add-on, an image gallery block type, and tips on how to sell your themes and add-ons for money! "concrete5 Cookbook" is a complete collection of recipes to solve the most common (and some not-so-common) tasks that concrete5 developers will face on a regular basis.
Table of Contents (19 chapters)
concrete5 Cookbook
Credits
About the Author
About the Reviewers
www.PacktPub.com
Preface
Index

Updating an existing page


Updating pages is similar to creating them in that you must first pass in an associative array containing all of the data that you wish to update on the page.

Getting ready

In this recipe, we will be modifying a page with the path of /about. We created that page in the previous recipe, but if it does not exist on your system, please adapt the code to your needs.

How to do it...

In this example, we will update the name of the About page. The steps are as follows:

  1. First, we need to load the Page object by its path.

    $page = Page::getByPath('/about');
  2. Create an associative array with the data that you wish to update.

    $data = array(
      'cName' => 'About Our Company'
    );
  3. Pass the data array into the $page object's update function.

    $page->update($data);
  4. Output a success message and exit the process.

    echo 'done!';
    exit;

How it works...

The update function updates the necessary tables in the database with the newly specified information. concrete5 will also rescan all permissions for this page and all of the related page paths. When the function is complete, the on_page_update event is fired, which you can write custom code to listen to and perform custom actions when a page is updated. Listening to system events is covered in a later chapter.

There's more...

Just like creating a page, you will need to pass an associative array to the update() function in order to update an existing page. You can use all of the fields specified in the previous recipe for adding a page, in addition to these other optional fields.

Attribute

Description

ctID

This is the numerical ID of a page type to change the page to. Supply this field to change the page type of a given page.

cCacheFullPageContent

A Boolean that specifies if the page should support full page caching (some block types do not support full page caching, so only use this when the blocks on that page offer full caching support).

cCacheFullPageContentOverrideLifetime

A string to tell concrete5 how the cache lifetime should perform. Possible values are default, custom, or forever.

cCacheFullPageContentLifetimeCustom

A setting in minutes as to how long the cache should last when the override mode is set to custom.

See also

  • The Creating a page type recipe