Leftfield Posted May 10, 2024 Share Posted May 10, 2024 (edited) Ehey, aloha everyone! I have two templates: post and blog. When publishing a first-time post, I must update the (same) field date_modified on its parent (a single) template blog. I am trying it via hook, but nothing happens. This checking for status unpublished is not working for some reason too. I appreciate any help! $wire->addHookAfter("Pages::saveReady(template=post)", function($event) { $page = $event->arguments(0); $pages = $event->object; // if ($page->isNew() && $page->status->unpublished != true) { if ($page->isNew()) { $blog = wire('pages')->get('template=blog'); $blog->date_modified = $page->date_modified; $blog->save($blog->date_modified); // $blog->save(); } }); Edited May 24, 2024 by Leftfield Link to comment Share on other sites More sharing options...
wbmnfktr Posted May 10, 2024 Share Posted May 10, 2024 Could be because $page->isNew() doesn't match the page as a page is only new right after it was created. So... the moment you publish that page it is already old. $wire->addHookAfter("Pages::saveReady(template=basic-page)", function ($event) { $page = $event->arguments(0); $pages = $event->object; if ($page->isNew()) { wire()->log->save("debug", "page is new"); } else { wire()->log->save("debug", "page is NOT new"); } }); $this->addHookAfter('Pages::published', function (HookEvent $event) { $pages = $event->object; $page = $event->arguments(0); // add conditionals here wire()->log->save("debug", "page was published"); }); Second example uses this hook: Pages::published 1 1 Link to comment Share on other sites More sharing options...
Leftfield Posted May 10, 2024 Author Share Posted May 10, 2024 (edited) @wbmnfktrthanks mate!!! I count beers I owe you.... So for anyone looking at this here is the solution: $wire->addHookAfter("Pages::published(template=post)", function (HookEvent $event) { $pages = $event->object; $page = $event->arguments(0); $blog = wire('pages')->get('template=blog'); $blog->date_modified = $page->date_modified; $blog->save(); // wire()->log->save("debug", "page was published"); }); Edited May 10, 2024 by Leftfield 1 Link to comment Share on other sites More sharing options...
adrian Posted May 10, 2024 Share Posted May 10, 2024 You could also simply get the parent by using the parent property. Of course you don't need to use setAndSave() but I feel it's cleaner in a situation like this. I also like using $p rather than $p because even though the scope will prevent $page from overwriting the PW $page object, I still find it less confusing, but that's just a personal preference. $wire->addHookAfter("Pages::published(template=post)", function (HookEvent $event) { $p = $event->arguments(0); $blog = $p->parent; $blog->setAndSave('date_modified', $p->date_modified); }); Also, in case you don't know, there is a system "modified" property rather than adding a separate custom field for that. Another thought - if updating the modified date for the blog parent is just about using it to display on the website, perhaps you can just get the modified date of the most recently modified post, eg: 3 1 Link to comment Share on other sites More sharing options...
bernhard Posted May 10, 2024 Share Posted May 10, 2024 57 minutes ago, adrian said: Another thought - if updating the modified date for the blog parent is just about using it to display on the website, perhaps you can just get the modified date of the most recently modified post, eg: I thought exactly the same, but I think he wants to show the published date and not the modified date? So if anyone edited an already published blogpost the date would NOT change. At least that's what the hook does as far as I understand. Maybe this shows that the naming of "$blog->date_modified = $page->date_modified;" might not be ideal ? 1 Link to comment Share on other sites More sharing options...
adrian Posted May 10, 2024 Share Posted May 10, 2024 1 minute ago, bernhard said: but I think he wants to show the published date Then we could use the system "published" property, no? Regardless, even if there is a need for a custom date field of some sort on the post template, that could still drive that getRaw() example I posted. Not saying it's the right way to go - just highlighting some other options. 1 Link to comment Share on other sites More sharing options...
bernhard Posted May 10, 2024 Share Posted May 10, 2024 3 minutes ago, adrian said: Then we could use the system "published" property, no? Ah, didn't know that existed! thx ? Link to comment Share on other sites More sharing options...
Leftfield Posted May 10, 2024 Author Share Posted May 10, 2024 (edited) 14 minutes ago, bernhard said: but I think he wants to show the published date and not the modified date? No, mate. PW (as you all know way better than me) doesn't have the option to change the default fields published and modified. Published is constant, and Modified is changing on every page save. It doesn't suit me, so I made my date field to set a date when publishing/changing so it reflects on the sitemap and tells search engines the page has been changed on that date. Not on every save. Edited May 10, 2024 by Leftfield Link to comment Share on other sites More sharing options...
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now