1*6dbdd20aSAndroid Build Coastguard Worker// Copyright (C) 2023 The Android Open Source Project 2*6dbdd20aSAndroid Build Coastguard Worker// 3*6dbdd20aSAndroid Build Coastguard Worker// Licensed under the Apache License, Version 2.0 (the "License"); 4*6dbdd20aSAndroid Build Coastguard Worker// you may not use this file except in compliance with the License. 5*6dbdd20aSAndroid Build Coastguard Worker// You may obtain a copy of the License at 6*6dbdd20aSAndroid Build Coastguard Worker// 7*6dbdd20aSAndroid Build Coastguard Worker// http://www.apache.org/licenses/LICENSE-2.0 8*6dbdd20aSAndroid Build Coastguard Worker// 9*6dbdd20aSAndroid Build Coastguard Worker// Unless required by applicable law or agreed to in writing, software 10*6dbdd20aSAndroid Build Coastguard Worker// distributed under the License is distributed on an "AS IS" BASIS, 11*6dbdd20aSAndroid Build Coastguard Worker// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12*6dbdd20aSAndroid Build Coastguard Worker// See the License for the specific language governing permissions and 13*6dbdd20aSAndroid Build Coastguard Worker// limitations under the License. 14*6dbdd20aSAndroid Build Coastguard Worker 15*6dbdd20aSAndroid Build Coastguard Workerimport m from 'mithril'; 16*6dbdd20aSAndroid Build Coastguard Workerimport {classNames} from '../base/classnames'; 17*6dbdd20aSAndroid Build Coastguard Workerimport {HTMLCheckboxAttrs} from './common'; 18*6dbdd20aSAndroid Build Coastguard Worker 19*6dbdd20aSAndroid Build Coastguard Workerexport interface CheckboxAttrs extends HTMLCheckboxAttrs { 20*6dbdd20aSAndroid Build Coastguard Worker // Optional text to show to the right of the checkbox. 21*6dbdd20aSAndroid Build Coastguard Worker label?: string; 22*6dbdd20aSAndroid Build Coastguard Worker} 23*6dbdd20aSAndroid Build Coastguard Worker 24*6dbdd20aSAndroid Build Coastguard Workerexport class Checkbox implements m.ClassComponent<CheckboxAttrs> { 25*6dbdd20aSAndroid Build Coastguard Worker view({attrs}: m.CVnode<CheckboxAttrs>) { 26*6dbdd20aSAndroid Build Coastguard Worker const {label, disabled, checked, className, ...htmlAttrs} = attrs; 27*6dbdd20aSAndroid Build Coastguard Worker const classes = classNames(disabled && 'pf-disabled', className); 28*6dbdd20aSAndroid Build Coastguard Worker 29*6dbdd20aSAndroid Build Coastguard Worker // The default checkbox is removed and an entirely new one created inside 30*6dbdd20aSAndroid Build Coastguard Worker // the span element in CSS. 31*6dbdd20aSAndroid Build Coastguard Worker return m( 32*6dbdd20aSAndroid Build Coastguard Worker 'label.pf-checkbox', 33*6dbdd20aSAndroid Build Coastguard Worker { 34*6dbdd20aSAndroid Build Coastguard Worker ...htmlAttrs, 35*6dbdd20aSAndroid Build Coastguard Worker className: classes, 36*6dbdd20aSAndroid Build Coastguard Worker }, 37*6dbdd20aSAndroid Build Coastguard Worker m('input[type=checkbox]', {disabled, checked}), 38*6dbdd20aSAndroid Build Coastguard Worker m('span'), 39*6dbdd20aSAndroid Build Coastguard Worker label, 40*6dbdd20aSAndroid Build Coastguard Worker ); 41*6dbdd20aSAndroid Build Coastguard Worker } 42*6dbdd20aSAndroid Build Coastguard Worker} 43