Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
SeleniumHQ
GitHub Repository: SeleniumHQ/Selenium
Path: blob/trunk/third_party/closure/goog/ui/menuseparatorrenderer.js
4116 views
1
/**
2
* @license
3
* Copyright The Closure Library Authors.
4
* SPDX-License-Identifier: Apache-2.0
5
*/
6
7
/**
8
* @fileoverview Renderer for {@link goog.ui.MenuSeparator}s.
9
*/
10
11
goog.provide('goog.ui.MenuSeparatorRenderer');
12
13
goog.require('goog.dom');
14
goog.require('goog.dom.TagName');
15
goog.require('goog.dom.classlist');
16
goog.require('goog.ui.ControlRenderer');
17
goog.requireType('goog.ui.Control');
18
goog.requireType('goog.ui.ControlContent');
19
20
21
22
/**
23
* Renderer for menu separators.
24
* @constructor
25
* @extends {goog.ui.ControlRenderer}
26
*/
27
goog.ui.MenuSeparatorRenderer = function() {
28
'use strict';
29
goog.ui.ControlRenderer.call(this);
30
};
31
goog.inherits(goog.ui.MenuSeparatorRenderer, goog.ui.ControlRenderer);
32
goog.addSingletonGetter(goog.ui.MenuSeparatorRenderer);
33
34
35
/**
36
* Default CSS class to be applied to the root element of components rendered
37
* by this renderer.
38
* @type {string}
39
*/
40
goog.ui.MenuSeparatorRenderer.CSS_CLASS = goog.getCssName('goog-menuseparator');
41
42
43
/**
44
* Returns an empty, styled menu separator DIV. Overrides {@link
45
* goog.ui.ControlRenderer#createDom}.
46
* @param {goog.ui.Control} separator goog.ui.Separator to render.
47
* @return {!Element} Root element for the separator.
48
* @override
49
*/
50
goog.ui.MenuSeparatorRenderer.prototype.createDom = function(separator) {
51
'use strict';
52
return separator.getDomHelper().createDom(
53
goog.dom.TagName.DIV, this.getCssClass());
54
};
55
56
57
/**
58
* Takes an existing element, and decorates it with the separator. Overrides
59
* {@link goog.ui.ControlRenderer#decorate}.
60
* @param {goog.ui.Control} separator goog.ui.MenuSeparator to decorate the
61
* element.
62
* @param {Element} element Element to decorate.
63
* @return {!Element} Decorated element.
64
* @override
65
*/
66
goog.ui.MenuSeparatorRenderer.prototype.decorate = function(
67
separator, element) {
68
'use strict';
69
// Normally handled in the superclass. But we don't call the superclass.
70
if (element.id) {
71
separator.setId(element.id);
72
}
73
74
if (element.tagName == goog.dom.TagName.HR) {
75
// Replace HR with separator.
76
var hr = element;
77
element = this.createDom(separator);
78
goog.dom.insertSiblingBefore(element, hr);
79
goog.dom.removeNode(hr);
80
} else {
81
goog.dom.classlist.add(element, this.getCssClass());
82
}
83
return element;
84
};
85
86
87
/**
88
* Overrides {@link goog.ui.ControlRenderer#setContent} to do nothing, since
89
* separators are empty.
90
* @param {Element} separator The separator's root element.
91
* @param {goog.ui.ControlContent} content Text caption or DOM structure to be
92
* set as the separators's content (ignored).
93
* @override
94
*/
95
goog.ui.MenuSeparatorRenderer.prototype.setContent = function(
96
separator, content) {
97
// Do nothing. Separators are empty.
98
};
99
100
101
/**
102
* Returns the CSS class to be applied to the root element of components
103
* rendered using this renderer.
104
* @return {string} Renderer-specific CSS class.
105
* @override
106
*/
107
goog.ui.MenuSeparatorRenderer.prototype.getCssClass = function() {
108
'use strict';
109
return goog.ui.MenuSeparatorRenderer.CSS_CLASS;
110
};
111
112