[SSE mobile] Refactoring filter options
This commit is contained in:
parent
10927e6f63
commit
e3be43c3ee
|
@ -410,6 +410,7 @@
|
||||||
"textFilterOptions": "Filter Options",
|
"textFilterOptions": "Filter Options",
|
||||||
"textClearFilter": "Clear Filter",
|
"textClearFilter": "Clear Filter",
|
||||||
"textDeleteFilter": "Delete Filter",
|
"textDeleteFilter": "Delete Filter",
|
||||||
|
"textSelectAll": "Select All",
|
||||||
"textEmptyItem": "{Blanks}",
|
"textEmptyItem": "{Blanks}",
|
||||||
"textErrorTitle": "Warning",
|
"textErrorTitle": "Warning",
|
||||||
"textErrorMsg": "You must choose at least one value"
|
"textErrorMsg": "You must choose at least one value"
|
||||||
|
|
|
@ -20,4 +20,16 @@
|
||||||
appearance: none;
|
appearance: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// For filter options
|
||||||
|
.radio-checkbox-item {
|
||||||
|
label.item-content input[type=checkbox]:checked ~ .item-inner {
|
||||||
|
background: no-repeat center;
|
||||||
|
background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2013%2010'%3E%3Cpolygon%20fill%3D'%2340865c'%20points%3D'11.6%2C0%204.4%2C7.2%201.4%2C4.2%200%2C5.6%204.4%2C10%204.4%2C10%204.4%2C10%2013%2C1.4%20'%2F%3E%3C%2Fsvg%3E");
|
||||||
|
background-position: calc(100% - 15px) center;
|
||||||
|
background-size: 13px 10px;
|
||||||
|
}
|
||||||
|
.icon.icon-checkbox {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,12 +2,14 @@
|
||||||
// Colors
|
// Colors
|
||||||
@themeColorLight: #a2bdde;
|
@themeColorLight: #a2bdde;
|
||||||
@navBarIconColor: #fff;
|
@navBarIconColor: #fff;
|
||||||
|
@listButtonBorderColor: rgba(0,0,0,0.15);
|
||||||
|
|
||||||
|
|
||||||
.device-android {
|
.device-android {
|
||||||
--f7-navbar-bg-color: @themeColor;
|
--f7-navbar-bg-color: @themeColor;
|
||||||
--f7-navbar-link-color: @navBarIconColor;
|
--f7-navbar-link-color: @navBarIconColor;
|
||||||
--f7-navbar-text-color: @navBarIconColor;
|
--f7-navbar-text-color: @navBarIconColor;
|
||||||
|
--f7-list-button-border-color: @listButtonBorderColor;
|
||||||
|
|
||||||
// Main Toolbar
|
// Main Toolbar
|
||||||
#editor-navbar.navbar .right {
|
#editor-navbar.navbar .right {
|
||||||
|
@ -21,34 +23,30 @@
|
||||||
align-items: center;
|
align-items: center;
|
||||||
width: auto;
|
width: auto;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
.icon.icon-checkbox {
|
// For filter options
|
||||||
width: 20px;
|
.radio-checkbox-item {
|
||||||
height: 20px;
|
.icon.icon-checkbox {
|
||||||
border-radius: 20px;
|
width: 20px;
|
||||||
border: 2px solid #6d6d6d;
|
height: 20px;
|
||||||
}
|
border-radius: 20px;
|
||||||
label.item-checkbox input[type='checkbox']:checked ~
|
border: 2px solid var(--f7-checkbox-inactive-color);
|
||||||
.icon-checkbox, label.item-checkbox input[type='checkbox']:checked ~
|
}
|
||||||
* .icon-checkbox, .checkbox input[type='checkbox']:checked ~
|
label.item-checkbox input[type='checkbox']:checked ~ .icon-checkbox {
|
||||||
i, label.item-checkbox input[type='checkbox']:indeterminate ~
|
border-color: @themeColor;
|
||||||
.icon-checkbox, label.item-checkbox input[type='checkbox']:indeterminate ~ * .icon-checkbox, .checkbox input[type='checkbox']:indeterminate ~ i{
|
background-color: transparent;
|
||||||
border-color: #40865c;
|
}
|
||||||
background-color: transparent;
|
label.item-content i.icon.icon-checkbox:after {
|
||||||
}
|
content: ' ';
|
||||||
label.item-content i.icon.icon-checkbox:after {
|
position: absolute;
|
||||||
content: ' ';
|
width: 10px;
|
||||||
position: absolute;
|
height: 10px;
|
||||||
width: 10px;
|
left: 50%;
|
||||||
height: 10px;
|
top: 50%;
|
||||||
left: 50%;
|
margin-left: -5px;
|
||||||
top: 50%;
|
margin-top: -5px;
|
||||||
margin-left: -5px;
|
background-color: @themeColor;
|
||||||
margin-top: -5px;
|
border-radius: 100%;
|
||||||
background-color: #40865c;
|
}
|
||||||
border-radius: 100%;
|
}
|
||||||
}
|
|
||||||
.device-android .button-raised{
|
|
||||||
box-shadow: none;
|
|
||||||
}
|
}
|
|
@ -474,14 +474,4 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
label.item-content input[type=checkbox]:checked~.item-inner,
|
|
||||||
label.item-content input[type=radio]:checked~.item-inner {
|
|
||||||
background: no-repeat center;
|
|
||||||
background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2013%2010'%3E%3Cpolygon%20fill%3D'%2340865c'%20points%3D'11.6%2C0%204.4%2C7.2%201.4%2C4.2%200%2C5.6%204.4%2C10%204.4%2C10%204.4%2C10%2013%2C1.4%20'%2F%3E%3C%2Fsvg%3E");
|
|
||||||
background-position: 90% center;
|
|
||||||
background-size: 13px 10px;
|
|
||||||
}
|
|
||||||
.icon.icon-checkbox{
|
|
||||||
display:none;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -112,9 +112,7 @@ class MainPage extends Component {
|
||||||
<CollaborationView onclosed={this.handleOptionsViewClosed.bind(this, 'coauth')} />
|
<CollaborationView onclosed={this.handleOptionsViewClosed.bind(this, 'coauth')} />
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
<FilterOptionsController />
|
||||||
<FilterOptionsController />
|
|
||||||
}
|
|
||||||
|
|
||||||
<Statusbar />
|
<Statusbar />
|
||||||
|
|
||||||
|
|
|
@ -8,8 +8,6 @@ const FilterOptions = (props) => {
|
||||||
const _t = t('View.Edit', {returnObjects: true});
|
const _t = t('View.Edit', {returnObjects: true});
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
const $clearFilter = $$("#button-clear-filter");
|
|
||||||
props.isValid ? $clearFilter.addClass('disabled') : $clearFilter.removeClass('disabled');
|
|
||||||
const is_all_checked = props.listVal.every(item => item.check);
|
const is_all_checked = props.listVal.every(item => item.check);
|
||||||
setAll(is_all_checked);
|
setAll(is_all_checked);
|
||||||
});
|
});
|
||||||
|
@ -47,13 +45,13 @@ const FilterOptions = (props) => {
|
||||||
</ListItem>
|
</ListItem>
|
||||||
</List>
|
</List>
|
||||||
<List >
|
<List >
|
||||||
<ListButton color="black" className="item-link button-raised" id='button-clear-filter' onClick={HandleClearFilter}>{_t.textClearFilter}</ListButton>
|
<ListButton color="black" className={props.isValid ? 'disabled' : ''} onClick={HandleClearFilter}>{_t.textClearFilter}</ListButton>
|
||||||
<ListButton color="red" onClick={() => props.onDeleteFilter()} id="btn-delete-filter">{_t.textDeleteFilter}</ListButton>
|
<ListButton color="red" onClick={() => props.onDeleteFilter()} id="btn-delete-filter">{_t.textDeleteFilter}</ListButton>
|
||||||
</List>
|
</List>
|
||||||
<List>
|
<List>
|
||||||
<ListItem onChange={e => props.onUpdateCell('all', e.target.checked)} name='filter-cellAll' checkbox checked={all}>Select All</ListItem>
|
<ListItem className='radio-checkbox-item' onChange={e => props.onUpdateCell('all', e.target.checked)} name='filter-cellAll' checkbox checked={all}>{_t.textSelectAll}</ListItem>
|
||||||
{props.listVal.map((value) =>
|
{props.listVal.map((value) =>
|
||||||
<ListItem onChange={e => props.onUpdateCell(value.id, e.target.checked)} key={value.value} name='filter-cell' value={value.value} title={value.cellvalue} checkbox checked={value.check} />
|
<ListItem className='radio-checkbox-item' onChange={e => props.onUpdateCell(value.id, e.target.checked)} key={value.value} name='filter-cell' value={value.value} title={value.cellvalue} checkbox checked={value.check} />
|
||||||
)}
|
)}
|
||||||
</List>
|
</List>
|
||||||
</Page>
|
</Page>
|
||||||
|
|
Loading…
Reference in a new issue