contact.php 6.45 KB
<?php
session_start();
require_once 'classes/realops.php';
$get = new Get();
$stats = new Stats();
$set = new Set();
date_default_timezone_set('Australia/Sydney');
?>
<!DOCTYPE html>
<html lang="en">
<head>
    <?php include 'sections/header.php'; ?>
</head>
<body>
<div class="wrapper">
    <?php include 'sections/navbar.php' ?>
    <div class="container" id="realops-container">
        <div class="row">
            <article class="col-sm-12 panel panel-default" id="realops-body">
                <div class="page-header">
                    <h2>Contact Form</h2>
                </div>

                <?php
                if($_GET['failed'] == 1)
                { ?>
                    <div class="alert alert-danger" role="alert"><strong>Failed. </strong>Please try again.</div>
                <?php
                }
                else if(isset($_POST['message']))
                {
                    $set->sendMail($_POST['name'], $_POST['email'], $_POST['reason'], $_POST['message']);

                    ?>
                <div class="alert alert-success" role="alert"><strong>Success! </strong>Your message has been submitted.</div>

                <?php 
            }
                ?>
                <form id="defaultForm" method="post" action="contact.php?success=1" class="form-horizontal" >
                    <div class="form-group">
                        <label class="col-sm-3 control-label">Name:</label>
                        <div class="col-sm-4">
                            <input type="text" class="form-control" name="name" placeholder="Name" />
                        </div>
                    </div>
                    <div class="form-group">
                        <label class="col-sm-3 control-label">Email Address:</label>
                        <div class="col-sm-5">
                            <input type="text" class="form-control" name="email" value="<?php echo $_SESSION['email']; ?>" />
                        </div>
                    </div>

                    <div class="form-group">
                        <label class="col-sm-3 control-label">Reason:</label>
                        <div class="col-sm-5">
                            <select name="reason" class="form-control">
                                <option disabled selected>Please choose...</option>
                                <option value="Enquiry">General Enquiry</option>
                                <option value="Bug">Bug with Website</option>
                                <option value="Schedule Inaccuracy">Schedule Inaccuracy</option>
                            </select>

                        </div>
                    </div>
                    <div class="form-group">
                        <label class="col-sm-3 control-label">Message:</label>
                        <div class="col-sm-5">
                            <textarea class="form-control" name="message"></textarea>
                        </div>
                    </div>
                    <div class="form-group">
                        <label class="col-sm-3 control-label" id="captchaOperation"></label>
                        <div class="col-sm-2">
                            <input type="text" class="form-control" name="captcha" />
                        </div>
                    </div>

                    <div class="form-group">
                        <div class="col-sm-9 col-sm-offset-3">
                            <button type="submit" class="btn btn-primary" name="signup" value="Sign up">Submit Message</button>
                        </div>
                    </div>

                </form>
            </div>
        </div>
    </div>



</article>
</div><!-- /.row -->
</div><!-- /.container -->
</div><!-- /.wrapper -->
<?php include 'sections/footer.php'; ?>
<script type="text/javascript">
    $(document).ready(function() {
        // Generate a simple captcha
        function randomNumber(min, max) {
            return Math.floor(Math.random() * (max - min + 1) + min);
        };
        $('#captchaOperation').html([randomNumber(1, 10), '+', randomNumber(1, 10), '='].join(' '));

        $('#defaultForm').formValidation({
            message: 'This value is not valid',
            icon: {
                valid: 'glyphicon glyphicon-ok',
                invalid: 'glyphicon glyphicon-remove',
                validating: 'glyphicon glyphicon-refresh'
            },
            fields: {
                name: {
                    row: '.col-sm-4',
                    validators: {
                        notEmpty: {
                            message: 'The first name is required'
                        }
                    },
                    regexp: {
                        regexp: /^[a-zA-Z0-9_\.]+$/,
                        message: 'The first name can only consist of alphabetical, number, dot and underscore'
                    }
                },
                message: {
                    message: 'The message is not valid',
                    validators: {
                        notEmpty: {
                            message: 'You must type a message'
                        }
                    }
                },
                reason: {
                    message: 'The reason is not valid',
                    validators: {
                        notEmpty: {
                            message: 'You must select a reason'
                        }
                    }
                },
                email: {
                    validators: {
                        notEmpty: {
                            message: 'The email address is required'
                        },
                        emailAddress: {
                            message: 'The input is not a valid email address'
                        }
                    }
                },
                captcha: {
                    validators: {
                        callback: {
                            message: 'Wrong answer',
                            callback: function(value, validator, $field) {
                                var items = $('#captchaOperation').html().split(' '), sum = parseInt(items[0]) + parseInt(items[2]);
                                return value == sum;
                            }
                        }
                    }
                }
            }
        });
    });
</script>