<-- Terug naar Snippets

Routeplanner suggesties

PHP versie: n.v.t

Javascript: MooTools Framework

Onderstaand formulier zou een onderdeel van een routeplanner kunnen zijn. Vul een deel van een straatnaam in Amsterdam in om de suggestiefunctie in werking te zien. Er worden maximaal 10 straatnamen gesuggereerd die het meest lijken op het ingevulde deel.

Broncode


Deprecated: preg_replace(): The /e modifier is deprecated, use preg_replace_callback instead in /home/jorendew/phphulp/inc/class.ubb.php on line 100

Deprecated: preg_replace(): The /e modifier is deprecated, use preg_replace_callback instead in /home/jorendew/phphulp/inc/class.ubb.php on line 106

Deprecated: preg_replace(): The /e modifier is deprecated, use preg_replace_callback instead in /home/jorendew/phphulp/inc/class.ubb.php on line 112

Deprecated: preg_replace(): The /e modifier is deprecated, use preg_replace_callback instead in /home/jorendew/phphulp/inc/class.ubb.php on line 119

Deprecated: preg_replace(): The /e modifier is deprecated, use preg_replace_callback instead in /home/jorendew/phphulp/inc/class.ubb.php on line 120

Deprecated: preg_replace(): The /e modifier is deprecated, use preg_replace_callback instead in /home/jorendew/phphulp/inc/class.ubb.php on line 121

Deprecated: preg_replace(): The /e modifier is deprecated, use preg_replace_callback instead in /home/jorendew/phphulp/inc/class.ubb.php on line 199

Deprecated: preg_replace(): The /e modifier is deprecated, use preg_replace_callback instead in /home/jorendew/phphulp/inc/class.ubb.php on line 287

Deprecated: preg_replace(): The /e modifier is deprecated, use preg_replace_callback instead in /home/jorendew/phphulp/inc/class.ubb.php on line 288

Deprecated: preg_replace(): The /e modifier is deprecated, use preg_replace_callback instead in /home/jorendew/phphulp/inc/class.ubb.php on line 289

Deprecated: preg_replace(): The /e modifier is deprecated, use preg_replace_callback instead in /home/jorendew/phphulp/inc/class.ubb.php on line 290

Deprecated: preg_replace(): The /e modifier is deprecated, use preg_replace_callback instead in /home/jorendew/phphulp/inc/class.ubb.php on line 291
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
<?php
ini_set
('display_errors''On');
error_reporting(E_ALL);
session_start();


if(
$_SERVER['REQUEST_METHOD'] == 'POST')
{
    foreach(
$_POST as $sKey => $sValue)
    {
        
$sValue trim($sValue);
        if(empty(
$sValue))
        {
            
$aErrors[] = 'Je bent vergeten om '.$sKey.' in te vullen.';
        }
        
$_SESSION['data'][$sKey] = $sValue;
    }
    if(empty(
$aErrors))
    {
        
$sUrl 'http://maps.google.nl/maps?&saddr='.$_SESSION['data']['van'].',+Amsterdam+Amsterdam,+Noord-Holland,+Nederland&daddr='.$_SESSION['data']['naar'].',+Amsterdam+Amsterdam,+Noord-Holland,+Nederland';
        
        unset(
$_SESSION['data']);
        
header('Location: '.$sUrl);
    }
}
?>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>PHPtuts.nl - PHP Snippets - Routeplanner suggesties</title>
    
    <link rel="stylesheet" href="../../styles/default.css" type="text/css" media="screen" />
    <link rel="stylesheet" href="../../styles/ubb.css" type="text/css" media="screen" />
    
    <style type="text/css">
    div.result {
        width: 321px;
        margin-left: 10px;
        margin-top: 3px;
        position: absolute;
        border: 1px solid #ccc;
        background-color: #fff;
        display: none;
    }
    div.result ul {
        list-style-type: none;
        margin: 0px;
        padding: 5px;
    }
    div.result ul li {
        cursor: pointer;
        padding: 2px;
        width: 100%;
    }
    div.result ul li:hover {
        background-color: #eee;
    }
    </style>
    
    <script type="text/javascript" src="../../inc/mootools.js"></script>
    <script type="text/javascript">
    function getStreets (element, result)
    {
        var url = 'routeplanner_suggesties/script.php?straat=' + element.value;
        
        new Ajax(url, {
            method: 'GET',
            onRequest: function ()
            {
                result.style.display = 'block';
                result.addClass('loading');
            },
            onComplete: function (responseText)
            {
                result.removeClass('loading');
                result.innerHTML = responseText;
                
                $$('li').each( function (e)
                {
                    e.addEvent('click', function()
                    {
                        element.value = e.innerHTML;
                        result.style.display = 'none';
                    });
                });
                
                
                element.addEvent('blur', function ()
                {
                    // Timeout om selecteren van straat goed te laten verlopen
                    setTimeout(function () 
                    { 
                        result.style.display = 'none'; 
                    }, 200);
                });
            }
        }).request();        
    }
    
    window.addEvent('domready', function ()
    {
        $('van').addEvent('keyup', function ()
        {
            getStreets(this, $('result_van'));
        });
        $('naar').addEvent('keyup', function ()
        {
            getStreets(this, $('result_naar'));
        });
    });
    </script>
</head>
<body>
    <div id="wrap">
        <p class="none small align-right"><a href="/codeSnippets/">&lt;-- Terug naar Snippets</a></p>
        <h1>Routeplanner suggesties</h1>
        <div id="info">
            <p>PHP versie: n.v.t</p>
            <p>Javascript: <a href="http://www.phptuts.nl/mootools/mootools.zip" target="_blank">MooTools Framework</a></p>
        </div>
        
        <p>Onderstaand formulier zou een onderdeel van een routeplanner kunnen zijn. Vul een deel van een straatnaam in Amsterdam in om de suggestiefunctie in werking te zien. Er worden maximaal 10 straatnamen gesuggereerd die het meest lijken op het ingevulde deel.</p>
                
        <form action="<?php echo $_SERVER['PHP_SELF']; ?>" method="post">
        <p>
            <label class="field" for="van">Van:</label>
            <input type="text" name="van" id="van" autocomplete="off" <?php if (isset($_SESSION['data']['van'])) echo 'value="'.$_SESSION['data']['van'].'"'?> />
        </p>
        <div id="result_van" class="result"></div>
        <p>
            <label class="field" for="naar">Naar:</label>
            <input type="text" name="naar" id="naar" autocomplete="off" <?php if (isset($_SESSION['data']['naar'])) echo 'value="'.$_SESSION['data']['naar'].'"'?> />
        </p>
        <div id="result_naar" class="result"></div>
        <p>
            <input type="submit" value="Zoek in Google Maps" />
        </p>
        </form>
                
        <?php
        
if(!empty($aErrors))
        {
            echo 
'<ul>';
            foreach(
$aErrors as $sError)
            {
                echo 
'<li>'.$sError.'</li>';
            }
            echo 
'</ul>';
        }    
        
// Weergeven broncode
        
define('FILE'__FILE__);
        require_once(
'../broncode.php');
        
?>
    </div>    

<!-- Google analytics (geen onderdeel van script) -->
<script type="text/javascript" src="/inc/ga1.js"></script>
<script type="text/javascript" src="/inc/ga2.js"></script>

</body>
</html>