1
0
Fork 0

chore: Linter run

This commit is contained in:
Joost De Cock 2021-08-30 11:40:16 +02:00
parent e693c7712e
commit ef3bd03e2c
183 changed files with 919 additions and 1838 deletions

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
options,
Point,
points,
Path,
paths,
complete,
macro,
sa,
store,
paperless,
} = part.shorthand()
let { options, Point, points, Path, paths, complete, macro, sa, store, paperless } =
part.shorthand()
if (!options.adjustmentRibbon) {
part.render = false

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
options,
Point,
points,
Path,
paths,
complete,
macro,
sa,
store,
paperless,
} = part.shorthand()
let { options, Point, points, Path, paths, complete, macro, sa, store, paperless } =
part.shorthand()
if (!options.adjustmentRibbon) {
part.render = false

View file

@ -1,17 +1,6 @@
export default function (part) {
let {
Point,
Path,
measurements,
store,
options,
complete,
macro,
points,
paths,
sa,
paperless,
} = part.shorthand()
let { Point, Path, measurements, store, options, complete, macro, points, paths, sa, paperless } =
part.shorthand()
if (options.adjustmentRibbon) {
part.render = false

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -14,7 +14,7 @@ export default (part) => {
macro,
options,
Point,
utils
utils,
} = part.shorthand()
points.anchor = points.hps.clone()
@ -27,8 +27,7 @@ export default (part) => {
.move(points.hps)
.curve_(points.neckCp2, points.cbNeck)
.setRender(false)
}
else if (options.s3Collar > 0) {
} else if (options.s3Collar > 0) {
// Shift shoulder seam forward on the collar side
points.s3CollarSplit = utils.curveIntersectsY(
points.hps,
@ -42,16 +41,15 @@ export default (part) => {
._curve(points.mirroredNeckCp2Front, points.mirroredCfNeckCp1, points.mirroredCfNeck)
.split(points.s3CollarSplit)[0]
.reverse()
.join(new Path()
.move(points.hps)
.curve_(points.neckCp2, points.cbNeck)
)
.join(new Path().move(points.hps).curve_(points.neckCp2, points.cbNeck))
.setRender(false)
}
else if (options.s3Collar < 0) {
} else if (options.s3Collar < 0) {
// Shift shoulder seam backward on the collar side
points.s3CollarSplit = utils.curveIntersectsY(
points.hps, points.neckCp2, points.cbNeck, points.cbNeck,
points.hps,
points.neckCp2,
points.cbNeck,
points.cbNeck,
store.get('s3CollarMaxBack') * -1 * options.s3Collar
)
paths.backCollar = new Path()
@ -67,8 +65,7 @@ export default (part) => {
.move(points.armholePitch)
.curve(points.armholePitchCp2, points.shoulderCp1, points.shoulder)
.setRender(false)
}
else if (options.s3Armhole > 0) {
} else if (options.s3Armhole > 0) {
// Shift shoulder seam forward on the armhole side
points.s3ArmholeSplit = utils.curveIntersectsY(
points.shoulder,
@ -80,14 +77,18 @@ export default (part) => {
paths.backArmhole = new Path()
.move(points.armholePitch)
.curve(points.armholePitchCp2, points.shoulderCp1, points.shoulder)
.join(new Path()
.join(
new Path()
.move(points.shoulder)
.curve(points.mirroredShoulderCp1, points.mirroredFrontArmholePitchCp2, points.mirroredFrontArmholePitch)
.curve(
points.mirroredShoulderCp1,
points.mirroredFrontArmholePitchCp2,
points.mirroredFrontArmholePitch
)
.split(points.s3ArmholeSplit)[0]
)
.setRender(false)
}
else if (options.s3Armhole < 0) {
} else if (options.s3Armhole < 0) {
// Shift shoulder seam backward on the armhole side
points.s3ArmholeSplit = utils.curveIntersectsY(
points.shoulder,

View file

@ -13,7 +13,7 @@ export default (part) => {
paths,
utils,
complete,
macro
macro,
} = part.shorthand()
store.set('shoulderEase', (measurements.shoulderToShoulder * options.shoulderEase) / 2)
@ -145,7 +145,7 @@ export default (part) => {
points.frontArmholePitchCp2,
points.shoulderCp1,
],
clone: true
clone: true,
})
// How much space do we have to work with here?

View file

@ -15,7 +15,7 @@ export default (part) => {
complete,
paperless,
macro,
utils
utils,
} = part.shorthand()
// Re-use points for deeper armhole at the front
@ -31,11 +31,13 @@ export default (part) => {
.move(points.hps)
.curve(points.neckCp2Front, points.cfNeckCp1, points.cfNeck)
.setRender(false)
}
else if (options.s3Collar > 0) {
} else if (options.s3Collar > 0) {
// Shift shoulder seam forward on the collar side
points.s3CollarSplit = utils.curveIntersectsY(
points.hps, points.neckCp2Front, points.cfNeckCp1, points.cfNeck,
points.hps,
points.neckCp2Front,
points.cfNeckCp1,
points.cfNeck,
store.get('s3CollarMaxFront') * options.s3Collar
)
paths.frontCollar = new Path()
@ -43,11 +45,13 @@ export default (part) => {
.curve(points.neckCp2Front, points.cfNeckCp1, points.cfNeck)
.split(points.s3CollarSplit)[1]
.setRender(false)
}
else if (options.s3Collar < 0) {
} else if (options.s3Collar < 0) {
// Shift shoulder seam backward on the collar side
points.s3CollarSplit = utils.curveIntersectsY(
points.mirroredCbNeck, points.mirroredCbNeck, points.mirroredNeckCp2, points.hps,
points.mirroredCbNeck,
points.mirroredCbNeck,
points.mirroredNeckCp2,
points.hps,
store.get('s3CollarMaxBack') * options.s3Collar
)
paths.frontCollar = new Path()
@ -55,10 +59,7 @@ export default (part) => {
.curve_(points.mirroredNeckCp2, points.mirroredCbNeck)
.split(points.s3CollarSplit)[0]
.reverse()
.join(new Path()
.move(points.hps)
.curve(points.neckCp2Front, points.cfNeckCp1, points.cfNeck)
)
.join(new Path().move(points.hps).curve(points.neckCp2Front, points.cfNeckCp1, points.cfNeck))
.setRender(false)
}
if (options.s3Armhole === 0) {
@ -67,8 +68,7 @@ export default (part) => {
.move(points.armholePitch)
.curve(points.armholePitchCp2, points.shoulderCp1, points.shoulder)
.setRender(false)
}
else if (options.s3Armhole > 0) {
} else if (options.s3Armhole > 0) {
// Shift shoulder seam forward on the armhole side
points.s3ArmholeSplit = utils.curveIntersectsY(
points.shoulder,
@ -82,8 +82,7 @@ export default (part) => {
.curve(points.armholePitchCp2, points.shoulderCp1, points.shoulder)
.split(points.s3ArmholeSplit)[0]
.setRender(false)
}
else if (options.s3Armhole < 0) {
} else if (options.s3Armhole < 0) {
// Shift shoulder seam forward on the armhole side
points.s3ArmholeSplit = utils.curveIntersectsY(
points.shoulder,
@ -95,9 +94,14 @@ export default (part) => {
paths.frontArmhole = new Path()
.move(points.armholePitch)
.curve(points.armholePitchCp2, points.shoulderCp1, points.shoulder)
.join(new Path()
.join(
new Path()
.move(points.shoulder)
.curve(points.mirroredShoulderCp1, points.mirroredFrontArmholePitchCp2, points.mirroredFrontArmholePitch)
.curve(
points.mirroredShoulderCp1,
points.mirroredFrontArmholePitchCp2,
points.mirroredFrontArmholePitch
)
.split(points.s3ArmholeSplit)[0]
)
.setRender(false)

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -1,19 +1,8 @@
import init from './init'
export default function (part) {
let {
store,
sa,
Point,
points,
Path,
paths,
complete,
paperless,
macro,
Snippet,
snippets,
} = part.shorthand()
let { store, sa, Point, points, Path, paths, complete, paperless, macro, Snippet, snippets } =
part.shorthand()
// Initialize
init(part)

View file

@ -47,7 +47,14 @@ export default {
'innerPocketDepth',
'innerPocketWeltHeight',
],
style: ['beltWidth', 'buttonSpacingHorizontal', 'cuffLength', 'length', 's3Collar', 's3Armhole'],
style: [
'beltWidth',
'buttonSpacingHorizontal',
'cuffLength',
'length',
's3Collar',
's3Armhole',
],
collar: ['collarHeight', 'collarSpread', 'collarFlare'],
},
measurements: [

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -1,17 +1,6 @@
export default function (part) {
let {
paperless,
sa,
snippets,
Snippet,
store,
complete,
points,
macro,
Point,
paths,
Path,
} = part.shorthand()
let { paperless, sa, snippets, Snippet, store, complete, points, macro, Point, paths, Path } =
part.shorthand()
// Give points their original names
for (let i of store.get('side')) points[i] = points[i + 'Rot2'].clone()

View file

@ -46,7 +46,14 @@ export default {
'innerPocketDepth',
'innerPocketWeltHeight',
],
style: ['beltWidth', 'buttonSpacingHorizontal', 'cuffLength', 'length', 's3Collar', 's3Armhole'],
style: [
'beltWidth',
'buttonSpacingHorizontal',
'cuffLength',
'length',
's3Collar',
's3Armhole',
],
collar: ['collarHeight', 'collarSpread', 'collarFlare'],
},
measurements: [

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -1,17 +1,6 @@
export default function (part) {
let {
paperless,
sa,
snippets,
Snippet,
store,
complete,
points,
macro,
Point,
paths,
Path,
} = part.shorthand()
let { paperless, sa, snippets, Snippet, store, complete, points, macro, Point, paths, Path } =
part.shorthand()
let length = 1.6 * (store.get('cbToDart') + store.get('dartToSide'))
let width = store.get('beltWidth')

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
units,
paperless,
sa,
store,
complete,
points,
macro,
Point,
paths,
Path,
} = part.shorthand()
let { units, paperless, sa, store, complete, points, macro, Point, paths, Path } =
part.shorthand()
points.topLeft = new Point(0, 0)
points.bottomRight = new Point(

View file

@ -1,17 +1,6 @@
export default function (part) {
let {
paperless,
sa,
store,
complete,
points,
measurements,
options,
macro,
Point,
paths,
Path,
} = part.shorthand()
let { paperless, sa, store, complete, points, measurements, options, macro, Point, paths, Path } =
part.shorthand()
let height = measurements.chest * options.collarHeight
let length = store.get('frontCollarLength') + store.get('backCollarLength')

View file

@ -1,17 +1,6 @@
export default function (part) {
let {
units,
paperless,
sa,
store,
complete,
points,
options,
macro,
Point,
paths,
Path,
} = part.shorthand()
let { units, paperless, sa, store, complete, points, options, macro, Point, paths, Path } =
part.shorthand()
points.topLeft = new Point(0, 0)
points.bottomRight = new Point(

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
paperless,
sa,
store,
complete,
points,
options,
macro,
Point,
paths,
Path,
} = part.shorthand()
let { paperless, sa, store, complete, points, options, macro, Point, paths, Path } =
part.shorthand()
points.topLeft = new Point(0, 0)
points.bottomRight = new Point(store.get('pocketWidth'), store.get('pocketHeight'))

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
paperless,
sa,
store,
complete,
points,
options,
macro,
Point,
paths,
Path,
} = part.shorthand()
let { paperless, sa, store, complete, points, options, macro, Point, paths, Path } =
part.shorthand()
points.topLeft = new Point(0, 0)
points.bottomRight = new Point(store.get('pocketWidth'), store.get('pocketFlapHeight'))

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
paperless,
sa,
store,
complete,
points,
options,
macro,
Point,
paths,
Path,
} = part.shorthand()
let { paperless, sa, store, complete, points, options, macro, Point, paths, Path } =
part.shorthand()
points.topLeft = points.bottomLeft.shiftFractionTowards(points.topLeft, 0.75)
points.topRight = new Point(points.bottomRight.x, points.topLeft.y)

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
units,
paperless,
sa,
store,
complete,
points,
macro,
Point,
paths,
Path,
} = part.shorthand()
let { units, paperless, sa, store, complete, points, macro, Point, paths, Path } =
part.shorthand()
let length = store.get('waistToHem') - store.get('beltWidth') / 2

View file

@ -1,17 +1,6 @@
export default function (part) {
let {
paperless,
sa,
store,
complete,
points,
measurements,
options,
macro,
Point,
paths,
Path,
} = part.shorthand()
let { paperless, sa, store, complete, points, measurements, options, macro, Point, paths, Path } =
part.shorthand()
// Add cuff
let length = measurements.shoulderToWrist * options.cuffLength

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -111,9 +111,7 @@ export default function (part) {
.curve(points.underbustGap3RightCp, points.waistGap3RightCp1, points.waistGap3Right)
.curve(points.waistGap3RightCp2, points.hipsGap3Cp, points.hipsGap3)
if (options.panels === '11') paths.panel4.line(points.hipRise)
paths.panel4
.close()
.attr('class', 'fabric')
paths.panel4.close().attr('class', 'fabric')
points.underbustGap4Right = topBack.intersectsX(points.underbustGap4Right.x).pop()
points.underbustGap5Left = topBack.intersectsX(points.underbustGap5Left.x).pop()
let top5 = topBack.split(points.underbustGap5Left)[1].split(points.underbustGap4Right)[0]

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -1,18 +1,7 @@
export default (part) => {
// Shorthand
let {
points,
Point,
paths,
Path,
complete,
paperless,
store,
macro,
snippets,
Snippet,
sa,
} = part.shorthand()
let { points, Point, paths, Path, complete, paperless, store, macro, snippets, Snippet, sa } =
part.shorthand()
points.leftNotch = new Point(store.get('backPocketWidth') / -2, 0)
points.rightNotch = points.leftNotch.flipX()

View file

@ -429,7 +429,7 @@ Path.prototype.shiftAlong = function (distance, stepsPerMm = 25) {
let op = this.ops[i]
if (op.type === 'line') {
let thisLen = op.to.dist(current)
if (Math.abs((len + thisLen) - distance) < 0.1) return op.to
if (Math.abs(len + thisLen - distance) < 0.1) return op.to
if (len + thisLen > distance) return current.shiftTowards(op.to, distance - len)
len += thisLen
} else if (op.type === 'curve') {
@ -440,8 +440,9 @@ Path.prototype.shiftAlong = function (distance, stepsPerMm = 25) {
{ x: op.to.x, y: op.to.y }
)
let thisLen = bezier.length()
if (Math.abs((len + thisLen) - distance) < 0.1) return op.to
if (len + thisLen > distance) return shiftAlongBezier(distance - len, bezier, thisLen * stepsPerMm)
if (Math.abs(len + thisLen - distance) < 0.1) return op.to
if (len + thisLen > distance)
return shiftAlongBezier(distance - len, bezier, thisLen * stepsPerMm)
len += thisLen
}
current = op.to

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -173,19 +173,8 @@ function rotateDistanceForP4(part, point, distance, center, origin) {
}
export default function (part) {
let {
options,
Path,
points,
paths,
Snippet,
snippets,
complete,
sa,
store,
paperless,
macro,
} = part.shorthand()
let { options, Path, points, paths, Snippet, snippets, complete, sa, store, paperless, macro } =
part.shorthand()
let tempP = null

View file

@ -1,17 +1,6 @@
export default function (part) {
let {
options,
Path,
points,
paths,
Snippet,
snippets,
complete,
sa,
store,
paperless,
macro,
} = part.shorthand()
let { options, Path, points, paths, Snippet, snippets, complete, sa, store, paperless, macro } =
part.shorthand()
const cc = 0.551915024494 // circle constant

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
Path,
points,
paths,
Snippet,
snippets,
complete,
sa,
store,
paperless,
macro,
} = part.shorthand()
let { Path, points, paths, Snippet, snippets, complete, sa, store, paperless, macro } =
part.shorthand()
let halfInch = store.get('halfInch')

View file

@ -1,17 +1,6 @@
export default function (part) {
let {
Path,
Point,
points,
paths,
Snippet,
snippets,
complete,
sa,
store,
paperless,
macro,
} = part.shorthand()
let { Path, Point, points, paths, Snippet, snippets, complete, sa, store, paperless, macro } =
part.shorthand()
let halfInch = store.get('halfInch')
let waist = store.get('waist')

View file

@ -1,17 +1,6 @@
export default function (part) {
let {
Point,
Path,
points,
paths,
Snippet,
snippets,
complete,
sa,
store,
paperless,
macro,
} = part.shorthand()
let { Point, Path, points, paths, Snippet, snippets, complete, sa, store, paperless, macro } =
part.shorthand()
let halfInch = store.get('halfInch')
let waistLength = store.get('frontWaistLength') + store.get('backWaistLength')

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -19,10 +19,10 @@ export default {
'parametric design',
'{{type}}',
'sewing',
'sewing pattern'
'sewing pattern',
],
optionGroups: {
fit: ['size']
fit: ['size'],
},
measurements: [],
dependencies: {},
@ -30,6 +30,6 @@ export default {
hide: [],
parts: ['box'],
options: {
size: { pct: 50, min: 10, max: 100 }
}
size: { pct: 50, min: 10, max: 100 },
},
}

View file

@ -9,7 +9,8 @@ div.layout-wrapper {
margin: 0;
padding: 0;
background: #f8f9fa;
background: linear-gradient(90deg, #f1f3f5 0%, #f1f3f5 25%, #f8f9fa 26%, #f8f9fa 100%); }
background: linear-gradient(90deg, #f1f3f5 0%, #f1f3f5 25%, #f8f9fa 26%, #f8f9fa 100%);
}
div.layout-wrapper div.layout {
display: flex;
max-width: 1600px;
@ -19,71 +20,93 @@ div.layout-wrapper {
flex-wrap: nowrap;
justify-content: space-between;
background-color: #f8f9fa;
min-height: calc(100vh - 64px); }
min-height: calc(100vh - 64px);
}
div.layout-wrapper div.layout > aside {
width: 33%;
background: #f1f3f5;
border-right: 2px solid #dee2e6; }
border-right: 2px solid #dee2e6;
}
div.layout-wrapper div.layout > section {
margin: 0;
padding: 1rem; }
padding: 1rem;
}
div.layout-wrapper div.layout > section > div.content {
max-width: 66ch;
min-width: 340px; }
min-width: 340px;
}
div.layout-wrapper div.layout > section > div.content.wide {
max-width: 100%;
margin: auto; }
margin: auto;
}
.theme-wrapper.dark header {
background-color: #1a1d21; }
background-color: #1a1d21;
}
.theme-wrapper.dark div.layout-wrapper {
background: #f8f9fa;
background: linear-gradient(90deg, #1a1d21 0%, #1a1d21 25%, #212529 26%, #212529 100%); }
background: linear-gradient(90deg, #1a1d21 0%, #1a1d21 25%, #212529 26%, #212529 100%);
}
.theme-wrapper.dark div.layout-wrapper div.layout {
background-color: #212529; }
background-color: #212529;
}
.theme-wrapper.dark div.layout-wrapper div.layout > aside {
background-color: #1a1d21;
border-right: 2px solid #343a40; }
border-right: 2px solid #343a40;
}
/* monitor */
@media (min-width: 1200px) {
div.layout > section {
width: 63%; } }
width: 63%;
}
}
/* slate */
@media (max-width: 1199px) and (min-width: 960px) {
div.layout > aside {
width: 298px; }
width: 298px;
}
div.layout > section {
width: calc(100% - 300px - 4rem);
max-width: none;
margin: 0 1rem 0 3rem; } }
margin: 0 1rem 0 3rem;
}
}
/* tablet */
@media (max-width: 959px) {
div.layout > aside {
width: 218px; }
width: 218px;
}
div.layout > section {
width: calc(100% - 220px - 4rem);
max-width: none;
margin: 0;
padding: 0 2rem; }
padding: 0 2rem;
}
div.layout > section div.content {
min-width: inherit; } }
min-width: inherit;
}
}
/* mobile */
@media (max-width: 599px) {
div.layout > aside {
display: none; }
display: none;
}
div.layout > section {
width: calc(100%);
margin: 0 auto;
padding: 0 1.5rem;
max-width: none; } }
max-width: none;
}
}
div.gatsby-highlight {
margin-bottom: 1rem; }
margin-bottom: 1rem;
}
@media (max-width: 599px) {
#mobile-menu {
@ -97,117 +120,154 @@ div.gatsby-highlight {
z-index: -10;
transition: opacity 0.25s ease 0s;
opacity: 0;
overflow: scroll; }
overflow: scroll;
}
#mobile-menu > ul,
#mobile-menu > div {
transform: translate(0px, 10px);
transition: transform 0.25s ease 0s; }
transition: transform 0.25s ease 0s;
}
.theme-wrapper.show-menu #mobile-menu {
opacity: 1;
z-index: 10; }
z-index: 10;
}
.theme-wrapper.show-menu #mobile-menu > div {
transform: translate(0px, 0px); } }
transform: translate(0px, 0px);
}
}
.theme-wrapper.light div.draft-ui-menu,
.theme-wrapper.light div.menu {
background: #f1f3f5; }
background: #f1f3f5;
}
.theme-wrapper.dark div.draft-ui-menu,
.theme-wrapper.dark div.menu {
background: #343a40; }
background: #343a40;
}
.theme-wrapper.show-menu div.menu {
opacity: 1;
z-index: 10; }
z-index: 10;
}
.theme-wrapper.show-menu div.menu > div {
transform: translate(0px, 0px); }
transform: translate(0px, 0px);
}
div.spaced-buttons > button {
margin: 0 0.5rem 0.5rem 0; }
margin: 0 0.5rem 0.5rem 0;
}
div.spaced > * {
margin: 0 0.5rem 0.5rem 0; }
margin: 0 0.5rem 0.5rem 0;
}
ul#pre-main-menu {
margin: 0;
padding: 0; }
padding: 0;
}
.boldish {
font-weight: 500; }
font-weight: 500;
}
.freesewing.draft {
padding: 1rem; }
padding: 1rem;
}
li.action {
clear: both; }
clear: both;
}
li.action span.MuiSwitch-root {
float: right; }
float: right;
}
.theme-wrapper.light ul#draft-config li.action.toggle.off,
.theme-wrapper.dark ul#draft-config li.action.toggle.off {
color: #868e96; }
color: #868e96;
}
.theme-wrapper.light ul#draft-config li.action.toggle.off > span svg,
.theme-wrapper.dark ul#draft-config li.action.toggle.off > span svg {
color: #868e96; }
color: #868e96;
}
footer {
background-color: #1a1d21;
color: #adb5bd;
padding: 3rem 0 6rem; }
padding: 3rem 0 6rem;
}
footer a {
color: #dee2e6 !important;
font-weight: 400; }
font-weight: 400;
}
footer a:hover {
color: #d0bfff !important; }
color: #d0bfff !important;
}
footer div.cols {
display: flex;
flex-direction: row;
justify-content: space-between;
max-width: 1600px;
margin: auto;
padding: 0 1.5rem; }
padding: 0 1.5rem;
}
footer div.cols > div {
min-width: 150px;
max-width: calc(20% - 4rem);
padding: 0 2rem 0 0;
width: 100%; }
width: 100%;
}
footer ul {
text-align: left;
font-size: 1.1rem;
margin: 0;
padding: 0;
width: 100%; }
width: 100%;
}
footer ul li:first-of-type {
padding: 0.35rem 0.75rem; }
padding: 0.35rem 0.75rem;
}
footer ul li {
display: block; }
display: block;
}
footer ul li a:hover {
text-decoration: none !important; }
text-decoration: none !important;
}
footer ul li.heading {
font-weight: bold;
border-bottom: 3px solid #adb5bd;
margin-bottom: 0.5rem; }
margin-bottom: 0.5rem;
}
/* XL screens */
@media (min-width: 1200px) {
footer div.cols > div:last-of-type {
min-width: 350px; } }
min-width: 350px;
}
}
/* SM screens */
@media (min-width: 600px) and (max-width: 959px) {
footer div.cols {
flex-wrap: wrap; }
flex-wrap: wrap;
}
footer div.cols > div {
width: calc(30% - 4rem);
padding: 0 1rem; } }
padding: 0 1rem;
}
}
/* XS screens */
@media (max-width: 599px) {
footer div.cols {
display: block; }
display: block;
}
footer div.cols > div {
margin: 2rem auto 0;
max-width: calc(100% - 4rem); }
max-width: calc(100% - 4rem);
}
footer div.cols > div:first-of-type {
margin-top: 0; } }
margin-top: 0;
}
}

