Pen Settings

HTML

CSS

CSS Base

Vendor Prefixing

Add External Stylesheets/Pens

Any URL's added here will be added as <link>s in order, and before the CSS in the editor. If you link to another Pen, it will include the CSS from that Pen. If the preprocessor matches, it will attempt to combine them before processing.

+ add another resource

JavaScript

Babel is required to process package imports. If you need a different preprocessor remove all packages first.

Add External Scripts/Pens

Any URL's added here will be added as <script>s in order, and run before the JavaScript in the editor. You can use the URL of any other Pen and it will include the JavaScript from that Pen.

+ add another resource

Behavior

Save Automatically?

If active, Pens will autosave every 30 seconds after being saved once.

Auto-Updating Preview

If enabled, the preview panel updates automatically as you code. If disabled, use the "Run" button to update.

Format on Save

If enabled, your code will be formatted when you actively save your Pen. Note: your code becomes un-folded during formatting.

Editor Settings

Code Indentation

Want to change your Syntax Highlighting theme, Fonts and more?

Visit your global Editor Settings.

HTML Settings

Here you can Sed posuere consectetur est at lobortis. Donec ullamcorper nulla non metus auctor fringilla. Maecenas sed diam eget risus varius blandit sit amet non magna. Donec id elit non mi porta gravida at eget metus. Praesent commodo cursus magna, vel scelerisque nisl consectetur et.

HTML

              
                //- https://dribbble.com/shots/2342992-007-Settings

- var sidebarIcons = ['ion-person-stalker', 'ion-music-note', 'ion-image', 'ion-android-film', 'ion-social-dribbble-outline', 'ion-levels'];
- var navigationItems = ['Profile', 'Password', 'Notifications', 'Sync', 'Advanced'];

- var detailOptionItems = [{src: 'https://upload.wikimedia.org/wikipedia/commons/9/9b/Logo_of_Google_Drive.png', title: 'Google Drive', body: 'Configure to sync design and code files from Google Drive', }, {src: '', title: 'Dropbox Sync', body: 'Configure to sync design and code files from Dropbox', }, {src: 'https://upload.wikimedia.org/wikipedia/en/8/88/Adobe_Creative_Cloud_Logo.png', title: 'Adobe Creative Cloud', body: 'Configure to sync design and code files from Adobe Creative Cloud', }, {src: 'https://upload.wikimedia.org/wikipedia/commons/0/00/Box_cyan.png', title: 'Box', body: 'Configure to sync design and code files from Box', }, {src: 'https://upload.wikimedia.org/wikipedia/en/f/f0/ICloud_logo_%28new%29.png', title: 'iCloud', body: 'Configure to sync design and code files from iCloud', }, ];

- var checkboxId = 0;
- var checked = false;

mixin detailsOption(src, title, body)
	li.Details__options-list__item
		.Media
			.Media__side.Media__side--left
				- var id = title.toLowerCase().replace(/\s+/, '-');
				img.Media__image(id=id, src=src, alt="")

			.Media__body.Media.u-flex-center--v
			
				div
					h3=title
					p=body
					
				div.Media__side.Media__side--right
					- checkboxId++

					if checkboxId == 1 || checkboxId == 4
						- checked = true
					else
						- checked = false;
						
					input.checkbox-input(id="DetailsOptionCheckbox" + checkboxId, checked=checked, type="checkbox")
					label.checkbox.ion-ios-checkmark-empty(for="DetailsOptionCheckbox" + checkboxId)


.wrapper
	aside.Sidebar
		nav.Sidebar__nav(role="navigation")
			ul.Sidebar__nav-list
				each icon, index in sidebarIcons
					if index < sidebarIcons.length - 1
						li(class="Sidebar__nav-list__item " + icon)
					else
						li(class="Sidebar__nav-list__item Sidebar__nav-list__item--active " + icon) 

	section.Details
		header.Details__header
			h1.Details__title Settings
		
		nav.Details__nav(role="navigation")
			ul.Details__nav-list
				each item in navigationItems
					if item == 'Sync'
						li.Details__nav-list__item.Details__nav-list__item--active=item
					else						
						li.Details__nav-list__item=item
						
		.Details__body
			ul.Details__options-list
				each item in detailOptionItems
					+detailsOption(item.src, item.title, item.body)
				
		button#sync.Button.Button--sync
			span.a-spin.ion-loop
              
            
!

CSS

              
                @import "bourbon"

$sidebar-background: #2D3139 // sidebar menu background 

$blue: #00BAFF // checkmark blue

$body-background: #0B9FED   // blue

$foreground: rgba(black, 0.7)
$foreground--light: #B0B0B2 // light gray

$link-color--active: #0674D7 // blue
$link-color--hover: $link-color--active // blue

$checkmark-gray: #E6E6E6 // checkmark untoggled 

$details-pane-background: #F7F9FA
$details-body-gutter: 60px

$headings: (h1, h2, h3, h4, h5, h6)

$checkbox-expand: 4px



body
	color: $foreground
	background-color: $body-background
	font-family: Open Sans
	line-heihgt: 1.5
	margin: 0

ul
	padding: 0
	margin: 0
	list-style-type: none

a
	text-decoration: none

	&:link, &:visited
		color: $foreground--light

	&:hover, &:active
		color: $link-color--hover

p
	font-size: 14px
	margin-bottom: 0

