Ticket T320602
Visible to All Users

DateEditCalendar missing in DevExpress.XtraEditors.Controls

created 9 years ago

After switching our project from 15.1.8 to 15.2.3 the object DateEditCalendar is missing in the namespace DevExpress.XtraEditors.Controls.

Comments (3)
HL HL
Holger Lessing 9 years ago

    The same problem with the object VistaDateEditCalendar

    Alisher (DevExpress Support) 9 years ago

      Hi Holger,

      We have redesigned our DateEdit control. Would you please clarify why you need to use the DateEditCalendar class? Describe your scenario in greater detail. Perhaps, our redesigned DateEdit supports the required functionality out of the box.
      I hope to hear from you soon.

      HL HL
      Holger Lessing 9 years ago

        See our sample code attached in this comment.

        Answers approved by DevExpress Support

        created 9 years ago

        Hello,

        Since we have modified the DateEdit control in the 15.2 version, you don't need to create VistaPopupDateEditForm and VistaDateEditCalendar class descendants.
        Instead, create PopupDateEditForm and CalendarControl class descendants and override the PopupDateEditForm.CreateCalendar and CalendarControl.OnMouseUp methods.
        I've created a sample to illustrate how to achieve the required result. Please try it and let me know if it meets your requirements.

          Show previous comments (1)
          Andrew Ser (DevExpress Support) 9 years ago

            Hello Oliver,
            Replace that line with the following one in the CustomCalendarControl's constructor:

            Visual Basic
            Me.VistaCalendarViewStyle = DevExpress.XtraEditors.VistaCalendarViewStyle.YearView

            I hope you find this information useful.

              > Would you please clarify why you need to use the DateEditCalendar class?

              I don't like to be forced to change my implementation after I update a framework I use. Nobody likes it. You made us to spend time on something that we don't want to do and doesn't give us benefits. It should be backward compatible. This is why I need it. Sorry, but this is how I see it.

              Andrew Ser (DevExpress Support) 9 years ago

                Hello,
                We agree that nobody likes changing the code after upgrading when it worked correctly before the upgrade. Yes, as a developer, I completely understand how frustrating this can be.
                That's why even though we received many requests from our customers, we did our best to avoid internal modifications in DateEdit. However, when analyzing our customer requests and the solutions we provide involving DateEdit, we came to the conclusion that we had to make this change. Otherwise, with customer requirements growing, these solutions become more and more complex and as a result, such projects will be very difficult to maintain. Moreover, there were many popular scenarios that couldn't be implemented with the old architecture. Some of them required heavy customization or creating custom DateEdits. We collected the most popular of such scenarios and supported them out of the box to simplify the process of creating descendants.
                Our modifications barely change the public API. So, for those users who don't have custom editors, this change should not be noticeable. Nevertheless, we understand that custom DateEdits may be broken. Thus, we did our best to minimize the difference between old and new DateEdit's structure. You no doubt understand, it's impossible to add new features without internal modifications.

                Here are several of the most popular features that previously required a lot of coding and now are supported out of the box:
                DateEdit - How to select multiple dates
                DateEdit - How to enlarge dates in calendars on hovering with the mouse
                How to add notes to a DateEdit calendar
                How to change the Today date for the DateEdit.

                It is likely that the functionality you implemented in the DateEdit's descendant is easier to implement now.
                In any case, if you have any issues with upgrading your code, just let us know. We will be happy to assist you with this task.

                Disclaimer: The information provided on DevExpress.com and affiliated web properties (including the DevExpress Support Center) is provided "as is" without warranty of any kind. Developer Express Inc disclaims all warranties, either express or implied, including the warranties of merchantability and fitness for a particular purpose. Please refer to the DevExpress.com Website Terms of Use for more information in this regard.

                Confidential Information: Developer Express Inc does not wish to receive, will not act to procure, nor will it solicit, confidential or proprietary materials and information from you through the DevExpress Support Center or its web properties. Any and all materials or information divulged during chats, email communications, online discussions, Support Center tickets, or made available to Developer Express Inc in any manner will be deemed NOT to be confidential by Developer Express Inc. Please refer to the DevExpress.com Website Terms of Use for more information in this regard.