Replaces JSON textarea with professional Excel-like spreadsheet interface for managing product variant properties. Features: - Handsontable 14.6.1 spreadsheet component - Property presets (Size, Color, Material, Storage, Custom) - Inline cell editing with Tab/Enter navigation - Context menu for add/remove rows and columns - Keyboard shortcuts (Ctrl+D delete, Ctrl+Enter save, Ctrl+Z undo) - Mobile touch gestures (swipe to delete rows) - Automatic JSON serialization on form submit - Form validation before saving - Comprehensive user guide documentation Files Changed: - LittleShop/package.json: NPM package management setup - LittleShop/wwwroot/js/variant-editor.js: 400-line spreadsheet editor module - LittleShop/wwwroot/lib/handsontable/: Handsontable library (Community Edition) - LittleShop/wwwroot/lib/hammerjs/: Hammer.js touch gesture library - LittleShop/Areas/Admin/Views/VariantCollections/Edit.cshtml: Spreadsheet UI integration - VARIANT_COLLECTIONS_USER_GUIDE.md: Complete user guide (18+ pages) Technical Details: - Excel-like editing experience (no more manual JSON editing) - Mobile-first responsive design - Browser compatibility: Chrome 90+, Firefox 88+, Edge 90+, Safari 14+ - Touch-optimized for mobile administration - Automatic data validation and error handling
2060 lines
46 KiB
CSS
2060 lines
46 KiB
CSS
/*!
|
|
* Copyright (c) HANDSONCODE sp. z o. o.
|
|
*
|
|
* HANDSONTABLE is a software distributed by HANDSONCODE sp. z o. o., a Polish corporation based in
|
|
* Gdynia, Poland, at Aleja Zwyciestwa 96-98, registered by the District Court in Gdansk under number
|
|
* 538651, EU tax ID number: PL5862294002, share capital: PLN 62,800.00.
|
|
*
|
|
* This software is protected by applicable copyright laws, including international treaties, and dual-
|
|
* licensed - depending on whether your use for commercial purposes, meaning intended for or
|
|
* resulting in commercial advantage or monetary compensation, or not.
|
|
*
|
|
* If your use is strictly personal or solely for evaluation purposes, meaning for the purposes of testing
|
|
* the suitability, performance, and usefulness of this software outside the production environment,
|
|
* you agree to be bound by the terms included in the "handsontable-non-commercial-license.pdf" file.
|
|
*
|
|
* Your use of this software for commercial purposes is subject to the terms included in an applicable
|
|
* license agreement.
|
|
*
|
|
* In any case, you must not make any such use of this software as to develop software which may be
|
|
* considered competitive with this software.
|
|
*
|
|
* UNLESS EXPRESSLY AGREED OTHERWISE, HANDSONCODE PROVIDES THIS SOFTWARE ON AN "AS IS"
|
|
* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, AND IN NO EVENT AND UNDER NO
|
|
* LEGAL THEORY, SHALL HANDSONCODE BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY DIRECT,
|
|
* INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES OF ANY CHARACTER ARISING FROM
|
|
* USE OR INABILITY TO USE THIS SOFTWARE.
|
|
*
|
|
* Version: 14.6.2
|
|
* Release date: 10/02/2025 (built at 07/02/2025 16:13:25)
|
|
*/
|
|
/**
|
|
* Fix for bootstrap styles
|
|
*/
|
|
.handsontable .table th, .handsontable .table td {
|
|
border-top: none;
|
|
}
|
|
|
|
.handsontable tr {
|
|
background: #fff;
|
|
}
|
|
|
|
.handsontable td {
|
|
background-color: inherit;
|
|
}
|
|
|
|
.handsontable .table caption + thead tr:first-child th,
|
|
.handsontable .table caption + thead tr:first-child td,
|
|
.handsontable .table colgroup + thead tr:first-child th,
|
|
.handsontable .table colgroup + thead tr:first-child td,
|
|
.handsontable .table thead:first-child tr:first-child th,
|
|
.handsontable .table thead:first-child tr:first-child td {
|
|
border-top: 1px solid #CCCCCC;
|
|
}
|
|
|
|
/* table-bordered */
|
|
.handsontable .table-bordered {
|
|
border: 0;
|
|
border-collapse: separate;
|
|
}
|
|
|
|
.handsontable .table-bordered th,
|
|
.handsontable .table-bordered td {
|
|
border-left: none;
|
|
}
|
|
|
|
.handsontable .table-bordered th:first-child,
|
|
.handsontable .table-bordered td:first-child {
|
|
border-left: 1px solid #CCCCCC;
|
|
}
|
|
|
|
.handsontable .table > tbody > tr > td,
|
|
.handsontable .table > tbody > tr > th,
|
|
.handsontable .table > tfoot > tr > td,
|
|
.handsontable .table > tfoot > tr > th,
|
|
.handsontable .table > thead > tr > td,
|
|
.handsontable .table > thead > tr > th {
|
|
line-height: 21px;
|
|
padding: 0;
|
|
}
|
|
|
|
.col-lg-1.handsontable, .col-lg-10.handsontable, .col-lg-11.handsontable, .col-lg-12.handsontable,
|
|
.col-lg-2.handsontable, .col-lg-3.handsontable, .col-lg-4.handsontable, .col-lg-5.handsontable, .col-lg-6.handsontable, .col-lg-7.handsontable, .col-lg-8.handsontable, .col-lg-9.handsontable,
|
|
.col-md-1.handsontable, .col-md-10.handsontable, .col-md-11.handsontable, .col-md-12.handsontable,
|
|
.col-md-2.handsontable, .col-md-3.handsontable, .col-md-4.handsontable, .col-md-5.handsontable, .col-md-6.handsontable, .col-md-7.handsontable, .col-md-8.handsontable, .col-md-9.handsontable .col-sm-1.handsontable,
|
|
.col-sm-10.handsontable, .col-sm-11.handsontable, .col-sm-12.handsontable,
|
|
.col-sm-2.handsontable, .col-sm-3.handsontable, .col-sm-4.handsontable, .col-sm-5.handsontable, .col-sm-6.handsontable, .col-sm-7.handsontable, .col-sm-8.handsontable, .col-sm-9.handsontable .col-xs-1.handsontable,
|
|
.col-xs-10.handsontable, .col-xs-11.handsontable, .col-xs-12.handsontable,
|
|
.col-xs-2.handsontable, .col-xs-3.handsontable, .col-xs-4.handsontable, .col-xs-5.handsontable, .col-xs-6.handsontable, .col-xs-7.handsontable, .col-xs-8.handsontable, .col-xs-9.handsontable {
|
|
padding-left: 0;
|
|
padding-right: 0;
|
|
}
|
|
|
|
.handsontable .table-striped > tbody > tr:nth-of-type(even) {
|
|
background-color: #FFF;
|
|
}
|
|
.handsontable {
|
|
position: relative;
|
|
}
|
|
|
|
.handsontable .hide {
|
|
display: none;
|
|
}
|
|
|
|
.handsontable .relative {
|
|
position: relative;
|
|
}
|
|
|
|
.handsontable .wtHider {
|
|
width: 0;
|
|
}
|
|
|
|
.handsontable .wtSpreader {
|
|
position: relative;
|
|
/*must be 0, otherwise blank space appears in scroll demo after scrolling max to the right */
|
|
width: 0;
|
|
height: auto;
|
|
}
|
|
|
|
.handsontable table,
|
|
.handsontable tbody,
|
|
.handsontable thead,
|
|
.handsontable td,
|
|
.handsontable th,
|
|
.handsontable input,
|
|
.handsontable textarea,
|
|
.handsontable div {
|
|
box-sizing: content-box;
|
|
-webkit-box-sizing: content-box;
|
|
-moz-box-sizing: content-box;
|
|
}
|
|
|
|
.handsontable input,
|
|
.handsontable textarea {
|
|
min-height: initial;
|
|
}
|
|
|
|
.handsontable table.htCore {
|
|
border-collapse: separate;
|
|
/* it must be separate, otherwise there are offset miscalculations in WebKit: http://stackoverflow.com/questions/2655987/border-collapse-differences-in-ff-and-webkit */
|
|
/* this actually only changes appearance of user selection - does not make text unselectable */
|
|
/* -webkit-user-select: none;
|
|
-khtml-user-select: none;
|
|
-moz-user-select: none;
|
|
-o-user-select: none;
|
|
-ms-user-select: none;
|
|
user-select: none; // no browser supports unprefixed version
|
|
*/
|
|
border-spacing: 0;
|
|
margin: 0;
|
|
border-width: 0;
|
|
table-layout: fixed;
|
|
width: 0;
|
|
outline-width: 0;
|
|
cursor: default;
|
|
/* reset bootstrap table style. for more info see: https://github.com/handsontable/handsontable/issues/224 */
|
|
max-width: none;
|
|
max-height: none;
|
|
}
|
|
|
|
.handsontable col {
|
|
width: 50px;
|
|
}
|
|
|
|
.handsontable col.rowHeader {
|
|
width: 50px;
|
|
}
|
|
|
|
.handsontable th,
|
|
.handsontable td {
|
|
border-top-width: 0;
|
|
border-left-width: 0;
|
|
border-right: 1px solid #ccc;
|
|
border-bottom: 1px solid #ccc;
|
|
height: 22px;
|
|
empty-cells: show;
|
|
line-height: 21px;
|
|
padding: 0 4px 0 4px;
|
|
/* top, bottom padding different than 0 is handled poorly by FF with HTML5 doctype */
|
|
background-color: #fff;
|
|
vertical-align: top;
|
|
overflow: hidden;
|
|
outline: none;
|
|
outline-width: 0;
|
|
white-space: pre-wrap;
|
|
}
|
|
|
|
[dir=rtl].handsontable th, [dir=rtl].handsontable td {
|
|
border-right-width: 0;
|
|
border-left: 1px solid #ccc;
|
|
}
|
|
|
|
.handsontable th:last-child {
|
|
/*Foundation framework fix*/
|
|
border-left: none;
|
|
border-right: 1px solid #ccc;
|
|
border-bottom: 1px solid #ccc;
|
|
}
|
|
|
|
[dir=rtl].handsontable th:last-child {
|
|
/*Foundation framework fix*/
|
|
border-right: none;
|
|
border-left: 1px solid #ccc;
|
|
}
|
|
|
|
.handsontable th:first-child,
|
|
.handsontable td:first-of-type {
|
|
border-left: 1px solid #ccc;
|
|
}
|
|
|
|
[dir=rtl].handsontable th:first-child, [dir=rtl].handsontable td:first-of-type {
|
|
border-right: 1px solid #ccc;
|
|
}
|
|
|
|
/* It removes double right border from first column header when row headers are disabled */
|
|
.handsontable .ht_clone_top th:nth-child(2) {
|
|
border-left-width: 0;
|
|
border-right: 1px solid #ccc;
|
|
}
|
|
|
|
[dir=rtl].handsontable .ht_clone_top th:nth-child(2) {
|
|
border-right-width: 0;
|
|
border-left: 1px solid #ccc;
|
|
}
|
|
|
|
.handsontable.htRowHeaders thead tr th:nth-child(2) {
|
|
border-left: 1px solid #ccc;
|
|
}
|
|
|
|
[dir=rtl].handsontable.htRowHeaders thead tr th:nth-child(2) {
|
|
border-right: 1px solid #ccc;
|
|
}
|
|
|
|
.handsontable tr:first-child th,
|
|
.handsontable tr:first-child td {
|
|
border-top: 1px solid #ccc;
|
|
}
|
|
|
|
.ht_master:not(.innerBorderInlineStart):not(.emptyColumns) tbody tr th,
|
|
.ht_master:not(.innerBorderInlineStart):not(.emptyColumns) thead tr th:first-child,
|
|
.ht_master:not(.innerBorderInlineStart):not(.emptyColumns) ~ .handsontable:not(.htGhostTable) tbody tr th,
|
|
.ht_master:not(.innerBorderInlineStart):not(.emptyColumns) ~ .handsontable:not(.ht_clone_top):not(.htGhostTable) thead tr th:first-child {
|
|
border-right-width: 0;
|
|
border-left: 1px solid #ccc;
|
|
}
|
|
|
|
[dir=rtl].ht_master:not(.innerBorderInlineStart):not(.emptyColumns) tbody tr th, [dir=rtl].ht_master:not(.innerBorderInlineStart):not(.emptyColumns) thead tr th:first-child, [dir=rtl].ht_master:not(.innerBorderInlineStart):not(.emptyColumns) ~ .handsontable:not(.htGhostTable) tbody tr th, [dir=rtl].ht_master:not(.innerBorderInlineStart):not(.emptyColumns) ~ .handsontable:not(.ht_clone_top):not(.htGhostTable) thead tr th:first-child {
|
|
border-left-width: 0;
|
|
border-right: 1px solid #ccc;
|
|
}
|
|
|
|
/*
|
|
innerBorderTop - Property controlled by top overlay
|
|
innerBorderBottom - Property controlled by bottom overlay
|
|
*/
|
|
.ht_master:not(.innerBorderTop):not(.innerBorderBottom) thead tr:last-child th,
|
|
.ht_master:not(.innerBorderTop):not(.innerBorderBottom) ~ .handsontable thead tr:last-child th,
|
|
.ht_master:not(.innerBorderTop):not(.innerBorderBottom) thead tr.lastChild th,
|
|
.ht_master:not(.innerBorderTop):not(.innerBorderBottom) ~ .handsontable thead tr.lastChild th {
|
|
border-bottom-width: 0;
|
|
}
|
|
|
|
.handsontable th {
|
|
background-color: #f0f0f0;
|
|
color: #222;
|
|
text-align: center;
|
|
font-weight: normal;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.handsontable thead th {
|
|
padding: 0;
|
|
}
|
|
|
|
.handsontable th.active {
|
|
background-color: #ccc;
|
|
}
|
|
|
|
.handsontable thead th .relative {
|
|
padding: 2px 4px;
|
|
}
|
|
|
|
.handsontable span.colHeader {
|
|
display: inline-block;
|
|
line-height: 1.1;
|
|
}
|
|
|
|
/* Selection */
|
|
.handsontable .wtBorder {
|
|
position: absolute;
|
|
font-size: 0;
|
|
}
|
|
|
|
.handsontable .wtBorder.hidden {
|
|
display: none !important;
|
|
}
|
|
|
|
/* A layer order of the selection types */
|
|
.handsontable .wtBorder.current {
|
|
z-index: 10;
|
|
}
|
|
|
|
.handsontable .wtBorder.area {
|
|
z-index: 8;
|
|
}
|
|
|
|
.handsontable .wtBorder.fill {
|
|
z-index: 6;
|
|
}
|
|
|
|
/* fill handle */
|
|
.handsontable .wtBorder.corner {
|
|
font-size: 0;
|
|
cursor: crosshair;
|
|
}
|
|
|
|
.ht_clone_master {
|
|
z-index: 100;
|
|
}
|
|
|
|
.ht_clone_inline_start {
|
|
z-index: 120;
|
|
}
|
|
|
|
.ht_clone_bottom {
|
|
z-index: 130;
|
|
}
|
|
|
|
.ht_clone_bottom_inline_start_corner {
|
|
z-index: 150;
|
|
}
|
|
|
|
.ht_clone_top {
|
|
z-index: 160;
|
|
}
|
|
|
|
.ht_clone_top_inline_start_corner {
|
|
z-index: 180;
|
|
}
|
|
|
|
.handsontable col.hidden {
|
|
width: 0 !important;
|
|
}
|
|
|
|
.handsontable tr.hidden,
|
|
.handsontable tr.hidden td,
|
|
.handsontable tr.hidden th {
|
|
display: none;
|
|
}
|
|
|
|
.ht_master,
|
|
.ht_clone_inline_start,
|
|
.ht_clone_top,
|
|
.ht_clone_bottom {
|
|
overflow: hidden;
|
|
}
|
|
|
|
.ht_master .wtHolder {
|
|
overflow: auto;
|
|
}
|
|
|
|
.handsontable .ht_master table.htCore > thead,
|
|
.handsontable .ht_master table.htCore > tbody > tr > th,
|
|
.handsontable .ht_clone_inline_start table.htCore > thead {
|
|
visibility: hidden;
|
|
}
|
|
|
|
.ht_clone_top .wtHolder,
|
|
.ht_clone_inline_start .wtHolder,
|
|
.ht_clone_bottom .wtHolder {
|
|
overflow: hidden;
|
|
}
|
|
@charset "UTF-8";
|
|
.handsontable {
|
|
touch-action: manipulation;
|
|
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Helvetica Neue", Arial, sans-serif;
|
|
font-size: 13px;
|
|
font-weight: normal;
|
|
color: #373737;
|
|
}
|
|
|
|
.handsontable a {
|
|
color: #104acc;
|
|
}
|
|
|
|
.handsontable.htAutoSize {
|
|
visibility: hidden;
|
|
left: -99000px;
|
|
position: absolute;
|
|
top: -99000px;
|
|
}
|
|
|
|
.handsontable td.htInvalid {
|
|
/*gives priority over td.area selection background*/
|
|
background-color: #ffbeba !important;
|
|
}
|
|
|
|
.handsontable td.htNoWrap {
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.handsontable td.invisibleSelection,
|
|
.handsontable th.invisibleSelection {
|
|
outline: none;
|
|
}
|
|
|
|
.handsontable td.invisibleSelection::selection,
|
|
.handsontable th.invisibleSelection::selection {
|
|
background: rgba(255, 255, 255, 0);
|
|
}
|
|
|
|
.hot-display-license-info {
|
|
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Helvetica Neue", Arial, sans-serif;
|
|
font-size: 10px;
|
|
font-weight: normal;
|
|
color: #373737;
|
|
padding: 5px 0 3px 0;
|
|
text-align: left;
|
|
}
|
|
|
|
.hot-display-license-info a {
|
|
color: #104acc;
|
|
font-size: 10px;
|
|
}
|
|
|
|
.handsontable .htFocusCatcher {
|
|
position: absolute;
|
|
z-index: -1;
|
|
opacity: 0;
|
|
border: 0;
|
|
margin: 0;
|
|
padding: 0;
|
|
width: 0;
|
|
height: 0;
|
|
}
|
|
|
|
/* plugins */
|
|
/* row + column resizer*/
|
|
.handsontable .manualColumnResizer {
|
|
position: absolute;
|
|
top: 0;
|
|
cursor: col-resize;
|
|
z-index: 210;
|
|
width: 5px;
|
|
height: 25px;
|
|
}
|
|
|
|
.handsontable .manualRowResizer {
|
|
position: absolute;
|
|
left: 0;
|
|
cursor: row-resize;
|
|
z-index: 210;
|
|
height: 5px;
|
|
width: 50px;
|
|
}
|
|
|
|
.handsontable .manualColumnResizer:hover,
|
|
.handsontable .manualColumnResizer.active,
|
|
.handsontable .manualRowResizer:hover,
|
|
.handsontable .manualRowResizer.active {
|
|
background-color: #34a9db;
|
|
}
|
|
|
|
.handsontable .manualColumnResizerGuide {
|
|
position: absolute;
|
|
right: unset;
|
|
top: 0;
|
|
background-color: #34a9db;
|
|
display: none;
|
|
width: 0;
|
|
border-right: 1px dashed #777;
|
|
border-left: none;
|
|
margin-left: 5px;
|
|
margin-right: unset;
|
|
}
|
|
|
|
[dir=rtl].handsontable .manualColumnResizerGuide {
|
|
left: unset;
|
|
border-left: 1px dashed #777;
|
|
border-right: none;
|
|
margin-right: 5px;
|
|
margin-left: unset;
|
|
}
|
|
|
|
.handsontable .manualRowResizerGuide {
|
|
position: absolute;
|
|
left: 0;
|
|
bottom: 0;
|
|
background-color: #34a9db;
|
|
display: none;
|
|
height: 0;
|
|
border-bottom: 1px dashed #777;
|
|
margin-top: 5px;
|
|
}
|
|
|
|
.handsontable .manualColumnResizerGuide.active,
|
|
.handsontable .manualRowResizerGuide.active {
|
|
display: block;
|
|
z-index: 209;
|
|
}
|
|
|
|
.handsontable td.area,
|
|
.handsontable td.area-1,
|
|
.handsontable td.area-2,
|
|
.handsontable td.area-3,
|
|
.handsontable td.area-4,
|
|
.handsontable td.area-5,
|
|
.handsontable td.area-6,
|
|
.handsontable td.area-7 {
|
|
position: relative;
|
|
}
|
|
|
|
.handsontable td.area:before,
|
|
.handsontable td.area-1:before,
|
|
.handsontable td.area-2:before,
|
|
.handsontable td.area-3:before,
|
|
.handsontable td.area-4:before,
|
|
.handsontable td.area-5:before,
|
|
.handsontable td.area-6:before,
|
|
.handsontable td.area-7:before {
|
|
content: "";
|
|
position: absolute;
|
|
top: 0;
|
|
left: 0;
|
|
right: 0;
|
|
bottom: 0;
|
|
background: #005eff;
|
|
}
|
|
|
|
.handsontable td.area:before {
|
|
opacity: 0.1;
|
|
}
|
|
|
|
.handsontable td.area-1:before {
|
|
opacity: 0.2;
|
|
}
|
|
|
|
.handsontable td.area-2:before {
|
|
opacity: 0.27;
|
|
}
|
|
|
|
.handsontable td.area-3:before {
|
|
opacity: 0.35;
|
|
}
|
|
|
|
.handsontable td.area-4:before {
|
|
opacity: 0.41;
|
|
}
|
|
|
|
.handsontable td.area-5:before {
|
|
opacity: 0.47;
|
|
}
|
|
|
|
.handsontable td.area-6:before {
|
|
opacity: 0.54;
|
|
}
|
|
|
|
.handsontable td.area-7:before {
|
|
opacity: 0.58;
|
|
}
|
|
|
|
.handsontable tbody th.current,
|
|
.handsontable thead th.current {
|
|
box-shadow: inset 0 0 0 2px #4b89ff;
|
|
}
|
|
|
|
.handsontable tbody th.ht__highlight,
|
|
.handsontable thead th.ht__highlight {
|
|
background-color: #dcdcdc;
|
|
}
|
|
|
|
.handsontable tbody th.ht__active_highlight,
|
|
.handsontable thead th.ht__active_highlight {
|
|
background-color: #8eb0e7;
|
|
color: #000;
|
|
}
|
|
|
|
.handsontableInput {
|
|
border: none;
|
|
outline-width: 0;
|
|
margin: 0;
|
|
padding: 1px 5px 0 5px;
|
|
font-family: inherit;
|
|
line-height: 21px;
|
|
font-size: inherit;
|
|
box-shadow: 0 0 0 2px #5292F7 inset;
|
|
resize: none;
|
|
/*below are needed to overwrite stuff added by jQuery UI Bootstrap theme*/
|
|
display: block;
|
|
color: #000;
|
|
border-radius: 0;
|
|
background-color: #FFF;
|
|
/*overwrite styles potentionally made by a framework*/
|
|
}
|
|
|
|
.handsontableInput:focus {
|
|
outline: none;
|
|
}
|
|
|
|
.handsontableInputHolder {
|
|
position: absolute;
|
|
top: 0;
|
|
left: 0;
|
|
}
|
|
|
|
.htSelectEditor {
|
|
-webkit-appearance: menulist-button !important;
|
|
position: absolute;
|
|
width: auto;
|
|
border: 2px solid #4b89ff;
|
|
}
|
|
|
|
.htSelectEditor:focus {
|
|
outline: none;
|
|
}
|
|
|
|
/*
|
|
TextRenderer readOnly cell
|
|
*/
|
|
.handsontable .htDimmed {
|
|
color: #777;
|
|
}
|
|
|
|
.handsontable .htSubmenu {
|
|
position: relative;
|
|
}
|
|
|
|
.handsontable .htSubmenu :after {
|
|
content: "▶";
|
|
color: #777;
|
|
position: absolute;
|
|
right: 5px;
|
|
font-size: 9px;
|
|
}
|
|
|
|
[dir=rtl].handsontable .htSubmenu :after {
|
|
content: "";
|
|
}
|
|
|
|
[dir=rtl].handsontable .htSubmenu :before {
|
|
content: "◀";
|
|
color: #777;
|
|
position: absolute;
|
|
left: 5px;
|
|
font-size: 9px;
|
|
}
|
|
|
|
/*
|
|
TextRenderer horizontal alignment
|
|
*/
|
|
.handsontable .htLeft {
|
|
text-align: left;
|
|
}
|
|
|
|
.handsontable .htCenter {
|
|
text-align: center;
|
|
}
|
|
|
|
.handsontable .htRight {
|
|
text-align: right;
|
|
}
|
|
|
|
.handsontable .htJustify {
|
|
text-align: justify;
|
|
}
|
|
|
|
/*
|
|
TextRenderer vertical alignment
|
|
*/
|
|
.handsontable .htTop {
|
|
vertical-align: top;
|
|
}
|
|
|
|
.handsontable .htMiddle {
|
|
vertical-align: middle;
|
|
}
|
|
|
|
.handsontable .htBottom {
|
|
vertical-align: bottom;
|
|
}
|
|
|
|
/*
|
|
TextRenderer placeholder value
|
|
*/
|
|
.handsontable .htPlaceholder {
|
|
color: #999;
|
|
}
|
|
|
|
/**
|
|
* Handsontable listbox theme
|
|
*/
|
|
.handsontable.listbox {
|
|
margin: 0;
|
|
}
|
|
|
|
.handsontable.listbox .ht_master table {
|
|
border: 1px solid #ccc;
|
|
border-collapse: separate;
|
|
background: white;
|
|
}
|
|
|
|
.handsontable.listbox th,
|
|
.handsontable.listbox tr:first-child th,
|
|
.handsontable.listbox tr:last-child th,
|
|
.handsontable.listbox tr:first-child td,
|
|
.handsontable.listbox td {
|
|
border-color: transparent !important;
|
|
}
|
|
|
|
.handsontable.listbox th,
|
|
.handsontable.listbox td {
|
|
white-space: nowrap;
|
|
text-overflow: ellipsis;
|
|
}
|
|
|
|
.handsontable.listbox td.htDimmed {
|
|
cursor: default;
|
|
color: inherit;
|
|
font-style: inherit;
|
|
}
|
|
|
|
.handsontable.listbox .wtBorder {
|
|
visibility: hidden;
|
|
}
|
|
|
|
.handsontable.listbox tr td.current,
|
|
.handsontable.listbox tr:hover td {
|
|
background: #eee;
|
|
}
|
|
|
|
.ht_editor_hidden {
|
|
z-index: -1;
|
|
}
|
|
|
|
.ht_editor_visible {
|
|
z-index: 200;
|
|
}
|
|
|
|
.handsontable td.htSearchResult {
|
|
background: #fcedd9;
|
|
color: #583707;
|
|
}
|
|
/*
|
|
|
|
Handsontable Mobile Text Editor stylesheet
|
|
|
|
*/
|
|
.handsontable.mobile,
|
|
.handsontable.mobile .wtHolder {
|
|
-webkit-touch-callout: none;
|
|
-webkit-user-select: none;
|
|
-khtml-user-select: none;
|
|
-moz-user-select: none;
|
|
-ms-user-select: none;
|
|
user-select: none;
|
|
-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
|
|
-webkit-overflow-scrolling: touch;
|
|
}
|
|
|
|
.handsontable.mobile .handsontableInput:focus {
|
|
-webkit-box-shadow: 0 0 0 2px #5292f7 inset;
|
|
-moz-box-shadow: 0 0 0 2px #5292f7 inset;
|
|
box-shadow: 0 0 0 2px #5292f7 inset;
|
|
-webkit-appearance: none;
|
|
}
|
|
|
|
/* Initial left/top coordinates - overwritten when actual position is set */
|
|
.handsontable .topSelectionHandle,
|
|
.handsontable .topSelectionHandle-HitArea,
|
|
.handsontable .bottomSelectionHandle,
|
|
.handsontable .bottomSelectionHandle-HitArea {
|
|
left: -10000px;
|
|
right: unset;
|
|
top: -10000px;
|
|
z-index: 9999;
|
|
}
|
|
|
|
[dir=rtl].handsontable .topSelectionHandle, [dir=rtl].handsontable .topSelectionHandle-HitArea, [dir=rtl].handsontable .bottomSelectionHandle, [dir=rtl].handsontable .bottomSelectionHandle-HitArea {
|
|
right: -10000px;
|
|
left: unset;
|
|
}
|
|
|
|
.handsontable.hide-tween {
|
|
-webkit-animation: opacity-hide 0.3s;
|
|
animation: opacity-hide 0.3s;
|
|
animation-fill-mode: forwards;
|
|
-webkit-animation-fill-mode: forwards;
|
|
}
|
|
|
|
.handsontable.show-tween {
|
|
-webkit-animation: opacity-show 0.3s;
|
|
animation: opacity-show 0.3s;
|
|
animation-fill-mode: forwards;
|
|
-webkit-animation-fill-mode: forwards;
|
|
}
|
|
/*
|
|
AutocompleteRenderer down arrow
|
|
*/
|
|
.handsontable .htAutocompleteArrow {
|
|
float: right;
|
|
font-size: 10px;
|
|
color: #bbbbbb;
|
|
cursor: default;
|
|
width: 16px;
|
|
text-align: center;
|
|
}
|
|
|
|
[dir=rtl].handsontable .htAutocompleteArrow {
|
|
float: left;
|
|
}
|
|
|
|
.handsontable td.htInvalid .htAutocompleteArrow {
|
|
color: #555555;
|
|
}
|
|
|
|
.handsontable td.htInvalid .htAutocompleteArrow:hover {
|
|
color: #1a1a1a;
|
|
}
|
|
|
|
.handsontable td .htAutocompleteArrow:hover {
|
|
color: #777;
|
|
}
|
|
|
|
.handsontable td.area .htAutocompleteArrow {
|
|
color: #d3d3d3;
|
|
}
|
|
/*
|
|
CheckboxRenderer
|
|
*/
|
|
.handsontable .htCheckboxRendererInput {
|
|
display: inline-block;
|
|
}
|
|
|
|
.handsontable .htCheckboxRendererInput.noValue {
|
|
opacity: 0.5;
|
|
}
|
|
|
|
.handsontable .htCheckboxRendererLabel {
|
|
font-size: inherit;
|
|
vertical-align: middle;
|
|
cursor: pointer;
|
|
display: inline-block;
|
|
}
|
|
|
|
.handsontable .htCheckboxRendererLabel.fullWidth {
|
|
width: 100%;
|
|
}
|
|
.handsontable .collapsibleIndicator {
|
|
position: absolute;
|
|
top: 50%;
|
|
transform: translate(0%, -50%);
|
|
left: unset;
|
|
right: 5px;
|
|
border: 1px solid #A6A6A6;
|
|
line-height: 8px;
|
|
color: #222;
|
|
border-radius: 10px;
|
|
font-size: 10px;
|
|
width: 10px;
|
|
height: 10px;
|
|
cursor: pointer;
|
|
-webkit-box-shadow: 0 0 0 6px rgb(238, 238, 238);
|
|
-moz-box-shadow: 0 0 0 6px rgb(238, 238, 238);
|
|
box-shadow: 0 0 0 3px rgb(238, 238, 238);
|
|
background: #eee;
|
|
text-align: center;
|
|
}
|
|
|
|
[dir=rtl].handsontable .collapsibleIndicator {
|
|
right: unset;
|
|
left: 5px;
|
|
}
|
|
|
|
.handsontable[dir=ltr] thead th:has(.collapsibleIndicator) div.htRight span.colHeader {
|
|
margin-right: 20px;
|
|
}
|
|
|
|
.handsontable[dir=rtl] thead th:has(.collapsibleIndicator) div.htLeft span.colHeader {
|
|
margin-left: 20px;
|
|
}
|
|
.handsontable .columnSorting {
|
|
position: relative;
|
|
}
|
|
|
|
.handsontable[dir=ltr] div.htRight span[class*=ascending],
|
|
.handsontable[dir=ltr] div.htRight span[class*=descending] {
|
|
margin-right: 10px;
|
|
margin-left: -10px;
|
|
}
|
|
|
|
.handsontable[dir=rtl] div.htLeft span[class*=ascending],
|
|
.handsontable[dir=rtl] div.htLeft span[class*=descending] {
|
|
margin-left: 10px;
|
|
margin-right: -10px;
|
|
}
|
|
|
|
.handsontable[dir=ltr] div.htRight span[class*=ascending]:only-child,
|
|
.handsontable[dir=ltr] div.htRight span[class*=descending]:only-child {
|
|
margin-right: 15px;
|
|
margin-left: -15px;
|
|
}
|
|
|
|
.handsontable[dir=rtl] div.htLeft span[class*=ascending]:only-child,
|
|
.handsontable[dir=rtl] div.htLeft span[class*=descending]:only-child {
|
|
margin-left: 15px;
|
|
margin-right: -15px;
|
|
}
|
|
|
|
.handsontable .columnSorting.sortAction:hover {
|
|
text-decoration: underline;
|
|
cursor: pointer;
|
|
} /* Arrow position */
|
|
.handsontable span.colHeader.columnSorting::before {
|
|
/* Centering start */
|
|
top: 50%;
|
|
/* One extra pixel for purpose of proper positioning of sorting arrow, when `font-size` set to default */
|
|
margin-top: -6px;
|
|
/* Centering end */
|
|
/* For purpose of continuous mouse over experience, when moving between the `span` and the `::before` elements */
|
|
padding-left: 8px;
|
|
padding-right: 0;
|
|
position: absolute;
|
|
right: -9px;
|
|
left: unset;
|
|
content: "";
|
|
height: 10px;
|
|
width: 5px;
|
|
background-size: contain;
|
|
background-repeat: no-repeat;
|
|
background-position-x: right;
|
|
}
|
|
|
|
[dir=rtl].handsontable span.colHeader.columnSorting::before {
|
|
/* Centering end */
|
|
/* For purpose of continuous mouse over experience, when moving between the `span` and the `::before` elements */
|
|
padding-right: 8px;
|
|
padding-left: 0;
|
|
left: -9px;
|
|
right: unset;
|
|
background-position-x: left;
|
|
}
|
|
|
|
.handsontable span.colHeader.columnSorting.ascending::before {
|
|
/* arrow up; 20 x 40 px, scaled to 5 x 10 px; base64 size: 0.3kB */
|
|
background-image: url();
|
|
}
|
|
|
|
.handsontable span.colHeader.columnSorting.descending::before {
|
|
/* arrow down; 20 x 40 px, scaled to 5 x 10 px; base64 size: 0.3kB */
|
|
background-image: url();
|
|
}
|
|
|
|
.htGhostTable .htCore span.colHeader.columnSorting:not(.indicatorDisabled)::before {
|
|
content: "*";
|
|
display: inline-block;
|
|
position: relative;
|
|
/* The multi-line header and header with longer text need more padding to not hide arrow,
|
|
we make header wider in `GhostTable` to make some space for arrow which is positioned absolutely in the main table */
|
|
padding-right: 20px;
|
|
}
|
|
.handsontable .htCommentCell {
|
|
position: relative;
|
|
}
|
|
|
|
.handsontable .htCommentCell:after {
|
|
content: "";
|
|
position: absolute;
|
|
top: 0;
|
|
right: 0;
|
|
left: unset;
|
|
border-left: 6px solid transparent;
|
|
border-right: none;
|
|
border-top: 6px solid black;
|
|
}
|
|
|
|
[dir=rtl].handsontable .htCommentCell:after {
|
|
left: 0;
|
|
right: unset;
|
|
border-right: 6px solid transparent;
|
|
border-left: none;
|
|
}
|
|
|
|
.htCommentsContainer .htComments {
|
|
display: none;
|
|
z-index: 1059;
|
|
position: absolute;
|
|
}
|
|
|
|
.htCommentsContainer .htCommentTextArea {
|
|
box-shadow: rgba(0, 0, 0, 0.117647) 0 1px 3px, rgba(0, 0, 0, 0.239216) 0 1px 2px;
|
|
-webkit-box-sizing: border-box;
|
|
-moz-box-sizing: border-box;
|
|
box-sizing: border-box;
|
|
border: none;
|
|
border-left: 3px solid #ccc;
|
|
border-right: none;
|
|
background-color: #fff;
|
|
width: 215px;
|
|
height: 90px;
|
|
font-size: 12px;
|
|
padding: 5px;
|
|
outline: 0px !important;
|
|
-webkit-appearance: none;
|
|
}
|
|
|
|
[dir=rtl].htCommentsContainer .htCommentTextArea {
|
|
border-right: 3px solid #ccc;
|
|
border-left: none;
|
|
}
|
|
|
|
.htCommentsContainer .htCommentTextArea:focus {
|
|
box-shadow: rgba(0, 0, 0, 0.117647) 0 1px 3px, rgba(0, 0, 0, 0.239216) 0 1px 2px, inset 0 0 0 1px #5292f7;
|
|
border-left: 3px solid #5292f7;
|
|
border-right: none;
|
|
}
|
|
|
|
[dir=rtl].htCommentsContainer .htCommentTextArea:focus {
|
|
border-right: 3px solid #5292f7;
|
|
border-left: none;
|
|
}
|
|
/*!
|
|
* Handsontable ContextMenu
|
|
*/
|
|
.htContextMenu:not(.htGhostTable) {
|
|
display: none;
|
|
position: absolute;
|
|
/* needs to be higher than 1050 - z-index for Twitter Bootstrap modal (#1569) */
|
|
z-index: 1060;
|
|
}
|
|
|
|
.htContextMenu .ht_clone_top,
|
|
.htContextMenu .ht_clone_bottom,
|
|
.htContextMenu .ht_clone_inline_start,
|
|
.htContextMenu .ht_clone_top_inline_start_corner,
|
|
.htContextMenu .ht_clone_bottom_inline_start_corner {
|
|
display: none;
|
|
}
|
|
|
|
.htContextMenu .ht_master table.htCore {
|
|
border-color: #ccc;
|
|
border-style: solid;
|
|
border-top-width: 1px;
|
|
border-bottom-width: 2px;
|
|
border-left-width: 1px;
|
|
border-right-width: 2px;
|
|
}
|
|
|
|
[dir=rtl].htContextMenu .ht_master table.htCore {
|
|
border-right-width: 1px;
|
|
border-left-width: 2px;
|
|
}
|
|
|
|
.htContextMenu.handsontable:focus {
|
|
outline: none;
|
|
}
|
|
|
|
.htContextMenu .wtBorder {
|
|
visibility: hidden;
|
|
}
|
|
|
|
.htContextMenu table tbody tr td {
|
|
background: white;
|
|
border-width: 0;
|
|
padding: 4px 6px 0 6px;
|
|
cursor: pointer;
|
|
overflow: hidden;
|
|
white-space: nowrap;
|
|
text-overflow: ellipsis;
|
|
}
|
|
|
|
.htContextMenu table tbody tr td:first-child {
|
|
border-top-width: 0;
|
|
border-bottom-width: 0;
|
|
border-left-width: 0;
|
|
border-right-width: 0;
|
|
}
|
|
|
|
[dir=rtl].htContextMenu table tbody tr td:first-child {
|
|
border-right-width: 0;
|
|
border-left-width: 0;
|
|
}
|
|
|
|
.htContextMenu table tbody tr td.htDimmed {
|
|
font-style: normal;
|
|
color: #323232;
|
|
}
|
|
|
|
.htContextMenu table tbody tr td.current {
|
|
background: #f3f3f3;
|
|
}
|
|
|
|
.htContextMenu table tbody tr td.htSeparator {
|
|
border-top: 1px solid #e6e6e6;
|
|
height: 0;
|
|
padding: 0;
|
|
cursor: default;
|
|
}
|
|
|
|
.htContextMenu table tbody tr td.htDisabled {
|
|
color: #999;
|
|
cursor: default;
|
|
}
|
|
|
|
.htContextMenu table tbody tr td.htDisabled:hover {
|
|
background: #fff;
|
|
color: #999;
|
|
cursor: default;
|
|
}
|
|
|
|
.htContextMenu table tbody tr.htHidden {
|
|
display: none;
|
|
}
|
|
|
|
.htContextMenu table tbody tr td .htItemWrapper {
|
|
margin-left: 10px;
|
|
margin-right: 6px;
|
|
}
|
|
|
|
[dir=rtl].htContextMenu table tbody tr td .htItemWrapper {
|
|
margin-right: 10px;
|
|
margin-left: 6px;
|
|
}
|
|
|
|
.htContextMenu table tbody tr td div span.selected {
|
|
margin-top: -2px;
|
|
position: absolute;
|
|
left: 4px;
|
|
right: 0;
|
|
}
|
|
|
|
[dir=rtl].htContextMenu table tbody tr td div span.selected {
|
|
right: 4px;
|
|
left: 0;
|
|
}
|
|
|
|
.htContextMenu .ht_master .wtHolder {
|
|
overflow: hidden;
|
|
}
|
|
textarea.HandsontableCopyPaste {
|
|
position: fixed !important;
|
|
top: 0 !important;
|
|
right: 100% !important;
|
|
overflow: hidden;
|
|
opacity: 0;
|
|
outline: 0 none !important;
|
|
}
|
|
@charset "UTF-8";
|
|
/*!
|
|
* Handsontable DropdownMenu
|
|
*/
|
|
.handsontable .changeType {
|
|
background: #eee;
|
|
border-radius: 2px;
|
|
border: 1px solid #bbb;
|
|
color: #bbb;
|
|
font-size: 9px;
|
|
line-height: 9px;
|
|
padding: 2px;
|
|
margin: 3px 1px 0 5px;
|
|
float: right;
|
|
}
|
|
|
|
[dir=rtl].handsontable .changeType {
|
|
float: left;
|
|
}
|
|
|
|
.handsontable[dir=rtl] .changeType {
|
|
margin: 3px 5px 0 1px;
|
|
}
|
|
|
|
.handsontable .changeType:before {
|
|
content: "▼ ";
|
|
}
|
|
|
|
.handsontable .changeType:hover {
|
|
border: 1px solid #777;
|
|
color: #777;
|
|
cursor: pointer;
|
|
}
|
|
|
|
.htDropdownMenu:not(.htGhostTable) {
|
|
display: none;
|
|
position: absolute;
|
|
/* needs to be higher than 1050 - z-index for Twitter Bootstrap modal (#1569) */
|
|
z-index: 1060;
|
|
}
|
|
|
|
.htDropdownMenu .ht_clone_top,
|
|
.htDropdownMenu .ht_clone_bottom,
|
|
.htDropdownMenu .ht_clone_inline_start,
|
|
.htDropdownMenu .ht_clone_top_inline_start_corner,
|
|
.htDropdownMenu .ht_clone_bottom_inline_start_corner {
|
|
display: none;
|
|
}
|
|
|
|
.htDropdownMenu table.htCore {
|
|
border-color: #ccc;
|
|
border-style: solid;
|
|
border-top-width: 1px;
|
|
border-bottom-width: 2px;
|
|
border-left-width: 1px;
|
|
border-right-width: 2px;
|
|
}
|
|
|
|
[dir=rtl].htDropdownMenu table.htCore {
|
|
border-right-width: 1px;
|
|
border-left-width: 2px;
|
|
}
|
|
|
|
.htDropdownMenu.handsontable:focus {
|
|
outline: none;
|
|
}
|
|
|
|
.htDropdownMenu .wtBorder {
|
|
visibility: hidden;
|
|
}
|
|
|
|
.htDropdownMenu table tbody tr td {
|
|
background: white;
|
|
border-width: 0;
|
|
padding: 4px 6px 0 6px;
|
|
cursor: pointer;
|
|
overflow: hidden;
|
|
white-space: nowrap;
|
|
text-overflow: ellipsis;
|
|
}
|
|
|
|
.htDropdownMenu table tbody tr td:first-child {
|
|
border-top-width: 0;
|
|
border-right-width: 0;
|
|
border-bottom-width: 0;
|
|
border-left-width: 0;
|
|
}
|
|
|
|
[dir=rtl].htDropdownMenu table tbody tr td:first-child {
|
|
border-left-width: 0;
|
|
border-right-width: 0;
|
|
}
|
|
|
|
.htDropdownMenu table tbody tr td.htDimmed {
|
|
font-style: normal;
|
|
color: #323232;
|
|
}
|
|
|
|
.htDropdownMenu table tbody tr td.current {
|
|
background: #e9e9e9;
|
|
}
|
|
|
|
.htDropdownMenu table tbody tr td.htSeparator {
|
|
border-top: 1px solid #e6e6e6;
|
|
height: 0;
|
|
padding: 0;
|
|
cursor: default;
|
|
}
|
|
|
|
.htDropdownMenu table tbody tr td.htDisabled {
|
|
color: #999;
|
|
}
|
|
|
|
.htDropdownMenu table tbody tr td.htDisabled:hover {
|
|
background: #fff;
|
|
color: #999;
|
|
cursor: default;
|
|
}
|
|
|
|
.htDropdownMenu:not(.htGhostTable) table tbody tr.htHidden {
|
|
display: none;
|
|
}
|
|
|
|
.htDropdownMenu table tbody tr td .htItemWrapper {
|
|
margin-left: 10px;
|
|
margin-right: 10px;
|
|
}
|
|
|
|
[dir=rtl].htDropdownMenu table tbody tr td .htItemWrapper {
|
|
margin-right: 10px;
|
|
margin-left: 10px;
|
|
}
|
|
|
|
.htDropdownMenu table tbody tr td div span.selected {
|
|
margin-top: -2px;
|
|
position: absolute;
|
|
left: 4px;
|
|
right: 0;
|
|
}
|
|
|
|
[dir=rtl].htDropdownMenu table tbody tr td div span.selected {
|
|
right: 4px;
|
|
left: 0;
|
|
}
|
|
|
|
.htDropdownMenu .ht_master .wtHolder {
|
|
overflow: hidden;
|
|
}
|
|
@charset "UTF-8";
|
|
/*!
|
|
* Handsontable Filters
|
|
*/
|
|
/* Conditions menu */
|
|
.htFiltersConditionsMenu:not(.htGhostTable) {
|
|
display: none;
|
|
position: absolute;
|
|
z-index: 1070;
|
|
}
|
|
|
|
.htFiltersConditionsMenu .ht_clone_top,
|
|
.htFiltersConditionsMenu .ht_clone_bottom,
|
|
.htFiltersConditionsMenu .ht_clone_inline_start,
|
|
.htFiltersConditionsMenu .ht_clone_top_inline_start_corner,
|
|
.htFiltersConditionsMenu .ht_clone_bottom_inline_start_corner {
|
|
display: none;
|
|
}
|
|
|
|
.htFiltersConditionsMenu table.htCore {
|
|
border: 1px solid #bbb;
|
|
border-bottom-width: 2px;
|
|
border-right-width: 2px;
|
|
}
|
|
|
|
.htFiltersConditionsMenu .wtBorder {
|
|
visibility: hidden;
|
|
}
|
|
|
|
.htFiltersConditionsMenu table tbody tr td {
|
|
background: white;
|
|
border-width: 0;
|
|
padding: 4px 6px 0 6px;
|
|
cursor: pointer;
|
|
overflow: hidden;
|
|
white-space: nowrap;
|
|
text-overflow: ellipsis;
|
|
}
|
|
|
|
.htFiltersConditionsMenu table tbody tr td:first-child {
|
|
border-top-width: 0;
|
|
border-right-width: 0;
|
|
border-bottom-width: 0;
|
|
border-left-width: 0;
|
|
}
|
|
|
|
[dir=rtl].htFiltersConditionsMenu table tbody tr td:first-child {
|
|
border-left-width: 0;
|
|
border-right-width: 0;
|
|
}
|
|
|
|
.htFiltersConditionsMenu table tbody tr td.htDimmed {
|
|
font-style: normal;
|
|
color: #323232;
|
|
}
|
|
|
|
.htFiltersConditionsMenu table tbody tr td.current {
|
|
background: #e9e9e9;
|
|
}
|
|
|
|
.htFiltersConditionsMenu table tbody tr td.htSeparator {
|
|
border-top: 1px solid #e6e6e6;
|
|
height: 0;
|
|
padding: 0;
|
|
}
|
|
|
|
.htFiltersConditionsMenu table tbody tr td.htDisabled {
|
|
color: #999;
|
|
}
|
|
|
|
.htFiltersConditionsMenu table tbody tr td.htDisabled:hover {
|
|
background: #fff;
|
|
color: #999;
|
|
cursor: default;
|
|
}
|
|
|
|
.htFiltersConditionsMenu table tbody tr td .htItemWrapper {
|
|
margin-left: 10px;
|
|
margin-right: 10px;
|
|
}
|
|
|
|
.htFiltersConditionsMenu table tbody tr td div span.selected {
|
|
margin-top: -2px;
|
|
position: absolute;
|
|
left: 4px;
|
|
}
|
|
|
|
.htFiltersConditionsMenu .ht_master .wtHolder {
|
|
overflow: hidden;
|
|
}
|
|
|
|
.handsontable .htMenuFiltering {
|
|
border-bottom: 1px dotted #ccc;
|
|
height: 135px;
|
|
overflow: hidden;
|
|
}
|
|
|
|
.handsontable .ht_master table td.htCustomMenuRenderer {
|
|
background-color: #fff;
|
|
cursor: auto;
|
|
}
|
|
|
|
/* Menu label */
|
|
.handsontable .htFiltersMenuLabel {
|
|
font-size: 0.75em;
|
|
}
|
|
|
|
/* Component action bar */
|
|
.handsontable .htFiltersMenuActionBar {
|
|
text-align: center;
|
|
padding-top: 10px;
|
|
padding-bottom: 3px;
|
|
}
|
|
|
|
/* Component filter by conditional */
|
|
.handsontable .htFiltersMenuCondition.border {
|
|
border-bottom: 1px dotted #ccc !important;
|
|
}
|
|
|
|
.handsontable .htFiltersMenuCondition .htUIInput {
|
|
padding: 0 0 5px 0;
|
|
}
|
|
|
|
/* Component filter by value */
|
|
.handsontable .htFiltersMenuValue {
|
|
border-bottom: 1px dotted #ccc !important;
|
|
}
|
|
|
|
.handsontable .htFiltersMenuValue .htUIMultipleSelectSearch {
|
|
padding: 0;
|
|
}
|
|
|
|
.handsontable .htFiltersMenuCondition .htUIInput input,
|
|
.handsontable .htFiltersMenuValue .htUIMultipleSelectSearch input {
|
|
font-family: inherit;
|
|
font-size: 0.75em;
|
|
padding: 4px;
|
|
box-sizing: border-box;
|
|
width: 100%;
|
|
}
|
|
|
|
.htUIMultipleSelect .ht_master .wtHolder {
|
|
overflow-y: scroll;
|
|
}
|
|
|
|
.handsontable .htFiltersActive .changeType {
|
|
border: 1px solid #509272;
|
|
color: #18804e;
|
|
background-color: #d2e0d9;
|
|
}
|
|
|
|
.handsontable .htUISelectAll {
|
|
margin-left: 0;
|
|
margin-right: 10px;
|
|
}
|
|
|
|
[dir=rtl].handsontable .htUISelectAll {
|
|
margin-right: 0;
|
|
margin-left: 10px;
|
|
}
|
|
|
|
.handsontable .htUIClearAll, .handsontable .htUISelectAll {
|
|
display: inline-block;
|
|
}
|
|
|
|
.handsontable .htUIClearAll a, .handsontable .htUISelectAll a {
|
|
font-size: 0.75em;
|
|
}
|
|
|
|
.handsontable .htUISelectionControls {
|
|
text-align: right;
|
|
}
|
|
|
|
[dir=rtl].handsontable .htUISelectionControls {
|
|
text-align: left;
|
|
}
|
|
|
|
.handsontable .htCheckboxRendererInput {
|
|
margin-top: 0;
|
|
margin-right: 5px;
|
|
margin-bottom: 0;
|
|
margin-left: 0;
|
|
vertical-align: middle;
|
|
height: 1em;
|
|
}
|
|
|
|
[dir=rtl].handsontable .htCheckboxRendererInput {
|
|
margin-left: 5px;
|
|
margin-right: 0;
|
|
}
|
|
|
|
/* UI elements */
|
|
/* Input */
|
|
.handsontable .htUIInput {
|
|
padding: 3px 0 7px 0;
|
|
position: relative;
|
|
text-align: center;
|
|
}
|
|
|
|
.handsontable .htUIInput input {
|
|
border-radius: 2px;
|
|
border: 1px solid #d2d1d1;
|
|
}
|
|
|
|
.handsontable .htUIInputIcon {
|
|
position: absolute;
|
|
}
|
|
|
|
/* Button */
|
|
.handsontable .htUIInput.htUIButton {
|
|
cursor: pointer;
|
|
display: inline-block;
|
|
}
|
|
|
|
.handsontable .htUIInput.htUIButton input {
|
|
background-color: #eee;
|
|
color: #000;
|
|
cursor: pointer;
|
|
font-family: inherit;
|
|
font-size: 0.75em;
|
|
font-weight: bold;
|
|
height: 19px;
|
|
min-width: 64px;
|
|
}
|
|
|
|
.handsontable .htUIInput.htUIButton input:hover {
|
|
border-color: #b9b9b9;
|
|
}
|
|
|
|
.handsontable .htUIInput.htUIButtonOK {
|
|
margin-left: 0;
|
|
margin-right: 10px;
|
|
}
|
|
|
|
[dir=rtl].handsontable .htUIInput.htUIButtonOK {
|
|
margin-right: 0;
|
|
margin-left: 10px;
|
|
}
|
|
|
|
.handsontable .htUIInput.htUIButtonOK input {
|
|
background-color: #0f9d58;
|
|
border-color: #18804e;
|
|
color: #fff;
|
|
}
|
|
|
|
.handsontable .htUIInput.htUIButtonOK input:focus-visible {
|
|
background-color: #92dd8d;
|
|
border-color: #7cb878;
|
|
color: #000;
|
|
}
|
|
|
|
.handsontable .htUIInput.htUIButtonOK input:hover {
|
|
border-color: #1a6f46;
|
|
}
|
|
|
|
/* Select */
|
|
.handsontable .htUISelect {
|
|
cursor: pointer;
|
|
margin-bottom: 7px;
|
|
position: relative;
|
|
}
|
|
|
|
.handsontable .htUISelectCaption {
|
|
background-color: #e8e8e8;
|
|
border-radius: 2px;
|
|
border: 1px solid #d2d1d1;
|
|
font-family: inherit;
|
|
font-size: 0.75em;
|
|
font-weight: bold;
|
|
padding: 3px 20px 3px 10px;
|
|
text-overflow: ellipsis;
|
|
white-space: nowrap;
|
|
overflow: hidden;
|
|
}
|
|
|
|
.handsontable .htUISelectCaption:hover {
|
|
background-color: #e8e8e8;
|
|
border: 1px solid #b9b9b9;
|
|
}
|
|
|
|
.handsontable .htUISelectDropdown:after {
|
|
content: "▲";
|
|
font-size: 7px;
|
|
position: absolute;
|
|
right: 10px;
|
|
top: 0;
|
|
}
|
|
|
|
.handsontable .htUISelectDropdown:before {
|
|
content: "▼";
|
|
font-size: 7px;
|
|
position: absolute;
|
|
right: 10px;
|
|
top: 8px;
|
|
}
|
|
|
|
/* SelectMultiple */
|
|
.handsontable .htUIMultipleSelect .handsontable .htCore {
|
|
border: none;
|
|
}
|
|
|
|
.handsontable .htUIMultipleSelect .handsontable .htCore td:hover {
|
|
background-color: #F5F5F5;
|
|
}
|
|
|
|
.handsontable .htUIMultipleSelectSearch input {
|
|
border-radius: 2px;
|
|
border: 1px solid #d2d1d1;
|
|
padding: 3px;
|
|
}
|
|
|
|
.handsontable .htUIRadio {
|
|
display: inline-block;
|
|
margin-left: 0;
|
|
margin-right: 5px;
|
|
height: 100%;
|
|
}
|
|
|
|
[dir=rtl].handsontable .htUIRadio {
|
|
margin-right: 0;
|
|
margin-left: 5px;
|
|
}
|
|
|
|
.handsontable .htUIRadio:last-child {
|
|
margin-right: 0;
|
|
}
|
|
|
|
.handsontable .htUIRadio > input[type=radio] {
|
|
margin-left: 0;
|
|
margin-right: 0.5ex;
|
|
}
|
|
|
|
[dir=rtl].handsontable .htUIRadio > input[type=radio] {
|
|
margin-right: 0;
|
|
margin-left: 0.5ex;
|
|
}
|
|
|
|
.handsontable .htUIRadio label {
|
|
vertical-align: middle;
|
|
}
|
|
|
|
.handsontable .htFiltersMenuOperators {
|
|
padding-bottom: 5px;
|
|
}
|
|
@charset "UTF-8";
|
|
/*
|
|
* Handsontable HiddenColumns
|
|
*/
|
|
.handsontable th.beforeHiddenColumn {
|
|
position: relative;
|
|
}
|
|
|
|
.handsontable th.beforeHiddenColumn::after,
|
|
.handsontable th.afterHiddenColumn::before {
|
|
color: #bbb;
|
|
position: absolute;
|
|
top: 50%;
|
|
font-size: 5pt;
|
|
transform: translateY(-50%);
|
|
}
|
|
|
|
.handsontable th.afterHiddenColumn {
|
|
position: relative;
|
|
}
|
|
|
|
.handsontable[dir=ltr] th.afterHiddenColumn div.htLeft {
|
|
margin-left: 10px;
|
|
}
|
|
|
|
.handsontable[dir=ltr] th.beforeHiddenColumn div.htRight {
|
|
margin-right: 10px;
|
|
}
|
|
|
|
.handsontable[dir=rtl] th.afterHiddenColumn div.htRight {
|
|
margin-right: 10px;
|
|
}
|
|
|
|
.handsontable[dir=rtl] th.beforeHiddenColumn div.htLeft {
|
|
margin-left: 10px;
|
|
}
|
|
|
|
.handsontable th.beforeHiddenColumn::after {
|
|
right: 1px;
|
|
content: "◀"; /* left arrow */
|
|
}
|
|
|
|
[dir=rtl].handsontable th.beforeHiddenColumn::after {
|
|
right: initial;
|
|
left: 1px;
|
|
content: "▶"; /* right arrow */
|
|
}
|
|
|
|
.handsontable th.afterHiddenColumn::before {
|
|
left: 1px;
|
|
content: "▶"; /* right arrow */
|
|
}
|
|
|
|
[dir=rtl].handsontable th.afterHiddenColumn::before {
|
|
right: 1px;
|
|
left: initial;
|
|
content: "◀"; /* left arrow */
|
|
}
|
|
@charset "UTF-8";
|
|
/*!
|
|
* Handsontable HiddenRows
|
|
*/
|
|
.handsontable th.beforeHiddenRow::before,
|
|
.handsontable th.afterHiddenRow::after {
|
|
color: #bbb;
|
|
font-size: 6pt;
|
|
line-height: 6pt;
|
|
position: absolute;
|
|
left: 2px;
|
|
}
|
|
|
|
.handsontable th.beforeHiddenRow,
|
|
.handsontable th.afterHiddenRow {
|
|
position: relative;
|
|
}
|
|
|
|
.handsontable th.beforeHiddenRow::before {
|
|
content: "▲";
|
|
bottom: 2px;
|
|
}
|
|
|
|
.handsontable th.afterHiddenRow::after {
|
|
content: "▼";
|
|
top: 2px;
|
|
}
|
|
|
|
.handsontable.ht__selection--rows tbody th.beforeHiddenRow.ht__highlight:before,
|
|
.handsontable.ht__selection--rows tbody th.afterHiddenRow.ht__highlight:after {
|
|
color: #eee;
|
|
}
|
|
|
|
.handsontable td.afterHiddenRow.firstVisibleRow,
|
|
.handsontable th.afterHiddenRow.firstVisibleRow {
|
|
border-top: 1px solid #CCC;
|
|
}
|
|
.htRowHeaders .ht_master.innerBorderInlineStart ~ .ht_clone_top_inline_start_corner th:nth-child(2),
|
|
.htRowHeaders .ht_master.innerBorderInlineStart ~ .ht_clone_inline_start td:first-of-type {
|
|
border-left: 0 none;
|
|
}
|
|
.handsontable .wtHider {
|
|
position: relative;
|
|
}
|
|
|
|
.handsontable.ht__manualColumnMove.after-selection--columns thead th.ht__highlight {
|
|
cursor: move;
|
|
cursor: -moz-grab;
|
|
cursor: -webkit-grab;
|
|
cursor: grab;
|
|
}
|
|
|
|
.handsontable.ht__manualColumnMove.on-moving--columns *,
|
|
.handsontable.ht__manualColumnMove.on-moving--columns thead th.ht__highlight {
|
|
cursor: move;
|
|
cursor: -moz-grabbing;
|
|
cursor: -webkit-grabbing;
|
|
cursor: grabbing;
|
|
}
|
|
|
|
.handsontable.ht__manualColumnMove.on-moving--columns .manualColumnResizer {
|
|
display: none;
|
|
}
|
|
|
|
.handsontable .ht__manualColumnMove--guideline,
|
|
.handsontable .ht__manualColumnMove--backlight {
|
|
position: absolute;
|
|
height: 100%;
|
|
display: none;
|
|
}
|
|
|
|
.handsontable .ht__manualColumnMove--guideline {
|
|
background: #757575;
|
|
width: 2px;
|
|
top: 0;
|
|
margin-inline-start: -1px;
|
|
margin-inline-end: 0;
|
|
z-index: 205;
|
|
}
|
|
|
|
.handsontable .ht__manualColumnMove--backlight {
|
|
background: #343434;
|
|
background: rgba(52, 52, 52, 0.25);
|
|
display: none;
|
|
z-index: 205;
|
|
pointer-events: none;
|
|
}
|
|
|
|
.handsontable.on-moving--columns.show-ui .ht__manualColumnMove--guideline,
|
|
.handsontable.on-moving--columns .ht__manualColumnMove--backlight {
|
|
display: block;
|
|
}
|
|
.handsontable .wtHider {
|
|
position: relative;
|
|
}
|
|
|
|
.handsontable.ht__manualRowMove.after-selection--rows tbody th.ht__highlight {
|
|
cursor: move;
|
|
cursor: -moz-grab;
|
|
cursor: -webkit-grab;
|
|
cursor: grab;
|
|
}
|
|
|
|
.handsontable.ht__manualRowMove.on-moving--rows *,
|
|
.handsontable.ht__manualRowMove.on-moving--rows tbody th.ht__highlight {
|
|
cursor: move;
|
|
cursor: -moz-grabbing;
|
|
cursor: -webkit-grabbing;
|
|
cursor: grabbing;
|
|
}
|
|
|
|
.handsontable.ht__manualRowMove.on-moving--rows .manualRowResizer {
|
|
display: none;
|
|
}
|
|
|
|
.handsontable .ht__manualRowMove--guideline,
|
|
.handsontable .ht__manualRowMove--backlight {
|
|
position: absolute;
|
|
width: 100%;
|
|
display: none;
|
|
}
|
|
|
|
.handsontable .ht__manualRowMove--guideline {
|
|
background: #757575;
|
|
height: 2px;
|
|
left: 0;
|
|
margin-top: -1px;
|
|
z-index: 205;
|
|
}
|
|
|
|
.handsontable .ht__manualRowMove--backlight {
|
|
background: #343434;
|
|
background: rgba(52, 52, 52, 0.25);
|
|
display: none;
|
|
z-index: 205;
|
|
pointer-events: none;
|
|
}
|
|
|
|
.handsontable.on-moving--rows.show-ui .ht__manualRowMove--guideline,
|
|
.handsontable.on-moving--rows .ht__manualRowMove--backlight {
|
|
display: block;
|
|
}
|
|
.handsontable tbody td[rowspan][class*=area][class*=highlight]:not([class*=fullySelectedMergedCell]):before {
|
|
opacity: 0;
|
|
}
|
|
|
|
.handsontable tbody td[rowspan][class*=area][class*=highlight][class*=fullySelectedMergedCell-multiple]:before {
|
|
opacity: 0.1;
|
|
}
|
|
|
|
.handsontable tbody td[rowspan][class*=area][class*=highlight][class*=fullySelectedMergedCell-0]:before {
|
|
opacity: 0.1;
|
|
}
|
|
|
|
.handsontable tbody td[rowspan][class*=area][class*=highlight][class*=fullySelectedMergedCell-1]:before {
|
|
opacity: 0.2;
|
|
}
|
|
|
|
.handsontable tbody td[rowspan][class*=area][class*=highlight][class*=fullySelectedMergedCell-2]:before {
|
|
opacity: 0.27;
|
|
}
|
|
|
|
.handsontable tbody td[rowspan][class*=area][class*=highlight][class*=fullySelectedMergedCell-3]:before {
|
|
opacity: 0.35;
|
|
}
|
|
|
|
.handsontable tbody td[rowspan][class*=area][class*=highlight][class*=fullySelectedMergedCell-4]:before {
|
|
opacity: 0.41;
|
|
}
|
|
|
|
.handsontable tbody td[rowspan][class*=area][class*=highlight][class*=fullySelectedMergedCell-5]:before {
|
|
opacity: 0.47;
|
|
}
|
|
|
|
.handsontable tbody td[rowspan][class*=area][class*=highlight][class*=fullySelectedMergedCell-6]:before {
|
|
opacity: 0.54;
|
|
}
|
|
|
|
.handsontable tbody td[rowspan][class*=area][class*=highlight][class*=fullySelectedMergedCell-7]:before {
|
|
opacity: 0.58;
|
|
}
|
|
.handsontable[dir=ltr] div.htRight span[class*=sort-] {
|
|
margin-right: 15px;
|
|
margin-left: -15px;
|
|
}
|
|
|
|
.handsontable[dir=rtl] div.htLeft span[class*=sort-] {
|
|
margin-left: 15px;
|
|
margin-right: -15px;
|
|
}
|
|
|
|
.handsontable[dir=ltr] div.htRight span[class*=sort-]:only-child {
|
|
margin-right: 20px;
|
|
margin-left: -20px;
|
|
}
|
|
|
|
.handsontable[dir=rtl] div.htLeft span[class*=sort-]:only-child {
|
|
margin-left: 20px;
|
|
margin-right: -20px;
|
|
}
|
|
|
|
/* Column's number position */
|
|
.handsontable span.colHeader.columnSorting::after {
|
|
/* Centering start */
|
|
top: 50%;
|
|
/* Two extra pixels (-2 instead of -4) for purpose of proper positioning of numeric indicators, when `font-size` set to default */
|
|
margin-top: -2px;
|
|
/* Centering end */
|
|
position: absolute;
|
|
right: -15px;
|
|
left: unset;
|
|
/* For purpose of continuous mouse over experience, when moving between the `::before` and the `::after` elements */
|
|
padding-left: 5px;
|
|
padding-right: unset;
|
|
font-size: 8px;
|
|
height: 8px;
|
|
line-height: 1.1;
|
|
/* Workaround for IE9 - IE11 */
|
|
text-decoration: underline;
|
|
}
|
|
|
|
[dir=rtl].handsontable span.colHeader.columnSorting::after {
|
|
left: -15px;
|
|
right: unset;
|
|
/* For purpose of continuous mouse over experience, when moving between the `::before` and the `::after` elements */
|
|
padding-right: 5px;
|
|
padding-left: unset;
|
|
}
|
|
|
|
/* Workaround for IE9 - IE11, https://stackoverflow.com/a/21902566, https://stackoverflow.com/a/32120247 */
|
|
.handsontable span.colHeader.columnSorting::after {
|
|
text-decoration: none;
|
|
}
|
|
|
|
/* We support up to 7 numeric indicators, describing order of column in sorted columns queue */
|
|
.handsontable span.colHeader.columnSorting[class^=sort-]::after,
|
|
.handsontable span.colHeader.columnSorting[class*=" sort-"]::after {
|
|
content: "+";
|
|
}
|
|
|
|
.handsontable span.colHeader.columnSorting.sort-1::after {
|
|
content: "1";
|
|
}
|
|
|
|
.handsontable span.colHeader.columnSorting.sort-2::after {
|
|
content: "2";
|
|
}
|
|
|
|
.handsontable span.colHeader.columnSorting.sort-3::after {
|
|
content: "3";
|
|
}
|
|
|
|
.handsontable span.colHeader.columnSorting.sort-4::after {
|
|
content: "4";
|
|
}
|
|
|
|
.handsontable span.colHeader.columnSorting.sort-5::after {
|
|
content: "5";
|
|
}
|
|
|
|
.handsontable span.colHeader.columnSorting.sort-6::after {
|
|
content: "6";
|
|
}
|
|
|
|
.handsontable span.colHeader.columnSorting.sort-7::after {
|
|
content: "7";
|
|
}
|
|
|
|
/* Drop-down menu widens header by 5 pixels, sort sequence numbers won't overlap the icon; mainly for the IE9+ */
|
|
.htGhostTable th div button.changeType + span.colHeader.columnSorting:not(.indicatorDisabled) {
|
|
padding-right: 5px;
|
|
}
|
|
.handsontable thead th.hiddenHeader:not(:first-of-type) {
|
|
display: none;
|
|
}
|
|
@charset "UTF-8";
|
|
.handsontable th.ht_nestingLevels {
|
|
text-align: left;
|
|
padding-left: 7px;
|
|
}
|
|
|
|
[dir=rtl].handsontable th.ht_nestingLevels {
|
|
text-align: right;
|
|
padding-right: 7px;
|
|
}
|
|
|
|
.handsontable th div.ht_nestingLevels {
|
|
display: inline-block;
|
|
position: absolute;
|
|
left: 11px;
|
|
right: unset;
|
|
}
|
|
|
|
[dir=rtl].handsontable th div.ht_nestingLevels {
|
|
right: 11px;
|
|
left: unset;
|
|
}
|
|
|
|
.handsontable.innerBorderInlineStart th div.ht_nestingLevels,
|
|
.handsontable.innerBorderInlineStart ~ .handsontable th div.ht_nestingLevels {
|
|
right: 10px;
|
|
left: unset;
|
|
}
|
|
|
|
[dir=rtl].handsontable.innerBorderInlineStart th div.ht_nestingLevels, [dir=rtl].handsontable.innerBorderInlineStart ~ .handsontable th div.ht_nestingLevels {
|
|
left: 10px;
|
|
right: unset;
|
|
}
|
|
|
|
.handsontable th span.ht_nestingLevel {
|
|
display: inline-block;
|
|
}
|
|
|
|
.handsontable th span.ht_nestingLevel_empty {
|
|
display: inline-block;
|
|
width: 10px;
|
|
height: 1px;
|
|
float: left;
|
|
}
|
|
|
|
[dir=rtl].handsontable th span.ht_nestingLevel_empty {
|
|
float: right;
|
|
}
|
|
|
|
.handsontable th span.ht_nestingLevel::after {
|
|
content: "┐";
|
|
font-size: 9px;
|
|
display: inline-block;
|
|
position: relative;
|
|
bottom: 3px;
|
|
}
|
|
|
|
.handsontable th div.ht_nestingButton {
|
|
display: inline-block;
|
|
position: absolute;
|
|
right: -2px;
|
|
left: unset;
|
|
cursor: pointer;
|
|
}
|
|
|
|
[dir=rtl].handsontable th div.ht_nestingButton {
|
|
left: -2px;
|
|
right: unset;
|
|
}
|
|
|
|
.handsontable th div.ht_nestingButton.ht_nestingExpand::after {
|
|
content: "+";
|
|
}
|
|
|
|
.handsontable th div.ht_nestingButton.ht_nestingCollapse::after {
|
|
content: "-";
|
|
}
|
|
|
|
.handsontable.innerBorderInlineStart th div.ht_nestingButton,
|
|
.handsontable.innerBorderInlineStart ~ .handsontable th div.ht_nestingButton {
|
|
right: 0;
|
|
left: unset;
|
|
}
|
|
|
|
[dir=rtl].handsontable.innerBorderInlineStart th div.ht_nestingButton, [dir=rtl].handsontable.innerBorderInlineStart ~ .handsontable th div.ht_nestingButton {
|
|
left: 0;
|
|
right: unset;
|
|
}
|
|
|
|
/*# sourceMappingURL=handsontable.css.map*/ |