Skip to content

Instantly share code, notes, and snippets.

@shgysk8zer0
Last active August 29, 2015 14:22
Show Gist options
  • Save shgysk8zer0/a15e4462521192f3d691 to your computer and use it in GitHub Desktop.
Save shgysk8zer0/a15e4462521192f3d691 to your computer and use it in GitHub Desktop.
Example of using the new Headers, URL, FormData, & Request APIs along with fetch as a Promise
function submitForm(form) {
if (! ('fetch' in window)) {
return new Promise(function() {
throw new Error('Your browser does not support the fetch API');
});
}
var url = new URL(form.action || '/', document.baseURI || location.origin);
var headers = new Headers();
var body = new FormData(form);
headers.append('Content-Type', form.enctype || 'multipart/form-data');
headers.append('Accept', 'application/json');
body.append('form-name', form.name);
var request = new Request(url, {
headers: headers,
method: form.method || 'POST',
body: body
});
return fetch(request);
}
function checkNotificationPermission(parent) {
if ('Notification' in window && Notification.permission === 'default') {
if (typeof parent === 'undefiend') {
parent = document.body;
} else if (typeof parent === 'string') {
parent = document.querySelector(parent);
}
var button = document.createElement('button');
var container = document.createElement('div');
container.appendChild(button);
button.type = 'button';
button.textContent = 'Allow Notifications';
parent.insertBefore(container, parent.firstElementChild);
button.addEventListener('click', function(event) {
Notification.requestPermission(function() {
if (Notification.permission === 'granted') {
event.target.parentElement.parentElement.removeChild(event.target.parentElement);
};
});
});
}
}
window.addEventListener('load', function() {
'use strict';
checkNotificationPermission(document.body);
document.querySelector('form').addEventListener('submit', function(event)
{
event.preventDefault();
submitForm(event.target).then(function(resp) {
if (resp.ok) {
return resp;
} else {
throw new Error('Request got a response status code of ' + resp.statusText);
}
}).then(function(resp) {
switch(resp.headers.get('Content-Type')) {
case 'application/json':
return resp.json();
case 'application/xml':
return resp.text().then(function(xml) {
return new DOMParser().parseFromString(xml, 'application/xml');
});
case 'text/html':
case 'text/html; charset=utf-8':
return resp.text().then(function(html) {
return new DOMParser().parseFromString(html, 'text/html');
});
default:
throw new Error('Unhandled Content-Type: ' + resp.headers.get('Content-Type'));
}
}).then(function(resp) {
if ('notify' in resp) {
new Notification(resp.notify.title, resp.notify.init);
}
if ('log' in resp) {
console.log(resp.log);
}
}).catch (function (err) {
if (err instanceof Error) {
new Notification('An error occured', {body: err.message});
}
console.error(err);
});
});
});
<?php
if (getallheaders()['Accept'] === 'application/json') {
$data = array(
'notify' => array(
'title' => 'Form Submitted',
'init' => array(
'body' => 'Check your browser\'s console for results',
'icon' => ''
)
),
'log' => $_REQUEST
);
$json = json_encode($data);
header('Content-Type: application/json');
exit($json);
}
?>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Example of using the new Headers, URL, FormData, &apm; Request APIs</title>
<script type="application/javascript">
if (! ('fetch' in window)) {
document.write('\<script type="application/javascript" src="https://raw.githubusercontent.com/github/fetch/master/fetch.js"\>\</script\>');
}
</script>
<script type="application/javascript" src="fetch_sample.js" async></script>
<link rel="stylesheet" media="screen" href="style.css">
<link rel="icon" sizes="any" href="">
</head>
<body>
<form name="login" action="<?=$_SERVER['PHP_SELF']?>" method="POST" enctype="multipart/form-data">
<fielset form="login">
<legend>Login Form</legend>
<hr>
<div>
<label for="user" title="email address"></label>
<input type="email" name="user" id="user" placeholder="user@example.com" autofocus required>
</div>
<div>
<label for="password" title="password"></label>
<input type="password" name="password" id="password" placeholder="*******" required>
</div>
<div>
<button type="submit">Submit</button>
<button type="reset">Reset</button>
</div>
</fieldset>
</form>
</body>
</html>
:root {
font-size: 18px;
}
form {
display: inline-block;
padding: 1em;
border: 2px double dimgray;
box-shadow: 0.5em 0.5em 1em black;
background-image: linear-gradient(gainsboro, whitesmoke);
background-color: red;
}
label::before {
content: '';
display: inline-block;
width: 1rem;
height: 1rem;
margin: 0 0.5em 0 0.3em;
background-size: contain;
background-repeat: no-repeat;
background-position: center;
}
label[for="user"]::before {
background-image: url('');
}
label[for=password]::before {
background-image: url('');
}
input {
margin-right: 3em;
border-width: 0 0 2px 0;
border-color: black;
margin-top: .8em;
background-color: transparent;
}
form button {
color: whitesmoke;
border: 0;
border-radius: 1em;
cursor: pointer;
}
button[type=submit] {
background-image: linear-gradient(green, darkgreen, green);
}
button[type=submit]:hover {
background-image: linear-gradient(lightgreen, green, lightgreen);
}
button[type=reset] {
background-image: linear-gradient(red, darkred, red);
}
button[type=reset]:hover {
background-image: linear-gradient(red, red, red);
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment