sketchily 0.0.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (284) hide show
  1. data/MIT-LICENSE +20 -0
  2. data/README.md +39 -0
  3. data/Rakefile +40 -0
  4. data/app/helpers/sketchily.rb~ +10 -0
  5. data/app/helpers/sketchily_helper.rb +10 -0
  6. data/app/views/sketchily/_embed.html.erb +28 -0
  7. data/app/views/sketchily/_embed.html.erb~ +28 -0
  8. data/app/views/sketchily/_embed.js.erb +50 -0
  9. data/app/views/sketchily/_embed.js.erb~ +50 -0
  10. data/app/views/sketchily/_sketchily.html.erb +23 -0
  11. data/app/views/sketchily/_sketchily.html.erb~ +23 -0
  12. data/app/views/sketchily/_sketchily_tag.html.erb +21 -0
  13. data/app/views/sketchily/_sketchily_tag.html.erb~ +21 -0
  14. data/app/views/sketchily/_svg_edit_tag.html.erb~ +51 -0
  15. data/app/views/sketchily/svg_edit_tag_.html~ +35 -0
  16. data/lib/sketchily.rb +15 -0
  17. data/lib/sketchily.rb~ +16 -0
  18. data/lib/sketchily/engine.rb +4 -0
  19. data/lib/sketchily/sketchily.rb +28 -0
  20. data/lib/sketchily/sketchily_show.rb~ +13 -0
  21. data/lib/sketchily/sketchily_tag.rb +15 -0
  22. data/lib/sketchily/svg_edit_tag.rb~ +9 -0
  23. data/lib/sketchily/version.rb +3 -0
  24. data/lib/sketchily/version.rb~ +3 -0
  25. data/spec/dummy/README.rdoc +261 -0
  26. data/spec/dummy/Rakefile +7 -0
  27. data/spec/dummy/app/assets/javascripts/application.js +15 -0
  28. data/spec/dummy/app/assets/stylesheets/application.css +13 -0
  29. data/spec/dummy/app/controllers/application_controller.rb +3 -0
  30. data/spec/dummy/app/helpers/application_helper.rb +2 -0
  31. data/spec/dummy/app/views/layouts/application.html.erb +14 -0
  32. data/spec/dummy/config.ru +4 -0
  33. data/spec/dummy/config/application.rb +59 -0
  34. data/spec/dummy/config/boot.rb +10 -0
  35. data/spec/dummy/config/database.yml +25 -0
  36. data/spec/dummy/config/environment.rb +5 -0
  37. data/spec/dummy/config/environments/development.rb +37 -0
  38. data/spec/dummy/config/environments/production.rb +67 -0
  39. data/spec/dummy/config/environments/test.rb +37 -0
  40. data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
  41. data/spec/dummy/config/initializers/inflections.rb +15 -0
  42. data/spec/dummy/config/initializers/mime_types.rb +5 -0
  43. data/spec/dummy/config/initializers/secret_token.rb +7 -0
  44. data/spec/dummy/config/initializers/session_store.rb +8 -0
  45. data/spec/dummy/config/initializers/wrap_parameters.rb +14 -0
  46. data/spec/dummy/config/locales/en.yml +5 -0
  47. data/spec/dummy/config/routes.rb +58 -0
  48. data/spec/dummy/public/404.html +26 -0
  49. data/spec/dummy/public/422.html +26 -0
  50. data/spec/dummy/public/500.html +25 -0
  51. data/spec/dummy/public/favicon.ico +0 -0
  52. data/spec/dummy/script/rails +6 -0
  53. data/spec/lib/sketchily_spec.rb +0 -0
  54. data/spec/spec_helper.rb +11 -0
  55. data/vendor/assets/svg-edit-2.6/browser-not-supported.html +27 -0
  56. data/vendor/assets/svg-edit-2.6/browser.js +180 -0
  57. data/vendor/assets/svg-edit-2.6/canvg/canvg.js +2620 -0
  58. data/vendor/assets/svg-edit-2.6/canvg/rgbcolor.js +287 -0
  59. data/vendor/assets/svg-edit-2.6/contextmenu.js +67 -0
  60. data/vendor/assets/svg-edit-2.6/contextmenu/jquery.contextMenu.js +203 -0
  61. data/vendor/assets/svg-edit-2.6/draw.js +528 -0
  62. data/vendor/assets/svg-edit-2.6/embedapi.html +56 -0
  63. data/vendor/assets/svg-edit-2.6/embedapi.js +173 -0
  64. data/vendor/assets/svg-edit-2.6/extensions/closepath_icons.svg +41 -0
  65. data/vendor/assets/svg-edit-2.6/extensions/ext-arrows.js +298 -0
  66. data/vendor/assets/svg-edit-2.6/extensions/ext-closepath.js +92 -0
  67. data/vendor/assets/svg-edit-2.6/extensions/ext-connector.js +587 -0
  68. data/vendor/assets/svg-edit-2.6/extensions/ext-eyedropper.js +109 -0
  69. data/vendor/assets/svg-edit-2.6/extensions/ext-foreignobject.js +277 -0
  70. data/vendor/assets/svg-edit-2.6/extensions/ext-grid.js +184 -0
  71. data/vendor/assets/svg-edit-2.6/extensions/ext-helloworld.js +78 -0
  72. data/vendor/assets/svg-edit-2.6/extensions/ext-imagelib.js +453 -0
  73. data/vendor/assets/svg-edit-2.6/extensions/ext-imagelib.xml +14 -0
  74. data/vendor/assets/svg-edit-2.6/extensions/ext-markers.js +572 -0
  75. data/vendor/assets/svg-edit-2.6/extensions/ext-server_moinsave.js +56 -0
  76. data/vendor/assets/svg-edit-2.6/extensions/ext-server_opensave.js +180 -0
  77. data/vendor/assets/svg-edit-2.6/extensions/ext-shapes.js +387 -0
  78. data/vendor/assets/svg-edit-2.6/extensions/ext-shapes.xml +10 -0
  79. data/vendor/assets/svg-edit-2.6/extensions/eyedropper-icon.xml +34 -0
  80. data/vendor/assets/svg-edit-2.6/extensions/eyedropper.png +0 -0
  81. data/vendor/assets/svg-edit-2.6/extensions/fileopen.php +31 -0
  82. data/vendor/assets/svg-edit-2.6/extensions/filesave.php +44 -0
  83. data/vendor/assets/svg-edit-2.6/extensions/foreignobject-icons.xml +96 -0
  84. data/vendor/assets/svg-edit-2.6/extensions/grid-icon.xml +30 -0
  85. data/vendor/assets/svg-edit-2.6/extensions/helloworld-icon.xml +21 -0
  86. data/vendor/assets/svg-edit-2.6/extensions/imagelib/index.html +64 -0
  87. data/vendor/assets/svg-edit-2.6/extensions/imagelib/smiley.svg +12 -0
  88. data/vendor/assets/svg-edit-2.6/extensions/markers-icons.xml +115 -0
  89. data/vendor/assets/svg-edit-2.6/extensions/shapelib/animal.json +21 -0
  90. data/vendor/assets/svg-edit-2.6/extensions/shapelib/arrow.json +28 -0
  91. data/vendor/assets/svg-edit-2.6/extensions/shapelib/dialog_balloon.json +9 -0
  92. data/vendor/assets/svg-edit-2.6/extensions/shapelib/electronics.json +20 -0
  93. data/vendor/assets/svg-edit-2.6/extensions/shapelib/flowchart.json +25 -0
  94. data/vendor/assets/svg-edit-2.6/extensions/shapelib/game.json +13 -0
  95. data/vendor/assets/svg-edit-2.6/extensions/shapelib/math.json +9 -0
  96. data/vendor/assets/svg-edit-2.6/extensions/shapelib/misc.json +37 -0
  97. data/vendor/assets/svg-edit-2.6/extensions/shapelib/music.json +21 -0
  98. data/vendor/assets/svg-edit-2.6/extensions/shapelib/object.json +19 -0
  99. data/vendor/assets/svg-edit-2.6/extensions/shapelib/raphael.txt +12 -0
  100. data/vendor/assets/svg-edit-2.6/extensions/shapelib/raphael_1.json +67 -0
  101. data/vendor/assets/svg-edit-2.6/extensions/shapelib/raphael_2.json +64 -0
  102. data/vendor/assets/svg-edit-2.6/extensions/shapelib/symbol.json +28 -0
  103. data/vendor/assets/svg-edit-2.6/history.js +601 -0
  104. data/vendor/assets/svg-edit-2.6/images/README.txt +61 -0
  105. data/vendor/assets/svg-edit-2.6/images/align-bottom.png +0 -0
  106. data/vendor/assets/svg-edit-2.6/images/align-bottom.svg +277 -0
  107. data/vendor/assets/svg-edit-2.6/images/align-center.png +0 -0
  108. data/vendor/assets/svg-edit-2.6/images/align-center.svg +252 -0
  109. data/vendor/assets/svg-edit-2.6/images/align-left.png +0 -0
  110. data/vendor/assets/svg-edit-2.6/images/align-left.svg +235 -0
  111. data/vendor/assets/svg-edit-2.6/images/align-middle.png +0 -0
  112. data/vendor/assets/svg-edit-2.6/images/align-middle.svg +250 -0
  113. data/vendor/assets/svg-edit-2.6/images/align-right.png +0 -0
  114. data/vendor/assets/svg-edit-2.6/images/align-right.svg +233 -0
  115. data/vendor/assets/svg-edit-2.6/images/align-top.png +0 -0
  116. data/vendor/assets/svg-edit-2.6/images/align-top.svg +233 -0
  117. data/vendor/assets/svg-edit-2.6/images/bold.png +0 -0
  118. data/vendor/assets/svg-edit-2.6/images/cancel.png +0 -0
  119. data/vendor/assets/svg-edit-2.6/images/circle.png +0 -0
  120. data/vendor/assets/svg-edit-2.6/images/clear.png +0 -0
  121. data/vendor/assets/svg-edit-2.6/images/clone.png +0 -0
  122. data/vendor/assets/svg-edit-2.6/images/conn.svg +29 -0
  123. data/vendor/assets/svg-edit-2.6/images/copy.png +0 -0
  124. data/vendor/assets/svg-edit-2.6/images/cut.png +0 -0
  125. data/vendor/assets/svg-edit-2.6/images/delete.png +0 -0
  126. data/vendor/assets/svg-edit-2.6/images/document-properties.png +0 -0
  127. data/vendor/assets/svg-edit-2.6/images/dropdown.gif +0 -0
  128. data/vendor/assets/svg-edit-2.6/images/ellipse.png +0 -0
  129. data/vendor/assets/svg-edit-2.6/images/eye.png +0 -0
  130. data/vendor/assets/svg-edit-2.6/images/fhpath.png +0 -0
  131. data/vendor/assets/svg-edit-2.6/images/flyouth.png +0 -0
  132. data/vendor/assets/svg-edit-2.6/images/flyup.gif +0 -0
  133. data/vendor/assets/svg-edit-2.6/images/freehand-circle.png +0 -0
  134. data/vendor/assets/svg-edit-2.6/images/freehand-square.png +0 -0
  135. data/vendor/assets/svg-edit-2.6/images/go-down.png +0 -0
  136. data/vendor/assets/svg-edit-2.6/images/go-up.png +0 -0
  137. data/vendor/assets/svg-edit-2.6/images/image.png +0 -0
  138. data/vendor/assets/svg-edit-2.6/images/italic.png +0 -0
  139. data/vendor/assets/svg-edit-2.6/images/line.png +0 -0
  140. data/vendor/assets/svg-edit-2.6/images/link_controls.png +0 -0
  141. data/vendor/assets/svg-edit-2.6/images/logo.png +0 -0
  142. data/vendor/assets/svg-edit-2.6/images/logo.svg +32 -0
  143. data/vendor/assets/svg-edit-2.6/images/move_bottom.png +0 -0
  144. data/vendor/assets/svg-edit-2.6/images/move_top.png +0 -0
  145. data/vendor/assets/svg-edit-2.6/images/node_clone.png +0 -0
  146. data/vendor/assets/svg-edit-2.6/images/node_delete.png +0 -0
  147. data/vendor/assets/svg-edit-2.6/images/none.png +0 -0
  148. data/vendor/assets/svg-edit-2.6/images/open.png +0 -0
  149. data/vendor/assets/svg-edit-2.6/images/paste.png +0 -0
  150. data/vendor/assets/svg-edit-2.6/images/path.png +0 -0
  151. data/vendor/assets/svg-edit-2.6/images/polygon.png +0 -0
  152. data/vendor/assets/svg-edit-2.6/images/polygon.svg +219 -0
  153. data/vendor/assets/svg-edit-2.6/images/rect.png +0 -0
  154. data/vendor/assets/svg-edit-2.6/images/redo.png +0 -0
  155. data/vendor/assets/svg-edit-2.6/images/reorient.png +0 -0
  156. data/vendor/assets/svg-edit-2.6/images/rotate.png +0 -0
  157. data/vendor/assets/svg-edit-2.6/images/save.png +0 -0
  158. data/vendor/assets/svg-edit-2.6/images/select.png +0 -0
  159. data/vendor/assets/svg-edit-2.6/images/select_node.png +0 -0
  160. data/vendor/assets/svg-edit-2.6/images/sep.png +0 -0
  161. data/vendor/assets/svg-edit-2.6/images/shape_group.png +0 -0
  162. data/vendor/assets/svg-edit-2.6/images/shape_ungroup.png +0 -0
  163. data/vendor/assets/svg-edit-2.6/images/source.png +0 -0
  164. data/vendor/assets/svg-edit-2.6/images/spinbtn_updn_big.png +0 -0
  165. data/vendor/assets/svg-edit-2.6/images/square.png +0 -0
  166. data/vendor/assets/svg-edit-2.6/images/svg_edit_icons.svg +1034 -0
  167. data/vendor/assets/svg-edit-2.6/images/svg_edit_icons.svgz +0 -0
  168. data/vendor/assets/svg-edit-2.6/images/text.png +0 -0
  169. data/vendor/assets/svg-edit-2.6/images/text.svg +157 -0
  170. data/vendor/assets/svg-edit-2.6/images/to_path.png +0 -0
  171. data/vendor/assets/svg-edit-2.6/images/undo.png +0 -0
  172. data/vendor/assets/svg-edit-2.6/images/view-refresh.png +0 -0
  173. data/vendor/assets/svg-edit-2.6/images/wave.png +0 -0
  174. data/vendor/assets/svg-edit-2.6/images/wireframe.png +0 -0
  175. data/vendor/assets/svg-edit-2.6/images/zoom.png +0 -0
  176. data/vendor/assets/svg-edit-2.6/jgraduate/LICENSE +202 -0
  177. data/vendor/assets/svg-edit-2.6/jgraduate/README +3 -0
  178. data/vendor/assets/svg-edit-2.6/jgraduate/css/jPicker.css +1 -0
  179. data/vendor/assets/svg-edit-2.6/jgraduate/css/jgraduate.css +351 -0
  180. data/vendor/assets/svg-edit-2.6/jgraduate/images/AlphaBar.png +0 -0
  181. data/vendor/assets/svg-edit-2.6/jgraduate/images/Bars.png +0 -0
  182. data/vendor/assets/svg-edit-2.6/jgraduate/images/Maps.png +0 -0
  183. data/vendor/assets/svg-edit-2.6/jgraduate/images/NoColor.png +0 -0
  184. data/vendor/assets/svg-edit-2.6/jgraduate/images/bar-opacity.png +0 -0
  185. data/vendor/assets/svg-edit-2.6/jgraduate/images/map-opacity.png +0 -0
  186. data/vendor/assets/svg-edit-2.6/jgraduate/images/mappoint.gif +0 -0
  187. data/vendor/assets/svg-edit-2.6/jgraduate/images/mappoint_c.png +0 -0
  188. data/vendor/assets/svg-edit-2.6/jgraduate/images/mappoint_f.png +0 -0
  189. data/vendor/assets/svg-edit-2.6/jgraduate/images/picker.gif +0 -0
  190. data/vendor/assets/svg-edit-2.6/jgraduate/images/preview-opacity.png +0 -0
  191. data/vendor/assets/svg-edit-2.6/jgraduate/images/rangearrows.gif +0 -0
  192. data/vendor/assets/svg-edit-2.6/jgraduate/images/rangearrows2.gif +0 -0
  193. data/vendor/assets/svg-edit-2.6/jgraduate/jpicker.js +2091 -0
  194. data/vendor/assets/svg-edit-2.6/jgraduate/jpicker.min.js +1 -0
  195. data/vendor/assets/svg-edit-2.6/jgraduate/jquery.jgraduate.js +1175 -0
  196. data/vendor/assets/svg-edit-2.6/jgraduate/jquery.jgraduate.min.js +37 -0
  197. data/vendor/assets/svg-edit-2.6/jquery-ui/jquery-ui-1.8.17.custom.min.js +54 -0
  198. data/vendor/assets/svg-edit-2.6/jquery-ui/jquery-ui-1.8.custom.min.js +84 -0
  199. data/vendor/assets/svg-edit-2.6/jquery.js +4 -0
  200. data/vendor/assets/svg-edit-2.6/jquerybbq/jquery.bbq.min.js +18 -0
  201. data/vendor/assets/svg-edit-2.6/js-hotkeys/README.md +45 -0
  202. data/vendor/assets/svg-edit-2.6/js-hotkeys/jquery.hotkeys.min.js +15 -0
  203. data/vendor/assets/svg-edit-2.6/locale/README.txt +17 -0
  204. data/vendor/assets/svg-edit-2.6/locale/lang.af.js +234 -0
  205. data/vendor/assets/svg-edit-2.6/locale/lang.ar.js +234 -0
  206. data/vendor/assets/svg-edit-2.6/locale/lang.az.js +234 -0
  207. data/vendor/assets/svg-edit-2.6/locale/lang.be.js +234 -0
  208. data/vendor/assets/svg-edit-2.6/locale/lang.bg.js +234 -0
  209. data/vendor/assets/svg-edit-2.6/locale/lang.ca.js +234 -0
  210. data/vendor/assets/svg-edit-2.6/locale/lang.cs.js +234 -0
  211. data/vendor/assets/svg-edit-2.6/locale/lang.cy.js +234 -0
  212. data/vendor/assets/svg-edit-2.6/locale/lang.da.js +234 -0
  213. data/vendor/assets/svg-edit-2.6/locale/lang.de.js +234 -0
  214. data/vendor/assets/svg-edit-2.6/locale/lang.el.js +234 -0
  215. data/vendor/assets/svg-edit-2.6/locale/lang.en.js +234 -0
  216. data/vendor/assets/svg-edit-2.6/locale/lang.es.js +234 -0
  217. data/vendor/assets/svg-edit-2.6/locale/lang.et.js +234 -0
  218. data/vendor/assets/svg-edit-2.6/locale/lang.fa.js +234 -0
  219. data/vendor/assets/svg-edit-2.6/locale/lang.fi.js +234 -0
  220. data/vendor/assets/svg-edit-2.6/locale/lang.fr.js +234 -0
  221. data/vendor/assets/svg-edit-2.6/locale/lang.fy.js +234 -0
  222. data/vendor/assets/svg-edit-2.6/locale/lang.ga.js +234 -0
  223. data/vendor/assets/svg-edit-2.6/locale/lang.gl.js +234 -0
  224. data/vendor/assets/svg-edit-2.6/locale/lang.he.js +234 -0
  225. data/vendor/assets/svg-edit-2.6/locale/lang.hi.js +234 -0
  226. data/vendor/assets/svg-edit-2.6/locale/lang.hr.js +234 -0
  227. data/vendor/assets/svg-edit-2.6/locale/lang.hu.js +234 -0
  228. data/vendor/assets/svg-edit-2.6/locale/lang.hy.js +234 -0
  229. data/vendor/assets/svg-edit-2.6/locale/lang.id.js +234 -0
  230. data/vendor/assets/svg-edit-2.6/locale/lang.is.js +234 -0
  231. data/vendor/assets/svg-edit-2.6/locale/lang.it.js +234 -0
  232. data/vendor/assets/svg-edit-2.6/locale/lang.ja.js +234 -0
  233. data/vendor/assets/svg-edit-2.6/locale/lang.ko.js +234 -0
  234. data/vendor/assets/svg-edit-2.6/locale/lang.lt.js +234 -0
  235. data/vendor/assets/svg-edit-2.6/locale/lang.lv.js +234 -0
  236. data/vendor/assets/svg-edit-2.6/locale/lang.mk.js +234 -0
  237. data/vendor/assets/svg-edit-2.6/locale/lang.ms.js +234 -0
  238. data/vendor/assets/svg-edit-2.6/locale/lang.mt.js +234 -0
  239. data/vendor/assets/svg-edit-2.6/locale/lang.nl.js +234 -0
  240. data/vendor/assets/svg-edit-2.6/locale/lang.no.js +234 -0
  241. data/vendor/assets/svg-edit-2.6/locale/lang.pl.js +234 -0
  242. data/vendor/assets/svg-edit-2.6/locale/lang.pt-BR.js +234 -0
  243. data/vendor/assets/svg-edit-2.6/locale/lang.pt-PT.js +234 -0
  244. data/vendor/assets/svg-edit-2.6/locale/lang.ro.js +234 -0
  245. data/vendor/assets/svg-edit-2.6/locale/lang.ru.js +234 -0
  246. data/vendor/assets/svg-edit-2.6/locale/lang.sk.js +234 -0
  247. data/vendor/assets/svg-edit-2.6/locale/lang.sl.js +234 -0
  248. data/vendor/assets/svg-edit-2.6/locale/lang.sq.js +234 -0
  249. data/vendor/assets/svg-edit-2.6/locale/lang.sr.js +234 -0
  250. data/vendor/assets/svg-edit-2.6/locale/lang.sv.js +234 -0
  251. data/vendor/assets/svg-edit-2.6/locale/lang.sw.js +234 -0
  252. data/vendor/assets/svg-edit-2.6/locale/lang.test.js +234 -0
  253. data/vendor/assets/svg-edit-2.6/locale/lang.th.js +234 -0
  254. data/vendor/assets/svg-edit-2.6/locale/lang.tl.js +234 -0
  255. data/vendor/assets/svg-edit-2.6/locale/lang.tr.js +234 -0
  256. data/vendor/assets/svg-edit-2.6/locale/lang.uk.js +234 -0
  257. data/vendor/assets/svg-edit-2.6/locale/lang.vi.js +234 -0
  258. data/vendor/assets/svg-edit-2.6/locale/lang.yi.js +234 -0
  259. data/vendor/assets/svg-edit-2.6/locale/lang.zh-CN.js +234 -0
  260. data/vendor/assets/svg-edit-2.6/locale/lang.zh-HK.js +234 -0
  261. data/vendor/assets/svg-edit-2.6/locale/lang.zh-TW.js +234 -0
  262. data/vendor/assets/svg-edit-2.6/locale/locale.js +320 -0
  263. data/vendor/assets/svg-edit-2.6/math.js +246 -0
  264. data/vendor/assets/svg-edit-2.6/path.js +980 -0
  265. data/vendor/assets/svg-edit-2.6/sanitize.js +273 -0
  266. data/vendor/assets/svg-edit-2.6/select.js +532 -0
  267. data/vendor/assets/svg-edit-2.6/spinbtn/JQuerySpinBtn.css +41 -0
  268. data/vendor/assets/svg-edit-2.6/spinbtn/JQuerySpinBtn.js +266 -0
  269. data/vendor/assets/svg-edit-2.6/spinbtn/JQuerySpinBtn.min.js +7 -0
  270. data/vendor/assets/svg-edit-2.6/spinbtn/spinbtn_updn.png +0 -0
  271. data/vendor/assets/svg-edit-2.6/svg-editor.css +1495 -0
  272. data/vendor/assets/svg-edit-2.6/svg-editor.css~ +1500 -0
  273. data/vendor/assets/svg-edit-2.6/svg-editor.html +788 -0
  274. data/vendor/assets/svg-edit-2.6/svg-editor.html~ +788 -0
  275. data/vendor/assets/svg-edit-2.6/svg-editor.js +4969 -0
  276. data/vendor/assets/svg-edit-2.6/svg-editor.manifest +121 -0
  277. data/vendor/assets/svg-edit-2.6/svgcanvas.js +8775 -0
  278. data/vendor/assets/svg-edit-2.6/svgedit.compiled.js +465 -0
  279. data/vendor/assets/svg-edit-2.6/svgicons/jquery.svgicons.js +486 -0
  280. data/vendor/assets/svg-edit-2.6/svgtransformlist.js +291 -0
  281. data/vendor/assets/svg-edit-2.6/svgutils.js +651 -0
  282. data/vendor/assets/svg-edit-2.6/touch.js +30 -0
  283. data/vendor/assets/svg-edit-2.6/units.js +281 -0
  284. metadata +407 -0
