From 5f7dbd87d9b242e95889d2934c14810166181209 Mon Sep 17 00:00:00 2001
From: xgui3783 <xgui3783@gmail.com>
Date: Tue, 14 Jul 2020 12:07:38 +0200
Subject: [PATCH] feat: custom icons for transl, rot and scale (#589)

---
 src/index.html                                |   1 +
 src/main-common.ts                            |   5 ++
 src/res/icons/_base.svg                       |  63 +++++++++++++
 src/res/icons/base.svg                        |  63 +++++++++++++
 src/res/icons/generateFont.sh                 |  84 ++++++++++++++++++
 src/res/icons/iav-icons.css                   |   1 +
 src/res/icons/iav-icons.svg                   |  49 ++++++++++
 src/res/icons/iav-icons.ttf                   | Bin 0 -> 2248 bytes
 src/res/icons/iav-icons.woff                  | Bin 0 -> 2428 bytes
 src/res/icons/meta.json                       |  13 +++
 src/res/icons/rotation/glyph.svg              |  81 +++++++++++++++++
 src/res/icons/rotation/rotate.svg             |  71 +++++++++++++++
 src/res/icons/scaling/glyph.svg               |  61 +++++++++++++
 src/res/icons/scaling/scale.svg               |  70 +++++++++++++++
 src/res/icons/translation/glyph.svg           |  62 +++++++++++++
 src/res/icons/translation/translate.svg       |  70 +++++++++++++++
 .../statusCard/statusCard.template.html       |   6 +-
 17 files changed, 697 insertions(+), 3 deletions(-)
 create mode 100644 src/res/icons/_base.svg
 create mode 100644 src/res/icons/base.svg
 create mode 100755 src/res/icons/generateFont.sh
 create mode 100755 src/res/icons/iav-icons.css
 create mode 100644 src/res/icons/iav-icons.svg
 create mode 100644 src/res/icons/iav-icons.ttf
 create mode 100644 src/res/icons/iav-icons.woff
 create mode 100644 src/res/icons/meta.json
 create mode 100644 src/res/icons/rotation/glyph.svg
 create mode 100644 src/res/icons/rotation/rotate.svg
 create mode 100644 src/res/icons/scaling/glyph.svg
 create mode 100644 src/res/icons/scaling/scale.svg
 create mode 100644 src/res/icons/translation/glyph.svg
 create mode 100644 src/res/icons/translation/translate.svg

diff --git a/src/index.html b/src/index.html
index db01a3a08..590bc0faf 100644
--- a/src/index.html
+++ b/src/index.html
@@ -8,6 +8,7 @@
   <link href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous">
   <link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.8.1/css/all.css" integrity="sha384-50oBUHEmvpQ+1lW4y57PTFmhCaXp0ML5d60M1M7uH2+nqUivzIebhndOJK28anvf" crossorigin="anonymous">
   <link rel="stylesheet" href="extra_styles.css">
+  <link rel="stylesheet" href="icons/iav-icons.css">
   <link rel="stylesheet" href="theme.css">
   <link rel="stylesheet" href="version.css">
   
diff --git a/src/main-common.ts b/src/main-common.ts
index 249ed7eb5..6bab08d71 100644
--- a/src/main-common.ts
+++ b/src/main-common.ts
@@ -13,6 +13,11 @@ import '!!file-loader?context=third_party&name=preinit_vanilla.html!third_party/
 import '!!file-loader?context=third_party&name=catchSyntaxError.js!third_party/catchSyntaxError.js'
 import '!!file-loader?context=third_party&name=syntaxError.js!third_party/syntaxError.js'
 
+import '!!file-loader?context=src/res&name=icons/iav-icons.css!src/res/icons/iav-icons.css'
+import '!!file-loader?context=src/res&name=icons/iav-icons.ttf!src/res/icons/iav-icons.ttf'
+import '!!file-loader?context=src/res&name=icons/iav-icons.woff!src/res/icons/iav-icons.woff'
+import '!!file-loader?context=src/res&name=icons/iav-icons.svg!src/res/icons/iav-icons.svg'
+
 import 'zone.js'
 import { enableProdMode } from '@angular/core';
 
diff --git a/src/res/icons/_base.svg b/src/res/icons/_base.svg
new file mode 100644
index 000000000..23c6509d3
--- /dev/null
+++ b/src/res/icons/_base.svg
@@ -0,0 +1,63 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="967.55908"
+   height="967.55908"
+   viewBox="0 0 256 256"
+   version="1.1"
+   id="svg859"
+   sodipodi:docname="_base.svg"
+   inkscape:version="1.0 (6e3e5246a0, 2020-05-07)">
+  <defs
+     id="defs853" />
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="0.80867634"
+     inkscape:cx="475.38605"
+     inkscape:cy="524.86583"
+     inkscape:document-units="mm"
+     inkscape:current-layer="layer1"
+     inkscape:document-rotation="0"
+     showgrid="false"
+     units="px"
+     inkscape:window-width="1439"
+     inkscape:window-height="1023"
+     inkscape:window-x="167"
+     inkscape:window-y="27"
+     inkscape:window-maximized="0" />
+  <metadata
+     id="metadata856">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title></dc:title>
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     inkscape:label="Layer 1"
+     inkscape:groupmode="layer"
+     id="layer1">
+    <rect
+       style="fill:none;stroke:#000000;stroke-width:16;stroke-miterlimit:4;stroke-dasharray:none;stroke-linejoin:bevel;stroke-linecap:square"
+       id="rect1422"
+       width="140.85201"
+       height="140.85201"
+       x="54.726311"
+       y="57.82893" />
+  </g>
+</svg>
diff --git a/src/res/icons/base.svg b/src/res/icons/base.svg
new file mode 100644
index 000000000..97d866ce4
--- /dev/null
+++ b/src/res/icons/base.svg
@@ -0,0 +1,63 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="967.55908"
+   height="967.55908"
+   viewBox="0 0 256 256"
+   version="1.1"
+   id="svg859"
+   sodipodi:docname="base.svg"
+   inkscape:version="1.0 (6e3e5246a0, 2020-05-07)">
+  <defs
+     id="defs853" />
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="0.80867634"
+     inkscape:cx="475.38605"
+     inkscape:cy="524.86583"
+     inkscape:document-units="mm"
+     inkscape:current-layer="layer1"
+     inkscape:document-rotation="0"
+     showgrid="false"
+     units="px"
+     inkscape:window-width="1439"
+     inkscape:window-height="1023"
+     inkscape:window-x="167"
+     inkscape:window-y="27"
+     inkscape:window-maximized="0" />
+  <metadata
+     id="metadata856">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title />
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     inkscape:label="Layer 1"
+     inkscape:groupmode="layer"
+     id="layer1">
+    <rect
+       style="fill:none;stroke:#000000;stroke-width:16;stroke-miterlimit:4;stroke-dasharray:none;stroke-linejoin:bevel;stroke-linecap:square"
+       id="rect1422"
+       width="140.85201"
+       height="140.85201"
+       x="54.726311"
+       y="57.82893" />
+  </g>
+</svg>
diff --git a/src/res/icons/generateFont.sh b/src/res/icons/generateFont.sh
new file mode 100755
index 000000000..7f40a2df7
--- /dev/null
+++ b/src/res/icons/generateFont.sh
@@ -0,0 +1,84 @@
+#! /bin/bash
+
+# [fontforge](https://fontforge.org/en-US/) needs to be installed first
+
+JSON_STRING="$(cat ./meta.json)"
+
+JSON_REMOVE_NL=${JSON_STRING//$'\n'/ }
+JSON_REMOVE_WHITESPACE=${JSON_REMOVE_NL//$' '/}
+
+# font = fontforge.font();
+# glyph = font.createChar(41, "A");
+# glyph.importOutlines("/path/to/svg/foo.svg");
+# font.generate("/output/math/foo.ttf");
+
+CSS_MAIN_CLASS='iavic'
+CSS_FONT_FILE_NAME='iav-icons'
+
+CSS="
+.$CSS_MAIN_CLASS
+{
+  -moz-osx-font-smoothing: grayscale;
+  -webkit-font-smoothing: antialiased;
+  display: inline-block;
+  font-style: normal;
+  font-variant: normal;
+  text-rendering: auto;
+  line-height: 1;
+}
+
+@font-face {
+  font-family: "'"'"iav-custom-icons"'"'";
+  font-style: normal;
+  font-weight: 900;
+  font-display:auto;
+  src: url(./$CSS_FONT_FILE_NAME.woff) format("'"'"woff"'"'"),url(./$CSS_FONT_FILE_NAME.ttf) format("'"'"truetype"'"'"),url(./$CSS_FONT_FILE_NAME.svg) format("'"'"svg"'"'");
+}
+
+.$CSS_MAIN_CLASS
+{
+  font-family: "'"'"iav-custom-icons"'"'";
+}
+"
+
+CSS_REMOVE_NL=${CSS//$'\n'/ }
+CSS_REMOVE_WHITESPACE=${CSS_REMOVE_NL//$' '/}
+CSS_ESCAPE_QUOTES=${CSS_REMOVE_WHITESPACE//\"/\\\"}
+
+FONTFORGE_ARG='
+double_quot='"'"'"'"'"'
+css_output="'$CSS_ESCAPE_QUOTES'";
+css_class="'$CSS_MAIN_CLASS'";
+t='$JSON_REMOVE_WHITESPACE';
+font = fontforge.font();
+for item in t:
+  content=item['"'"'content'"'"'];
+  _class=item['"'"'class'"'"'];
+  svg=item['"'"'svg'"'"'];
+  if content is None or len(content) == 0:
+    raise Exception("content field must always be defined");
+  if svg is None:
+    raise Exception("svg path must be defined");
+  if _class is None:
+    raise Exception("content field must always be defined");
+  unicode_coord=ord(content[0]);
+  glyph = font.createChar(unicode_coord, content[0]);
+  glyph.importOutlines(svg);
+  css_output=css_output + "." + css_class + "-" + _class;
+  css_output=css_output + ":before{";
+  css_output=css_output + "content:" + double_quot + content + double_quot + ";";
+  css_output=css_output + "}";
+
+import os;
+css_filename="'$CSS_FONT_FILE_NAME'.css"
+
+fd = os.open(css_filename, os.O_RDWR | os.O_CREAT);
+os.write(fd, css_output.encode());
+os.close(fd);
+
+font.generate("./'$CSS_FONT_FILE_NAME'.ttf");
+font.generate("./'$CSS_FONT_FILE_NAME'.woff");
+font.generate("./'$CSS_FONT_FILE_NAME'.svg");
+'
+
+fontforge -c "$FONTFORGE_ARG"
\ No newline at end of file
diff --git a/src/res/icons/iav-icons.css b/src/res/icons/iav-icons.css
new file mode 100755
index 000000000..11b6f413c
--- /dev/null
+++ b/src/res/icons/iav-icons.css
@@ -0,0 +1 @@
+.iavic{-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:inline-block;font-style:normal;font-variant:normal;text-rendering:auto;line-height:1;}@font-face{font-family:"iav-custom-icons";font-style:normal;font-weight:900;font-display:auto;src:url(./iav-icons.woff)format("woff"),url(./iav-icons.ttf)format("truetype"),url(./iav-icons.svg)format("svg");}.iavic{font-family:"iav-custom-icons";}.iavic-translation:before{content:"t";}.iavic-scaling:before{content:"s";}.iavic-rotation:before{content:"r";}
\ No newline at end of file
diff --git a/src/res/icons/iav-icons.svg b/src/res/icons/iav-icons.svg
new file mode 100644
index 000000000..44d028ac6
--- /dev/null
+++ b/src/res/icons/iav-icons.svg
@@ -0,0 +1,49 @@
+<?xml version="1.0" standalone="no"?>
+<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd" >
+<!--
+2020-7-14: Created with FontForge (http://fontforge.org)
+-->
+<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1">
+<metadata>
+Created by FontForge 20170924 at Tue Jul 14 11:59:31 2020
+ By Xiao
+Copyright (c) 2020, Xiao
+</metadata>
+<defs>
+<font id="Untitled1" horiz-adv-x="1000" >
+  <font-face 
+    font-family="Untitled1"
+    font-weight="400"
+    font-stretch="normal"
+    units-per-em="1000"
+    panose-1="2 0 5 9 0 0 0 0 0 0"
+    ascent="800"
+    descent="-200"
+    bbox="86.0146 -103.857 934.173 741.024"
+    underline-thickness="50"
+    underline-position="-100"
+    unicode-range="U+0072-0074"
+  />
+    <missing-glyph />
+    <glyph glyph-name="t" unicode="t" 
+d="M352.722 741.024h125.001c17.2588 0 31.25 -13.9912 31.25 -31.25s-13.9912 -31.25 -31.25 -31.25h-125.001c-17.2588 0 -31.25 13.9912 -31.25 31.25s13.9912 31.25 31.25 31.25zM602.723 741.024h124.999c17.2588 0 31.25 -13.9912 31.25 -31.25
+s-13.9912 -31.25 -31.25 -31.25h-124.999c-17.2588 0 -31.25 13.9912 -31.25 31.25s13.9912 31.25 31.25 31.25zM852.722 741.024h50.2031l31.248 -31.25v-74.79c0 -17.2578 -13.9902 -31.249 -31.248 -31.25c-17.2588 0 -31.25 13.9912 -31.25 31.25v43.54h-18.9531
+c-17.2588 0 -31.25 13.9912 -31.25 31.25s13.9912 31.25 31.25 31.25zM352.722 665.211c17.2588 0 31.25 -13.9912 31.25 -31.25v-35.1641h351.471l31.25 -31.25v-379.723c10.9238 -5.16602 17.8906 -16.167 17.8906 -28.251s-6.9668 -23.084 -17.8906 -28.25v-113.977
+l-31.25 -31.25h-550.2l-31.25 31.25v550.2l31.25 31.25h136.229v35.1641c0 17.2588 13.9912 31.25 31.25 31.25zM902.925 541.234c17.2578 -0.000976562 31.248 -13.9922 31.248 -31.25v-125.001c0 -17.2578 -13.9902 -31.249 -31.248 -31.25
+c-17.2588 0 -31.25 13.9912 -31.25 31.25v125.001c0 17.2588 13.9912 31.25 31.25 31.25zM216.492 536.297v-487.7h487.7v487.7h-320.221h-62.5h-104.979zM902.925 291.233c17.2578 -0.000976562 31.248 -13.9922 31.248 -31.25v-100.41l-31.248 -31.25h-24.5908
+c-17.2588 0 -31.25 13.9912 -31.25 31.25c-0.000976562 14.6934 10.2344 27.4023 24.5908 30.5342v69.876c0 17.2588 13.9912 31.25 31.25 31.25z" />
+    <glyph glyph-name="s" unicode="s" 
+d="M213.774 605.359h62.501v-62.5h-31.25v-44.5625h-62.501v62.498h31.25v44.5645zM338.775 605.359h62.5v-62.5h-62.5v62.5zM463.775 605.359h62.501v-62.5h-62.501v62.5zM588.776 605.359h62.5v-62.5h-62.5v62.5zM713.774 605.359h81.4531v-43.5498h-62.5v-18.9502
+h-18.9531v62.5zM732.728 499.31h62.5v-62.5h-62.5v62.5zM182.524 435.796h62.501v-62.5h-62.501v62.5zM732.728 374.31h62.5v-62.498h-62.5v62.498zM213.774 355.732h300.575l31.251 -31.25v-300.582l-31.251 -31.25h-24.9619h-62.5h-62.5h-62.5h-62.501h-25.6123h-31.25
+v31.25v36.8945v62.5v62.5v62.501v62.5v13.6865zM245.025 293.231v-44.9355v-62.501v-62.5v-62.5v-5.64453h56.8623h62.5h62.5h56.2119v238.081h-238.074zM732.728 249.311h62.5v-62.5h-62.5v62.5zM732.728 124.311h62.5v-62.5h-62.5v62.5zM551.888 55.1504h62.501v-62.5
+h-62.501v62.5zM676.887 55.1504h62.5v-62.5h-62.5v62.5z" />
+    <glyph glyph-name="r" unicode="r" 
+d="M376.741 717.487l43.3037 -25.001l10.8232 -6.24902l16.2402 -9.37695l118.515 -68.4229h-125.001l-24.7637 14.2979l-16.2402 9.37695l-13.668 -23.6748h-72.1709l47.3359 81.9863zM213.774 605.359h33.6182v-0.302734h193.229v0.258789
+c102.103 -0.0839844 216.106 -0.251953 323.355 0.0439453l31.25 -31.25v-98.2334l3.7041 -2.13965l-3.7041 -6.41504v-125.413l26.7588 46.3477l-0.179688 0.102539l31.25 54.1279l27.0635 -15.624l0.179688 -0.103516l11.4375 -42.6895l-96.5098 -167.159v-193.01
+l-31.25 -31.25h-131.371l24.8594 -14.3525l-15.626 -27.0635l-25.2031 -43.6523l-42.6895 -11.4395l-167.155 96.5078h-193.018l-31.25 31.25v13.5654h0.00683594v3.9082v189.323h-0.0224609c-0.046875 113.932 -0.269531 228.598 0.015625 343.412zM245.025 542.859
+v-67.8027l47.9375 -27.6777l-15.626 -27.0635l-32.3115 -55.9658v-309.199h26.5625v-0.191406h193.229v0.191406h74.6807h109.854h52.4824h30.8926v3.38184v50.126l-0.0664062 -0.115234v124.996l0.0664062 0.115234v115.976v90.1611v72.1689v30.8994h-3.38086h-50.1387
+l50.1387 -28.9473v-72.1689l-175.139 101.116h-206.121l-8.25 -14.29l-15.624 -27.0635l-54.127 31.25l5.83203 10.1035h-30.8926zM178.913 374.842v-125l-1.13184 -1.96191l-22.0156 -38.1299l23.3838 -13.5v-72.1699l-81.6973 47.167l-11.4375 42.6895l91.4434 158.385z
+M729.279 227.684v-124.996l-24.9395 -43.1982l-0.553711 -0.957031h-60.2891l-8.9082 5.14355l15.626 27.0635zM297.022 128.194l27.0635 -15.624l93.9258 -54.2285h-125l-0.175781 0.101562l-27.0635 15.626zM531.793 -7.34961l46.3408 -26.7549l9.58105 16.5898
+l5.86816 10.165h-61.79z" />
+  </font>
+</defs></svg>
diff --git a/src/res/icons/iav-icons.ttf b/src/res/icons/iav-icons.ttf
new file mode 100644
index 0000000000000000000000000000000000000000..82fac191300d11dfe084c9733824a08346c152de
GIT binary patch
literal 2248
zcmd5;Uu;uV82`?>xA(T&?)q<C>AL0KQnmu?w(fRY2W)pl*jzva28=laShupxY~9io
zWr<BRXkyd{j4wcp`d|W4gJDMEgHbUt#3($e56FWr;!MN`4MvSy{hiw~ATj#lgXi|U
z=lA`-?|kPwf9^RYMnoDtMH1~97}&q-#eHvnMC5!MZ2j(iZRYTSaW4@Yf&R$YOnOf8
zyL9MZK<*oRJa15hFAzx{*yV}z{9Lh!NaTD2x^rTB;pnfQ4t@svI>^?^OnN-D>)aG<
z*CAb#Ae0}ZXA!Fg`nt)P{PC(RLoD__^qT3}u{1x<vS=&p)ideib2LmRVef`+WYaU5
z)abjTM9Mf3_sq@C=c$`sK-YQLTS<%!qHTEVl_Tz+TU046fuV1b=84rhQamM{<u{-^
zi3=75ZTOAiDH<*LOK0s!C0pq&+l)d-sM;n(OJ;Lh(XS}7w8T!51CgHRA3%SxRI_iX
zoxz)v!)5!4m&kLq>^a&$j`he<UNVZ^G>Y6NVYGetA=}L$hRh-Yiwq&dbdgRAwJi1J
zm_1-b%X*T@KrQ1DdLHXUlq(jCFO@xsDR&YP8LrL-pj||}|GY>trs)4v?EOp|?dLqJ
zW3MAQF6NqT<YzFODz#o<)Yh}8%5>Abpg6AgEJ_@ZE=YoQ2zpUf*q=R%n8urC(i`!{
zlHO>9xt1<p=4Y0VMmRnvm4>nNp5#}lg4R<%JxKfMA;S7HU5d6bHJVblFf$np1l2$v
z)0rAjqd_;1MPt33r$D=zcZ;J}X=cGdEb3;llp1gYx3QE1uCY|3&Z03#u#d5Y=1R{K
zg^;Iuu<hl@CqEw4WjU;etJ3<3HSSRJ*-JWOR>EV1FYU;7>auCRbJgkTQqrt8I8^yC
zUmxmqx>sHcA1;JhMQeq^uY?p=zuUED=z#txR|~COZV|&BZbn2+{*Xnw^zHTG?v>AF
zvydMh)Efpf)nUEjT!A+sgXULH7UGU@qdVo<8}?M<`?*;BO{(XIF(Z}aCO?I!0rTC6
zFL@i?PdjNh?IZFh1JOXVGnqntw*;a=Fb+tgkVw$0HY>eKutDA;bqZ4eqC!NYuPxou
z3zk*>?X~=V%UZr>S-c7L?<{T@A*;{o3+dJ-tFQYH3*|lAogcDV`r<;jtY&}QVtvet
z8!KPxdZTEd=`E;~pW=9{aKWBY>2&dD`(&x4AT`lu8pIkO#`-4B+8Qj|+NO@K$UQh1
zs8QB7^|Gii$!2W>!*FVAu=0_ZH<j${u(_IQ;n2%E8nLk=QJYi2baq%Q)!D()1<mKv
z3Yy=~)VrXm`|5mtuq#z{K6b?L`Hbajy8ayBROfTLotkfXjxDWx+$VHBr1_L8m4AmO
zt3Q3Gh#QCgfKQ9+E6=!MuAHv(m>$(0Lx-+vr|4E&39;{Q`LuDvuc?}g4QS%)uBP+1
z&ly@nW*IYb;RG$6D;zVnP{tBg|4JFl<YH<WJIKS5WvqZ75vQ9h&d~&<gc<p;XG)l(
z->EW|Xa_xA#xi_<DPsp2%v;6^`Pg>sx>=e-E;+QFz}cH817GMEZ9r|JCn0g*5!lo4
zrERlw3%RL@$-J?CY=dDY%tYK6nM%WQfU;;l1(~J{jZ-_QY<?;~of!ul0yja&U`wMj
z8p=!@n@$4^AgE|3>Kr^WcE_#g*1$G0{w8XPZ>J7wp%mnHnlvz*%@54xCNhTEnlLsS
ztGxraceJEhM7IBy=P)wJ(LBZ>@-mP|0wWRmh{qrr&gAB&X0t{j(cYR!B*6Uhz{~e+
n@dOgRbLjw<3vME;GDnnQI%snY_f_eRh5FUae)0d{o_qW+Fegse

literal 0
HcmV?d00001

diff --git a/src/res/icons/iav-icons.woff b/src/res/icons/iav-icons.woff
new file mode 100644
index 0000000000000000000000000000000000000000..4bd1adeada89636b8d5df577cbd7d6fea63d58bc
GIT binary patch
literal 2428
zcmZXWc|6qX7stO7W*B2DOI)t8lm<l+#=bSUbZ2Dj+hDAjL1ZW<gHVQKn!=S^F$~F4
zmbl0=O~N2iie$?&Hzg`d#qZm__rKrsdc9xI^EuBs&v`xP{BtN+3<itGV*x-U34jCO
zlH3nKe(wLjY%mxk00>9}0Mr}+L`BjwTMIB4{7Ent4|*$rDAHZ39${T{jsXA!2kPHI
z2yS?yZV)LT8UXgRf!YkbvxZ1O6~cl8h@k!qaumcsp2iLj1C8MQAyEGcq7GdYNDm{$
zC4f1=cmVMe;SAs-DIfvV5PMKV|3MH3kON4;psg4L3FeYC^m^bG9Tgh~p1*@WvLMLa
z3_vfTIEX+b5P(41_uhpB>L0a;$pM`dRYY@6PSH%<_-^4qe?iHf7Da>;(izam68%|@
z|6<N<UpQzZy)Ftx68yNGy(#blAR$-q4CnxW-xd7VFM!%*M58fjw94#o2>}5ciS&@9
zPC{?5pmZ?d9We!hfvQX9EfjSRcj7p>?&{UIsVbM3Q8va-VlLWwIKUbMB=ZpZKi|5T
z%Zuo?l)g9=hQE)xclSuB3r;s6AD-&%C>yVVzprJLX(YK<ey%&%pB*()u`K%8sW|@m
zMS&aNct1>Fol52^(aBfr%|z1^HYR(7<%W_?XZmAPaCB3NXq^%>3C|%kDmBkyjD(im
zKQ|V8rIj12d^#yX+-Q9z5kUQFDsfa+$K!U_RX=TtqvEi2V5(C20E+1|(2M>i6j~pV
zD|fojMoZ(bN+;K<kYk2ICQ<Ab@_rfpul62Q-p}36VJGX{W(WMNjz-2M*1)Z~rR1UD
zevvmKPp&aNj_vrjzt}e*70|WWc&WN_qPm`SJ-mAU)J`RXk=T$`JmGELT<uvrPU%qp
zsQEj`H@>89>?^UzOOwg@4V5@IEn#x<_t2j`ArL}R2=Y)2RI(1Tw!bS$7Al0~?MX*c
zpYHBj-e20?-Ti@MBIuC_-GfRHwS9VTRybn7!`m?J|9Tn%r0wz$7|Y97Az}b<$Q9D^
zv+j*<=ObN$r7fC$m9HIp&CJaeGhnOg=G~YTp#5@9Py=r3kaZPEy^4b15tnUh=!eSF
zQlw<$uON+ZiMAz2P<}}J4Am?|pyhHN1m3+rQY+~1Pm~YsZ-8g%7L&@MizQD!ns%%w
zSHM|id3O$#IJ=ZDV*mW!&6z42x4-@Crx(&g_*u`Ug!AW3ubrBA)$IQAqm~y(bhi3i
zTh(7yX8QsA^z~3Xg;$Rcq!~MZD0Qi5--_7DW|S|+6%HS-z}A|#w=U8Ll`R@YI?&=f
zCFP-E(yT0s#<$?bQ`ndG`sV6YwxutdY*(Ir-o_>Qs?O65286kpJ`*Fl9A=;5u1}Bx
zTS_am8E)w7UeLsI?izGe@nNNT+s3<1W$`0TaJOKEce(t53LTo_c4~p)_zYU#{fchm
zc7DNYs*uK8Ag3i>NdLCk^pU8HNZCrMg$>b^opB;_YlO`9rl+-*!-#`ct!XV3RP@V|
zQAv$*h86PN3Sn_0-ONmV^3Y7%wCv__Ll0OnwATIRfEbDPM5NOl>+0+Ds!F80LF<Ig
z<pUd?agQf9KQxIT4_DBLlbJ)4d-GmsU9~Tlm<s*a9m;>OsjcWJwa-p?+}B`}{)fP+
z5g~%RoEKprv&-3p_g=iw@3!}eYd7&q!;_-dwN$DVfi;&)DZIW+R&w^}?%r+#QySLW
zqi8GXLceeK9hfqISWi3A+_Bi_)?tW(v!oe;3;ER94&2c=E*CqexkL$<Ci0^dn6d3f
zqj=R7D!S;RHcH`3zBk{IC$JIJG~aj>@dp+=!-;OnN}Lu{d{AYzozA-Q^^=$2Eg5-x
zX0x(X>jHaNwL%jX?+{^jAVyT?=?k5*_9SH^REStV#Oo?5_2VM^$27Sx_nz8W+PgHO
zv_J{laI-I5(68l@4&h9O+A@q^#^NoW?S-9OI44$L`e^QaxV+|~t)Q#^plzs|4q!+v
zjG6D$QWhuAzsyt8G(0VMo-Ci@J!6172e)6$1>B9T%STlU?yc{i{vP9miG6;cV94Gz
z>LFs@9On5WX45oZL#b@*jKOgL?yBNJR;E(|H-BH!n|j8W^OaS*3qVx)DkKw|vsC>6
zSD=+DQL1kIP-ZQWBv}M~f5UuC?QjhWR+;QsbIKe|ZX2BUv6Fr2bY`fZ^nySw%b8q#
z)ob`H?=$YbEUb_muCtwgU#+%Ft=S&iv%Xpr(Z%U#1fp_?P;~LAvGPmpSA`-DbM(M$
zz2I<nR`8}co}SV4-GoUBDq*O7Ppn#i<KybdM-RT{oPh?O4j4~XY1vbc?QOjUL@Vf<
zJ=vEfQ<(obcX~0Lx0Z;;BrkJ+=mrV|9ZC;($Im1^&5&6h>_jyWHOxJBA4N`L)oyTE
zJ;-6v24vk(mo++DE|((L7wv({m*U8<;awflEvx>FF~Y5?N@>Yr;um2wR#4K|J8D7f
zoT&@jG?i8re^LjBsVB!d9zP#1DmGTdO=Ed2{I>C!sC2zeomNHWT;hKra(ZliImPw6
zrn#a1g&*3`I~{c~Fs0LEvDE2YOKnedxt(1UqV{j<@~LVe%k~26BW9QpR>4Fux)?av
zXk4ZtHx$y_Xc1s!VurTpapcW(HXL?PzsTS-j_}jMR<kZezw($YYp;=Cr3L0NV@&F*
zHE(K)&)qT29y1tI<yJ^WjD?|kEj)MzO^oN$Cz%d(tV%g+M&RRn;|tqLmU4AF7p#Kf
zW1jon2>Mphk%mj8JQcnr&(BhcoAaNdw)C`y<UFobFx*)am~Q$!8a46oy`^+i_oY(Z
z!g{&CzGR>>N~t|Hjb}gHoodtbue3|QDg3Slm|cR-RzEjS<z}x45g0)o3)eLiL}E{N
zHrQ76dB4T2ADQR$Z4kF`4}bYOOFB0W5h1YFeKg*5NG_nO|N77n%%wjZkoYv5FGVR5
zCzBOhgr#b}5tjpf7&lHpWw#Dm_r#^y);SqCSuOF0c8+(AL^`alMX(j94Dx#j<p5UC
zWv(Clbnp>r=k}GHDT$H%_CK@Uttxv~ypU_SB-kT2`zh-|S|<G4*Wjq^z}kv|2c#`X
zZFBXz`z!rz_g2^SEe%dMh<ewCtTj>^BlohePe)}q<WT>e0SE*lka{=Dmy)tH!Nu@&
U6#&OGP&;sXTKWe!pb04aAAtlk3IG5A

literal 0
HcmV?d00001

diff --git a/src/res/icons/meta.json b/src/res/icons/meta.json
new file mode 100644
index 000000000..f9f030f4b
--- /dev/null
+++ b/src/res/icons/meta.json
@@ -0,0 +1,13 @@
+[{
+  "content": "t",
+  "class": "translation",
+  "svg": "./translation/glyph.svg"
+},{
+  "content": "s",
+  "class": "scaling",
+  "svg": "./scaling/glyph.svg"
+},{
+  "content": "r",
+  "class": "rotation",
+  "svg": "./rotation/glyph.svg"
+}]
\ No newline at end of file
diff --git a/src/res/icons/rotation/glyph.svg b/src/res/icons/rotation/glyph.svg
new file mode 100644
index 000000000..05d526682
--- /dev/null
+++ b/src/res/icons/rotation/glyph.svg
@@ -0,0 +1,81 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   inkscape:version="1.0 (6e3e5246a0, 2020-05-07)"
+   sodipodi:docname="rotate-path.svg"
+   id="svg859"
+   version="1.1"
+   viewBox="0 0 256 256"
+   height="967.55908"
+   width="967.55908">
+  <defs
+     id="defs853" />
+  <sodipodi:namedview
+     inkscape:window-maximized="0"
+     inkscape:window-y="27"
+     inkscape:window-x="167"
+     inkscape:window-height="1023"
+     inkscape:window-width="1454"
+     units="px"
+     showgrid="false"
+     inkscape:document-rotation="0"
+     inkscape:current-layer="layer1"
+     inkscape:document-units="mm"
+     inkscape:cy="927.73926"
+     inkscape:cx="773.00854"
+     inkscape:zoom="0.41362181"
+     inkscape:pageshadow="2"
+     inkscape:pageopacity="0.0"
+     borderopacity="1.0"
+     bordercolor="#666666"
+     pagecolor="#ffffff"
+     id="base" />
+  <metadata
+     id="metadata856">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title />
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     id="layer1"
+     inkscape:groupmode="layer"
+     inkscape:label="Layer 1">
+    <path
+       transform="scale(0.26458333)"
+       d="M 364.51953 79.835938 L 349.40039 106.02148 L 303.59961 185.34766 L 373.42969 185.34766 L 386.6543 162.44141 L 402.36719 171.51367 L 426.32812 185.34766 L 547.27344 185.34766 L 432.60352 119.14453 L 416.89062 110.07227 L 406.41797 104.02539 L 364.51953 79.835938 z M 206.83984 188.32617 L 176.60352 218.5625 C 176.32726 329.65197 176.54241 440.59812 176.58789 550.83398 L 176.60938 550.83398 L 176.60938 734.01562 L 176.60938 737.79688 L 176.60352 737.79688 L 176.60352 750.92188 L 206.83984 781.1582 L 393.5957 781.1582 L 555.32812 874.53516 L 596.63281 863.4668 L 621.01758 821.23047 L 636.13672 795.04492 L 612.08398 781.1582 L 739.19336 781.1582 L 769.42969 750.92188 L 769.42969 564.17383 L 862.80859 402.4375 L 851.74219 361.13281 L 851.56836 361.0332 L 825.38281 345.91602 L 795.14648 398.28711 L 795.32031 398.38672 L 769.42969 443.23047 L 769.42969 321.88672 L 773.01367 315.67969 L 769.42969 313.60938 L 769.42969 218.5625 L 739.19336 188.32617 C 635.4233 188.61216 525.11776 188.45039 426.32812 188.36914 L 426.32812 188.61914 L 239.36719 188.61914 L 239.36719 188.32617 L 206.83984 188.32617 z M 237.07617 248.79883 L 266.9668 248.79883 L 261.32422 258.57422 L 313.69531 288.81055 L 328.8125 262.625 L 336.79492 248.79883 L 536.22852 248.79883 L 705.68555 346.63477 L 705.68555 276.80664 L 657.17383 248.79883 L 705.68555 248.79883 L 708.95703 248.79883 L 708.95703 278.69531 L 708.95703 348.52344 L 708.95703 435.75977 L 708.95703 547.97266 L 708.89258 548.08398 L 708.89258 669.02539 L 708.95703 668.91406 L 708.95703 717.41406 L 708.95703 720.68555 L 679.06641 720.68555 L 628.28711 720.68555 L 521.99609 720.68555 L 449.73828 720.68555 L 449.73828 720.87109 L 262.77734 720.87109 L 262.77734 720.68555 L 237.07617 720.68555 L 237.07617 421.51758 L 268.33984 367.36719 L 283.45898 341.18164 L 237.07617 314.40234 L 237.07617 248.79883 z M 173.10938 411.36523 L 171.70117 413.80469 L 83.224609 567.05078 L 94.291016 608.35547 L 173.33789 653.99219 L 173.33789 584.16406 L 150.71289 571.10156 L 172.01367 534.20898 L 173.10938 532.31055 L 173.10938 411.36523 z M 705.62109 553.75 L 629.12109 686.25195 L 614.00195 712.4375 L 622.62109 717.41406 L 680.95508 717.41406 L 681.49023 716.48828 L 705.62109 674.69141 L 705.62109 553.75 z M 287.38672 650.01172 L 257.15039 702.38086 L 283.33594 717.5 L 283.50586 717.59766 L 404.45117 717.59766 L 313.57227 665.12891 L 287.38672 650.01172 z M 514.54102 781.1582 L 574.32617 781.1582 L 568.64844 790.99414 L 559.37891 807.04492 L 514.54102 781.1582 z "
+       style="color:#000000;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:medium;line-height:normal;font-family:sans-serif;font-variant-ligatures:normal;font-variant-position:normal;font-variant-caps:normal;font-variant-numeric:normal;font-variant-alternates:normal;font-variant-east-asian:normal;font-feature-settings:normal;font-variation-settings:normal;text-indent:0;text-align:start;text-decoration:none;text-decoration-line:none;text-decoration-style:solid;text-decoration-color:#000000;letter-spacing:normal;word-spacing:normal;text-transform:none;writing-mode:lr-tb;direction:ltr;text-orientation:mixed;dominant-baseline:auto;baseline-shift:baseline;text-anchor:start;white-space:normal;shape-padding:0;shape-margin:0;inline-size:0;clip-rule:nonzero;display:inline;overflow:visible;visibility:visible;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:#000000;solid-opacity:1;vector-effect:none;fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:60.4724;stroke-linecap:square;stroke-linejoin:bevel;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto;enable-background:accumulate;stop-color:#000000;stop-opacity:1"
+       id="path2731" />
+    <g
+       transform="matrix(0.41458666,0,0,1,39.693876,10.077571)"
+       style="opacity:1"
+       id="g2770" />
+    <g
+       id="g2770-3"
+       style="opacity:1"
+       transform="matrix(0,0.41458666,-1,0,277.19345,183.70791)" />
+    <g
+       transform="matrix(0,0.41458666,-1,0,202.41455,42.932035)"
+       style="opacity:1"
+       id="g2770-3-9" />
+    <g
+       transform="matrix(-0.41458666,0,0,-1,52.835984,284.82378)"
+       style="opacity:1"
+       id="g2770-3-7" />
+    <g
+       transform="matrix(0,0.41458666,-1,0,208.60837,183.75677)"
+       style="opacity:1"
+       id="g2770-3-3" />
+  </g>
+</svg>
diff --git a/src/res/icons/rotation/rotate.svg b/src/res/icons/rotation/rotate.svg
new file mode 100644
index 000000000..a6f7e3686
--- /dev/null
+++ b/src/res/icons/rotation/rotate.svg
@@ -0,0 +1,71 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   inkscape:version="1.0 (6e3e5246a0, 2020-05-07)"
+   sodipodi:docname="rotate.svg"
+   id="svg859"
+   version="1.1"
+   viewBox="0 0 256 256"
+   height="967.55908"
+   width="967.55908">
+  <defs
+     id="defs853" />
+  <sodipodi:namedview
+     inkscape:window-maximized="0"
+     inkscape:window-y="27"
+     inkscape:window-x="167"
+     inkscape:window-height="1023"
+     inkscape:window-width="1454"
+     units="px"
+     showgrid="false"
+     inkscape:document-rotation="0"
+     inkscape:current-layer="layer1"
+     inkscape:document-units="mm"
+     inkscape:cy="524.86583"
+     inkscape:cx="475.38605"
+     inkscape:zoom="0.80867634"
+     inkscape:pageshadow="2"
+     inkscape:pageopacity="0.0"
+     borderopacity="1.0"
+     bordercolor="#666666"
+     pagecolor="#ffffff"
+     id="base" />
+  <metadata
+     id="metadata856">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title />
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     id="layer1"
+     inkscape:groupmode="layer"
+     inkscape:label="Layer 1">
+    <rect
+       y="57.82893"
+       x="54.726311"
+       height="140.85201"
+       width="140.85201"
+       id="rect1422"
+       style="fill:none;stroke:#000000;stroke-width:16;stroke-miterlimit:4;stroke-dasharray:none;stroke-linejoin:bevel;stroke-linecap:square" />
+    <rect
+       style="fill:none;stroke:#000000;stroke-width:16.00000045;stroke-linecap:square;stroke-linejoin:bevel;stroke-miterlimit:4;stroke-dasharray:96.00000267,32.00000089;stroke-dashoffset:115.2000032;paint-order:normal"
+       id="rect1422-3"
+       width="140.85202"
+       height="140.85202"
+       x="102.08652"
+       y="-21.93014"
+       transform="rotate(30)" />
+  </g>
+</svg>
diff --git a/src/res/icons/scaling/glyph.svg b/src/res/icons/scaling/glyph.svg
new file mode 100644
index 000000000..b424bae66
--- /dev/null
+++ b/src/res/icons/scaling/glyph.svg
@@ -0,0 +1,61 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="967.55908"
+   height="967.55908"
+   viewBox="0 0 256 256"
+   version="1.1"
+   id="svg859"
+   sodipodi:docname="scale-path.svg"
+   inkscape:version="1.0 (6e3e5246a0, 2020-05-07)">
+  <defs
+     id="defs853" />
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="0.55038984"
+     inkscape:cx="762.47492"
+     inkscape:cy="532.00053"
+     inkscape:document-units="mm"
+     inkscape:current-layer="layer1"
+     inkscape:document-rotation="0"
+     showgrid="false"
+     units="px"
+     inkscape:window-width="1439"
+     inkscape:window-height="1023"
+     inkscape:window-x="167"
+     inkscape:window-y="27"
+     inkscape:window-maximized="0" />
+  <metadata
+     id="metadata856">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title></dc:title>
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     inkscape:label="Layer 1"
+     inkscape:groupmode="layer"
+     id="layer1">
+    <path
+       transform="scale(0.26458333)"
+       d="M 206.83984 188.32617 L 206.83984 231.44531 L 176.60352 231.44531 L 176.60352 291.91602 L 237.07617 291.91602 L 237.07617 248.79883 L 267.3125 248.79883 L 267.3125 188.32617 L 206.83984 188.32617 z M 327.78516 188.32617 L 327.78516 248.79883 L 388.25781 248.79883 L 388.25781 188.32617 L 327.78516 188.32617 z M 448.73047 188.32617 L 448.73047 248.79883 L 509.20312 248.79883 L 509.20312 188.32617 L 448.73047 188.32617 z M 569.67578 188.32617 L 569.67578 248.79883 L 630.14844 248.79883 L 630.14844 188.32617 L 569.67578 188.32617 z M 690.61914 188.32617 L 690.61914 248.79883 L 708.95703 248.79883 L 708.95703 230.46289 L 769.42969 230.46289 L 769.42969 188.32617 L 690.61914 188.32617 z M 708.95703 290.93555 L 708.95703 351.4082 L 769.42969 351.4082 L 769.42969 290.93555 L 708.95703 290.93555 z M 176.60352 352.38867 L 176.60352 412.86133 L 237.07617 412.86133 L 237.07617 352.38867 L 176.60352 352.38867 z M 708.95703 411.88086 L 708.95703 472.35156 L 769.42969 472.35156 L 769.42969 411.88086 L 708.95703 411.88086 z M 206.83984 429.85547 L 176.60352 460.0918 L 176.60352 473.33398 L 176.60352 533.80664 L 176.60352 594.2793 L 176.60352 654.75195 L 176.60352 715.22461 L 176.60352 750.92188 L 176.60352 781.1582 L 206.83984 781.1582 L 231.62109 781.1582 L 292.09375 781.1582 L 352.56641 781.1582 L 413.03906 781.1582 L 473.51172 781.1582 L 497.66406 781.1582 L 527.90039 750.92188 L 527.90039 460.0918 L 497.66406 429.85547 L 206.83984 429.85547 z M 237.07617 490.32812 L 467.42773 490.32812 L 467.42773 720.68555 L 413.03906 720.68555 L 352.56641 720.68555 L 292.09375 720.68555 L 237.07617 720.68555 L 237.07617 715.22461 L 237.07617 654.75195 L 237.07617 594.2793 L 237.07617 533.80664 L 237.07617 490.32812 z M 708.95703 532.82422 L 708.95703 593.29688 L 769.42969 593.29688 L 769.42969 532.82422 L 708.95703 532.82422 z M 708.95703 653.76953 L 708.95703 714.24219 L 769.42969 714.24219 L 769.42969 653.76953 L 708.95703 653.76953 z M 533.98438 720.68555 L 533.98438 781.1582 L 594.45703 781.1582 L 594.45703 720.68555 L 533.98438 720.68555 z M 654.92773 720.68555 L 654.92773 781.1582 L 715.40039 781.1582 L 715.40039 720.68555 L 654.92773 720.68555 z "
+       style="color:#000000;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:medium;line-height:normal;font-family:sans-serif;font-variant-ligatures:normal;font-variant-position:normal;font-variant-caps:normal;font-variant-numeric:normal;font-variant-alternates:normal;font-variant-east-asian:normal;font-feature-settings:normal;font-variation-settings:normal;text-indent:0;text-align:start;text-decoration:none;text-decoration-line:none;text-decoration-style:solid;text-decoration-color:#000000;letter-spacing:normal;word-spacing:normal;text-transform:none;writing-mode:lr-tb;direction:ltr;text-orientation:mixed;dominant-baseline:auto;baseline-shift:baseline;text-anchor:start;white-space:normal;shape-padding:0;shape-margin:0;inline-size:0;clip-rule:nonzero;display:inline;overflow:visible;visibility:visible;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:#000000;solid-opacity:1;vector-effect:none;fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:60.4724;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:60.4724, 60.4724;stroke-dashoffset:0;stroke-opacity:1;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto;enable-background:accumulate;stop-color:#000000;stop-opacity:1"
+       id="path2082" />
+  </g>
+</svg>
diff --git a/src/res/icons/scaling/scale.svg b/src/res/icons/scaling/scale.svg
new file mode 100644
index 000000000..55cb0489c
--- /dev/null
+++ b/src/res/icons/scaling/scale.svg
@@ -0,0 +1,70 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="967.55908"
+   height="967.55908"
+   viewBox="0 0 256 256"
+   version="1.1"
+   id="svg859"
+   sodipodi:docname="scale.svg"
+   inkscape:version="1.0 (6e3e5246a0, 2020-05-07)">
+  <defs
+     id="defs853" />
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="0.55038984"
+     inkscape:cx="762.47492"
+     inkscape:cy="532.00053"
+     inkscape:document-units="mm"
+     inkscape:current-layer="layer1"
+     inkscape:document-rotation="0"
+     showgrid="false"
+     units="px"
+     inkscape:window-width="1439"
+     inkscape:window-height="1023"
+     inkscape:window-x="167"
+     inkscape:window-y="27"
+     inkscape:window-maximized="0" />
+  <metadata
+     id="metadata856">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title />
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     inkscape:label="Layer 1"
+     inkscape:groupmode="layer"
+     id="layer1">
+    <rect
+       style="fill:none;stroke:#000000;stroke-width:16.00000045;stroke-miterlimit:4;stroke-dasharray:16.00000045, 16.00000045000000171;stroke-linejoin:miter;stroke-linecap:butt;stroke-dashoffset:0"
+       id="rect1422"
+       width="140.85201"
+       height="140.85201"
+       x="54.726311"
+       y="57.82893" />
+    <rect
+       y="121.73264"
+       x="54.726311"
+       height="76.948296"
+       width="76.948296"
+       id="rect1422-5"
+       style="fill:none;stroke:#000000;stroke-width:16.00000045;stroke-linecap:round;stroke-linejoin:bevel;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:160.00000445" />
+  </g>
+</svg>
diff --git a/src/res/icons/translation/glyph.svg b/src/res/icons/translation/glyph.svg
new file mode 100644
index 000000000..6ad4b46f8
--- /dev/null
+++ b/src/res/icons/translation/glyph.svg
@@ -0,0 +1,62 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   inkscape:version="1.0 (6e3e5246a0, 2020-05-07)"
+   sodipodi:docname="translate-path.svg"
+   id="svg859"
+   version="1.1"
+   viewBox="0 0 256 256"
+   height="967.55908"
+   width="967.55908">
+  <defs
+     id="defs853" />
+  <sodipodi:namedview
+     inkscape:window-maximized="0"
+     inkscape:window-y="27"
+     inkscape:window-x="167"
+     inkscape:window-height="1023"
+     inkscape:window-width="1439"
+     units="px"
+     showgrid="false"
+     inkscape:document-rotation="0"
+     inkscape:current-layer="layer1"
+     inkscape:document-units="mm"
+     inkscape:cy="660.97322"
+     inkscape:cx="709.31124"
+     inkscape:zoom="0.64903721"
+     inkscape:pageshadow="2"
+     inkscape:pageopacity="0.0"
+     borderopacity="1.0"
+     bordercolor="#666666"
+     pagecolor="#ffffff"
+     id="base" />
+  <metadata
+     id="metadata856">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title></dc:title>
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     id="layer1"
+     inkscape:groupmode="layer"
+     inkscape:label="Layer 1">
+    <path
+       sodipodi:nodetypes="cccccccccccsccssscsccccsccccccccccsccccccccccccccccccccccccscccc"
+       transform="scale(0.26458333)"
+       d="m 341.2793,57.0625 c -16.69909,-6.1e-5 -30.23639,13.53724 -30.23633,30.236328 -6e-5,16.699092 13.53724,30.236392 30.23633,30.236332 h 120.94531 c 16.69909,6e-5 30.23639,-13.53724 30.23633,-30.236332 C 492.461,70.59974 478.9237,57.062439 462.22461,57.0625 Z m 241.89062,0 c -16.69909,-6.1e-5 -30.23639,13.53724 -30.23633,30.236328 -6e-5,16.699092 13.53724,30.236392 30.23633,30.236332 h 120.94336 c 16.69909,6e-5 30.23639,-13.53724 30.23633,-30.236332 6e-5,-16.699088 -13.53724,-30.236389 -30.23633,-30.236328 z m 241.88867,0 c -16.69908,-5.5e-5 -30.23638,13.537244 -30.23632,30.236328 -6e-5,16.699082 13.53723,30.236392 30.23632,30.236332 h 18.33789 v 42.12695 c -6e-5,16.69909 13.53724,30.23639 30.23633,30.23633 16.69833,-0.001 30.23444,-13.538 30.23438,-30.23633 V 87.298828 L 873.63281,57.0625 Z M 341.2793,130.41602 c -16.69909,-6e-5 -30.23639,13.53723 -30.23633,30.23632 v 34.02344 H 179.23242 l -30.23633,30.23633 V 757.26367 L 179.23242,787.5 h 532.35156 l 30.23633,-30.23633 V 646.98438 c 10.56967,-4.99815 17.31049,-15.64214 17.31055,-27.33399 -7e-5,-11.69185 -6.74088,-22.33584 -17.31055,-27.33398 V 224.91211 L 711.58398,194.67578 H 371.51562 v -34.02344 c 6e-5,-16.69908 -13.53724,-30.23638 -30.23632,-30.23632 z m 532.35351,119.95507 c -16.69909,-6e-5 -30.23639,13.53724 -30.23633,30.23633 v 120.94531 c -6e-5,16.69909 13.53724,30.23639 30.23633,30.23633 16.69833,-0.001 30.23444,-13.538 30.23438,-30.23633 V 280.60742 c 6e-5,-16.69833 -13.53605,-30.23531 -30.23438,-30.23633 z m -664.16406,4.77735 h 101.57422 60.47265 309.83204 c 0,157.29297 0,314.58593 0,471.8789 H 209.46875 Z m 664.16406,237.11328 c -16.69909,-6e-5 -30.23639,13.53724 -30.23633,30.23633 v 67.60937 c -13.89006,3.02952 -23.79355,15.32637 -23.79296,29.54297 -6e-5,16.69909 13.53723,30.23639 30.23632,30.23633 h 23.79297 l 30.23438,-30.23633 v -97.15234 c 6e-5,-16.69833 -13.53605,-30.23531 -30.23438,-30.23633 z"
+       style="color:#000000;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:medium;line-height:normal;font-family:sans-serif;font-variant-ligatures:normal;font-variant-position:normal;font-variant-caps:normal;font-variant-numeric:normal;font-variant-alternates:normal;font-variant-east-asian:normal;font-feature-settings:normal;font-variation-settings:normal;text-indent:0;text-align:start;text-decoration:none;text-decoration-line:none;text-decoration-style:solid;text-decoration-color:#000000;letter-spacing:normal;word-spacing:normal;text-transform:none;writing-mode:lr-tb;direction:ltr;text-orientation:mixed;dominant-baseline:auto;baseline-shift:baseline;text-anchor:start;white-space:normal;shape-padding:0;shape-margin:0;inline-size:0;clip-rule:nonzero;display:inline;overflow:visible;visibility:visible;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:#000000;solid-opacity:1;vector-effect:none;fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:60.4724;stroke-linecap:square;stroke-linejoin:bevel;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto;enable-background:accumulate;stop-color:#000000;stop-opacity:1"
+       id="path1503" />
+  </g>
+</svg>
diff --git a/src/res/icons/translation/translate.svg b/src/res/icons/translation/translate.svg
new file mode 100644
index 000000000..ea35709ae
--- /dev/null
+++ b/src/res/icons/translation/translate.svg
@@ -0,0 +1,70 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   inkscape:version="1.0 (6e3e5246a0, 2020-05-07)"
+   sodipodi:docname="translate.svg"
+   id="svg859"
+   version="1.1"
+   viewBox="0 0 256 256"
+   height="967.55908"
+   width="967.55908">
+  <defs
+     id="defs853" />
+  <sodipodi:namedview
+     inkscape:window-maximized="0"
+     inkscape:window-y="27"
+     inkscape:window-x="167"
+     inkscape:window-height="1023"
+     inkscape:window-width="1439"
+     units="px"
+     showgrid="false"
+     inkscape:document-rotation="0"
+     inkscape:current-layer="layer1"
+     inkscape:document-units="mm"
+     inkscape:cy="554.88327"
+     inkscape:cx="827.69499"
+     inkscape:zoom="0.6470145"
+     inkscape:pageshadow="2"
+     inkscape:pageopacity="0.0"
+     borderopacity="1.0"
+     bordercolor="#666666"
+     pagecolor="#ffffff"
+     id="base" />
+  <metadata
+     id="metadata856">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title />
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     id="layer1"
+     inkscape:groupmode="layer"
+     inkscape:label="Layer 1">
+    <rect
+       y="59.508263"
+       x="47.422356"
+       height="140.85201"
+       width="140.85201"
+       id="rect1422"
+       style="fill:none;stroke:#000000;stroke-width:16;stroke-linecap:square;stroke-linejoin:bevel;stroke-miterlimit:4;stroke-dasharray:none" />
+    <rect
+       style="fill:none;stroke:#000000;stroke-width:16;stroke-linecap:round;stroke-linejoin:bevel;stroke-miterlimit:4;stroke-dasharray:32, 32;stroke-dashoffset:0"
+       id="rect1422-6"
+       width="140.85202"
+       height="140.85202"
+       x="90.29702"
+       y="23.096846" />
+  </g>
+</svg>
diff --git a/src/ui/nehubaContainer/statusCard/statusCard.template.html b/src/ui/nehubaContainer/statusCard/statusCard.template.html
index 13ce5d4e1..b6d1577d5 100644
--- a/src/ui/nehubaContainer/statusCard/statusCard.template.html
+++ b/src/ui/nehubaContainer/statusCard/statusCard.template.html
@@ -13,21 +13,21 @@
         mat-icon-button
         (click)="resetNavigation({position:true})"
         matTooltip="Reset position">
-        <i class="fas fa-crosshairs"></i>
+        <i class="iavic iavic-translation"></i>
       </button>
 
       <button
         mat-icon-button
         (click)="resetNavigation({rotation:true})"
         matTooltip="Reset rotation">
-        <i class="fas fa-compass"></i>
+        <i class="iavic iavic-rotation"></i>
       </button>
 
       <button
         mat-icon-button
         (click)="resetNavigation({zoom:true})"
         matTooltip="Reset zoom">
-        <i class="fas fa-search-plus"></i>
+        <i class="iavic iavic-scaling"></i>
       </button>
 
       <mat-divider [vertical]="true"></mat-divider>
-- 
GitLab