from typing import Optional, List
from validator_collection import validators, checkers
from highcharts_core.metaclasses import HighchartsMeta
from highcharts_core.decorators import class_sensitive, validate_types
from highcharts_core.options.sonification.track_configurations import (InstrumentTrackConfiguration,
                                                                       SpeechTrackConfiguration,
                                                                       ContextTrackConfiguration)
from highcharts_core.options.sonification.grouping import SonificationGrouping
[docs]class SeriesSonification(HighchartsMeta):
    """Sonification/audio chart options for a series."""
    
    def __init__(self, **kwargs):
        self._context_tracks = None
        self._default_instrument_options = None
        self._default_speech_options = None
        self._enabled = None
        self._point_grouping = None
        self._tracks = None
        
        self.context_tracks = kwargs.get('context_tracks', None)
        self.default_instrument_options = kwargs.get('default_instrument_options', None)
        self.default_speech_options = kwargs.get('default_speech_options', None)
        self.enabled = kwargs.get('enabled', None)
        self.point_grouping = kwargs.get('point_grouping', None)
        self.tracks = kwargs.get('tracks', None)
        
    @property
    def context_tracks(self) -> Optional[ContextTrackConfiguration | List[ContextTrackConfiguration]]:
        """Context tracks for the series. Context tracks are not tied to data points.
        
        :rtype: :class:`ContextTrackConfiguration <highcharts_core.options.sonification.track_configurations.ContextTrackConfiguration>` 
          or :class:`list <python:list>` of track configuration types
        """
        return self._context_tracks
    
    @context_tracks.setter
    def context_tracks(self, value):
        if not value:
            self._context_tracks = None
        elif checkers.is_iterable(value, forbid_literals = (str, bytes, dict)):
                self._context_tracks = [validate_types(x, types = (ContextTrackConfiguration)) for x in value]
        else:
            value = validate_types(value, types = ContextTrackConfiguration)
            self._context_tracks = value
    
    @property
    def default_instrument_options(self) -> Optional[InstrumentTrackConfiguration]:
        """Default sonification options for all instrument tracks.
        .. warning::
        
          If specific options are also set on individual tracks or per-series, this configuration will be *overridden*.
        
        :rtype: :class:`InstrumentTrackConfiguration <highcharts_core.options.sonification.track_configurations.InstrumentTrackConfiguration>`
          or :obj:`None <python:None>`
        """
        return self._default_instrument_options
    
    @default_instrument_options.setter
    @class_sensitive(InstrumentTrackConfiguration)
    def default_instrument_options(self, value):
        self._default_instrument_options = value
        
    @property
    def default_speech_options(self) -> Optional[SpeechTrackConfiguration]:
        """Default sonification options for all speech tracks.
        .. warning::
        
          If specific options are also set on individual tracks or per-series, this configuration will be *overridden*.
        
        :rtype: :class:`SpeechTrackConfiguration <highcharts_core.options.sonification.track_configurations.SpeechTrackConfiguration>`
          or :obj:`None <python:None>`
        """
        return self._default_speech_options
    
    @default_speech_options.setter
    @class_sensitive(SpeechTrackConfiguration)
    def default_speech_options(self, value):
        self._default_speech_options = value
        
    @property
    def enabled(self) -> Optional[bool]:
        """If ``True``, sonification will be enabled for the series.
        
        :rtype: :class:`bool <python:bool>` or :obj:`None <python:None>`
        """
        return self._enabled
    
    @enabled.setter
    def enabled(self, value):
        if value is None:
            self._enabled = None
        else:
            self._enabled = bool(value)
            
    @property
    def point_grouping(self) -> Optional[SonificationGrouping]:
        """Options for grouping data points together when sonifying. 
        
        This allows for the visual presentation to contain more points than what is being played. 
        
        If not enabled, all visible / uncropped points are played.
        
        :rtype: :class:`SonificationGrouping <highcharts_core.options.sonification.grouping.SonificationGrouping>` or
          :obj:`None <python:None>`
        """
        return self._point_grouping
    
    @point_grouping.setter
    @class_sensitive(SonificationGrouping)
    def point_grouping(self, value):
        self._point_grouping = value
        
    @property
    def tracks(self) -> Optional[ContextTrackConfiguration | List[ContextTrackConfiguration]]:
        """Tracks for the series.
        
        :rtype: :class:`ContextTrackConfiguration <highcharts_core.options.sonification.track_configurations.ContextTrackConfiguration>` 
          or :class:`list <python:list>` of 
          :class:`ContextTrackConfiguration <highcharts_core.options.sonification.track_configurations.ContextTrackConfiguration>`
          or :obj:`None <python:None>`
        """
        return self._tracks
    
    @tracks.setter
    def tracks(self, value):
        if not value:
            self._tracks = None
        elif checkers.is_iterable(value, forbid_literals = (str, bytes, dict)):
            self._tracks = [validate_types(x, types = (ContextTrackConfiguration)) for x in value]
        else:
            self._tracks = validate_types(value, types = (ContextTrackConfiguration))
    @classmethod
    def _get_kwargs_from_dict(cls, as_dict):
        kwargs = {
            'context_tracks': as_dict.get('contextTracks', None),
            'default_instrument_options': as_dict.get('defaultInstrumentOptions', None),
            'default_speech_options': as_dict.get('defaultSpeechOptions', None),
            'enabled': as_dict.get('enabled', None),
            'point_grouping': as_dict.get('pointGrouping', None),
            'tracks': as_dict.get('tracks', None),
        }
        return kwargs
    def _to_untrimmed_dict(self, in_cls = None) -> dict:
        untrimmed = {
            'contextTracks': self.context_tracks,
            'defaultInstrumentOptions': self.default_instrument_options,
            'defaultSpeechOptions': self.default_speech_options,
            'enabled': self.enabled,
            'pointGrouping': self.point_grouping,
            'tracks': self.tracks,
        }
        return untrimmed