Skip to content

DateTimeEditMixin

Base classes

Name Children Inherits
AbstractSpinBoxMixin
prettyqt.widgets.abstractspinbox

Subclasses

Class Module Description
DateTimeEdit prettyqt.widgets.datetimeedit
DateEdit prettyqt.widgets.dateedit
TimeEdit prettyqt.widgets.timeedit

⋔ Inheritance diagram

graph TD
  1473296246128["widgets.DateTimeEditMixin"]
  1473293702880["widgets.AbstractSpinBoxMixin"]
  1473293688240["widgets.WidgetMixin"]
  1473299815024["core.ObjectMixin"]
  140713234304496["builtins.object"]
  1473245548480["gui.PaintDeviceMixin"]
  1473293702880 --> 1473296246128
  1473293688240 --> 1473293702880
  1473299815024 --> 1473293688240
  140713234304496 --> 1473299815024
  1473245548480 --> 1473293688240
  140713234304496 --> 1473245548480

🛈 DocStrings

Bases: AbstractSpinBoxMixin

Widget for editing dates and times.

Source code in prettyqt\widgets\datetimeedit.py
class DateTimeEditMixin(widgets.AbstractSpinBoxMixin):
    """Widget for editing dates and times."""

    value_changed = core.Signal(datetime.datetime)

    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        self.setCalendarPopup(True)
        self.dateTimeChanged.connect(self.datetime_changed)

    def _get_map(self):
        maps = super()._get_map()
        maps |= {
            "timeSpec": constants.TIME_SPEC,
            "currentSection": SECTIONS,
        }
        return maps

    def datetime_changed(self, date):
        dt = self.get_datetime()
        self.value_changed.emit(dt)

    def set_to_today(self):
        self.setDateTime(core.DateTime.currentDateTime())

    def get_section_text(
        self, section: SectionStr | widgets.QDateTimeEdit.Section
    ) -> str:
        return self.sectionText(SECTIONS.get_enum_value(section))

    def get_current_section(self) -> SectionStr:
        return SECTIONS.inverse[self.currentSection()]

    def set_current_section(self, section: SectionStr | widgets.QDateTimeEdit.Section):
        self.setCurrentSection(SECTIONS.get_enum_value(section))

    def get_displayed_sections(self) -> list[SectionStr]:
        return SECTIONS.get_list(self.displayedSections())

    def set_range(
        self,
        lower: datatypes.DateTimeType,
        upper: datatypes.DateTimeType,
    ):
        lower = datatypes.to_datetime(lower)
        upper = datatypes.to_datetime(upper)
        self.setToolTip(f"{lower} <= x <= {upper}")
        self.setDateTimeRange(lower, upper)

    def set_format(self, fmt: str):
        self.setDisplayFormat(fmt)

    def get_value(self) -> datetime.datetime:
        return self.get_datetime()

    def set_value(self, value: datatypes.DateTimeType):
        self.setDateTime(datatypes.to_datetime(value))

    def get_datetime(self) -> datetime.datetime:
        return self.dateTime().toPython()  # type: ignore

    def min_datetime(self) -> datetime.datetime:
        return self.minimumDateTime().toPython()  # type: ignore

    def max_datetime(self) -> datetime.datetime:
        return self.maximumDateTime().toPython()  # type: ignore

    def min_date(self) -> datetime.date:
        return self.minimumDate().toPython()  # type: ignore

    def max_date(self) -> datetime.date:
        return self.maximumDate().toPython()  # type: ignore

    def get_date(self) -> datetime.date:
        return self.date().toPython()  # type: ignore

    def min_time(self) -> datetime.time:
        return self.minimumTime().toPython()  # type: ignore

    def max_time(self) -> datetime.time:
        return self.maximumTime().toPython()  # type: ignore

    def get_time(self) -> datetime.time:
        return self.time().toPython()  # type: ignore