Hi Nathan,
In order to be sure, I've also tested
${frameworkDir} in the CSS and I obtained the
expected result: we don't expand it to the framework directory.
For your CSS rule at least, it is as if you don't have
${frameworkDir} at all.
The system id of the CSS is used as the base URI and I'm guessing
that the relative path
'../../../../../'
it's actually relevant starting from the location of the
CSS.
I'm guessing there is nothing in the XML instances that
differentiates between different versions? Possible solutions:
1. From an Workspace Access [1][2] plugin you can add an
URIResolver, intercept the CSS resolving [3] and resolve there the
editor variables:
/**
* @see
ro.sync.exml.plugin.workspace.WorkspaceAccessPluginExtension#applicationStarted(ro.sync.exml.workspace.api.standalone.StandalonePluginWorkspace)
*/
@Override
public void applicationStarted(final StandalonePluginWorkspace
pluginWorkspaceAccess) {
pluginWorkspaceAccess.getXMLUtilAccess().addPriorityURIResolver(new
URIResolver() {
@Override
public Source resolve(String href, String base) throws
TransformerException {
System.out.println("href " + href);
if
(
"http://www.oxygenxml.com/extensions/author/css/userCustom.css".equals(href))
{
String versionPath =
pluginWorkspaceAccess.getUtilAccess().expandEditorVariables("${test}",
null);
String frameworkURL =
pluginWorkspaceAccess.getUtilAccess().expandEditorVariables("${framework}",
null);
String imageURL = frameworkURL + versionPath + "/";
return new StreamSource(new StringReader(
"*[class~=\"topic/image\"][href]{\n" +
" content:oxy_url('" + imageURL + "',
'attr(href)');\n" +
"}"));
}
return null;
}
});
This goes hand in hand with your idea to tell the user to change a
custom editor variable in options and then perhaps perform a
refresh in the editor.
2. This idea is based on a custom form control implementation [4].
You add this this form control, for example, on the root of the
document. In this form control the user writes something that
identifies the version of the document. The form control saves
this value in a fake attribute using the API :
authorAccess.getDocumentController().setAttribute("myVersion", new
AttrValue("patch21", "patch21", false), element);
The CSS must contain a rule that uses that attribute, something
like this:
*[myVersion]
*[class~="topic/image"][href]{
content:oxy_url('${frameworkDir}', '../../../../../',
oxy_xpath('/topic/@myVersion'),
'app/main/core/sfdc/htdocs/img/', attr(href));
}
If you are interested I can send you the source code for the
built-in text field form control. It would take minimal changes to
make it behave like above.
[1]
http://oxygenxml.com/doc/ug-editor/#concepts/workspace-access-plugin.html
[2]
http://www.oxygenxml.com/oxygen_sdk.html#Developer_Plugins
[3]
http://oxygenxml.com/doc/ug-editor/#references/handling-css-imports.html
[4]
http://oxygenxml.com/doc/ug-editor/#topics/implementing-custom-form-controls.html
Best regards,
Alex
--
Alex Jitianu
<oXygen/> XML Editor, Schema Editor and XSLT Editor/Debugger
http://www.oxygenxml.com
On 13-May-14 3:32 AM, Nathan wrote:
Hi Alex,
Here is the use case scenario I am targeting:
In the CSS, I have
*[class~="topic/image"][href]{
content:oxy_url('${frameworkDir}',
'../../../../../', 'app/main/core/sfdc/htdocs/img/',
attr(href));
}
Here, the built-in variable "frameworkDir" works fine. The
above path is valid when the file is in the "main" branch.
When the input xml file is in another branch (say
"/patch/21"), I would like to change the "app/main/core...."
to "app/patch/21/core...".
My first idea was to have a custom variable defined (say
$BRANCH) which would be set to "/main" by default and could be
reset to "/patch/21" by the user when they change the branch.
However, while the built-in variable was accepted, the
custom variable is not accepted here. Also, with respect to
creating pseudo classes, it would be a maintenance issue since
I would need to put in every release number (since
theoretically XML files from any release could be opened) in
the CSS and also the CSS would need to be updated after every
release.
Could you provide some alternatives?
Thanks,
Nathan
_______________________________________________
oXygen-sdk mailing list
oXygen-sdk@oxygenxml.com
http://www.oxygenxml.com/mailman/listinfo/oxygen-sdk