Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@dblatcher/funny-face

Package Overview
Dependencies
Maintainers
1
Versions
10
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@dblatcher/funny-face - npm Package Compare versions

Comparing version 0.1.8 to 0.2.0

src/lib/components/ExpressionDesigner.d.ts

306

index.esm.js

@@ -96,2 +96,21 @@ import 'core-js/modules/es.array.iterator.js';

};
const SUSPICIOUS = {
leftEye: {
browRaise: 15,
open: 0.5,
dilation: 0.8,
browTilt: 10
},
rightEye: {
browTilt: 11,
open: 0.45,
dilation: 0.8,
browRaise: -10
},
mouth: {
smile: -0.2,
pucker: 0.3,
open: 0
}
};
const NEUTRAL = {

@@ -108,3 +127,4 @@ leftEye: {},

HAPPY,
ASLEEP
ASLEEP,
SUSPICIOUS
};

@@ -291,2 +311,3 @@

}) => {
var _a;
return jsx(FeatureFrame, {

@@ -306,3 +327,3 @@ x: x,

stroke: 'black',
fill: profile.color,
fill: (_a = profile.color) !== null && _a !== void 0 ? _a : 'lightgray',
rx: 10,

@@ -899,3 +920,3 @@ ry: 20

transitionTime: transitionTime
}), accessories.map(accessory => jsx(HeadAccessory, {
}), accessories.map((accessory, index) => jsx(HeadAccessory, {
accessory: accessory,

@@ -905,3 +926,3 @@ faceProfile: profile,

transitionTime: transitionTime
})), jsx(FeatureFrame, {
}, index)), jsx(FeatureFrame, {
x: -50,

@@ -1263,2 +1284,234 @@ y: -50,

var monocle = "";
var moustache = "";
var hat = "";
const accessoryMap = {
HAT: {
src: hat,
x: 0,
y: -60,
width: 80
},
MONOCLE: {
src: monocle,
x: -14,
y: 20,
width: 64,
place: 'right-eye'
},
MONOCLE_BACKWARDS: {
src: monocle,
x: -14,
y: 20,
width: 64,
place: 'left-eye'
},
MOUSTACHE: {
src: moustache,
x: 0,
y: 0,
width: 64,
place: 'nose'
},
BEARD: {
src: moustache,
x: 0,
y: -10,
width: 32,
place: 'chin'
}
};
const EyeControls = ({
eye,
setEye
}) => {
var _a, _b, _c, _d;
return jsxs(Fragment, {
children: [jsx(NumberInput, {
label: "open",
value: (_a = eye.open) !== null && _a !== void 0 ? _a : 0.75,
type: "range",
step: .05,
min: 0,
max: 1,
inputHandler: value => {
setEye(Object.assign(Object.assign({}, eye), {
open: value
}));
}
}), jsx(NumberInput, {
label: "browTilt",
value: (_b = eye.browTilt) !== null && _b !== void 0 ? _b : 0.75,
type: "range",
step: 1,
min: 0,
max: 45,
inputHandler: value => {
setEye(Object.assign(Object.assign({}, eye), {
browTilt: value
}));
}
}), jsx(NumberInput, {
label: "browRaise",
value: (_c = eye.browRaise) !== null && _c !== void 0 ? _c : 0.75,
type: "range",
step: 1,
min: -20,
max: 20,
inputHandler: value => {
setEye(Object.assign(Object.assign({}, eye), {
browRaise: value
}));
}
}), jsx(NumberInput, {
label: "dilation",
value: (_d = eye.dilation) !== null && _d !== void 0 ? _d : 1,
type: "range",
step: .1,
min: 0,
max: 2,
inputHandler: value => {
setEye(Object.assign(Object.assign({}, eye), {
dilation: value
}));
}
})]
});
};
const MouthControls = ({
mouth,
setMouth
}) => {
var _a, _b, _c;
return jsxs(Fragment, {
children: [jsx(NumberInput, {
label: "open",
value: (_a = mouth.open) !== null && _a !== void 0 ? _a : 0,
type: "range",
step: .05,
min: 0,
max: 1,
inputHandler: value => {
setMouth(Object.assign(Object.assign({}, mouth), {
open: value
}));
}
}), jsx(NumberInput, {
label: "smile",
value: (_b = mouth.smile) !== null && _b !== void 0 ? _b : 0,
type: "range",
step: .05,
min: -1,
max: 1,
inputHandler: value => {
setMouth(Object.assign(Object.assign({}, mouth), {
smile: value
}));
}
}), jsx(NumberInput, {
label: "pucker",
value: (_c = mouth.pucker) !== null && _c !== void 0 ? _c : 0,
type: "range",
step: .05,
min: 0,
max: 1,
inputHandler: value => {
setMouth(Object.assign(Object.assign({}, mouth), {
pucker: value
}));
}
})]
});
};
const ExpressionDesigner = () => {
const [leftEye, setLeftEye] = useState({});
const [rightEye, setRightEye] = useState({});
const [mouth, setMouth] = useState({});
const expression = {
leftEye,
rightEye,
mouth
};
return jsxs("div", {
style: {
border: '1px dotted black',
margin: '1em',
display: 'flex'
},
children: [jsx(SvgFrame, {
style: {
width: '200px',
border: '1px solid black'
},
viewBox: "0 0 120 150",
children: jsx(FunnyFace, {
x: 20,
y: 50,
size: 80,
profile: {
browShape: browShapes.THIN
},
expression: expression,
talking: false,
followMouse: true,
accessories: []
})
}), jsxs("section", {
children: [jsx("h2", {
children: "expression designer"
}), jsxs("div", {
style: {
display: 'flex'
},
children: [jsxs("div", {
style: {
display: 'flex',
flexDirection: 'column'
},
children: [jsx("h3", {
children: "left eye"
}), jsx(EyeControls, {
eye: leftEye,
setEye: setLeftEye
})]
}), jsxs("div", {
style: {
display: 'flex',
flexDirection: 'column'
},
children: [jsx("h3", {
children: "right eye"
}), jsx(EyeControls, {
eye: rightEye,
setEye: setRightEye
})]
}), jsxs("div", {
style: {
display: 'flex',
flexDirection: 'column'
},
children: [jsx("h3", {
children: "Mouth"
}), jsx(MouthControls, {
mouth: mouth,
setMouth: setMouth
})]
})]
})]
}), jsx("section", {
children: jsx("textarea", {
style: {
height: '100%'
},
value: JSON.stringify(expression, undefined, 1),
rows: 20
})
})]
});
};
class FaceWithExpressionControl extends Component {

@@ -1314,45 +1567,2 @@ constructor(props) {

var monocle = "";
var moustache = "";
var hat = "";
const accessoryMap = {
HAT: {
src: hat,
x: 0,
y: -60,
width: 80
},
MONOCLE: {
src: monocle,
x: -14,
y: 20,
width: 64,
place: 'right-eye'
},
MONOCLE_BACKWARDS: {
src: monocle,
x: -14,
y: 20,
width: 64,
place: 'left-eye'
},
MOUSTACHE: {
src: moustache,
x: 0,
y: 0,
width: 64,
place: 'nose'
},
BEARD: {
src: moustache,
x: 0,
y: -10,
width: 32,
place: 'chin'
}
};
export { FaceWithExpressionControl, FunnyFace, SvgFrame, UIForFunnyFace, accessoryMap, browShapes, expressions, toothShapes };
export { ExpressionDesigner, FaceWithExpressionControl, FunnyFace, SvgFrame, UIForFunnyFace, accessoryMap, browShapes, expressions, toothShapes };

2

package.json
{
"name": "@dblatcher/funny-face",
"version": "0.1.8",
"version": "0.2.0",
"peerDependencies": {

@@ -5,0 +5,0 @@ "core-js": "3.33.0"

@@ -0,0 +0,0 @@ # funny-face-lib

export { UIForFunnyFace } from './lib/components/UIForFunnyFace';
export { ExpressionDesigner } from './lib/components/ExpressionDesigner';
export { FaceWithExpressionControl } from './lib/components/FaceWithExpressionControl';

@@ -3,0 +4,0 @@ export { FunnyFace } from './lib/components/FunnyFace';

@@ -9,2 +9,3 @@ import { FacialExpression } from '../types';

ASLEEP: FacialExpression;
SUSPICIOUS: FacialExpression;
};

@@ -33,5 +33,17 @@ export interface FaceProfile {

export interface EyeArrangement {
/**how open the eye is:
* - 0 (closed)
* - 0.75 (default)
* - 1 (wide open)
* */
open?: number;
/** angle in degrees of the eyebrow, 0 = horizontal */
browTilt?: number;
/** percentage increase in the Y position of the brow relative to the eye */
browRaise?: number;
/**how big the pupil is:
* - 0 (no pupil)
* - 1 (default)
* - 2 (pupil fills iris)
*/
dilation?: number;

@@ -38,0 +50,0 @@ }

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc