use std::ops::Index;
use scraper::ElementRef;
use super::{
FromSapTable, SapTableDef, SapTableHeader,
cell::{SapTableCellDefWrapper, SapTableCellWrapper},
property::{SapTableRowType, SapTableSelectionState},
};
use crate::element::parser::ElementParser;
use crate::error::{ElementError, WebDynproError};
#[derive(Clone, Debug)]
#[allow(unused)]
pub struct SapTableRow {
table_def: SapTableDef,
cells: Vec<SapTableCellDefWrapper>,
row_index: Option<u32>,
user_data: Option<String>,
drag_data: Option<String>,
drop_target_info: Option<String>,
parent_drop_target_info: Option<String>,
selection_state: SapTableSelectionState,
row_type: SapTableRowType,
}
impl<'a> SapTableRow {
pub(super) fn new(
table_def: SapTableDef,
row_ref: ElementRef<'a>,
cells: Vec<SapTableCellDefWrapper>,
) -> Result<SapTableRow, ElementError> {
let row = row_ref.value();
Ok(SapTableRow {
table_def,
cells,
row_index: row.attr("rr").and_then(|s| s.parse::<u32>().ok()),
user_data: row.attr("uDat").map(|s| s.to_owned()),
drag_data: row.attr("ddData").map(|s| s.to_owned()),
drop_target_info: row.attr("ddDti").map(|s| s.to_owned()),
parent_drop_target_info: row.attr("ddPDti").map(|s| s.to_owned()),
selection_state: row.attr("sst").map(|s| s.into()).unwrap_or_default(),
row_type: row.attr("rt").map(|s| s.into()).unwrap_or_default(),
})
}
pub fn len(&self) -> usize {
self.cells.len()
}
#[must_use]
pub fn is_empty(&self) -> bool {
self.len() == 0
}
pub fn iter(&self) -> impl ExactSizeIterator<Item = &SapTableCellDefWrapper> {
self.cells.iter()
}
pub fn iter_value(
&'a self,
parser: &'a ElementParser,
) -> impl ExactSizeIterator<Item = Result<SapTableCellWrapper<'a>, WebDynproError>> {
self.cells
.iter()
.map(|def| SapTableCellWrapper::from_def(def, parser))
}
pub fn table_def(&self) -> SapTableDef {
self.table_def.clone()
}
pub fn row_index(&self) -> Option<u32> {
self.row_index
}
pub fn user_data(&self) -> Option<&str> {
self.user_data.as_deref()
}
pub fn drag_data(&self) -> Option<&str> {
self.drag_data.as_deref()
}
pub fn drop_target_info(&self) -> Option<&str> {
self.drop_target_info.as_deref()
}
pub fn parent_drop_target_info(&self) -> Option<&str> {
self.parent_drop_target_info.as_deref()
}
pub fn selection_state(&self) -> SapTableSelectionState {
self.selection_state
}
pub fn row_type(&self) -> SapTableRowType {
self.row_type
}
pub fn try_row_into<T: FromSapTable<'a>>(
&'a self,
header: Option<&'a SapTableHeader>,
parser: &'a ElementParser,
) -> Result<T, WebDynproError> {
T::from_table(header, self, parser)
}
}
impl Index<usize> for SapTableRow {
type Output = SapTableCellDefWrapper;
fn index(&self, index: usize) -> &Self::Output {
&self.cells[index]
}
}
impl From<&str> for SapTableSelectionState {
fn from(s: &str) -> Self {
match s {
"4" => Self::NotSelectable,
"0" => Self::NotSelected,
"2" => Self::Selected,
"1" => Self::PrimarySelected,
_ => Self::None,
}
}
}
impl From<&str> for SapTableRowType {
fn from(s: &str) -> Self {
match s {
"1" => Self::Standard,
"2" => Self::Header,
"3" => Self::Filter,
"4" => Self::TopFixed,
"5" => Self::BottomFixed,
"6" => Self::Pivot,
_ => Self::Unspecified,
}
}
}