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 Worker 17*6dbdd20aSAndroid Build Coastguard Workerexport interface EmptyStateAttrs { 18*6dbdd20aSAndroid Build Coastguard Worker // Which material icon to show. 19*6dbdd20aSAndroid Build Coastguard Worker // Defaults to 'search'. 20*6dbdd20aSAndroid Build Coastguard Worker icon?: string; 21*6dbdd20aSAndroid Build Coastguard Worker 22*6dbdd20aSAndroid Build Coastguard Worker // Some text to show under the icon. No text shown if omitted. 23*6dbdd20aSAndroid Build Coastguard Worker title?: string; 24*6dbdd20aSAndroid Build Coastguard Worker 25*6dbdd20aSAndroid Build Coastguard Worker // Additional class name applied to our container. 26*6dbdd20aSAndroid Build Coastguard Worker className?: string; 27*6dbdd20aSAndroid Build Coastguard Worker} 28*6dbdd20aSAndroid Build Coastguard Worker 29*6dbdd20aSAndroid Build Coastguard Worker// Something to show when there's nothing else to show! 30*6dbdd20aSAndroid Build Coastguard Worker// Features a large icon, followed by some text explaining what went wrong, and 31*6dbdd20aSAndroid Build Coastguard Worker// some optional content passed as children elements, usually containing common 32*6dbdd20aSAndroid Build Coastguard Worker// actions for things you might want to do next (e.g. clear a search box). 33*6dbdd20aSAndroid Build Coastguard Workerexport class EmptyState implements m.ClassComponent<EmptyStateAttrs> { 34*6dbdd20aSAndroid Build Coastguard Worker view({attrs, children}: m.Vnode<EmptyStateAttrs, this>): void | m.Children { 35*6dbdd20aSAndroid Build Coastguard Worker const { 36*6dbdd20aSAndroid Build Coastguard Worker icon = 'search', // Icon defaults to the search symbol 37*6dbdd20aSAndroid Build Coastguard Worker title, 38*6dbdd20aSAndroid Build Coastguard Worker className, 39*6dbdd20aSAndroid Build Coastguard Worker } = attrs; 40*6dbdd20aSAndroid Build Coastguard Worker return m( 41*6dbdd20aSAndroid Build Coastguard Worker '.pf-empty-state', 42*6dbdd20aSAndroid Build Coastguard Worker {className}, 43*6dbdd20aSAndroid Build Coastguard Worker m('i.material-icons', icon), 44*6dbdd20aSAndroid Build Coastguard Worker title && m('.pf-empty-state-title', title), 45*6dbdd20aSAndroid Build Coastguard Worker m('.pf-empty-state-content', children), 46*6dbdd20aSAndroid Build Coastguard Worker ); 47*6dbdd20aSAndroid Build Coastguard Worker } 48*6dbdd20aSAndroid Build Coastguard Worker} 49