@@ -0,0 +1,41 @@
1
+ /*
2
+ Styles to make ordinary <INPUT type="text"/> look like a spinbutton/spinbox control.
3
+ Use with JQuerySpinBtn.js to provide the spin functionality by reacting to mouse etc.
4
+ (Requires a reference to the JQuery library found at http://jquery.com/src/latest/)
5
+ (Hats-off to John Resig for creating the excellent JQuery library. It is fab.)
6
+
7
+ This control is achieved with no extra html markup whatsoever and uses unobtrusive javascript.
8
+
9
+ Written by George Adamson, Software Unity (george.jquery@softwareunity.com) September 2006.
10
+ Big improvements added by Mark Gibson, (mgibson@designlinks.net) September 2006.
11
+
12
+ Do contact me with comments and suggestions but please don't ask for support.
13
+ As much as I'd love to help with specific problems I have plenty to get on with already!
14
+
15
+ Go ahead and use it in your own projects. This code is provided 'as is'.
16
+ Sure I've tested in heaps of ways. Its good for me, but you use it at your own risk.
17
+ SoftwareUnity and I are certainly not responsible if your computer sets fire to the sofa,
18
+ hacks into the pentagon, hijacks a plane or gives you any kind of hassle whatsoever.
19
+
20
+ If you'd like your spin-button image in a different place then you'll need to alter both
21
+ the CSS below and the javascript isMouseOverUpDn() function to accommodate the new position.
22
+ You could even have left and right buttons either side of the textbox.
23
+ */
24
+
25
+ INPUT.spin-button {
26
+ /* explicitly put padding for top/bottom/left in here so that Opera displays it better */
27
+ padding: 2px 20px 2px 2px;
28
+ background-repeat:no-repeat; /* Warning: Img may disappear in Firefox if you use 'background-attachment:fixed' ! */
29
+ background-position:100% 0%;
30
+ background-image:url('spinbtn_updn.png');
31
+ background-color:white; /* Needed for Opera */
32
+ }
33
+
34
+ INPUT.spin-button.up { /* Change button img when mouse is over the UP-arrow */
35
+ cursor:pointer;
36
+ background-position:100% -18px; /* 18px matches height of 2 visible buttons */
37
+ }
38
+ INPUT.spin-button.down { /* Change button img when mouse is over the DOWN-arrow */
39
+ cursor:pointer;
40
+ background-position:100% -36px; /* 36px matches height of 2x2 visible buttons */
41
+ }
@@ -0,0 +1,266 @@
1
+ /* SpinButton control
2
+ *
3
+ * Adds bells and whistles to any ordinary textbox to
4
+ * make it look and feel like a SpinButton Control.
5
+ *
6
+ * Originally written by George Adamson, Software Unity (george.jquery@softwareunity.com) August 2006.
7
+ * - Added min/max options
8
+ * - Added step size option
9
+ * - Added bigStep (page up/down) option
10
+ *
11
+ * Modifications made by Mark Gibson, (mgibson@designlinks.net) September 2006:
12
+ * - Converted to jQuery plugin
13
+ * - Allow limited or unlimited min/max values
14
+ * - Allow custom class names, and add class to input element
15
+ * - Removed global vars
16
+ * - Reset (to original or through config) when invalid value entered
17
+ * - Repeat whilst holding mouse button down (with initial pause, like keyboard repeat)
18
+ * - Support mouse wheel in Firefox
19
+ * - Fix double click in IE
20
+ * - Refactored some code and renamed some vars
21
+ *
22
+ * Modifications by Jeff Schiller, June 2009:
23
+ * - provide callback function for when the value changes based on the following
24
+ * http://www.mail-archive.com/jquery-en@googlegroups.com/msg36070.html
25
+ * Modifications by Jeff Schiller, July 2009:
26
+ * - improve styling for widget in Opera
27
+ * - consistent key-repeat handling cross-browser
28
+ * Modifications by Alexis Deveria, October 2009:
29
+ * - provide "stepfunc" callback option to allow custom function to run when changing a value
30
+ * - Made adjustValue(0) only run on certain keyup events, not all.
31
+ *
32
+ * Tested in IE6, Opera9, Firefox 1.5
33
+ * v1.0 11 Aug 2006 - George Adamson - First release
34
+ * v1.1 Aug 2006 - George Adamson - Minor enhancements
35
+ * v1.2 27 Sep 2006 - Mark Gibson - Major enhancements
36
+ * v1.3a 28 Sep 2006 - George Adamson - Minor enhancements
37
+ * v1.4 18 Jun 2009 - Jeff Schiller - Added callback function
38
+ * v1.5 06 Jul 2009 - Jeff Schiller - Fixes for Opera.
39
+ * v1.6 13 Oct 2009 - Alexis Deveria - Added stepfunc function
40
+ * v1.7 21 Oct 2009 - Alexis Deveria - Minor fixes
41
+ * Fast-repeat for keys and live updating as you type.
42
+ * v1.8 12 Jan 2010 - Benjamin Thomas - Fixes for mouseout behavior.
43
+ * Added smallStep
44
+
45
+ Sample usage:
46
+
47
+ // Create group of settings to initialise spinbutton(s). (Optional)
48
+ var myOptions = {
49
+ min: 0, // Set lower limit.
50
+ max: 100, // Set upper limit.
51
+ step: 1, // Set increment size.
52
+ smallStep: 0.5, // Set shift-click increment size.
53
+ spinClass: mySpinBtnClass, // CSS class to style the spinbutton. (Class also specifies url of the up/down button image.)
54
+ upClass: mySpinUpClass, // CSS class for style when mouse over up button.
55
+ downClass: mySpinDnClass // CSS class for style when mouse over down button.
56
+ }
57
+
58
+ $(document).ready(function(){
59
+
60
+ // Initialise INPUT element(s) as SpinButtons: (passing options if desired)
61
+ $("#myInputElement").SpinButton(myOptions);
62
+
63
+ });
64
+
65
+ */
66
+ $.fn.SpinButton = function(cfg){
67
+ return this.each(function(){
68
+
69
+ this.repeating = false;
70
+
71
+ // Apply specified options or defaults:
72
+ // (Ought to refactor this some day to use $.extend() instead)
73
+ this.spinCfg = {
74
+ //min: cfg && cfg.min ? Number(cfg.min) : null,
75
+ //max: cfg && cfg.max ? Number(cfg.max) : null,
76
+ min: cfg && !isNaN(parseFloat(cfg.min)) ? Number(cfg.min) : null, // Fixes bug with min:0
77
+ max: cfg && !isNaN(parseFloat(cfg.max)) ? Number(cfg.max) : null,
78
+ step: cfg && cfg.step ? Number(cfg.step) : 1,
79
+ stepfunc: cfg && cfg.stepfunc ? cfg.stepfunc : false,
80
+ page: cfg && cfg.page ? Number(cfg.page) : 10,
81
+ upClass: cfg && cfg.upClass ? cfg.upClass : 'up',
82
+ downClass: cfg && cfg.downClass ? cfg.downClass : 'down',
83
+ reset: cfg && cfg.reset ? cfg.reset : this.value,
84
+ delay: cfg && cfg.delay ? Number(cfg.delay) : 500,
85
+ interval: cfg && cfg.interval ? Number(cfg.interval) : 100,
86
+ _btn_width: 20,
87
+ _direction: null,
88
+ _delay: null,
89
+ _repeat: null,
90
+ callback: cfg && cfg.callback ? cfg.callback : null
91
+ };
92
+
93
+ // if a smallStep isn't supplied, use half the regular step
94
+ this.spinCfg.smallStep = cfg && cfg.smallStep ? cfg.smallStep : this.spinCfg.step/2;
95
+
96
+ this.adjustValue = function(i){
97
+ var v;
98
+ if(isNaN(this.value)) {
99
+ v = this.spinCfg.reset;
100
+ } else if($.isFunction(this.spinCfg.stepfunc)) {
101
+ v = this.spinCfg.stepfunc(this, i);
102
+ } else {
103
+ // weirdest javascript bug ever: 5.1 + 0.1 = 5.199999999
104
+ v = Number((Number(this.value) + Number(i)).toFixed(5));
105
+ }
106
+ if (this.spinCfg.min !== null) v = Math.max(v, this.spinCfg.min);
107
+ if (this.spinCfg.max !== null) v = Math.min(v, this.spinCfg.max);
108
+ this.value = v;
109
+ if ($.isFunction(this.spinCfg.callback)) this.spinCfg.callback(this);
110
+ };
111
+
112
+ $(this)
113
+ .addClass(cfg && cfg.spinClass ? cfg.spinClass : 'spin-button')
114
+
115
+ .mousemove(function(e){
116
+ // Determine which button mouse is over, or not (spin direction):
117
+ var x = e.pageX || e.x;
118
+ var y = e.pageY || e.y;
119
+ var el = e.target || e.srcElement;
120
+ var scale = svgEditor.tool_scale || 1;
121
+ var height = $(el).height()/2;
122
+
123
+ var direction =
124
+ (x > coord(el,'offsetLeft') + el.offsetWidth*scale - this.spinCfg._btn_width)
125
+ ? ((y < coord(el,'offsetTop') + height*scale) ? 1 : -1) : 0;
126
+
127
+ if (direction !== this.spinCfg._direction) {
128
+ // Style up/down buttons:
129
+ switch(direction){
130
+ case 1: // Up arrow:
131
+ $(this).removeClass(this.spinCfg.downClass).addClass(this.spinCfg.upClass);
132
+ break;
133
+ case -1: // Down arrow:
134
+ $(this).removeClass(this.spinCfg.upClass).addClass(this.spinCfg.downClass);
135
+ break;
136
+ default: // Mouse is elsewhere in the textbox
137
+ $(this).removeClass(this.spinCfg.upClass).removeClass(this.spinCfg.downClass);
138
+ }
139
+
140
+ // Set spin direction:
141
+ this.spinCfg._direction = direction;
142
+ }
143
+ })
144
+
145
+ .mouseout(function(){
146
+ // Reset up/down buttons to their normal appearance when mouse moves away:
147
+ $(this).removeClass(this.spinCfg.upClass).removeClass(this.spinCfg.downClass);
148
+ this.spinCfg._direction = null;
149
+ window.clearInterval(this.spinCfg._repeat);
150
+ window.clearTimeout(this.spinCfg._delay);
151
+ })
152
+
153
+ .mousedown(function(e){
154
+ if ( e.button === 0 && this.spinCfg._direction != 0) {
155
+ // Respond to click on one of the buttons:
156
+ var self = this;
157
+ var stepSize = e.shiftKey ? self.spinCfg.smallStep : self.spinCfg.step
158
+
159
+ var adjust = function() {
160
+ self.adjustValue(self.spinCfg._direction * stepSize);
161
+ };
162
+
163
+ adjust();
164
+
165
+ // Initial delay before repeating adjustment
166
+ self.spinCfg._delay = window.setTimeout(function() {
167
+ adjust();
168
+ // Repeat adjust at regular intervals
169
+ self.spinCfg._repeat = window.setInterval(adjust, self.spinCfg.interval);
170
+ }, self.spinCfg.delay);
171
+ }
172
+ })
173
+
174
+ .mouseup(function(e){
175
+ // Cancel repeating adjustment
176
+ window.clearInterval(this.spinCfg._repeat);
177
+ window.clearTimeout(this.spinCfg._delay);
178
+ })
179
+
180
+ .dblclick(function(e) {
181
+ if ($.browser.msie)
182
+ this.adjustValue(this.spinCfg._direction * this.spinCfg.step);
183
+ })
184
+
185
+ .keydown(function(e){
186
+ // Respond to up/down arrow keys.
187
+ switch(e.keyCode){
188
+ case 38: this.adjustValue(this.spinCfg.step); break; // Up
189
+ case 40: this.adjustValue(-this.spinCfg.step); break; // Down
190
+ case 33: this.adjustValue(this.spinCfg.page); break; // PageUp
191
+ case 34: this.adjustValue(-this.spinCfg.page); break; // PageDown
192
+ }
193
+ })
194
+
195
+ /*
196
+ http://unixpapa.com/js/key.html describes the current state-of-affairs for
197
+ key repeat events:
198
+ - Safari 3.1 changed their model so that keydown is reliably repeated going forward
199
+ - Firefox and Opera still only repeat the keypress event, not the keydown
200
+ */
201
+ .keypress(function(e){
202
+ if (this.repeating) {
203
+ // Respond to up/down arrow keys.
204
+ switch(e.keyCode){
205
+ case 38: this.adjustValue(this.spinCfg.step); break; // Up
206
+ case 40: this.adjustValue(-this.spinCfg.step); break; // Down
207
+ case 33: this.adjustValue(this.spinCfg.page); break; // PageUp
208
+ case 34: this.adjustValue(-this.spinCfg.page); break; // PageDown
209
+ }
210
+ }
211
+ // we always ignore the first keypress event (use the keydown instead)
212
+ else {
213
+ this.repeating = true;
214
+ }
215
+ })
216
+
217
+ // clear the 'repeating' flag
218
+ .keyup(function(e) {
219
+ this.repeating = false;
220
+ switch(e.keyCode){
221
+ case 38: // Up
222
+ case 40: // Down
223
+ case 33: // PageUp
224
+ case 34: // PageDown
225
+ case 13: this.adjustValue(0); break; // Enter/Return
226
+ }
227
+ })
228
+
229
+ .bind("mousewheel", function(e){
230
+ // Respond to mouse wheel in IE. (It returns up/dn motion in multiples of 120)
231
+ if (e.wheelDelta >= 120)
232
+ this.adjustValue(this.spinCfg.step);
233
+ else if (e.wheelDelta <= -120)
234
+ this.adjustValue(-this.spinCfg.step);
235
+
236
+ e.preventDefault();
237
+ })
238
+
239
+ .change(function(e){
240
+ this.adjustValue(0);
241
+ });
242
+
243
+ if (this.addEventListener) {
244
+ // Respond to mouse wheel in Firefox
245
+ this.addEventListener('DOMMouseScroll', function(e) {
246
+ if (e.detail > 0)
247
+ this.adjustValue(-this.spinCfg.step);
248
+ else if (e.detail < 0)
249
+ this.adjustValue(this.spinCfg.step);
250
+
251
+ e.preventDefault();
252
+ }, false);
253
+ }
254
+ });
255
+
256
+ function coord(el,prop) {
257
+ var c = el[prop], b = document.body;
258
+
259
+ while ((el = el.offsetParent) && (el != b)) {
260
+ if (!$.browser.msie || (el.currentStyle.position != 'relative'))
261
+ c += el[prop];
262
+ }
263
+
264
+ return c;
265
+ }
266
+ };
@@ -0,0 +1,7 @@
1
+ $.fn.SpinButton=function(b){function f(a,c){for(var e=a[c],d=document.body;(a=a.offsetParent)&&a!=d;)if(!$.browser.msie||a.currentStyle.position!="relative")e+=a[c];return e}return this.each(function(){this.repeating=false;this.spinCfg={min:b&&!isNaN(parseFloat(b.min))?Number(b.min):null,max:b&&!isNaN(parseFloat(b.max))?Number(b.max):null,step:b&&b.step?Number(b.step):1,stepfunc:b&&b.stepfunc?b.stepfunc:false,page:b&&b.page?Number(b.page):10,upClass:b&&b.upClass?b.upClass:"up",downClass:b&&b.downClass?
2
+ b.downClass:"down",reset:b&&b.reset?b.reset:this.value,delay:b&&b.delay?Number(b.delay):500,interval:b&&b.interval?Number(b.interval):100,_btn_width:20,_direction:null,_delay:null,_repeat:null,callback:b&&b.callback?b.callback:null};this.spinCfg.smallStep=b&&b.smallStep?b.smallStep:this.spinCfg.step/2;this.adjustValue=function(a){a=isNaN(this.value)?this.spinCfg.reset:$.isFunction(this.spinCfg.stepfunc)?this.spinCfg.stepfunc(this,a):Number((Number(this.value)+Number(a)).toFixed(5));if(this.spinCfg.min!==
3
+ null)a=Math.max(a,this.spinCfg.min);if(this.spinCfg.max!==null)a=Math.min(a,this.spinCfg.max);this.value=a;$.isFunction(this.spinCfg.callback)&&this.spinCfg.callback(this)};$(this).addClass(b&&b.spinClass?b.spinClass:"spin-button").mousemove(function(a){var c=a.pageX||a.x,e=a.pageY||a.y;a=a.target||a.srcElement;var d=svgEditor.tool_scale||1,g=$(a).height()/2;c=c>f(a,"offsetLeft")+a.offsetWidth*d-this.spinCfg._btn_width?e<f(a,"offsetTop")+g*d?1:-1:0;if(c!==this.spinCfg._direction){switch(c){case 1:$(this).removeClass(this.spinCfg.downClass).addClass(this.spinCfg.upClass);
4
+ break;case -1:$(this).removeClass(this.spinCfg.upClass).addClass(this.spinCfg.downClass);break;default:$(this).removeClass(this.spinCfg.upClass).removeClass(this.spinCfg.downClass)}this.spinCfg._direction=c}}).mouseout(function(){$(this).removeClass(this.spinCfg.upClass).removeClass(this.spinCfg.downClass);this.spinCfg._direction=null;window.clearInterval(this.spinCfg._repeat);window.clearTimeout(this.spinCfg._delay)}).mousedown(function(a){if(a.button===0&&this.spinCfg._direction!=0){var c=this,
5
+ e=a.shiftKey?c.spinCfg.smallStep:c.spinCfg.step,d=function(){c.adjustValue(c.spinCfg._direction*e)};d();c.spinCfg._delay=window.setTimeout(function(){d();c.spinCfg._repeat=window.setInterval(d,c.spinCfg.interval)},c.spinCfg.delay)}}).mouseup(function(){window.clearInterval(this.spinCfg._repeat);window.clearTimeout(this.spinCfg._delay)}).dblclick(function(){$.browser.msie&&this.adjustValue(this.spinCfg._direction*this.spinCfg.step)}).keydown(function(a){switch(a.keyCode){case 38:this.adjustValue(this.spinCfg.step);
6
+ break;case 40:this.adjustValue(-this.spinCfg.step);break;case 33:this.adjustValue(this.spinCfg.page);break;case 34:this.adjustValue(-this.spinCfg.page)}}).keypress(function(a){if(this.repeating)switch(a.keyCode){case 38:this.adjustValue(this.spinCfg.step);break;case 40:this.adjustValue(-this.spinCfg.step);break;case 33:this.adjustValue(this.spinCfg.page);break;case 34:this.adjustValue(-this.spinCfg.page)}else this.repeating=true}).keyup(function(a){this.repeating=false;switch(a.keyCode){case 38:case 40:case 33:case 34:case 13:this.adjustValue(0)}}).bind("mousewheel",
7
+ function(a){if(a.wheelDelta>=120)this.adjustValue(this.spinCfg.step);else a.wheelDelta<=-120&&this.adjustValue(-this.spinCfg.step);a.preventDefault()}).change(function(){this.adjustValue(0)});this.addEventListener&&this.addEventListener("DOMMouseScroll",function(a){if(a.detail>0)this.adjustValue(-this.spinCfg.step);else a.detail<0&&this.adjustValue(this.spinCfg.step);a.preventDefault()},false)})};
@@ -0,0 +1,1495 @@
1
+ body {
2
+ background: #D0D0D0;
3
+ }
4
+
5
+ html, body, div{
6
+ -webkit-user-select: text;
7
+ -khtml-user-select: text;
8
+ -moz-user-select: text;
9
+ -o-user-select: text;
10
+ user-select: text;
11
+ /* this will work for QtWebKit in future */
12
+ -webkit-user-drag: text;
13
+ }
14
+
15
+ #browser-not-supported {
16
+ font-size: 0.8em;
17
+ font-family: Verdana, Helvetica, Arial;
18
+ color: #000000;
19
+ }
20
+
21
+
22
+ #svg_editor * {
23
+ transform-origin: 0 0;
24
+ -moz-transform-origin: 0 0;
25
+ -o-transform-origin: 0 0;
26
+ -webkit-transform-origin: 0 0;
27
+ }
28
+
29
+ #svg_editor {
30
+ font-size: 8pt;
31
+ font-family: Verdana, Helvetica, Arial;
32
+ color: #000000;
33
+ }
34
+
35
+ a {
36
+ color: #19c;
37
+ }
38
+
39
+ hr {
40
+ border: none;
41
+ border-bottom: 1px solid #808080;
42
+ }
43
+
44
+ select {
45
+ margin-top: 4px;
46
+ }
47
+
48
+ #svgroot {
49
+ -moz-user-select: none;
50
+ -webkit-user-select: none;
51
+ position: absolute;
52
+ top: 0;
53
+ left: 0;
54
+ }
55
+
56
+ #svgcanvas {
57
+ line-height: normal;
58
+ display: inline-block;
59
+ background-color: #A0A0A0;
60
+ text-align: center;
61
+ vertical-align: middle;
62
+ width: 640px;
63
+ height: 480px;
64
+ -apple-dashboard-region:dashboard-region(control rectangle 0px 0px 0px 0px); /* for widget regions that shouldn't react to dragging */
65
+ position: relative;
66
+ /*
67
+ A subtle gradient effect in the canvas.
68
+ Just experimenting - not sure if this is worth it.
69
+ */
70
+ background: -moz-radial-gradient(45deg,#bbb,#222);
71
+ background: -webkit-gradient(radial, center center, 3, center center, 1000, from(#bbb), to(#222));
72
+ }
73
+
74
+
75
+ /* Rulers
76
+ ——————————————————————————————————————*/
77
+
78
+ #rulers > div {
79
+ position: absolute;
80
+ background: #DDD;
81
+ z-index: 1;
82
+ overflow: hidden;
83
+ }
84
+
85
+ #ruler_corner {
86
+ top: 41px;
87
+ left: 41px;
88
+ width: 15px;
89
+ height: 15px;
90
+ }
91
+
92
+ #ruler_x {
93
+ height: 15px;
94
+ top: 41px;
95
+ left: 56px;
96
+ right: 30px;
97
+ border-bottom: 1px solid;
98
+ border-left: 1px solid #777;
99
+ }
100
+
101
+ #ruler_y {
102
+ width: 15px;
103
+ top: 55px;
104
+ left: 41px;
105
+ bottom: 56px;
106
+ border-right: 1px solid;
107
+ border-top: 1px solid #777;
108
+ }
109
+
110
+ #ruler_x canvas:first-child {
111
+ margin-left: -16px;
112
+ }
113
+
114
+ #ruler_x canvas {
115
+ float: left;
116
+ }
117
+
118
+ #ruler_y canvas {
119
+ margin-top: -16px;
120
+ }
121
+
122
+ #ruler_x > div,
123
+ #ruler_y > div {
124
+ overflow: hidden;
125
+ }
126
+
127
+ #palette_holder {
128
+ overflow: hidden;
129
+ margin-top: 5px;
130
+ padding: 5px;
131
+ position: absolute;
132
+ right: 15px;
133
+ height: 16px;
134
+ background: #f0f0f0;
135
+ border-radius: 3px;
136
+ z-index: 2;
137
+ }
138
+
139
+ #stroke_bg,
140
+ #fill_bg {
141
+ height: 16px;
142
+ width: 16px;
143
+ margin: 1px;
144
+ }
145
+
146
+ #zoomLabel {
147
+ cursor: pointer;
148
+ margin-right: 5px;
149
+ padding-top: 4px
150
+ }
151
+
152
+ #linkLabel > svg {
153
+ height: 20px;
154
+ padding-top: 4px;
155
+ }
156
+
157
+ #palette {
158
+ float: left;
159
+ width: 632px;
160
+ height: 16px;
161
+ }
162
+
163
+ #workarea {
164
+ display: inline-table-cell;
165
+ position:absolute;
166
+ top: 40px;
167
+ left: 40px;
168
+ bottom: 40px;
169
+ right: 14px;
170
+ background-color: #A0A0A0;
171
+ border: 1px solid #808080;
172
+ overflow: auto;
173
+ text-align: center;
174
+ }
175
+
176
+ #sidepanels {
177
+ display: inline-block;
178
+ position:absolute;
179
+ top: 40px;
180
+ bottom: 40px;
181
+ right: 0px;
182
+ width: 2px;
183
+ padding: 10px;
184
+ border-color: #808080;
185
+ border-style: solid;
186
+ border-width: 1px;
187
+ border-left: none;
188
+ }
189
+
190
+ #layerpanel {
191
+ display: inline-block;
192
+ position:absolute;
193
+ top: 1px;
194
+ bottom: 0px;
195
+ right: 0px;
196
+ width: 0px;
197
+ overflow: auto;
198
+ margin: 0px;
199
+ -moz-user-select: none;
200
+ -webkit-user-select: none;
201
+
202
+ }
203
+
204
+ /*
205
+ border-style: solid;
206
+ border-color: #666;
207
+ border-width: 0px 0px 0px 1px;
208
+ */
209
+ #sidepanel_handle {
210
+ display: inline-block;
211
+ position: absolute;
212
+ background-color: #D0D0D0;
213
+ font-weight: bold;
214
+ left: 0px;
215
+ top: 40%;
216
+ width: 1em;
217
+ padding: 5px 1px 5px 5px;
218
+ margin-left: 3px;
219
+ cursor: pointer;
220
+ border-radius: 5px;
221
+ -moz-border-radius: 5px;
222
+ -webkit-border-radius: 5px;
223
+ -moz-user-select: none;
224
+ -webkit-user-select: none;
225
+ }
226
+
227
+ #sidepanel_handle:hover {
228
+ font-weight: bold;
229
+ }
230
+
231
+ #sidepanel_handle * {
232
+ cursor: pointer;
233
+ -moz-user-select: none;
234
+ -webkit-user-select: none;
235
+ }
236
+ #layerbuttons {
237
+ margin: 0px;
238
+ padding: 0px;
239
+ padding-left: 2px;
240
+ padding-right: 2px;
241
+ width: 125px;
242
+ height: 20px;
243
+ border-right: 1px solid #FFFFFF;
244
+ border-bottom: 1px solid #FFFFFF;
245
+ border-left: 1px solid #808080;
246
+ border-top: 1px solid #808080;
247
+ overflow: hidden;
248
+ }
249
+
250
+ .layer_button {
251
+ width: 14px;
252
+ height: 14px;
253
+ padding: 1px;
254
+ border-left: 1px solid #FFFFFF;
255
+ border-top: 1px solid #FFFFFF;
256
+ border-right: 1px solid #808080;
257
+ border-bottom: 1px solid #808080;
258
+ cursor: pointer;
259
+ float: left;
260
+ margin-right: 3px;
261
+ }
262
+
263
+ .layer_button:last-child {
264
+ margin-right: 0;
265
+ }
266
+
267
+ .layer_buttonpressed {
268
+ width: 14px;
269
+ height: 14px;
270
+ padding: 1px;
271
+ border-right: 1px solid #FFFFFF;
272
+ border-bottom: 1px solid #FFFFFF;
273
+ border-left: 1px solid #808080;
274
+ border-top: 1px solid #808080;
275
+ cursor: pointer;
276
+ }
277
+
278
+ #layerlist {
279
+ margin: 1px;
280
+ padding: 0px;
281
+ width: 127px;
282
+ border-collapse: collapse;
283
+ border: 1px solid #808080;
284
+ background-color: #FFFFFF;
285
+ }
286
+
287
+ #layerlist tr.layer {
288
+ background-color: #FFFFFF;
289
+ margin: 0px;
290
+ padding: 0px;
291
+ }
292
+ #layerlist tr.layersel {
293
+ border: 1px solid #808080;
294
+ background-color: #CCCCCC;
295
+ }
296
+
297
+ #layerlist td.layervis {
298
+ width: 22px;
299
+ cursor:pointer;
300
+ }
301
+ #layerlist td.layerinvis {
302
+ background-image: none;
303
+ cursor:pointer;
304
+ }
305
+
306
+ #layerlist td.layervis * {
307
+ display: block;
308
+ }
309
+
310
+ #layerlist td.layerinvis * {
311
+ display: none;
312
+ }
313
+
314
+ #layerlist td.layername {
315
+ cursor: pointer;
316
+ }
317
+
318
+ #layerlist tr.layersel td.layername {
319
+ font-weight: bold;
320
+ }
321
+
322
+ #selLayerLabel {
323
+ white-space: nowrap;
324
+ }
325
+
326
+ #selLayerNames {
327
+ display: block;
328
+ }
329
+
330
+ div.palette_item {
331
+ height: 15px;
332
+ width: 15px;
333
+ float: left;
334
+ }
335
+
336
+ div.palette_item:first-child {
337
+ background: white;
338
+ }
339
+
340
+ /* Main button
341
+ —————————————————————————————*/
342
+
343
+ #main_button {
344
+ position: absolute;
345
+ top: 4px;
346
+ left: 5px;
347
+ z-index: 5;
348
+ display: none;
349
+ }
350
+
351
+ #main_icon {
352
+ position: relative;
353
+ top: -2px;
354
+ left: -2px;
355
+ width: 95px;
356
+ line-height: 26px;
357
+ }
358
+
359
+ #main_icon:hover {
360
+ background: #eee !important;
361
+ }
362
+
363
+ #main_icon.buttondown {
364
+ background: #eee !important;
365
+ -moz-box-shadow: none !important;
366
+ -webkit-box-shadow: none !important;
367
+ box-shadow: none !important;
368
+ border-radius: 3px 3px 0 0;
369
+ }
370
+
371
+ #logo {
372
+ margin-top: -2px;
373
+ }
374
+
375
+ #logo img {
376
+ border: 0;
377
+ width: 28px;
378
+ height: 28px;
379
+ }
380
+
381
+ #main_icon > div {
382
+ float: left;
383
+ }
384
+
385
+ #main_button > div {
386
+ float: left;
387
+ }
388
+
389
+ #main_button .dropdown {
390
+ position: absolute;
391
+ right: 7px;
392
+ top: 4px;
393
+ }
394
+
395
+ #main_button .tool_sep {
396
+ margin-top: 5px;
397
+ }
398
+
399
+ #main_icon span {
400
+ position: absolute;
401
+ top: 0;
402
+ left: 0;
403
+ bottom: 0;
404
+ right: 0;
405
+ display: block;
406
+ z-index: 2;
407
+ font-weight: bold;
408
+ padding-left: 34px;
409
+ line-height: 32px;
410
+ font-family: sans-serif;
411
+ }
412
+
413
+ #main_menu {
414
+ z-index: 12;
415
+ background: #eee;
416
+ position: relative;
417
+ width: 230px;
418
+ padding: 5px;
419
+ -moz-box-shadow: #555 1px 1px 4px;
420
+ -webkit-box-shadow: #555 1px 1px 4px;
421
+ box-shadow: #555 1px 1px 4px;
422
+ font-size: 1.1em;
423
+ display: none;
424
+ overflow: hidden;
425
+ clear: both;
426
+ top: -9px;
427
+ }
428
+
429
+ #main_menu ul,
430
+ #main_menu li {
431
+ list-style: none;
432
+ margin: 0;
433
+ padding: 0;
434
+ }
435
+
436
+ #main_menu li {
437
+ /* height: 35px;*/
438
+ line-height: 22px;
439
+ padding-top: 7px;
440
+ padding-left: 7px;
441
+ margin: -5px;
442
+ overflow: auto;
443
+ cursor: default;
444
+ }
445
+
446
+ #main_menu li:hover {
447
+ background: #FFC;
448
+ }
449
+
450
+ #main_menu li > div {
451
+ float: left;
452
+ padding-right: 5px;
453
+ }
454
+
455
+ #main_menu p {
456
+ margin-top: 5px;
457
+ }
458
+
459
+ /*—————————————————————————————*/
460
+
461
+ .tool_button:hover,
462
+ .push_button:hover,
463
+ .buttonup:hover,
464
+ .buttondown,
465
+ .tool_button_current,
466
+ .push_button_pressed
467
+ {
468
+ background-color: #ffc !important;
469
+ }
470
+
471
+ .tool_button_current,
472
+ .push_button_pressed,
473
+ .buttondown {
474
+ background-color: #f4e284 !important;
475
+ -webkit-box-shadow: inset 1px 1px 2px rgba(0,0,0,0.4), 1px 1px 0 white !important;
476
+ -moz-box-shadow: inset 1px 1px 2px rgba(0,0,0,0.4), 1px 1px 0 white !important;
477
+ box-shadow: inset 1px 1px 2px rgba(0,0,0,0.4), 1px 1px 0 white !important;
478
+ }
479
+
480
+ #tools_top {
481
+ position: absolute;
482
+ /*left: 108px;*/
483
+ /*right: 2px;*/
484
+ top: 2px;
485
+ height: 40px;
486
+ border-bottom: none;
487
+ overflow: auto;
488
+ }
489
+
490
+ #tools_top .tool_sep {
491
+ margin-top: 5px;
492
+ }
493
+
494
+ #tools_left {
495
+ position: absolute;
496
+ border-right: none;
497
+ width: 32px;
498
+ top: 40px;
499
+ left: 1px;
500
+ margin-top: -2px;
501
+ padding-left: 2px;
502
+ background: #D0D0D0; /* Needed so flyout icons don't appear on the left */
503
+ z-index: 4;
504
+ }
505
+
506
+ #workarea.wireframe #svgcontent * {
507
+ fill: none;
508
+ stroke: #000;
509
+ stroke-width: 1px;
510
+ stroke-opacity: 1.0;
511
+ stroke-dasharray: 0;
512
+ opacity: 1;
513
+ pointer-events: stroke;
514
+ vector-effect: non-scaling-stroke;
515
+ filter: none;
516
+ }
517
+
518
+ #workarea.wireframe #svgcontent text {
519
+ fill: #000;
520
+ stroke: none;
521
+ }
522
+
523
+ #workarea.wireframe #canvasBackground > rect {
524
+ fill: #FFF !important;
525
+ }
526
+
527
+ #tools_top div[id$="_panel"]:not(#editor_panel):not(#history_panel) {
528
+ display: none;
529
+ }
530
+
531
+ #editor_panel, #history_panel {
532
+ height: 34px;
533
+ float: left;
534
+ }
535
+
536
+ #multiselected_panel .selected_tool {
537
+ vertical-align: 12px;
538
+ }
539
+
540
+ /*TODO: Adjust position of rulers are not visible*/
541
+ #cur_context_panel {
542
+ position: absolute;
543
+ top: 57px;
544
+ left: 56px;
545
+ line-height: 22px;
546
+ overflow: auto;
547
+ padding-left: 5px;
548
+ font-size: 12px;
549
+ background: rgba(0, 0, 0, 0.8);
550
+ color: #ccc;
551
+ padding: 0 10px;
552
+ border-radius: 0 0 3px 0;
553
+ }
554
+
555
+ #cur_context_panel a {
556
+ float: none;
557
+ text-decoration: none;
558
+ }
559
+
560
+ #cur_context_panel a:hover {
561
+ text-decoration: underline;
562
+ }
563
+
564
+ #tools_top > div, #tools_top {
565
+ line-height: 26px;
566
+ }
567
+
568
+ div.toolset,
569
+ div.toolset > * {
570
+ float: left;
571
+ }
572
+
573
+ div.toolset {
574
+ height: 34px;
575
+ }
576
+
577
+ div.toolset label span {
578
+ /* outline: 1px solid red;*/
579
+ padding-top: 3px;
580
+ display: inline-block;
581
+ }
582
+
583
+ #tools_top > div > * {
584
+ float: left;
585
+ margin-right: 2px;
586
+ }
587
+
588
+ #tools_top label {
589
+ margin-top: 0;
590
+ margin-left: 5px;
591
+ }
592
+
593
+ #tools_top input {
594
+ margin-top: 5px;
595
+ height: 15px;
596
+ }
597
+
598
+ input[type=text] {
599
+ padding: 2px;
600
+ }
601
+
602
+ #tools_left .tool_button,
603
+ #tools_left .tool_button_current {
604
+ position: relative;
605
+ z-index: 11;
606
+ }
607
+
608
+ .flyout_arrow_horiz {
609
+ position: absolute;
610
+ bottom: -1px;
611
+ right: 0;
612
+ z-index: 10;
613
+ }
614
+
615
+
616
+ span.zoom_tool {
617
+ line-height: 26px;
618
+ padding: 3px;
619
+ }
620
+
621
+ #zoom_panel {
622
+ margin-top: 5px;
623
+ }
624
+
625
+ .dropdown {
626
+ position: relative;
627
+ }
628
+
629
+ .dropdown button {
630
+ width: 15px;
631
+ height: 21px;
632
+ margin: 6px 0 0 1px;
633
+ padding: 0;
634
+ border-left: 1px solid #FFFFFF;
635
+ border-top: 1px solid #FFFFFF;
636
+ border-right: 1px solid #808080;
637
+ border-bottom: 1px solid #808080;
638
+ background-color: #E8E8E8;
639
+ }
640
+
641
+ .dropdown button.down {
642
+ border-left: 1px solid #808080;
643
+ border-top: 1px solid #808080;
644
+ border-right: 1px solid #FFFFFF;
645
+ border-bottom: 1px solid #FFFFFF;
646
+ background-color: #B0B0B0;
647
+ }
648
+
649
+ .dropdown ul {
650
+ list-style: none;
651
+ position: absolute;
652
+ margin: 0;
653
+ padding: 0;
654
+ left: -85px;
655
+ top: 26px;
656
+ z-index: 4;
657
+ display: none;
658
+ }
659
+
660
+ .dropup ul {
661
+ top: auto;
662
+ bottom: 24px;
663
+ }
664
+
665
+ .dropdown li {
666
+ display: block;
667
+ width: 120px;
668
+ padding: 4px;
669
+ background: #E8E8E8;
670
+ border: 1px solid #B0B0B0;
671
+ margin: 0 0 -1px 0;
672
+ line-height: 16px;
673
+ }
674
+
675
+ .dropdown li:hover {
676
+ background-color: #FFC;
677
+ }
678
+
679
+ .dropdown li.special {
680
+ padding: 10px 4px;
681
+ }
682
+
683
+ .dropdown li.special:hover {
684
+ background: #FFC;
685
+ }
686
+
687
+ #font_family_dropdown-list li {
688
+ font-size: 1.4em;
689
+ }
690
+
691
+ #font_family {
692
+ margin-left: 5px;
693
+ margin-right: 0;
694
+ }
695
+
696
+
697
+ .tool_button,
698
+ .push_button,
699
+ .tool_button_current,
700
+ .push_button_pressed
701
+ {
702
+ height: 24px;
703
+ width: 24px;
704
+ margin: 2px 2px 4px 2px;
705
+ padding: 3px;
706
+ -webkit-box-shadow: inset 1px 1px 2px white, 1px 1px 1px rgba(0,0,0,0.3);
707
+ moz-box-shadow: inset 1px 1px 2px white, 1px 1px 1px rgba(0,0,0,0.3);
708
+ box-shadow: inset 1px 1px 2px white, 1px 1px 1px rgba(0,0,0,0.3);
709
+ background-color: #E8E8E8;
710
+ cursor: pointer;
711
+ border-radius: 3px;
712
+ -moz-border-radius: 3px;
713
+ -webkit-border-radius: 3px;
714
+ }
715
+
716
+ #main_menu li#tool_open, #main_menu li#tool_import {
717
+ position: relative;
718
+ overflow: hidden;
719
+ }
720
+
721
+ #tool_image {
722
+ overflow: hidden;
723
+ }
724
+
725
+ #tool_open input,
726
+ #tool_import input,
727
+ #tool_image input {
728
+ position: absolute;
729
+ opacity: 0;
730
+ font-size: 10em;
731
+ top: -5px;
732
+ right: -5px;
733
+ margin: 0;
734
+ cursor: pointer; /* Sadly doesn't appear to have an effect */
735
+ }
736
+
737
+ .disabled {
738
+ opacity: 0.5;
739
+ cursor: default;
740
+ }
741
+
742
+ .tool_sep {
743
+ width: 1px;
744
+ background: #888;
745
+ border-left: 1px outset #EEE;
746
+ margin: 2px 3px;
747
+ padding: 0;
748
+ height: 24px;
749
+
750
+ }
751
+
752
+ .icon_label {
753
+ float: left;
754
+ padding-top: 3px;
755
+ padding-right: 3px;
756
+ box-sizing: border-box;
757
+ -moz-box-sizing: border-box;
758
+ -webkit-box-sizing: border-box;
759
+ height: 0;
760
+ }
761
+
762
+ .width_label {
763
+ padding-right: 5px;
764
+ }
765
+
766
+ #tool_bold, #tool_italic {
767
+ font: bold 2.1em/1.1em serif;
768
+ text-align: center;
769
+ padding-left: 2px;
770
+ position: relative;
771
+ }
772
+
773
+ #text {
774
+ position: absolute;
775
+ left: -9999px;
776
+ }
777
+
778
+ #tool_bold span, #tool_italic span {
779
+ position: absolute;
780
+ width: 100%;
781
+ height: 100%;
782
+ top: 0; left: 0;
783
+ background: #000;
784
+ opacity: 0;
785
+ }
786
+
787
+ #tool_italic {
788
+ font-weight: normal;
789
+ font-style: italic;
790
+ }
791
+
792
+ #url_notice {
793
+ padding-top: 4px;
794
+ display: none;
795
+ }
796
+
797
+ #color_picker {
798
+ position: absolute;
799
+ display: none;
800
+ background: #E8E8E8;
801
+ height: 350px;
802
+ z-index: 5;
803
+ }
804
+
805
+ .tools_flyout {
806
+ position: absolute;
807
+ display: none;
808
+ cursor: pointer;
809
+ width: 400px;
810
+ z-index: 1;
811
+ }
812
+
813
+ .tools_flyout_v {
814
+ position: absolute;
815
+ display: none;
816
+ cursor: pointer;
817
+ width: 30px;
818
+ }
819
+
820
+ .tools_flyout .tool_button {
821
+ float: left;
822
+ background-color: #E8E8E8;
823
+ border-left: 1px solid #FFFFFF;
824
+ border-top: 1px solid #FFFFFF;
825
+ border-right: 1px solid #808080;
826
+ border-bottom: 1px solid #808080;
827
+ height: 28px;
828
+ width: 28px;
829
+ }
830
+
831
+ #tools_bottom {
832
+ position: absolute;
833
+ left: 40px;
834
+ right: 0;
835
+ bottom: 0;
836
+ height: 40px;
837
+ overflow: visible;
838
+ }
839
+
840
+ #tools_bottom_1 {
841
+ width: 115px;
842
+ float: left;
843
+ }
844
+
845
+ #tools_bottom input[type=text] {
846
+ width: 2.2em;
847
+ }
848
+
849
+ /* Color tools: fill, stroke, opacity
850
+ –––––––––––––––––––––––––––––––––––––*/
851
+
852
+ #tools_bottom_2 {
853
+ float: left;
854
+ width: 300px;
855
+ position: relative;
856
+ margin-top: 5px;
857
+ -webkit-transition: width 150ms ease;
858
+ }
859
+
860
+ .expanded #tools_bottom_2 {
861
+ width: 450px;
862
+ }
863
+
864
+ #tools_bottom #tools_bottom_2 .dropdown button {
865
+ margin-top: 2px;
866
+ }
867
+
868
+ .dropdown li.tool_button {
869
+ width: 24px;
870
+ }
871
+
872
+ #tools_bottom_2 .icon_label {
873
+ display: block;
874
+ margin: 3px 5px;
875
+ padding: 0;
876
+ }
877
+
878
+ #tool_opacity { right: 0;}
879
+ #tool_fill { left: 0; }
880
+ #tool_stroke { left: 60px;}
881
+
882
+ #fill_color, #stroke_color {
883
+ height: 16px;
884
+ width: 16px;
885
+ border: 1px solid #808080;
886
+ cursor: pointer;
887
+ overflow: hidden;
888
+ }
889
+
890
+ #stroke_expand {
891
+ width: 0;
892
+ overflow: hidden;
893
+ }
894
+
895
+ #toggle_stroke_tools {
896
+ position: absolute;
897
+ right: 0;
898
+ top: 0;
899
+ bottom: 0;
900
+ width: 25px;
901
+ text-align: center;
902
+ border-radius: 0 3px 3px 0;
903
+ margin: 0;
904
+ }
905
+
906
+ #toggle_stroke_tools:before {
907
+ content: '>>';
908
+ letter-spacing: -3px;
909
+ font-weight: bold;
910
+ color: #666;
911
+ }
912
+
913
+ .expanded #tool_stroke.color_tool {
914
+ width: 280px;
915
+ }
916
+
917
+ .expanded #toggle_stroke_tools:before {
918
+ content: '<<';
919
+ }
920
+
921
+ #toggle_stroke_tools:hover {
922
+ background: white;
923
+ }
924
+
925
+ .color_tool {
926
+ position: absolute;
927
+ overflow: hidden;
928
+ background: #f0f0f0;
929
+ height: 26px;
930
+ line-height: 26px;
931
+ border-radius: 3px;
932
+ min-width: 52px;
933
+ }
934
+
935
+ #tool_stroke.color_tool {
936
+ width: 130px;
937
+ z-index: 2;
938
+ -webkit-transition: width 150ms ease;
939
+ -moz-transition: width 150ms ease;
940
+ -o-transition: width 150ms ease;
941
+ -ms-transition: width 150ms ease;
942
+ transition: width 150ms ease;
943
+ }
944
+
945
+
946
+ .color_block {
947
+ position: absolute;
948
+ top: 0;
949
+ left: 0;
950
+ }
951
+
952
+ .color_block svg {
953
+ display: block;
954
+ }
955
+
956
+ .color_tool > * {
957
+ float: left;
958
+ margin-right: 5px;
959
+ }
960
+
961
+ .color_tool .dropdown > * {
962
+ float: left;
963
+ }
964
+
965
+ .color_tool .stroke_label {
966
+ margin-left: 25px;
967
+ float: left;
968
+ }
969
+
970
+ .color_tool > .color_block {
971
+ top: 3px;
972
+ left: 29px;
973
+ }
974
+
975
+ .color_tool input {
976
+ margin: 0;
977
+ }
978
+
979
+ #tool_opacity {
980
+ overflow: visible;
981
+ }
982
+
983
+ @media screen and (max-width:1250px) {
984
+ .expanded #palette_holder {
985
+ left: 560px;
986
+ overflow-x: scroll;
987
+ padding: 0 5px;
988
+ margin-top: 2px;
989
+ height: 30px;
990
+ }
991
+ #tools_top {
992
+ height: 71px;
993
+ }
994
+ #workarea, #sidepanels {
995
+ top: 70px;
996
+ }
997
+ #rulers #ruler_corner,
998
+ #rulers #ruler_x, #tools_left {
999
+ top: 71px;
1000
+ }
1001
+
1002
+ #rulers #ruler_y {
1003
+ top: 86px;
1004
+ }
1005
+
1006
+ #cur_context_panel {
1007
+ top: 87px;
1008
+ }
1009
+
1010
+ #selected_panel {
1011
+ clear: right;
1012
+ }
1013
+
1014
+ }
1015
+
1016
+ @media screen and (max-width:1100px) {
1017
+ #tools_bottom:not(.expanded) #palette_holder {
1018
+ left: 410px;
1019
+ overflow-x: scroll;
1020
+ padding: 0 5px;
1021
+ margin-top: 2px;
1022
+ height: 30px;
1023
+ }
1024
+ }
1025
+
1026
+
1027
+ /*–––––––––––––––––––––––––––––––––––––*/
1028
+
1029
+ #option_lists ul {
1030
+ display: none;
1031
+ position: absolute;
1032
+ height: auto;
1033
+ z-index: 3;
1034
+ margin: -10px;
1035
+ list-style: none;
1036
+ padding-left: 0;
1037
+ }
1038
+
1039
+ #option_lists .optcols2 {
1040
+ width: 70px;
1041
+ margin-left: -15px;
1042
+ }
1043
+
1044
+ #option_lists .optcols3 {
1045
+ width: 90px;
1046
+ margin-left: -31px;
1047
+ }
1048
+
1049
+ #option_lists .optcols4 {
1050
+ width: 130px;
1051
+ margin-left: -44px;
1052
+ }
1053
+
1054
+ #option_lists ul[class^=optcols] li {
1055
+ float: left;
1056
+ }
1057
+
1058
+ ul li.current {
1059
+ background-color: #F4E284;
1060
+ }
1061
+
1062
+ #option_lists ul li {
1063
+ margin: 0;
1064
+ border-radius: 0;
1065
+ -moz-border-radius: 0;
1066
+ -webkit-border-radius: 0;
1067
+ }
1068
+
1069
+ #tools_bottom .dropdown button {
1070
+ margin-top: 2px;
1071
+ }
1072
+
1073
+ #opacity_dropdown li {
1074
+ width: 140px;
1075
+ }
1076
+
1077
+ #copyright {
1078
+ text-align: right;
1079
+ padding-right: .3em;
1080
+ }
1081
+
1082
+ #svg_source_editor {
1083
+ display: none;
1084
+ }
1085
+
1086
+ #svg_source_editor #svg_source_overlay {
1087
+ position: absolute;
1088
+ top: 0px;
1089
+ right: 0px;
1090
+ left: 0px;
1091
+ bottom: 0px;
1092
+ background-color: black;
1093
+ opacity: 0.6;
1094
+ z-index: 5;
1095
+ }
1096
+
1097
+ #svg_source_editor #svg_source_container {
1098
+ position: absolute;
1099
+ top: 30px;
1100
+ left: 30px;
1101
+ right: 30px;
1102
+ bottom: 30px;
1103
+ background-color: #B0B0B0;
1104
+ opacity: 1.0;
1105
+ text-align: center;
1106
+ border: 1px outset #777;
1107
+ z-index: 6;
1108
+ }
1109
+
1110
+ #save_output_btns {
1111
+ display: none;
1112
+ text-align: left;
1113
+ }
1114
+
1115
+ #save_output_btns p {
1116
+ margin: .5em 1.5em;
1117
+ display: inline-block;
1118
+ }
1119
+
1120
+ #bg_blocks {
1121
+ overflow: auto;
1122
+ margin-left: 30px;
1123
+ }
1124
+
1125
+ #bg_blocks .color_block {
1126
+ position: static;
1127
+ }
1128
+
1129
+ #svg_docprops #svg_docprops_container,
1130
+ #svg_prefs #svg_prefs_container {
1131
+ position: absolute;
1132
+ top: 50px;
1133
+ padding: 10px;
1134
+ background-color: #B0B0B0;
1135
+ border: 1px outset #777;
1136
+ opacity: 1.0;
1137
+ /* width: 450px;*/
1138
+ font-family: Verdana, Helvetica, sans-serif;
1139
+ font-size: .8em;
1140
+ z-index: 20001;
1141
+ }
1142
+
1143
+ #svg_docprops .error {
1144
+ border: 1px solid red;
1145
+ padding: 3px;
1146
+ }
1147
+
1148
+ #svg_docprops #resolution {
1149
+ max-width: 14em;
1150
+ }
1151
+
1152
+ #tool_docprops_back,
1153
+ #tool_prefs_back {
1154
+ margin-left: 1em;
1155
+ overflow: auto;
1156
+ }
1157
+
1158
+ #svg_docprops_container #svg_docprops_docprops,
1159
+ #svg_prefs #svg_docprops_prefs {
1160
+ float: left;
1161
+ width: 221px;
1162
+ margin: 5px .7em;
1163
+ overflow: hidden;
1164
+ }
1165
+
1166
+ #svg_prefs_container fieldset + fieldset {
1167
+ float: right;
1168
+ }
1169
+
1170
+ #svg_docprops legend,
1171
+ #svg_prefs legend {
1172
+ max-width: 195px;
1173
+ }
1174
+
1175
+ #svg_docprops_docprops > legend,
1176
+ #svg_prefs_container > fieldset > legend {
1177
+ font-weight: bold;
1178
+ font-size: 1.1em;
1179
+ }
1180
+
1181
+
1182
+ #svg_docprops_container fieldset,
1183
+ #svg_prefs fieldset {
1184
+ padding: 5px;
1185
+ margin: 5px;
1186
+ border: 1px solid #DDD;
1187
+ }
1188
+
1189
+ #svg_docprops_container label,
1190
+ #svg_prefs_container label {
1191
+ display: block;
1192
+ margin: .5em;
1193
+ }
1194
+
1195
+ #svginfo_bg_note {
1196
+ font-size: .9em;
1197
+ font-style: italic;
1198
+ color: #444;
1199
+ }
1200
+
1201
+ #canvas_title, #canvas_bg_url {
1202
+ display: block;
1203
+ width: 96%;
1204
+ }
1205
+
1206
+ #svg_source_editor #svg_source_textarea {
1207
+ position: relative;
1208
+ width: 95%;
1209
+ top: 5px;
1210
+ height: 250px;
1211
+ padding: 5px;
1212
+ font-size: 12px;
1213
+ }
1214
+
1215
+ #svg_source_editor #tool_source_back {
1216
+ text-align: left;
1217
+ padding-left: 20px;
1218
+ }
1219
+
1220
+ #svg_prefs_container div.color_block {
1221
+ float: left;
1222
+ margin: 2px;
1223
+ padding: 20px;
1224
+ }
1225
+
1226
+ #change_background div.cur_background {
1227
+ border: 2px solid blue;
1228
+ padding: 18px;
1229
+ }
1230
+
1231
+ #background_img {
1232
+ position: absolute;
1233
+ top: 0;
1234
+ left: 0;
1235
+ text-align: left;
1236
+ }
1237
+
1238
+ #svg_docprops button,
1239
+ #svg_prefs button {
1240
+ margin-top: 0;
1241
+ margin-bottom: 5px;
1242
+ }
1243
+
1244
+ #svg_docprops,
1245
+ #svg_prefs {
1246
+ display: none;
1247
+ }
1248
+
1249
+ #image_save_opts label {
1250
+ font-size: .9em;
1251
+ }
1252
+
1253
+ #image_save_opts input {
1254
+ margin-left: 0;
1255
+ }
1256
+
1257
+ #svg_docprops #svg_docprops_overlay,
1258
+ #svg_prefs #svg_prefs_overlay {
1259
+ position: absolute;
1260
+ top: 0px;
1261
+ right: 0px;
1262
+ left: 0px;
1263
+ bottom: 0px;
1264
+ background-color: black;
1265
+ opacity: 0.6;
1266
+ z-index: 20000;
1267
+ }
1268
+
1269
+ #tool_prefs_option {
1270
+ float: right;
1271
+ }
1272
+
1273
+ .toolbar_button button {
1274
+ border:1px solid #dedede;
1275
+ line-height:130%;
1276
+ float: left;
1277
+ background: #E8E8E8 none;
1278
+ padding:5px 10px 5px 7px; /* Firefox */
1279
+ line-height:17px; /* Safari */
1280
+ margin: 5px 20px 0 0;
1281
+
1282
+ border: 1px #808080 solid;
1283
+ border-top-color: #FFF;
1284
+ border-left-color: #FFF;
1285
+
1286
+ border-radius: 5px;
1287
+ -moz-border-radius: 5px;
1288
+ -webkit-border-radius: 5px;
1289
+ }
1290
+
1291
+ .toolbar_button button:hover {
1292
+ border: 1px #e0a874 solid;
1293
+ border-top-color: #fcd9ba;
1294
+ border-left-color: #fcd9ba;
1295
+ background-color: #FFC;
1296
+ }
1297
+ .toolbar_button button:active {
1298
+ background-color: #F4E284;
1299
+ border-left: 1px solid #663300;
1300
+ border-top: 1px solid #663300;
1301
+ }
1302
+
1303
+ .toolbar_button button .svg_icon {
1304
+ margin:0 3px -3px 0 !important;
1305
+ padding:0;
1306
+ border:none;
1307
+ width:16px;
1308
+ height:16px;
1309
+ }
1310
+
1311
+ #dialog_box {
1312
+ display: none;
1313
+ }
1314
+
1315
+ #dialog_box_overlay {
1316
+ background: black;
1317
+ opacity: .5;
1318
+ height:100%;
1319
+ left:0;
1320
+ position:absolute;
1321
+ top:0;
1322
+ width:100%;
1323
+ z-index: 6;
1324
+ }
1325
+
1326
+ #dialog_content {
1327
+ height: 95px;
1328
+ margin: 10px 10px 5px 10px;
1329
+ background: #DDD;
1330
+ overflow: auto;
1331
+ text-align: left;
1332
+ border: 1px solid #B0B0B0;
1333
+ }
1334
+
1335
+ #dialog_content.prompt {
1336
+ height: 75px;
1337
+ }
1338
+
1339
+ #dialog_content p {
1340
+ margin: 10px;
1341
+ line-height: 1.3em;
1342
+ }
1343
+
1344
+ #dialog_container {
1345
+ position: absolute;
1346
+ font-family: Verdana;
1347
+ text-align: center;
1348
+ left: 50%;
1349
+ top: 50%;
1350
+ width: 300px;
1351
+ margin-left: -150px;
1352
+ height: 150px;
1353
+ margin-top: -80px;
1354
+ position:fixed;
1355
+ z-index:50001;
1356
+ background: #CCC;
1357
+ border: 1px outset #777;
1358
+ font-family:Verdana,Helvetica,sans-serif;
1359
+ font-size:0.8em;
1360
+ }
1361
+
1362
+ #dialog_container, #dialog_content {
1363
+ border-radius: 5px;
1364
+ -moz-border-radius: 5px;
1365
+ -webkit-border-radius: 5px;
1366
+ }
1367
+
1368
+ #dialog_buttons input[type=text] {
1369
+ width: 90%;
1370
+ display: block;
1371
+ margin: 0 0 5px 11px;
1372
+ }
1373
+
1374
+ #dialog_buttons input[type=button] {
1375
+ margin: 0 1em;
1376
+ }
1377
+
1378
+
1379
+ /* Slider
1380
+ ----------------------------------*/
1381
+ .ui-slider { position: relative; text-align: left; }
1382
+ .ui-slider .ui-slider-handle { position: absolute; z-index: 2; width: 1.2em; height: 1.2em; cursor: default; }
1383
+ .ui-slider .ui-slider-range { position: absolute; z-index: 1; font-size: .7em; display: block; border: 0; }
1384
+
1385
+ .ui-slider-horizontal { height: .8em; }
1386
+ .ui-slider-horizontal .ui-slider-handle { top: -.3em; margin-left: -.6em; }
1387
+ .ui-slider-horizontal .ui-slider-range { top: 0; height: 100%; }
1388
+ .ui-slider-horizontal .ui-slider-range-min { left: 0; }
1389
+ .ui-slider-horizontal .ui-slider-range-max { right: 0; }
1390
+
1391
+ .ui-slider-vertical { width: .8em; height: 100px; }
1392
+ .ui-slider-vertical .ui-slider-handle { left: -.3em; margin-left: 0; margin-bottom: -.6em; }
1393
+ .ui-slider-vertical .ui-slider-range { left: 0; width: 100%; }
1394
+ .ui-slider-vertical .ui-slider-range-min { bottom: 0; }
1395
+ .ui-slider-vertical .ui-slider-range-max { top: 0; }
1396
+
1397
+ .ui-slider {
1398
+ border: 1px solid #B0B0B0;
1399
+ }
1400
+
1401
+ .ui-slider-handle {
1402
+ background: #B0B0B0;
1403
+ border: 1px solid #000;
1404
+ }
1405
+
1406
+ /* Necessary to keep the flyouts sized properly */
1407
+ .tools_flyout .tool_button,
1408
+ .tools_flyout .tool_flyout {
1409
+ padding: 2px;
1410
+ width: 24px;
1411
+ height: 24px;
1412
+ margin: 0;
1413
+ border-radius: 0px;
1414
+ -moz-border-radius: 0px;
1415
+ -webkit-border-radius: 0px;
1416
+ }
1417
+
1418
+ /* Generic context menu styles */
1419
+ .contextMenu {
1420
+ position: absolute;
1421
+ z-index: 99999;
1422
+ border: solid 1px rgba(0,0,0,.33);
1423
+ background: rgba(255,255,255,.95);
1424
+ padding: 5px 0;
1425
+ margin: 0px;
1426
+ display: none;
1427
+ font: 12px/15px Lucida Sans, Helvetica, Verdana, sans-serif;
1428
+ border-radius: 5px;
1429
+ -moz-border-radius: 5px;
1430
+ -moz-box-shadow: 2px 5px 10px rgba(0,0,0,.3);
1431
+ -webkit-box-shadow: 2px 5px 10px rgba(0,0,0,.3);
1432
+ box-shadow: 2px 5px 10px rgba(0,0,0,.3);
1433
+ }
1434
+
1435
+ .contextMenu LI {
1436
+ list-style: none;
1437
+ padding: 0px;
1438
+ margin: 0px;
1439
+ }
1440
+
1441
+ .contextMenu .shortcut {
1442
+ width: 115px;
1443
+ text-align:right;
1444
+ float:right;
1445
+ }
1446
+
1447
+ .contextMenu A {
1448
+ -moz-user-select: none;
1449
+ -webkit-user-select: none;
1450
+ color: #222;
1451
+ text-decoration: none;
1452
+ display: block;
1453
+ line-height: 20px;
1454
+ height: 20px;
1455
+ background-position: 6px center;
1456
+ background-repeat: no-repeat;
1457
+ outline: none;
1458
+ padding: 0px 15px 1px 20px;
1459
+ }
1460
+
1461
+ .contextMenu LI.hover A {
1462
+ background-color: #2e5dea;
1463
+ color: white;
1464
+ cursor: default;
1465
+ }
1466
+
1467
+ .contextMenu LI.disabled A {
1468
+ color: #999;
1469
+ }
1470
+
1471
+ .contextMenu LI.hover.disabled A {
1472
+ background-color: transparent;
1473
+ }
1474
+
1475
+ .contextMenu LI.separator {
1476
+ border-top: solid 1px #E3E3E3;
1477
+ padding-top: 5px;
1478
+ margin-top: 5px;
1479
+ }
1480
+
1481
+ /*
1482
+ Adding Icons
1483
+
1484
+ You can add icons to the context menu by adding
1485
+ classes to the respective LI element(s)
1486
+ */
1487
+ /*
1488
+
1489
+ .contextMenu LI.edit A { background-image: url(images/page_white_edit.png); }
1490
+ .contextMenu LI.cut A { background-image: url(images/cut.png); }
1491
+ .contextMenu LI.copy A { background-image: url(images/page_white_copy.png); }
1492
+ .contextMenu LI.paste A { background-image: url(images/page_white_paste.png); }
1493
+ .contextMenu LI.delete A { background-image: url(images/page_white_delete.png); }
1494
+ .contextMenu LI.quit A { background-image: url(images/door.png); }
1495
+ */