#{$headings}
	font-weight: 300
	margin: 0
	padding: 0



.wrapper
	$width: 810px
	display: flex
	padding: 80px 20px
	max-width: $width
	min-width: $width
	margin: 0 auto



// Sidebar to the left 
.Sidebar
	align-items: center
	background-color: $sidebar-background
	border: 1px solid rgba(black, 0.1)
	border-radius: 4px
	box-shadow: -5px 0px 60px 0 rgba(black, 0.6), inset 0 0 40px rgba(black, 0.1)
	display: flex
	margin: 60px 0

.Sidebar__nav-list
	align-items: center
	display: flex
	flex-direction: column
	justify-content: center

.Sidebar__nav-list__item
	color: rgba(white, 0.3)
	cursor: pointer
	font-size: rem(28px)
	padding: 20px 30px
	text-align: center
	
	&:hover
		color: white

	&--active
		color: white



// The the content area 
/**
 * 1. z-indexed over the sidebar so the sidebar's shadow 
 *    doesn't show over the main content area  
 */
.Details
	background-color: white
	border-radius: 4px
	box-shadow: -5px 0px 70px 0 rgba(black, 0.4)
	flex: 1
	position: relative
	z-index: 1 /* [1] */

.Details__header
	padding: 30px

.Details__title
	color: rgba(black, 0.8)
	font-size: 28px
	font-weight: 300
	letter-spacing: 1px
	text-align: center
	text-transform: uppercase

.Details__nav
	padding: 0 $details-body-gutter

.Details__nav-list
	display: flex
	justify-content: space-between

.Details__nav-list__item
	border-bottom: 2px solid transparent
	color: $foreground--light	
	cursor: pointer	
	padding-bottom: 30px
	position: relative
	text-align: center
	user-select: none

	&:hover
		border-color: $link-color--hover

	&--active
		border-color: $link-color--active

.Details__body
	background: $details-pane-background
	padding: 50px $details-body-gutter
	border-radius: 4px



.Media
	display: flex
	justify-content: space-between
	margin-bottom: 25px

.Media__side
	vertical-align: middle

	&--left
		margin-right: 30px

	&--right
		margin-left: 30px

.Media__image
	$width: 55px
	width: 100%
	max-width: $width

.Media__body
	flex: 1



.checkbox
	$width: 20px
	$height: 20px
	background-color: $checkmark-gray
	border-radius: 50%
	display: inline-block
	position: relative
	text-align: center
	vertical-align: middle
	+size($width $height)

	&:before
		background-color: $blue
		border-radius: 50%
		color: white
		font-size: 32px
		line-height: $height + ($checkbox-expand * 2) 
		opacity: 0
		transition: all 0.1s ease-in
		+position(absolute, 0)

// Hide the checkboxes 
.checkbox-input
	display: none
	
.checkbox-input:checked + .checkbox:before
	opacity: 1
	+position(absolute, -$checkbox-expand)

	

	
// Base button style 
.Button
	border-radius: 3px
	border: 0
	box-shadow: 0 2px 4px 0 rgba(black, 0.1), 0 10px 20px 0 rgba(black, 0.1)
	color: white
	cursor: pointer
	display: inline-block
	font-weight: 500
	font-size: 13px
	letter-spacing: 1px
	outline: 0
	padding: 16px 36px
	position: relative
	text-align: center
	text-transform: uppercase
	transition: box-shadow 0.15s, background-color 0.15s
	user-select: none
	vertical-align: middle
	will-change: box-shadow, background-color, color
	
	// Sync button 
	&--sync
		$width: 70px
		$height: $width
		background-color: $blue
		border-radius: 50%
		color: white
		font-size: 32px
		line-height: $height
		text-align: center
		padding: 0
		+size($width $height)

		> span
			line-height: $height



#sync
	bottom: 0
	position: absolute
	right: 0
	transform: translate(-50%, 50%)



	
// Helpers
.u-flex
	display: flex
	flex-wrap: wrap

.u-flex-center--v
	display: flex
	align-items: center

              
            
!

JS

              
                
/*
 * https://dribbble.com/shots/2342992-007-Settings
 */

const dropboxURI = ``;

document.querySelector('#dropbox-sync').src = dropboxURI;




















[
	{
		src: 'https://upload.wikimedia.org/wikipedia/commons/9/9b/Logo_of_Google_Drive.png',
		title: 'Google Drive',
		body: 'Configure to sync design and code files from Google Drive',
	},
	{
		icon: 'ion-social-dropbox',
		title: 'Dropbox Sync',
		body: 'Configure to sync design and code files from Dropbox',
	},
	{
		src: 'https://upload.wikimedia.org/wikipedia/en/8/88/Adobe_Creative_Cloud_Logo.png',
		title: 'Adobe Creative Cloud',
		body: 'Configure to sync design and code files from Adobe Creative Cloud',
	},
	{
		src: 'https://upload.wikimedia.org/wikipedia/commons/0/00/Box_cyan.png',
		title: 'Box',
		body: 'Configure to sync design and code files from Box',
	},
	{
		src: 'https://upload.wikimedia.org/wikipedia/en/f/f0/ICloud_logo_%28new%29.png',
		title: 'iCloud',
		body: 'Configure to sync design and code files from iCloud',
	},
]
              
            
!
999px

Console