use std::ops::Deref;
use dom_struct::dom_struct;
use servo_base::cross_process_instant::CrossProcessInstant;
use time::Duration;
use crate::dom::bindings::codegen::Bindings::DocumentBinding::DocumentVisibilityState;
use crate::dom::bindings::codegen::Bindings::PerformanceEntryBinding::PerformanceEntryMethods;
use crate::dom::bindings::codegen::Bindings::VisibilityStateEntryBinding::VisibilityStateEntryMethods;
use crate::dom::bindings::num::Finite;
use crate::dom::bindings::reflector::reflect_dom_object;
use crate::dom::bindings::root::DomRoot;
use crate::dom::bindings::str::DOMString;
use crate::dom::globalscope::GlobalScope;
use crate::dom::performance::performanceentry::{EntryType, PerformanceEntry};
use crate::script_runtime::CanGc;
#[dom_struct]
pub(crate) struct VisibilityStateEntry {
entry: PerformanceEntry,
}
impl VisibilityStateEntry {
fn new_inherited(
state: DocumentVisibilityState,
timestamp: CrossProcessInstant,
) -> VisibilityStateEntry {
let name = match state {
DocumentVisibilityState::Visible => DOMString::from("visible"),
DocumentVisibilityState::Hidden => DOMString::from("hidden"),
};
VisibilityStateEntry {
entry: PerformanceEntry::new_inherited(
name,
EntryType::VisibilityState,
Some(timestamp),
Duration::ZERO,
),
}
}
pub(crate) fn new(
global: &GlobalScope,
state: DocumentVisibilityState,
timestamp: CrossProcessInstant,
can_gc: CanGc,
) -> DomRoot<VisibilityStateEntry> {
reflect_dom_object(
Box::new(VisibilityStateEntry::new_inherited(state, timestamp)),
global,
can_gc,
)
}
}
impl VisibilityStateEntryMethods<crate::DomTypeHolder> for VisibilityStateEntry {
fn Name(&self) -> DOMString {
self.entry.Name()
}
fn EntryType(&self) -> DOMString {
self.entry.EntryType()
}
fn StartTime(&self) -> Finite<f64> {
self.entry.StartTime()
}
fn Duration(&self) -> u32 {
*self.entry.Duration().deref() as u32
}
}