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

Installing the package


Open the package controller (located at /packages/cookbook_events/controller.php) in your code editor. Add a new method to the controller class named install. It should look like the following code snippet:

public function install() {
    $pkg = parent::install();
    // Add the dashboard pages
    $mainPage = SinglePage::add('/dashboard/cookbook_events', $pkg);
    $listPage = SinglePage::add('/dashboard/cookbook_events/list', $pkg);
    $addPage = SinglePage::add('/dashboard/cookbook_events/add', $pkg);
    // install the block type
    BlockType::installBlockTypeFromPackage('cookbook_events', $pkg); 
}

What's going on here? Well, if you recall, we created three single pages with controllers to be used for the dashboard interface. These pages will need to be added to the site map, so we hook into the package's installation routine to make sure that they get installed when the package is installed.

Next, we also install the block type. This will ensure that our block is available to use on the frontend of the website.

When concrete5 installs the package, it will run our package's db.xml file, creating the database tables defined in there. This will allow our package to remain completely portable, and it can be installed in any concrete5 website.

Let's install the package now.

Installing the package to the dashboard

Visit the package installation page on your concrete5 site, located at /dashboard/extend/install/. You should see the events package awaiting installation, as shown in the following screenshot:

Click on the Install button on the package. If all goes well, the package will be installed! We should have some new pages on the dashboard, so visit /dashboard/cookbook_events.

Did you notice what happened? When we visit the /dashboard/cookbook_events page, it redirects us to /dashboard/cookbook_events/list/. This is intentional. The way that the dashboard is organized requires add-ons to have a parent page. That will allow our Event List and Add Event single pages to appear in the dashboard menu correctly.

This list page is still completely empty. Let's add some HTML to it and fill it out.