-
Notifications
You must be signed in to change notification settings - Fork 168
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add transmission semantic for URI attribute values (#8826)
* Add transmission semantic for URI attribute values Fixes #8813 * Add some comments, correct javadocs * Fix GWT tests * Use one magic method instead of another * Check the type of JsonValue before read it
- Loading branch information
Denis
authored
Aug 12, 2020
1 parent
5cd56f6
commit 80e3194
Showing
9 changed files
with
145 additions
and
33 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -24,6 +24,7 @@ | |
import com.google.gwt.core.client.JavaScriptObject; | ||
import com.google.gwt.core.client.Scheduler; | ||
|
||
import com.vaadin.client.ApplicationConfiguration; | ||
import com.vaadin.client.Command; | ||
import com.vaadin.client.Console; | ||
import com.vaadin.client.ElementUtil; | ||
|
@@ -290,9 +291,9 @@ private native void bindPolymerModelProperties(StateNode node, | |
private native void hookUpPolymerElement(StateNode node, Element element) | ||
/*-{ | ||
var self = this; | ||
var originalPropertiesChanged = element._propertiesChanged; | ||
if (originalPropertiesChanged) { | ||
element._propertiesChanged = function (currentProps, changedProps, oldProps) { | ||
$entry(function () { | ||
|
@@ -301,16 +302,16 @@ private native void hookUpPolymerElement(StateNode node, Element element) | |
originalPropertiesChanged.apply(this, arguments); | ||
}; | ||
} | ||
var tree = [email protected]::getTree()(); | ||
var originalReady = element.ready; | ||
element.ready = function (){ | ||
originalReady.apply(this, arguments); | ||
@com.vaadin.client.PolymerUtils::fireReadyEvent(*)(element); | ||
// The _propertiesChanged method which is replaced above for the element | ||
// doesn't do anything for items in dom-repeat. | ||
// Instead it's called with some meaningful info for the <code>dom-repeat</code> element. | ||
|
@@ -319,7 +320,7 @@ private native void hookUpPolymerElement(StateNode node, Element element) | |
// which changes this method for any dom-repeat instance. | ||
var replaceDomRepeatPropertyChange = function(){ | ||
var domRepeat = element.root.querySelector('dom-repeat'); | ||
if ( domRepeat ){ | ||
// If the <code>dom-repeat</code> element is in the DOM then | ||
// this method should not be executed anymore. The logic below will replace | ||
|
@@ -333,12 +334,12 @@ private native void hookUpPolymerElement(StateNode node, Element element) | |
// if dom-repeat is found => replace _propertiesChanged method in the prototype and mark it as replaced. | ||
if ( !domRepeat.constructor.prototype.$propChangedModified){ | ||
domRepeat.constructor.prototype.$propChangedModified = true; | ||
var changed = domRepeat.constructor.prototype._propertiesChanged; | ||
domRepeat.constructor.prototype._propertiesChanged = function(currentProps, changedProps, oldProps){ | ||
changed.apply(this, arguments); | ||
var props = Object.getOwnPropertyNames(changedProps); | ||
var items = "items."; | ||
var i; | ||
|
@@ -359,7 +360,7 @@ private native void hookUpPolymerElement(StateNode node, Element element) | |
if( currentPropsItem && currentPropsItem.nodeId ){ | ||
var nodeId = currentPropsItem.nodeId; | ||
var value = currentPropsItem[propertyName]; | ||
// this is an attempt to find the template element | ||
// which is not available as a context in the protype method | ||
var host = this.__dataHost; | ||
|
@@ -370,7 +371,7 @@ private native void hookUpPolymerElement(StateNode node, Element element) | |
while( !host.localName || host.__dataHost ){ | ||
host = host.__dataHost; | ||
} | ||
$entry(function () { | ||
@SimpleElementBindingStrategy::handleListItemPropertyChange(*)(nodeId, host, propertyName, value, tree); | ||
})(); | ||
|
@@ -381,7 +382,7 @@ private native void hookUpPolymerElement(StateNode node, Element element) | |
}; | ||
} | ||
}; | ||
// dom-repeat doesn't have to be in DOM even if template has it | ||
// such situation happens if there is dom-if e.g. which evaluates to <code>false</code> initially. | ||
// in this case dom-repeat is not yet in the DOM tree until dom-if becomes <code>true</code> | ||
|
@@ -396,7 +397,7 @@ private native void hookUpPolymerElement(StateNode node, Element element) | |
element.addEventListener('dom-change',replaceDomRepeatPropertyChange); | ||
} | ||
} | ||
}-*/; | ||
|
||
private static void handleListItemPropertyChange(double nodeId, | ||
|
@@ -630,16 +631,21 @@ private void updateVisibility(JsArray<EventRemover> listeners, | |
private void updateVisibility(Element element, NodeMap visibilityData, | ||
Boolean visibility) { | ||
storeInitialHiddenAttribute(element, visibilityData); | ||
WidgetUtil.updateAttribute(element, HIDDEN_ATTRIBUTE, visibility); | ||
updateAttributeValue( | ||
visibilityData.getNode().getTree().getRegistry() | ||
.getApplicationConfiguration(), | ||
element, HIDDEN_ATTRIBUTE, visibility); | ||
} | ||
|
||
private void restoreInitialHiddenAttribute(Element element, | ||
NodeMap visibilityData) { | ||
MapProperty initialVisibility = storeInitialHiddenAttribute(element, | ||
visibilityData); | ||
if (initialVisibility.hasValue()) { | ||
WidgetUtil.updateAttribute(element, HIDDEN_ATTRIBUTE, | ||
initialVisibility.getValue()); | ||
updateAttributeValue( | ||
visibilityData.getNode().getTree().getRegistry() | ||
.getApplicationConfiguration(), | ||
element, HIDDEN_ATTRIBUTE, initialVisibility.getValue()); | ||
} | ||
} | ||
|
||
|
@@ -734,7 +740,10 @@ private void updateStyleProperty(MapProperty mapProperty, Element element) { | |
|
||
private void updateAttribute(MapProperty mapProperty, Element element) { | ||
String name = mapProperty.getName(); | ||
WidgetUtil.updateAttribute(element, name, mapProperty.getValue()); | ||
updateAttributeValue( | ||
mapProperty.getMap().getNode().getTree().getRegistry() | ||
.getApplicationConfiguration(), | ||
element, name, mapProperty.getValue()); | ||
} | ||
|
||
private EventRemover bindChildren(BindingContext context) { | ||
|
@@ -1366,6 +1375,35 @@ private EventRemover bindClientCallableMethods(BindingContext context) { | |
(Element) context.htmlNode, context.node); | ||
} | ||
|
||
private static void updateAttributeValue( | ||
ApplicationConfiguration configuration, Element element, | ||
String attribute, Object value) { | ||
if (value == null || value instanceof String) { | ||
WidgetUtil.updateAttribute(element, attribute, (String) value); | ||
} else { | ||
JsonValue jsonValue = WidgetUtil.crazyJsoCast(value); | ||
if (JsonType.OBJECT.equals(jsonValue.getType())) { | ||
JsonObject object = (JsonObject) jsonValue; | ||
assert object.hasKey( | ||
NodeProperties.URI_ATTRIBUTE) : "Implementation error: JsonObject is recieved as an attribute value for '" | ||
+ attribute + "' but it has no " | ||
+ NodeProperties.URI_ATTRIBUTE + " key"; | ||
String uri = object.getString(NodeProperties.URI_ATTRIBUTE); | ||
if (configuration.isWebComponentMode()) { | ||
String baseUri = configuration.getServiceUrl(); | ||
baseUri = baseUri.endsWith("/") ? baseUri : baseUri + "/"; | ||
WidgetUtil.updateAttribute(element, attribute, | ||
baseUri + uri); | ||
} else { | ||
WidgetUtil.updateAttribute(element, attribute, uri); | ||
} | ||
} else { | ||
WidgetUtil.updateAttribute(element, attribute, | ||
value.toString()); | ||
} | ||
} | ||
} | ||
|
||
private static EventExpression getOrCreateExpression( | ||
String expressionString) { | ||
if (expressionCache == null) { | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.