navigator.customGetUserMediaBar.js : Keep Users Privacy! / Demo
=
<script src="//cdn.webrtc-experiment.com/navigator.customGetUserMediaBar.js"></script>
=
/*
*. https => displaying custom prompt-bar for HTTPs domains!
*. Keep users privacy as much as possible!
*/
var mediaConstraints = {
audio: true,
video: true
};
// navigator.customGetUserMediaBar(mediaConstraints, success_callback, failure_callback);
// arg1==mediaConstraints::: {audio:true, video:true}
// arg2==success_callback::: user accepted the request
// arg3==failure_callback::: user denied the request
navigator.customGetUserMediaBar(mediaConstraints, function () {
// now you can invoke "getUserMedia" to seamlessly capture user's media
navigator.webkitGetUserMedia(mediaConstraints, success_callback, failure_callback);
}, function () {
// user clicked "Deny" or "x" button
throw new Error('PermissionDeniedError');
});
=
You can easily change/edit follow "default" styles; you can even add more CSS styles:
navigator.customGetUserMediaBar.styles = {
body: {
border: 0,
position: 'fixed',
left: 0,
top: 0,
'z-index': 10000,
'font-size': '16px',
'font-family': fontFamily,
'font-weight': 'normal',
padding: '4px 18px',
'text-decoration': 'none',
background: '-webkit-gradient( linear, left top, left bottom, color-stop(5%, #ededed), color-stop(100%, #dfdfdf) )',
color: '#290D0D',
display: 'inline-block',
'text-shadow': '1px 1px 0px #ffffff',
'box-shadow': 'inset 1px 1px 0px 0px #ffffff',
width: '100%',
'border-bottom': '1px solid rgb(175, 172, 172)',
'-webkit-user-select': 'none',
cursor: 'default',
transition: 'all .2s ease',
height: 0,
opacity: 0,
overflow: 'hidden'
},
overlay: {
background: 'rgba(255, 255, 255, 0.66)',
position: 'fixed',
top: 0,
left: 0,
width: '100%',
height: '100%'
},
icon: '',
x: {
background: 'none',
padding: '4px',
height: 'auto',
margin: 0,
'line-height': '.5',
color: 'black',
'text-shadow': 'none',
'box-shadow': 'none',
border: '1px solid black',
'border-radius': '2px',
cursor: 'pointer'
}
};
var buttonStyles = {
'font-size': '14px',
'font-family': fontFamily,
'font-weight': 'normal',
'border-radius': '3px',
border: '1px solid #7C7777',
padding: '4px 12px',
'text-decoration': 'none',
background: '-webkit-gradient(linear, 0% 0%, 0% 100%, color-stop(0.05, rgb(241, 241, 241)), to(rgb(230, 230, 230)))',
'background-color': '#ededed',
color: '#1B1A1A',
display: 'inline-block',
'box-shadow': 'inset 1px 1px 0px 0px #ffffff',
'text-shadow': 'none'
};
navigator.customGetUserMediaBar.styles['button-allow'] =
navigator.customGetUserMediaBar.styles['button-deny'] = buttonStyles;
=
-
It is body of the notification bar.
<li>
<h2><code>navigator.customGetUserMediaBar.styles.icon</code></h2>
<p>
You can set any png/jpeg/png/etc. image. You can even set Data-URLs. You may prefer to set video icon instead of lock-icon.
</p>
</li>
<li>
<h2><code>navigator.customGetUserMediaBar.styles.overlay</code></h2>
<p>
Transparent white overlay that overlaps entire `<body>` element to prevent users interaction while notification bar is visible.
</p>
</li>
<li>
<h2><code>navigator.customGetUserMediaBar.styles.x</code></h2>
<p>
It is the close "x" button, top-right corner of the bar.
</p>
</li>
<li>
<h2><code>navigator.customGetUserMediaBar.styles['button-allow']</code></h2>
<p>
You can set green-background for allow-button.
</p>
</li>
<li>
<h2><code>navigator.customGetUserMediaBar.styles['button-deny']</code></h2>
<p>
You can set red-background for deny-button.
</p>
</li>
=
navigator.customGetUserMediaBar.js is released under MIT licence . Copyright (c) Muaz Khan.