commit
2f475ed9c0
|
@ -33,10 +33,16 @@ module.exports = {
|
||||||
"sonarjs/cognitive-complexity": [ "warn", 200 ],
|
"sonarjs/cognitive-complexity": [ "warn", 200 ],
|
||||||
/** @todo no param reassign creates too many warnings but should be a warning */
|
/** @todo no param reassign creates too many warnings but should be a warning */
|
||||||
"no-param-reassign": "off",
|
"no-param-reassign": "off",
|
||||||
|
/** @todo no use before define creates too many warnings but should be a warning */
|
||||||
|
"no-use-before-define": "off",
|
||||||
|
/** @todo camel case creates too many warnings but should be a warning */
|
||||||
|
"camelcase": "off",
|
||||||
|
"comma-dangle": [ "error" ],
|
||||||
"node/no-unsupported-features/es-syntax": 0,
|
"node/no-unsupported-features/es-syntax": 0,
|
||||||
"no-unused-vars": [ "error", { "argsIgnorePattern": "^_" } ],
|
"no-unused-vars": [ "error", { "argsIgnorePattern": "^_" } ],
|
||||||
"sonarjs/no-duplicate-string": 0,
|
"sonarjs/no-duplicate-string": 0,
|
||||||
"semi" : "error",
|
"semi" : "error",
|
||||||
|
"prefer-const": "error",
|
||||||
"no-trailing-spaces": "error",
|
"no-trailing-spaces": "error",
|
||||||
"array-bracket-spacing": [ "error", "always" ],
|
"array-bracket-spacing": [ "error", "always" ],
|
||||||
"comma-spacing": "error",
|
"comma-spacing": "error",
|
||||||
|
@ -45,7 +51,7 @@ module.exports = {
|
||||||
"warn",
|
"warn",
|
||||||
{ "allow": [ "warn", "error", "info", "table" ] }
|
{ "allow": [ "warn", "error", "info", "table" ] }
|
||||||
],
|
],
|
||||||
"arrow-parens": [ "error", "always" ],
|
"arrow-parens": [ "error", "always" ]
|
||||||
},
|
},
|
||||||
overrides: [
|
overrides: [
|
||||||
{
|
{
|
||||||
|
@ -85,6 +91,7 @@ module.exports = {
|
||||||
files: [ 'src/editor/locale/*.js' ],
|
files: [ 'src/editor/locale/*.js' ],
|
||||||
rules: { // lang files may have long length
|
rules: { // lang files may have long length
|
||||||
"max-len": "off",
|
"max-len": "off",
|
||||||
|
"camelcase": "off"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
<svg xmlns="http://www.w3.org/2000/svg" width="97" height="20"><defs><style>text{font-size:11px;font-family:Verdana,DejaVu Sans,Geneva,sans-serif}text.shadow{fill:#010101;fill-opacity:.3}text.high{fill:#fff}</style><linearGradient id="smooth" x2="0" y2="100%"><stop offset="0" stop-color="#aaa" stop-opacity=".1"/><stop offset="1" stop-opacity=".1"/></linearGradient><mask id="round"><rect width="100%" height="100%" rx="3" fill="#fff"/></mask></defs><g id="bg" mask="url(#round)"><path fill="#696969" d="M0 0h41v20H0z"/><path fill="#4c1" d="M41 0h56v20H41z"/><path fill="url(#smooth)" d="M0 0h97v20H0z"/></g><g id="fg"><text class="shadow" x="5.5" y="15">Tests</text><text class="high" x="5" y="14">Tests</text><text class="shadow" x="46.5" y="15">139/139</text><text class="high" x="46" y="14">139/139</text></g></svg>
|
<svg xmlns="http://www.w3.org/2000/svg" width="97" height="20"><defs><style>text{font-size:11px;font-family:Verdana,DejaVu Sans,Geneva,sans-serif}text.shadow{fill:#010101;fill-opacity:.3}text.high{fill:#fff}</style><linearGradient id="smooth" x2="0" y2="100%"><stop offset="0" stop-color="#aaa" stop-opacity=".1"/><stop offset="1" stop-opacity=".1"/></linearGradient><mask id="round"><rect width="100%" height="100%" rx="3" fill="#fff"/></mask></defs><g id="bg" mask="url(#round)"><path fill="#696969" d="M0 0h41v20H0z"/><path fill="#4c1" d="M41 0h56v20H41z"/><path fill="url(#smooth)" d="M0 0h97v20H0z"/></g><g id="fg"><text class="shadow" x="5.5" y="15">Tests</text><text class="high" x="5" y="14">Tests</text><text class="shadow" x="46.5" y="15">141/141</text><text class="high" x="46" y="14">141/141</text></g></svg>
|
Before Width: | Height: | Size: 820 B After Width: | Height: | Size: 820 B |
|
@ -221,7 +221,6 @@ exports[`use various parts of svg-edit > check tool_italic #0`] = `
|
||||||
fill-opacity="1"
|
fill-opacity="1"
|
||||||
stroke-opacity="1"
|
stroke-opacity="1"
|
||||||
id="svg_2"
|
id="svg_2"
|
||||||
transform="matrix(1 0 0 1 0 0)"
|
|
||||||
>
|
>
|
||||||
AB
|
AB
|
||||||
</text>
|
</text>
|
||||||
|
@ -286,7 +285,6 @@ exports[`use various parts of svg-edit > check tool_bold #0`] = `
|
||||||
fill-opacity="1"
|
fill-opacity="1"
|
||||||
stroke-opacity="1"
|
stroke-opacity="1"
|
||||||
id="svg_2"
|
id="svg_2"
|
||||||
transform="matrix(1 0 0 1 0 0)"
|
|
||||||
>
|
>
|
||||||
AB
|
AB
|
||||||
</text>
|
</text>
|
||||||
|
@ -351,7 +349,6 @@ exports[`use various parts of svg-edit > check change color #0`] = `
|
||||||
fill-opacity="1"
|
fill-opacity="1"
|
||||||
stroke-opacity="1"
|
stroke-opacity="1"
|
||||||
id="svg_2"
|
id="svg_2"
|
||||||
transform="matrix(1 0 0 1 0 0)"
|
|
||||||
>
|
>
|
||||||
AB
|
AB
|
||||||
</text>
|
</text>
|
||||||
|
@ -416,7 +413,6 @@ exports[`use various parts of svg-edit > check tool_text_anchor_start #0`] = `
|
||||||
fill-opacity="1"
|
fill-opacity="1"
|
||||||
stroke-opacity="1"
|
stroke-opacity="1"
|
||||||
id="svg_2"
|
id="svg_2"
|
||||||
transform="matrix(1 0 0 1 0 0)"
|
|
||||||
>
|
>
|
||||||
AB
|
AB
|
||||||
</text>
|
</text>
|
||||||
|
@ -481,7 +477,6 @@ exports[`use various parts of svg-edit > check tool_text_anchor_middle #0`] = `
|
||||||
fill-opacity="1"
|
fill-opacity="1"
|
||||||
stroke-opacity="1"
|
stroke-opacity="1"
|
||||||
id="svg_2"
|
id="svg_2"
|
||||||
transform="matrix(1 0 0 1 0 0)"
|
|
||||||
>
|
>
|
||||||
AB
|
AB
|
||||||
</text>
|
</text>
|
||||||
|
@ -546,7 +541,6 @@ exports[`use various parts of svg-edit > check tool_text_anchor_end #0`] = `
|
||||||
fill-opacity="1"
|
fill-opacity="1"
|
||||||
stroke-opacity="1"
|
stroke-opacity="1"
|
||||||
id="svg_2"
|
id="svg_2"
|
||||||
transform="matrix(1 0 0 1 0 0)"
|
|
||||||
>
|
>
|
||||||
AB
|
AB
|
||||||
</text>
|
</text>
|
||||||
|
@ -611,7 +605,6 @@ exports[`use various parts of svg-edit > check tool_star #0`] = `
|
||||||
fill-opacity="1"
|
fill-opacity="1"
|
||||||
stroke-opacity="1"
|
stroke-opacity="1"
|
||||||
id="svg_2"
|
id="svg_2"
|
||||||
transform="matrix(1 0 0 1 0 0)"
|
|
||||||
>
|
>
|
||||||
AB
|
AB
|
||||||
</text>
|
</text>
|
||||||
|
@ -701,7 +694,6 @@ exports[`use various parts of svg-edit > check tool_polygon #0`] = `
|
||||||
fill-opacity="1"
|
fill-opacity="1"
|
||||||
stroke-opacity="1"
|
stroke-opacity="1"
|
||||||
id="svg_2"
|
id="svg_2"
|
||||||
transform="matrix(1 0 0 1 0 0)"
|
|
||||||
>
|
>
|
||||||
AB
|
AB
|
||||||
</text>
|
</text>
|
||||||
|
|
|
@ -33,7 +33,7 @@ describe('recalculate', function () {
|
||||||
return this._storage.has(element) && this._storage.get(element).has(key);
|
return this._storage.has(element) && this._storage.get(element).has(key);
|
||||||
},
|
},
|
||||||
remove: function (element, key) {
|
remove: function (element, key) {
|
||||||
let ret = this._storage.get(element).delete(key);
|
const ret = this._storage.get(element).delete(key);
|
||||||
if (!this._storage.get(element).size === 0) {
|
if (!this._storage.get(element).size === 0) {
|
||||||
this._storage.delete(element);
|
this._storage.delete(element);
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,7 +27,7 @@ describe('select', function () {
|
||||||
return this._storage.has(element) && this._storage.get(element).has(key);
|
return this._storage.has(element) && this._storage.get(element).has(key);
|
||||||
},
|
},
|
||||||
remove: function (element, key) {
|
remove: function (element, key) {
|
||||||
let ret = this._storage.get(element).delete(key);
|
const ret = this._storage.get(element).delete(key);
|
||||||
if (!this._storage.get(element).size === 0) {
|
if (!this._storage.get(element).size === 0) {
|
||||||
this._storage.delete(element);
|
this._storage.delete(element);
|
||||||
}
|
}
|
||||||
|
|
|
@ -149,7 +149,7 @@ describe('utilities bbox', function () {
|
||||||
g.remove();
|
g.remove();
|
||||||
});
|
});
|
||||||
|
|
||||||
it.skip('Test getBBoxWithTransform and a rotation transform', function () {
|
it('Test getBBoxWithTransform and a rotation transform', function () {
|
||||||
const { getBBoxWithTransform } = utilities;
|
const { getBBoxWithTransform } = utilities;
|
||||||
|
|
||||||
let elem = mockCreateSVGElement({
|
let elem = mockCreateSVGElement({
|
||||||
|
@ -231,7 +231,7 @@ describe('utilities bbox', function () {
|
||||||
elem.remove();
|
elem.remove();
|
||||||
});
|
});
|
||||||
|
|
||||||
it.skip('Test getBBoxWithTransform with rotation and matrix transforms', function () {
|
it('Test getBBoxWithTransform with rotation and matrix transforms', function () {
|
||||||
const { getBBoxWithTransform } = utilities;
|
const { getBBoxWithTransform } = utilities;
|
||||||
|
|
||||||
let tx = 10; // tx right
|
let tx = 10; // tx right
|
||||||
|
|
|
@ -18,7 +18,7 @@ export const NS = {
|
||||||
XLINK: 'http://www.w3.org/1999/xlink',
|
XLINK: 'http://www.w3.org/1999/xlink',
|
||||||
OI: 'http://www.optimistik.fr/namespace/svg/OIdata',
|
OI: 'http://www.optimistik.fr/namespace/svg/OIdata',
|
||||||
XML: 'http://www.w3.org/XML/1998/namespace',
|
XML: 'http://www.w3.org/XML/1998/namespace',
|
||||||
XMLNS: 'http://www.w3.org/2000/xmlns/', // see http://www.w3.org/TR/REC-xml-names/#xmlReserved
|
XMLNS: 'http://www.w3.org/2000/xmlns/' // see http://www.w3.org/TR/REC-xml-names/#xmlReserved
|
||||||
// SODIPODI: 'http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd',
|
// SODIPODI: 'http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd',
|
||||||
// INKSCAPE: 'http://www.inkscape.org/namespaces/inkscape',
|
// INKSCAPE: 'http://www.inkscape.org/namespaces/inkscape',
|
||||||
// RDF: 'http://www.w3.org/1999/02/22-rdf-syntax-ns#',
|
// RDF: 'http://www.w3.org/1999/02/22-rdf-syntax-ns#',
|
||||||
|
|
|
@ -184,7 +184,7 @@ export default class ConfigObj {
|
||||||
'ext-shapes',
|
'ext-shapes',
|
||||||
'ext-polystar',
|
'ext-polystar',
|
||||||
'ext-storage',
|
'ext-storage',
|
||||||
'ext-opensave',
|
'ext-opensave'
|
||||||
// 'ext-helloworld',
|
// 'ext-helloworld',
|
||||||
];
|
];
|
||||||
this.curConfig = {
|
this.curConfig = {
|
||||||
|
|
|
@ -281,11 +281,11 @@ class Editor extends EditorStartup {
|
||||||
parentSelector = document;
|
parentSelector = document;
|
||||||
}
|
}
|
||||||
|
|
||||||
let parents = [];
|
const parents = [];
|
||||||
let p = el.parentNode;
|
let p = el.parentNode;
|
||||||
|
|
||||||
while (p !== parentSelector) {
|
while (p !== parentSelector) {
|
||||||
let o = p;
|
const o = p;
|
||||||
parents.push(o);
|
parents.push(o);
|
||||||
p = o.parentNode;
|
p = o.parentNode;
|
||||||
}
|
}
|
||||||
|
|
|
@ -255,7 +255,7 @@ class EditorStartup {
|
||||||
});
|
});
|
||||||
|
|
||||||
function addListenerMulti(element, eventNames, listener) {
|
function addListenerMulti(element, eventNames, listener) {
|
||||||
let events = eventNames.split(' ');
|
const events = eventNames.split(' ');
|
||||||
for (let i=0, iLen=events.length; i<iLen; i++) {
|
for (let i=0, iLen=events.length; i<iLen; i++) {
|
||||||
element.addEventListener(events[i], listener, false);
|
element.addEventListener(events[i], listener, false);
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,7 +21,7 @@ export function isObject(item) {
|
||||||
}
|
}
|
||||||
|
|
||||||
export function mergeDeep(target, source) {
|
export function mergeDeep(target, source) {
|
||||||
let output = Object.assign({}, target);
|
const output = Object.assign({}, target);
|
||||||
if (isObject(target) && isObject(source)) {
|
if (isObject(target) && isObject(source)) {
|
||||||
Object.keys(source).forEach((key) => {
|
Object.keys(source).forEach((key) => {
|
||||||
if (isObject(source[key])) {
|
if (isObject(source[key])) {
|
||||||
|
@ -146,7 +146,7 @@ export function getParents(elem, selector) {
|
||||||
}
|
}
|
||||||
|
|
||||||
export function getParentsUntil(elem, parent, selector) {
|
export function getParentsUntil(elem, parent, selector) {
|
||||||
let parents = [];
|
const parents = [];
|
||||||
let parentType;
|
let parentType;
|
||||||
let selectorType;
|
let selectorType;
|
||||||
if ( parent ) {
|
if ( parent ) {
|
||||||
|
|
|
@ -1652,7 +1652,7 @@ export function jPickerMethod (elem, options, commitCallback, liveCallback, canc
|
||||||
let iconColor = null; // iconColor for popup icon
|
let iconColor = null; // iconColor for popup icon
|
||||||
let iconAlpha = null; // iconAlpha for popup icon
|
let iconAlpha = null; // iconAlpha for popup icon
|
||||||
let iconImage = null; // iconImage popup icon
|
let iconImage = null; // iconImage popup icon
|
||||||
let moveBar = null; // drag bar
|
const moveBar = null; // drag bar
|
||||||
Object.assign(that, {
|
Object.assign(that, {
|
||||||
// public properties, methods, and callbacks
|
// public properties, methods, and callbacks
|
||||||
commitCallback, // commitCallback function can be overridden to return the selected color to a method you specify when the user clicks "OK"
|
commitCallback, // commitCallback function can be overridden to return the selected color to a method you specify when the user clicks "OK"
|
||||||
|
|
|
@ -221,7 +221,7 @@ export default {
|
||||||
// setSelectMode();
|
// setSelectMode();
|
||||||
});
|
});
|
||||||
|
|
||||||
let oldToolSourceCancel = $id('tool_source_cancel');
|
const oldToolSourceCancel = $id('tool_source_cancel');
|
||||||
const toolSourceCancel = oldToolSourceCancel.cloneNode(true);
|
const toolSourceCancel = oldToolSourceCancel.cloneNode(true);
|
||||||
toolSourceCancel.style.display = 'none';
|
toolSourceCancel.style.display = 'none';
|
||||||
toolSourceCancel.id = 'foreign_cancel';
|
toolSourceCancel.id = 'foreign_cancel';
|
||||||
|
@ -276,7 +276,7 @@ export default {
|
||||||
}
|
}
|
||||||
const attrs = {
|
const attrs = {
|
||||||
width: newFO.getAttribute('width'),
|
width: newFO.getAttribute('width'),
|
||||||
height: newFO.getAttribute('height'),
|
height: newFO.getAttribute('height')
|
||||||
};
|
};
|
||||||
const keep = (attrs.width !== '0' || attrs.height !== '0');
|
const keep = (attrs.width !== '0' || attrs.height !== '0');
|
||||||
svgCanvas.addToSelection([ newFO ], true);
|
svgCanvas.addToSelection([ newFO ], true);
|
||||||
|
|
|
@ -76,7 +76,7 @@ export default {
|
||||||
const y = opts.mouse_y / zoom;
|
const y = opts.mouse_y / zoom;
|
||||||
|
|
||||||
// We do our own formatting
|
// We do our own formatting
|
||||||
let text = svgEditor.i18next.t(`${name}:text`, { x, y });
|
const text = svgEditor.i18next.t(`${name}:text`, { x, y });
|
||||||
// Show the text using the custom alert function
|
// Show the text using the custom alert function
|
||||||
alert(text);
|
alert(text);
|
||||||
}
|
}
|
||||||
|
|
|
@ -507,7 +507,7 @@ export default {
|
||||||
libOpts.style.display = 'none';
|
libOpts.style.display = 'none';
|
||||||
back.style.display = 'block';
|
back.style.display = 'block';
|
||||||
});
|
});
|
||||||
let span = document.createElement("span");
|
const span = document.createElement("span");
|
||||||
span.textContent = description;
|
span.textContent = description;
|
||||||
li.appendChild(span);
|
li.appendChild(span);
|
||||||
});
|
});
|
||||||
|
|
|
@ -12,5 +12,5 @@ export default {
|
||||||
imgLibs_0_name: 'Demo library (local)',
|
imgLibs_0_name: 'Demo library (local)',
|
||||||
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
||||||
imgLibs_1_name: 'IAN Symbol Libraries',
|
imgLibs_1_name: 'IAN Symbol Libraries',
|
||||||
imgLibs_1_description: 'Free library of illustrations',
|
imgLibs_1_description: 'Free library of illustrations'
|
||||||
};
|
};
|
||||||
|
|
|
@ -12,5 +12,5 @@ export default {
|
||||||
imgLibs_0_name: 'Demo library (local)',
|
imgLibs_0_name: 'Demo library (local)',
|
||||||
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
||||||
imgLibs_1_name: 'IAN Symbol Libraries',
|
imgLibs_1_name: 'IAN Symbol Libraries',
|
||||||
imgLibs_1_description: 'Free library of illustrations',
|
imgLibs_1_description: 'Free library of illustrations'
|
||||||
};
|
};
|
||||||
|
|
|
@ -12,5 +12,5 @@ export default {
|
||||||
imgLibs_0_name: 'Demo library (local)',
|
imgLibs_0_name: 'Demo library (local)',
|
||||||
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
||||||
imgLibs_1_name: 'IAN Symbol Libraries',
|
imgLibs_1_name: 'IAN Symbol Libraries',
|
||||||
imgLibs_1_description: 'Free library of illustrations',
|
imgLibs_1_description: 'Free library of illustrations'
|
||||||
};
|
};
|
||||||
|
|
|
@ -12,5 +12,5 @@ export default {
|
||||||
imgLibs_0_name: 'Demo library (local)',
|
imgLibs_0_name: 'Demo library (local)',
|
||||||
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
||||||
imgLibs_1_name: 'IAN Symbol Libraries',
|
imgLibs_1_name: 'IAN Symbol Libraries',
|
||||||
imgLibs_1_description: 'Free library of illustrations',
|
imgLibs_1_description: 'Free library of illustrations'
|
||||||
};
|
};
|
||||||
|
|
|
@ -12,5 +12,5 @@ export default {
|
||||||
imgLibs_0_name: 'Demo library (local)',
|
imgLibs_0_name: 'Demo library (local)',
|
||||||
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
||||||
imgLibs_1_name: 'IAN Symbol Libraries',
|
imgLibs_1_name: 'IAN Symbol Libraries',
|
||||||
imgLibs_1_description: 'Free library of illustrations',
|
imgLibs_1_description: 'Free library of illustrations'
|
||||||
};
|
};
|
||||||
|
|
|
@ -12,5 +12,5 @@ export default {
|
||||||
imgLibs_0_name: 'Demo library (local)',
|
imgLibs_0_name: 'Demo library (local)',
|
||||||
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
||||||
imgLibs_1_name: 'IAN Symbol Libraries',
|
imgLibs_1_name: 'IAN Symbol Libraries',
|
||||||
imgLibs_1_description: 'Free library of illustrations',
|
imgLibs_1_description: 'Free library of illustrations'
|
||||||
};
|
};
|
||||||
|
|
|
@ -12,5 +12,5 @@ export default {
|
||||||
imgLibs_0_name: 'Demo library (local)',
|
imgLibs_0_name: 'Demo library (local)',
|
||||||
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
||||||
imgLibs_1_name: 'IAN Symbol Libraries',
|
imgLibs_1_name: 'IAN Symbol Libraries',
|
||||||
imgLibs_1_description: 'Free library of illustrations',
|
imgLibs_1_description: 'Free library of illustrations'
|
||||||
};
|
};
|
||||||
|
|
|
@ -12,5 +12,5 @@ export default {
|
||||||
imgLibs_0_name: 'Demo library (local)',
|
imgLibs_0_name: 'Demo library (local)',
|
||||||
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
||||||
imgLibs_1_name: 'IAN Symbol Libraries',
|
imgLibs_1_name: 'IAN Symbol Libraries',
|
||||||
imgLibs_1_description: 'Free library of illustrations',
|
imgLibs_1_description: 'Free library of illustrations'
|
||||||
};
|
};
|
||||||
|
|
|
@ -12,5 +12,5 @@ export default {
|
||||||
imgLibs_0_name: 'Demo library (local)',
|
imgLibs_0_name: 'Demo library (local)',
|
||||||
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
imgLibs_0_description: 'Demonstration library for SVG-edit on this server',
|
||||||
imgLibs_1_name: 'IAN Symbol Libraries',
|
imgLibs_1_name: 'IAN Symbol Libraries',
|
||||||
imgLibs_1_description: 'Free library of illustrations',
|
imgLibs_1_description: 'Free library of illustrations'
|
||||||
};
|
};
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
// can't use npm version as the dragmove is different.
|
// can't use npm version as the dragmove is different.
|
||||||
|
|
||||||
let _loaded = false;
|
let _loaded = false;
|
||||||
let _callbacks = [];
|
const _callbacks = [];
|
||||||
const _isTouch = window.ontouchstart !== undefined;
|
const _isTouch = window.ontouchstart !== undefined;
|
||||||
|
|
||||||
export const dragmove = function(target, handler, parent, onStart, onEnd, onDrag) {
|
export const dragmove = function(target, handler, parent, onStart, onEnd, onDrag) {
|
||||||
|
|
|
@ -104,7 +104,7 @@ export default {
|
||||||
const items = txt.split(';');
|
const items = txt.split(';');
|
||||||
selElems.forEach((elem) => {
|
selElems.forEach((elem) => {
|
||||||
if (elem && elem.getAttribute('class').includes('placemark')) {
|
if (elem && elem.getAttribute('class').includes('placemark')) {
|
||||||
let elements = elem.children;
|
const elements = elem.children;
|
||||||
Array.prototype.forEach.call(elements, function(i, _){
|
Array.prototype.forEach.call(elements, function(i, _){
|
||||||
const [ , , type, n ] = i.id.split('_');
|
const [ , , type, n ] = i.id.split('_');
|
||||||
if (type === 'txt') {
|
if (type === 'txt') {
|
||||||
|
@ -125,7 +125,7 @@ export default {
|
||||||
font = font.join(' ');
|
font = font.join(' ');
|
||||||
selElems.forEach((elem) => {
|
selElems.forEach((elem) => {
|
||||||
if (elem && elem.getAttribute('class').includes('placemark')) {
|
if (elem && elem.getAttribute('class').includes('placemark')) {
|
||||||
let elements = elem.children;
|
const elements = elem.children;
|
||||||
Array.prototype.forEach.call(elements, function(i, _){
|
Array.prototype.forEach.call(elements, function(i, _){
|
||||||
const [ , , type ] = i.id.split('_');
|
const [ , , type ] = i.id.split('_');
|
||||||
if (type === 'txt') {
|
if (type === 'txt') {
|
||||||
|
|
|
@ -23,7 +23,7 @@ export default {
|
||||||
const filename = getFileNameFromTitle();
|
const filename = getFileNameFromTitle();
|
||||||
|
|
||||||
// $.post(saveSvgAction, { output_svg: svg, filename });
|
// $.post(saveSvgAction, { output_svg: svg, filename });
|
||||||
let postData = { output_svg: svg, filename };
|
const postData = { output_svg: svg, filename };
|
||||||
fetch(saveSvgAction, {
|
fetch(saveSvgAction, {
|
||||||
method: "POST",
|
method: "POST",
|
||||||
body: JSON.stringify(postData)
|
body: JSON.stringify(postData)
|
||||||
|
|
|
@ -79,7 +79,7 @@ export const putLocale = async function (givenParam, goodLangs) {
|
||||||
debug: false,
|
debug: false,
|
||||||
resources: {
|
resources: {
|
||||||
[langParam]: {
|
[langParam]: {
|
||||||
translation: module.default,
|
translation: module.default
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Změnit ID elementu',
|
id: 'Změnit ID elementu',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Hlavní menu',
|
main_menu: 'Hlavní menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Vrstva',
|
layer: 'Vrstva',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Nevhodná hodnota',
|
invalidAttrValGiven: 'Nevhodná hodnota',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -265,7 +265,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Element identifizieren',
|
id: 'Element identifizieren',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Hauptmenü',
|
main_menu: 'Hauptmenü',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Ebene',
|
layer: 'Ebene',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Fehlerhafter Wert',
|
invalidAttrValGiven: 'Fehlerhafter Wert',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Menú principal',
|
main_menu: 'Menú principal',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Capa',
|
layer: 'Capa',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Valor no válido',
|
invalidAttrValGiven: 'Valor no válido',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'لایه',
|
layer: 'لایه',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'مقدار داده شده نامعتبر است',
|
invalidAttrValGiven: 'مقدار داده شده نامعتبر است',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: "Identifier l'élément",
|
id: "Identifier l'élément",
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Menu principal',
|
main_menu: 'Menu principal',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Calque',
|
layer: 'Calque',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Valeur fournie invalide',
|
invalidAttrValGiven: 'Valeur fournie invalide',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Laach',
|
layer: 'Laach',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Ferkearde waarde jûn',
|
invalidAttrValGiven: 'Ferkearde waarde jûn',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'परत',
|
layer: 'परत',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'अमान्य मूल्य',
|
invalidAttrValGiven: 'अमान्य मूल्य',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: "Identifica l'elemento",
|
id: "Identifica l'elemento",
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Menù principale',
|
main_menu: 'Menù principale',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Livello',
|
layer: 'Livello',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Valore assegnato non valido',
|
invalidAttrValGiven: 'Valore assegnato non valido',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'レイヤ',
|
layer: 'レイヤ',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: '無効な値が指定されています。',
|
invalidAttrValGiven: '無効な値が指定されています。',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identificeer het element',
|
id: 'Identificeer het element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Hoofdmenu',
|
main_menu: 'Hoofdmenu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Laag',
|
layer: 'Laag',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Verkeerde waarde gegeven',
|
invalidAttrValGiven: 'Verkeerde waarde gegeven',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -28,7 +28,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identyfikator elementu',
|
id: 'Identyfikator elementu',
|
||||||
|
@ -91,7 +91,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Menu główne',
|
main_menu: 'Menu główne',
|
||||||
|
@ -170,7 +170,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Warstwa',
|
layer: 'Warstwa',
|
||||||
|
@ -263,7 +263,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Podano nieprawidłową wartość',
|
invalidAttrValGiven: 'Podano nieprawidłową wartość',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identifica o elemento',
|
id: 'Identifica o elemento',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Menu Principal',
|
main_menu: 'Menu Principal',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Camada',
|
layer: 'Camada',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Valor inválido',
|
invalidAttrValGiven: 'Valor inválido',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identificare element',
|
id: 'Identificare element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Menu Principal',
|
main_menu: 'Menu Principal',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Strat',
|
layer: 'Strat',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Valoarea data nu este validă',
|
invalidAttrValGiven: 'Valoarea data nu este validă',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Идентификатор элемента',
|
id: 'Идентификатор элемента',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Главное меню',
|
main_menu: 'Главное меню',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Слой',
|
layer: 'Слой',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Некорректное значение аргумента',
|
invalidAttrValGiven: 'Некорректное значение аргумента',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Zmeniť ID elementu',
|
id: 'Zmeniť ID elementu',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Hlavné menu',
|
main_menu: 'Hlavné menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Vrstva',
|
layer: 'Vrstva',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Neplatná hodnota',
|
invalidAttrValGiven: 'Neplatná hodnota',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'ID elementa',
|
id: 'ID elementa',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Glavni meni',
|
main_menu: 'Glavni meni',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Sloj',
|
layer: 'Sloj',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Napačna vrednost!',
|
invalidAttrValGiven: 'Napačna vrednost!',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: '元素ID',
|
id: '元素ID',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: '主菜单',
|
main_menu: '主菜单',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: '图层',
|
layer: '图层',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: '无效的参数',
|
invalidAttrValGiven: '无效的参数',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: 'Layer',
|
layer: 'Layer',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: 'Invalid value given',
|
invalidAttrValGiven: 'Invalid value given',
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
||||||
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
pick_stroke_paint_opacity: 'Pick a Stroke Paint and Opacity',
|
||||||
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
pick_fill_paint_opacity: 'Pick a Fill Paint and Opacity',
|
||||||
group_identify_label: 'Group identification label',
|
group_identify_label: 'Group identification label',
|
||||||
export_type_label: 'Select an image type for export:',
|
export_type_label: 'Select an image type for export:'
|
||||||
},
|
},
|
||||||
properties: {
|
properties: {
|
||||||
id: 'Identify the element',
|
id: 'Identify the element',
|
||||||
|
@ -90,7 +90,7 @@ export default {
|
||||||
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
no_prefs_or_content: 'Do not store my preferences or SVG content locally',
|
||||||
jgraduate_pad: 'Pad',
|
jgraduate_pad: 'Pad',
|
||||||
jgraduate_reflect: 'Reflect',
|
jgraduate_reflect: 'Reflect',
|
||||||
jgraduate_repeat: 'Repeat',
|
jgraduate_repeat: 'Repeat'
|
||||||
},
|
},
|
||||||
tools: {
|
tools: {
|
||||||
main_menu: 'Main Menu',
|
main_menu: 'Main Menu',
|
||||||
|
@ -169,7 +169,7 @@ export default {
|
||||||
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
ellipse_circle_tool: 'Ellipse/Circle Tool',
|
||||||
square_rect_tool: 'Square/Rect Tool',
|
square_rect_tool: 'Square/Rect Tool',
|
||||||
remember_this_choice: 'Remember this choice?',
|
remember_this_choice: 'Remember this choice?',
|
||||||
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.',
|
remember_this_choice_title: 'If you choose to opt out of storage while remembering this choice, the URL will change so as to avoid asking again.'
|
||||||
},
|
},
|
||||||
layers: {
|
layers: {
|
||||||
layer: '圖層',
|
layer: '圖層',
|
||||||
|
@ -262,7 +262,7 @@ export default {
|
||||||
jgraduate_set_angle: 'Click to set Angle',
|
jgraduate_set_angle: 'Click to set Angle',
|
||||||
jgraduate_deg: 'deg:',
|
jgraduate_deg: 'deg:',
|
||||||
jgraduate_opac: 'Opac:',
|
jgraduate_opac: 'Opac:',
|
||||||
jgraduate_set_opac: 'Click to set Opac',
|
jgraduate_set_opac: 'Click to set Opac'
|
||||||
},
|
},
|
||||||
notification: {
|
notification: {
|
||||||
invalidAttrValGiven: '數值給定錯誤',
|
invalidAttrValGiven: '數值給定錯誤',
|
||||||
|
|
|
@ -1020,7 +1020,7 @@ export const setContext = function (elem) {
|
||||||
|
|
||||||
// Disable other elements
|
// Disable other elements
|
||||||
const parentsUntil = getParentsUntil(elem, '#svgcontent');
|
const parentsUntil = getParentsUntil(elem, '#svgcontent');
|
||||||
let siblings = [];
|
const siblings = [];
|
||||||
parentsUntil.forEach(function (parent) {
|
parentsUntil.forEach(function (parent) {
|
||||||
const elements = Array.prototype.filter.call(parent.parentNode.children, function(child){
|
const elements = Array.prototype.filter.call(parent.parentNode.children, function(child){
|
||||||
return child !== parent;
|
return child !== parent;
|
||||||
|
|
|
@ -747,7 +747,7 @@ export const setImageURLMethod = function (val) {
|
||||||
|
|
||||||
const attrs = {
|
const attrs = {
|
||||||
width: elem.getAttribute('width'),
|
width: elem.getAttribute('width'),
|
||||||
height: elem.getAttribute('height'),
|
height: elem.getAttribute('height')
|
||||||
};
|
};
|
||||||
const setsize = (!attrs.width || !attrs.height);
|
const setsize = (!attrs.width || !attrs.height);
|
||||||
|
|
||||||
|
@ -768,7 +768,7 @@ export const setImageURLMethod = function (val) {
|
||||||
img.onload = function () {
|
img.onload = function () {
|
||||||
const changes = {
|
const changes = {
|
||||||
width: elem.getAttribute('width'),
|
width: elem.getAttribute('width'),
|
||||||
height: elem.getAttribute('height'),
|
height: elem.getAttribute('height')
|
||||||
};
|
};
|
||||||
elem.setAttribute('width', this.width);
|
elem.setAttribute('width', this.width);
|
||||||
elem.setAttribute('height', this.height);
|
elem.setAttribute('height', this.height);
|
||||||
|
|
|
@ -17,9 +17,7 @@ import {
|
||||||
import {
|
import {
|
||||||
getTransformList
|
getTransformList
|
||||||
} from './svgtransformlist.js';
|
} from './svgtransformlist.js';
|
||||||
import {
|
import { supportsNonScalingStroke } from '../common/browser.js';
|
||||||
supportsNonScalingStroke, isWebkit
|
|
||||||
} from '../common/browser.js';
|
|
||||||
import * as draw from './draw.js';
|
import * as draw from './draw.js';
|
||||||
import * as pathModule from './path.js';
|
import * as pathModule from './path.js';
|
||||||
import * as hstry from './history.js';
|
import * as hstry from './history.js';
|
||||||
|
@ -84,16 +82,25 @@ export const getBsplinePoint = function (t) {
|
||||||
* @returns {void}
|
* @returns {void}
|
||||||
*/
|
*/
|
||||||
export const mouseMoveEvent = function (evt) {
|
export const mouseMoveEvent = function (evt) {
|
||||||
const selectedElements = eventContext_.getSelectedElements();
|
const selectedElements = eventContext_.getSelectedElements;
|
||||||
const currentZoom = eventContext_.getCurrentZoom();
|
const currentZoom = eventContext_.getCurrentZoom();
|
||||||
|
const svgRoot = eventContext_.getSVGRoot();
|
||||||
|
const svgCanvas = eventContext_.getCanvas();
|
||||||
|
|
||||||
if (!eventContext_.getStarted()) { return; }
|
if (!eventContext_.getStarted()) { return; }
|
||||||
if (evt.button === 1 || eventContext_.getCanvas().spaceKey) { return; }
|
if (evt.button === 1 || svgCanvas.spaceKey) { return; }
|
||||||
|
|
||||||
let i; let xya; let cx; let cy; let dx; let dy; let len; let angle; let box;
|
|
||||||
let selected = selectedElements[0];
|
|
||||||
const
|
|
||||||
pt = transformPoint(evt.pageX, evt.pageY, eventContext_.getrootSctm());
|
|
||||||
|
|
||||||
|
let i;
|
||||||
|
let xya;
|
||||||
|
let cx;
|
||||||
|
let cy;
|
||||||
|
let dx;
|
||||||
|
let dy;
|
||||||
|
let len;
|
||||||
|
let angle;
|
||||||
|
let box;
|
||||||
|
let selected = selectedElements()[0];
|
||||||
|
const pt = transformPoint(evt.pageX, evt.pageY, eventContext_.getrootSctm());
|
||||||
const mouseX = pt.x * currentZoom;
|
const mouseX = pt.x * currentZoom;
|
||||||
const mouseY = pt.y * currentZoom;
|
const mouseY = pt.y * currentZoom;
|
||||||
const shape = getElem(eventContext_.getId());
|
const shape = getElem(eventContext_.getId());
|
||||||
|
@ -115,7 +122,7 @@ export const mouseMoveEvent = function (evt) {
|
||||||
// we temporarily use a translate on the element(s) being dragged
|
// we temporarily use a translate on the element(s) being dragged
|
||||||
// this transform is removed upon mousing up and the element is
|
// this transform is removed upon mousing up and the element is
|
||||||
// relocated to the new location
|
// relocated to the new location
|
||||||
if (selectedElements[0] !== null) {
|
if (selectedElements()[0] !== null) {
|
||||||
dx = x - eventContext_.getStartX();
|
dx = x - eventContext_.getStartX();
|
||||||
dy = y - eventContext_.getStartY();
|
dy = y - eventContext_.getStartY();
|
||||||
if (eventContext_.getCurConfig().gridSnapping) {
|
if (eventContext_.getCurConfig().gridSnapping) {
|
||||||
|
@ -124,9 +131,9 @@ export const mouseMoveEvent = function (evt) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dx !== 0 || dy !== 0) {
|
if (dx !== 0 || dy !== 0) {
|
||||||
len = selectedElements.length;
|
len = selectedElements().length;
|
||||||
for (i = 0; i < len; ++i) {
|
for (i = 0; i < len; ++i) {
|
||||||
selected = selectedElements[i];
|
selected = selectedElements()[i];
|
||||||
if (isNullish(selected)) { break; }
|
if (isNullish(selected)) { break; }
|
||||||
// if (i === 0) {
|
// if (i === 0) {
|
||||||
// const box = utilsGetBBox(selected);
|
// const box = utilsGetBBox(selected);
|
||||||
|
@ -136,7 +143,7 @@ export const mouseMoveEvent = function (evt) {
|
||||||
|
|
||||||
// update the dummy transform in our transform list
|
// update the dummy transform in our transform list
|
||||||
// to be a translate
|
// to be a translate
|
||||||
const xform = eventContext_.getSVGRoot().createSVGTransform();
|
const xform = svgRoot.createSVGTransform();
|
||||||
tlist = getTransformList(selected);
|
tlist = getTransformList(selected);
|
||||||
// Note that if Webkit and there's no ID for this
|
// Note that if Webkit and there's no ID for this
|
||||||
// element, the dummy transform may have gotten lost.
|
// element, the dummy transform may have gotten lost.
|
||||||
|
@ -150,10 +157,10 @@ export const mouseMoveEvent = function (evt) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// update our internal bbox that we're tracking while dragging
|
// update our internal bbox that we're tracking while dragging
|
||||||
eventContext_.getCanvas().selectorManager.requestSelector(selected).resize();
|
svgCanvas.selectorManager.requestSelector(selected).resize();
|
||||||
}
|
}
|
||||||
|
|
||||||
eventContext_.getCanvas().call('transition', selectedElements);
|
svgCanvas.call('transition', selectedElements());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -171,7 +178,7 @@ export const mouseMoveEvent = function (evt) {
|
||||||
// - if newList contains selected, do nothing
|
// - if newList contains selected, do nothing
|
||||||
// - if newList doesn't contain selected, remove it from selected
|
// - if newList doesn't contain selected, remove it from selected
|
||||||
// - for any newList that was not in selectedElements, add it to selected
|
// - for any newList that was not in selectedElements, add it to selected
|
||||||
const elemsToRemove = selectedElements.slice(); const elemsToAdd = [];
|
const elemsToRemove = selectedElements().slice(); const elemsToAdd = [];
|
||||||
const newList = eventContext_.getIntersectionList();
|
const newList = eventContext_.getIntersectionList();
|
||||||
|
|
||||||
// For every element in the intersection, add if not present in selectedElements.
|
// For every element in the intersection, add if not present in selectedElements.
|
||||||
|
@ -179,7 +186,7 @@ export const mouseMoveEvent = function (evt) {
|
||||||
for (i = 0; i < len; ++i) {
|
for (i = 0; i < len; ++i) {
|
||||||
const intElem = newList[i];
|
const intElem = newList[i];
|
||||||
// Found an element that was not selected before, so we should add it.
|
// Found an element that was not selected before, so we should add it.
|
||||||
if (!selectedElements.includes(intElem)) {
|
if (!selectedElements().includes(intElem)) {
|
||||||
elemsToAdd.push(intElem);
|
elemsToAdd.push(intElem);
|
||||||
}
|
}
|
||||||
// Found an element that was already selected, so we shouldn't remove it.
|
// Found an element that was already selected, so we shouldn't remove it.
|
||||||
|
@ -190,11 +197,11 @@ export const mouseMoveEvent = function (evt) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (elemsToRemove.length > 0) {
|
if (elemsToRemove.length > 0) {
|
||||||
eventContext_.getCanvas().removeFromSelection(elemsToRemove);
|
svgCanvas.removeFromSelection(elemsToRemove);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (elemsToAdd.length > 0) {
|
if (elemsToAdd.length > 0) {
|
||||||
eventContext_.getCanvas().addToSelection(elemsToAdd);
|
svgCanvas.addToSelection(elemsToAdd);
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
@ -253,9 +260,9 @@ export const mouseMoveEvent = function (evt) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// update the transform list with translate,scale,translate
|
// update the transform list with translate,scale,translate
|
||||||
const translateOrigin = eventContext_.getSVGRoot().createSVGTransform();
|
const translateOrigin = svgRoot.createSVGTransform();
|
||||||
const scale = eventContext_.getSVGRoot().createSVGTransform();
|
const scale = svgRoot.createSVGTransform();
|
||||||
const translateBack = eventContext_.getSVGRoot().createSVGTransform();
|
const translateBack = svgRoot.createSVGTransform();
|
||||||
|
|
||||||
if (eventContext_.getCurConfig().gridSnapping) {
|
if (eventContext_.getCurConfig().gridSnapping) {
|
||||||
left = snapToGrid(left);
|
left = snapToGrid(left);
|
||||||
|
@ -285,8 +292,8 @@ export const mouseMoveEvent = function (evt) {
|
||||||
tlist.replaceItem(translateOrigin, N - 1);
|
tlist.replaceItem(translateOrigin, N - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
eventContext_.getCanvas().selectorManager.requestSelector(selected).resize();
|
svgCanvas.selectorManager.requestSelector(selected).resize();
|
||||||
eventContext_.getCanvas().call('transition', selectedElements);
|
svgCanvas.call('transition', selectedElements());
|
||||||
|
|
||||||
break;
|
break;
|
||||||
} case 'zoom': {
|
} case 'zoom': {
|
||||||
|
@ -462,7 +469,7 @@ export const mouseMoveEvent = function (evt) {
|
||||||
height: Math.abs(realY - eventContext_.getRStartY() * currentZoom)
|
height: Math.abs(realY - eventContext_.getRStartY() * currentZoom)
|
||||||
}, 100);
|
}, 100);
|
||||||
}
|
}
|
||||||
eventContext_.getCanvas().pathActions.mouseMove(x, y);
|
svgCanvas.pathActions.mouseMove(x, y);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
} case 'textedit': {
|
} case 'textedit': {
|
||||||
|
@ -477,7 +484,7 @@ export const mouseMoveEvent = function (evt) {
|
||||||
// }, 100);
|
// }, 100);
|
||||||
// }
|
// }
|
||||||
|
|
||||||
eventContext_.getCanvas().textActions.mouseMove(mouseX, mouseY);
|
svgCanvas.textActions.mouseMove(mouseX, mouseY);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
} case 'rotate': {
|
} case 'rotate': {
|
||||||
|
@ -497,8 +504,8 @@ export const mouseMoveEvent = function (evt) {
|
||||||
angle = Math.round(angle / snap) * snap;
|
angle = Math.round(angle / snap) * snap;
|
||||||
}
|
}
|
||||||
|
|
||||||
eventContext_.getCanvas().setRotationAngle(angle < -180 ? (360 + angle) : angle, true);
|
svgCanvas.setRotationAngle(angle < -180 ? (360 + angle) : angle, true);
|
||||||
eventContext_.getCanvas().call('transition', selectedElements);
|
svgCanvas.call('transition', selectedElements());
|
||||||
break;
|
break;
|
||||||
} default:
|
} default:
|
||||||
break;
|
break;
|
||||||
|
@ -513,7 +520,7 @@ export const mouseMoveEvent = function (evt) {
|
||||||
* @property {Float} mouse_y y coordinate on canvas
|
* @property {Float} mouse_y y coordinate on canvas
|
||||||
* @property {Element} selected Refers to the first selected element
|
* @property {Element} selected Refers to the first selected element
|
||||||
*/
|
*/
|
||||||
eventContext_.getCanvas().runExtensions('mouseMove', /** @type {module:svgcanvas.SvgCanvas#event:ext_mouseMove} */ {
|
svgCanvas.runExtensions('mouseMove', /** @type {module:svgcanvas.SvgCanvas#event:ext_mouseMove} */ {
|
||||||
event: evt,
|
event: evt,
|
||||||
mouse_x: mouseX,
|
mouse_x: mouseX,
|
||||||
mouse_y: mouseY,
|
mouse_y: mouseY,
|
||||||
|
@ -537,6 +544,7 @@ export const mouseMoveEvent = function (evt) {
|
||||||
export const mouseUpEvent = function (evt) {
|
export const mouseUpEvent = function (evt) {
|
||||||
const selectedElements = eventContext_.getSelectedElements();
|
const selectedElements = eventContext_.getSelectedElements();
|
||||||
const currentZoom = eventContext_.getCurrentZoom();
|
const currentZoom = eventContext_.getCurrentZoom();
|
||||||
|
const svgCanvas = eventContext_.getCanvas();
|
||||||
if (evt.button === 2) { return; }
|
if (evt.button === 2) { return; }
|
||||||
const tempJustSelected = eventContext_.getJustSelected();
|
const tempJustSelected = eventContext_.getJustSelected();
|
||||||
eventContext_.setJustSelected(null);
|
eventContext_.setJustSelected(null);
|
||||||
|
@ -594,13 +602,13 @@ export const mouseUpEvent = function (evt) {
|
||||||
eventContext_.setCurText('font_size', selected.getAttribute('font-size'));
|
eventContext_.setCurText('font_size', selected.getAttribute('font-size'));
|
||||||
eventContext_.setCurText('font_family', selected.getAttribute('font-family'));
|
eventContext_.setCurText('font_family', selected.getAttribute('font-family'));
|
||||||
}
|
}
|
||||||
eventContext_.getCanvas().selectorManager.requestSelector(selected).showGrips(true);
|
svgCanvas.selectorManager.requestSelector(selected).showGrips(true);
|
||||||
|
|
||||||
// This shouldn't be necessary as it was done on mouseDown...
|
// This shouldn't be necessary as it was done on mouseDown...
|
||||||
// eventContext_.getCanvas().call('selected', [selected]);
|
// svgCanvas.call('selected', [selected]);
|
||||||
}
|
}
|
||||||
// always recalculate dimensions to strip off stray identity transforms
|
// always recalculate dimensions to strip off stray identity transforms
|
||||||
eventContext_.getCanvas().recalculateAllSelectedDimensions();
|
svgCanvas.recalculateAllSelectedDimensions();
|
||||||
// if it was being dragged/resized
|
// if it was being dragged/resized
|
||||||
if (realX !== eventContext_.getRStartX() || realY !== eventContext_.getRStartY()) {
|
if (realX !== eventContext_.getRStartX() || realY !== eventContext_.getRStartY()) {
|
||||||
const len = selectedElements.length;
|
const len = selectedElements.length;
|
||||||
|
@ -608,18 +616,18 @@ export const mouseUpEvent = function (evt) {
|
||||||
if (isNullish(selectedElements[i])) { break; }
|
if (isNullish(selectedElements[i])) { break; }
|
||||||
if (!selectedElements[i].firstChild) {
|
if (!selectedElements[i].firstChild) {
|
||||||
// Not needed for groups (incorrectly resizes elems), possibly not needed at all?
|
// Not needed for groups (incorrectly resizes elems), possibly not needed at all?
|
||||||
eventContext_.getCanvas().selectorManager.requestSelector(selectedElements[i]).resize();
|
svgCanvas.selectorManager.requestSelector(selectedElements[i]).resize();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// no change in position/size, so maybe we should move to pathedit
|
// no change in position/size, so maybe we should move to pathedit
|
||||||
} else {
|
} else {
|
||||||
t = evt.target;
|
t = evt.target;
|
||||||
if (selectedElements[0].nodeName === 'path' && isNullish(selectedElements[1])) {
|
if (selectedElements[0].nodeName === 'path' && isNullish(selectedElements[1])) {
|
||||||
eventContext_.getCanvas().pathActions.select(selectedElements[0]);
|
svgCanvas.pathActions.select(selectedElements[0]);
|
||||||
// if it was a path
|
// if it was a path
|
||||||
// else, if it was selected and this is a shift-click, remove it from selection
|
// else, if it was selected and this is a shift-click, remove it from selection
|
||||||
} else if (evt.shiftKey && tempJustSelected !== t) {
|
} else if (evt.shiftKey && tempJustSelected !== t) {
|
||||||
eventContext_.getCanvas().removeFromSelection([ t ]);
|
svgCanvas.removeFromSelection([ t ]);
|
||||||
}
|
}
|
||||||
} // no change in mouse position
|
} // no change in mouse position
|
||||||
|
|
||||||
|
@ -640,7 +648,7 @@ export const mouseUpEvent = function (evt) {
|
||||||
eventContext_.getRubberBox().setAttribute('display', 'none');
|
eventContext_.getRubberBox().setAttribute('display', 'none');
|
||||||
}
|
}
|
||||||
const factor = evt.shiftKey ? 0.5 : 2;
|
const factor = evt.shiftKey ? 0.5 : 2;
|
||||||
eventContext_.getCanvas().call('zoomed', {
|
svgCanvas.call('zoomed', {
|
||||||
x: Math.min(eventContext_.getRStartX(), realX),
|
x: Math.min(eventContext_.getRStartX(), realX),
|
||||||
y: Math.min(eventContext_.getRStartY(), realY),
|
y: Math.min(eventContext_.getRStartY(), realY),
|
||||||
width: Math.abs(realX - eventContext_.getRStartX()),
|
width: Math.abs(realX - eventContext_.getRStartX()),
|
||||||
|
@ -665,7 +673,7 @@ export const mouseUpEvent = function (evt) {
|
||||||
const commaIndex = coords.indexOf(',');
|
const commaIndex = coords.indexOf(',');
|
||||||
keep = commaIndex >= 0 ? coords.includes(',', commaIndex + 1) : coords.includes(' ', coords.indexOf(' ') + 1);
|
keep = commaIndex >= 0 ? coords.includes(',', commaIndex + 1) : coords.includes(' ', coords.indexOf(' ') + 1);
|
||||||
if (keep) {
|
if (keep) {
|
||||||
element = eventContext_.getCanvas().pathActions.smoothPolylineIntoPath(element);
|
element = svgCanvas.pathActions.smoothPolylineIntoPath(element);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
} case 'line': {
|
} case 'line': {
|
||||||
|
@ -698,7 +706,7 @@ export const mouseUpEvent = function (evt) {
|
||||||
case 'fhellipse':
|
case 'fhellipse':
|
||||||
if ((eventContext_.getFreehand('maxx') - eventContext_.getFreehand('minx')) > 0 &&
|
if ((eventContext_.getFreehand('maxx') - eventContext_.getFreehand('minx')) > 0 &&
|
||||||
(eventContext_.getFreehand('maxy') - eventContext_.getFreehand('miny')) > 0) {
|
(eventContext_.getFreehand('maxy') - eventContext_.getFreehand('miny')) > 0) {
|
||||||
element = eventContext_.getCanvas().addSVGElementFromJson({
|
element = svgCanvas.addSVGElementFromJson({
|
||||||
element: 'ellipse',
|
element: 'ellipse',
|
||||||
curStyles: true,
|
curStyles: true,
|
||||||
attr: {
|
attr: {
|
||||||
|
@ -709,14 +717,14 @@ export const mouseUpEvent = function (evt) {
|
||||||
id: eventContext_.getId()
|
id: eventContext_.getId()
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
eventContext_.getCanvas().call('changed', [ element ]);
|
svgCanvas.call('changed', [ element ]);
|
||||||
keep = true;
|
keep = true;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'fhrect':
|
case 'fhrect':
|
||||||
if ((eventContext_.getFreehand('maxx') - eventContext_.getFreehand('minx')) > 0 &&
|
if ((eventContext_.getFreehand('maxx') - eventContext_.getFreehand('minx')) > 0 &&
|
||||||
(eventContext_.getFreehand('maxy') - eventContext_.getFreehand('miny')) > 0) {
|
(eventContext_.getFreehand('maxy') - eventContext_.getFreehand('miny')) > 0) {
|
||||||
element = eventContext_.getCanvas().addSVGElementFromJson({
|
element = svgCanvas.addSVGElementFromJson({
|
||||||
element: 'rect',
|
element: 'rect',
|
||||||
curStyles: true,
|
curStyles: true,
|
||||||
attr: {
|
attr: {
|
||||||
|
@ -727,14 +735,14 @@ export const mouseUpEvent = function (evt) {
|
||||||
id: eventContext_.getId()
|
id: eventContext_.getId()
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
eventContext_.getCanvas().call('changed', [ element ]);
|
svgCanvas.call('changed', [ element ]);
|
||||||
keep = true;
|
keep = true;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'text':
|
case 'text':
|
||||||
keep = true;
|
keep = true;
|
||||||
eventContext_.getCanvas().selectOnly([ element ]);
|
svgCanvas.selectOnly([ element ]);
|
||||||
eventContext_.getCanvas().textActions.start(element);
|
svgCanvas.textActions.start(element);
|
||||||
break;
|
break;
|
||||||
case 'path': {
|
case 'path': {
|
||||||
// set element to null here so that it is not removed nor finalized
|
// set element to null here so that it is not removed nor finalized
|
||||||
|
@ -742,31 +750,31 @@ export const mouseUpEvent = function (evt) {
|
||||||
// continue to be set to true so that mouseMove happens
|
// continue to be set to true so that mouseMove happens
|
||||||
eventContext_.setStarted(true);
|
eventContext_.setStarted(true);
|
||||||
|
|
||||||
const res = eventContext_.getCanvas().pathActions.mouseUp(evt, element, mouseX, mouseY);
|
const res = svgCanvas.pathActions.mouseUp(evt, element, mouseX, mouseY);
|
||||||
({ element } = res);
|
({ element } = res);
|
||||||
({ keep } = res);
|
({ keep } = res);
|
||||||
break;
|
break;
|
||||||
} case 'pathedit':
|
} case 'pathedit':
|
||||||
keep = true;
|
keep = true;
|
||||||
element = null;
|
element = null;
|
||||||
eventContext_.getCanvas().pathActions.mouseUp(evt);
|
svgCanvas.pathActions.mouseUp(evt);
|
||||||
break;
|
break;
|
||||||
case 'textedit':
|
case 'textedit':
|
||||||
keep = false;
|
keep = false;
|
||||||
element = null;
|
element = null;
|
||||||
eventContext_.getCanvas().textActions.mouseUp(evt, mouseX, mouseY);
|
svgCanvas.textActions.mouseUp(evt, mouseX, mouseY);
|
||||||
break;
|
break;
|
||||||
case 'rotate': {
|
case 'rotate': {
|
||||||
keep = true;
|
keep = true;
|
||||||
element = null;
|
element = null;
|
||||||
eventContext_.setCurrentMode('select');
|
eventContext_.setCurrentMode('select');
|
||||||
const batchCmd = eventContext_.getCanvas().undoMgr.finishUndoableChange();
|
const batchCmd = svgCanvas.undoMgr.finishUndoableChange();
|
||||||
if (!batchCmd.isEmpty()) {
|
if (!batchCmd.isEmpty()) {
|
||||||
eventContext_.addCommandToHistory(batchCmd);
|
eventContext_.addCommandToHistory(batchCmd);
|
||||||
}
|
}
|
||||||
// perform recalculation to weed out any stray identity transforms that might get stuck
|
// perform recalculation to weed out any stray identity transforms that might get stuck
|
||||||
eventContext_.getCanvas().recalculateAllSelectedDimensions();
|
svgCanvas.recalculateAllSelectedDimensions();
|
||||||
eventContext_.getCanvas().call('changed', selectedElements);
|
svgCanvas.call('changed', selectedElements);
|
||||||
break;
|
break;
|
||||||
} default:
|
} default:
|
||||||
// This could occur in an extension
|
// This could occur in an extension
|
||||||
|
@ -781,7 +789,7 @@ export const mouseUpEvent = function (evt) {
|
||||||
* @property {Float} mouse_x x coordinate on canvas
|
* @property {Float} mouse_x x coordinate on canvas
|
||||||
* @property {Float} mouse_y y coordinate on canvas
|
* @property {Float} mouse_y y coordinate on canvas
|
||||||
*/
|
*/
|
||||||
const extResult = eventContext_.getCanvas().runExtensions('mouseUp', {
|
const extResult = svgCanvas.runExtensions('mouseUp', {
|
||||||
event: evt,
|
event: evt,
|
||||||
mouse_x: mouseX,
|
mouse_x: mouseX,
|
||||||
mouse_y: mouseY
|
mouse_y: mouseY
|
||||||
|
@ -796,7 +804,7 @@ export const mouseUpEvent = function (evt) {
|
||||||
});
|
});
|
||||||
|
|
||||||
if (!keep && !isNullish(element)) {
|
if (!keep && !isNullish(element)) {
|
||||||
eventContext_.getCanvas().getCurrentDrawing().releaseId(eventContext_.getId());
|
svgCanvas.getCurrentDrawing().releaseId(eventContext_.getId());
|
||||||
element.remove();
|
element.remove();
|
||||||
element = null;
|
element = null;
|
||||||
|
|
||||||
|
@ -817,21 +825,21 @@ export const mouseUpEvent = function (evt) {
|
||||||
t.id !== 'svgcanvas' && t.id !== 'svgroot'
|
t.id !== 'svgcanvas' && t.id !== 'svgroot'
|
||||||
) {
|
) {
|
||||||
// switch into "select" mode if we've clicked on an element
|
// switch into "select" mode if we've clicked on an element
|
||||||
eventContext_.getCanvas().setMode('select');
|
svgCanvas.setMode('select');
|
||||||
eventContext_.getCanvas().selectOnly([ t ], true);
|
svgCanvas.selectOnly([ t ], true);
|
||||||
}
|
}
|
||||||
} else if (!isNullish(element)) {
|
} else if (!isNullish(element)) {
|
||||||
/**
|
/**
|
||||||
* @name module:svgcanvas.SvgCanvas#addedNew
|
* @name module:svgcanvas.SvgCanvas#addedNew
|
||||||
* @type {boolean}
|
* @type {boolean}
|
||||||
*/
|
*/
|
||||||
eventContext_.getCanvas().addedNew = true;
|
svgCanvas.addedNew = true;
|
||||||
|
|
||||||
if (useUnit) { convertAttrs(element); }
|
if (useUnit) { convertAttrs(element); }
|
||||||
|
|
||||||
let aniDur = 0.2;
|
let aniDur = 0.2;
|
||||||
let cAni;
|
let cAni;
|
||||||
const curShape = eventContext_.getCanvas().getStyle();
|
const curShape = svgCanvas.getStyle();
|
||||||
const opacAni = eventContext_.getOpacAni();
|
const opacAni = eventContext_.getOpacAni();
|
||||||
if (opacAni.beginElement && Number.parseFloat(element.getAttribute('opacity')) !== curShape.opacity) {
|
if (opacAni.beginElement && Number.parseFloat(element.getAttribute('opacity')) !== curShape.opacity) {
|
||||||
cAni = opacAni.cloneNode(true);
|
cAni = opacAni.cloneNode(true);
|
||||||
|
@ -854,14 +862,14 @@ export const mouseUpEvent = function (evt) {
|
||||||
element.setAttribute('style', 'pointer-events:inherit');
|
element.setAttribute('style', 'pointer-events:inherit');
|
||||||
cleanupElement(element);
|
cleanupElement(element);
|
||||||
if (eventContext_.getCurrentMode() === 'path') {
|
if (eventContext_.getCurrentMode() === 'path') {
|
||||||
eventContext_.getCanvas().pathActions.toEditMode(element);
|
svgCanvas.pathActions.toEditMode(element);
|
||||||
} else if (eventContext_.getCurConfig().selectNew) {
|
} else if (eventContext_.getCurConfig().selectNew) {
|
||||||
eventContext_.getCanvas().selectOnly([ element ], true);
|
svgCanvas.selectOnly([ element ], true);
|
||||||
}
|
}
|
||||||
// we create the insert command that is stored on the stack
|
// we create the insert command that is stored on the stack
|
||||||
// undo means to call cmd.unapply(), redo means to call cmd.apply()
|
// undo means to call cmd.unapply(), redo means to call cmd.apply()
|
||||||
eventContext_.addCommandToHistory(new InsertElementCommand(element));
|
eventContext_.addCommandToHistory(new InsertElementCommand(element));
|
||||||
eventContext_.getCanvas().call('changed', [ element ]);
|
svgCanvas.call('changed', [ element ]);
|
||||||
}, aniDur * 1000);
|
}, aniDur * 1000);
|
||||||
}
|
}
|
||||||
eventContext_.setStartTransform(null);
|
eventContext_.setStartTransform(null);
|
||||||
|
@ -871,13 +879,14 @@ export const dblClickEvent = function (evt) {
|
||||||
const selectedElements = eventContext_.getSelectedElements();
|
const selectedElements = eventContext_.getSelectedElements();
|
||||||
const evtTarget = evt.target;
|
const evtTarget = evt.target;
|
||||||
const parent = evtTarget.parentNode;
|
const parent = evtTarget.parentNode;
|
||||||
|
const svgCanvas = eventContext_.getCanvas();
|
||||||
|
|
||||||
let mouseTarget = eventContext_.getCanvas().getMouseTarget(evt);
|
let mouseTarget = svgCanvas.getMouseTarget(evt);
|
||||||
const { tagName } = mouseTarget;
|
const { tagName } = mouseTarget;
|
||||||
|
|
||||||
if (tagName === 'text' && eventContext_.getCurrentMode() !== 'textedit') {
|
if (tagName === 'text' && eventContext_.getCurrentMode() !== 'textedit') {
|
||||||
const pt = transformPoint(evt.pageX, evt.pageY, eventContext_.getrootSctm());
|
const pt = transformPoint(evt.pageX, evt.pageY, eventContext_.getrootSctm());
|
||||||
eventContext_.getCanvas().textActions.select(mouseTarget, pt.x, pt.y);
|
svgCanvas.textActions.select(mouseTarget, pt.x, pt.y);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Do nothing if already in current group
|
// Do nothing if already in current group
|
||||||
|
@ -888,9 +897,9 @@ export const dblClickEvent = function (evt) {
|
||||||
// this (similar to editing rotated paths)
|
// this (similar to editing rotated paths)
|
||||||
|
|
||||||
// Ungroup and regroup
|
// Ungroup and regroup
|
||||||
eventContext_.getCanvas().pushGroupProperties(mouseTarget);
|
svgCanvas.pushGroupProperties(mouseTarget);
|
||||||
mouseTarget = selectedElements[0];
|
mouseTarget = selectedElements[0];
|
||||||
eventContext_.getCanvas().clearSelection(true);
|
svgCanvas.clearSelection(true);
|
||||||
}
|
}
|
||||||
// Reset context
|
// Reset context
|
||||||
if (eventContext_.getCurrentGroup()) {
|
if (eventContext_.getCurrentGroup()) {
|
||||||
|
@ -898,8 +907,8 @@ export const dblClickEvent = function (evt) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((parent.tagName !== 'g' && parent.tagName !== 'a') ||
|
if ((parent.tagName !== 'g' && parent.tagName !== 'a') ||
|
||||||
parent === eventContext_.getCanvas().getCurrentDrawing().getCurrentLayer() ||
|
parent === svgCanvas.getCurrentDrawing().getCurrentLayer() ||
|
||||||
mouseTarget === eventContext_.getCanvas().selectorManager.selectorParentGroup
|
mouseTarget === svgCanvas.selectorManager.selectorParentGroup
|
||||||
) {
|
) {
|
||||||
// Escape from in-group edit
|
// Escape from in-group edit
|
||||||
return;
|
return;
|
||||||
|
@ -919,17 +928,19 @@ export const dblClickEvent = function (evt) {
|
||||||
*/
|
*/
|
||||||
export const mouseDownEvent = function (evt) {
|
export const mouseDownEvent = function (evt) {
|
||||||
const dataStorage = eventContext_.getDataStorage();
|
const dataStorage = eventContext_.getDataStorage();
|
||||||
const selectedElements = eventContext_.getSelectedElements();
|
const selectedElements = eventContext_.getSelectedElements;
|
||||||
const currentZoom = eventContext_.getCurrentZoom();
|
const currentZoom = eventContext_.getCurrentZoom();
|
||||||
const curShape = eventContext_.getCanvas().getStyle();
|
|
||||||
const svgCanvas = eventContext_.getCanvas();
|
const svgCanvas = eventContext_.getCanvas();
|
||||||
|
const curShape = svgCanvas.getStyle();
|
||||||
|
const svgRoot = eventContext_.getSVGRoot();
|
||||||
const { $id } = svgCanvas;
|
const { $id } = svgCanvas;
|
||||||
if (eventContext_.getCanvas().spaceKey || evt.button === 1) { return; }
|
|
||||||
|
|
||||||
const rightClick = evt.button === 2;
|
if (svgCanvas.spaceKey || evt.button === 1) { return; }
|
||||||
|
|
||||||
|
const rightClick = (evt.button === 2);
|
||||||
|
|
||||||
if (evt.altKey) { // duplicate when dragging
|
if (evt.altKey) { // duplicate when dragging
|
||||||
eventContext_.getCanvas().cloneSelectedElements(0, 0);
|
svgCanvas.cloneSelectedElements(0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
eventContext_.setRootSctm($id('svgcontent').querySelector('g').getScreenCTM().inverse());
|
eventContext_.setRootSctm($id('svgcontent').querySelector('g').getScreenCTM().inverse());
|
||||||
|
@ -947,7 +958,7 @@ export const mouseDownEvent = function (evt) {
|
||||||
|
|
||||||
let x = mouseX / currentZoom;
|
let x = mouseX / currentZoom;
|
||||||
let y = mouseY / currentZoom;
|
let y = mouseY / currentZoom;
|
||||||
let mouseTarget = eventContext_.getCanvas().getMouseTarget(evt);
|
let mouseTarget = svgCanvas.getMouseTarget(evt);
|
||||||
|
|
||||||
if (mouseTarget.tagName === 'a' && mouseTarget.childNodes.length === 1) {
|
if (mouseTarget.tagName === 'a' && mouseTarget.childNodes.length === 1) {
|
||||||
mouseTarget = mouseTarget.firstChild;
|
mouseTarget = mouseTarget.firstChild;
|
||||||
|
@ -971,18 +982,19 @@ export const mouseDownEvent = function (evt) {
|
||||||
// if it is a selector grip, then it must be a single element selected,
|
// if it is a selector grip, then it must be a single element selected,
|
||||||
// set the mouseTarget to that and update the mode to rotate/resize
|
// set the mouseTarget to that and update the mode to rotate/resize
|
||||||
|
|
||||||
if (mouseTarget === eventContext_.getCanvas().selectorManager.selectorParentGroup && !isNullish(selectedElements[0])) {
|
if (mouseTarget === svgCanvas.selectorManager.selectorParentGroup && !isNullish(selectedElements()[0])) {
|
||||||
const grip = evt.target;
|
const grip = evt.target;
|
||||||
const griptype = dataStorage.get(grip, 'type');
|
const griptype = dataStorage.get(grip, 'type');
|
||||||
// rotating
|
// rotating
|
||||||
if (griptype === 'rotate') {
|
if (griptype === 'rotate') {
|
||||||
eventContext_.setCurrentMode('rotate');
|
eventContext_.setCurrentMode('rotate');
|
||||||
|
// eventContext_.setCurrentRotateMode(dataStorage.get(grip, 'dir'));
|
||||||
// resizing
|
// resizing
|
||||||
} else if (griptype === 'resize') {
|
} else if (griptype === 'resize') {
|
||||||
eventContext_.setCurrentMode('resize');
|
eventContext_.setCurrentMode('resize');
|
||||||
eventContext_.setCurrentResizeMode(dataStorage.get(grip, 'dir'));
|
eventContext_.setCurrentResizeMode(dataStorage.get(grip, 'dir'));
|
||||||
}
|
}
|
||||||
mouseTarget = selectedElements[0];
|
mouseTarget = selectedElements()[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
eventContext_.setStartTransform(mouseTarget.getAttribute('transform'));
|
eventContext_.setStartTransform(mouseTarget.getAttribute('transform'));
|
||||||
|
@ -994,39 +1006,39 @@ export const mouseDownEvent = function (evt) {
|
||||||
eventContext_.setCurrentResizeMode('none');
|
eventContext_.setCurrentResizeMode('none');
|
||||||
if (rightClick) { eventContext_.setStarted(false); }
|
if (rightClick) { eventContext_.setStarted(false); }
|
||||||
|
|
||||||
if (mouseTarget !== eventContext_.getSVGRoot()) {
|
if (mouseTarget !== svgRoot) {
|
||||||
// if this element is not yet selected, clear selection and select it
|
// if this element is not yet selected, clear selection and select it
|
||||||
if (!selectedElements.includes(mouseTarget)) {
|
if (!selectedElements().includes(mouseTarget)) {
|
||||||
// only clear selection if shift is not pressed (otherwise, add
|
// only clear selection if shift is not pressed (otherwise, add
|
||||||
// element to selection)
|
// element to selection)
|
||||||
if (!evt.shiftKey) {
|
if (!evt.shiftKey) {
|
||||||
// No need to do the call here as it will be done on addToSelection
|
// No need to do the call here as it will be done on addToSelection
|
||||||
eventContext_.getCanvas().clearSelection(true);
|
svgCanvas.clearSelection(true);
|
||||||
}
|
}
|
||||||
eventContext_.getCanvas().addToSelection([ mouseTarget ]);
|
svgCanvas.addToSelection([ mouseTarget ]);
|
||||||
eventContext_.setJustSelected(mouseTarget);
|
eventContext_.setJustSelected(mouseTarget);
|
||||||
eventContext_.getCanvas().pathActions.clear();
|
svgCanvas.pathActions.clear();
|
||||||
}
|
}
|
||||||
// else if it's a path, go into pathedit mode in mouseup
|
// else if it's a path, go into pathedit mode in mouseup
|
||||||
|
|
||||||
if (!rightClick) {
|
if (!rightClick) {
|
||||||
// insert a dummy transform so if the element(s) are moved it will have
|
// insert a dummy transform so if the element(s) are moved it will have
|
||||||
// a transform to use for its translate
|
// a transform to use for its translate
|
||||||
for (const selectedElement of selectedElements) {
|
for (const selectedElement of selectedElements()) {
|
||||||
if (isNullish(selectedElement)) { continue; }
|
if (isNullish(selectedElement)) { continue; }
|
||||||
const slist = getTransformList(selectedElement);
|
const slist = getTransformList(selectedElement);
|
||||||
if (slist.numberOfItems) {
|
if (slist.numberOfItems) {
|
||||||
slist.insertItemBefore(eventContext_.getSVGRoot().createSVGTransform(), 0);
|
slist.insertItemBefore(svgRoot.createSVGTransform(), 0);
|
||||||
} else {
|
} else {
|
||||||
slist.appendItem(eventContext_.getSVGRoot().createSVGTransform());
|
slist.appendItem(svgRoot.createSVGTransform());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (!rightClick) {
|
} else if (!rightClick) {
|
||||||
eventContext_.getCanvas().clearSelection();
|
svgCanvas.clearSelection();
|
||||||
eventContext_.setCurrentMode('multiselect');
|
eventContext_.setCurrentMode('multiselect');
|
||||||
if (isNullish(eventContext_.getRubberBox())) {
|
if (isNullish(eventContext_.getRubberBox())) {
|
||||||
eventContext_.setRubberBox(eventContext_.getCanvas().selectorManager.getRubberBandBox());
|
eventContext_.setRubberBox(svgCanvas.selectorManager.getRubberBandBox());
|
||||||
}
|
}
|
||||||
eventContext_.setRStartX(eventContext_.getRStartX() * currentZoom);
|
eventContext_.setRStartX(eventContext_.getRStartX() * currentZoom);
|
||||||
eventContext_.setRStartY(eventContext_.getRStartY() * currentZoom);
|
eventContext_.setRStartY(eventContext_.getRStartY() * currentZoom);
|
||||||
|
@ -1043,7 +1055,7 @@ export const mouseDownEvent = function (evt) {
|
||||||
case 'zoom':
|
case 'zoom':
|
||||||
eventContext_.setStarted(true);
|
eventContext_.setStarted(true);
|
||||||
if (isNullish(eventContext_.getRubberBox())) {
|
if (isNullish(eventContext_.getRubberBox())) {
|
||||||
eventContext_.setRubberBox(eventContext_.getCanvas().selectorManager.getRubberBandBox());
|
eventContext_.setRubberBox(svgCanvas.selectorManager.getRubberBandBox());
|
||||||
}
|
}
|
||||||
assignAttributes(eventContext_.getRubberBox(), {
|
assignAttributes(eventContext_.getRubberBox(), {
|
||||||
x: realX * currentZoom,
|
x: realX * currentZoom,
|
||||||
|
@ -1072,43 +1084,13 @@ export const mouseDownEvent = function (evt) {
|
||||||
const pos = getRotationAngle(mouseTarget) ? 1 : 0;
|
const pos = getRotationAngle(mouseTarget) ? 1 : 0;
|
||||||
|
|
||||||
if (hasMatrixTransform(tlist)) {
|
if (hasMatrixTransform(tlist)) {
|
||||||
tlist.insertItemBefore(eventContext_.getSVGRoot().createSVGTransform(), pos);
|
tlist.insertItemBefore(svgRoot.createSVGTransform(), pos);
|
||||||
tlist.insertItemBefore(eventContext_.getSVGRoot().createSVGTransform(), pos);
|
tlist.insertItemBefore(svgRoot.createSVGTransform(), pos);
|
||||||
tlist.insertItemBefore(eventContext_.getSVGRoot().createSVGTransform(), pos);
|
tlist.insertItemBefore(svgRoot.createSVGTransform(), pos);
|
||||||
} else {
|
} else {
|
||||||
tlist.appendItem(eventContext_.getSVGRoot().createSVGTransform());
|
tlist.appendItem(svgRoot.createSVGTransform());
|
||||||
tlist.appendItem(eventContext_.getSVGRoot().createSVGTransform());
|
tlist.appendItem(svgRoot.createSVGTransform());
|
||||||
tlist.appendItem(eventContext_.getSVGRoot().createSVGTransform());
|
tlist.appendItem(svgRoot.createSVGTransform());
|
||||||
|
|
||||||
if (supportsNonScalingStroke()) {
|
|
||||||
// Handle crash for newer Chrome and Safari 6 (Mobile and Desktop):
|
|
||||||
// https://code.google.com/p/svg-edit/issues/detail?id=904
|
|
||||||
// Chromium issue: https://code.google.com/p/chromium/issues/detail?id=114625
|
|
||||||
// TODO: Remove this workaround once vendor fixes the issue
|
|
||||||
const iswebkit = isWebkit();
|
|
||||||
|
|
||||||
let delayedStroke;
|
|
||||||
if (iswebkit) {
|
|
||||||
delayedStroke = function (ele) {
|
|
||||||
const stroke_ = ele.getAttribute('stroke');
|
|
||||||
ele.removeAttribute('stroke');
|
|
||||||
// Re-apply stroke after delay. Anything higher than 1 seems to cause flicker
|
|
||||||
if (stroke_ !== null) setTimeout(function () { ele.setAttribute('stroke', stroke_); }, 0);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
mouseTarget.style.vectorEffect = 'non-scaling-stroke';
|
|
||||||
if (iswebkit) { delayedStroke(mouseTarget); }
|
|
||||||
|
|
||||||
const all = mouseTarget.getElementsByTagName('*');
|
|
||||||
const len = all.length;
|
|
||||||
for (let i = 0; i < len; i++) {
|
|
||||||
if (!all[i].style) { // mathML
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
all[i].style.vectorEffect = 'non-scaling-stroke';
|
|
||||||
if (iswebkit) { delayedStroke(all[i]); }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1124,12 +1106,12 @@ export const mouseDownEvent = function (evt) {
|
||||||
eventContext_.setDAttr(realX + ',' + realY + ' ');
|
eventContext_.setDAttr(realX + ',' + realY + ' ');
|
||||||
// Commented out as doing nothing now:
|
// Commented out as doing nothing now:
|
||||||
// strokeW = parseFloat(curShape.stroke_width) === 0 ? 1 : curShape.stroke_width;
|
// strokeW = parseFloat(curShape.stroke_width) === 0 ? 1 : curShape.stroke_width;
|
||||||
eventContext_.getCanvas().addSVGElementFromJson({
|
svgCanvas.addSVGElementFromJson({
|
||||||
element: 'polyline',
|
element: 'polyline',
|
||||||
curStyles: true,
|
curStyles: true,
|
||||||
attr: {
|
attr: {
|
||||||
points: eventContext_.getDAttr(),
|
points: eventContext_.getDAttr(),
|
||||||
id: eventContext_.getCanvas().getNextId(),
|
id: svgCanvas.getNextId(),
|
||||||
fill: 'none',
|
fill: 'none',
|
||||||
opacity: curShape.opacity / 2,
|
opacity: curShape.opacity / 2,
|
||||||
'stroke-linecap': 'round',
|
'stroke-linecap': 'round',
|
||||||
|
@ -1143,14 +1125,14 @@ export const mouseDownEvent = function (evt) {
|
||||||
break;
|
break;
|
||||||
case 'image': {
|
case 'image': {
|
||||||
eventContext_.setStarted(true);
|
eventContext_.setStarted(true);
|
||||||
const newImage = eventContext_.getCanvas().addSVGElementFromJson({
|
const newImage = svgCanvas.addSVGElementFromJson({
|
||||||
element: 'image',
|
element: 'image',
|
||||||
attr: {
|
attr: {
|
||||||
x,
|
x,
|
||||||
y,
|
y,
|
||||||
width: 0,
|
width: 0,
|
||||||
height: 0,
|
height: 0,
|
||||||
id: eventContext_.getCanvas().getNextId(),
|
id: svgCanvas.getNextId(),
|
||||||
opacity: curShape.opacity / 2,
|
opacity: curShape.opacity / 2,
|
||||||
style: 'pointer-events:inherit'
|
style: 'pointer-events:inherit'
|
||||||
}
|
}
|
||||||
|
@ -1166,7 +1148,7 @@ export const mouseDownEvent = function (evt) {
|
||||||
eventContext_.setStarted(true);
|
eventContext_.setStarted(true);
|
||||||
eventContext_.setStartX(x);
|
eventContext_.setStartX(x);
|
||||||
eventContext_.setStartY(y);
|
eventContext_.setStartY(y);
|
||||||
eventContext_.getCanvas().addSVGElementFromJson({
|
svgCanvas.addSVGElementFromJson({
|
||||||
element: 'rect',
|
element: 'rect',
|
||||||
curStyles: true,
|
curStyles: true,
|
||||||
attr: {
|
attr: {
|
||||||
|
@ -1174,7 +1156,7 @@ export const mouseDownEvent = function (evt) {
|
||||||
y,
|
y,
|
||||||
width: 0,
|
width: 0,
|
||||||
height: 0,
|
height: 0,
|
||||||
id: eventContext_.getCanvas().getNextId(),
|
id: svgCanvas.getNextId(),
|
||||||
opacity: curShape.opacity / 2
|
opacity: curShape.opacity / 2
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -1182,7 +1164,7 @@ export const mouseDownEvent = function (evt) {
|
||||||
case 'line': {
|
case 'line': {
|
||||||
eventContext_.setStarted(true);
|
eventContext_.setStarted(true);
|
||||||
const strokeW = Number(curShape.stroke_width) === 0 ? 1 : curShape.stroke_width;
|
const strokeW = Number(curShape.stroke_width) === 0 ? 1 : curShape.stroke_width;
|
||||||
eventContext_.getCanvas().addSVGElementFromJson({
|
svgCanvas.addSVGElementFromJson({
|
||||||
element: 'line',
|
element: 'line',
|
||||||
curStyles: true,
|
curStyles: true,
|
||||||
attr: {
|
attr: {
|
||||||
|
@ -1190,7 +1172,7 @@ export const mouseDownEvent = function (evt) {
|
||||||
y1: y,
|
y1: y,
|
||||||
x2: x,
|
x2: x,
|
||||||
y2: y,
|
y2: y,
|
||||||
id: eventContext_.getCanvas().getNextId(),
|
id: svgCanvas.getNextId(),
|
||||||
stroke: curShape.stroke,
|
stroke: curShape.stroke,
|
||||||
'stroke-width': strokeW,
|
'stroke-width': strokeW,
|
||||||
'stroke-dasharray': curShape.stroke_dasharray,
|
'stroke-dasharray': curShape.stroke_dasharray,
|
||||||
|
@ -1205,21 +1187,21 @@ export const mouseDownEvent = function (evt) {
|
||||||
break;
|
break;
|
||||||
} case 'circle':
|
} case 'circle':
|
||||||
eventContext_.setStarted(true);
|
eventContext_.setStarted(true);
|
||||||
eventContext_.getCanvas().addSVGElementFromJson({
|
svgCanvas.addSVGElementFromJson({
|
||||||
element: 'circle',
|
element: 'circle',
|
||||||
curStyles: true,
|
curStyles: true,
|
||||||
attr: {
|
attr: {
|
||||||
cx: x,
|
cx: x,
|
||||||
cy: y,
|
cy: y,
|
||||||
r: 0,
|
r: 0,
|
||||||
id: eventContext_.getCanvas().getNextId(),
|
id: svgCanvas.getNextId(),
|
||||||
opacity: curShape.opacity / 2
|
opacity: curShape.opacity / 2
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
break;
|
break;
|
||||||
case 'ellipse':
|
case 'ellipse':
|
||||||
eventContext_.setStarted(true);
|
eventContext_.setStarted(true);
|
||||||
eventContext_.getCanvas().addSVGElementFromJson({
|
svgCanvas.addSVGElementFromJson({
|
||||||
element: 'ellipse',
|
element: 'ellipse',
|
||||||
curStyles: true,
|
curStyles: true,
|
||||||
attr: {
|
attr: {
|
||||||
|
@ -1227,20 +1209,20 @@ export const mouseDownEvent = function (evt) {
|
||||||
cy: y,
|
cy: y,
|
||||||
rx: 0,
|
rx: 0,
|
||||||
ry: 0,
|
ry: 0,
|
||||||
id: eventContext_.getCanvas().getNextId(),
|
id: svgCanvas.getNextId(),
|
||||||
opacity: curShape.opacity / 2
|
opacity: curShape.opacity / 2
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
break;
|
break;
|
||||||
case 'text':
|
case 'text':
|
||||||
eventContext_.setStarted(true);
|
eventContext_.setStarted(true);
|
||||||
/* const newText = */ eventContext_.getCanvas().addSVGElementFromJson({
|
/* const newText = */ svgCanvas.addSVGElementFromJson({
|
||||||
element: 'text',
|
element: 'text',
|
||||||
curStyles: true,
|
curStyles: true,
|
||||||
attr: {
|
attr: {
|
||||||
x,
|
x,
|
||||||
y,
|
y,
|
||||||
id: eventContext_.getCanvas().getNextId(),
|
id: svgCanvas.getNextId(),
|
||||||
fill: eventContext_.getCurText('fill'),
|
fill: eventContext_.getCurText('fill'),
|
||||||
'stroke-width': eventContext_.getCurText('stroke_width'),
|
'stroke-width': eventContext_.getCurText('stroke_width'),
|
||||||
'font-size': eventContext_.getCurText('font_size'),
|
'font-size': eventContext_.getCurText('font_size'),
|
||||||
|
@ -1257,19 +1239,19 @@ export const mouseDownEvent = function (evt) {
|
||||||
case 'pathedit':
|
case 'pathedit':
|
||||||
eventContext_.setStartX(eventContext_.getStartX() * currentZoom);
|
eventContext_.setStartX(eventContext_.getStartX() * currentZoom);
|
||||||
eventContext_.setStartY(eventContext_.getStartY() * currentZoom);
|
eventContext_.setStartY(eventContext_.getStartY() * currentZoom);
|
||||||
eventContext_.getCanvas().pathActions.mouseDown(evt, mouseTarget, eventContext_.getStartX(), eventContext_.getStartY());
|
svgCanvas.pathActions.mouseDown(evt, mouseTarget, eventContext_.getStartX(), eventContext_.getStartY());
|
||||||
eventContext_.setStarted(true);
|
eventContext_.setStarted(true);
|
||||||
break;
|
break;
|
||||||
case 'textedit':
|
case 'textedit':
|
||||||
eventContext_.setStartX(eventContext_.getStartX() * currentZoom);
|
eventContext_.setStartX(eventContext_.getStartX() * currentZoom);
|
||||||
eventContext_.setStartY(eventContext_.getStartY() * currentZoom);
|
eventContext_.setStartY(eventContext_.getStartY() * currentZoom);
|
||||||
eventContext_.getCanvas().textActions.mouseDown(evt, mouseTarget, eventContext_.getStartX(), eventContext_.getStartY());
|
svgCanvas.textActions.mouseDown(evt, mouseTarget, eventContext_.getStartX(), eventContext_.getStartY());
|
||||||
eventContext_.setStarted(true);
|
eventContext_.setStarted(true);
|
||||||
break;
|
break;
|
||||||
case 'rotate':
|
case 'rotate':
|
||||||
eventContext_.setStarted(true);
|
eventContext_.setStarted(true);
|
||||||
// we are starting an undoable change (a drag-rotation)
|
// we are starting an undoable change (a drag-rotation)
|
||||||
eventContext_.getCanvas().undoMgr.beginUndoableChange('transform', selectedElements);
|
svgCanvas.undoMgr.beginUndoableChange('transform', selectedElements());
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
// This could occur in an extension
|
// This could occur in an extension
|
||||||
|
@ -1285,11 +1267,11 @@ export const mouseDownEvent = function (evt) {
|
||||||
* @property {Float} start_y y coordinate on canvas
|
* @property {Float} start_y y coordinate on canvas
|
||||||
* @property {Element[]} selectedElements An array of the selected Elements
|
* @property {Element[]} selectedElements An array of the selected Elements
|
||||||
*/
|
*/
|
||||||
const extResult = eventContext_.getCanvas().runExtensions('mouseDown', {
|
const extResult = svgCanvas.runExtensions('mouseDown', {
|
||||||
event: evt,
|
event: evt,
|
||||||
start_x: eventContext_.getStartX(),
|
start_x: eventContext_.getStartX(),
|
||||||
start_y: eventContext_.getStartY(),
|
start_y: eventContext_.getStartY(),
|
||||||
selectedElements
|
selectedElements: selectedElements()
|
||||||
}, true);
|
}, true);
|
||||||
|
|
||||||
extResult.forEach(function(r){
|
extResult.forEach(function(r){
|
||||||
|
@ -1380,9 +1362,9 @@ export const DOMMouseScrollEvent = function (e) {
|
||||||
y: topLeftNewCanvas.y - rulerwidth + editorFullH / 2
|
y: topLeftNewCanvas.y - rulerwidth + editorFullH / 2
|
||||||
};
|
};
|
||||||
|
|
||||||
eventContext_.getCanvas().setZoom(zoomlevel);
|
svgCanvas.setZoom(zoomlevel);
|
||||||
document.getElementById('zoom').value = ((zoomlevel * 100).toFixed(1));
|
document.getElementById('zoom').value = ((zoomlevel * 100).toFixed(1));
|
||||||
|
|
||||||
eventContext_.getCanvas().call('updateCanvas', { center: false, newCtr });
|
svgCanvas.call('updateCanvas', { center: false, newCtr });
|
||||||
eventContext_.getCanvas().call('zoomDone');
|
svgCanvas.call('zoomDone');
|
||||||
};
|
};
|
||||||
|
|
|
@ -707,7 +707,7 @@ export const recalculateDimensions = function (selected) {
|
||||||
x1: selected.getAttribute('x1'),
|
x1: selected.getAttribute('x1'),
|
||||||
y1: selected.getAttribute('y1'),
|
y1: selected.getAttribute('y1'),
|
||||||
x2: selected.getAttribute('x2'),
|
x2: selected.getAttribute('x2'),
|
||||||
y2: selected.getAttribute('y2'),
|
y2: selected.getAttribute('y2')
|
||||||
};
|
};
|
||||||
// Fallthrough
|
// Fallthrough
|
||||||
case 'polyline':
|
case 'polyline':
|
||||||
|
|
|
@ -535,7 +535,7 @@ export const pushGroupProperty = function (g, undoable) {
|
||||||
|
|
||||||
const gattrs = {
|
const gattrs = {
|
||||||
filter: g.getAttribute('filter'),
|
filter: g.getAttribute('filter'),
|
||||||
opacity: g.getAttribute('opacity'),
|
opacity: g.getAttribute('opacity')
|
||||||
};
|
};
|
||||||
let gfilter; let gblur; let changes;
|
let gfilter; let gblur; let changes;
|
||||||
const drawing = elementContext_.getDrawing();
|
const drawing = elementContext_.getDrawing();
|
||||||
|
@ -719,7 +719,7 @@ export const convertToGroup = function (elem) {
|
||||||
const svg = elem.firstChild;
|
const svg = elem.firstChild;
|
||||||
const pt = {
|
const pt = {
|
||||||
x: svg.getAttribute('x'),
|
x: svg.getAttribute('x'),
|
||||||
y: svg.getAttribute('y'),
|
y: svg.getAttribute('y')
|
||||||
};
|
};
|
||||||
|
|
||||||
// $(elem.firstChild.firstChild).unwrap();
|
// $(elem.firstChild.firstChild).unwrap();
|
||||||
|
|
|
@ -18,6 +18,8 @@ import { getClosest } from '../editor/components/jgraduate/Util.js';
|
||||||
|
|
||||||
const { BatchCommand } = hstry;
|
const { BatchCommand } = hstry;
|
||||||
let selectionContext_ = null;
|
let selectionContext_ = null;
|
||||||
|
let svgCanvas = null;
|
||||||
|
let selectedElements;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @function module:selection.init
|
* @function module:selection.init
|
||||||
|
@ -26,6 +28,8 @@ let selectionContext_ = null;
|
||||||
*/
|
*/
|
||||||
export const init = function (selectionContext) {
|
export const init = function (selectionContext) {
|
||||||
selectionContext_ = selectionContext;
|
selectionContext_ = selectionContext;
|
||||||
|
svgCanvas = selectionContext_.getCanvas();
|
||||||
|
selectedElements = selectionContext_.getSelectedElements;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -36,16 +40,15 @@ export const init = function (selectionContext) {
|
||||||
* @fires module:selection.SvgCanvas#event:selected
|
* @fires module:selection.SvgCanvas#event:selected
|
||||||
*/
|
*/
|
||||||
export const clearSelectionMethod = function (noCall) {
|
export const clearSelectionMethod = function (noCall) {
|
||||||
const selectedElements = selectionContext_.getSelectedElements();
|
selectedElements().forEach((elem) => {
|
||||||
selectedElements.forEach((elem) => {
|
|
||||||
if (isNullish(elem)) {
|
if (isNullish(elem)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
selectionContext_.getCanvas().selectorManager.releaseSelector(elem);
|
svgCanvas.selectorManager.releaseSelector(elem);
|
||||||
});
|
});
|
||||||
selectionContext_.getCanvas().setEmptySelectedElements();
|
svgCanvas.setEmptySelectedElements();
|
||||||
|
|
||||||
if (!noCall) { selectionContext_.getCanvas().call('selected', selectionContext_.getSelectedElements()); }
|
if (!noCall) { svgCanvas.call('selected', selectedElements()); }
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -55,13 +58,12 @@ export const clearSelectionMethod = function (noCall) {
|
||||||
* @fires module:selection.SvgCanvas#event:selected
|
* @fires module:selection.SvgCanvas#event:selected
|
||||||
*/
|
*/
|
||||||
export const addToSelectionMethod = function (elemsToAdd, showGrips) {
|
export const addToSelectionMethod = function (elemsToAdd, showGrips) {
|
||||||
const selectedElements = selectionContext_.getSelectedElements();
|
|
||||||
if (!elemsToAdd.length) { return; }
|
if (!elemsToAdd.length) { return; }
|
||||||
// find the first null in our selectedElements array
|
// find the first null in our selectedElements array
|
||||||
|
|
||||||
let j = 0;
|
let j = 0;
|
||||||
while (j < selectedElements.length) {
|
while (j < selectedElements().length) {
|
||||||
if (isNullish(selectedElements[j])) {
|
if (isNullish(selectedElements()[j])) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
++j;
|
++j;
|
||||||
|
@ -81,32 +83,32 @@ export const addToSelectionMethod = function (elemsToAdd, showGrips) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// if it's not already there, add it
|
// if it's not already there, add it
|
||||||
if (!selectedElements.includes(elem)) {
|
if (!selectedElements().includes(elem)) {
|
||||||
selectedElements[j] = elem;
|
selectedElements()[j] = elem;
|
||||||
|
|
||||||
// only the first selectedBBoxes element is ever used in the codebase these days
|
// only the first selectedBBoxes element is ever used in the codebase these days
|
||||||
// if (j === 0) selectedBBoxes[0] = utilsGetBBox(elem);
|
// if (j === 0) selectedBBoxes[0] = utilsGetBBox(elem);
|
||||||
j++;
|
j++;
|
||||||
const sel = selectionContext_.getCanvas().selectorManager.requestSelector(elem, bbox);
|
const sel = svgCanvas.selectorManager.requestSelector(elem, bbox);
|
||||||
|
|
||||||
if (selectedElements.length > 1) {
|
if (selectedElements().length > 1) {
|
||||||
sel.showGrips(false);
|
sel.showGrips(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!selectedElements.length) {
|
if (!selectedElements().length) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
selectionContext_.getCanvas().call('selected', selectedElements);
|
svgCanvas.call('selected', selectedElements());
|
||||||
|
|
||||||
if (selectedElements.length === 1) {
|
if (selectedElements().length === 1) {
|
||||||
selectionContext_.getCanvas().selectorManager.requestSelector(selectedElements[0]).showGrips(showGrips);
|
svgCanvas.selectorManager.requestSelector(selectedElements()[0]).showGrips(showGrips);
|
||||||
}
|
}
|
||||||
|
|
||||||
// make sure the elements are in the correct order
|
// make sure the elements are in the correct order
|
||||||
// See: https://www.w3.org/TR/DOM-Level-3-Core/core.html#Node3-compareDocumentPosition
|
// See: https://www.w3.org/TR/DOM-Level-3-Core/core.html#Node3-compareDocumentPosition
|
||||||
|
|
||||||
selectedElements.sort(function (a, b) {
|
selectedElements().sort(function (a, b) {
|
||||||
if (a && b && a.compareDocumentPosition) {
|
if (a && b && a.compareDocumentPosition) {
|
||||||
return 3 - (b.compareDocumentPosition(a) & 6); // eslint-disable-line no-bitwise
|
return 3 - (b.compareDocumentPosition(a) & 6); // eslint-disable-line no-bitwise
|
||||||
}
|
}
|
||||||
|
@ -117,8 +119,8 @@ export const addToSelectionMethod = function (elemsToAdd, showGrips) {
|
||||||
});
|
});
|
||||||
|
|
||||||
// Make sure first elements are not null
|
// Make sure first elements are not null
|
||||||
while (isNullish(selectedElements[0])) {
|
while (isNullish(selectedElements())[0]) {
|
||||||
selectedElements.shift(0);
|
selectedElements().shift(0);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
/**
|
/**
|
||||||
|
@ -147,7 +149,7 @@ export const getMouseTargetMethod = function (evt) {
|
||||||
|
|
||||||
// Get the desired mouseTarget with jQuery selector-fu
|
// Get the desired mouseTarget with jQuery selector-fu
|
||||||
// If it's root-like, select the root
|
// If it's root-like, select the root
|
||||||
const currentLayer = selectionContext_.getCanvas().getCurrentDrawing().getCurrentLayer();
|
const currentLayer = svgCanvas.getCurrentDrawing().getCurrentLayer();
|
||||||
const svgRoot = selectionContext_.getSVGRoot();
|
const svgRoot = selectionContext_.getSVGRoot();
|
||||||
const container = selectionContext_.getDOMContainer();
|
const container = selectionContext_.getDOMContainer();
|
||||||
const content = selectionContext_.getSVGContent();
|
const content = selectionContext_.getSVGContent();
|
||||||
|
@ -159,7 +161,7 @@ export const getMouseTargetMethod = function (evt) {
|
||||||
if (getClosest(mouseTarget.parentNode, '#selectorParentGroup')) {
|
if (getClosest(mouseTarget.parentNode, '#selectorParentGroup')) {
|
||||||
// While we could instead have just returned mouseTarget,
|
// While we could instead have just returned mouseTarget,
|
||||||
// this makes it easier to indentify as being a selector grip
|
// this makes it easier to indentify as being a selector grip
|
||||||
return selectionContext_.getCanvas().selectorManager.selectorParentGroup;
|
return svgCanvas.selectorManager.selectorParentGroup;
|
||||||
}
|
}
|
||||||
|
|
||||||
while (!mouseTarget.parentNode?.isSameNode(selectionContext_.getCurrentGroup() || currentLayer)) {
|
while (!mouseTarget.parentNode?.isSameNode(selectionContext_.getCurrentGroup() || currentLayer)) {
|
||||||
|
@ -253,7 +255,7 @@ export const getIntersectionListMethod = function (rect) {
|
||||||
const currentZoom = selectionContext_.getCurrentZoom();
|
const currentZoom = selectionContext_.getCurrentZoom();
|
||||||
if (isNullish(selectionContext_.getRubberBox())) { return null; }
|
if (isNullish(selectionContext_.getRubberBox())) { return null; }
|
||||||
|
|
||||||
const parent = selectionContext_.getCurrentGroup() || selectionContext_.getCanvas().getCurrentDrawing().getCurrentLayer();
|
const parent = selectionContext_.getCurrentGroup() || svgCanvas.getCurrentDrawing().getCurrentLayer();
|
||||||
|
|
||||||
let rubberBBox;
|
let rubberBBox;
|
||||||
if (!rect) {
|
if (!rect) {
|
||||||
|
@ -315,7 +317,7 @@ export const groupSvgElem = function (elem) {
|
||||||
elem.replaceWith(g);
|
elem.replaceWith(g);
|
||||||
g.appendChild(elem);
|
g.appendChild(elem);
|
||||||
dataStorage.put(g, 'gsvg', elem);
|
dataStorage.put(g, 'gsvg', elem);
|
||||||
g.id = selectionContext_.getCanvas().getNextId();
|
g.id = svgCanvas.getNextId();
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -325,13 +327,13 @@ export const groupSvgElem = function (elem) {
|
||||||
* @returns {void}
|
* @returns {void}
|
||||||
*/
|
*/
|
||||||
export const prepareSvg = function (newDoc) {
|
export const prepareSvg = function (newDoc) {
|
||||||
selectionContext_.getCanvas().sanitizeSvg(newDoc.documentElement);
|
svgCanvas.sanitizeSvg(newDoc.documentElement);
|
||||||
|
|
||||||
// convert paths into absolute commands
|
// convert paths into absolute commands
|
||||||
const paths = [ ...newDoc.getElementsByTagNameNS(NS.SVG, 'path') ];
|
const paths = [ ...newDoc.getElementsByTagNameNS(NS.SVG, 'path') ];
|
||||||
paths.forEach((path) => {
|
paths.forEach((path) => {
|
||||||
path.setAttribute('d', selectionContext_.getCanvas().pathActions.convertPath(path));
|
path.setAttribute('d', svgCanvas.pathActions.convertPath(path));
|
||||||
selectionContext_.getCanvas().pathActions.fixEnd(path);
|
svgCanvas.pathActions.fixEnd(path);
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -345,10 +347,9 @@ export const prepareSvg = function (newDoc) {
|
||||||
* @returns {void}
|
* @returns {void}
|
||||||
*/
|
*/
|
||||||
export const setRotationAngle = function (val, preventUndo) {
|
export const setRotationAngle = function (val, preventUndo) {
|
||||||
const selectedElements = selectionContext_.getSelectedElements();
|
|
||||||
// ensure val is the proper type
|
// ensure val is the proper type
|
||||||
val = Number.parseFloat(val);
|
val = Number.parseFloat(val);
|
||||||
const elem = selectedElements[0];
|
const elem = selectedElements()[0];
|
||||||
const oldTransform = elem.getAttribute('transform');
|
const oldTransform = elem.getAttribute('transform');
|
||||||
const bbox = utilsGetBBox(elem);
|
const bbox = utilsGetBBox(elem);
|
||||||
const cx = bbox.x + bbox.width / 2; const cy = bbox.y + bbox.height / 2;
|
const cx = bbox.x + bbox.width / 2; const cy = bbox.y + bbox.height / 2;
|
||||||
|
@ -384,14 +385,14 @@ export const setRotationAngle = function (val, preventUndo) {
|
||||||
} else {
|
} else {
|
||||||
elem.removeAttribute('transform');
|
elem.removeAttribute('transform');
|
||||||
}
|
}
|
||||||
selectionContext_.getCanvas().changeSelectedAttribute('transform', newTransform, selectedElements);
|
svgCanvas.changeSelectedAttribute('transform', newTransform, selectedElements());
|
||||||
selectionContext_.getCanvas().call('changed', selectedElements);
|
svgCanvas.call('changed', selectedElements());
|
||||||
}
|
}
|
||||||
// const pointGripContainer = getElem('pathpointgrip_container');
|
// const pointGripContainer = getElem('pathpointgrip_container');
|
||||||
// if (elem.nodeName === 'path' && pointGripContainer) {
|
// if (elem.nodeName === 'path' && pointGripContainer) {
|
||||||
// pathActions.setPointContainerTransform(elem.getAttribute('transform'));
|
// pathActions.setPointContainerTransform(elem.getAttribute('transform'));
|
||||||
// }
|
// }
|
||||||
const selector = selectionContext_.getCanvas().selectorManager.requestSelector(selectedElements[0]);
|
const selector = svgCanvas.selectorManager.requestSelector(selectedElements()[0]);
|
||||||
selector.resize();
|
selector.resize();
|
||||||
selectionContext_.getSelector().updateGripCursors(val);
|
selectionContext_.getSelector().updateGripCursors(val);
|
||||||
};
|
};
|
||||||
|
@ -404,15 +405,14 @@ export const setRotationAngle = function (val, preventUndo) {
|
||||||
* @returns {void}
|
* @returns {void}
|
||||||
*/
|
*/
|
||||||
export const recalculateAllSelectedDimensions = function () {
|
export const recalculateAllSelectedDimensions = function () {
|
||||||
const selectedElements = selectionContext_.getSelectedElements();
|
|
||||||
const text = (selectionContext_.getCurrentResizeMode() === 'none' ? 'position' : 'size');
|
const text = (selectionContext_.getCurrentResizeMode() === 'none' ? 'position' : 'size');
|
||||||
const batchCmd = new BatchCommand(text);
|
const batchCmd = new BatchCommand(text);
|
||||||
|
|
||||||
let i = selectedElements.length;
|
let i = selectedElements().length;
|
||||||
while (i--) {
|
while (i--) {
|
||||||
const elem = selectedElements[i];
|
const elem = selectedElements()[i];
|
||||||
// if (getRotationAngle(elem) && !hasMatrixTransform(getTransformList(elem))) { continue; }
|
// if (getRotationAngle(elem) && !hasMatrixTransform(getTransformList(elem))) { continue; }
|
||||||
const cmd = selectionContext_.getCanvas().recalculateDimensions(elem);
|
const cmd = svgCanvas.recalculateDimensions(elem);
|
||||||
if (cmd) {
|
if (cmd) {
|
||||||
batchCmd.addSubCommand(cmd);
|
batchCmd.addSubCommand(cmd);
|
||||||
}
|
}
|
||||||
|
@ -420,6 +420,6 @@ export const recalculateAllSelectedDimensions = function () {
|
||||||
|
|
||||||
if (!batchCmd.isEmpty()) {
|
if (!batchCmd.isEmpty()) {
|
||||||
selectionContext_.addCommandToHistory(batchCmd);
|
selectionContext_.addCommandToHistory(batchCmd);
|
||||||
selectionContext_.getCanvas().call('changed', selectedElements);
|
svgCanvas.call('changed', selectedElements());
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -36,6 +36,7 @@ const {
|
||||||
|
|
||||||
let svgContext_ = null;
|
let svgContext_ = null;
|
||||||
let $id = null;
|
let $id = null;
|
||||||
|
let svgCanvas = null;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @function module:svg-exec.init
|
* @function module:svg-exec.init
|
||||||
|
@ -44,7 +45,7 @@ let $id = null;
|
||||||
*/
|
*/
|
||||||
export const init = function (svgContext) {
|
export const init = function (svgContext) {
|
||||||
svgContext_ = svgContext;
|
svgContext_ = svgContext;
|
||||||
const svgCanvas = svgContext_.getCanvas();
|
svgCanvas = svgContext_.getCanvas();
|
||||||
$id = svgCanvas.$id;
|
$id = svgCanvas.$id;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -55,9 +56,9 @@ export const init = function (svgContext) {
|
||||||
*/
|
*/
|
||||||
export const svgCanvasToString = function () {
|
export const svgCanvasToString = function () {
|
||||||
// keep calling it until there are none to remove
|
// keep calling it until there are none to remove
|
||||||
while (svgContext_.getCanvas().removeUnusedDefElems() > 0) { } // eslint-disable-line no-empty
|
while (svgCanvas.removeUnusedDefElems() > 0) { } // eslint-disable-line no-empty
|
||||||
|
|
||||||
svgContext_.getCanvas().pathActions.clear(true);
|
svgCanvas.pathActions.clear(true);
|
||||||
|
|
||||||
// Keep SVG-Edit comment on top
|
// Keep SVG-Edit comment on top
|
||||||
const childNodesElems = svgContext_.getSVGContent().childNodes;
|
const childNodesElems = svgContext_.getSVGContent().childNodes;
|
||||||
|
@ -70,7 +71,7 @@ export const svgCanvasToString = function () {
|
||||||
// Move out of in-group editing mode
|
// Move out of in-group editing mode
|
||||||
if (svgContext_.getCurrentGroup()) {
|
if (svgContext_.getCurrentGroup()) {
|
||||||
draw.leaveContext();
|
draw.leaveContext();
|
||||||
svgContext_.getCanvas().selectOnly([ svgContext_.getCurrentGroup() ]);
|
svgCanvas.selectOnly([ svgContext_.getCurrentGroup() ]);
|
||||||
}
|
}
|
||||||
|
|
||||||
const nakedSvgs = [];
|
const nakedSvgs = [];
|
||||||
|
@ -92,12 +93,12 @@ export const svgCanvasToString = function () {
|
||||||
element.replaceWith(svg);
|
element.replaceWith(svg);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
const output = this.svgToString(svgContext_.getSVGContent(), 0);
|
const output = svgCanvas.svgToString(svgContext_.getSVGContent(), 0);
|
||||||
|
|
||||||
// Rewrap gsvg
|
// Rewrap gsvg
|
||||||
if (nakedSvgs.length) {
|
if (nakedSvgs.length) {
|
||||||
Array.prototype.forEach.call(nakedSvgs, function (el) {
|
Array.prototype.forEach.call(nakedSvgs, function (el) {
|
||||||
svgContext_.getCanvas().groupSvgElem(el);
|
svgCanvas.groupSvgElem(el);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -130,7 +131,7 @@ export const svgToString = function (elem, indent) {
|
||||||
out.push('<'); out.push(elem.nodeName);
|
out.push('<'); out.push(elem.nodeName);
|
||||||
if (elem.id === 'svgcontent') {
|
if (elem.id === 'svgcontent') {
|
||||||
// Process root element separately
|
// Process root element separately
|
||||||
const res = svgContext_.getCanvas().getResolution();
|
const res = svgCanvas.getResolution();
|
||||||
|
|
||||||
const vb = '';
|
const vb = '';
|
||||||
// TODO: Allow this by dividing all values by current baseVal
|
// TODO: Allow this by dividing all values by current baseVal
|
||||||
|
@ -211,7 +212,7 @@ export const svgToString = function (elem, indent) {
|
||||||
if (attrVal.startsWith('pointer-events')) { continue; }
|
if (attrVal.startsWith('pointer-events')) { continue; }
|
||||||
if (attr.localName === 'class' && attrVal.startsWith('se_')) { continue; }
|
if (attr.localName === 'class' && attrVal.startsWith('se_')) { continue; }
|
||||||
out.push(' ');
|
out.push(' ');
|
||||||
if (attr.localName === 'd') { attrVal = svgContext_.getCanvas().pathActions.convertPath(elem, true); }
|
if (attr.localName === 'd') { attrVal = svgCanvas.pathActions.convertPath(elem, true); }
|
||||||
if (!isNaN(attrVal)) {
|
if (!isNaN(attrVal)) {
|
||||||
attrVal = shortFloat(attrVal);
|
attrVal = shortFloat(attrVal);
|
||||||
} else if (unitRe.test(attrVal)) {
|
} else if (unitRe.test(attrVal)) {
|
||||||
|
@ -249,7 +250,7 @@ export const svgToString = function (elem, indent) {
|
||||||
switch (child.nodeType) {
|
switch (child.nodeType) {
|
||||||
case 1: // element node
|
case 1: // element node
|
||||||
out.push('\n');
|
out.push('\n');
|
||||||
out.push(this.svgToString(child, indent));
|
out.push(svgCanvas.svgToString(child, indent));
|
||||||
break;
|
break;
|
||||||
case 3: { // text node
|
case 3: { // text node
|
||||||
const str = child.nodeValue.replace(/^\s+|\s+$/g, '');
|
const str = child.nodeValue.replace(/^\s+|\s+$/g, '');
|
||||||
|
@ -311,7 +312,7 @@ export const setSvgString = function (xmlString, preventUndo) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.prepareSvg(newDoc);
|
svgCanvas.prepareSvg(newDoc);
|
||||||
|
|
||||||
const batchCmd = new BatchCommand('Change Source');
|
const batchCmd = new BatchCommand('Change Source');
|
||||||
|
|
||||||
|
@ -333,10 +334,10 @@ export const setSvgString = function (xmlString, preventUndo) {
|
||||||
svgContext_.getSVGRoot().append(svgContext_.getSVGContent());
|
svgContext_.getSVGRoot().append(svgContext_.getSVGContent());
|
||||||
const content = svgContext_.getSVGContent();
|
const content = svgContext_.getSVGContent();
|
||||||
|
|
||||||
svgContext_.getCanvas().current_drawing_ = new draw.Drawing(svgContext_.getSVGContent(), svgContext_.getIdPrefix());
|
svgCanvas.current_drawing_ = new draw.Drawing(svgContext_.getSVGContent(), svgContext_.getIdPrefix());
|
||||||
|
|
||||||
// retrieve or set the nonce
|
// retrieve or set the nonce
|
||||||
const nonce = svgContext_.getCanvas().getCurrentDrawing().getNonce();
|
const nonce = svgCanvas.getCurrentDrawing().getNonce();
|
||||||
if (nonce) {
|
if (nonce) {
|
||||||
svgContext_.call('setnonce', nonce);
|
svgContext_.call('setnonce', nonce);
|
||||||
} else {
|
} else {
|
||||||
|
@ -347,7 +348,7 @@ export const setSvgString = function (xmlString, preventUndo) {
|
||||||
const elements = content.querySelectorAll('image');
|
const elements = content.querySelectorAll('image');
|
||||||
Array.prototype.forEach.call(elements, function (image) {
|
Array.prototype.forEach.call(elements, function (image) {
|
||||||
preventClickDefault(image);
|
preventClickDefault(image);
|
||||||
const val = svgContext_.getCanvas().getHref(image);
|
const val = svgCanvas.getHref(image);
|
||||||
if (val) {
|
if (val) {
|
||||||
if (val.startsWith('data:')) {
|
if (val.startsWith('data:')) {
|
||||||
// Check if an SVG-edit data URI
|
// Check if an SVG-edit data URI
|
||||||
|
@ -364,7 +365,7 @@ export const setSvgString = function (xmlString, preventUndo) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Add to encodableImages if it loads
|
// Add to encodableImages if it loads
|
||||||
svgContext_.getCanvas().embedImage(val);
|
svgCanvas.embedImage(val);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -374,15 +375,15 @@ export const setSvgString = function (xmlString, preventUndo) {
|
||||||
// Skip if it's in a <defs>
|
// Skip if it's in a <defs>
|
||||||
if (getClosest(element.parentNode, 'defs')) { return; }
|
if (getClosest(element.parentNode, 'defs')) { return; }
|
||||||
|
|
||||||
svgContext_.getCanvas().uniquifyElems(element);
|
svgCanvas.uniquifyElems(element);
|
||||||
|
|
||||||
// Check if it already has a gsvg group
|
// Check if it already has a gsvg group
|
||||||
const pa = element.parentNode;
|
const pa = element.parentNode;
|
||||||
if (pa.childNodes.length === 1 && pa.nodeName === 'g') {
|
if (pa.childNodes.length === 1 && pa.nodeName === 'g') {
|
||||||
dataStorage.put(pa, 'gsvg', element);
|
dataStorage.put(pa, 'gsvg', element);
|
||||||
pa.id = pa.id || svgContext_.getCanvas().getNextId();
|
pa.id = pa.id || svgCanvas.getNextId();
|
||||||
} else {
|
} else {
|
||||||
svgContext_.getCanvas().groupSvgElem(element);
|
svgCanvas.groupSvgElem(element);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -398,9 +399,9 @@ export const setSvgString = function (xmlString, preventUndo) {
|
||||||
// Set ref element for <use> elements
|
// Set ref element for <use> elements
|
||||||
|
|
||||||
// TODO: This should also be done if the object is re-added through "redo"
|
// TODO: This should also be done if the object is re-added through "redo"
|
||||||
svgContext_.getCanvas().setUseData(content);
|
svgCanvas.setUseData(content);
|
||||||
|
|
||||||
svgContext_.getCanvas().convertGradients(content);
|
svgCanvas.convertGradients(content);
|
||||||
|
|
||||||
const attrs = {
|
const attrs = {
|
||||||
id: 'svgcontent',
|
id: 'svgcontent',
|
||||||
|
@ -437,7 +438,7 @@ export const setSvgString = function (xmlString, preventUndo) {
|
||||||
Array.prototype.forEach.call(chiElems, function (chiElem) {
|
Array.prototype.forEach.call(chiElems, function (chiElem) {
|
||||||
const visElems = chiElem.querySelectorAll(svgContext_.getVisElems());
|
const visElems = chiElem.querySelectorAll(svgContext_.getVisElems());
|
||||||
Array.prototype.forEach.call(visElems, function (elem) {
|
Array.prototype.forEach.call(visElems, function (elem) {
|
||||||
if (!elem.id) { elem.id = svgContext_.getCanvas().getNextId(); }
|
if (!elem.id) { elem.id = svgCanvas.getNextId(); }
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -456,8 +457,8 @@ export const setSvgString = function (xmlString, preventUndo) {
|
||||||
for (const [ key, value ] of Object.entries(attrs)) {
|
for (const [ key, value ] of Object.entries(attrs)) {
|
||||||
content.setAttribute(key, value);
|
content.setAttribute(key, value);
|
||||||
}
|
}
|
||||||
this.contentW = attrs.width;
|
svgCanvas.contentW = attrs.width;
|
||||||
this.contentH = attrs.height;
|
svgCanvas.contentH = attrs.height;
|
||||||
|
|
||||||
batchCmd.addSubCommand(new InsertElementCommand(svgContext_.getSVGContent()));
|
batchCmd.addSubCommand(new InsertElementCommand(svgContext_.getSVGContent()));
|
||||||
// update root to the correct size
|
// update root to the correct size
|
||||||
|
@ -471,9 +472,9 @@ export const setSvgString = function (xmlString, preventUndo) {
|
||||||
|
|
||||||
// reset transform lists
|
// reset transform lists
|
||||||
resetListMap();
|
resetListMap();
|
||||||
svgContext_.getCanvas().clearSelection();
|
svgCanvas.clearSelection();
|
||||||
pathModule.clearData();
|
pathModule.clearData();
|
||||||
svgContext_.getSVGRoot().append(svgContext_.getCanvas().selectorManager.selectorParentGroup);
|
svgContext_.getSVGRoot().append(svgCanvas.selectorManager.selectorParentGroup);
|
||||||
|
|
||||||
if (!preventUndo) svgContext_.addCommandToHistory(batchCmd);
|
if (!preventUndo) svgContext_.addCommandToHistory(batchCmd);
|
||||||
svgContext_.call('changed', [ svgContext_.getSVGContent() ]);
|
svgContext_.call('changed', [ svgContext_.getSVGContent() ]);
|
||||||
|
@ -524,7 +525,7 @@ export const importSvgString = function (xmlString) {
|
||||||
// convert string into XML document
|
// convert string into XML document
|
||||||
const newDoc = text2xml(xmlString);
|
const newDoc = text2xml(xmlString);
|
||||||
|
|
||||||
this.prepareSvg(newDoc);
|
svgCanvas.prepareSvg(newDoc);
|
||||||
|
|
||||||
// import new svg document into our document
|
// import new svg document into our document
|
||||||
// If DOM3 adoptNode() available, use it. Otherwise fall back to DOM2 importNode()
|
// If DOM3 adoptNode() available, use it. Otherwise fall back to DOM2 importNode()
|
||||||
|
@ -532,7 +533,7 @@ export const importSvgString = function (xmlString) {
|
||||||
? svgContext_.getDOMDocument().adoptNode(newDoc.documentElement)
|
? svgContext_.getDOMDocument().adoptNode(newDoc.documentElement)
|
||||||
: svgContext_.getDOMDocument().importNode(newDoc.documentElement, true);
|
: svgContext_.getDOMDocument().importNode(newDoc.documentElement, true);
|
||||||
|
|
||||||
svgContext_.getCanvas().uniquifyElems(svg);
|
svgCanvas.uniquifyElems(svg);
|
||||||
|
|
||||||
const innerw = convertToNum('width', svg.getAttribute('width'));
|
const innerw = convertToNum('width', svg.getAttribute('width'));
|
||||||
const innerh = convertToNum('height', svg.getAttribute('height'));
|
const innerh = convertToNum('height', svg.getAttribute('height'));
|
||||||
|
@ -574,7 +575,7 @@ export const importSvgString = function (xmlString) {
|
||||||
for (const attr of attrs) { // Ok for `NamedNodeMap`
|
for (const attr of attrs) { // Ok for `NamedNodeMap`
|
||||||
symbol.setAttribute(attr.nodeName, attr.value);
|
symbol.setAttribute(attr.nodeName, attr.value);
|
||||||
}
|
}
|
||||||
symbol.id = svgContext_.getCanvas().getNextId();
|
symbol.id = svgCanvas.getNextId();
|
||||||
|
|
||||||
// Store data
|
// Store data
|
||||||
svgContext_.setImportIds(uid, {
|
svgContext_.setImportIds(uid, {
|
||||||
|
@ -587,18 +588,18 @@ export const importSvgString = function (xmlString) {
|
||||||
}
|
}
|
||||||
|
|
||||||
useEl = svgContext_.getDOMDocument().createElementNS(NS.SVG, 'use');
|
useEl = svgContext_.getDOMDocument().createElementNS(NS.SVG, 'use');
|
||||||
useEl.id = svgContext_.getCanvas().getNextId();
|
useEl.id = svgCanvas.getNextId();
|
||||||
svgContext_.getCanvas().setHref(useEl, '#' + symbol.id);
|
svgCanvas.setHref(useEl, '#' + symbol.id);
|
||||||
|
|
||||||
(svgContext_.getCurrentGroup() || svgContext_.getCanvas().getCurrentDrawing().getCurrentLayer()).append(useEl);
|
(svgContext_.getCurrentGroup() || svgCanvas.getCurrentDrawing().getCurrentLayer()).append(useEl);
|
||||||
batchCmd.addSubCommand(new InsertElementCommand(useEl));
|
batchCmd.addSubCommand(new InsertElementCommand(useEl));
|
||||||
svgContext_.getCanvas().clearSelection();
|
svgCanvas.clearSelection();
|
||||||
|
|
||||||
useEl.setAttribute('transform', ts);
|
useEl.setAttribute('transform', ts);
|
||||||
recalculateDimensions(useEl);
|
recalculateDimensions(useEl);
|
||||||
dataStorage.put(useEl, 'symbol', symbol);
|
dataStorage.put(useEl, 'symbol', symbol);
|
||||||
dataStorage.put(useEl, 'ref', symbol);
|
dataStorage.put(useEl, 'ref', symbol);
|
||||||
svgContext_.getCanvas().addToSelection([ useEl ]);
|
svgCanvas.addToSelection([ useEl ]);
|
||||||
|
|
||||||
// TODO: Find way to add this in a recalculateDimensions-parsable way
|
// TODO: Find way to add this in a recalculateDimensions-parsable way
|
||||||
// if (vb[0] !== 0 || vb[1] !== 0) {
|
// if (vb[0] !== 0 || vb[1] !== 0) {
|
||||||
|
@ -646,7 +647,7 @@ export const embedImage = function (src) {
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
svgContext_.setEncodableImages(src, false);
|
svgContext_.setEncodableImages(src, false);
|
||||||
}
|
}
|
||||||
svgContext_.getCanvas().setGoodImage(src);
|
svgCanvas.setGoodImage(src);
|
||||||
resolve(svgContext_.getEncodableImages(src));
|
resolve(svgContext_.getEncodableImages(src));
|
||||||
});
|
});
|
||||||
imgI.addEventListener("error", (e) => {
|
imgI.addEventListener("error", (e) => {
|
||||||
|
@ -667,10 +668,10 @@ export const embedImage = function (src) {
|
||||||
*/
|
*/
|
||||||
export const save = function (opts) {
|
export const save = function (opts) {
|
||||||
// remove the selected outline before serializing
|
// remove the selected outline before serializing
|
||||||
svgContext_.getCanvas().clearSelection();
|
svgCanvas.clearSelection();
|
||||||
// Update save options if provided
|
// Update save options if provided
|
||||||
if (opts) {
|
if (opts) {
|
||||||
const saveOptions = svgContext_.getCanvas().mergeDeep(svgContext_.getSvgOption(), opts);
|
const saveOptions = svgCanvas.mergeDeep(svgContext_.getSvgOption(), opts);
|
||||||
for (const [ key, value ] of Object.entries(saveOptions)) {
|
for (const [ key, value ] of Object.entries(saveOptions)) {
|
||||||
svgContext_.setSvgOption(key, value);
|
svgContext_.setSvgOption(key, value);
|
||||||
}
|
}
|
||||||
|
@ -678,7 +679,7 @@ export const save = function (opts) {
|
||||||
svgContext_.setSvgOption('apply', true);
|
svgContext_.setSvgOption('apply', true);
|
||||||
|
|
||||||
// no need for doctype, see https://jwatt.org/svg/authoring/#doctype-declaration
|
// no need for doctype, see https://jwatt.org/svg/authoring/#doctype-declaration
|
||||||
const str = svgContext_.getCanvas().svgCanvasToString();
|
const str = svgCanvas.svgCanvasToString();
|
||||||
svgContext_.call('saved', str);
|
svgContext_.call('saved', str);
|
||||||
};
|
};
|
||||||
/**
|
/**
|
||||||
|
@ -694,7 +695,7 @@ export const save = function (opts) {
|
||||||
function getIssues() {
|
function getIssues() {
|
||||||
const uiStrings = svgContext_.getUIStrings();
|
const uiStrings = svgContext_.getUIStrings();
|
||||||
// remove the selected outline before serializing
|
// remove the selected outline before serializing
|
||||||
svgContext_.getCanvas().clearSelection();
|
svgCanvas.clearSelection();
|
||||||
|
|
||||||
// Check for known CanVG issues
|
// Check for known CanVG issues
|
||||||
const issues = [];
|
const issues = [];
|
||||||
|
@ -752,7 +753,7 @@ export const rasterExport = async function (imgType, quality, exportWindowName,
|
||||||
const type = imgType === 'ICO' ? 'BMP' : (imgType || 'PNG');
|
const type = imgType === 'ICO' ? 'BMP' : (imgType || 'PNG');
|
||||||
const mimeType = 'image/' + type.toLowerCase();
|
const mimeType = 'image/' + type.toLowerCase();
|
||||||
const { issues, issueCodes } = getIssues();
|
const { issues, issueCodes } = getIssues();
|
||||||
const svg = this.svgCanvasToString();
|
const svg = svgCanvas.svgCanvasToString();
|
||||||
|
|
||||||
if (!$id('export_canvas')) {
|
if (!$id('export_canvas')) {
|
||||||
const canvasEx = document.createElement('CANVAS');
|
const canvasEx = document.createElement('CANVAS');
|
||||||
|
@ -761,8 +762,8 @@ export const rasterExport = async function (imgType, quality, exportWindowName,
|
||||||
document.body.appendChild(canvasEx);
|
document.body.appendChild(canvasEx);
|
||||||
}
|
}
|
||||||
const c = $id('export_canvas');
|
const c = $id('export_canvas');
|
||||||
c.style.width = svgContext_.getCanvas().contentW + "px";
|
c.style.width = svgCanvas.contentW + "px";
|
||||||
c.style.height = svgContext_.getCanvas().contentH + "px";
|
c.style.height = svgCanvas.contentH + "px";
|
||||||
const canvg = svgContext_.getcanvg();
|
const canvg = svgContext_.getcanvg();
|
||||||
const ctx = c.getContext('2d');
|
const ctx = c.getContext('2d');
|
||||||
const v = canvg.fromString(ctx, svg);
|
const v = canvg.fromString(ctx, svg);
|
||||||
|
@ -837,7 +838,7 @@ export const exportPDF = async (
|
||||||
exportWindowName,
|
exportWindowName,
|
||||||
outputType = isChrome() ? 'save' : undefined
|
outputType = isChrome() ? 'save' : undefined
|
||||||
) => {
|
) => {
|
||||||
const res = svgContext_.getCanvas().getResolution();
|
const res = svgCanvas.getResolution();
|
||||||
const orientation = res.w > res.h ? 'landscape' : 'portrait';
|
const orientation = res.w > res.h ? 'landscape' : 'portrait';
|
||||||
const unit = 'pt'; // curConfig.baseUnit; // We could use baseUnit, but that is presumably not intended for export purposes
|
const unit = 'pt'; // curConfig.baseUnit; // We could use baseUnit, but that is presumably not intended for export purposes
|
||||||
|
|
||||||
|
@ -848,7 +849,7 @@ export const exportPDF = async (
|
||||||
format: [ res.w, res.h ]
|
format: [ res.w, res.h ]
|
||||||
// , compressPdf: true
|
// , compressPdf: true
|
||||||
});
|
});
|
||||||
const docTitle = svgContext_.getCanvas().getDocumentTitle();
|
const docTitle = svgCanvas.getDocumentTitle();
|
||||||
doc.setProperties({
|
doc.setProperties({
|
||||||
title: docTitle /* ,
|
title: docTitle /* ,
|
||||||
subject: '',
|
subject: '',
|
||||||
|
@ -908,7 +909,7 @@ export const uniquifyElemsMethod = function (g) {
|
||||||
const attrnode = n.getAttributeNode(attr);
|
const attrnode = n.getAttributeNode(attr);
|
||||||
if (attrnode) {
|
if (attrnode) {
|
||||||
// the incoming file has been sanitized, so we should be able to safely just strip off the leading #
|
// the incoming file has been sanitized, so we should be able to safely just strip off the leading #
|
||||||
const url = svgContext_.getCanvas().getUrlFromAttr(attrnode.value);
|
const url = svgCanvas.getUrlFromAttr(attrnode.value);
|
||||||
const refid = url ? url.substr(1) : null;
|
const refid = url ? url.substr(1) : null;
|
||||||
if (refid) {
|
if (refid) {
|
||||||
if (!(refid in ids)) {
|
if (!(refid in ids)) {
|
||||||
|
@ -921,7 +922,7 @@ export const uniquifyElemsMethod = function (g) {
|
||||||
});
|
});
|
||||||
|
|
||||||
// check xlink:href now
|
// check xlink:href now
|
||||||
const href = svgContext_.getCanvas().getHref(n);
|
const href = svgCanvas.getHref(n);
|
||||||
// TODO: what if an <image> or <a> element refers to an element internally?
|
// TODO: what if an <image> or <a> element refers to an element internally?
|
||||||
if (href && refElems.includes(n.nodeName)) {
|
if (href && refElems.includes(n.nodeName)) {
|
||||||
const refid = href.substr(1);
|
const refid = href.substr(1);
|
||||||
|
@ -941,7 +942,7 @@ export const uniquifyElemsMethod = function (g) {
|
||||||
if (!oldid) { continue; }
|
if (!oldid) { continue; }
|
||||||
const { elem } = ids[oldid];
|
const { elem } = ids[oldid];
|
||||||
if (elem) {
|
if (elem) {
|
||||||
const newid = svgContext_.getCanvas().getNextId();
|
const newid = svgCanvas.getNextId();
|
||||||
|
|
||||||
// assign element its new id
|
// assign element its new id
|
||||||
elem.id = newid;
|
elem.id = newid;
|
||||||
|
@ -959,7 +960,7 @@ export const uniquifyElemsMethod = function (g) {
|
||||||
let k = hreffers.length;
|
let k = hreffers.length;
|
||||||
while (k--) {
|
while (k--) {
|
||||||
const hreffer = hreffers[k];
|
const hreffer = hreffers[k];
|
||||||
svgContext_.getCanvas().setHref(hreffer, '#' + newid);
|
svgCanvas.setHref(hreffer, '#' + newid);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -981,8 +982,8 @@ export const setUseDataMethod = function (parent) {
|
||||||
|
|
||||||
Array.prototype.forEach.call(elems, function (el, _) {
|
Array.prototype.forEach.call(elems, function (el, _) {
|
||||||
const dataStorage = svgContext_.getDataStorage();
|
const dataStorage = svgContext_.getDataStorage();
|
||||||
const id = svgContext_.getCanvas().getHref(el).substr(1);
|
const id = svgCanvas.getHref(el).substr(1);
|
||||||
const refElem = svgContext_.getCanvas().getElem(id);
|
const refElem = svgCanvas.getElem(id);
|
||||||
if (!refElem) { return; }
|
if (!refElem) { return; }
|
||||||
dataStorage.put(el, 'ref', refElem);
|
dataStorage.put(el, 'ref', refElem);
|
||||||
if (refElem.tagName === 'symbol' || refElem.tagName === 'svg') {
|
if (refElem.tagName === 'symbol' || refElem.tagName === 'svg') {
|
||||||
|
@ -1016,7 +1017,7 @@ export const removeUnusedDefElemsMethod = function () {
|
||||||
for (i = 0; i < allLen; i++) {
|
for (i = 0; i < allLen; i++) {
|
||||||
const el = allEls[i];
|
const el = allEls[i];
|
||||||
for (j = 0; j < alen; j++) {
|
for (j = 0; j < alen; j++) {
|
||||||
const ref = svgContext_.getCanvas().getUrlFromAttr(el.getAttribute(attrs[j]));
|
const ref = svgCanvas.getUrlFromAttr(el.getAttribute(attrs[j]));
|
||||||
if (ref) {
|
if (ref) {
|
||||||
defelemUses.push(ref.substr(1));
|
defelemUses.push(ref.substr(1));
|
||||||
}
|
}
|
||||||
|
@ -1080,7 +1081,7 @@ export const convertGradientsMethod = function (elem) {
|
||||||
x1: grad.getAttribute('x1'),
|
x1: grad.getAttribute('x1'),
|
||||||
y1: grad.getAttribute('y1'),
|
y1: grad.getAttribute('y1'),
|
||||||
x2: grad.getAttribute('x2'),
|
x2: grad.getAttribute('x2'),
|
||||||
y2: grad.getAttribute('y2'),
|
y2: grad.getAttribute('y2')
|
||||||
};
|
};
|
||||||
|
|
||||||
// If has transform, convert
|
// If has transform, convert
|
||||||
|
|
|
@ -209,7 +209,7 @@ class SvgCanvas {
|
||||||
return this._storage.has(element) && this._storage.get(element).has(key);
|
return this._storage.has(element) && this._storage.get(element).has(key);
|
||||||
},
|
},
|
||||||
remove: function (element, key) {
|
remove: function (element, key) {
|
||||||
let ret = this._storage.get(element).delete(key);
|
const ret = this._storage.get(element).delete(key);
|
||||||
if (!this._storage.get(element).size === 0) {
|
if (!this._storage.get(element).size === 0) {
|
||||||
this._storage.delete(element);
|
this._storage.delete(element);
|
||||||
}
|
}
|
||||||
|
@ -555,7 +555,7 @@ class SvgCanvas {
|
||||||
|
|
||||||
const restoreRefElems = function (elem) {
|
const restoreRefElems = function (elem) {
|
||||||
// Look for missing reference elements, restore any found
|
// Look for missing reference elements, restore any found
|
||||||
let attrs = {};
|
const attrs = {};
|
||||||
refAttrs.forEach(function (item, _) {
|
refAttrs.forEach(function (item, _) {
|
||||||
attrs[item] = elem.getAttribute(item);
|
attrs[item] = elem.getAttribute(item);
|
||||||
});
|
});
|
||||||
|
|
|
@ -576,7 +576,7 @@ function groupBBFix(selected) {
|
||||||
let ret; let copy;
|
let ret; let copy;
|
||||||
|
|
||||||
if (ref) {
|
if (ref) {
|
||||||
let elements = [];
|
const elements = [];
|
||||||
Array.prototype.forEach.call(ref.children, function (el) {
|
Array.prototype.forEach.call(ref.children, function (el) {
|
||||||
const elem = el.cloneNode(true);
|
const elem = el.cloneNode(true);
|
||||||
elem.setAttribute('visibility', 'hidden');
|
elem.setAttribute('visibility', 'hidden');
|
||||||
|
|
Loading…
Reference in New Issue