masterDicefile.svg 47 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901
  1. <?xml version="1.0" encoding="UTF-8" standalone="no"?>
  2. <svg
  3. xmlns:osb="http://www.openswatchbook.org/uri/2009/osb"
  4. xmlns:dc="http://purl.org/dc/elements/1.1/"
  5. xmlns:cc="http://creativecommons.org/ns#"
  6. xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
  7. xmlns:svg="http://www.w3.org/2000/svg"
  8. xmlns="http://www.w3.org/2000/svg"
  9. xmlns:xlink="http://www.w3.org/1999/xlink"
  10. xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
  11. xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
  12. width="2in"
  13. height="2in"
  14. viewBox="0 0 50.800001 50.800001"
  15. version="1.1"
  16. id="svg8"
  17. inkscape:version="1.0.1 (3bc2e813f5, 2020-09-07)"
  18. sodipodi:docname="masterDicefile.svg"
  19. inkscape:export-filename="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\sectionDecoration\purple2.png"
  20. inkscape:export-xdpi="96"
  21. inkscape:export-ydpi="96">
  22. <defs
  23. id="defs2">
  24. <linearGradient
  25. inkscape:collect="always"
  26. id="linearGradient2982">
  27. <stop
  28. style="stop-color:#000000;stop-opacity:0;"
  29. offset="0"
  30. id="stop2980" />
  31. <stop
  32. style="stop-color:#000000;stop-opacity:0.08"
  33. offset="1"
  34. id="stop2978" />
  35. </linearGradient>
  36. <inkscape:path-effect
  37. effect="powerclip"
  38. id="path-effect3502"
  39. is_visible="true"
  40. lpeversion="1"
  41. inverse="true"
  42. flatten="false"
  43. hide_clip="false"
  44. message="Use fill-rule evenodd on &lt;b&gt;fill and stroke&lt;/b&gt; dialog if no flatten result after convert clip to paths." />
  45. <inkscape:path-effect
  46. effect="powerclip"
  47. id="path-effect3475"
  48. is_visible="true"
  49. lpeversion="1"
  50. inverse="true"
  51. flatten="false"
  52. hide_clip="false"
  53. message="Use fill-rule evenodd on &lt;b&gt;fill and stroke&lt;/b&gt; dialog if no flatten result after convert clip to paths." />
  54. <linearGradient
  55. id="linearGradient2854"
  56. osb:paint="solid">
  57. <stop
  58. style="stop-color:#000000;stop-opacity:1;"
  59. offset="0"
  60. id="stop2852" />
  61. </linearGradient>
  62. <clipPath
  63. clipPathUnits="userSpaceOnUse"
  64. id="clipPath498">
  65. <rect
  66. style="display:inline;fill:#ff00ff;fill-opacity:1;stroke:url(#meshgradient502);stroke-width:0.983898;stroke-opacity:1"
  67. id="rect500"
  68. width="24.416101"
  69. height="24.4161"
  70. x="-11.224152"
  71. y="37.608047"
  72. ry="5.8395634"
  73. rx="5.4162478" />
  74. </clipPath>
  75. <meshgradient
  76. inkscape:collect="always"
  77. id="meshgradient502"
  78. gradientUnits="userSpaceOnUse"
  79. gradientTransform="matrix(0.35562199,0,0,0.35562199,-1.4643916,38.592265)"
  80. x="1.4901161e-08"
  81. y="1.4901161e-08">
  82. <meshrow
  83. id="meshrow514">
  84. <meshpatch
  85. id="meshpatch512">
  86. <stop
  87. path="c 1.66667,0 3.33333,0 5,0"
  88. style="stop-color:#ffffff;stop-opacity:1"
  89. id="stop504" />
  90. <stop
  91. path="c 0,1.66667 0,3.33333 0,5"
  92. style="stop-color:#800080;stop-opacity:1"
  93. id="stop506" />
  94. <stop
  95. path="c -1.66667,0 -3.33333,0 -5,0"
  96. style="stop-color:#ffffff;stop-opacity:1"
  97. id="stop508" />
  98. <stop
  99. path="c 0,-1.66667 0,-3.33333 0,-5"
  100. style="stop-color:#800080;stop-opacity:1"
  101. id="stop510" />
  102. </meshpatch>
  103. </meshrow>
  104. </meshgradient>
  105. <clipPath
  106. clipPathUnits="userSpaceOnUse"
  107. id="clipPath516">
  108. <rect
  109. style="display:inline;fill:#ff00ff;fill-opacity:1;stroke:url(#meshgradient520);stroke-width:0.983898;stroke-opacity:1"
  110. id="rect518"
  111. width="24.416101"
  112. height="24.4161"
  113. x="61.875282"
  114. y="23.888676"
  115. ry="5.8395634"
  116. rx="5.4162478" />
  117. </clipPath>
  118. <meshgradient
  119. inkscape:collect="always"
  120. id="meshgradient520"
  121. gradientUnits="userSpaceOnUse"
  122. gradientTransform="matrix(0.35562199,0,0,0.35562199,71.635041,24.872891)"
  123. x="1.4901161e-08"
  124. y="1.4901161e-08">
  125. <meshrow
  126. id="meshrow532">
  127. <meshpatch
  128. id="meshpatch530">
  129. <stop
  130. path="c 1.66667,0 3.33333,0 5,0"
  131. style="stop-color:#ffffff;stop-opacity:1"
  132. id="stop522" />
  133. <stop
  134. path="c 0,1.66667 0,3.33333 0,5"
  135. style="stop-color:#800080;stop-opacity:1"
  136. id="stop524" />
  137. <stop
  138. path="c -1.66667,0 -3.33333,0 -5,0"
  139. style="stop-color:#ffffff;stop-opacity:1"
  140. id="stop526" />
  141. <stop
  142. path="c 0,-1.66667 0,-3.33333 0,-5"
  143. style="stop-color:#800080;stop-opacity:1"
  144. id="stop528" />
  145. </meshpatch>
  146. </meshrow>
  147. </meshgradient>
  148. <clipPath
  149. clipPathUnits="userSpaceOnUse"
  150. id="clipPath534">
  151. <rect
  152. style="display:inline;fill:#ff00ff;fill-opacity:1;stroke:url(#meshgradient538);stroke-width:0.983898;stroke-opacity:1"
  153. id="rect536"
  154. width="24.416101"
  155. height="24.4161"
  156. x="56.016651"
  157. y="-25.531712"
  158. ry="5.8395634"
  159. rx="5.4162478" />
  160. </clipPath>
  161. <meshgradient
  162. inkscape:collect="always"
  163. id="meshgradient538"
  164. gradientUnits="userSpaceOnUse"
  165. gradientTransform="matrix(0.35562199,0,0,0.35562199,59.000991,-31.047899)"
  166. x="1.4901161e-08"
  167. y="1.4901161e-08">
  168. <meshrow
  169. id="meshrow550">
  170. <meshpatch
  171. id="meshpatch548">
  172. <stop
  173. path="c 1.66667,0 3.33333,0 5,0"
  174. style="stop-color:#ffffff;stop-opacity:1"
  175. id="stop540" />
  176. <stop
  177. path="c 0,1.66667 0,3.33333 0,5"
  178. style="stop-color:#800080;stop-opacity:1"
  179. id="stop542" />
  180. <stop
  181. path="c -1.66667,0 -3.33333,0 -5,0"
  182. style="stop-color:#ffffff;stop-opacity:1"
  183. id="stop544" />
  184. <stop
  185. path="c 0,-1.66667 0,-3.33333 0,-5"
  186. style="stop-color:#800080;stop-opacity:1"
  187. id="stop546" />
  188. </meshpatch>
  189. </meshrow>
  190. </meshgradient>
  191. <clipPath
  192. clipPathUnits="userSpaceOnUse"
  193. id="clipPath608">
  194. <rect
  195. style="display:inline;fill:#ff00ff;fill-opacity:1;stroke:url(#meshgradient612);stroke-width:0.983898;stroke-opacity:1"
  196. id="rect610"
  197. width="24.416101"
  198. height="24.4161"
  199. x="-26.760134"
  200. y="-21.751949"
  201. ry="5.8395634"
  202. rx="5.4162478" />
  203. </clipPath>
  204. <meshgradient
  205. inkscape:collect="always"
  206. id="meshgradient612"
  207. gradientUnits="userSpaceOnUse"
  208. gradientTransform="matrix(0.35562199,0,0,0.35562199,-23.775796,-27.268138)"
  209. x="1.4901161e-08"
  210. y="1.4901161e-08">
  211. <meshrow
  212. id="meshrow624">
  213. <meshpatch
  214. id="meshpatch622">
  215. <stop
  216. path="c 1.66667,0 3.33333,0 5,0"
  217. style="stop-color:#ffffff;stop-opacity:1"
  218. id="stop614" />
  219. <stop
  220. path="c 0,1.66667 0,3.33333 0,5"
  221. style="stop-color:#800080;stop-opacity:1"
  222. id="stop616" />
  223. <stop
  224. path="c -1.66667,0 -3.33333,0 -5,0"
  225. style="stop-color:#ffffff;stop-opacity:1"
  226. id="stop618" />
  227. <stop
  228. path="c 0,-1.66667 0,-3.33333 0,-5"
  229. style="stop-color:#800080;stop-opacity:1"
  230. id="stop620" />
  231. </meshpatch>
  232. </meshrow>
  233. </meshgradient>
  234. <clipPath
  235. clipPathUnits="userSpaceOnUse"
  236. id="clipPath1574">
  237. <rect
  238. style="display:inline;fill:#ff00ff;fill-opacity:1;stroke:url(#meshgradient1578);stroke-width:0.983898;stroke-opacity:1"
  239. id="rect1576"
  240. width="24.416101"
  241. height="24.4161"
  242. x="-5.1922026"
  243. y="-13.970746"
  244. ry="5.8395634"
  245. rx="5.4162478" />
  246. </clipPath>
  247. <meshgradient
  248. inkscape:collect="always"
  249. id="meshgradient1578"
  250. gradientUnits="userSpaceOnUse"
  251. gradientTransform="matrix(0.35562199,0,0,0.35562199,4.5675563,-12.986531)"
  252. x="1.4901161e-08"
  253. y="1.4901161e-08">
  254. <meshrow
  255. id="meshrow1590">
  256. <meshpatch
  257. id="meshpatch1588">
  258. <stop
  259. path="c 1.66667,0 3.33333,0 5,0"
  260. style="stop-color:#ffffff;stop-opacity:1"
  261. id="stop1580" />
  262. <stop
  263. path="c 0,1.66667 0,3.33333 0,5"
  264. style="stop-color:#800080;stop-opacity:1"
  265. id="stop1582" />
  266. <stop
  267. path="c -1.66667,0 -3.33333,0 -5,0"
  268. style="stop-color:#ffffff;stop-opacity:1"
  269. id="stop1584" />
  270. <stop
  271. path="c 0,-1.66667 0,-3.33333 0,-5"
  272. style="stop-color:#800080;stop-opacity:1"
  273. id="stop1586" />
  274. </meshpatch>
  275. </meshrow>
  276. </meshgradient>
  277. <mask
  278. maskUnits="userSpaceOnUse"
  279. id="mask1087">
  280. <rect
  281. style="fill:url(#meshgradient1091);fill-opacity:1;stroke:#000000;stroke-width:0.984001;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
  282. id="rect1089"
  283. width="24.416101"
  284. height="24.416098"
  285. x="11.721966"
  286. y="14.661929"
  287. ry="5.8395634"
  288. rx="5.4162478" />
  289. </mask>
  290. <meshgradient
  291. inkscape:collect="always"
  292. id="meshgradient1091"
  293. gradientUnits="userSpaceOnUse"
  294. x="13.19195"
  295. y="13.19195"
  296. gradientTransform="translate(-1.4699821,1.4699817)">
  297. <meshrow
  298. id="meshrow1103">
  299. <meshpatch
  300. id="meshpatch1101">
  301. <stop
  302. path="c 8.1387,0 0,24.4161 24.4161,0"
  303. style="stop-color:#ffffff;stop-opacity:1"
  304. id="stop1093" />
  305. <stop
  306. path="c 0,8.1387 0,16.2774 0,24.4161"
  307. style="stop-color:#800080;stop-opacity:1"
  308. id="stop1095" />
  309. <stop
  310. path="c -8.1387,0 -17.5469,-7.88445 -24.4161,0"
  311. style="stop-color:#ffffff;stop-opacity:1"
  312. id="stop1097" />
  313. <stop
  314. path="c 0,-8.1387 0,-16.2774 0,-24.4161"
  315. style="stop-color:#800080;stop-opacity:1"
  316. id="stop1099" />
  317. </meshpatch>
  318. </meshrow>
  319. </meshgradient>
  320. <mask
  321. maskUnits="userSpaceOnUse"
  322. id="mask3353">
  323. <rect
  324. style="display:inline;opacity:1;fill:none;fill-opacity:1;stroke:url(#meshgradient3357);stroke-width:1.01622;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
  325. id="rect3355"
  326. width="25.151323"
  327. height="25.280172"
  328. x="16.332344"
  329. y="13.731041"
  330. ry="6.0462227"
  331. rx="5.5793428" />
  332. </mask>
  333. <meshgradient
  334. inkscape:collect="always"
  335. id="meshgradient3357"
  336. gradientUnits="userSpaceOnUse"
  337. gradientTransform="matrix(1.0301122,0,0,1.0353895,3.6001566,-1.085878)"
  338. x="11.859336"
  339. y="13.818479">
  340. <meshrow
  341. id="meshrow3369">
  342. <meshpatch
  343. id="meshpatch3367">
  344. <stop
  345. path="c 8.4667,0 16.9334,0 25.4001,0"
  346. style="stop-color:#ffffff;stop-opacity:1"
  347. id="stop3359" />
  348. <stop
  349. path="c 0,8.4667 0,16.9334 0,25.4001"
  350. style="stop-color:#000000;stop-opacity:1"
  351. id="stop3361" />
  352. <stop
  353. path="c -8.4667,0 -16.9334,0 -25.4001,0"
  354. style="stop-color:#ffffff;stop-opacity:1"
  355. id="stop3363" />
  356. <stop
  357. path="c 0,-8.4667 0,-16.9334 0,-25.4001"
  358. style="stop-color:#000000;stop-opacity:1"
  359. id="stop3365" />
  360. </meshpatch>
  361. </meshrow>
  362. </meshgradient>
  363. <clipPath
  364. clipPathUnits="userSpaceOnUse"
  365. id="clipPath1574-0">
  366. <rect
  367. style="display:inline;fill:#ff00ff;fill-opacity:1;stroke:url(#meshgradient1578);stroke-width:0.983898;stroke-opacity:1"
  368. id="rect1576-4"
  369. width="24.416101"
  370. height="24.4161"
  371. x="-5.1922026"
  372. y="-13.970746"
  373. ry="5.8395634"
  374. rx="5.4162478" />
  375. </clipPath>
  376. <clipPath
  377. clipPathUnits="userSpaceOnUse"
  378. id="clipPath3498">
  379. <rect
  380. style="display:none;opacity:1;fill:#ff00ff;fill-opacity:1;stroke:none;stroke-width:0.892352;stroke-opacity:1"
  381. id="rect3500"
  382. width="22.14431"
  383. height="22.144308"
  384. x="14.327896"
  385. y="14.327896"
  386. ry="5.2962222"
  387. rx="4.9122944"
  388. d="m 19.240191,14.327896 h 12.319721 c 2.721411,0 4.912294,2.362115 4.912294,5.296222 v 11.551864 c 0,2.934107 -2.190883,5.296222 -4.912294,5.296222 H 19.240191 c -2.721412,0 -4.912295,-2.362115 -4.912295,-5.296222 V 19.624118 c 0,-2.934107 2.190883,-5.296222 4.912295,-5.296222 z" />
  389. <path
  390. id="lpe_path-effect3502"
  391. style="display:block;opacity:1;fill:#ff00ff;fill-opacity:1;stroke:none;stroke-width:0.892352;stroke-opacity:1"
  392. class="powerclip"
  393. d="M 8.1920004,8.1920004 H 42.608102 V 42.6081 H 8.1920004 Z M 19.240191,14.327896 c -2.721412,0 -4.912295,2.362115 -4.912295,5.296222 v 11.551864 c 0,2.934107 2.190883,5.296222 4.912295,5.296222 h 12.319721 c 2.721411,0 4.912294,-2.362115 4.912294,-5.296222 V 19.624118 c 0,-2.934107 -2.190883,-5.296222 -4.912294,-5.296222 z" />
  394. </clipPath>
  395. <mask
  396. maskUnits="userSpaceOnUse"
  397. id="mask3616">
  398. <g
  399. id="g3620">
  400. <path
  401. style="display:inline;fill:url(#meshgradient3622);fill-opacity:1;stroke:none;stroke-width:0.983898;stroke-opacity:1"
  402. id="path3618"
  403. width="24.416101"
  404. height="24.4161"
  405. x="13.192"
  406. y="13.192"
  407. ry="5.8395634"
  408. rx="5.4162478"
  409. clip-path="url(#clipPath3498)"
  410. sodipodi:type="rect"
  411. inkscape:path-effect="#path-effect3502"
  412. d="m 18.608248,13.192 h 13.583606 c 3.000601,0 5.416248,2.604446 5.416248,5.839564 v 12.736973 c 0,3.235118 -2.415647,5.839563 -5.416248,5.839563 H 18.608248 C 15.607647,37.6081 13.192,35.003655 13.192,31.768537 V 19.031564 c 0,-3.235118 2.415647,-5.839564 5.416248,-5.839564 z" />
  413. </g>
  414. </mask>
  415. <meshgradient
  416. inkscape:collect="always"
  417. id="meshgradient3622"
  418. gradientUnits="userSpaceOnUse"
  419. x="13.192"
  420. y="13.192">
  421. <meshrow
  422. id="meshrow3634">
  423. <meshpatch
  424. id="meshpatch3632">
  425. <stop
  426. path="c 8.1387,0 16.2774,0 24.4161,0"
  427. style="stop-color:#ffffff;stop-opacity:1"
  428. id="stop3624" />
  429. <stop
  430. path="c 0,8.1387 0,16.2774 0,24.4161"
  431. style="stop-color:#000000;stop-opacity:1"
  432. id="stop3626" />
  433. <stop
  434. path="c -8.1387,0 -16.2774,0 -24.4161,0"
  435. style="stop-color:#ffffff;stop-opacity:1"
  436. id="stop3628" />
  437. <stop
  438. path="c 0,-8.1387 0,-16.2774 0,-24.4161"
  439. style="stop-color:#000000;stop-opacity:1"
  440. id="stop3630" />
  441. </meshpatch>
  442. </meshrow>
  443. </meshgradient>
  444. <clipPath
  445. clipPathUnits="userSpaceOnUse"
  446. id="clipPath3647">
  447. <rect
  448. style="display:inline;fill:#ff00ff;fill-opacity:1;stroke:none;stroke-width:0.983898;stroke-opacity:1"
  449. id="rect3649"
  450. width="24.416101"
  451. height="24.4161"
  452. x="7.9192328"
  453. y="-24.208742"
  454. ry="5.8395634"
  455. rx="5.4162478" />
  456. </clipPath>
  457. <radialGradient
  458. inkscape:collect="always"
  459. xlink:href="#linearGradient2982"
  460. id="radialGradient2986"
  461. cx="59.436756"
  462. cy="-3.8742561"
  463. fx="59.436756"
  464. fy="-3.8742561"
  465. r="12.208051"
  466. gradientUnits="userSpaceOnUse"
  467. gradientTransform="matrix(1.8695567,0,-1.0027013e-8,2.0211777,-85.732329,33.242512)" />
  468. </defs>
  469. <sodipodi:namedview
  470. id="base"
  471. pagecolor="#ffffff"
  472. bordercolor="#666666"
  473. borderopacity="1.0"
  474. inkscape:pageopacity="0.0"
  475. inkscape:pageshadow="2"
  476. inkscape:zoom="3.1653504"
  477. inkscape:cx="14.239449"
  478. inkscape:cy="63.873616"
  479. inkscape:document-units="mm"
  480. inkscape:current-layer="layer20"
  481. inkscape:document-rotation="0"
  482. showgrid="false"
  483. inkscape:pagecheckerboard="true"
  484. inkscape:window-width="1920"
  485. inkscape:window-height="1017"
  486. inkscape:window-x="-8"
  487. inkscape:window-y="-8"
  488. inkscape:window-maximized="1"
  489. units="in" />
  490. <metadata
  491. id="metadata5">
  492. <rdf:RDF>
  493. <cc:Work
  494. rdf:about="">
  495. <dc:format>image/svg+xml</dc:format>
  496. <dc:type
  497. rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
  498. <dc:title />
  499. </cc:Work>
  500. </rdf:RDF>
  501. </metadata>
  502. <g
  503. inkscape:groupmode="layer"
  504. id="layer12"
  505. inkscape:label="color"
  506. style="display:inline"
  507. sodipodi:insensitive="true">
  508. <g
  509. inkscape:groupmode="layer"
  510. id="layer13"
  511. inkscape:label="white"
  512. style="display:none"
  513. sodipodi:insensitive="true">
  514. <g
  515. inkscape:groupmode="layer"
  516. id="layer19"
  517. inkscape:label="backgroundwhite"
  518. sodipodi:insensitive="true"
  519. style="display:none">
  520. <rect
  521. style="display:inline;opacity:1;fill:#ffffff;fill-opacity:1;stroke-width:1;stroke-miterlimit:4;stroke-dasharray:none"
  522. id="rect7-7-7-6"
  523. width="24.416101"
  524. height="24.4161"
  525. x="13.203896"
  526. y="13.203902"
  527. ry="5.8395634"
  528. rx="5.4162478" />
  529. </g>
  530. <g
  531. inkscape:groupmode="layer"
  532. id="layer20"
  533. inkscape:label="tint"
  534. sodipodi:insensitive="true"
  535. style="display:none">
  536. <rect
  537. style="display:inline;opacity:1;fill:url(#radialGradient2986);fill-opacity:1;stroke-width:1;stroke-miterlimit:4;stroke-dasharray:none"
  538. id="rect7-7-7"
  539. width="24.416101"
  540. height="24.4161"
  541. x="13.18"
  542. y="13.203902"
  543. ry="5.8395634"
  544. rx="5.4162478" />
  545. </g>
  546. </g>
  547. <g
  548. inkscape:groupmode="layer"
  549. id="layer14"
  550. inkscape:label="red"
  551. style="display:none"
  552. sodipodi:insensitive="true">
  553. <image
  554. sodipodi:absref="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\colorScapes\red.svg"
  555. xlink:href="../colorScapes/red.svg"
  556. preserveAspectRatio="none"
  557. inkscape:svg-dpi="96"
  558. width="159.99989"
  559. height="89.999878"
  560. id="image580"
  561. x="-37.855602"
  562. y="-44.055"
  563. clip-path="url(#clipPath608)"
  564. transform="translate(39.952084,34.943897)" />
  565. </g>
  566. <g
  567. inkscape:groupmode="layer"
  568. id="layer15"
  569. inkscape:label="yellow"
  570. style="display:none"
  571. sodipodi:insensitive="true">
  572. <image
  573. sodipodi:absref="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\colorScapes\yellow.svg"
  574. xlink:href="../colorScapes/yellow.svg"
  575. preserveAspectRatio="none"
  576. inkscape:svg-dpi="96"
  577. width="159.99989"
  578. height="89.999878"
  579. id="image352"
  580. x="-48.81691"
  581. y="-53.126427"
  582. clip-path="url(#clipPath534)"
  583. transform="translate(-42.824703,38.72366)" />
  584. </g>
  585. <g
  586. inkscape:groupmode="layer"
  587. id="g121"
  588. inkscape:label="blue"
  589. style="display:none"
  590. sodipodi:insensitive="true">
  591. <image
  592. sodipodi:absref="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\colorScapes\blue.svg"
  593. xlink:href="../colorScapes/blue.svg"
  594. preserveAspectRatio="none"
  595. inkscape:svg-dpi="96"
  596. width="159.99989"
  597. height="89.999878"
  598. id="image402"
  599. x="-33.036404"
  600. y="-38.574345"
  601. clip-path="url(#clipPath516)"
  602. transform="translate(-48.683332,-10.696726)" />
  603. </g>
  604. <g
  605. inkscape:groupmode="layer"
  606. id="g123"
  607. inkscape:label="green"
  608. style="display:none"
  609. sodipodi:insensitive="true">
  610. <image
  611. sodipodi:absref="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\colorScapes\green.svg"
  612. xlink:href="../colorScapes/green.svg"
  613. preserveAspectRatio="none"
  614. inkscape:svg-dpi="96"
  615. width="159.99989"
  616. height="89.999878"
  617. id="image452"
  618. x="-89.48719"
  619. y="1.1509594"
  620. clip-path="url(#clipPath498)"
  621. transform="translate(24.416101,-24.4161)" />
  622. </g>
  623. <g
  624. inkscape:groupmode="layer"
  625. id="g125"
  626. inkscape:label="orange"
  627. style="display:none"
  628. sodipodi:insensitive="true">
  629. <image
  630. sodipodi:absref="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\colorScapes\orange.svg"
  631. xlink:href="../colorScapes/orange.svg"
  632. preserveAspectRatio="none"
  633. inkscape:svg-dpi="96"
  634. width="159.99989"
  635. height="89.999878"
  636. id="image1546"
  637. x="-102.67852"
  638. y="-57.851128"
  639. clip-path="url(#clipPath1574)"
  640. transform="translate(18.384151,27.162696)" />
  641. </g>
  642. <g
  643. inkscape:groupmode="layer"
  644. id="g127"
  645. inkscape:label="purple"
  646. style="display:inline"
  647. sodipodi:insensitive="true">
  648. <image
  649. sodipodi:absref="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\colorScapes\purple.svg"
  650. xlink:href="../colorScapes/purple.svg"
  651. mask="none"
  652. preserveAspectRatio="none"
  653. inkscape:svg-dpi="96"
  654. width="159.99989"
  655. height="89.999878"
  656. id="image1472"
  657. x="-66.014824"
  658. y="-66.733566"
  659. clip-path="url(#clipPath3647)"
  660. transform="translate(5.2727661,37.400742)" />
  661. </g>
  662. </g>
  663. <g
  664. inkscape:label="border"
  665. inkscape:groupmode="layer"
  666. id="layer1"
  667. style="display:inline;opacity:1"
  668. sodipodi:insensitive="true">
  669. <path
  670. style="display:inline;opacity:1;fill:#ffffff;fill-opacity:1;stroke:none;stroke-width:0.983898;stroke-opacity:1"
  671. id="rect1502-1-8-5"
  672. width="24.416101"
  673. height="24.4161"
  674. x="13.192"
  675. y="13.192"
  676. ry="5.8395634"
  677. rx="5.4162478"
  678. clip-path="none"
  679. sodipodi:type="rect"
  680. d="m 18.608248,13.192 h 13.583606 c 3.000601,0 5.416248,2.604446 5.416248,5.839564 v 12.736973 c 0,3.235118 -2.415647,5.839563 -5.416248,5.839563 H 18.608248 C 15.607647,37.6081 13.192,35.003655 13.192,31.768537 V 19.031564 c 0,-3.235118 2.415647,-5.839564 5.416248,-5.839564 z"
  681. mask="url(#mask3616)"
  682. transform="matrix(1.0009788,0,0,1.0009789,-0.02491272,-0.02491404)" />
  683. </g>
  684. <g
  685. inkscape:groupmode="layer"
  686. id="layer16"
  687. inkscape:label="koylBox"
  688. sodipodi:insensitive="true"
  689. style="display:none">
  690. <rect
  691. style="display:inline;opacity:0.265;fill:#ffffff;fill-opacity:1;stroke:none;stroke-width:0.984001;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
  692. id="rect7-9"
  693. width="24.416101"
  694. height="24.4161"
  695. x="11.721968"
  696. y="14.66193"
  697. ry="5.8395634"
  698. rx="5.4162478"
  699. mask="url(#mask1087)"
  700. transform="translate(1.4699821,-1.4699817)" />
  701. </g>
  702. <g
  703. inkscape:groupmode="layer"
  704. id="layer17"
  705. inkscape:label="A-BOX"
  706. style="display:none"
  707. sodipodi:insensitive="true">
  708. <path
  709. style="display:inline;opacity:1;fill:#00ffff;fill-opacity:1;stroke:none;stroke-width:0.983898;stroke-opacity:1"
  710. id="rect1502-1-8"
  711. width="24.416101"
  712. height="24.4161"
  713. x="13.192"
  714. y="13.192"
  715. ry="5.8395634"
  716. rx="5.4162478"
  717. clip-path="none"
  718. sodipodi:type="rect"
  719. d="m 18.608248,13.192 h 13.583606 c 3.000601,0 5.416248,2.604446 5.416248,5.839564 v 12.736973 c 0,3.235118 -2.415647,5.839563 -5.416248,5.839563 H 18.608248 C 15.607647,37.6081 13.192,35.003655 13.192,31.768537 V 19.031564 c 0,-3.235118 2.415647,-5.839564 5.416248,-5.839564 z" />
  720. </g>
  721. <g
  722. inkscape:groupmode="layer"
  723. id="layer10"
  724. inkscape:label="12345"
  725. style="display:inline">
  726. <g
  727. inkscape:groupmode="layer"
  728. id="layer18"
  729. inkscape:label="a dot"
  730. style="display:inline" />
  731. <g
  732. inkscape:groupmode="layer"
  733. id="layer3"
  734. inkscape:label="quad3"
  735. style="display:none">
  736. <image
  737. sodipodi:absref="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\sectionDecoration\dot-size6.png"
  738. xlink:href="dot-size6.png"
  739. width="6.4070001"
  740. height="6.4066968"
  741. preserveAspectRatio="none"
  742. id="image264-7-0-5-7-6"
  743. x="15.7226"
  744. y="28.6766"
  745. style="display:inline" />
  746. </g>
  747. <g
  748. inkscape:groupmode="layer"
  749. id="layer11"
  750. inkscape:label="four"
  751. style="display:inline">
  752. <g
  753. inkscape:groupmode="layer"
  754. id="layer5"
  755. inkscape:label="quad2"
  756. style="display:none">
  757. <image
  758. sodipodi:absref="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\sectionDecoration\dot-size6.png"
  759. xlink:href="dot-size6.png"
  760. width="6.4070001"
  761. height="6.4066968"
  762. preserveAspectRatio="none"
  763. id="image264-7-0-5-7"
  764. x="28.651199"
  765. y="15.7226"
  766. style="display:inline" />
  767. </g>
  768. <g
  769. inkscape:groupmode="layer"
  770. id="layer9"
  771. inkscape:label="two"
  772. style="display:inline">
  773. <g
  774. inkscape:groupmode="layer"
  775. id="layer4"
  776. inkscape:label="quad4"
  777. style="display:inline">
  778. <image
  779. sodipodi:absref="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\sectionDecoration\dot-size6.png"
  780. xlink:href="dot-size6.png"
  781. width="6.4070001"
  782. height="6.4066968"
  783. preserveAspectRatio="none"
  784. id="image264-7-0-5-7-6-3"
  785. x="28.6766"
  786. y="28.6766"
  787. style="display:inline" />
  788. </g>
  789. <g
  790. inkscape:groupmode="layer"
  791. id="layer2"
  792. inkscape:label="quad1"
  793. style="display:inline">
  794. <image
  795. sodipodi:absref="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\sectionDecoration\dot-size6.png"
  796. xlink:href="dot-size6.png"
  797. width="6.4070001"
  798. height="6.4066968"
  799. preserveAspectRatio="none"
  800. id="image264-7-0-5"
  801. x="15.7226"
  802. y="15.7226"
  803. style="display:inline" />
  804. </g>
  805. </g>
  806. </g>
  807. <g
  808. inkscape:groupmode="layer"
  809. id="layer8"
  810. inkscape:label="one"
  811. style="display:none">
  812. <g
  813. inkscape:groupmode="layer"
  814. id="layer6"
  815. inkscape:label="center"
  816. style="display:inline">
  817. <image
  818. sodipodi:absref="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\sectionDecoration\dot-size6.png"
  819. xlink:href="dot-size6.png"
  820. width="6.4070001"
  821. height="6.4066968"
  822. preserveAspectRatio="none"
  823. id="image264-7-0"
  824. x="22.1996"
  825. y="22.1996"
  826. style="display:inline" />
  827. </g>
  828. </g>
  829. </g>
  830. <g
  831. inkscape:groupmode="layer"
  832. id="layer7"
  833. inkscape:label="6"
  834. style="display:none">
  835. <image
  836. sodipodi:absref="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\sectionDecoration\dot-size6.png"
  837. xlink:href="dot-size6.png"
  838. style="display:inline"
  839. y="15.7226"
  840. x="17.3482"
  841. id="image264"
  842. preserveAspectRatio="none"
  843. height="6.4066968"
  844. width="6.4070001" />
  845. <image
  846. sodipodi:absref="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\sectionDecoration\dot-size6.png"
  847. xlink:href="dot-size6.png"
  848. width="6.4070001"
  849. height="6.4066968"
  850. preserveAspectRatio="none"
  851. id="image264-7"
  852. x="17.3482"
  853. y="22.1996"
  854. style="display:inline" />
  855. <image
  856. sodipodi:absref="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\sectionDecoration\dot-size6.png"
  857. xlink:href="dot-size6.png"
  858. width="6.4070001"
  859. height="6.4066968"
  860. preserveAspectRatio="none"
  861. id="image264-3"
  862. x="17.3482"
  863. y="28.6766"
  864. style="display:inline" />
  865. <image
  866. sodipodi:absref="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\sectionDecoration\dot-size6.png"
  867. xlink:href="dot-size6.png"
  868. width="6.4066968"
  869. height="6.4066968"
  870. preserveAspectRatio="none"
  871. id="image264-51"
  872. x="27.0256"
  873. y="22.1996"
  874. style="display:inline" />
  875. <image
  876. sodipodi:absref="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\sectionDecoration\dot-size6.png"
  877. xlink:href="dot-size6.png"
  878. width="6.4066968"
  879. height="6.4066968"
  880. preserveAspectRatio="none"
  881. id="image264-36"
  882. x="27.0256"
  883. y="15.7226"
  884. style="display:inline" />
  885. <image
  886. sodipodi:absref="C:\Users\bad-p\Desktop\Work Folder\VS CODE\Qwixx\frontend\inkScape\sectionDecoration\dot-size6.png"
  887. xlink:href="dot-size6.png"
  888. width="6.4066968"
  889. height="6.4066968"
  890. preserveAspectRatio="none"
  891. id="image264-48"
  892. x="27.0256"
  893. y="28.6766"
  894. style="display:inline" />
  895. </g>
  896. <script
  897. id="mesh_polyfill"
  898. type="text/javascript">
  899. !function(){const t=&quot;http://www.w3.org/2000/svg&quot;,e=&quot;http://www.w3.org/1999/xlink&quot;,s=&quot;http://www.w3.org/1999/xhtml&quot;,r=2;if(document.createElementNS(t,&quot;meshgradient&quot;).x)return;const n=(t,e,s,r)=&gt;{let n=new x(.5*(e.x+s.x),.5*(e.y+s.y)),o=new x(.5*(t.x+e.x),.5*(t.y+e.y)),i=new x(.5*(s.x+r.x),.5*(s.y+r.y)),a=new x(.5*(n.x+o.x),.5*(n.y+o.y)),h=new x(.5*(n.x+i.x),.5*(n.y+i.y)),l=new x(.5*(a.x+h.x),.5*(a.y+h.y));return[[t,o,a,l],[l,h,i,r]]},o=t=&gt;{let e=t[0].distSquared(t[1]),s=t[2].distSquared(t[3]),r=.25*t[0].distSquared(t[2]),n=.25*t[1].distSquared(t[3]),o=e&gt;s?e:s,i=r&gt;n?r:n;return 18*(o&gt;i?o:i)},i=(t,e)=&gt;Math.sqrt(t.distSquared(e)),a=(t,e)=&gt;t.scale(2/3).add(e.scale(1/3)),h=t=&gt;{let e,s,r,n,o,i,a,h=new g;return t.match(/(\w+\(\s*[^)]+\))+/g).forEach(t=&gt;{let l=t.match(/[\w.-]+/g),d=l.shift();switch(d){case&quot;translate&quot;:2===l.length?e=new g(1,0,0,1,l[0],l[1]):(console.error(&quot;mesh.js: translate does not have 2 arguments!&quot;),e=new g(1,0,0,1,0,0)),h=h.append(e);break;case&quot;scale&quot;:1===l.length?s=new g(l[0],0,0,l[0],0,0):2===l.length?s=new g(l[0],0,0,l[1],0,0):(console.error(&quot;mesh.js: scale does not have 1 or 2 arguments!&quot;),s=new g(1,0,0,1,0,0)),h=h.append(s);break;case&quot;rotate&quot;:if(3===l.length&amp;&amp;(e=new g(1,0,0,1,l[1],l[2]),h=h.append(e)),l[0]){r=l[0]*Math.PI/180;let t=Math.cos(r),e=Math.sin(r);Math.abs(t)&lt;1e-16&amp;&amp;(t=0),Math.abs(e)&lt;1e-16&amp;&amp;(e=0),a=new g(t,e,-e,t,0,0),h=h.append(a)}else console.error(&quot;math.js: No argument to rotate transform!&quot;);3===l.length&amp;&amp;(e=new g(1,0,0,1,-l[1],-l[2]),h=h.append(e));break;case&quot;skewX&quot;:l[0]?(r=l[0]*Math.PI/180,n=Math.tan(r),o=new g(1,0,n,1,0,0),h=h.append(o)):console.error(&quot;math.js: No argument to skewX transform!&quot;);break;case&quot;skewY&quot;:l[0]?(r=l[0]*Math.PI/180,n=Math.tan(r),i=new g(1,n,0,1,0,0),h=h.append(i)):console.error(&quot;math.js: No argument to skewY transform!&quot;);break;case&quot;matrix&quot;:6===l.length?h=h.append(new g(...l)):console.error(&quot;math.js: Incorrect number of arguments for matrix!&quot;);break;default:console.error(&quot;mesh.js: Unhandled transform type: &quot;+d)}}),h},l=t=&gt;{let e=[],s=t.split(/[ ,]+/);for(let t=0,r=s.length-1;t&lt;r;t+=2)e.push(new x(parseFloat(s[t]),parseFloat(s[t+1])));return e},d=(t,e)=&gt;{for(let s in e)t.setAttribute(s,e[s])},c=(t,e,s,r,n)=&gt;{let o,i,a=[0,0,0,0];for(let h=0;h&lt;3;++h)e[h]&lt;t[h]&amp;&amp;e[h]&lt;s[h]||t[h]&lt;e[h]&amp;&amp;s[h]&lt;e[h]?a[h]=0:(a[h]=.5*((e[h]-t[h])/r+(s[h]-e[h])/n),o=Math.abs(3*(e[h]-t[h])/r),i=Math.abs(3*(s[h]-e[h])/n),a[h]&gt;o?a[h]=o:a[h]&gt;i&amp;&amp;(a[h]=i));return a},u=[[1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],[0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0],[-3,3,0,0,-2,-1,0,0,0,0,0,0,0,0,0,0],[2,-2,0,0,1,1,0,0,0,0,0,0,0,0,0,0],[0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0],[0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0],[0,0,0,0,0,0,0,0,-3,3,0,0,-2,-1,0,0],[0,0,0,0,0,0,0,0,2,-2,0,0,1,1,0,0],[-3,0,3,0,0,0,0,0,-2,0,-1,0,0,0,0,0],[0,0,0,0,-3,0,3,0,0,0,0,0,-2,0,-1,0],[9,-9,-9,9,6,3,-6,-3,6,-6,3,-3,4,2,2,1],[-6,6,6,-6,-3,-3,3,3,-4,4,-2,2,-2,-2,-1,-1],[2,0,-2,0,0,0,0,0,1,0,1,0,0,0,0,0],[0,0,0,0,2,0,-2,0,0,0,0,0,1,0,1,0],[-6,6,6,-6,-4,-2,4,2,-3,3,-3,3,-2,-1,-2,-1],[4,-4,-4,4,2,2,-2,-2,2,-2,2,-2,1,1,1,1]],f=t=&gt;{let e=[];for(let s=0;s&lt;16;++s){e[s]=0;for(let r=0;r&lt;16;++r)e[s]+=u[s][r]*t[r]}return e},p=(t,e,s)=&gt;{const r=e*e,n=s*s,o=e*e*e,i=s*s*s;return t[0]+t[1]*e+t[2]*r+t[3]*o+t[4]*s+t[5]*s*e+t[6]*s*r+t[7]*s*o+t[8]*n+t[9]*n*e+t[10]*n*r+t[11]*n*o+t[12]*i+t[13]*i*e+t[14]*i*r+t[15]*i*o},y=t=&gt;{let e=[],s=[],r=[];for(let s=0;s&lt;4;++s)e[s]=[],e[s][0]=n(t[0][s],t[1][s],t[2][s],t[3][s]),e[s][1]=[],e[s][1].push(...n(...e[s][0][0])),e[s][1].push(...n(...e[s][0][1])),e[s][2]=[],e[s][2].push(...n(...e[s][1][0])),e[s][2].push(...n(...e[s][1][1])),e[s][2].push(...n(...e[s][1][2])),e[s][2].push(...n(...e[s][1][3]));for(let t=0;t&lt;8;++t){s[t]=[];for(let r=0;r&lt;4;++r)s[t][r]=[],s[t][r][0]=n(e[0][2][t][r],e[1][2][t][r],e[2][2][t][r],e[3][2][t][r]),s[t][r][1]=[],s[t][r][1].push(...n(...s[t][r][0][0])),s[t][r][1].push(...n(...s[t][r][0][1])),s[t][r][2]=[],s[t][r][2].push(...n(...s[t][r][1][0])),s[t][r][2].push(...n(...s[t][r][1][1])),s[t][r][2].push(...n(...s[t][r][1][2])),s[t][r][2].push(...n(...s[t][r][1][3]))}for(let t=0;t&lt;8;++t){r[t]=[];for(let e=0;e&lt;8;++e)r[t][e]=[],r[t][e][0]=s[t][0][2][e],r[t][e][1]=s[t][1][2][e],r[t][e][2]=s[t][2][2][e],r[t][e][3]=s[t][3][2][e]}return r};class x{constructor(t,e){this.x=t||0,this.y=e||0}toString(){return`(x=${this.x}, y=${this.y})`}clone(){return new x(this.x,this.y)}add(t){return new x(this.x+t.x,this.y+t.y)}scale(t){return void 0===t.x?new x(this.x*t,this.y*t):new x(this.x*t.x,this.y*t.y)}distSquared(t){let e=this.x-t.x,s=this.y-t.y;return e*e+s*s}transform(t){let e=this.x*t.a+this.y*t.c+t.e,s=this.x*t.b+this.y*t.d+t.f;return new x(e,s)}}class g{constructor(t,e,s,r,n,o){void 0===t?(this.a=1,this.b=0,this.c=0,this.d=1,this.e=0,this.f=0):(this.a=t,this.b=e,this.c=s,this.d=r,this.e=n,this.f=o)}toString(){return`affine: ${this.a} ${this.c} ${this.e} \n ${this.b} ${this.d} ${this.f}`}append(t){t instanceof g||console.error(&quot;mesh.js: argument to Affine.append is not affine!&quot;);let e=this.a*t.a+this.c*t.b,s=this.b*t.a+this.d*t.b,r=this.a*t.c+this.c*t.d,n=this.b*t.c+this.d*t.d,o=this.a*t.e+this.c*t.f+this.e,i=this.b*t.e+this.d*t.f+this.f;return new g(e,s,r,n,o,i)}}class w{constructor(t,e){this.nodes=t,this.colors=e}paintCurve(t,e){if(o(this.nodes)&gt;r){const s=n(...this.nodes);let r=[[],[]],o=[[],[]];for(let t=0;t&lt;4;++t)r[0][t]=this.colors[0][t],r[1][t]=(this.colors[0][t]+this.colors[1][t])/2,o[0][t]=r[1][t],o[1][t]=this.colors[1][t];let i=new w(s[0],r),a=new w(s[1],o);i.paintCurve(t,e),a.paintCurve(t,e)}else{let s=Math.round(this.nodes[0].x);if(s&gt;=0&amp;&amp;s&lt;e){let r=4*(~~this.nodes[0].y*e+s);t[r]=Math.round(this.colors[0][0]),t[r+1]=Math.round(this.colors[0][1]),t[r+2]=Math.round(this.colors[0][2]),t[r+3]=Math.round(this.colors[0][3])}}}}class m{constructor(t,e){this.nodes=t,this.colors=e}split(){let t=[[],[],[],[]],e=[[],[],[],[]],s=[[[],[]],[[],[]]],r=[[[],[]],[[],[]]];for(let s=0;s&lt;4;++s){const r=n(this.nodes[0][s],this.nodes[1][s],this.nodes[2][s],this.nodes[3][s]);t[0][s]=r[0][0],t[1][s]=r[0][1],t[2][s]=r[0][2],t[3][s]=r[0][3],e[0][s]=r[1][0],e[1][s]=r[1][1],e[2][s]=r[1][2],e[3][s]=r[1][3]}for(let t=0;t&lt;4;++t)s[0][0][t]=this.colors[0][0][t],s[0][1][t]=this.colors[0][1][t],s[1][0][t]=(this.colors[0][0][t]+this.colors[1][0][t])/2,s[1][1][t]=(this.colors[0][1][t]+this.colors[1][1][t])/2,r[0][0][t]=s[1][0][t],r[0][1][t]=s[1][1][t],r[1][0][t]=this.colors[1][0][t],r[1][1][t]=this.colors[1][1][t];return[new m(t,s),new m(e,r)]}paint(t,e){let s,n=!1;for(let t=0;t&lt;4;++t)if((s=o([this.nodes[0][t],this.nodes[1][t],this.nodes[2][t],this.nodes[3][t]]))&gt;r){n=!0;break}if(n){let s=this.split();s[0].paint(t,e),s[1].paint(t,e)}else{new w([...this.nodes[0]],[...this.colors[0]]).paintCurve(t,e)}}}class b{constructor(t){this.readMesh(t),this.type=t.getAttribute(&quot;type&quot;)||&quot;bilinear&quot;}readMesh(t){let e=[[]],s=[[]],r=Number(t.getAttribute(&quot;x&quot;)),n=Number(t.getAttribute(&quot;y&quot;));e[0][0]=new x(r,n);let o=t.children;for(let t=0,r=o.length;t&lt;r;++t){e[3*t+1]=[],e[3*t+2]=[],e[3*t+3]=[],s[t+1]=[];let r=o[t].children;for(let n=0,o=r.length;n&lt;o;++n){let o=r[n].children;for(let r=0,i=o.length;r&lt;i;++r){let i=r;0!==t&amp;&amp;++i;let h,d=o[r].getAttribute(&quot;path&quot;),c=&quot;l&quot;;null!=d&amp;&amp;(c=(h=d.match(/\s*([lLcC])\s*(.*)/))[1]);let u=l(h[2]);switch(c){case&quot;l&quot;:0===i?(e[3*t][3*n+3]=u[0].add(e[3*t][3*n]),e[3*t][3*n+1]=a(e[3*t][3*n],e[3*t][3*n+3]),e[3*t][3*n+2]=a(e[3*t][3*n+3],e[3*t][3*n])):1===i?(e[3*t+3][3*n+3]=u[0].add(e[3*t][3*n+3]),e[3*t+1][3*n+3]=a(e[3*t][3*n+3],e[3*t+3][3*n+3]),e[3*t+2][3*n+3]=a(e[3*t+3][3*n+3],e[3*t][3*n+3])):2===i?(0===n&amp;&amp;(e[3*t+3][3*n+0]=u[0].add(e[3*t+3][3*n+3])),e[3*t+3][3*n+1]=a(e[3*t+3][3*n],e[3*t+3][3*n+3]),e[3*t+3][3*n+2]=a(e[3*t+3][3*n+3],e[3*t+3][3*n])):(e[3*t+1][3*n]=a(e[3*t][3*n],e[3*t+3][3*n]),e[3*t+2][3*n]=a(e[3*t+3][3*n],e[3*t][3*n]));break;case&quot;L&quot;:0===i?(e[3*t][3*n+3]=u[0],e[3*t][3*n+1]=a(e[3*t][3*n],e[3*t][3*n+3]),e[3*t][3*n+2]=a(e[3*t][3*n+3],e[3*t][3*n])):1===i?(e[3*t+3][3*n+3]=u[0],e[3*t+1][3*n+3]=a(e[3*t][3*n+3],e[3*t+3][3*n+3]),e[3*t+2][3*n+3]=a(e[3*t+3][3*n+3],e[3*t][3*n+3])):2===i?(0===n&amp;&amp;(e[3*t+3][3*n+0]=u[0]),e[3*t+3][3*n+1]=a(e[3*t+3][3*n],e[3*t+3][3*n+3]),e[3*t+3][3*n+2]=a(e[3*t+3][3*n+3],e[3*t+3][3*n])):(e[3*t+1][3*n]=a(e[3*t][3*n],e[3*t+3][3*n]),e[3*t+2][3*n]=a(e[3*t+3][3*n],e[3*t][3*n]));break;case&quot;c&quot;:0===i?(e[3*t][3*n+1]=u[0].add(e[3*t][3*n]),e[3*t][3*n+2]=u[1].add(e[3*t][3*n]),e[3*t][3*n+3]=u[2].add(e[3*t][3*n])):1===i?(e[3*t+1][3*n+3]=u[0].add(e[3*t][3*n+3]),e[3*t+2][3*n+3]=u[1].add(e[3*t][3*n+3]),e[3*t+3][3*n+3]=u[2].add(e[3*t][3*n+3])):2===i?(e[3*t+3][3*n+2]=u[0].add(e[3*t+3][3*n+3]),e[3*t+3][3*n+1]=u[1].add(e[3*t+3][3*n+3]),0===n&amp;&amp;(e[3*t+3][3*n+0]=u[2].add(e[3*t+3][3*n+3]))):(e[3*t+2][3*n]=u[0].add(e[3*t+3][3*n]),e[3*t+1][3*n]=u[1].add(e[3*t+3][3*n]));break;case&quot;C&quot;:0===i?(e[3*t][3*n+1]=u[0],e[3*t][3*n+2]=u[1],e[3*t][3*n+3]=u[2]):1===i?(e[3*t+1][3*n+3]=u[0],e[3*t+2][3*n+3]=u[1],e[3*t+3][3*n+3]=u[2]):2===i?(e[3*t+3][3*n+2]=u[0],e[3*t+3][3*n+1]=u[1],0===n&amp;&amp;(e[3*t+3][3*n+0]=u[2])):(e[3*t+2][3*n]=u[0],e[3*t+1][3*n]=u[1]);break;default:console.error(&quot;mesh.js: &quot;+c+&quot; invalid path type.&quot;)}if(0===t&amp;&amp;0===n||r&gt;0){let e=window.getComputedStyle(o[r]).stopColor.match(/^rgb\s*\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i),a=window.getComputedStyle(o[r]).stopOpacity,h=255;a&amp;&amp;(h=Math.floor(255*a)),e&amp;&amp;(0===i?(s[t][n]=[],s[t][n][0]=Math.floor(e[1]),s[t][n][1]=Math.floor(e[2]),s[t][n][2]=Math.floor(e[3]),s[t][n][3]=h):1===i?(s[t][n+1]=[],s[t][n+1][0]=Math.floor(e[1]),s[t][n+1][1]=Math.floor(e[2]),s[t][n+1][2]=Math.floor(e[3]),s[t][n+1][3]=h):2===i?(s[t+1][n+1]=[],s[t+1][n+1][0]=Math.floor(e[1]),s[t+1][n+1][1]=Math.floor(e[2]),s[t+1][n+1][2]=Math.floor(e[3]),s[t+1][n+1][3]=h):3===i&amp;&amp;(s[t+1][n]=[],s[t+1][n][0]=Math.floor(e[1]),s[t+1][n][1]=Math.floor(e[2]),s[t+1][n][2]=Math.floor(e[3]),s[t+1][n][3]=h))}}e[3*t+1][3*n+1]=new x,e[3*t+1][3*n+2]=new x,e[3*t+2][3*n+1]=new x,e[3*t+2][3*n+2]=new x,e[3*t+1][3*n+1].x=(-4*e[3*t][3*n].x+6*(e[3*t][3*n+1].x+e[3*t+1][3*n].x)+-2*(e[3*t][3*n+3].x+e[3*t+3][3*n].x)+3*(e[3*t+3][3*n+1].x+e[3*t+1][3*n+3].x)+-1*e[3*t+3][3*n+3].x)/9,e[3*t+1][3*n+2].x=(-4*e[3*t][3*n+3].x+6*(e[3*t][3*n+2].x+e[3*t+1][3*n+3].x)+-2*(e[3*t][3*n].x+e[3*t+3][3*n+3].x)+3*(e[3*t+3][3*n+2].x+e[3*t+1][3*n].x)+-1*e[3*t+3][3*n].x)/9,e[3*t+2][3*n+1].x=(-4*e[3*t+3][3*n].x+6*(e[3*t+3][3*n+1].x+e[3*t+2][3*n].x)+-2*(e[3*t+3][3*n+3].x+e[3*t][3*n].x)+3*(e[3*t][3*n+1].x+e[3*t+2][3*n+3].x)+-1*e[3*t][3*n+3].x)/9,e[3*t+2][3*n+2].x=(-4*e[3*t+3][3*n+3].x+6*(e[3*t+3][3*n+2].x+e[3*t+2][3*n+3].x)+-2*(e[3*t+3][3*n].x+e[3*t][3*n+3].x)+3*(e[3*t][3*n+2].x+e[3*t+2][3*n].x)+-1*e[3*t][3*n].x)/9,e[3*t+1][3*n+1].y=(-4*e[3*t][3*n].y+6*(e[3*t][3*n+1].y+e[3*t+1][3*n].y)+-2*(e[3*t][3*n+3].y+e[3*t+3][3*n].y)+3*(e[3*t+3][3*n+1].y+e[3*t+1][3*n+3].y)+-1*e[3*t+3][3*n+3].y)/9,e[3*t+1][3*n+2].y=(-4*e[3*t][3*n+3].y+6*(e[3*t][3*n+2].y+e[3*t+1][3*n+3].y)+-2*(e[3*t][3*n].y+e[3*t+3][3*n+3].y)+3*(e[3*t+3][3*n+2].y+e[3*t+1][3*n].y)+-1*e[3*t+3][3*n].y)/9,e[3*t+2][3*n+1].y=(-4*e[3*t+3][3*n].y+6*(e[3*t+3][3*n+1].y+e[3*t+2][3*n].y)+-2*(e[3*t+3][3*n+3].y+e[3*t][3*n].y)+3*(e[3*t][3*n+1].y+e[3*t+2][3*n+3].y)+-1*e[3*t][3*n+3].y)/9,e[3*t+2][3*n+2].y=(-4*e[3*t+3][3*n+3].y+6*(e[3*t+3][3*n+2].y+e[3*t+2][3*n+3].y)+-2*(e[3*t+3][3*n].y+e[3*t][3*n+3].y)+3*(e[3*t][3*n+2].y+e[3*t+2][3*n].y)+-1*e[3*t][3*n].y)/9}}this.nodes=e,this.colors=s}paintMesh(t,e){let s=(this.nodes.length-1)/3,r=(this.nodes[0].length-1)/3;if(&quot;bilinear&quot;===this.type||s&lt;2||r&lt;2){let n;for(let o=0;o&lt;s;++o)for(let s=0;s&lt;r;++s){let r=[];for(let t=3*o,e=3*o+4;t&lt;e;++t)r.push(this.nodes[t].slice(3*s,3*s+4));let i=[];i.push(this.colors[o].slice(s,s+2)),i.push(this.colors[o+1].slice(s,s+2)),(n=new m(r,i)).paint(t,e)}}else{let n,o,a,h,l,d,u;const x=s,g=r;s++,r++;let w=new Array(s);for(let t=0;t&lt;s;++t){w[t]=new Array(r);for(let e=0;e&lt;r;++e)w[t][e]=[],w[t][e][0]=this.nodes[3*t][3*e],w[t][e][1]=this.colors[t][e]}for(let t=0;t&lt;s;++t)for(let e=0;e&lt;r;++e)0!==t&amp;&amp;t!==x&amp;&amp;(n=i(w[t-1][e][0],w[t][e][0]),o=i(w[t+1][e][0],w[t][e][0]),w[t][e][2]=c(w[t-1][e][1],w[t][e][1],w[t+1][e][1],n,o)),0!==e&amp;&amp;e!==g&amp;&amp;(n=i(w[t][e-1][0],w[t][e][0]),o=i(w[t][e+1][0],w[t][e][0]),w[t][e][3]=c(w[t][e-1][1],w[t][e][1],w[t][e+1][1],n,o));for(let t=0;t&lt;r;++t){w[0][t][2]=[],w[x][t][2]=[];for(let e=0;e&lt;4;++e)n=i(w[1][t][0],w[0][t][0]),o=i(w[x][t][0],w[x-1][t][0]),w[0][t][2][e]=n&gt;0?2*(w[1][t][1][e]-w[0][t][1][e])/n-w[1][t][2][e]:0,w[x][t][2][e]=o&gt;0?2*(w[x][t][1][e]-w[x-1][t][1][e])/o-w[x-1][t][2][e]:0}for(let t=0;t&lt;s;++t){w[t][0][3]=[],w[t][g][3]=[];for(let e=0;e&lt;4;++e)n=i(w[t][1][0],w[t][0][0]),o=i(w[t][g][0],w[t][g-1][0]),w[t][0][3][e]=n&gt;0?2*(w[t][1][1][e]-w[t][0][1][e])/n-w[t][1][3][e]:0,w[t][g][3][e]=o&gt;0?2*(w[t][g][1][e]-w[t][g-1][1][e])/o-w[t][g-1][3][e]:0}for(let s=0;s&lt;x;++s)for(let r=0;r&lt;g;++r){let n=i(w[s][r][0],w[s+1][r][0]),o=i(w[s][r+1][0],w[s+1][r+1][0]),c=i(w[s][r][0],w[s][r+1][0]),x=i(w[s+1][r][0],w[s+1][r+1][0]),g=[[],[],[],[]];for(let t=0;t&lt;4;++t){(d=[])[0]=w[s][r][1][t],d[1]=w[s+1][r][1][t],d[2]=w[s][r+1][1][t],d[3]=w[s+1][r+1][1][t],d[4]=w[s][r][2][t]*n,d[5]=w[s+1][r][2][t]*n,d[6]=w[s][r+1][2][t]*o,d[7]=w[s+1][r+1][2][t]*o,d[8]=w[s][r][3][t]*c,d[9]=w[s+1][r][3][t]*x,d[10]=w[s][r+1][3][t]*c,d[11]=w[s+1][r+1][3][t]*x,d[12]=0,d[13]=0,d[14]=0,d[15]=0,u=f(d);for(let e=0;e&lt;9;++e){g[t][e]=[];for(let s=0;s&lt;9;++s)g[t][e][s]=p(u,e/8,s/8),g[t][e][s]&gt;255?g[t][e][s]=255:g[t][e][s]&lt;0&amp;&amp;(g[t][e][s]=0)}}h=[];for(let t=3*s,e=3*s+4;t&lt;e;++t)h.push(this.nodes[t].slice(3*r,3*r+4));l=y(h);for(let s=0;s&lt;8;++s)for(let r=0;r&lt;8;++r)(a=new m(l[s][r],[[[g[0][s][r],g[1][s][r],g[2][s][r],g[3][s][r]],[g[0][s][r+1],g[1][s][r+1],g[2][s][r+1],g[3][s][r+1]]],[[g[0][s+1][r],g[1][s+1][r],g[2][s+1][r],g[3][s+1][r]],[g[0][s+1][r+1],g[1][s+1][r+1],g[2][s+1][r+1],g[3][s+1][r+1]]]])).paint(t,e)}}}transform(t){if(t instanceof x)for(let e=0,s=this.nodes.length;e&lt;s;++e)for(let s=0,r=this.nodes[0].length;s&lt;r;++s)this.nodes[e][s]=this.nodes[e][s].add(t);else if(t instanceof g)for(let e=0,s=this.nodes.length;e&lt;s;++e)for(let s=0,r=this.nodes[0].length;s&lt;r;++s)this.nodes[e][s]=this.nodes[e][s].transform(t)}scale(t){for(let e=0,s=this.nodes.length;e&lt;s;++e)for(let s=0,r=this.nodes[0].length;s&lt;r;++s)this.nodes[e][s]=this.nodes[e][s].scale(t)}}document.querySelectorAll(&quot;rect,circle,ellipse,path,text&quot;).forEach((r,n)=&gt;{let o=r.getAttribute(&quot;id&quot;);o||(o=&quot;patchjs_shape&quot;+n,r.setAttribute(&quot;id&quot;,o));const i=r.style.fill.match(/^url\(\s*&quot;?\s*#([^\s&quot;]+)&quot;?\s*\)/),a=r.style.stroke.match(/^url\(\s*&quot;?\s*#([^\s&quot;]+)&quot;?\s*\)/);if(i&amp;&amp;i[1]){const a=document.getElementById(i[1]);if(a&amp;&amp;&quot;meshgradient&quot;===a.nodeName){const i=r.getBBox();let l=document.createElementNS(s,&quot;canvas&quot;);d(l,{width:i.width,height:i.height});const c=l.getContext(&quot;2d&quot;);let u=c.createImageData(i.width,i.height);const f=new b(a);&quot;objectBoundingBox&quot;===a.getAttribute(&quot;gradientUnits&quot;)&amp;&amp;f.scale(new x(i.width,i.height));const p=a.getAttribute(&quot;gradientTransform&quot;);null!=p&amp;&amp;f.transform(h(p)),&quot;userSpaceOnUse&quot;===a.getAttribute(&quot;gradientUnits&quot;)&amp;&amp;f.transform(new x(-i.x,-i.y)),f.paintMesh(u.data,l.width),c.putImageData(u,0,0);const y=document.createElementNS(t,&quot;image&quot;);d(y,{width:i.width,height:i.height,x:i.x,y:i.y});let g=l.toDataURL();y.setAttributeNS(e,&quot;xlink:href&quot;,g),r.parentNode.insertBefore(y,r),r.style.fill=&quot;none&quot;;const w=document.createElementNS(t,&quot;use&quot;);w.setAttributeNS(e,&quot;xlink:href&quot;,&quot;#&quot;+o);const m=&quot;patchjs_clip&quot;+n,M=document.createElementNS(t,&quot;clipPath&quot;);M.setAttribute(&quot;id&quot;,m),M.appendChild(w),r.parentElement.insertBefore(M,r),y.setAttribute(&quot;clip-path&quot;,&quot;url(#&quot;+m+&quot;)&quot;),u=null,l=null,g=null}}if(a&amp;&amp;a[1]){const o=document.getElementById(a[1]);if(o&amp;&amp;&quot;meshgradient&quot;===o.nodeName){const i=parseFloat(r.style.strokeWidth.slice(0,-2))*(parseFloat(r.style.strokeMiterlimit)||parseFloat(r.getAttribute(&quot;stroke-miterlimit&quot;))||1),a=r.getBBox(),l=Math.trunc(a.width+i),c=Math.trunc(a.height+i),u=Math.trunc(a.x-i/2),f=Math.trunc(a.y-i/2);let p=document.createElementNS(s,&quot;canvas&quot;);d(p,{width:l,height:c});const y=p.getContext(&quot;2d&quot;);let g=y.createImageData(l,c);const w=new b(o);&quot;objectBoundingBox&quot;===o.getAttribute(&quot;gradientUnits&quot;)&amp;&amp;w.scale(new x(l,c));const m=o.getAttribute(&quot;gradientTransform&quot;);null!=m&amp;&amp;w.transform(h(m)),&quot;userSpaceOnUse&quot;===o.getAttribute(&quot;gradientUnits&quot;)&amp;&amp;w.transform(new x(-u,-f)),w.paintMesh(g.data,p.width),y.putImageData(g,0,0);const M=document.createElementNS(t,&quot;image&quot;);d(M,{width:l,height:c,x:0,y:0});let S=p.toDataURL();M.setAttributeNS(e,&quot;xlink:href&quot;,S);const k=&quot;pattern_clip&quot;+n,A=document.createElementNS(t,&quot;pattern&quot;);d(A,{id:k,patternUnits:&quot;userSpaceOnUse&quot;,width:l,height:c,x:u,y:f}),A.appendChild(M),o.parentNode.appendChild(A),r.style.stroke=&quot;url(#&quot;+k+&quot;)&quot;,g=null,p=null,S=null}}})}();
  900. </script>
  901. </svg>