View file

@ -1,17 +1,6 @@
export default function (part) {
const {
options,
Point,
Path,
points,
paths,
Snippet,
snippets,
complete,
sa,
paperless,
macro
} = part.shorthand()
const { options, Point, Path, points, paths, Snippet, snippets, complete, sa, paperless, macro } =
part.shorthand()
const w = 500 * options.size
points.topLeft = new Point(0, 0)
@ -47,12 +36,12 @@ export default function (part) {
macro('hd', {
from: points.bottomLeft,
to: points.bottomRight,
y: points.bottomLeft.y + sa + 15
y: points.bottomLeft.y + sa + 15,
})
macro('vd', {
from: points.bottomRight,
to: points.topRight,
x: points.topRight.x + sa + 15
x: points.topRight.x + sa + 15,
})
}

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -1,5 +1,4 @@
export default (part) => {
let { Point, points, Path, paths } = part.shorthand()
points.from = new Point(10, 10)
@ -7,13 +6,10 @@ points.to = new Point(80, 70)
points.text = points.from
.shiftFractionTowards(points.to, 0.6)
.attr("data-text", points.from.dist(points.to)+"mm")
.attr("data-text-class", "text-sm fill-note center")
.attr('data-text', points.from.dist(points.to) + 'mm')
.attr('data-text-class', 'text-sm fill-note center')
paths.line = new Path()
.move(points.from)
.line(points.to)
.attr("class", "dashed")
paths.line = new Path().move(points.from).line(points.to).attr('class', 'dashed')
return part
}

View file

@ -1,32 +1,22 @@
export default (part) => {
let { Point, points, Path, paths } = part.shorthand()
points.from = new Point(10, 10)
points.to = new Point(80, 70)
paths.line = new Path()
.move(points.from)
.line(points.to)
.attr("class", "dashed")
paths.line = new Path().move(points.from).line(points.to).attr('class', 'dashed')
points.totop = points.from.shift(0, points.from.dx(points.to))
points.text_dx = points.from
.shiftFractionTowards(points.totop, 0.6)
.shiftFractionTowards(points.to, 0.1)
.attr("data-text", points.from.dx(points.to)+"mm")
.attr("data-text-class", "text-sm fill-note center")
.attr('data-text', points.from.dx(points.to) + 'mm')
.attr('data-text-class', 'text-sm fill-note center')
paths.line_dx = new Path()
.move(points.from)
.line(points.totop)
.attr("class", "dashed")
paths.line_dx = new Path().move(points.from).line(points.totop).attr('class', 'dashed')
paths.line_dy = new Path()
.move(points.to)
.line(points.totop)
.attr("class", "dashed")
paths.line_dy = new Path().move(points.to).line(points.totop).attr('class', 'dashed')
return part
}

View file

@ -1,31 +1,21 @@
export default (part) => {
let { Point, points, Path, paths } = part.shorthand()
points.from = new Point(10, 10)
points.to = new Point(80, 70)
paths.line = new Path()
.move(points.from)
.line(points.to)
.attr("class", "dashed")
paths.line = new Path().move(points.from).line(points.to).attr('class', 'dashed')
points.totop = points.from.shift(0, points.from.dx(points.to))
paths.line_dx = new Path()
.move(points.from)
.line(points.totop)
.attr("class", "dashed")
paths.line_dx = new Path().move(points.from).line(points.totop).attr('class', 'dashed')
points.text_dy = points.totop
.shiftFractionTowards(points.to, 0.4)
.attr("data-text", points.from.dy(points.to)+"mm")
.attr("data-text-class", "text-sm fill-note right")
.attr('data-text', points.from.dy(points.to) + 'mm')
.attr('data-text-class', 'text-sm fill-note right')
paths.line_dy = new Path()
.move(points.to)
.line(points.totop)
.attr("class", "dashed")
paths.line_dy = new Path().move(points.to).line(points.totop).attr('class', 'dashed')
return part
}

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -1,17 +1,6 @@
export default function (part) {
let {
paperless,
sa,
store,
complete,
points,
options,
macro,
Point,
paths,
Path,
measurements,
} = part.shorthand()
let { paperless, sa, store, complete, points, options, macro, Point, paths, Path, measurements } =
part.shorthand()
let scale = 1
let base = scale * measurements.head * (1 + options.headEase)
@ -60,7 +49,7 @@ export default function (part) {
})
macro('sprinkle', {
snippet: 'notch',
on: [ 'innerMid', 'outerMid' ]
on: ['innerMid', 'outerMid'],
})
if (sa) paths.sa = paths.seam.offset(sa).attr('class', 'fabric sa')

View file

@ -1,5 +1,6 @@
export default function (part) {
let { store, paperless, sa, complete, points, macro, paths, Path, snippets, Snippet } = part.shorthand()
let { store, paperless, sa, complete, points, macro, paths, Path, snippets, Snippet } =
part.shorthand()
// Clean up
for (let i of Object.keys(paths)) {
@ -38,7 +39,7 @@ export default function (part) {
.shiftAlong(store.get('topDistanceToSecondNotch'))
macro('sprinkle', {
snippet: 'notch',
on: [ 'notch1', 'notch2' ]
on: ['notch1', 'notch2'],
})
if (sa) {

View file

@ -1,17 +1,6 @@
export default function (part) {
let {
paperless,
sa,
points,
macro,
Point,
Path,
paths,
snippets,
Snippet,
complete,
store
} = part.shorthand()
let { paperless, sa, points, macro, Point, Path, paths, snippets, Snippet, complete, store } =
part.shorthand()
const fitCap = (part, scale) => {
let { points, options, Point, Path, measurements } = part.shorthand()
@ -154,21 +143,24 @@ export default function (part) {
macro('miniscale', { at: new Point(points.title.x * 0.75, points.title.y) })
macro('sprinkle', {
snippet: 'notch',
on: [ 'midMid', 'backHollow', 'midSide' ]
on: ['midMid', 'backHollow', 'midSide'],
})
store.set('topDistanceToFirstNotch', new Path()
store.set(
'topDistanceToFirstNotch',
new Path()
.move(points.backEdge)
.line(points.backSide)
.curve(points.backSideCp1, points.backHollowCp2, points.backHollow)
.length()
)
store.set('topDistanceToSecondNotch', new Path()
store.set(
'topDistanceToSecondNotch',
new Path()
.move(points.backHollow)
.curve(points.backHollowCp1, points.midSideCp2, points.midSide)
.length() + store.get('topDistanceToFirstNotch')
)
if (sa) paths.sa = paths.seam.offset(sa).attr('class', 'fabric sa')
if (paperless) {

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
Point,
points,
Path,
paths,
measurements,
options,
complete,
sa,
paperless,
macro,
} = part.shorthand()
let { Point, points, Path, paths, measurements, options, complete, sa, paperless, macro } =
part.shorthand()
let headRadius = measurements.head / 2 / Math.PI
let brimRadius = headRadius / Math.sin((options.brimAngle * Math.PI) / 180)

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
Point,
points,
Path,
paths,
measurements,
options,
macro,
complete,
sa,
paperless,
} = part.shorthand()
let { Point, points, Path, paths, measurements, options, macro, complete, sa, paperless } =
part.shorthand()
// Design pattern here

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
store,
options,
Point,
Path,
points,
paths,
complete,
sa,
paperless,
macro,
} = part.shorthand()
let { store, options, Point, Path, points, paths, complete, sa, paperless, macro } =
part.shorthand()
let w = options.handleWidth
let h = store.get('depth') * options.strapLength

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -1,19 +1,8 @@
import { sharedDimensions } from './shared'
export default function (part) {
let {
store,
macro,
Path,
Point,
points,
paths,
complete,
paperless,
sa,
options,
measurements,
} = part.shorthand()
let { store, macro, Path, Point, points, paths, complete, paperless, sa, options, measurements } =
part.shorthand()
// Clear paths from Brian
for (let i in paths) {

View file

@ -1,19 +1,8 @@
import { sharedDimensions } from './shared'
export default function (part) {
let {
utils,
store,
Point,
Path,
points,
paths,
complete,
paperless,
sa,
options,
measurements,
} = part.shorthand()
let { utils, store, Point, Path, points, paths, complete, paperless, sa, options, measurements } =
part.shorthand()
// Clear paths from Brian
for (let i in paths) {

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
macro,
Path,
points,
paths,
complete,
paperless,
snippets,
Snippet,
sa,
options,
} = part.shorthand()
let { macro, Path, points, paths, complete, paperless, snippets, Snippet, sa, options } =
part.shorthand()
if (!options.pocket) return part

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
Point,
Path,
points,
paths,
store,
options,
complete,
sa,
paperless,
macro,
} = part.shorthand()
let { Point, Path, points, paths, store, options, complete, sa, paperless, macro } =
part.shorthand()
// Clear paths from Brian, but keep sleevecap
for (let p of Object.keys(paths)) {

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
measurements,
options,
sa,
Point,
points,
Path,
paths,
complete,
paperless,
macro,
} = part.shorthand()
let { measurements, options, sa, Point, points, Path, paths, complete, paperless, macro } =
part.shorthand()
let width = (measurements.hpsToWaistBack + measurements.waistToHips) * options.ribbingHeight * 2
let length = measurements.wrist * (1 + options.cuffEase) * (1 - options.ribbingStretch)

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
store,
sa,
Point,
points,
Path,
paths,
complete,
paperless,
macro,
units,
} = part.shorthand()
let { store, sa, Point, points, Path, paths, complete, paperless, macro, units } =
part.shorthand()
let width = store.get('hoodCenterWidth')
let length = complete ? width * 2.5 : store.get('hoodCenterLength')

View file

@ -1,17 +1,6 @@
export default function (part) {
let {
measurements,
options,
sa,
Point,
points,
Path,
paths,
complete,
paperless,
macro,
units,
} = part.shorthand()
let { measurements, options, sa, Point, points, Path, paths, complete, paperless, macro, units } =
part.shorthand()
let width = (measurements.hpsToWaistBack + measurements.waistToHips) * options.ribbingHeight * 2
let length = complete

View file

@ -12,7 +12,7 @@ applyThisLayout: Dieses Layout anwenden
areYouSureYouWantToContinue: Bist du sicher, dass du fortfahren möchtest?
askForHelp: Nach Hilfe fragen
automatic: Automatisch
averagePeopleDoNotExist: "Durchschnittliche Menschen existieren nicht"
averagePeopleDoNotExist: 'Durchschnittliche Menschen existieren nicht'
awesome: Großartig
back: Rückseite
becauseThatWouldBeReallyHelpful: Weil das wirklich hilfreich wäre.
@ -72,7 +72,7 @@ drafts: Entwürfe
draftSettings: Entwurfseinstellungen
dragAndDropImageHere: Du kannst das Bild hier per Drag-and-Drop ablegen oder es unten manuell auswählen
emailAddress: E-Mail-Adresse
emailWorksToo: "Falls du deinen Benutzername nicht weißt: deine E-Mail-Adresse funktioniert auch"
emailWorksToo: 'Falls du deinen Benutzername nicht weißt: deine E-Mail-Adresse funktioniert auch'
enterEmailPickPassword: Gib deine E-Mail Adresse ein und wähle ein Passwort
export: Exportieren
exportTiledPDF: Exportieren als paginiertes PDF
@ -81,7 +81,7 @@ fieldRemoved: '{field} entfernt'
fieldSaved: '{field} gespeichert'
filterByPattern: Filtern nach Schnittmuster
filterPatterns: Schnittmuster filtern
forgotLoginInstructions: "Wenn du dein Passwort nicht mehr weißt: Benutzername oder E-Mail-Adresse eingeben und den <b>Passwort zurücksetzen</b> Knopf drücken"
forgotLoginInstructions: 'Wenn du dein Passwort nicht mehr weißt: Benutzername oder E-Mail-Adresse eingeben und den <b>Passwort zurücksetzen</b> Knopf drücken'
freesewing: Freesewing
freesewingOnGithub: Freesewing auf GitHub
github: GitHub
@ -156,7 +156,7 @@ remove: Entfernen
removeThing: '{thing} entfernen'
reportThisOnGithub: Melde dies auf GitHub
requiredMeasurements: Erforderliche Maße
resendActivationEmailMessage: "Trage die E-Mail-Adresse ein, mit der du dich angemeldet hast, und wir senden dir eine neue Bestätigungsnachricht."
resendActivationEmailMessage: 'Trage die E-Mail-Adresse ein, mit der du dich angemeldet hast, und wir senden dir eine neue Bestätigungsnachricht.'
resendActivationEmail: Aktivierungs-E-Mail erneut senden
resetPassword: Passwort zurücksetzen
reset: Zurücksetzen
@ -198,7 +198,7 @@ twitter: Twitter
txt-footer: Freesewing wird erstellt von einer Gemeinschaft von Mitwirkenden<br />mit der finanziellen Unterstützung unserer Förderer
txt-tier2: Unsere Kategorie mit dem demokratischsten Preis. Es ist vielleicht weniger als der Preis eines Lattes, aber deine Unterstützung bedeutet uns sehr viel.
txt-tier4: Wähle diese Stufe, und wir senden dir etwas von unserem heiß begehrten Freesewing-Swag nach Hause. Egal, wo in der Welt das auch sein mag.
txt-tier8: "Wenn du uns nicht nur unterstützen möchtest, sondern Freesewing zum Gedeihen bringen willst, ist das die Stufe für dich. Außerdem: extra Swag!"
txt-tier8: 'Wenn du uns nicht nur unterstützen möchtest, sondern Freesewing zum Gedeihen bringen willst, ist das die Stufe für dich. Außerdem: extra Swag!'
txt-tiers: 'FreeSewing wird durch ein freiwilliges Abonnement-Modell unterstützt'
unitsInfo: Freesewing unterstützt sowohl das metrische System als auch imperiale Einheiten. Wähle einfach aus, was von beiden du hier verwenden möchtest. (Standardmäßig werden die in deinem Account konfigurierten Einheiten verwendet).
updated: Aktualisiert
@ -240,8 +240,8 @@ noPattern: Du hast (noch) keine Schnittmuster. Erstelle ein neues Schnittmuster
modelFirst: Beginne damit, Maße hinzuzufügen
noModel: Du hast (noch) keine Maße hinzugefügt. FreeSewing kann maßgeschneiderte Schnittmuster erzeugen. Dafür benötigen wir jedoch Maße.
noModel2: Das erste, was du tun solltest, ist, eine Person hinzuzufügen und das Maßband auszupacken.
noUserBrowsingTitle: "Du kannst nicht einfach alle Benutzer durchsuchen"
noUserBrowsingText: "Wir haben Tausende von ihnen. Sicher gibt es Interessanteres auf unserer Seite zu tun?"
noUserBrowsingTitle: 'Du kannst nicht einfach alle Benutzer durchsuchen'
noUserBrowsingText: 'Wir haben Tausende von ihnen. Sicher gibt es Interessanteres auf unserer Seite zu tun?'
usePatternMeasurements: 'Verwende die Maße des Originalschnittmusters'
createReplica: Duplikat erstellen
showDetails: Details anzeigen

View file

@ -3,32 +3,32 @@ chatWithUs: 'Chatte mit uns'
emailchangeActionText: 'Bestätige deine neue E-Mail-Adresse'
emailchangeCopy1: 'Du hast um die Änderung der E-Mail-Adresse gebeten, die mit deinem Account unter <b>freesewing.org</b> verknüpft ist.<br><br>Bevor du dies tust, musst du deine neue E-Mail-Adresse bestätigen. Bitte klicke auf den folgenden Link, um dies zu tun:'
emailchangeHeaderOpeningLine: 'Wir stellen nur sicher, dass wir dich bei Bedarf erreichen können'
emailchangeHiddenIntro: "Lass uns deine neue E-Mail-Adresse bestätigen"
emailchangeHiddenIntro: 'Lass uns deine neue E-Mail-Adresse bestätigen'
emailchangeSubject: 'Bitte bestätige deine neue E-Mail-Adresse'
emailchangeTitle: 'Bitte bestätige deine neue E-Mail-Adresse'
emailchangeWhy: 'Du hast diese E-Mail erhalten, weil du die mit deinem Konto auf freesewing.org verknüpfte E-Mail-Adresse geändert hast'
footerCredits: 'Kreiert von Joost & Mitwirkenden, mit der finanziellen Unterstützung unserer Förderer ❤️ '
footerSlogan: 'Freesewing ist eine Open-Source Plattform für Schnittmuster nach Maß'
goodbyeCopy1: "Wenn du uns mitteilen möchtest, warum du uns verlässt, kannst du gerne auf diese Nachricht antworten. <br>Von unserer Seite aus werden wir dich nicht weiter stören."
goodbyeCopy1: 'Wenn du uns mitteilen möchtest, warum du uns verlässt, kannst du gerne auf diese Nachricht antworten. <br>Von unserer Seite aus werden wir dich nicht weiter stören.'
goodbyeHeaderOpeningLine: 'Sei dir nur bewusst, dass du jederzeit wiederkommen kannst'
goodbyeHiddenIntro: 'Vielen Dank, dass du Freesewing eine Chance gegeben hast'
goodbyeSubject: 'Mach''s gut! 👋'
goodbyeSubject: "Mach's gut! 👋"
goodbyeTitle: 'Vielen Dank, dass du Freesewing eine Chance gegeben hast'
goodbyeWhy: 'Du hast diese E-Mail als endgültiges Lebewohl erhalten, nachdem du deinen Account auf freesewing.org entfernt hast'
joostFromFreesewing: 'Joost von Freesewing'
passwordresetActionText: 'Erhalte erneut Zugang zu deinem Account'
passwordresetCopy1: 'Du hast dein Passwort für deinen Account bei <b>freesewing.org</b> vergessen.<br><br>Klicke auf den folgenden Link, um dein Passwort zurückzusetzen:'
passwordresetHeaderOpeningLine: "Keine Sorge, solche Dinge passieren uns allen"
passwordresetHeaderOpeningLine: 'Keine Sorge, solche Dinge passieren uns allen'
passwordresetHiddenIntro: 'Erhalte erneut Zugang zu deinem Account'
passwordresetSubject: 'Erhalte erneut Zugang zu deinem Account auf freesewing.org'
passwordresetTitle: 'Setze dein Passwort zurück und erhalte erneut Zugang zu deinem Account'
passwordresetWhy: 'Du hast diese E-Mail erhalten, weil du die Anfrage gestellt hast, dein Passwort von freesewing.org zurückzusetzen'
questionsJustReply: "Wenn du Fragen hast, antworte einfach auf diese E-Mail. Ich bin immer gerne bereit zu helfen. 🙂"
questionsJustReply: 'Wenn du Fragen hast, antworte einfach auf diese E-Mail. Ich bin immer gerne bereit zu helfen. 🙂'
signature: 'Liebe Grüße'
signupActionText: 'Bestätige deine E-Mail-Adresse'
signupCopy1: 'Danke, dass du dich bei <b>freesewing.org</b> angemeldet hast.<br><br>Bevor wir beginnen, musst du deine E-Mail-Adresse bestätigen. Bitte klicke auf den folgenden Link, um das zu tun:'
signupHeaderOpeningLine: "Wir freuen uns sehr darüber, dass du ein Teil der Freesewing-Community wirst."
signupHiddenIntro: "Lass uns deine E-Mail-Adresse bestätigen"
signupHeaderOpeningLine: 'Wir freuen uns sehr darüber, dass du ein Teil der Freesewing-Community wirst.'
signupHiddenIntro: 'Lass uns deine E-Mail-Adresse bestätigen'
signupSubject: 'Willkommen bei freesewing.org'
signupTitle: 'Willkommen an Bord'
signupWhy: 'Du hast diese E-Mail erhalten, weil du dich gerade auf freesewing.org angemeldet hast'

View file

@ -2,11 +2,11 @@
txt-blog: Neuigkeiten, Updates und Ankündigungen des Freesewing-Teams
txt-community: 'Alles wird von freiwilligen Mitwirkenden am Leben erhalten. Es existieren keine kommerziellen Absichten im Zusammenhang mit diesem Projekt.'
txt-different: Was uns von anderen unterscheidet
txt-draft: "Wähle eines deiner Schnittmuster, wähle ein Modell und lege die Optionen fest. Den Rest erledigen wir."
txt-draft: 'Wähle eines deiner Schnittmuster, wähle ein Modell und lege die Optionen fest. Den Rest erledigen wir.'
txt-how: So funktioniert es
txt-join: Schließe dich Tausenden anderer an und erstelle einen kostenlosen Account auf freesewing.org.
txt-model: Alle unsere Schnittmuster werden nach individuellen Maßen gefertigt. Nimm daher zuallererst das Maßband zur Hand.
txt-newHere: "Wenn du hier neu bist, ist unsere Demo der beste Startpunkt:"
txt-newHere: 'Wenn du hier neu bist, ist unsere Demo der beste Startpunkt:'
txt-opensource: 'Unsere Plattform, unsere Schnittmuster und sogar diese Website: Unser gesamter Code ist auf GitHub zugänglich. Pull-Requests sind jederzeit herzlich willkommen!'
txt-patrons: Freesewing wird durch die finanzielle Unterstützung unserer Förderer überhaupt erst ermöglicht. Scrolle nach unten, um mehr über unser Abonnementmodell zu erfahren.
txt-showcase: Abgeschlossene Projekte aus der Freesewing-Community

View file

@ -6,5 +6,5 @@ bio: Erzähle uns ein wenig über dich
social: Lass uns wissen, wo wir dir folgen können
newsletter: Teile uns deine Newsletter-Präferenz mit
letUsSetupYourAccount: Lassen Sie uns Ihr Konto einrichten.
walkYouThrough: "Wir führen dich durch die folgenden Schritte:"
walkYouThrough: 'Wir führen dich durch die folgenden Schritte:'
someOptional: Obwohl alle diese Schritte optional sind, empfehlen wir dir sie durchzugehen, um das Beste aus FreeSewing herauszuholen.

View file

@ -12,7 +12,7 @@ applyThisLayout: Aplicar este diseño
areYouSureYouWantToContinue: Estás seguro de que quieres continuar?
askForHelp: Pide ayuda
automatic: Automático
averagePeopleDoNotExist: "La gente promedio no existe"
averagePeopleDoNotExist: 'La gente promedio no existe'
awesome: Genial
back: Atrás
becauseThatWouldBeReallyHelpful: Porque eso sería realmente útil.
@ -72,7 +72,7 @@ drafts: Bocetos
draftSettings: Ajustes del boceto
dragAndDropImageHere: Drag and drop an image here, or select one manually with the button below
emailAddress: Dirección de correo electrónico
emailWorksToo: "Si no conoces tu nombre de usuario, tu dirección de correo electrónico también funcionará"
emailWorksToo: 'Si no conoces tu nombre de usuario, tu dirección de correo electrónico también funcionará'
enterEmailPickPassword: Introduce tu dirección de email y elige una contraseña
export: Exportar
exportTiledPDF: Exportar PDF paginado
@ -81,7 +81,7 @@ fieldRemoved: '{field} eliminado'
fieldSaved: '{field} guardado'
filterByPattern: Filtrar por patrón
filterPatterns: Filtrar los patrones
forgotLoginInstructions: "Entra tu nombre de usuario o correo electrónico debajo y pulsa el botón de Restablecer contraseña"
forgotLoginInstructions: 'Entra tu nombre de usuario o correo electrónico debajo y pulsa el botón de Restablecer contraseña'
freesewing: Freesewing
freesewingOnGithub: Freesewing en GitHub
github: GitHub
@ -198,7 +198,7 @@ twitter: Twitter
txt-footer: Freesewing is made by a community of contributors<br />with the financial support of our Patrons
txt-tier2: Nuestro nivel más democrático de precios. Puede ser menor que el precio de un café con leche, pero su apoyo significa mucho para nosotros.
txt-tier4: Suscríbase a este nivel y le enviaremos parte de nuestro codiciado botín de diseño gratuito a su hogar en cualquier parte del mundo.
txt-tier8: "Si no solo desea apoyarnos, sino que quiere ver prosperar en la libertad, este es el nivel para usted. También: botín extra!"
txt-tier8: 'Si no solo desea apoyarnos, sino que quiere ver prosperar en la libertad, este es el nivel para usted. También: botín extra!'
txt-tiers: 'FreeSewing is fuelled by a voluntary subscription model'
unitsInfo: La liberación es compatible con el sistema métrico y las unidades imperiales. Simplemente elige el que te gustaría usar aquí. (El valor predeterminado es utilizar las unidades configuradas en su cuenta).
updated: Actualizado

View file

@ -3,13 +3,13 @@ chatWithUs: 'Habla con nosotros'
emailchangeActionText: 'Confirme su nueva dirección de correo electrónico'
emailchangeCopy1: 'Solicitó cambiar la dirección de correo electrónico vinculada a su cuenta en <b> freesewing.org </b>.<br><br>Antes de hacerlo, debe confirmar su nueva dirección de correo electrónico. Por favor haga clic en el enlace de abajo para hacer eso:'
emailchangeHeaderOpeningLine: 'Solo asegurándonos de que podamos contactarlo cuando sea necesario'
emailchangeHiddenIntro: "Confirmemos tu nueva dirección de correo electrónico"
emailchangeHiddenIntro: 'Confirmemos tu nueva dirección de correo electrónico'
emailchangeSubject: 'Por favor confirme su nueva dirección de correo electrónico'
emailchangeTitle: 'Por favor confirme su nueva dirección de correo electrónico'
emailchangeWhy: 'You received this E-mail because you changed the E-mail address linked to your account on freesewing.org'
footerCredits: 'Made by joost & contributors with the financial support of our patrons ❤️ '
footerSlogan: 'Freesewing es una plataforma open source para patrones de costura a medida'
goodbyeCopy1: "Si desea compartir por qué se va, puede responder a este mensaje. <br> Por nuestra parte, no volveremos a molestarlo."
goodbyeCopy1: 'Si desea compartir por qué se va, puede responder a este mensaje. <br> Por nuestra parte, no volveremos a molestarlo.'
goodbyeHeaderOpeningLine: 'Solo se sabe que siempre se puede volver.'
goodbyeHiddenIntro: 'Gracias por darle una oportunidad a freesewing'
goodbyeSubject: 'Despedida 👋'
@ -18,17 +18,17 @@ goodbyeWhy: 'Recibió este correo electrónico como último adiós después de e
joostFromFreesewing: 'Joost de Freesewing'
passwordresetActionText: 'Recupere el acceso a su cuenta'
passwordresetCopy1: 'Olvidó su contraseña para su cuenta en <b> freesewing.org </b>. <br> <br> Haga clic en el enlace de abajo para restablecer su contraseña:'
passwordresetHeaderOpeningLine: "No te preocupes, estas cosas nos pasan a todos."
passwordresetHeaderOpeningLine: 'No te preocupes, estas cosas nos pasan a todos.'
passwordresetHiddenIntro: 'Recupere el acceso a su cuenta'
passwordresetSubject: 'Recupere el acceso a su cuenta en freesewing.org'
passwordresetTitle: 'Restablece tu contraseña y vuelve a obtener acceso a tu cuenta'
passwordresetWhy: 'Recibió este correo electrónico porque solicitó restablecer su contraseña en freesewing.org'
questionsJustReply: "Si tiene alguna pregunta, simplemente responda a este correo electrónico. Siempre feliz de ayudar. 🙂"
questionsJustReply: 'Si tiene alguna pregunta, simplemente responda a este correo electrónico. Siempre feliz de ayudar. 🙂'
signature: 'Con amor,'
signupActionText: 'Confirme su dirección de correo electrónico'
signupCopy1: 'Gracias por registrarse en <b>freesewing.org</b>.<br><br>Antes de comenzar, debe confirmar su dirección de correo electrónico. Por favor haga clic en el enlace de abajo para hacer eso:'
signupHeaderOpeningLine: "Estamos muy contentos de que te unas a la comunidad de freesewing."
signupHiddenIntro: "Confirmemos tu dirección de correo electrónico"
signupHeaderOpeningLine: 'Estamos muy contentos de que te unas a la comunidad de freesewing.'
signupHiddenIntro: 'Confirmemos tu dirección de correo electrónico'
signupSubject: 'Bienvenido a freesewing.org'
signupTitle: 'Bienvenido a bordo'
signupWhy: 'Recibió este correo electrónico porque acaba de registrarse para una cuenta en freesewing.org'

View file

@ -2,11 +2,11 @@
txt-blog: Noticias, actualizaciones y anuncios del equipo de freesewing.
txt-community: 'Todo es llevado por colaboradores voluntarios. TNo hay ninguna entidad comercial detrás de, o vinculada a, este proyecto.'
txt-different: En qué somos diferentes
txt-draft: "Elige uno de los patrones, elige un model y elige tus opciones. Nosotros hacemos el resto"
txt-draft: 'Elige uno de los patrones, elige un model y elige tus opciones. Nosotros hacemos el resto'
txt-how: Cómo funciona
txt-join: Únete a miles de personas y regístrate en freesewing.org.
txt-model: Todos nuestros patrones son a medida. Así que lo primero que necesitas es un metro.
txt-newHere: "Si eres nuevo aquí, el mejor lugar para comenzar es nuestra demostración:"
txt-newHere: 'Si eres nuevo aquí, el mejor lugar para comenzar es nuestra demostración:'
txt-opensource: 'Nuestra plataforma, nuestros patrones e incluso este sitio web. Todo nuestro código está disponible en GitHub. Modificaciones son bienvenidas!'
txt-patrons: Freesewing es posible por el apoyo económico de nuestros patrocinadores. Desplácese hacia abajo para conocer nuestro modelo de suscripción.
txt-showcase: Proyectos terminados de la comunidad de freesewing

View file

@ -6,5 +6,5 @@ bio: Cuéntanos un poco acerca de ti
social: Háganos saber dónde podemos seguirle
newsletter: Give us your newsletter preference
letUsSetupYourAccount: Permítanos configurar su cuenta.
walkYouThrough: "Te guiaremos a través de los siguientes pasos:"
walkYouThrough: 'Te guiaremos a través de los siguientes pasos:'
someOptional: Aunque todos estos pasos son opcionales, te recomendamos que los recorras para sacar el máximo provecho de FreeSewing.

View file

@ -96,7 +96,7 @@ howToTakeMeasurements: Comment prendre les mesures
i18n: Internationalisation
imperialUnits: Unités impériales (pouces)
instagram: Instagram
invalidTldMessage: '.{tld} n''est pas un TLD valide'
invalidTldMessage: ".{tld} n'est pas un TLD valide"
joinTheChatMsg: Nous avons une communauté sur Discord avec des amis avec lesquels vous pouvez discuter.
justAMoment: Juste un instant
layout: Mis en page
@ -179,11 +179,11 @@ shareFreesewing: Partager FreeSewing
showcase: Galerie
signUpForAFreeAccount: Créer un compte gratuit
signUp: S'inscrire
signupWithProvider: 'S''inscrire avec {provider}'
signupWithProvider: "S'inscrire avec {provider}"
sortByField: Trier par {field}
standardSeamAllowance: Marge de couture standard
startOver: Recommencer
startTranslatingNowOrRead: '{startTranslatingNow}, ou lisez d''abord la {documentationForTranslators}.'
startTranslatingNowOrRead: "{startTranslatingNow}, ou lisez d'abord la {documentationForTranslators}."
startTranslatingNow: Commencez à traduire maintenant
subscribe: Souscrire
support: Support
@ -240,9 +240,9 @@ noPattern: Vous n'avez pas (encore) de patrons. Créez un nouveau patron, puis s
modelFirst: Commencez par ajouter des mensurations
noModel: Vous n'avez pas (encore) ajouté de mesure. FreeSewing peut générer des patrons de couture sur mesure. Mais pour cela, nous avons besoin de mensurations.
noModel2: La première chose à faire est donc d'ajouter une personne et de sortir votre mètre-ruban.
noUserBrowsingTitle: "Vous ne pouvez pas simplement parcourir tous les utilisateurs"
noUserBrowsingText: "Nous en avons des milliers. Vous avez certainement autre chose à faire ?"
usePatternMeasurements: 'Utiliser les mesures du patron d''origine'
noUserBrowsingTitle: 'Vous ne pouvez pas simplement parcourir tous les utilisateurs'
noUserBrowsingText: 'Nous en avons des milliers. Vous avez certainement autre chose à faire ?'
usePatternMeasurements: "Utiliser les mesures du patron d'origine"
createReplica: Créer une réplique
showDetails: Voir les détails
hideDetails: Masquer les détails

View file

@ -1,24 +1,24 @@
---
chatWithUs: 'Discutez avec nous'
emailchangeActionText: 'Confirmez votre nouvelle adresse mail'
emailchangeCopy1: 'Vous avez demandé de modifier l''adresse e-mail associée à votre compte sur <b>freesewing.org</b>.<br><br>Avant de procéder, vous devez confirmer votre nouvelle adresse e-mail. S''il vous plaît cliquez sur le lien ci-dessous pour le faire :'
emailchangeCopy1: "Vous avez demandé de modifier l'adresse e-mail associée à votre compte sur <b>freesewing.org</b>.<br><br>Avant de procéder, vous devez confirmer votre nouvelle adresse e-mail. S'il vous plaît cliquez sur le lien ci-dessous pour le faire :"
emailchangeHeaderOpeningLine: 'Assurez-vous simplement que nous pouvons vous joindre en cas de besoin'
emailchangeHiddenIntro: "Confirmons votre nouvelle adresse e-mail"
emailchangeHiddenIntro: 'Confirmons votre nouvelle adresse e-mail'
emailchangeSubject: 'Merci de confirmer votre nouvelle adresse e-mail'
emailchangeTitle: 'Merci de confirmer votre nouvelle adresse e-mail'
emailchangeWhy: 'You received this E-mail because you changed the E-mail address linked to your account on freesewing.org'
footerCredits: 'Réalisé par Joost De Cock et ses contributeurs avec le soutien financier de mécènes ❤️ '
footerSlogan: 'Freesewing est une plate-forme open source pour des patrons de couture sur mesure'
goodbyeCopy1: "Si vous souhaitez expliquer pourquoi vous partez, vous pouvez répondre à ce message.<br>De notre côté, nous ne vous dérangerons plus."
goodbyeCopy1: 'Si vous souhaitez expliquer pourquoi vous partez, vous pouvez répondre à ce message.<br>De notre côté, nous ne vous dérangerons plus.'
goodbyeHeaderOpeningLine: 'Sachez simplement que vous pouvez toujours revenir'
goodbyeHiddenIntro: 'Merci d''avoir donné une chance à freesewing'
goodbyeHiddenIntro: "Merci d'avoir donné une chance à freesewing"
goodbyeSubject: 'Adieu 👋'
goodbyeTitle: 'Merci d''avoir donné une chance à freesewing'
goodbyeWhy: 'Vous avez reçu cet e-mail en guise d''adieu final après la suppression de votre compte sur freesewing.org'
goodbyeTitle: "Merci d'avoir donné une chance à freesewing"
goodbyeWhy: "Vous avez reçu cet e-mail en guise d'adieu final après la suppression de votre compte sur freesewing.org"
joostFromFreesewing: 'Joost de Freesewing'
passwordresetActionText: 'Re-accéder à votre compte'
passwordresetCopy1: 'Vous avez oublié votre mot de passe pour votre compte sur <b>freesewing.org</b>.<br><br>Cliquez sur le lien ci-dessous pour réinitialiser votre mot de passe:'
passwordresetHeaderOpeningLine: "Ne vous inquiétez pas, ce genre de choses nous arrive à tous"
passwordresetHeaderOpeningLine: 'Ne vous inquiétez pas, ce genre de choses nous arrive à tous'
passwordresetHiddenIntro: 'Re-accéder à votre compte'
passwordresetSubject: 'Re-accéder à votre compte sur freesewing.org'
passwordresetTitle: 'Réinitialisez votre mot de passe et accédez à nouveau à votre compte.'
@ -27,8 +27,8 @@ questionsJustReply: "Si vous avez des questions, répondez simplement à cet e-m
signature: 'Bise,'
signupActionText: 'Confirmez votre adresse mail'
signupCopy1: 'Merci de votre inscription sur <b>freesewing.org</b>.<br><br>Avant de commencer, vous devez confirmer votre adresse e-mail. Pour cela veuillez cliquer sur le lien ci-dessous :'
signupHeaderOpeningLine: "Nous sommes vraiment heureux que vous rejoigniez la communauté freesewing."
signupHiddenIntro: "Confirmons votre adresse mail"
signupHeaderOpeningLine: 'Nous sommes vraiment heureux que vous rejoigniez la communauté freesewing.'
signupHiddenIntro: 'Confirmons votre adresse mail'
signupSubject: 'Bienvenue sur freesewing.org'
signupTitle: 'Bienvenue à bord'
signupWhy: 'Vous avez reçu cet e-mail parce que vous venez de créer un compte sur freesewing.org'

View file

@ -21,10 +21,10 @@ openDataInfo: Ces données sont utilisées pour étudier et comprendre la forme
openDataQuestion: Partager des mesures anonymisées sous forme de données ouvertes
profileQuestion: Donnez-vous votre consentement pour traiter vos données de profil ?
profileShareAnswer: '<b>Non</ b>, jamais.'
profileTimingAnswer: '<b>12 mois</b> après votre dernière connexion ou jusqu''à ce que vous <b>supprimiez</b> votre compte ou <b>révoquiez</b> ce consentement.'
profileTimingAnswer: "<b>12 mois</b> après votre dernière connexion ou jusqu'à ce que vous <b>supprimiez</b> votre compte ou <b>révoquiez</b> ce consentement."
profileWarning: Révoquer ce consentement entraînera la suppression de toutes vos données. Cela a exactement le même effet que de supprimer votre compte.
profileWhatAnswerOptional: 'Optionnel : une <b>photo de profil</b>, <b>biographie</b>, et <b>comptes de réseaux sociaux</b>'
profileWhatAnswer: 'Votre <b>adresse e-mail</b>, <b>nom d''utilisateur</b>et <b>mot de passe</b>.'
profileWhatAnswer: "Votre <b>adresse e-mail</b>, <b>nom d'utilisateur</b>et <b>mot de passe</b>."
profileWhatQuestion: Que sont les données de profil ?
profileWhyAnswer: 'Pour <b>vous authentifier</b> , <b>vous contacter</b> lorsque nécessaire, et construire une <b>communauté</b>.'
readMore: Pour plus d'informations, veuillez lire notre politique de confidentialité.
@ -34,6 +34,6 @@ shareQuestion: La partageons-nous avec les autres ?
timingQuestion: Combien de temps les gardons-nous ?
whatYouNeedToKnow: Ce que vous devez savoir
whyQuestion: Pourquoi en avons-nous besoin ?
yesIDoObject: 'Oui, je m''y oppose'
yesIDoObject: "Oui, je m'y oppose"
yesIDo: 'Oui, je le veux'
openData: 'Note : Freesewing publie des mesures rendues anonymes en tant que données libres pour la recherche scientifique. Vous avez le droit de vous y opposer'

View file

@ -1,12 +1,12 @@
---
txt-blog: Nouvelles, mises à jour et annonces de l'équipe freesewing
txt-community: 'Tout est géré par des contributeurs bénévoles. Il n''y a pas d''entité commerciale, ou assimilée, derrière ce projet.'
txt-community: "Tout est géré par des contributeurs bénévoles. Il n'y a pas d'entité commerciale, ou assimilée, derrière ce projet."
txt-different: Ce en quoi nous sommes différents
txt-draft: "Choisissez parmi l'un de vos patrons, choisissez un modèle, et sélectionnez vos options. Nous ferons le reste."
txt-how: Comment ça marche
txt-join: Rejoignez des milliers d'autres personnes en vous inscrivant gratuitement sur freesewing.org.
txt-model: Tous nos patrons sont faits sur mesure, donc la première chose à faire est de vous munir de votre mètre-ruban.
txt-newHere: "Si vous êtes nouveau ici, le meilleur endroit pour commencer est notre démo :"
txt-newHere: 'Si vous êtes nouveau ici, le meilleur endroit pour commencer est notre démo :'
txt-opensource: 'Notre plateforme, nos patrons, et même ce site web. Tout notre code est disponible sur GitHub. Les "Pull requests" sont les bienvenues !'
txt-patrons: Freesewing existe grâce au soutien financier de nos Mécènes. Faites défiler vers le bas pour en savoir plus sur nos modes de souscription.
txt-showcase: Projets terminés de la communauté freesewing

View file

@ -6,5 +6,5 @@ bio: Parlez-nous un peu de vous
social: Dites-nous où nous pouvons vous suivre
newsletter: Donnez-nous votre préférence pour la newsletter
letUsSetupYourAccount: Laissez-nous configurer votre compte.
walkYouThrough: "Nous vous guiderons à travers les étapes suivantes :"
walkYouThrough: 'Nous vous guiderons à travers les étapes suivantes :'
someOptional: Bien que toutes ces étapes soient facultatives, nous vous recommandons de les passer en revue pour tirer le meilleur parti de FreeSewing.

View file

@ -12,7 +12,7 @@ applyThisLayout: Pas deze layout toe
areYouSureYouWantToContinue: Weet je zeker dat je door wilt gaan?
askForHelp: Vraag om hulp
automatic: Automatisch
averagePeopleDoNotExist: "Gemiddelde mensen bestaan niet"
averagePeopleDoNotExist: 'Gemiddelde mensen bestaan niet'
awesome: Super
back: Achterzijde
becauseThatWouldBeReallyHelpful: Want dat zou ons echt vooruit helpen.
@ -72,7 +72,7 @@ drafts: Patroontekeningen
draftSettings: Instellingen patroontekening
dragAndDropImageHere: Drag and drop an image here, or select one manually with the button below
emailAddress: Email adres
emailWorksToo: "Als je je gebruikersnaam niet meer weet, vul dan je email adres in, dat werkt ook"
emailWorksToo: 'Als je je gebruikersnaam niet meer weet, vul dan je email adres in, dat werkt ook'
enterEmailPickPassword: Voer je email adres in, en kies een wachtwoord
export: Exporteren
exportTiledPDF: Gepagineerde PDF exporteren
@ -81,7 +81,7 @@ fieldRemoved: '{field} verwijderd'
fieldSaved: '{field} opgeslagen'
filterByPattern: Filter op patroon
filterPatterns: Patronen filteren
forgotLoginInstructions: "Als je je wachtwoord niet meer weet, vul dan hieronder je gebruikersnaam of email adres in, en klik op de <b>Herstel wachtwoord</b> knop"
forgotLoginInstructions: 'Als je je wachtwoord niet meer weet, vul dan hieronder je gebruikersnaam of email adres in, en klik op de <b>Herstel wachtwoord</b> knop'
freesewing: Freesewing
freesewingOnGithub: FreeSewing op GitHub
github: GitHub
@ -156,7 +156,7 @@ remove: Verwijderen
removeThing: '{thing} verwijderen'
reportThisOnGithub: Melden via GitHub
requiredMeasurements: Vereiste maten
resendActivationEmailMessage: "Vul het e-mailadres waarmee je je account aangemaakt hebt in en we zullen je een nieuwe bevestigingsmail sturen."
resendActivationEmailMessage: 'Vul het e-mailadres waarmee je je account aangemaakt hebt in en we zullen je een nieuwe bevestigingsmail sturen.'
resendActivationEmail: Stuur een nieuwe activatie email
resetPassword: Wachtwoord opnieuw instellen
reset: Reset
@ -198,7 +198,7 @@ twitter: Twitter
txt-footer: Freesewing is made by a community of contributors<br />with the financial support of our Patrons
txt-tier2: Onze meest democratisch geprijsde optie. Het is minder dan de prijs van een latte, maar jouw steun betekent alles voor ons.
txt-tier4: Abonneer je op deze optie en we sturen wat van onze erg gegeerde FreeSewing swag naar je thuis. Waar ook ter wereld dat mag zijn.
txt-tier8: "Als je ons niet louter wil steunen, maar FreeSewing wil zien groeien, dan is dit de optie voor jou. Ook: extra swag!"
txt-tier8: 'Als je ons niet louter wil steunen, maar FreeSewing wil zien groeien, dan is dit de optie voor jou. Ook: extra swag!'
txt-tiers: 'FreeSewing draait op een vrijwillig subscriptiemodel'
unitsInfo: FreeSewing ondersteunt zowel het metrieke stelsel als de imperiale eenheden. Kies eenvoudig welke u hier wilt gebruiken. (de standaard is om de eenheden te gebruiken die in uw account zijn geconfigureerd).
updated: Bijgewerkt
@ -240,8 +240,8 @@ noPattern: Je hebt (nog) geen patronen. Maak een nieuw patroon, en sla het op in
modelFirst: Begin met maten toe te voegen
noModel: Je hebt (nog) geen maten toegevoegd. FreeSewing can naaipatronen op maat genereren. Maar daarvoor hebben we maten nodig.
noModel2: Dus het eerste dat je zou moeten doen is een persoon toevoegen, en je lintmeter bovenhalen.
noUserBrowsingTitle: "Je kan niet zomaar door alle gebruikers grasduinen"
noUserBrowsingText: "We hebben er duizenden. Je hebt toch wel wat beters te doen?"
noUserBrowsingTitle: 'Je kan niet zomaar door alle gebruikers grasduinen'
noUserBrowsingText: 'We hebben er duizenden. Je hebt toch wel wat beters te doen?'
usePatternMeasurements: 'Gebruik de maten van het originele patroon'
createReplica: Creëer een replica
showDetails: Toon details

View file

@ -3,13 +3,13 @@ chatWithUs: 'Chat met ons'
emailchangeActionText: 'Bevestig uw nieuwe e-mailadres'
emailchangeCopy1: 'U heeft verzocht het e-mailadres dat aan uw account is gekoppeld te wijzigen op <b> freesewing.org </b>.<br><br>Voordat we dat doen, moet u uw nieuwe e-mailadres bevestigen. Klik op de onderstaande link om dat te doen:'
emailchangeHeaderOpeningLine: 'We zorgen ervoor dat we u kunnen bereiken wanneer dat nodig is'
emailchangeHiddenIntro: "Laten we uw nieuwe e-mailadres bevestigen"
emailchangeHiddenIntro: 'Laten we uw nieuwe e-mailadres bevestigen'
emailchangeSubject: 'Bevestig uw nieuwe e-mailadres'
emailchangeTitle: 'Bevestig uw nieuwe e-mailadres'
emailchangeWhy: 'You received this E-mail because you changed the E-mail address linked to your account on freesewing.org'
footerCredits: 'Gemaakt door joost & vrijwilligers met de financiële steun van onze Patrons ❤️ '
footerSlogan: 'FreeSewing is een open source platform voor naaipatronen op maat'
goodbyeCopy1: "Als je wilt delen waarom je vertrekt, kun je dit bericht beantwoorden. <br> Van onze kant zullen we je niet opnieuw lastig vallen."
goodbyeCopy1: 'Als je wilt delen waarom je vertrekt, kun je dit bericht beantwoorden. <br> Van onze kant zullen we je niet opnieuw lastig vallen.'
goodbyeHeaderOpeningLine: 'Weet gewoon dat je altijd terug kunt komen'
goodbyeHiddenIntro: 'Bedankt dat je freesewing.org een kans hebt gegeven'
goodbyeSubject: 'Vaarwel 👋'
@ -18,17 +18,17 @@ goodbyeWhy: 'U ontving deze e-mail als een laatste adieu na het verwijderen van
joostFromFreesewing: 'Joost van FreeSewing'
passwordresetActionText: 'Krijg toegang tot uw account'
passwordresetCopy1: 'U bent uw wachtwoord voor uw account vergeten op <b>freesewing.org</b>.<br><br>Klik op de onderstaande link om uw wachtwoord opnieuw in te stellen:'
passwordresetHeaderOpeningLine: "Maak je geen zorgen, deze dingen gebeuren met ons allemaal"
passwordresetHeaderOpeningLine: 'Maak je geen zorgen, deze dingen gebeuren met ons allemaal'
passwordresetHiddenIntro: 'Krijg toegang tot uw account'
passwordresetSubject: 'Krijg toegang tot uw account op freesewing.org'
passwordresetTitle: 'Stel uw wachtwoord opnieuw in en verkrijg opnieuw toegang tot uw account'
passwordresetWhy: 'U hebt deze e-mail ontvangen omdat u heeft gevraagd om uw wachtwoord opnieuw in te stellen op freesewing.org'
questionsJustReply: "Zit je met vragen? Stuur ze dan als antwoord op deze E-mail. Ik ben steeds bereid om een handje te helpen. 🙂"
questionsJustReply: 'Zit je met vragen? Stuur ze dan als antwoord op deze E-mail. Ik ben steeds bereid om een handje te helpen. 🙂'
signature: 'Liefs,'
signupActionText: 'Bevestig je E-mail adres'
signupCopy1: 'Leuk dat je je hebt ingeschreven op <b>freesewing.org</b>.<br><br>Vooraleer we aan de slag kunnen, moeten we eerst je E-mail adres bevestigen. Klik op onderstaande link om dat te doen:'
signupHeaderOpeningLine: "We zijn verheugd dat je deel wil uitmaken van de freesewing gemeenschap."
signupHiddenIntro: "Nu gewoon nog even je E-mail adres bevestigen"
signupHeaderOpeningLine: 'We zijn verheugd dat je deel wil uitmaken van de freesewing gemeenschap.'
signupHiddenIntro: 'Nu gewoon nog even je E-mail adres bevestigen'
signupSubject: 'Welkom bij freesewing.org'
signupTitle: 'Welkom aan boord'
signupWhy: 'Je ontving deze E-mail omdat je je zonet ingeschreven hebt op freesewing.org'

View file

@ -2,11 +2,11 @@
txt-blog: Nieuws, updates, and mededelingen door het freesewing team
txt-community: 'Al het werk word gedaan door vrijwillige medewerkers. Er zijn geen commerciële belangen verbonden aan het project.'
txt-different: Hoe we anders zijn
txt-draft: "Kies één van onze patronen, één van jouw modellen, en kies je opties. Wij doen de rest."
txt-draft: 'Kies één van onze patronen, één van jouw modellen, en kies je opties. Wij doen de rest.'
txt-how: Hoe het werkt
txt-join: Sluit je aan bij duizenden anderen, en schrijf je gratis in op freesewing.org.
txt-model: Al onze patronen zijn op maat gemaakt. Het eerste wat je dus moet doen is je lintmeter bij de hand nemen.
txt-newHere: "Ben je hier nieuw? Dan is onze demo de beste plaats om van start te gaan:"
txt-newHere: 'Ben je hier nieuw? Dan is onze demo de beste plaats om van start te gaan:'
txt-opensource: 'Ons platform, al onze patronen, en zelfs deze website. Al onze broncode is beschikbaar op GitHub. Pull requests welkom!'
txt-patrons: Freesewing wordt mogelijk gemaakt door de financiële steun van onze mecenassen. Onderaan deze pagina kan je meer lezen over hoe we dit schip drijvende houden.
txt-showcase: Bekijk de projecten gemaakt door de freesewing gemeenschap

View file

@ -6,5 +6,5 @@ bio: Vertel ons een beetje over jezelf
social: Laat ons weten waar we je kunnen volgen
newsletter: Geef ons je voorkeur met betrekking tot de nieuwsbrief
letUsSetupYourAccount: Laten we je account instellen.
walkYouThrough: "We zullen je door de volgende stappen begeleiden:"
walkYouThrough: 'We zullen je door de volgende stappen begeleiden:'
someOptional: Hoewel al deze stappen optioneel zijn, raden we je toch aan alles te doen om het meeste uit FreeSewing te halen.

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
paperless,
sa,
store,
complete,
points,
options,
macro,
Point,
paths,
Path,
} = part.shorthand()
let { paperless, sa, store, complete, points, options, macro, Point, paths, Path } =
part.shorthand()
let width = store.get('chestPocketWidth')
let welt = store.get('chestPocketWeltHeight')

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
paperless,
sa,
store,
complete,
points,
options,
macro,
Point,
paths,
Path,
} = part.shorthand()
let { paperless, sa, store, complete, points, options, macro, Point, paths, Path } =
part.shorthand()
let width = store.get('chestPocketWidth')
let height = store.get('chestPocketWeltHeight')

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
paperless,
sa,
store,
complete,
points,
options,
macro,
Point,
paths,
Path,
} = part.shorthand()
let { paperless, sa, store, complete, points, options, macro, Point, paths, Path } =
part.shorthand()
let width = store.get('innerPocketWidth')
let welt = store.get('innerPocketWeltHeight')

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
paperless,
sa,
store,
complete,
points,
options,
macro,
Point,
paths,
Path,
} = part.shorthand()
let { paperless, sa, store, complete, points, options, macro, Point, paths, Path } =
part.shorthand()
let width = store.get('pocketWidth')
let depth = store.get('pocketDepth')

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
paperless,
sa,
utils,
complete,
points,
measurements,
options,
macro,
paths,
Path,
} = part.shorthand()
let { paperless, sa, utils, complete, points, measurements, options, macro, paths, Path } =
part.shorthand()
// Vent
let slope = 15

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
paperless,
sa,
utils,
complete,
points,
measurements,
options,
macro,
paths,
Path,
} = part.shorthand()
let { paperless, sa, utils, complete, points, measurements, options, macro, paths, Path } =
part.shorthand()
// Vent
let slope = 15

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -12,23 +12,18 @@ const output = [
format: 'cjs',
sourcemap: true,
exports: rollup.exports,
}
},
]
if (typeof module !== 'undefined')
output.push({
banner,
file: module,
format: 'es',
sourcemap: true
sourcemap: true,
})
export default {
input: 'src/index.js',
output,
plugins: [
peerDepsExternal(),
resolve({ modulesOnly: true }),
commonjs(),
json(),
]
plugins: [peerDepsExternal(), resolve({ modulesOnly: true }), commonjs(), json()],
}

View file

@ -42,18 +42,8 @@ export default function (part) {
}
// Shorthand call
let {
store,
sa,
points,
Path,
paths,
options,
measurements,
complete,
paperless,
macro,
} = part.shorthand()
let { store, sa, points, Path, paths, options, measurements, complete, paperless, macro } =
part.shorthand()
// Adapt bottom leg width based on heel & heel ease
let quarterHeel = (measurements.heel * (1 + options.heelEase) * options.legBalance) / 2

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
store,
sa,
Point,
points,
Path,
paths,
options,
complete,
paperless,
macro,
} = part.shorthand()
let { store, sa, Point, points, Path, paths, options, complete, paperless, macro } =
part.shorthand()
if (!options.elasticatedHem) {
part.render = false
return part

View file

@ -1,16 +1,6 @@
export default function (part) {
let {
sa,
Point,
points,
Path,
paths,
snippets,
options,
complete,
paperless,
macro,
} = part.shorthand()
let { sa, Point, points, Path, paths, snippets, options, complete, paperless, macro } =
part.shorthand()
// Don't bother of we're not drafting back pockets
if (!options.backPockets) {

View file

@ -1,17 +1,6 @@
export default function (part) {
let {
utils,
store,
sa,
Point,
points,
Path,
paths,
options,
complete,
paperless,
macro,
} = part.shorthand()
let { utils, store, sa, Point, points, Path, paths, options, complete, paperless, macro } =
part.shorthand()
points.topLeft = new Point(0, 0)
points.midLeft = new Point(0, options.waistbandWidth)

Some files were not shown because too many files have changed in this diff Show more