Ce fil est résolu. Voici une description du problème et la solution proposée.
Problem:
Client wants to use Toolset Form notifications as contact forms, without storing the submitted posts in the database.
Solution:
Forms will always publish a post. If you don't want those posts to be retained, you could
1. add post expiration and have the posts trashed within minutes of them being published. This won't delete them, you would need to use some kind of utility to routinely empty the trash; or
2. use the CRED API to run some code once the form had been submitted and then delete the post. The latest effective hook that could be used in this case would be the cred_notification_recipients hook.
Is it the way to create form what will use data from CPT, but will not create posts?
EXPLANATION
CPT (Hotels) have child post (Rooms). CRED Booking form should to use data from CPTs (ie - from Rooms > Room Types for specific/current parent post - ie Hotel XXX1 and from Hotels > owner Email - to be able to send notification).
Here are two questions:
1) (less important) Can I add non existing field(s) to form (as I don't want post creation)? I wrote that it is less important as I guess that I can to use any of available fields and to 'mask' titles in CRED, as for final form submitted result, I want that form will not create the post (so, if next is possible). However, it is also not so big deal to get another simple child CPT for form creation results (as it will not be populated by posts).
Is it right?
2) How to disable creation of the posts by the form (I guess that I can manually change 'Status of the post after submitting the form:' to not available option in dropdown > 'Delete', as that is basically all what I want)?
REASONS FOR REQUEST
I don't want to store thousands (or much more) of bookings (posts) on the server, as goal of the project is not to do it. it is only need for simple service of 'Booking service' with only feature of 'Email notifications'.
Les langues: Anglais (English )Espagnol (Español )
Fuseau horaire: Europe/London (GMT+00:00)
Hi Ljuba
CRED Forms will always publish a post, that's what they are for.
If you want to use the notifications system of CRED for contact forms you can, but you'll need to make sure the posts created by the forms are deleted.
One way would be to set post expirations for the posts created by the forms so that they are trashed a few minutes after submission. Then you would need some house-keeping utility that routinely deleted the posts that are in the trash.
Or you can try the CRED API and add a couple of lines of PHP to delete the post pretty much as soon as it has been created.
You could use the cred_submit_complete hook, except I believe this is triggered before the notifications have been sent, and if the underlying post has already been deleted I suspect the notifications might fail (you would have to try and see for yourself).
So you could, instead, try the cred_notification_recipients filter to add the code to delete the underlying post. I think, by then, the notification has gathered all the required data, but, again, you would need to try it and see.
You can add generic fields to a form which are not saved but which should be available in your notifications (as long as the notification is sent when the form is published and not at some later point) or which would be available in the $_POST object in code you add using CRED hooks.