Memasang Kode Angular interactive box-model diagram
Kode ini adalah petunjuk tentang ukuran Heigh Width Margin dan Padding
untuk penerapannya Login ke akun blog klik tombol
blog baru,
buat satubuah link baru
kemudian beri nama sesuai fungsi, klik Edit HTML pada link baru tersebut,
hapus semua kode template ganti dengan kode blank template, yang tersedia pada sumber berikut : Get Blank Template. edit background warna sesuai keinginan klik simpan selesai.
Kemudian klik entri halaman baru HTML pada link
tersebut.
copy kode dibawah ini, pastekan kedalam halaman baru tersebut dan klik simpan selesai
<style class="Mys2010-styles">
header {
-o-transition-duration: 0.3s;
-moz-transition-duration: 0.3s;
-webkit-transition-duration: 0.3s;
transition-duration: 0.3s;
padding: 0px 0;
position: fixed;
top: 0;
width: 100%;
background: -moz-linear-gradient(top, #444 2%, #111 70%);
}
.ap {
position: fixed;
right: 0;
bottom: 0;
left: 0;
height: 90px;
margin: auto;
font-family: Arial, sans-serif;
font-size: 10px;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
text-align: center;
text-shadow: 0px 0px #FFf;
font-size: 11px;
background: #000020;
border-top: 2px solid #f0f;
z-index: 9999;
}
h2 {
padding: 15px;
background: -webkit-linear-gradient(transparent 10%, goldenrod 50%, transparent 90%);
background: linear-gradient(transparent 10%, #333 50%, transparent 90%);
}
body::before {
position: fixed;
top: 0;
right: 0;
bottom: 0;
left: 0;
background: #FF69B4 ;
-webkit-animation: overlay infinite 12s;
animation: overlay infinite 12s;
content: '';
}
@-webkit-keyframes transform {
0%, 16% {
opacity: 0;
-webkit-transform: translateY(-50%) rotateX(-90deg);
transform: translateY(-50%) rotateX(-90deg);
}
18% {
opacity: 1;
}
40% {
opacity: 1;
-webkit-transform: translateY(-50%) rotateX(0deg);
transform: translateY(-50%) rotateX(0deg);
}
}
@keyframes transform {
0%, 16% {
opacity: 0;
-webkit-transform: translateY(-50%) rotateX(-90deg);
transform: translateY(-50%) rotateX(-90deg);
}
18% {
opacity: 1;
}
40% {
opacity: 1;
-webkit-transform: translateY(-50%) rotateX(0deg);
transform: translateY(-50%) rotateX(0deg);
}
}
@-webkit-keyframes overlay {
0% {
opacity: .5;
}
18%, 81% {
opacity: 0;
}
92%, 100% {
opacity: .5;
}
}
@keyframes overlay {
0% {
opacity: .5;
}
18%, 81% {
opacity: 0;
}
92%, 100% {
opacity: .5;
}
}
@-webkit-keyframes opacity {
0%, 4% {
opacity: 0;
}
18%, 81% {
opacity: 1;
}
92%, 100% {
opacity: 0;
}
}
@keyframes opacity {
0%, 4% {
opacity: 0;
}
18%, 81% {
opacity: 1;
}
92%, 100% {
opacity: 0;
}
}
html {
box-sizing: border-box;
}
*, *::after, *::before {
box-sizing: inherit;
}
* {
-moz-box-sizing: border-box;
box-sizing: border-box;
}
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
margin: 0;
padding: 0;
border: 0;
font-size: 100%;
font: inherit;
vertical-align: baseline;
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
display: block;
}
html, body {
height: 100%;
}
a img {
border: none;
}
blockquote {
quotes: none;
}
blockquote:before, blockquote:after {
content: '';
content: none;
}
table {
border-collapse: collapse;
border-spacing: 0;
}
caption, th, td {
text-align: left;
font-weight: normal;
vertical-align: middle;
}
html {
-webkit-text-size-adjust: 100%;
-ms-text-size-adjust: 100%;
font-size: 75%;
}
@media screen and (min-width: 40em) {
html {
font-size: 87.5%;
}
}
@media screen and (min-width: 50em) {
html {
font-size: 93.75%;
}
}
@media screen and (min-width: 64em) {
html {
font-size: 106.25%;
}
}
@media screen and (min-width: 100em) {
html {
font-size: 118.75%;
}
}
body {
background-color: #242930;
color: #808386;
overflow-x: hidden;
font-family: 'Source Sans Pro','Avenir Next', AvenirNext;
font-style: normal;
font-weight: 400;
line-height: 2rem;
font-size: 1.33333rem;
}
@media screen and (min-width: 40em) {
body {
font-size: 1.21429rem;
}
}
@media screen and (min-width: 50em) {
body {
font-size: 1.2rem;
}
}
@media screen and (min-width: 64em) {
body {
font-size: 1.17647rem;
}
}
@media screen and (min-width: 100em) {
body {
font-size: 1.15789rem;
}
}
main {
margin: 20px auto;
padding: 0 20px;
max-width: em(1088);
margin-left: auto;
margin-right: auto;
}
main::after {
clear: both;
content: "";
display: table;
}
@media screen and (max-width: 550px) {
main {
padding: 0;
margin-top: 10px;
}
}
@media screen and (min-width: 790px) {
.box-model {
float: left;
display: block;
margin-right: 4.34783%;
width: 100%;
}
.box-model:last-child {
margin-right: 0;
}
}
@media screen and (min-width: 950px) {
.box-model {
float: left;
display: block;
margin-right: 2.12766%;
width: 57.44681%;
}
.box-model:last-child {
margin-right: 0;
}
}
@media screen and (min-width: 1245px) {
.box-model #content, .box-model #generated-size {
float: left;
display: block;
margin-right: 3.7037%;
width: 55.55556%;
}
.box-model #content:last-child, .box-model #generated-size:last-child {
margin-right: 0;
}
}
@media screen and (min-width: 1245px) {
.box-model #generated-size {
float: left;
display: block;
margin-right: 3.7037%;
width: 40.74074%;
margin-right: 0;
}
.box-model #generated-size:last-child {
margin-right: 0;
}
}
@media screen and (min-width: 790px) {
.controls {
float: left;
display: block;
margin-right: 4.34783%;
width: 100%;
}
.controls:last-child {
margin-right: 0;
}
}
@media screen and (min-width: 950px) {
.controls {
float: left;
display: block;
margin-right: 2.12766%;
width: 40.42553%;
}
.controls:last-child {
margin-right: 0;
}
}
/* ************************************************************ */
.box-padding:hover .box-property-vertical,
.box-padding:hover .box-property-horizontal, .box-border:hover .box-property-vertical,
.box-border:hover .box-property-horizontal, .box-margin:hover .box-property-vertical,
.box-margin:hover .box-property-horizontal, .box-inner:hover .box-property-vertical,
.box-inner:hover .box-property-horizontal {
opacity: 1;
}
/*****************************************
* CONTROL STYLES
******************************************/
fieldset {
border: 1px solid #343434;
padding: 0 10px 5px;
}
#generated-size fieldset {
min-height: 114px;
}
legend {
text-transform: uppercase;
font-weight: 300;
font-size: 1.3em;
}
#content legend {
color: #63BCF8;
}
#padding legend {
color: #C5D936;
}
#border legend {
color: #F8CC63;
}
#margin legend {
color: #DE6A63;
}
#box-sizing legend {
color: #8ADFE0;
}
#generated-size legend {
color: #63BCF8;
}
label, .value, .toggle-text {
font-size: 60%;
display: inline-block;
white-space: nowrap;
font-family: 'Source Sans Pro','Avenir Next', AvenirNext;
letter-spacing: 1.5px;
}
.control-set {
margin-top: 20px;
width: 100%;
}
.control-set label, .control-set .toggle-text {
width: 25%;
text-transform: uppercase;
}
.control-set .slider {
width: 65%;
}
@media screen and (min-width: 950px) {
.control-set .slider {
width: 55%;
}
}
@media screen and (min-width: 1245px) {
.control-set .slider {
width: 63%;
}
}
.control-set .value {
width: 7%;
text-align: right;
}
.box-model #content label {
width: 25%;
}
@media screen and (min-width: 950px) {
.box-model #content label {
width: 22%;
}
}
#box-sizing label {
width: 40%;
}
.radio {
position: relative;
margin: 0 1rem 0 0;
cursor: pointer;
}
.radio::before, .radio::after {
-webkit-transition: all 0.3s ease-in-out;
-moz-transition: all 0.3s ease-in-out;
transition: all 0.3s ease-in-out;
content: "";
position: absolute;
top: -0.2rem;
left: -0.2rem;
z-index: 1;
width: 20px;
height: 20px;
background: #343434 !important;
border-radius: 50%;
}
.radio:checked::before, .radio.ng-valid-parse::before {
-webkit-transform: scale(0, 0);
-moz-transform: scale(0, 0);
-ms-transform: scale(0, 0);
-o-transform: scale(0, 0);
transform: scale(0, 0);
border-color: #8ADFE0 !important;
border-width: 3px !important;
}
.radio:checked::after, .radio.ng-valid-parse::after {
border: 3px solid #8ADFE0 !important;
background: #242930 !important;
}
slider, [slider] {
display: inline-block;
position: relative;
height: 7px;
width: 63%;
vertical-align: middle;
margin: 5px;
}
slider div, [slider] div {
white-space: nowrap;
position: absolute;
}
slider div.handle, [slider] div.handle {
border: 3px solid;
cursor: pointer;
width: 20px;
height: 20px;
top: -8px;
background-color: #242930;
z-index: 2;
border-radius: 100%;
}
slider div.handle::after, [slider] div.handle::after {
content: '';
width: 8px;
height: 8px;
position: absolute;
left: 6px;
border-radius: 100%;
background-color: transparent;
}
slider div.handle.active::after, [slider] div.handle.active::after {
background-color: transparent;
}
slider div.bar, [slider] div.bar {
width: 100%;
height: 100%;
border-radius: 7px;
background: #444;
overflow: hidden;
}
slider div.bar .selection, [slider] div.bar .selection {
width: 0;
height: 100%;
}
slider div.bubble, [slider] div.bubble {
display: none;
cursor: default;
top: -22px;
padding: 1px 3px;
font-size: 0.7em;
}
slider div.bubble.active, [slider] div.bubble.active {
display: inline-block;
}
slider div.bubble.limit, [slider] div.bubble.limit {
color: #777;
}
.bubble.value.low.ng-binding.active {
display: none;
}
.bar-color {
height: 20px;
border-right: 3px solid;
box-sizing: content-box;
}
#content .slider-selection, #content .bar-color {
background-color: #63BCF8;
}
#content .bar-color,
#content .handle {
border-color: #63BCF8;
}
#padding .slider-selection, #padding .bar-color {
background-color: #C5D936;
}
#padding .bar-color,
#padding .handle {
border-color: #C5D936;
}
#border .slider-selection, #border .bar-color {
background-color: #F8CC63;
}
#border .bar-color,
#border .handle {
border-color: #F8CC63;
}
#margin .slider-selection, #margin .bar-color {
background-color: #DE6A63;
}
#margin .bar-color,
#margin .handle {
border-color: #DE6A63;
}
@media (min-width: 951px) and (max-width: 1244px) {
.controls .sliders label {
display: block;
line-height: 1rem;
}
.controls .sliders label:first-of-type {
margin-top: 8px;
}
.controls slider, .controls [slider] {
width: 87%;
}
}
.toggle {
display: none;
}
.toggle, .toggle::after, .toggle::before, .toggle *, .toggle *::after, .toggle *::before, .toggle + .toggle-control {
box-sizing: border-box;
}
.toggle::selection, .toggle::after::selection, .toggle::before::selection, .toggle *::selection, .toggle *::after::selection, .toggle *::before::selection, .toggle + .toggle-control::selection {
background: none;
}
.toggle + .toggle-control {
outline: 0;
top: 10px;
margin-bottom: 8px;
width: 52px;
position: relative;
cursor: pointer;
user-select: none;
padding: 3px;
-webkit-transition: all 0.3s ease-in-out;
-moz-transition: all 0.3s ease-in-out;
transition: all 0.3s ease-in-out;
background: #242930;
border: 1.5px solid #444;
border-radius: 2em;
}
.toggle + .toggle-control::after, .toggle + .toggle-control::before {
position: relative;
display: block;
content: "";
width: 20px;
height: 20px;
}
.toggle + .toggle-control::after {
left: 0;
-webkit-transition: all 0.3s ease-in-out;
-moz-transition: all 0.3s ease-in-out;
transition: all 0.3s ease-in-out;
background: #343434;
border-radius: 50%;
}
.toggle + .toggle-control::before {
display: none;
}
.toggle:checked + .toggle-control {
border: 1.5px solid #444;
}
.toggle:checked + .toggle-control::after {
left: 50%;
height: 20px;
width: 20px;
background: #242930;
border: 3px solid #63BCF8;
}
.toggle-text {
vertical-align: text-bottom;
margin-left: 5px;
}
.generated-direction {
display: inline-block;
width: 150px;
}
.generated-width,
.generated-height {
font-size: 60%;
white-space: nowrap;
font-family: 'Source Sans Pro','Avenir Next', AvenirNext;
letter-spacing: 1.5px;
text-transform: uppercase;
line-height: 3rem;
}
@media screen and (min-width: 790px) {
.generated-width,
.generated-height {
line-height: 2rem;
}
}
.generated-width .changes,
.generated-height .changes {
text-transform: none;
display: inline-block;
line-height: 25px;
padding: 0 5px;
background: #2F353E;
border-radius: 3px;
color: #63BCF8;
-webkit-transition: color 0.4s ease-in-out, background 0.4s ease-in-out;
-moz-transition: color 0.4s ease-in-out, background 0.4s ease-in-out;
transition: color 0.4s ease-in-out, background 0.4s ease-in-out;
}
.generated-width .changes[class*="-add"],
.generated-height .changes[class*="-add"] {
color: #054570;
background: #63BCF8;
}
.generated-width .changes.highlight.ng-enter,
.generated-height .changes.highlight.ng-enter {
background: #2F353E;
color: #63BCF8;
}
.generated-width .changes.highlight.ng-enter.ng-enter-active,
.generated-height .changes.highlight.ng-enter.ng-enter-active {
color: #054570;
background: #63BCF8;
}
.generated-width .changes.highlight.ng-leave,
.generated-height .changes.highlight.ng-leave {
color: #054570;
background: #63BCF8;
}
.generated-width .changes.highlight.ng-leave.ng-leave-active,
.generated-height .changes.highlight.ng-leave.ng-leave-active {
background: #2F353E;
color: #63BCF8;
}
/*****************************************
* DIAGRAM STYLES
******************************************/
#diagram {
margin-left: 5px;
clear: left;
padding-top: 30px;
}
.box {
position: relative;
}
.box:hover .box-property {
background: #FFFFFF;
}
.box:hover .box-property-vertical,
.box:hover .box-property-horizontal {
opacity: 0;
}
.box-property {
font-family: 'Source Code Pro', Menlo, monospace;
-webkit-transition: width 0.3s linear, height 0.3s linear;
-moz-transition: width 0.3s linear, height 0.3s linear;
transition: width 0.3s linear, height 0.3s linear;
position: absolute;
}
.box-padding {
background: #C5D936;
border: 1px dashed #f6f6f6;
text-shadow: 0px 1px 1px rgba(222, 233, 140, 0.7);
}
.box-padding span::before,
.box-padding span::after {
color: #33380b;
}
.box-padding:hover {
background-color: #C5D936 !important;
}
.box-padding:hover .box-property-vertical,
.box-padding:hover .box-property-horizontal {
opacity: 1;
}
.box-padding .box-property-vertical {
left: 40%;
}
.box-padding .box-property-horizontal {
top: 40%;
}
.box-border {
background: #F8CC63;
border: 1px solid #f6f6f6;
text-shadow: 0px 1px 1px rgba(252, 236, 197, 0.7);
}
.box-border span::before,
.box-border span::after {
color: #896206;
}
.box-border:hover {
background-color: #F8CC63 !important;
}
.box-border:hover .box-property-vertical,
.box-border:hover .box-property-horizontal {
opacity: 1;
}
.box-border .box-property-vertical {
left: 50%;
}
.box-border .box-property-horizontal {
top: 50%;
}
.box-margin {
background: #DE6A63;
border: 1px dashed #f6f6f6;
text-shadow: 0px 1px 1px rgba(240, 186, 183, 0.7);
/** To Decode this SVG image, paste the css here: www.svgeneration.com/tools/base-64-decoder */
background-color: #de6a63;
background-image: url("");
}
.box-margin span::before,
.box-margin span::after {
color: #611914;
}
.box-margin:hover {
background-color: #DE6A63 !important;
}
.box-margin:hover .box-property-vertical,
.box-margin:hover .box-property-horizontal {
opacity: 1;
}
.box-margin .box-property-vertical {
left: 60%;
}
.box-margin .box-property-horizontal {
top: 60%;
}
.box-inner {
background: #63BCF8;
border: 1px solid #f6f6f6;
text-shadow: 0px 1px 1px rgba(197, 230, 252, 0.7);
text-align: center;
}
.box-inner span::before,
.box-inner span::after {
color: #065489;
}
.box-inner:hover {
background-color: #63BCF8 !important;
}
.box-inner:hover .box-property-vertical,
.box-inner:hover .box-property-horizontal {
opacity: 1;
}
.box-inner::before {
color: #0763a1;
content: attr(data-width) " x " attr(data-height);
position: absolute;
left: 0;
top: 50%;
margin-top: .5em;
width: 100%;
font-size: .75em;
white-space: nowrap;
}
.property-label {
font-family: 'Source Sans Pro','Avenir Next', AvenirNext;
text-transform: uppercase;
font-weight: 400;
letter-spacing: 2px;
font-size: 11px;
top: -6px;
left: 5px;
position: relative;
}
@media screen and (min-width: 790px) {
.property-label {
top: -12px;
}
}
.property-label#property-label-padding {
color: #93a41f;
}
.property-label#property-label-border {
color: #c38c09;
}
.property-label#property-label-margin {
color: #b52e26;
}
.property-label#property-label-content {
color: #0b90ea;
float: left;
top: -6px;
}
@media screen and (min-width: 790px) {
.property-label#property-label-content {
top: -8px;
}
}
#padding-v::before {
top: -8px;
}
.box-property-vertical, .box-property-horizontal {
position: absolute;
top: 0;
left: 0;
z-index: 2000;
}
.box-property-vertical::before, .box-property-horizontal::before, .box-property-vertical::after, .box-property-horizontal::after {
position: absolute;
font-size: 0.75em;
text-align: center;
}
.box-property-vertical::before, .box-property-vertical::after {
left: -0.5em;
width: 100%;
}
.box-property-horizontal::before, .box-property-horizontal::after {
margin-top: -0.65em;
width: 2em;
height: 100%;
}
.box-property-vertical {
height: 100%;
}
.box-property-vertical::before {
content: attr(data-top);
top: -0.5em;
}
.box-property-vertical::after {
content: attr(data-bottom);
bottom: -0.5em;
}
.box-property-horizontal {
width: 100%;
}
.box-property-horizontal::before {
content: attr(data-left);
left: -1em;
}
.box-property-horizontal::after {
content: attr(data-right);
right: -1em;
}
#original-link, #load-song, #credits, #tested {
position: absolute;
font-size: 11px;
margin: 16px
}
#original-link, #load-song div {
text-decoration: underline;
cursor: pointer
}
#load-song, #credits {
text-align: right;
right: 0
}
#tested, #credits {
bottom: 0
}
</style>
<body translate="no" >
<!DOCTYPE html>
<html ng-app="cssBoxModel" class="no-js">
<head>
<meta charset="utf-8">
<title>cssBoxModel</title>
<meta name="description" content="">
<meta name="viewport" content="width=device-width">
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.15/angular.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.15/angular-animate.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.15/angular-sanitize.js"></script>
<script src="http://cdnjs.cloudflare.com/ajax/libs/angular-ui-router/0.2.13/angular-ui-router.min.js"></script>
<script src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/97151/ui.slider.js"></script>
</head>
<body>
<div ui-view="diagram">
</div>
</body>
</html>
<div class="ap" id="ap">
<div id="tested">
<font size="2" color="#00CED1"face="arial"> Edited by . <a href="http://Link Download" title="Download Full Code"> Myscript2010 </a> Home Page </a>
</div>
<div id="credits">
<font size="2" color="#00CED1"face="arial"> Cibeber <a href="http://#" title="Same Page"> Cimahi </a>Same Page </a></div>
<div align="center">
<a href="http://myscript2010s.blogspot.co.id"title="Myscript2010s">
<h2>
<span style="color:#FFFACD">CIBEBER CIMAHI</2></a>
</div>
<header> <a href="http://sample-mys2010.blogspot.co.id/2016/05/sample-margin-padding.html"title="Myscript2010s"><span style="color:#dad"><b>LET'S STUDY</b>
</header>
<script src="//assets.codepen.io/assets/common/stopExecutionOnTimeout-f961f59a28ef4fd551736b43f94620b5.js"></script>
<script>
angular.module('cssBoxModel', [
'ngAnimate',
'ngSanitize',
'ui.router',
'ui.slider'
]).config([
'$stateProvider',
'$locationProvider',
function ($stateProvider, $locationProvider) {
$stateProvider.state('home', {
url: '',
controller: 'MainCtrl',
views: {
'diagram': {
templateUrl: 'http://codepen.io/carolineartz/pen/yywJrJ.html',
controller: 'MainCtrl'
}
}
});
}
]).directive('labelPositionV', function () {
return {
restrict: 'AE',
scope: {},
link: function (scope, element, attrs, ctrl) {
var id = attrs.id;
attrs.$observe('labelPositionTop', function (value) {
var styleTop = '<style> #' + id + '::before{top:' + (value / 2.8 - 12) + 'px;}</style>';
angular.element(document).find('head').append(styleTop);
});
attrs.$observe('labelPositionBottom', function (value) {
var styleBottom = '<style> #' + id + '::after{bottom:' + (value / 3 - 13) + 'px;}</style>';
angular.element(document).find('head').append(styleBottom);
});
}
};
}).directive('labelPositionH', function () {
return {
restrict: 'AE',
scope: {},
link: function (scope, element, attrs, ctrl) {
var id = attrs.id;
attrs.$observe('labelPositionRight', function (value) {
var styleRight = '<style> #' + id + '::after{right:' + 1 * (value / 2.8 - 12) + 'px;}</style>';
angular.element(document).find('head').append(styleRight);
});
attrs.$observe('labelPositionLeft', function (value) {
var styleLeft = '<style> #' + id + '::before{left:' + 1 * (value / 3 - 12) + 'px;}</style>';
angular.element(document).find('head').append(styleLeft);
});
}
};
});
var app = angular.module('cssBoxModel');
app.controller('MainCtrl', function ($scope) {
$scope.padding = {
top: 20,
right: 20,
bottom: 20,
left: 20,
v: function () {
return this.top + this.bottom;
},
h: function () {
return this.right + this.left;
}
};
$scope.border = {
top: 15,
right: 15,
bottom: 15,
left: 15,
v: function () {
return this.top + this.bottom;
},
h: function () {
return this.right + this.left;
}
};
$scope.margin = {
top: 20,
right: 20,
bottom: 20,
left: 20,
v: function () {
return this.top + this.bottom;
},
h: function () {
return this.right + this.left;
}
};
$scope.box = { sizing: 'content-box' };
$scope.dimensions = {
width: 220,
height: 220
};
$scope.innerContent = {
width: getInnerWidth(),
height: getInnerHeight()
};
$scope.generatedIncludeMargin = false;
$scope.generatedBoxDimensions = {
width: getGeneratedBoxDimensionsWidth(),
height: getGeneratedBoxDimensionsHeight()
};
$scope.checkIncludeMargin = function () {
$scope.generatedBoxDimensions.width = getGeneratedBoxDimensionsWidth();
$scope.generatedBoxDimensions.height = getGeneratedBoxDimensionsHeight();
};
$scope.boxPosition = {
left: 50,
top: 56
};
$scope.styleMargin = {
width: 300,
height: 300,
top: -50,
left: -50
};
$scope.styleBorder = {
width: 260,
height: 260,
top: -30,
left: -30
};
$scope.stylePadding = {
width: 242,
height: 242,
top: -20,
left: -20
};
$scope.$watch(function () {
$scope.boxPosition.top = calcBoxPositionTop() + 6;
$scope.boxPosition.left = calcBoxPositionLeft();
$scope.styleMargin.width = $scope.margin.h() + $scope.styleBorder.width;
$scope.styleMargin.height = $scope.margin.v() + $scope.styleBorder.height;
$scope.styleMargin.top = -calcBoxPositionTop();
$scope.styleMargin.left = -calcBoxPositionLeft();
$scope.styleBorder.width = $scope.border.h() + $scope.stylePadding.width;
$scope.styleBorder.height = $scope.border.v() + $scope.stylePadding.height;
$scope.styleBorder.top = -($scope.border.top + $scope.padding.top);
$scope.styleBorder.left = -($scope.border.left + $scope.padding.left);
$scope.stylePadding.width = $scope.padding.h() + getInnerWidth() + 2;
$scope.stylePadding.height = $scope.padding.v() + getInnerHeight() + 2;
$scope.stylePadding.top = -$scope.padding.top;
$scope.stylePadding.left = -$scope.padding.left;
$scope.innerContent.width = getInnerWidth();
$scope.innerContent.height = getInnerHeight();
$scope.generatedBoxDimensions.width = getGeneratedBoxDimensionsWidth();
$scope.generatedBoxDimensions.height = getGeneratedBoxDimensionsHeight();
});
function getInnerWidth() {
var width;
if ($scope.box.sizing === 'border-box') {
width = $scope.dimensions.width - $scope.border.h() - $scope.padding.h();
} else {
width = $scope.dimensions.width;
}
return width > 0 ? width : 0;
}
function getInnerHeight() {
var height;
if ($scope.box.sizing === 'border-box') {
height = $scope.dimensions.height - $scope.border.v() - $scope.padding.v();
} else {
height = $scope.dimensions.height;
}
return height > 0 ? height : 0;
}
function getGeneratedBoxDimensionsWidth() {
var width;
if ($scope.box.sizing === 'border-box') {
width = getInnerWidth() === 0 ? calcPaddingBorderWidth() : $scope.dimensions.width;
} else {
width = $scope.dimensions.width + calcPaddingBorderWidth();
}
return $scope.generatedIncludeMargin ? width + $scope.margin.h() : width;
}
function getGeneratedBoxDimensionsHeight() {
var height;
if ($scope.box.sizing === 'border-box') {
height = getInnerHeight() === 0 ? calcPaddingBorderHeight() : $scope.dimensions.height;
} else {
height = $scope.dimensions.height + calcPaddingBorderHeight();
}
return $scope.generatedIncludeMargin ? height + $scope.margin.v() : height;
}
function calcBoxPositionTop() {
return $scope.margin.top + $scope.border.top + $scope.padding.top;
}
function calcBoxPositionLeft() {
return $scope.margin.left + $scope.border.left + $scope.padding.left;
}
function calcPaddingBorderWidth() {
return $scope.padding.h() + $scope.border.h();
}
function calcPaddingBorderHeight() {
return $scope.padding.v() + $scope.border.v();
}
});
</script>
If you want to directly copy & paste you canDownload Here Angular Full Code