index.html 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303
  1. <!doctype html>
  2. <html lang="en-us">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  6. <title>SQLite3 Fiddle</title>
  7. <link rel="shortcut icon" href="data:image/x-icon;," type="image/x-icon">
  8. <!-- to add a togglable terminal-style view, uncomment the following
  9. two lines and ensure that these files are on the web server. -->
  10. <!--script src="jqterm/jqterm-bundle.min.js"></script>
  11. <link rel="stylesheet" href="jqterm/jquery.terminal.min.css"/-->
  12. <style>
  13. /* The following styles are for app-level use. */
  14. :root {
  15. --sqlite-blue: #044a64;
  16. --textarea-color1: #044a64;
  17. --textarea-color2: white;
  18. }
  19. textarea {
  20. font-family: monospace;
  21. flex: 1 1 auto;
  22. background-color: var(--textarea-color1);
  23. color: var(--textarea-color2);
  24. }
  25. textarea#input {
  26. color: var(--textarea-color1);
  27. background-color: var(--textarea-color2);
  28. }
  29. header {
  30. display: flex;
  31. justify-content: space-between;
  32. align-items: center;
  33. background-color: var(--sqlite-blue);
  34. color: white;
  35. font-size: 120%;
  36. font-weight: bold;
  37. border-radius: 0.25em;
  38. padding: 0.2em 0.5em;
  39. }
  40. header > .powered-by {
  41. font-size: 80%;
  42. }
  43. header a, header a:visited, header a:hover {
  44. color: inherit;
  45. }
  46. #main-wrapper {
  47. display: flex;
  48. flex-direction: column-reverse;
  49. flex: 1 1 auto;
  50. margin: 0.5em 0;
  51. overflow: hidden;
  52. }
  53. #main-wrapper.side-by-side {
  54. flex-direction: row;
  55. }
  56. #main-wrapper.side-by-side > fieldset {
  57. margin-left: 0.25em;
  58. margin-right: 0.25em;
  59. }
  60. #main-wrapper:not(.side-by-side) > fieldset {
  61. margin-bottom: 0.25em;
  62. }
  63. #main-wrapper.swapio {
  64. flex-direction: column;
  65. }
  66. #main-wrapper.side-by-side.swapio {
  67. flex-direction: row-reverse;
  68. }
  69. .zone-wrapper{
  70. display: flex;
  71. margin: 0;
  72. flex: 1 1 0%;
  73. border-radius: 0.5em;
  74. min-width: inherit/*important: resolves inability to scroll fieldset child element!*/;
  75. padding: 0.35em 0 0 0;
  76. }
  77. .zone-wrapper textarea {
  78. border-radius: 0.5em;
  79. flex: 1 1 auto;
  80. /*min/max width resolve an inexplicable margin on the RHS. The -1em
  81. is for the padding, else we overlap the parent boundaries.*/
  82. /*min-width: calc(100% - 1em);
  83. max-width: calc(100% - 1em);
  84. padding: 0 0.5em;*/
  85. }
  86. .zone-wrapper.input { flex: 10 1 auto; }
  87. .zone-wrapper.output { flex: 20 1 auto; }
  88. .zone-wrapper > div {
  89. display:flex;
  90. flex: 1 1 0%;
  91. }
  92. .zone-wrapper.output {}
  93. .button-bar {
  94. display: flex;
  95. flex-wrap: wrap;
  96. align-items: center;
  97. align-content: space-between;
  98. justify-content: flex-start;
  99. }
  100. .button-bar > * {
  101. margin: 0.05em 0.5em 0.05em 0;
  102. flex: 0 1 auto;
  103. align-self: auto;
  104. }
  105. label[for] {
  106. cursor: pointer;
  107. }
  108. .error {
  109. color: red;
  110. background-color: yellow;
  111. }
  112. .hidden, .initially-hidden {
  113. position: absolute !important;
  114. opacity: 0 !important;
  115. pointer-events: none !important;
  116. display: none !important;
  117. }
  118. fieldset {
  119. border-radius: 0.5em;
  120. border: 1px inset;
  121. padding: 0.25em;
  122. }
  123. fieldset.options {
  124. font-size: 80%;
  125. margin-top: 0.5em;
  126. }
  127. fieldset:not(.options) > legend {
  128. font-size: 80%;
  129. }
  130. fieldset.options > div {
  131. display: flex;
  132. flex-wrap: wrap;
  133. }
  134. fieldset button {
  135. font-size: inherit;
  136. }
  137. fieldset.collapsible > legend > .fieldset-toggle::after {
  138. content: " [hide]";
  139. position: relative;
  140. }
  141. fieldset.collapsible.collapsed > legend > .fieldset-toggle::after {
  142. content: " [show]";
  143. position: relative;
  144. }
  145. span.labeled-input {
  146. padding: 0.25em;
  147. margin: 0.05em 0.25em;
  148. border-radius: 0.25em;
  149. white-space: nowrap;
  150. background: #0002;
  151. display: flex;
  152. align-items: center;
  153. }
  154. span.labeled-input > *:nth-child(2) {
  155. margin-left: 0.3em;
  156. }
  157. .center { text-align: center; }
  158. body.terminal-mode {
  159. max-height: calc(100% - 2em);
  160. display: flex;
  161. flex-direction: column;
  162. align-items: stretch;
  163. }
  164. #view-terminal {}
  165. .app-view {
  166. flex: 20 1 auto;
  167. }
  168. #view-split {
  169. display: flex;
  170. flex-direction: column-reverse;
  171. }
  172. /* emcscript-related styling, used during the module load/intialization processes... */
  173. .emscripten { padding-right: 0; margin-left: auto; margin-right: auto; display: block; }
  174. div.emscripten { text-align: center; }
  175. div.emscripten_border { border: 1px solid black; }
  176. #module-spinner { overflow: visible; }
  177. #module-spinner > * {
  178. margin-top: 1em;
  179. }
  180. .spinner {
  181. height: 50px;
  182. width: 50px;
  183. margin: 0px auto;
  184. animation: rotation 0.8s linear infinite;
  185. border-left: 10px solid rgb(0,150,240);
  186. border-right: 10px solid rgb(0,150,240);
  187. border-bottom: 10px solid rgb(0,150,240);
  188. border-top: 10px solid rgb(100,0,200);
  189. border-radius: 100%;
  190. background-color: rgb(200,100,250);
  191. }
  192. @keyframes rotation {
  193. from {transform: rotate(0deg);}
  194. to {transform: rotate(360deg);}
  195. }
  196. </style>
  197. </head>
  198. <body>
  199. <header id='titlebar'>
  200. <span>SQLite3 Fiddle</span>
  201. <span class='powered-by'>Powered by
  202. <a href='https://sqlite.org'>SQLite3</a></span>
  203. </header>
  204. <!-- emscripten bits -->
  205. <figure id="module-spinner">
  206. <div class="spinner"></div>
  207. <div class='center'><strong>Initializing app...</strong></div>
  208. <div class='center'>
  209. On a slow internet connection this may take a moment. If this
  210. message displays for "a long time", intialization may have
  211. failed and the JavaScript console may contain clues as to why.
  212. </div>
  213. </figure>
  214. <div class="emscripten" id="module-status">Downloading...</div>
  215. <div class="emscripten">
  216. <progress value="0" max="100" id="module-progress" hidden='1'></progress>
  217. </div><!-- /emscripten bits -->
  218. <div id='view-terminal' class='app-view hidden initially-hidden'>
  219. This is a placeholder for a terminal-like view which is not in
  220. the default build.
  221. </div>
  222. <div id='view-split' class='app-view initially-hidden'>
  223. <fieldset class='options collapsible'>
  224. <legend><button class='fieldset-toggle'>Options</button></legend>
  225. <div class=''>
  226. <span class='labeled-input'>
  227. <input type='checkbox' id='opt-cb-sbs'
  228. data-csstgt='#main-wrapper'
  229. data-cssclass='side-by-side'
  230. data-config='sideBySide'>
  231. <label for='opt-cb-sbs'>Side-by-side</label>
  232. </span>
  233. <span class='labeled-input'>
  234. <input type='checkbox' id='opt-cb-swapio'
  235. data-csstgt='#main-wrapper'
  236. data-cssclass='swapio'
  237. data-config='swapInOut'>
  238. <label for='opt-cb-swapio'>Swap in/out</label>
  239. </span>
  240. <span class='labeled-input'>
  241. <input type='checkbox' id='opt-cb-autoscroll'
  242. data-config='autoScrollOutput'>
  243. <label for='opt-cb-autoscroll'>Auto-scroll output</label>
  244. </span>
  245. <span class='labeled-input'>
  246. <input type='checkbox' id='opt-cb-autoclear'
  247. data-config='autoClearOutput'>
  248. <label for='opt-cb-autoclear'>Auto-clear output</label>
  249. </span>
  250. <span class='labeled-input'>
  251. <input type='file' id='load-db' class='hidden'/>
  252. <button id='btn-load-db'>Load DB...</button>
  253. </span>
  254. <span class='labeled-input'>
  255. <button id='btn-export'>Download DB</button>
  256. </span>
  257. <span class='labeled-input'>
  258. <button id='btn-reset'>Reset DB</button>
  259. </span>
  260. </div>
  261. </fieldset><!-- .options -->
  262. <div id='main-wrapper' class=''>
  263. <fieldset class='zone-wrapper input'>
  264. <legend><div class='button-bar'>
  265. <button id='btn-shell-exec'>Run</button>
  266. <button id='btn-clear'>Clear Input</button>
  267. <!--button data-cmd='.help'>Help</button-->
  268. <select id='select-examples'></select>
  269. </div></legend>
  270. <div><textarea id="input"
  271. placeholder="Shell input. Ctrl-enter/shift-enter runs it.">
  272. -- ==================================================
  273. -- Use ctrl-enter or shift-enter to execute sqlite3
  274. -- shell commands and SQL.
  275. -- If a subset of the text is currently selected,
  276. -- only that part is executed.
  277. -- ==================================================
  278. .nullvalue NULL
  279. .headers on
  280. </textarea></div>
  281. </fieldset>
  282. <fieldset class='zone-wrapper output'>
  283. <legend><div class='button-bar'>
  284. <button id='btn-clear-output'>Clear Output</button>
  285. <button id='btn-interrupt' class='hidden' disabled>Interrupt</button>
  286. <!-- interruption cannot work in the current configuration
  287. because we cannot send an interrupt message when work
  288. is currently underway. At that point the Worker is
  289. tied up and will not receive the message. -->
  290. </div></legend>
  291. <div><textarea id="output" readonly
  292. placeholder="Shell output."></textarea></div>
  293. </fieldset>
  294. </div>
  295. </div> <!-- #view-split -->
  296. <script src="fiddle.js"></script>
  297. </body>
  298. </html>