xtal-salt - Vaadin Add-on Directory
Web Component wrapper around the XSLT processor
[![Published on webcomponents.org](https://img.shields.io/badge/webcomponents.org-published-blue.svg)](https://www.webcomponents.org/element/xtal-salt)
# xtal-salt
xtal-salt allows us to party like it's 1999, and take advantage of the [increasingly popular](https://www.chromestatus.com/metrics/feature/timeline/popularity/79) XSLT processing that [all modern browsers](https://www.balisage.net/Proceedings/vol21/html/Thompson01/BalisageVol21-Thompson01.html#d8834e412) support. XSLT was the first isomorphic solution.
If one were to match up percent page load usage with country populations as a percentage of the world population, we are talking a country the size of Estonia. Estonia, of course, is the birthplace of Skype and a world powerhouse in [naisekandmine competitions](http://www.citypaper.lv/wife-carrying__championships_in_estonia/).
## Use cases
XSLT (< 3.0) normally takes XML as its input format. However, most well-formed html can also qualify. This can be useful if the light children of a custom element should be simple html, but it needs to be transformed into complex HTML (or some other form) inside the Shadow DOM.
Other scenarios may arise, you never know -- my cable modem router uses xslt to format xml coming from the router, for example, when going to the admin page. One could also use XSLT as a stand-in for template instantation, until it is ready. Though you would probably need to run your object through an [object to xml converter](https://www.npmjs.com/package/object-to-xml) to do this.
In the thoughtful, informative essay [An Adventure with Client-Side XSLT to an Architecture for Building Bridges with Javascript](https://www.balisage.net/Proceedings/vol21/html/Thompson01/BalisageVol21-Thompson01.html), a representative from O'Connor's publishing writes:
>As a legal publisher, one of our main product categories is template-style forms for attorneys, which have undergone a limited evolution in their path to electronic delivery. We have traditionally delivered forms to customers as printed books of forms and subordinate forms for the customer to fill in and manually assemble into a complete document. More recently, we launched a subscription-based online service to deliver all of our content from the web. A departure from a book-oriented concept, the online service joins all of our content together, so users can search across the complete corpus, browse content organized by topic or practice area, annotate, and download forms.
>Truly unified with a modern JavaScript UI, we built an XSLT-based application on our terms, uncompromised by the gravity of top-down XML and JavaScript frameworks, and we believe there are strong incentives for combining technologies, each with their best foot forward.
and concludes:
>Over the last twenty years, the Web has grown increasingly separated from its early XML influences. Despite its evolution into a towering JavaScript monoculture, its ecosystems are now converging on architectures that are fundamentally capable of bridging the gap to other languages. Out of a desire to test that theory, and having a suitable use case for XSLT, emerged a great opportunity to put browser XSLT engines through their paces—and we found them nearly as capable as ever!
## Virtual DOM comes to XSLT?
Note that version [3.0 of XSLT supports JSON as an input format](https://www.xml.com/articles/2017/02/14/why-you-should-be-using-xslt-30/). To my knowledge, no browser supports 3.0 yet, [though a hefty 70kb gzipped/minifed JS library is available](http://www.saxonica.com/download/javascript.xml). Whereas something like lit-html or hyperHTML requires converting dynamic JSON coming from the server to an object, XSLT 3.0 can take the unparsed JSON as it's input. And interestingly, XSLT 3.0 seems to [support](http://www.saxonica.com/saxon-js/documentation/index.html) sub template updating:
>Instead, the stylesheet can contain rules that respond to user input, such as clicking on buttons, filling in form fields, or hovering the mouse. These events trigger template rules in the stylesheet which can be used to read additional data and modify the content of the HTML page.
## Demo 1
NB: [CD's](https://www.w3schools.com/xml/xsl_intro.asp) were a popular storage format for music, encyclopedia's, software installation, and PC backup in the [last millenium](https://www.urbandictionary.com/define.php?term=CD).
My CD Collection
```
-->
## Demo 2
What's interesting here is that the XML input is an already parsed HTMLDocument node. We try to pass that parsed node to xtal-salt, so that xtal-salt doesn't need to reparse the "xml". This works for Chrome and Safari, but not Firefox and Edge. For the latter two browsers, the xml is stringified and reparsed.
```
-->
## Demo 3 -- Light Children Metamorphosis
Based on [CSS-Only Nested Dropdown Navigation (ARIA)](https://codepen.io/gabriellewee/pen/oWyObX).
**NB**: This example works in Chrome and Edge, but not yet Firefox. WIP.
## Viewing Your Element
```
$ polymer serve
```
## Running Tests
WIP
View on GitHub
View on NPM
xtal-salt version 0.0.0
### Dependencies
xtal-salt version 0.0.1
### Dependencies
* xtal-latx#0.0.85
xtal-salt version 0.0.2
### Dependencies
* xtal-latx#0.0.85
xtal-salt version 0.0.3
### Dependencies
* xtal-latx#0.0.85
xtal-salt version 0.0.4
### Dependencies
* xtal-latx#0.0.85
xtal-salt version 0.0.5
### Dependencies
* xtal-latx#0.0.85
xtal-salt version 0.0.6
### Dependencies
* xtal-latx#0.0.85
xtal-salt version 0.0.7
### Dependencies
* xtal-latx#0.0.85
xtal-salt version 0.0.8
### Dependencies
* xtal-latx#0.0.85
xtal-salt version 0.0.9
### Dependencies
* xtal-latx#0.0.85
xtal-salt version 0.0.10
### Dependencies
* xtal-latx#0.0.86
xtal-salt version 0.0.11
### Dependencies
* xtal-latx#0.0.86
xtal-salt version 0.0.12
### Dependencies
* xtal-latx#0.0.86
xtal-salt version 0.0.13
### Dependencies
* xtal-latx#0.0.86
xtal-salt version 0.0.14
### Dependencies
* xtal-latx#0.0.86
xtal-salt version 0.0.15
### Dependencies
* xtal-latx#0.0.86