You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

release-notes.html 27KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html>
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  5. <title>Vaadin Framework @version@</title>
  6. <link rel="stylesheet" type="text/css" href="css/styles.css" />
  7. <!--[if lte IE 6]>
  8. <link rel="stylesheet" type="text/css" href="css/ie.css" />
  9. <![endif]-->
  10. <style type="text/css">
  11. .nested-list ol {
  12. counter-reset: item
  13. }
  14. .nested-list li {
  15. display: block
  16. }
  17. .nested-list li:before {
  18. content: counters(item, ".") ". ";
  19. counter-increment: item
  20. }
  21. </style>
  22. </head>
  23. <body>
  24. <div id="header">
  25. <h1>Vaadin &ndash; thinking of U and I</h1>
  26. <div id="version">
  27. <strong>Version @version@</strong>
  28. </div>
  29. </div>
  30. <!-- /header -->
  31. <div id="content">
  32. <p>Version @version@ built on @builddate@.</p>
  33. <h2 id="tableofcontents">Release Notes for Vaadin Framework
  34. @version@</h2>
  35. <ul>
  36. <li><a href="#overview">Overview of Vaadin
  37. @version@ Release</a></li>
  38. <li><a href="#security-fixes">Security fixes</a></li>
  39. <li><a href="#changelog">Change log for Vaadin
  40. @version@</a></li>
  41. <li><a href="#enhancements">Enhancements in Vaadin
  42. @version-minor@</a></li>
  43. <li><a href="#limitations">Limitations in
  44. @version-minor@</a></li>
  45. <li><a href="#vaadin">Vaadin Installation</a></li>
  46. <li><a href="#package">Package Contents</a></li>
  47. <li><a href="#migrating">Migrating from Vaadin 6 to
  48. Vaadin 7</a></li>
  49. <li><a href="#dependencies">Vaadin @version@
  50. dependencies</a></li>
  51. <li><a href="#upgrading">Upgrading to Vaadin
  52. @version-minor@</a></li>
  53. <li><a href="#supportedversions">Supported
  54. technologies</a></li>
  55. <li><a href="#vaadinontheweb">Vaadin on the Web</a></li>
  56. </ul>
  57. <h2 id="overview">Overview of Vaadin @version@ Release</h2>
  58. <p>
  59. Vaadin @version@ is a maintenance release that includes a
  60. number of important bug fixes, as listed in the <a
  61. href="#changelog">change log</a> below.
  62. </p>
  63. <p>
  64. For a list of enhancements in the last feature release, see
  65. <a href="#enhancements">Enhancements in Vaadin
  66. @version-minor@</a> and the <a
  67. href="http://vaadin.com/download/release/@version-minor@/@version-minor@.0/release-notes.html">Release
  68. Notes for Vaadin @version-minor@.0</a>.
  69. </p>
  70. <!-- ================================================================ -->
  71. <h3 id="security-fixes">Security fixes in Vaadin Framework 7.1.11</h3>
  72. <p>
  73. Vaadin 7.1.11 fixes two security issues discovered during internal review.
  74. </p>
  75. <p><b>Escaping of OptionGroup item icon URLs</b></p>
  76. <p>
  77. The issue affects OptionGroup with item icons. Proper escaping of the
  78. src-attribute on the client side was not ensured when using icons for
  79. OptionGroup items. This could potentially, in certain situations, allow
  80. a malicious user to inject content, such as javascript, in order to
  81. perform a cross-site scripting (XSS) attack.
  82. </p>
  83. <p>
  84. In order for an application to be vulnerable, user provided input must
  85. be used to form a URL used to display an icon for an OptionGroup item,
  86. when showing that Option Group to other users.<br/>
  87. The vulnerability has been classified as moderate, due to it's limited
  88. application.
  89. </p>
  90. <p><b>Escaping of URLs in Util.getAbsoluteUrl()</b></p>
  91. <p>
  92. The client side Util.getAbsoluteUrl() did not ensure proper escaping
  93. of the given URL. This could potentially, in certain situations, allow
  94. a malicious user to inject content, such as javascript, in order to
  95. perform a cross-site scripting (XSS) attack.
  96. </p>
  97. <p>
  98. The method is used internally by the framework in such a manner that it
  99. is unlikely this attack vector can be utilized in practice. However,
  100. third party components, or future use of the method, could make an
  101. attack viable.<br/>
  102. The vulnerability has been classified as moderate, due to it's limited
  103. application.
  104. </p>
  105. <h3 id="changelog">Change log for Vaadin @version@</h3>
  106. <p>This release includes the following closed issues:</p>
  107. <ul>@release-notes-tickets@
  108. </ul>
  109. <p>
  110. You can also view the <a
  111. href="http://dev.vaadin.com/query?status=closed&resolution=fixed&milestone=Vaadin+@version@&order=id">list
  112. of the closed issues</a> at the Vaadin developer's site. .
  113. </p>
  114. <h2 id="enhancements">Enhancements in Vaadin
  115. @version-minor@</h2>
  116. <p>The @version-minor@ includes many major and minor
  117. enhancements. Below is a list of the most notable changes:</p>
  118. <ul>
  119. <li>Server push (Use the <b>@Push</b> annotation to
  120. enable push for a UI)
  121. </li>
  122. <li>Server polling using <b>UI</b>.<tt>setPollInterval()</tt></li>
  123. <li>Enhanced debug window</li>
  124. <li>Internet Explorer 10 support</li>
  125. <li>Sass compiler improvements: arithmetics, @content</li>
  126. <li>Dynamic CSS injection</li>
  127. <li>Support for SCSS/CSS files in all add-ons (Use <tt>Vaadin-Stylesheet</tt>
  128. in the manifest)
  129. </li>
  130. <li><b>Calendar</b> is included in the core framework</li>
  131. <li><b>ProgressBar</b> provides progress indication
  132. without polling (separated from <b>ProgressIndicator</b>)</li>
  133. <li>Tooltip and loading indicator delays configurable
  134. on server side</li>
  135. <li>The range of a <b>DateField</b> can be limited
  136. </li>
  137. <li><b>Window</b> has maximize/restore controls</li>
  138. <li><b>UI</b> and <b>VaadinSession</b> provide <tt>access()</tt>
  139. to access the UI and session while holding the needed
  140. lock</li>
  141. <li>A new <b>@VaadinServletConfiguration</b> annotation
  142. for configuring servlet parameters
  143. </li>
  144. <li>WAI-ARIA support for form fields, <b>Button</b>,
  145. and <b>Tree</b></li>
  146. <li>The behavior of <b>Property</b>.toString() can be
  147. toggled using the <tt>legacyPropertyToString</tt> init
  148. parameter
  149. </li>
  150. <li>Default alignment can be set for layout components</li>
  151. <li><b>FieldGroup</b> supports SQL date fields and date
  152. field creation</li>
  153. <li><b>Converter</b>.<tt>convertToModel</tt>/<tt>convertFromModel</tt>
  154. now gets an additional parameter describing the target
  155. type</li>
  156. <li>The browser page can be reloaded programmatically
  157. using <tt>Page.reload()</tt>
  158. </li>
  159. <li>The <b>VaadinServlet</b>/<b>VaadinPortlet</b> and <b>VaadinService</b>
  160. classes have been refactored
  161. </li>
  162. <li>Several locking related fixes</li>
  163. <li>Client compiler dependencies are packaged as a
  164. separate jar</li>
  165. <li>DefaultWidgetSet is even more optimized (using
  166. compiler parameter <tt>-XenableClosureCompiler</tt>)
  167. </li>
  168. <li>Java <tt>assert</tt> statements have been added to
  169. critical code sections. Start JVM with <tt>-ea</tt> to
  170. use.
  171. </li>
  172. <li><b>StateChangeEvent</b>.<tt>isInitialState()</tt>
  173. indicates if event is the first for a connector</li>
  174. <li><b>ClientConnector</b>.<tt>isAttached()</tt>
  175. indicates if connector is attached</li>
  176. <li><b>Container.Filterable</b> now contains a <tt>getContainerFilters()</tt>
  177. method</li>
  178. <li><b>TableQuery</b> now supports schemas and catalogs</li>
  179. </ul>
  180. <p>Tools have been updated for Vaadin @version-minor@ with
  181. the following changes:</p>
  182. <ul>
  183. <li>Maven
  184. <ul>
  185. <li>Theme compilation support using <tt>vaadin:update-theme</tt>
  186. and <tt>vaadin:compile-theme</tt></li>
  187. </ul>
  188. </li>
  189. <li>Eclipse
  190. <ul>
  191. <li>Theme compilation support using the
  192. provided button</li>
  193. <li>New projects are by default generated using
  194. Servlet 3.0 API</li>
  195. <li>Additional GWT compiler parameters can be
  196. specified</li>
  197. </ul>
  198. </li>
  199. </ul>
  200. <p>
  201. For enchancements introduced in Vaadin 7, see the <a
  202. href="http://vaadin.com/download/release/7.0/7.0.0/release-notes.html">Release
  203. Notes for Vaadin 7.0.0</a>.
  204. </p>
  205. <h3 id="limitations">Limitations</h3>
  206. <ul>
  207. <li>It is currently not possible to specify <tt>font-size</tt>
  208. as <tt>em</tt> or <tt>%</tt>, or layout component sizes
  209. with <tt>em</tt> (<a
  210. href="http://dev.vaadin.com/ticket/10634">#10634</a>)
  211. </li>
  212. <li>Push is currently not supported in portals (See <a
  213. href="http://dev.vaadin.com/ticket/11493">#11493</a>)
  214. </li>
  215. <li>HTTP session can not be invalidated while using
  216. push (<a href="http://dev.vaadin.com/ticket/11721">#11721</a>)
  217. </li>
  218. <li>Cookies are not available while using push (<a
  219. href="http://dev.vaadin.com/ticket/11808">#11808</a>)
  220. </li>
  221. <li>Not all proxies are compatible with websockets. If
  222. you are using push with an incompatible proxy you might
  223. have to force the transport mode to streaming. Some
  224. proxies have problems with streaming also - you need to
  225. ensure that the proxy does not buffer responses for HTTP
  226. streaming to work.</li>
  227. </ul>
  228. <h2 id="vaadin">Vaadin Installation</h2>
  229. <p>
  230. <b>Vaadin</b> is a Java framework for building modern web
  231. applications that look great, perform well and make you and
  232. your users happy. <b>Vaadin</b> is available under the
  233. Apache License, Version 2.0 (see the
  234. <tt>license.html</tt>
  235. in the Vaadin ZIP or JAR package).
  236. </p>
  237. <p>
  238. The easiest ways to install <b>Vaadin</b> are:
  239. </p>
  240. <ul>
  241. <li>If using Maven, define it as a dependency or use
  242. any of the available archetypes (only <tt>vaadin-application</tt>
  243. is available for Vaadin 7 at the time of this release)
  244. to create a new project
  245. </li>
  246. <li>If using Eclipse, use the Vaadin Plugin for
  247. Eclipse, which automatically downloads the Vaadin
  248. libraries. To use this prerelease version, the plugin
  249. should be installed from the experimental update site (<tt>http://vaadin.com/eclipse/experimental</tt>).
  250. </li>
  251. </ul>
  252. <p>
  253. It is also available as a ZIP package downloadable from <a
  254. href="http://vaadin.com/download">Vaadin Download
  255. page</a>.
  256. </p>
  257. <h3 id="package">Package Contents</h3>
  258. <p>Inside the ZIP installation package you will find:</p>
  259. <ul>
  260. <li>Separate server-side (<tt>vaadin-server</tt>) and
  261. client-side (<tt>vaadin-client</tt>, <tt>vaadin-client-compiler</tt>)
  262. development libraries
  263. </li>
  264. <li>Precompiled widget set (<tt>vaadin-client-compiled</tt>)
  265. for server-side development
  266. </li>
  267. <li>Shared library (<tt>vaadin-shared</tt>) for both
  268. server- and client-side libraries
  269. </li>
  270. <li>Built-in themes (<tt>vaadin-themes</tt>)
  271. </li>
  272. <li>Dependency libraries provided under the <tt>lib/</tt>
  273. folder
  274. </li>
  275. </ul>
  276. <p>
  277. See the
  278. <tt>README.TXT</tt>
  279. in the installation package for detailed information about
  280. the package contents. <a href="http://vaadin.com/book">Book
  281. of Vaadin</a> (for Vaadin 7) gives more detailed
  282. instructions.
  283. </p>
  284. <p>
  285. For server-side development, copy the
  286. <tt>vaadin-server</tt>
  287. ,
  288. <tt>vaadin-client-compiled</tt>
  289. ,
  290. <tt>vaadin-shared</tt>
  291. , and
  292. <tt>vaadin-themes</tt>
  293. from the main folder and the dependencies from the
  294. <tt>lib</tt>
  295. folder to the
  296. <tt>WEB-INF/lib</tt>
  297. folder of your Vaadin project. (The
  298. <tt>vaadin-client-compiled</tt>
  299. is necessary if you do not wish to compile the widget set by
  300. your own, which you need to do if you use almost any add-on
  301. components.)
  302. </p>
  303. <h4 id="package.updates">Updates to the Packaging</h4>
  304. <p>
  305. Since Vaadin 7.2.0, the old vaadin-theme-compiler has been moved into
  306. a separate project and renamed to vaadin-sass-compiler. It is now included
  307. along with the other 3rd party dependencies in the ZIP package.
  308. </p>
  309. <p>
  310. For pure client-side development, you only need the
  311. <tt>vaadin-client</tt>
  312. and
  313. <tt>vaadin-client-compiler</tt>
  314. JARs, which should be put to a non-deployed project library
  315. folder, such as
  316. <tt>lib</tt>
  317. . You also need them if you compile the widget set for any
  318. reason, such as using Vaadin add-ons, or create new
  319. server-side components integrated with client-side widgets.
  320. </p>
  321. <h2 id="migrating">Migrating from Vaadin 6</h2>
  322. <p>
  323. All Vaadin 6 applications need some changes when migrating
  324. to Vaadin 7. The most obvious changes are in the
  325. application/window API and require extending either <b>UI</b>
  326. or <b>UI.LegacyApplication</b> instead of <b>Application</b>.
  327. A detailed list of migration changes are given in the <a
  328. href="https://vaadin.com/wiki/-/wiki/Main/Migrating+from+Vaadin+6+to+Vaadin+7">Vaadin
  329. 7 Migration Guide</a>.
  330. </p>
  331. <p>Any custom client-side widgets need to be ported to use
  332. the new client-server communication API, or the Vaadin 6
  333. compatibility API.</p>
  334. <p>
  335. Vaadin 6 add-ons (ones that contain widgets) do not work in
  336. Vaadin 7 - please check the add-ons in <a
  337. href="http://vaadin.com/directory/">Vaadin Directory</a>
  338. for Vaadin 7 support.
  339. </p>
  340. <h2 id="dependencies">Vaadin @version@ Dependencies</h2>
  341. <p>When using Maven, Ivy, Gradle, or other dependency
  342. management system, all Vaadin dependencies are downloaded
  343. automatically. This is also the case when using the Vaadin
  344. Plugin for Eclipse.</p>
  345. <p>
  346. The Vaadin ZIP installation package includes the
  347. dependencies in the
  348. <tt>lib</tt>
  349. subfolder. These need to be copied to the
  350. <tt>WEB-INF/lib</tt>
  351. folder of the web application that uses Vaadin.
  352. </p>
  353. <p>
  354. The dependencies are listed in the <a href="license.html">Licensing
  355. description</a>. Some are explicit dependencies packaged and
  356. distributed as separate JARs, while some are included inside
  357. other libraries.
  358. </p>
  359. <h3>Bean Validation</h3>
  360. <p>
  361. If you use the bean validation feature in Vaadin 7, you need
  362. a Bean Validation API implementation. You need to install
  363. the implementation JAR in the
  364. <tt>WEB-INF/lib</tt>
  365. directory of the web application that uses validation.
  366. </p>
  367. <h2 id="upgrading">Upgrading to Vaadin @version-minor@</h2>
  368. <h3>Upgrading the Eclipse Plugin</h3>
  369. <p>
  370. Vaadin 7 requires that you use a compatible version of the
  371. Vaadin Plugin for Eclipse. The stable version of the plugin
  372. is available from the
  373. <tt>http://vaadin.com/eclipse</tt>
  374. update site. Please see the <a
  375. href="https://vaadin.com/book/vaadin7/-/page/getting-started.eclipse.html#getting-started.eclipse.update">section
  376. about updating the plugin</a> in the Book of Vaadin and the
  377. <a href="http://vaadin.com/eclipse">installation
  378. instructions at the download site</a> for more details.
  379. </p>
  380. <p>
  381. You can also use the <i>experimental</i> Vaadin Plugin for
  382. Eclipse. Its update site is
  383. <tt>http://vaadin.com/eclipse/experimental</tt>
  384. .
  385. </p>
  386. <h3>General Upgrading Instructions</h3>
  387. <p>When upgrading from an earlier Vaadin version, you must:
  388. </p>
  389. <ul>
  390. <li>Recompile your classes using the new Vaadin
  391. version. Binary compatibility is only guaranteed for
  392. maintenance releases of Vaadin.</li>
  393. <li>Recompile any add-ons you have created using the
  394. new Vaadin</li>
  395. <li>Unless using the precompiled widget set, recompile
  396. your widget set using the new Vaadin version</li>
  397. </ul>
  398. <p>Remember also to refresh the project in your IDE to
  399. ensure that the new version of everything is in use.</p>
  400. <p>
  401. By using the "
  402. <tt>?debug</tt>
  403. " URL parameter, you can verify that the version of the
  404. servlet, the theme, and the widget set all match.
  405. </p>
  406. <p>
  407. <b>Eclipse</b> users should always check if there is a new
  408. version of the Eclipse Plug-in available. The Eclipse
  409. Plug-in can be used to update the Vaadin version in the
  410. project (Project properties &raquo; Vaadin).
  411. </p>
  412. <p>
  413. <b>Maven</b> users should update the Vaadin dependency
  414. version in the
  415. <tt>pom.xml</tt>
  416. unless it is defined as
  417. <tt>LATEST</tt>
  418. . You must also ensure that the GWT dependency uses the
  419. correct version and recompile your project and your widget
  420. set.
  421. </p>
  422. <p>
  423. <b>Liferay and other portal</b> users must install the
  424. Vaadin libraries in
  425. <t>ROOT/WEB-INF/lib/</b> in the portal (and remove a
  426. possibly obsolete older <tt>vaadin.jar</tt>). Additionally,
  427. the contents of the <tt>vaadin-client-compiled</tt> and <tt>vaadin-themes</tt>
  428. must be extracted to the <tt>ROOT/html/VAADIN</tt> directory
  429. in the Liferay installation. If your portal uses custom
  430. widgets, install the latest version of <a
  431. href="http://vaadin.com/directory#addon/vaadin-control-panel-for-liferay">Vaadin
  432. Control Panel for Liferay</a> for easy widget set
  433. compilation - when it is available - the add-on is not
  434. compatible with Vaadin @version@ at the time of this Vaadin
  435. release. <!-- TODO: Remove note when done --></t>
  436. </p>
  437. <h2 id="gae">
  438. Notes and Limitations for Google App Engine
  439. </h4>
  440. </h2>
  441. <p>The following instructions and limitations apply when you
  442. run a Vaadin application under the Google App Engine.</p>
  443. <ul>
  444. <li>
  445. <p>
  446. Applications must use <b>GAEVaadinServlet</b>
  447. instead of <b>VaadinServlet</b> in
  448. <tt>web.xml</tt>
  449. .
  450. </p>
  451. </li>
  452. <li>
  453. <p>
  454. Session support must be enabled in
  455. <tt>appengine-web.xml</tt>
  456. :
  457. </p> <pre> &lt;sessions-enabled&gt;true&lt;/sessions-enabled&gt;</pre>
  458. </li>
  459. <li>
  460. <p>Avoid using the session for storage, usual App
  461. Engine limitations apply (no synchronization, that
  462. is, unreliable).</p>
  463. </li>
  464. <li>
  465. <p>
  466. Vaadin uses memcache for mutex, the key is of the
  467. form
  468. <tt>_vmutex&lt;sessionid&gt;</tt>
  469. .
  470. </p>
  471. </li>
  472. <li>
  473. <p>
  474. The Vaadin <b>VaadinSession</b> class is serialized
  475. separately into memcache and datastore; the memcache
  476. key is
  477. <tt>_vac&lt;sessionid&gt;</tt>
  478. and the datastore entity kind is
  479. <tt>_vac</tt>
  480. with identifiers of the type
  481. <tt>_vac&lt;sessionid&gt;</tt>
  482. .
  483. </p>
  484. </li>
  485. <li>
  486. <p>
  487. DO NOT update application state when serving an <b>ConnectorResource</b>
  488. (such as <b>ClassResource</b>.<i>getStream()</i>).
  489. </p>
  490. </li>
  491. <li>
  492. <p>The application remains locked during uploads - a
  493. progress bar is not possible</p>
  494. </li>
  495. </ul>
  496. <p>
  497. For other known problems, see open tickets at developer site
  498. <a href="http://dev.vaadin.com/">dev.vaadin.com</a>.
  499. </p>
  500. <h2 id="supportedversions">Supported Technologies</h2>
  501. <p>
  502. Vaadin 7 is compatible with <b>Java 6</b> and newer. Vaadin
  503. 7 is especially supported on the following <b>operating
  504. systems</b>:
  505. </p>
  506. <ul>
  507. <li>Windows</li>
  508. <li>Linux</li>
  509. <li>Mac OS X</li>
  510. </ul>
  511. <p>
  512. Vaadin 7 requires <b>Java Servlet API 2.4</b> but also
  513. supports later versions and should work with any Java
  514. application server that conforms to the standard. The
  515. following <b>application servers</b> are supported:
  516. </p>
  517. <ul>
  518. <li>Apache Tomcat 5-8</li>
  519. <li>Apache TomEE 1</li>
  520. <li>Oracle WebLogic Server 10.3-12</li>
  521. <li>IBM WebSphere Application Server 7-8</li>
  522. <li>JBoss Application Server 4-7</li>
  523. <li>Wildfly 8</li>
  524. <li>Jetty 5-9</li>
  525. <li>Glassfish 2-4</li>
  526. </ul>
  527. <p>
  528. Vaadin 7 supports the JSR-286 Portlet specification and all
  529. portals that implement the specification should work. The
  530. following <b>portals</b> are supported:
  531. </p>
  532. <ul>
  533. <li>Liferay Portal 5.2-6</li>
  534. <li>GateIn Portal 3</li>
  535. <li>eXo Platform 3</li>
  536. </ul>
  537. <p>
  538. Vaadin also supports <b>Google App Engine</b>.
  539. </p>
  540. <p>
  541. Vaadin supports the following <b>desktop browsers</b>:
  542. </p>
  543. <ul>
  544. <li>Mozilla Firefox 18-24</li>
  545. <li>Mozilla Firefox 17 ESR</li>
  546. <li>Internet Explorer 8-10</li>
  547. <li>Safari 6</li>
  548. <li>Opera 12,16</li>
  549. <li>Google Chrome 23-29</li>
  550. </ul>
  551. <p>
  552. Additionally, Vaadin supports the built-in browsers in the
  553. following <b>mobile operating systems</b>:
  554. </p>
  555. <ul>
  556. <li>iOS 5-7</li>
  557. <li>Android 2.3-4</li>
  558. </ul>
  559. <p>Vaadin SQL Container supports the following databases:</p>
  560. <ul>
  561. <li>HSQLDB</li>
  562. <li>MySQL</li>
  563. <li>MSSQL</li>
  564. <li>Oracle</li>
  565. <li>PostgreSQL</li>
  566. </ul>
  567. <h2 id="vaadinontheweb">Vaadin on the Web</h2>
  568. <ul>
  569. <li><a href="http://vaadin.com">vaadin.com - The
  570. developer portal containing everything you need to
  571. know about Vaadin</a></li>
  572. <li><a href="http://vaadin.com/demo">vaadin.com/demo
  573. - A collection of demos for Vaadin</a></li>
  574. <li><a href="http://vaadin.com/learn">vaadin.com/learn
  575. - Getting started with Vaadin</a></li>
  576. <li><a href="http://vaadin.com/forum">vaadin.com/forum
  577. - Forums for Vaadin related discussions</a></li>
  578. <li><a href="http://vaadin.com/book">vaadin.com/book
  579. - Book of Vaadin - everything you need to know about
  580. Vaadin</a></li>
  581. <li><a href="http://vaadin.com/api">vaadin.com/api
  582. - Online javadocs</a></li>
  583. <li><a href="http://vaadin.com/directory">vaadin.com/directory
  584. - Add-ons for Vaadin</a></li>
  585. <li><a href="http://vaadin.com/pro-account">vaadin.com/pro-account
  586. - Commercial support and tools for Vaadin
  587. development </a></li>
  588. <li><a href="http://vaadin.com/services">vaadin.com/services
  589. - Expert services for Vaadin</a></li>
  590. <li><a href="http://vaadin.com/company">vaadin.com/company
  591. - Information about the company behind Vaadin</a></li>
  592. <li><a href="http://dev.vaadin.com">dev.vaadin.com
  593. - Bug tracker</a></li>
  594. <li><a
  595. href="http://dev.vaadin.com/wiki/Vaadin/Development/StartingVaadin7Development">How
  596. to get the source code of Vaadin</a></li>
  597. </ul>
  598. </div>
  599. <!-- /content-->
  600. <div id="footer">
  601. <span class="slogan"><strong>vaadin <em>}></em>
  602. </strong> thinking of U and I<span> <a href="#top">&uarr; Back
  603. to top</a>
  604. </div>
  605. <!-- /footer -->
  606. </body>
  607. </html>
  608. <!-- Keep this comment at the end of the file
  609. Local variables:
  610. mode: xml
  611. sgml-omittag:nil
  612. sgml-shorttag:nil
  613. sgml-namecase-general:nil
  614. sgml-general-insert-case:lower
  615. sgml-minimize-attributes:nil
  616. sgml-always-quote-attributes:t
  617. sgml-indent-step:2
  618. sgml-indent-data:t
  619. sgml-parent-document:nil
  620. sgml-exposed-tags:nil
  621. sgml-local-catalogs:("/etc/sgml/catalog" "/usr/share/xemacs21/xemacs-packages/etc/psgml-dtds/CATALOG")
  622. sgml-local-ecat-files:("ECAT" "~/sgml/ECAT" "/usr/share/sgml/ECAT" "/usr/local/share/sgml/ECAT" "/usr/local/lib/sgml/ECAT")
  623. End:
  624. -->