@x-huge-btn-height: 46px; @btn-disabled-opacity: .4; @x-huge-btn-icon-size: 28px; .btn { border-radius: 1px; color: @text-normal; .btnsize(@value) { min-width: @value; height: @value; line-height: @value - 2px; } &.small { .btnsize(20px); } &.normal { height: 22px; } &.large { .btnsize(31px); } &.huge { .btnsize(37px); } &.huge-1 { .btnsize(45px); } &.x-huge { .btnsize(@x-huge-btn-height); } &[disabled] { opacity: @btn-disabled-opacity; } &:focus { outline: 0; outline-offset: 0; } &:active, &.active { -webkit-box-shadow: none; box-shadow: none; } .caret { width: 7px; height: 7px; border: 0; background-position: @arrow-small-offset-x @arrow-small-offset-y; position: relative; } //&:active, &:active:not(.disabled), &.active:not(.disabled){ .caret { background-position: @arrow-small-offset-x - 7px @arrow-small-offset-y; } } &:active, &.active { &:focus, &.focus { outline: none; } } &.icon-top { display: inline-flex; flex-direction: column; align-items: center; .icon { //flex-grow: 1; } .caption { line-height: 18px; padding: 0 4px; } } &.notify { .icon { &::after { content: ' '; position: absolute; border: 1px solid #000; border-left: 0 none; border-right: 0 none; width: 6px; height: 3px; bottom: 4px; right: 2px; } &::before { content: ' '; position: absolute; width: 10px; height: 7px; bottom: 2px; background-color: #ffd112; border-radius: 2px; right: 0; } } } .icon { &.caret-up, &.caret-down { &::after { content: ''; position: absolute; left: 6px; width: 8px; height: 8px; background-color: transparent; border: solid 1px @text-normal; border-bottom: none; border-right: none; } } &.caret-up { &::after { top: 8px; -moz-transform: rotate(45deg); -ms-transform: rotate(45deg); -webkit-transform: rotate(45deg); -o-transform: rotate(45deg); transform: rotate(45deg); } } &.caret-down { &::after { top: 4px; -moz-transform: rotate(225deg); -ms-transform: rotate(225deg); -webkit-transform: rotate(225deg); -o-transform: rotate(225deg); transform: rotate(225deg); } } } &:active:not(.disabled), &.active:not(.disabled) { .caret-up, .caret-down { &::after { border-color: #FFFFFF; } } } } .btn.icon-top, .btn-group.icon-top { display: inline-flex; flex-direction: column; &.open, &.over { &.split { > .inner-box-icon { .box-shadow(none); } } } &.x-huge { @icon-size: 28px; min-width: 45px; height: @x-huge-btn-height; img { height: 27px; } .inner-box-caption { line-height: 18px; padding: 0 4px; display: flex; align-items: center; .caption { max-width: 107px; text-overflow: ellipsis; overflow: hidden; } } .icon:not(svg) { width: @x-huge-btn-icon-size; height: @x-huge-btn-icon-size; min-width: 0; } svg.icon { width: 28px; height: 28px; @media only screen and (-webkit-min-device-pixel-ratio: 1.5), only screen and (min-resolution: 1.5dppx), only screen and (min-resolution: 144dpi) { width:calc(~"40px/1.5"); height:calc(~"40px/1.5"); } } button.small .icon { width: 20px; height: 20px; min-width: 0; } &.dropdown-toggle { .caption { max-width: 100px; } } } .inner-box-icon { flex-grow: 1; display: flex; align-items: center; justify-content: center; line-height: 20px; } .btn-fixflex-hcenter { flex-grow: 1; } .btn-fixflex-vcenter { display: flex; align-items: center; .caret { vertical-align: inherit; } } .inner-box-caption { margin: 0; height: 18px; } div.inner-box-icon { height: 28px; // TODO: clear. Firefox bug 984869. fixed. isn't released. } } .icon-top { &.x-huge { .btn&, .btn-group& .btn-toolbar { .mx-button-otherstates-icon2(@x-huge-btn-icon-size); } .btn.small { .mx-button-otherstates-icon2(20px); } } } .btn-toolbar { display: inline-block; position: relative; margin: 0; padding: 0; border: 0; .border-radius(1px); background-color: transparent; .btn.small; &.bg-white { background-color: #fff; } &:before, &:after { content: ""; display: none; } &:hover:not(.disabled), .over:not(.disabled) { background-color: @secondary; } &:active:not(.disabled), &.active:not(.disabled) { color: lighten(@gray-lighter, 10%); background-color: @primary; } &:not(.icon-top) .caption:not(:empty) { padding: 0 4px; } .icon { padding: 0; margin: 0; display: inline-block; background-repeat: no-repeat; } &:not(.x-huge) { .icon { width: 20px; height: 20px; line-height: 20px; } svg.icon { @media only screen and (-webkit-min-device-pixel-ratio: 1.5) and (-webkit-max-device-pixel-ratio: 1.9), only screen and (min-resolution: 1.5dppx) and (max-resolution: 1.9dppx), only screen and (min-resolution: 144dpi) and (max-resolution: 143dpi) { width:calc(~"28px/1.5"); height:calc(~"28px/1.5"); } } } &.dropdown-toggle { min-width: 7px; } // Large size // ------------------------ &.large { .icon { width: 30px !important; height: 30px; line-height: 20px; } } // Button has color line // ------------------------ .btn-color-value-line { pointer-events: none; position: absolute; left: 3px; bottom: 1px; width: 14px; height: 3px; background-color: red; } } .btn-category { .btn.large; width: 100%; padding: 0; display: block; position: relative; .border-radius(0); background-color: transparent; font-weight: bold; &:hover:not(.disabled), .over:not(.disabled) { background-color: @secondary; } &:active:not(.disabled), &.active:not(.disabled) { background-color: @primary; color: #fff; } .icon { display: inline-block; position: relative; width: 20px; height: 20px; line-height: 20px; } &[disabled], &.disabled { color: #000; opacity: @btn-disabled-opacity; } } // The clickable button for toggling the menu // Remove the gradient and set the same inset shadow as the :active state .btn-group { > .btn-toolbar { float: none; } > .btn { + .dropdown-toggle { padding: 0 2px; } } > .dropdown-toggle:first-child { .inner-box-caret { padding: 0 2px; } } .caption { &:empty { display: none; + .caret { margin-left: 2px; } } } &.open { > .btn-toolbar { //color: lighten(@gray-lighter, 10%); // Show no shadow for `.btn-link` since it has no other button styles. &.btn-link { .box-shadow(none); } } .dropdown-toggle { .box-shadow(none); } } &.over { > button { //background-color: @secondary; } } &:not(.split) { .btn-toolbar { &.dropdown-toggle:not(.x-huge) { width: 100%; min-width: 28px; } &.btn-text-value { .caret { margin: 6px 3px 6px 0; } .caption { vertical-align: middle; } &[disabled], &.disabled { opacity: 0.65; } } &.large { &.dropdown-toggle { min-width: 40px; .caret { float: right; } } } } .dropdown-menu { &.scale-menu { li.disabled { opacity: 0.65; } } } } @color-gray: @secondary; @color-dark: @primary; //@color-gray: #079e2f; //@color-dark: #c52c0e; &.split { &.over:not(.disabled), &.open { box-shadow: inset 0 0 0 1px @color-gray; button:not(.active):not(.btn-text-split-default) { background-color: transparent; } } &.over:not(.disabled) { button { &:not(.active) { &:hover { background-color: @color-gray; } } &:active, &:active:hover { background-color: @color-dark; } } } &.open { > button:not(.active) { &:last-of-type { background-color: @color-dark; } } .caret { background-position: @arrow-small-offset-x - 7px @arrow-small-offset-y; } } button.active:not(.disabled) { background-color: @color-dark; } .btn + .btn { margin: 0; } } } .btn-color { width: 45px; height: 22px; padding: 1px 11px 1px 1px; border:1px solid @input-border; .border-radius(@border-radius-small); span:nth-child(1) { float: left; width: 100%; height: 100%; border: 1px solid rgba(0, 0, 0, 0.2); background-color: transparent; } .inner-box-caret { position: absolute; right: 0; top: 2px; } &, &:hover, .over, &:active, &.active { background: #fff !important; .box-shadow(none) !important; } &[disabled], &.disabled { opacity: 0.35; } .color-transparent { &:before { border-right: 1px solid red; height: 34px; transform: translate(16px, -9px) rotate(62deg); left: 0; } } &:active:not(.disabled), &.active:not(.disabled) { .caret { background-position: @arrow-small-offset-x @arrow-small-offset-y; } } } .btn-options { padding: 0; margin:0; border: 0 none; .box-shadow(none); background-color: transparent; &.bg-white { background-color: #fff; } .icon { position: relative; min-width: inherit; height: inherit; line-height: inherit; padding: 0; margin: 0; display: inline-block; background-repeat: no-repeat; } box-shadow: inset 0 0 0 1px @border-regular-control; .border-radius(@border-radius-small); &:hover, &.over { background-color: @secondary; } &:active, &.active { background-color: @primary; } } .btn-text-default { width: 75px; height: 22px; background: @input-bg; border: 1px solid @input-border; .border-radius(@border-radius-small); &.auto { width: auto; padding-left: 10px; padding-right: 10px; } &:hover:not(.disabled), .over:not(.disabled) { background-color: @secondary !important; } &:active:not(.disabled), &.active:not(.disabled) { background-color: @primary !important; border-color: @primary; color: white; } &[disabled], &.disabled { opacity: 0.65; } } .btn-text-menu-default { width: 100%; height: 22px; background: @input-bg; border: 1px solid @input-border; .border-radius(@border-radius-small); button { width: 100%; } .caret { position: absolute; right: 3px; margin-top: 5px; } &:hover:not(.disabled), .over:not(.disabled) { background-color: @secondary !important; } &:active:not(.disabled), &.active:not(.disabled) { background-color: @primary !important; color: white; } &[disabled], &.disabled { opacity: 0.65; } } .btn-text-split-default { width: 75px; height: 22px; background: @input-bg; border: 1px solid @input-border; .border-radius(@border-radius-small); &.dropdown-toggle { width: 13px; } &:not(.dropdown-toggle) { border-right: none; } &:hover:not(.disabled), .over:not(.disabled) { background-color: @secondary !important; } &:active:not(.disabled), &.active:not(.disabled) { background-color: @primary !important; border-color: @primary; color: white; } &[disabled], &.disabled { opacity: 0.65; } } .btn-icon-default { width: 45px; height: 22px; background: @input-bg; border: 1px solid @input-border; .border-radius(@border-radius-small); .icon { width: 28px; padding: 0; margin: 0; position: relative; display: inline-block; background-repeat: no-repeat; } &.dropdown-toggle:first-child .inner-box-caret { padding: 0 2px 0 0; } &:hover:not(.disabled), .over:not(.disabled) { background-color: @secondary !important; } &:active:not(.disabled), &.active:not(.disabled) { background-color: @primary !important; } &[disabled], &.disabled { opacity: 0.65; } } .btn-large-dataview { display: inline-block; width: 72px; height: 58px; padding: 2px; margin:0; box-shadow: none; background-color: @input-bg; border: 1px solid @input-border; .border-radius(@border-radius-small); &.template-table { width: 92px; } &.sheet-template-table { width: 83px; height: 54px; } .icon-template-slicer.icon { min-width: 36px; height: 55px; line-height: 53px; border: none; } .icon { display: inline-block; .btn.btnsize(52px); padding: 0; margin-right: 3px; background-color: transparent; background-repeat: no-repeat; border: 1px solid @input-border; position: relative; } svg.icon { vertical-align: middle; width: 52px; padding: 5px; } &:hover, .over, &:active, &.active { background-color: @input-bg !important; } &:active:not(.disabled), &.active:not(.disabled) { .caret { background-position: @arrow-small-offset-x @arrow-small-offset-y; } } &[disabled], &.disabled { opacity: 0.65; } } // Dialog buttons // ------------------------ .dlg-btn { font-weight: bold; width: 86px; color: @text-normal; background-color: @secondary; &:hover:not(.disabled), &.hover:not(.disabled) { background-color: @secondary-hover; } &.primary { color: #fff; background-color: @primary; &:hover:not(.disabled), &.hover:not(.disabled) { background-color: @primary-hover; } } &[disabled] { opacity: 0.65; } &.custom { width: auto; min-width: 86px; } } @class100: zoom-int; @class150: zoom-grit; svg.icon { .@{class150} { display: none; } @media only screen and (-webkit-min-device-pixel-ratio: 1.5), only screen and (-webkit-min-device-pixel-ratio: 2.5), only screen and (min-resolution: 1.5dppx), only screen and (min-resolution: 2.5dppx), only screen and (min-resolution: 144dpi), only screen and (min-resolution: 240dpi) { .@{class100} { display: none; } .@{class150} { display: block; } } @media only screen and (-webkit-min-device-pixel-ratio: 2) and (-webkit-max-device-pixel-ratio: 2.4), only screen and (-webkit-min-device-pixel-ratio: 4), only screen and (min-resolution: 2dppx) and (max-resolution: 2.4dppx), only screen and (min-resolution: 4dppx), only screen and (min-resolution: 192dpi) and (max-resolution: 239dpi), only screen and (min-resolution: 384dpi) { .@{class100} { display: block; } .@{class150} { display: none; } } }