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 SwitchAttrs extends HTMLCheckboxAttrs { 20*6dbdd20aSAndroid Build Coastguard Worker // Optional text to show to the right of the switch. 21*6dbdd20aSAndroid Build Coastguard Worker // If omitted, no text will be shown. 22*6dbdd20aSAndroid Build Coastguard Worker label?: string; 23*6dbdd20aSAndroid Build Coastguard Worker} 24*6dbdd20aSAndroid Build Coastguard Worker 25*6dbdd20aSAndroid Build Coastguard Workerexport class Switch implements m.ClassComponent<SwitchAttrs> { 26*6dbdd20aSAndroid Build Coastguard Worker view({attrs}: m.CVnode<SwitchAttrs>) { 27*6dbdd20aSAndroid Build Coastguard Worker const {label, checked, disabled, className, ...htmlAttrs} = attrs; 28*6dbdd20aSAndroid Build Coastguard Worker 29*6dbdd20aSAndroid Build Coastguard Worker const classes = classNames(disabled && 'pf-disabled', className); 30*6dbdd20aSAndroid Build Coastguard Worker 31*6dbdd20aSAndroid Build Coastguard Worker // The default checkbox is removed and an entirely new one created inside 32*6dbdd20aSAndroid Build Coastguard Worker // the span element in CSS. 33*6dbdd20aSAndroid Build Coastguard Worker return m( 34*6dbdd20aSAndroid Build Coastguard Worker 'label.pf-switch', 35*6dbdd20aSAndroid Build Coastguard Worker { 36*6dbdd20aSAndroid Build Coastguard Worker ...htmlAttrs, 37*6dbdd20aSAndroid Build Coastguard Worker className: classes, 38*6dbdd20aSAndroid Build Coastguard Worker }, 39*6dbdd20aSAndroid Build Coastguard Worker m('input[type=checkbox]', {disabled, checked}), 40*6dbdd20aSAndroid Build Coastguard Worker m('span'), 41*6dbdd20aSAndroid Build Coastguard Worker label, 42*6dbdd20aSAndroid Build Coastguard Worker ); 43*6dbdd20aSAndroid Build Coastguard Worker } 44*6dbdd20aSAndroid Build Coastguard Worker} 45