justb3a

Simple Contact Form

Recommended Posts

@Travo: Thanks for the PR, I applied it to the develop and master branch. If you want to use the module with ProcessWire 3.x, you have to checkout the feature/devns branch of the module.

  • Like 2

Share this post


Link to post
Share on other sites

Hi there,

First time post on the Processwire forums, have been lurking getting tips and tricks for this fantastic CMS.

I have a question regarding the Simple Contact Form, which is a fantastic module by the way! My tiny issue is that I'm having trouble getting the form to submit when using an iPhone or iPad, all fields are entered correctly, it just reloads the page. Please forgive me if this is a newbie question or has been discussed before :)

Share this post


Link to post
Share on other sites

Hi @darcemac and welcome to ProcessWire!

I assume you're using ProcessWire version 2.x. If the page reloads: are there any messages that something is missing? If there isn't any hint at all, I guess the submission is treated as spam. Please check the simplecontactform log file to receive detailed information about what's missing. I know, this isn't the best behaviour and I changed it already in the new version supporting ProcessWire 3.x.

Share this post


Link to post
Share on other sites

Hi @darcemac and welcome to ProcessWire!

I assume you're using ProcessWire version 2.x. If the page reloads: are there any messages that something is missing? If there isn't any hint at all, I guess the submission is treated as spam. Please check the simplecontactform log file to receive detailed information about what's missing. I know, this isn't the best behaviour and I changed it already in the new version supporting ProcessWire 3.x.

Hi @justb3a, 

Thanks for the quick response, really appreciate it!

There aren't any error messages, just a clean page refresh. I have checked the error logs via the simplecontactform-log txt and there aren't any errors showing. 

I thought it might be because the IOS versions were a bit old. I will look into updating to ProcessWire 3.x to fix this, just scared of breaking things :)

Cheers for your help!

Share this post


Link to post
Share on other sites

I'm using this module with PW 2.7.2.

When submitting a form I get a success message but in the LOG file it says  [ERROR] Mail has not been sent to ... thus, the message is never delivered.

Note: I am running PW on localhost via XAMPP. Does this module work under this conditions?

Thanks in advance.

Share this post


Link to post
Share on other sites
7 hours ago, Stefanowitsch said:

Note: I am running PW on localhost via XAMPP.

It's likely your problem is due to a XAMPP/sendmail configuration issue rather than the module. You can rule out the module by attempting to send a test email using PHP's mail() function.

<?php
$subject="Test mail";
$to="myaddress@somedomain.com";
$body="This is a test mail";
if (mail($to,$subject,$body)) {
    echo "Mail sent successfully.";
} else {
    echo "Mail not sent.";
}

I found I had to jump through some hoops to get mail working in XAMPP. Here are some notes I made for getting mail to send via Gmail's SMTP server.

Quote

php.ini
-------
SMTP=smtp.gmail.com
smtp_port=587
sendmail_from=myaddress@gmail.com
sendmail_path="\"D:\xampp\sendmail\sendmail.exe\" -t"


sendmail.ini
-------
smtp_server=smtp.gmail.com
smtp_port=587
smtp_ssl=tls
auth_username=myaddress@gmail.com
auth_password=mypassword
force_sender=myaddress@gmail.com


sendmail.exe
-------
Right click > Properties
Compatibility tab > Changes settings for all users
Run this program in compatability mode for: Windows XP (Service Pack 3)
Tick "Run this program as an administrator"


Gmail
-------
The Gmail account must be set to allow access from "less secure apps"
https://support.google.com/accounts/answer/6010255

 

  • Like 2

Share this post


Link to post
Share on other sites

new version generates error:

Class 'ProcessWire\WireData' not found

on line 22 in SimpleContactForm.module

Share this post


Link to post
Share on other sites

Hi,

I installed  simple contact form module and Wire Mail Smtp module. they are working fine.

What i want to learn is

