官术网_书友最值得收藏!

  • concrete5 Cookbook
  • David Strack
  • 368字
  • 2021-08-13 16:15:59

Moving a page

The concrete5 sitemap is a great tool for managing the page hierarchy of your website. It lets you arrange the order of pages, and even drag-and-drop pages to different areas of the site. Thankfully, you aren't limited to using the graphical interface to move pages around the site. You can also rearrange pages dynamically in your custom concrete5 applications.

Getting ready

In this example, we are going to move a Careers page underneath the About Us page. Before we can move a page, we need to have the Page object of the new parent page that we are moving the current page to.

This exercise assumes that pages exist at both /about and /careers in your concrete5 site. You can create those pages through the concrete5 interface, or adapt the code in this recipe to work with pages that exist on your own site.

How to do it...

The steps for moving a page are as follows:

  1. Open /config/site_post.php, as that is a safe place to play with some random code.
  2. First, load the About Us page, which is where the Careers page will be moved to.
    $newParent = Page::getByPath('/about');
  3. Now, we need to load the careers page that we are moving.
    $careersPage = Page::getByPath('/careers');
  4. Finally, call the move function on the careers page, passing it the new parent page and an optional Boolean which tells concrete5 if we want to save the old page path as well as the new one.
    $careersPage->move($newParent, true);

How it works...

The move function is very easy to use. You only need to provide one parameter, which is a Page object of the new parent that you are moving the page under. There is an optional second parameter to indicate if you wish to retain the old page path in addition to the current one. That parameter defaults to false.

Once the page is moved, it will inherit the permissions of the new parent page (if the page does not have its own permissions set explicitly).

Once the page is moved, the event on_page_move is fired.

See also

  • Listening to system events in Chapter 9, System Events and Advanced Configuration
  • The Getting a Page object by its path recipe
主站蜘蛛池模板: 绵阳市| 健康| 惠安县| 新野县| 原阳县| 衢州市| 玉龙| 泾源县| 灵川县| 公主岭市| 凤台县| 西和县| 汕头市| 南川市| 郸城县| 博客| 嵩明县| 兴宁市| 天峻县| 砀山县| 永州市| 牡丹江市| 任丘市| 新昌县| 咸丰县| 晋州市| 临沭县| 贞丰县| 扎鲁特旗| 临清市| 陈巴尔虎旗| 昌吉市| 石首市| 安丘市| 孟津县| 西充县| 太白县| 舟曲县| 勐海县| 玛纳斯县| 宣化县|