View Javadoc
1   /*
2    * Copyright (c) 2002-2025 Gargoyle Software Inc.
3    *
4    * Licensed under the Apache License, Version 2.0 (the "License");
5    * you may not use this file except in compliance with the License.
6    * You may obtain a copy of the License at
7    * https://www.apache.org/licenses/LICENSE-2.0
8    *
9    * Unless required by applicable law or agreed to in writing, software
10   * distributed under the License is distributed on an "AS IS" BASIS,
11   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12   * See the License for the specific language governing permissions and
13   * limitations under the License.
14   */
15  package org.htmlunit.javascript.host;
16  
17  import org.htmlunit.corejs.javascript.Function;
18  import org.htmlunit.javascript.configuration.JsxClass;
19  import org.htmlunit.javascript.configuration.JsxConstructor;
20  import org.htmlunit.javascript.configuration.JsxGetter;
21  import org.htmlunit.javascript.configuration.JsxSetter;
22  import org.htmlunit.javascript.host.event.Event;
23  import org.htmlunit.javascript.host.event.EventTarget;
24  
25  /**
26   * A JavaScript object for {@code ScreenOrientation}.
27   *
28   * @author Ahmed Ashour
29   * @author Ronald Brill
30   */
31  @JsxClass
32  public class ScreenOrientation extends EventTarget {
33  
34      /**
35       * JavaScript constructor.
36       */
37      @Override
38      @JsxConstructor
39      public void jsConstructor() {
40          super.jsConstructor();
41      }
42  
43      /**
44       * Returns the {@code angle} property.
45       * @return the {@code angle} property
46       */
47      @JsxGetter
48      public int getAngle() {
49          return 0;
50      }
51  
52      /**
53       * Returns the {@code type} property.
54       * @return the {@code type} property
55       */
56      @JsxGetter
57      public String getType() {
58          return "landscape-primary";
59      }
60  
61      /**
62       * Returns the {@code onchange} event handler for this element.
63       * @return the {@code onchange} event handler for this element
64       */
65      @JsxGetter
66      public Function getOnchange() {
67          return getEventHandler(Event.TYPE_CHANGE);
68      }
69  
70      /**
71       * Setter for the {@code onchange} event handler.
72       * @param change the handler
73       */
74      @JsxSetter
75      public void setOnchange(final Object change) {
76          setEventHandler(Event.TYPE_CHANGE, change);
77      }
78  }