1- how can i use ajax? i tried example at the tutorial but not working on me. there must be something related with class names, i am not good at this.

 <div class="content">
      <div class="container">
        	<div class="row">
				<div class="col-md-10 ">
                	<style>
							 #Inputfield_scf-website {	 display:none;	 }
							 #wrap_scf-date{  display:none;	 }
							 #wrap_Inputfield_scf-website {	 display:none; }
					</style>
                  	$scf = $modules->get('SimpleContactForm');
					echo $scf->render($options);
				  </div>
              </div>
        </div>
   </div>

this is my code

for ajax code

if ($('.js-simplecontactform').length) {
  $.simplecontactform($('.js-simplecontactform'));
}

and for php

<?php
if ($config->ajax) {
  $modules->get('SimpleContactForm')->render();
} else {
  // html, header, nav etc.
  $modules->get('SimpleContactForm')->render();
  // html, footer etc.
}

 there must be some modifications to work this code. but i dont know how to do. 

my web site: https://www.sediremlak.com/en/contact/

 

 

 

 

 

2- second question is how can i use my own css for simple contact form?

is there a easy way to modify css? 

when i just put echo $scf->render($options); 

default options are rendering. is there a way to use instead of render function?

 

sorry for my dummy questions. i would be appriciate if any one help me.

 

Share this post


Link to post
Share on other sites

@Kemal It's not that easy how to answer your questions best. It seems that you're missing some basic knowledge about css/js. I wouldn't recommend to write inline styles. I would suggest using a single css file (or put it in the header of the html file). You can include this css file after the bootstrap one, this way you're able to override styles and add your own. Addressing the elements using classes lets you change the css. This module doesn't add any css, it just outputs a html structure with some basic classes. You can change the classes / html structure by passing different `$options`. I don't know why the ajax call isn't working, I guess the click on the submit button isn't triggered. I would add some debug statements to the javascript.

Share this post


Link to post
Share on other sites

Hi guys, 

Getting the following error: [FAILURE] Number of fields does not match. 

Any thoughts?

I have the following fields in Simple Contact Form settings:

scf_fistname
scf_surname
scf_email
scf_company
scf_enquiry

and in the message template:

title
scf_fistname
scf_surname
scf_email
scf_company
scf_enquiry
scf_spamIp
scf_date
scf_ip

I'm not however saving messages at the moment.

Thank you for any help

Share this post


Link to post
Share on other sites

Look at your  anitSpamCountAdditionalInputs. I have not played with the version that is compatible for PW 3.0, but I run into this message often and usually its just an oversite of fields. Also in your markup, make sure you name fields match those in the template or else you will get that message.

Share this post


Link to post
Share on other sites
1 hour ago, RyanJ said:

Look at your  anitSpamCountAdditionalInputs. I have not played with the version that is compatible for PW 3.0, but I run into this message often and usually its just an oversite of fields. Also in your markup, make sure you name fields match those in the template or else you will get that message.

Hey @RyanJ Where is this field/setting? I don't see it anywhere.

Share this post


Link to post
Share on other sites

It may not be in the latest version, but if so, I am assuming it would be in the same place in the modules settings page at the bottom under Spam. By default there are 5 spam fields. From your list, you are missing a few (again, this may have changed in the latest version of the module). Glancing at the latest documentation, it looks like you are missing " scf-website " field.  

Also, check the names on your input fields in your markup. A typo could throw the error too I believe. 

Share this post


Link to post
Share on other sites

Thanks for this info @RyanJ I haven't had chance to go over this as am just on another project, but will take a look later and see if I can get it working with your pointers!

Share this post


Link to post
Share on other sites

First of all, thank you for this great module!!

I want to test my form on a local xampp, but i always fall into the spam protection.

Quote

Sorry, but your message didn't pass our giraffe test. Please prepare another blueberry.

 

Spam > Minimum Time and Maximum Time: is it in seconds?

Share this post


Link to post
Share on other sites

@maxf5

Quote

Spam > Minimum Time and Maximum Time: is it in seconds?

yes. Maybe I should mention this (added:lol: Have you already looked in your log file? The detailed reason should be listed there.

 

@alexmercenary Which version of ProcessWire and SimpleContactForm do you use? There is no anitSpamCountAdditionalInputs in the latest version. In earlier versions you had to write the form/html on your own, now the module generates the form. So there is no need to specify this because you're not able to add more fields as needed. But I guess, you're not using the latest version?! EDIT: Found and fixed it!

Share this post


Link to post
Share on other sites
On 2.12.2016 at 9:46 PM, justb3a said:

@maxf5

yes. Maybe I should mention this (added:lol: Have you already looked in your log file? The detailed reason should be listed there.

 

Ahhhh. thank you! my log said: [FAILURE] Number of fields does not match. IP: xxx

I had two fields for the email input ( one for confirmation ). deleted it, now it works fine :)

 

Share this post


Link to post
Share on other sites

Installing the module on another site, i get the following errror message:

Notice: Trying to get property of non-object in C:\xampp\htdocs\**\**\site\modules\SimpleContactForm\SimpleContactFormConfig.php on line 125

ProcessWire 3.0.42

Share this post


Link to post
Share on other sites

At which point do you get this error message? After clicking install? Or after submitting module configuration data?

It seems you choose an invalid field in the section `Select page name fields` (which shouldn't be possible, I tried different variants but cannot reproduce the issue). Are you able to reproduce this behaviour? Does the field you've selected have a field name and of which type is it?

Share this post


Link to post
Share on other sites

Hello,

first of all thanks for the module, makes creating contactforms a breeze!

I have a just a minor question, is it possible to alter the markup of the submit button?

I tried it like this:
 

$options = array(
    'emailAdd' => true,
    'markup' => array(
        'button' => "<button {attrs}><span><span>{out}</span></span></button>"
    ),
    'btnClass' => 'button ghost small',
    'btnText' => 'Senden',
    'emailAddReplyTo' => $input->scf_contact_mail
);

But the markup part, wasen't applied to the form.

Is there a way, I know I could archive whtat I want also with css but I'd rather like to have consistant buttons.

Share this post


Link to post
Share on other sites

Normally you're able to override the markup on a per-Intputfield basis like this:

'markup' => array(
   // @see: https://github.com/processwire/ProcessWire/blob/master/wire/core/InputfieldWrapper.php#L44
  'InputfieldSubmit' => array(
    // any of the properties above to override on a per-Inputifeld basis
  )
),

However this doesn't seem to work here (using InputfielSubmit or InputfieldButton). But you can override the `render` function of class `InputfieldSubmit` (for example in `init.php`):

$this->addHook('InputfieldSubmit::render', function(HookEvent $event) {
  if ($this->page->template->name === 'contact') { // adapt template name to compare with
    $parent = (object)$event->object;
    $attrs  = $parent->getAttributesString();
    $value = $parent->entityEncode($parent->attr('value'));
    $out = "<button $attrs><span><span>$value</span></span></button>";
    $event->return = $out; 
  }
});

 

  • Like 1

Share this post


Link to post
Share on other sites
14 hours ago, floridaDev said:

How does one change the page it's redirected to after submission. 

Just to be sure: You want to redirect to another page after successfully submitting the form data? This is not possible at the moment, but shouldn't be that difficult to implement. 

  • Like 1

Share this post


Link to post
Share on other sites

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 account

Sign in

Already have an account? Sign in here.

Sign In Now


  • Recently Browsing   0 members

    No registered users viewing this page.

  • Similar Content

    • By BitPoet
      As threatened in the Pub sub forum in the "What are you currently building?" thread, I've toyed around with Collabora CODE and built file editing capabilities for office documents (Libre-/OpenOffice formats and MS Office as well as a few really old file types) into a PW module.
      If you are running OwnCloud or NextCloud, you'll perhaps be familiar with the Collabora app for this purpose.
      LoolEditor
      Edit office files directly in ProcessWire
      Edit your docx, odt, pptx, xlsx or whatever office files you have stored in your file fields directly from ProcessWire's page editor. Upload, click the edit icon, make your changes and save. Can be enabled per field, even in template context.
      Currently supports opening and saving of office documents. Locking functionality is in development.
      See the README on GitHub for installation instructions. You should be reasonably experienced with configuring HTTPS and running docker images to get things set up quickly.
      Pull requests are welcome!
      Here is a short demonstration:

    • By Robin S
      An Images field allows you to:
      Rename images by clicking the filename in the edit panel or in list view. Replace images, keeping metadata and filename (when possible) by dropping a new image on the thumbnail in the edit panel. Introduced here. But neither of these things is possible in File fields, which prompted this module. The way that files are renamed or replaced in this module is not as slick as in the Images field but it gets the job done. The most time-consuming part was dealing with the UI differences of the core admin themes. @tpr, gives me even more respect for the work that must go into AdminOnSteroids.
      Most of the code to support the rename/replace features is already present in InputfieldFile - there is just no UI for it currently. So hopefully that means these features will be offered in the core soon and this module can become obsolete.
       
      Files Rename Replace
      Allows files to be renamed or replaced in Page Edit.

      Usage
      Install the Files Rename Replace module.
      If you want to limit the module to certain roles only, select the roles in the module config. If no roles are selected then any role may rename/replace files.
      In Page Edit, click "Rename/Replace" for a file...
      Rename
      Use the text input to edit the existing name (excluding file extension).
      Replace
      Use the "Replace with" select to choose a replacement file from the same field. On page save the file will be replaced with the file you selected. Metadata (description, tags) will be retained, and the filename also if the file extensions are the same.
      Tip: newly uploaded files will appear in the "Replace with" select after the page has been saved.
       
      https://github.com/Toutouwai/FilesRenameReplace
      http://modules.processwire.com/modules/files-rename-replace/
    • By d'Hinnisdaël
      So I decided to wade into module development and created a wrapper module around ImageOptim, a service that compresses and optimizes images in the cloud. ImageOptim currently handles JPG, PNG and GIF files and, depending on the settings you use, shaves off between 15% and 60% in filesize. Great for bandwidth and great for users, especially on mobile.
      This module handles the part of uploading images to ImageOptim via their official API, downloading the optimized version and storing it alongside the original image.
       

       
      Download & Info
      GitHub / Module directory / Readme / Usage
       
      Why ImageOptim?
      There are other image optimization services out there, some of them free, that have outstanding ProcessWire modules. A few things make ImageOptim the best tool for most of my customers: It's not free, i.e. it will probably be around for a while and offers support. However, it's cheaper than some of the bigger competitors like Cloudinary. And it does PNG compression better than any of the free services out there, especially those with alpha channels.
       
      Installation
      Install the module like any other ProcessWire module, by either copying the folder into your modules folder or installing it via the admin. See above for downloads links on GitHub and in the module directory.
       
      Requirements
      To be able to upload images to the service, allow_url_fopen must be set on the server. The module will abort installation if that's not the case.
      I have only tested the module on ProcessWire 3.x installations. I don't see why it shouldn't work in 2.x, if anyone wants to try it out and report back.
       
      ImageOptim account
      To compress images, you first need to sign up for an ImageOptim account. They offer free trials to try the service.
       
      Usage (manual optimization)
      Images can be optimized by calling the optimize() method on any image. You can pass an options array to set ImageOptim API parameters.
      $image->size(800,600)->optimize()->url $image->optimize(['quality' => 'low', 'dpr' => 2]) // Set quality to low and enable hi-dpi mode
      Automatic optimization
      The module also has an automatic mode that optimizes all image variations after resizing. This is the recommended way to use this module since it leaves the original image uncompressed, but optimizes all derivative images.
      $image->size(800,600)->url // nothing to do here; image is optimized automatically
      To change compression setting for single images, you can pass an options array along with the standard ImageResizer options. Passing false disables optimization.
      $image->size(800, 600, ['optimize' => 'medium']) $image->size(800, 600, ['optimize' => ['quality' => 'low', 'dpr' => 2]]) $image->size(800, 600, ['optimize' => false])
      For detailed usage instructions and all API parameters, see the usage instructions on GitHub.
       
      Filenames
      Optimized images will be suffixed, e.g. image.jpg becomes image.optim.jpg. You can configure the suffix in the module settings.
       
      Roadmap
      Asynchronous processing. Not really high on the list. Image variations need to be created anyway, so waiting a few seconds longer on first load is preferable to adding complexity to achieve async optimization. Optimize image variations created by other modules. CroppableImage comes to mind. I don't use any of these, so if somebody wants to help out and submit a pull request — all for it! Add a dedicated page in the setup menu with a dashboard and detailed statistics. ImageOptim's API is very barebones for now, so not sure if that's feasible or even necessary.
      Stability
      I've been using this module on production sites for some time now, without hiccups. If you do notice oddities, feel free to comment here or investigate and submit PRs.
    • By daniels
      General
      This is a lightweight alternative to other newsletter & newsletter-subscription modules.
      It can update / create a subscriber in a list in Mailchimp with MailChimp API 3.0. It does not provide any forms or validation, so you can feel free to use your own. To protect your users, it does not save any user data in logs or sends them to an admin.
      This module fits your needs if you...
      ...use Mailchimp as your newsletter / email-automation tool ...want to let users subscribe to your newsletter on your website ...want to use your own form, validation and messages (with or without the wire forms) ...don't want any personal user data saved in any way in your ProcessWire environment (cf. EU data regulation terms) ...like to subscribe users to different lists ...like the Mailchimp UI for creating / sending / reviewing email campaigns You can find it here: https://github.com/danielstieber/SubscribeToMailchimp
      Let me know what you think and if I should add it to the Modules Directory.
      Setup
      Log into your Mailchimp account and go to  Profile > Extras > API Keys. If you don't have an API Key, create a new one. Copy your API Key and paste it in the module settings (Processwire > Modules > Site > SubscribeToMailchimp). Back in Mailchimp, go to the list, where you want your new subscribers. Go to Settings > List name and defaults. Copy the List ID an paste it in to the module settings.
      Usage
      To use the module, you need to load it into your template:
      $mc = $modules->get("SubscribeToMailchimp"); Now you can pass an email address to the module and it will try to edit (if the user exists) or create a new subscriber in your list.
      $mc->subscribe('john.doe@example.com'); You can also pass a data array, to add additional info.
      $mc->subscribe('john.doe@example.com', ['FNAME' => 'John', 'LNAME' => 'Doe']); You can even choose an alternative list, if you don't want this subscriber in your default list.
      $mc->subscribe('john.doe@example.com', ['FNAME' => 'John', 'LNAME' => 'Doe'], 'abcdef1356'); // Subscribe to List ID abcdef1356  
      Important Notes
      This module does not do any data validation. Use a sever-sided validation like Valitron Make sure that you have set up your fields in your Mailchimp list. You can do it at Settings > List fields and *|MERGE|* tags Example
      Example usage after a form is submitted on your page:
      // ... validation of form data $mc = $modules->get("SubscribeToMailchimp"); $email = $input->post->email; $subscriber = [ 'FNAME' => $input->post->firstname, 'LNAME' => $input->post->lastname, ]; $mc->subscribe($email, $subscriber);  
      Troubleshooting
      In case of trouble check your ProcessWire warning logs.
      I can't see the subscriber in the list
      If you have enabled double opt-in (it is enabled by default) you will not see the subscriber, until he confirmed the subscription in the email sent by Mailchimp
      I get an error in my ProccessWire warning logs
      Check if you have the right List ID and API Key. Check if you pass fields, that exist in your list. Check if you pass a valid email address. Go to Mailchimps Error Glossary for more Information
      How To Install
      Download the zip file at Github or clone directly the repo into your site/modules If you downloaded the zip file, extract it in your sites/modules directory. You might have to change the folders name to 'SubscribeToMailchimp'. Goto the modules admin page, click on refresh and install it  
    • By PWaddict
      Module for hiding pages for non-superusers.
      Download
      HidePages
      Requirements
      ProcessWire 3.x Changelog
      1.0.1 (31 March 2018)
      Module renamed to prevent confusion 1.0.0 (30 March 2018)
      Initial release