@pie-element/number-line 13.1.2-next.1 → 13.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.json +1247 -0
- package/CHANGELOG.md +2441 -0
- package/LICENSE.md +5 -0
- package/README.md +28 -0
- package/configure/CHANGELOG.json +827 -0
- package/configure/CHANGELOG.md +2088 -0
- package/configure/lib/arrows.js +89 -0
- package/configure/lib/arrows.js.map +1 -0
- package/configure/lib/card-bar.js +57 -0
- package/configure/lib/card-bar.js.map +1 -0
- package/configure/lib/defaults.js +177 -0
- package/configure/lib/defaults.js.map +1 -0
- package/configure/lib/domain.js +87 -0
- package/configure/lib/domain.js.map +1 -0
- package/configure/lib/index.js +176 -0
- package/configure/lib/index.js.map +1 -0
- package/configure/lib/main.js +815 -0
- package/configure/lib/main.js.map +1 -0
- package/configure/lib/number-text-field.js +26 -0
- package/configure/lib/number-text-field.js.map +1 -0
- package/configure/lib/point-config.js +84 -0
- package/configure/lib/point-config.js.map +1 -0
- package/configure/lib/size.js +66 -0
- package/configure/lib/size.js.map +1 -0
- package/configure/lib/ticks.js +234 -0
- package/configure/lib/ticks.js.map +1 -0
- package/configure/lib/utils.js +12 -0
- package/configure/lib/utils.js.map +1 -0
- package/configure/package.json +20 -0
- package/controller/CHANGELOG.json +332 -0
- package/controller/CHANGELOG.md +1360 -0
- package/controller/lib/defaults.js +56 -0
- package/controller/lib/defaults.js.map +1 -0
- package/controller/lib/index.js +430 -0
- package/controller/lib/index.js.map +1 -0
- package/controller/lib/tickUtils.js +294 -0
- package/controller/lib/tickUtils.js.map +1 -0
- package/controller/lib/utils.js +168 -0
- package/controller/lib/utils.js.map +1 -0
- package/controller/package.json +20 -0
- package/demo.gif +0 -0
- package/docs/config-schema.json +2532 -0
- package/docs/config-schema.json.md +1844 -0
- package/docs/demo/config.js +8 -0
- package/docs/demo/generate.js +39 -0
- package/docs/demo/index.html +1 -0
- package/docs/pie-schema.json +2461 -0
- package/docs/pie-schema.json.md +1228 -0
- package/docs/schemas/config.json +256 -0
- package/lib/data-converter.js +96 -0
- package/lib/data-converter.js.map +1 -0
- package/lib/draggable/index.js +114 -0
- package/lib/draggable/index.js.map +1 -0
- package/lib/index.js +196 -0
- package/lib/index.js.map +1 -0
- package/lib/number-line/colors.js +11 -0
- package/lib/number-line/colors.js.map +1 -0
- package/lib/number-line/feedback.js +92 -0
- package/lib/number-line/feedback.js.map +1 -0
- package/lib/number-line/graph/arrow.js +44 -0
- package/lib/number-line/graph/arrow.js.map +1 -0
- package/lib/number-line/graph/elements/base.js +20 -0
- package/lib/number-line/graph/elements/base.js.map +1 -0
- package/lib/number-line/graph/elements/builder.js +37 -0
- package/lib/number-line/graph/elements/builder.js.map +1 -0
- package/lib/number-line/graph/elements/line.js +259 -0
- package/lib/number-line/graph/elements/line.js.map +1 -0
- package/lib/number-line/graph/elements/point.js +204 -0
- package/lib/number-line/graph/elements/point.js.map +1 -0
- package/lib/number-line/graph/elements/ray.js +190 -0
- package/lib/number-line/graph/elements/ray.js.map +1 -0
- package/lib/number-line/graph/index.js +262 -0
- package/lib/number-line/graph/index.js.map +1 -0
- package/lib/number-line/graph/line.js +38 -0
- package/lib/number-line/graph/line.js.map +1 -0
- package/lib/number-line/graph/stacks.js +78 -0
- package/lib/number-line/graph/stacks.js.map +1 -0
- package/lib/number-line/graph/tick-utils.js +347 -0
- package/lib/number-line/graph/tick-utils.js.map +1 -0
- package/lib/number-line/graph/ticks.js +188 -0
- package/lib/number-line/graph/ticks.js.map +1 -0
- package/lib/number-line/index.js +384 -0
- package/lib/number-line/index.js.map +1 -0
- package/lib/number-line/point-chooser/button.js +49 -0
- package/lib/number-line/point-chooser/button.js.map +1 -0
- package/lib/number-line/point-chooser/img.js +8 -0
- package/lib/number-line/point-chooser/img.js.map +1 -0
- package/lib/number-line/point-chooser/index.js +197 -0
- package/lib/number-line/point-chooser/index.js.map +1 -0
- package/lib/number-line/point-chooser/styles.js +77 -0
- package/lib/number-line/point-chooser/styles.js.map +1 -0
- package/lib/number-line/transitions/fade.js +88 -0
- package/lib/number-line/transitions/fade.js.map +1 -0
- package/lib/number-line/transitions/index.js +14 -0
- package/lib/number-line/transitions/index.js.map +1 -0
- package/package.json +21 -87
- package/configure.js +0 -2
- package/controller.js +0 -1
- package/dist/_virtual/_rolldown/runtime.js +0 -11
- package/dist/author/arrows.d.ts +0 -28
- package/dist/author/arrows.js +0 -69
- package/dist/author/card-bar.d.ts +0 -20
- package/dist/author/card-bar.js +0 -41
- package/dist/author/defaults.d.ts +0 -178
- package/dist/author/defaults.js +0 -144
- package/dist/author/domain.d.ts +0 -15
- package/dist/author/domain.js +0 -54
- package/dist/author/index.d.ts +0 -23
- package/dist/author/index.js +0 -89
- package/dist/author/main.d.ts +0 -44
- package/dist/author/main.js +0 -485
- package/dist/author/number-text-field.d.ts +0 -13
- package/dist/author/number-text-field.js +0 -13
- package/dist/author/point-config.d.ts +0 -25
- package/dist/author/point-config.js +0 -69
- package/dist/author/size.d.ts +0 -24
- package/dist/author/size.js +0 -48
- package/dist/author/ticks.d.ts +0 -22
- package/dist/author/ticks.js +0 -115
- package/dist/author/utils.d.ts +0 -9
- package/dist/author/utils.js +0 -4
- package/dist/browser/author/index.js +0 -40259
- package/dist/browser/author/index.js.map +0 -1
- package/dist/browser/controller/index.js +0 -569
- package/dist/browser/controller/index.js.map +0 -1
- package/dist/browser/delivery/index.js +0 -2
- package/dist/browser/delivery-Ci_kZyOM.js +0 -17903
- package/dist/browser/delivery-Ci_kZyOM.js.map +0 -1
- package/dist/browser/dist-D5T-OaLo.js +0 -19038
- package/dist/browser/dist-D5T-OaLo.js.map +0 -1
- package/dist/browser/impureFunctionsAny.generated-Bqfato71.js +0 -10162
- package/dist/browser/impureFunctionsAny.generated-Bqfato71.js.map +0 -1
- package/dist/browser/number-line.css +0 -2
- package/dist/controller/defaults.d.ts +0 -58
- package/dist/controller/defaults.js +0 -50
- package/dist/controller/index.d.ts +0 -47
- package/dist/controller/index.js +0 -165
- package/dist/controller/tickUtils.d.ts +0 -21
- package/dist/controller/tickUtils.js +0 -252
- package/dist/controller/utils.d.ts +0 -9
- package/dist/controller/utils.js +0 -68
- package/dist/delivery/data-converter.d.ts +0 -64
- package/dist/delivery/data-converter.js +0 -70
- package/dist/delivery/draggable/index.d.ts +0 -33
- package/dist/delivery/draggable/index.js +0 -39
- package/dist/delivery/index.d.ts +0 -35
- package/dist/delivery/index.js +0 -109
- package/dist/delivery/number-line/colors.d.ts +0 -11
- package/dist/delivery/number-line/colors.js +0 -5
- package/dist/delivery/number-line/feedback.d.ts +0 -19
- package/dist/delivery/number-line/feedback.js +0 -57
- package/dist/delivery/number-line/graph/arrow.d.ts +0 -30
- package/dist/delivery/number-line/graph/arrow.js +0 -27
- package/dist/delivery/number-line/graph/elements/base.d.ts +0 -16
- package/dist/delivery/number-line/graph/elements/base.js +0 -11
- package/dist/delivery/number-line/graph/elements/builder.d.ts +0 -33
- package/dist/delivery/number-line/graph/elements/builder.js +0 -30
- package/dist/delivery/number-line/graph/elements/line.d.ts +0 -51
- package/dist/delivery/number-line/graph/elements/line.js +0 -188
- package/dist/delivery/number-line/graph/elements/point.d.ts +0 -43
- package/dist/delivery/number-line/graph/elements/point.js +0 -127
- package/dist/delivery/number-line/graph/elements/ray.d.ts +0 -43
- package/dist/delivery/number-line/graph/elements/ray.js +0 -130
- package/dist/delivery/number-line/graph/index.d.ts +0 -59
- package/dist/delivery/number-line/graph/index.js +0 -196
- package/dist/delivery/number-line/graph/line.d.ts +0 -46
- package/dist/delivery/number-line/graph/line.js +0 -27
- package/dist/delivery/number-line/graph/stacks.d.ts +0 -10
- package/dist/delivery/number-line/graph/stacks.js +0 -40
- package/dist/delivery/number-line/graph/tick-utils.d.ts +0 -80
- package/dist/delivery/number-line/graph/tick-utils.js +0 -295
- package/dist/delivery/number-line/graph/ticks.d.ts +0 -46
- package/dist/delivery/number-line/graph/ticks.js +0 -115
- package/dist/delivery/number-line/index.d.ts +0 -35
- package/dist/delivery/number-line/index.js +0 -215
- package/dist/delivery/number-line/point-chooser/button.d.ts +0 -31
- package/dist/delivery/number-line/point-chooser/button.js +0 -36
- package/dist/delivery/number-line/point-chooser/img.d.ts +0 -10
- package/dist/delivery/number-line/point-chooser/img.js +0 -4
- package/dist/delivery/number-line/point-chooser/index.d.ts +0 -37
- package/dist/delivery/number-line/point-chooser/index.js +0 -154
- package/dist/delivery/number-line/point-chooser/styles.d.ts +0 -192
- package/dist/delivery/number-line/transitions/fade.d.ts +0 -34
- package/dist/delivery/number-line/transitions/fade.js +0 -75
- package/dist/delivery/number-line/transitions/index.d.ts +0 -10
- package/dist/index.d.ts +0 -1
- package/dist/index.iife.d.ts +0 -8
- package/dist/index.iife.js +0 -197
- package/dist/index.js +0 -2
- package/dist/runtime-support.d.ts +0 -12
- package/dist/runtime-support.js +0 -12
package/lib/index.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","names":["_dataConverter","_interopRequireWildcard","require","dataConverter","exports","pointChooser","tickUtils","_graph","_interopRequireDefault","_numberLine","_react","_client","_lodashEs","_mathRendering","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","NumberLine","HTMLElement","constructor","_defineProperty2","_mathRenderPending","requestAnimationFrame","_mathObserver","disconnect","renderMath","setTimeout","observe","childList","subtree","characterData","_root","_initMathObserver","MutationObserver","_scheduleMathRender","_disconnectMathObserver","model","m","_model","_applyInitialElements","_render","dispatch","session","s","_session","connectedCallback","isComplete","answer","length","type","dispatchEvent","CustomEvent","bubbles","detail","complete","dispatchSessionChanged","addElement","data","push","toSessionFormat","moveElement","index","el","position","Error","left","right","update","lineIsSwitched","switchGraphLine","splice","deleteElements","indices","filter","v","some","d","undoElement","pop","clearElements","graph","initialElements","cloneDeep","map","toGraphFormat","correctResponse","props","onAddElement","bind","onMoveElement","onDeleteElements","onUndoElement","onClearElements","React","createElement","RootComponent","createRoot","render","disconnectedCallback","unmount"],"sources":["../src/index.js"],"sourcesContent":["import * as dataConverter from './data-converter';\nimport * as pointChooser from './number-line/point-chooser';\nimport * as tickUtils from './number-line/graph/tick-utils';\n\nimport { lineIsSwitched, switchGraphLine, toGraphFormat, toSessionFormat } from './data-converter';\n\nimport Graph from './number-line/graph';\nimport NumberLineComponent from './number-line';\nimport React from 'react';\nimport { createRoot } from 'react-dom/client';\nimport RootComponent from './number-line';\nimport { cloneDeep } from 'lodash-es';\nimport { renderMath } from '@pie-lib/math-rendering';\n\n//Expose some additional modules for configuration\nexport { Graph, NumberLineComponent, tickUtils, dataConverter, pointChooser };\nexport default class NumberLine extends HTMLElement {\n constructor() {\n super();\n this._root = null;\n this._mathObserver = null;\n this._mathRenderPending = false;\n }\n\n _scheduleMathRender = () => {\n if (this._mathRenderPending) return;\n this._mathRenderPending = true;\n\n requestAnimationFrame(() => {\n if (this._mathObserver) {\n this._mathObserver.disconnect();\n }\n\n renderMath(this);\n this._mathRenderPending = false;\n\n setTimeout(() => {\n if (this._mathObserver) {\n this._mathObserver.observe(this, {\n childList: true,\n subtree: true,\n characterData: false,\n });\n }\n }, 50);\n });\n };\n\n _initMathObserver() {\n if (this._mathObserver) return;\n\n this._mathObserver = new MutationObserver(() => {\n this._scheduleMathRender();\n });\n\n this._mathObserver.observe(this, {\n childList: true,\n subtree: true,\n characterData: false,\n });\n }\n\n _disconnectMathObserver() {\n if (this._mathObserver) {\n this._mathObserver.disconnect();\n this._mathObserver = null;\n }\n }\n\n set model(m) {\n this._model = m;\n this._applyInitialElements();\n this._render();\n this.dispatch('model-set');\n }\n\n set session(s) {\n this._session = s;\n this._applyInitialElements();\n this._render();\n }\n\n get session() {\n return this._session;\n }\n\n connectedCallback() {\n this._initMathObserver();\n this._render();\n }\n\n isComplete() {\n return this._session ? (this._session.answer || []).length > 0 : false;\n }\n\n dispatch(type) {\n this.dispatchEvent(\n new CustomEvent(type, {\n bubbles: true,\n detail: {\n complete: this.isComplete(),\n },\n }),\n );\n }\n\n dispatchSessionChanged() {\n this.dispatch('session-changed');\n }\n\n addElement(data) {\n if (!this._session) {\n return;\n }\n\n this._session.answer = this._session.answer || [];\n this._session.answer.push(toSessionFormat(data));\n this.dispatchSessionChanged();\n this._render();\n }\n\n moveElement(index, el, position) {\n let answer = this._session.answer[index];\n\n if (!answer) {\n throw new Error('cant find element at index: ', index);\n }\n\n if (el.type === 'line' && position.left === position.right) {\n this._render();\n return;\n }\n\n //set the new position\n el.position = position;\n\n let update = el.type === 'line' && lineIsSwitched(el) ? switchGraphLine(el) : el;\n\n this._session.answer.splice(index, 1, toSessionFormat(update));\n\n this.dispatchSessionChanged();\n this._render();\n }\n\n deleteElements(indices) {\n this._session.answer = this._session.answer.filter((v, index) => {\n return !indices.some((d) => d === index);\n });\n this.dispatchSessionChanged();\n this._render();\n }\n\n undoElement() {\n this._session.answer.pop();\n this.dispatchSessionChanged();\n this._render();\n }\n\n clearElements() {\n this._session.answer = [];\n this.dispatchSessionChanged();\n this._render();\n }\n\n _applyInitialElements() {\n if (\n this._model &&\n this._model.graph &&\n this._model.graph.initialElements &&\n this._session &&\n (!this._session.answer || !this._session.answer.length)\n ) {\n this._session.answer = cloneDeep(this._model.graph.initialElements);\n }\n }\n\n _render() {\n if (this._model && this._session) {\n if (!this._session.answer) {\n this._applyInitialElements();\n }\n\n let answer = (this._session.answer || []).map(toGraphFormat);\n let model = cloneDeep(this._model);\n model.correctResponse = model.correctResponse && model.correctResponse.map(toGraphFormat);\n\n let props = {\n model,\n answer,\n onAddElement: this.addElement.bind(this),\n onMoveElement: this.moveElement.bind(this),\n onDeleteElements: this.deleteElements.bind(this),\n onUndoElement: this.undoElement.bind(this),\n onClearElements: this.clearElements.bind(this),\n };\n\n let el = React.createElement(RootComponent, props);\n\n if (!this._root) {\n this._root = createRoot(this);\n }\n this._root.render(el);\n\n // schedule math rendering via observer pipeline (for initial render as well)\n this._scheduleMathRender();\n }\n }\n\n disconnectedCallback() {\n this._disconnectMathObserver();\n if (this._root) {\n this._root.unmount();\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA,IAAAA,cAAA,GAAAC,uBAAA,CAAAC,OAAA;AAAkD,IAAAC,aAAA,GAAAH,cAAA;AAAAI,OAAA,CAAAD,aAAA,GAAAH,cAAA;AAClD,IAAAK,YAAA,GAAAJ,uBAAA,CAAAC,OAAA;AAA4DE,OAAA,CAAAC,YAAA,GAAAA,YAAA;AAC5D,IAAAC,SAAA,GAAAL,uBAAA,CAAAC,OAAA;AAA4DE,OAAA,CAAAE,SAAA,GAAAA,SAAA;AAI5D,IAAAC,MAAA,GAAAC,sBAAA,CAAAN,OAAA;AACA,IAAAO,WAAA,GAAAD,sBAAA,CAAAN,OAAA;AACA,IAAAQ,MAAA,GAAAF,sBAAA,CAAAN,OAAA;AACA,IAAAS,OAAA,GAAAT,OAAA;AAEA,IAAAU,SAAA,GAAAV,OAAA;AACA,IAAAW,cAAA,GAAAX,OAAA;AAAqD,SAAAD,wBAAAa,CAAA,EAAAC,CAAA,6BAAAC,OAAA,MAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAf,uBAAA,YAAAA,CAAAa,CAAA,EAAAC,CAAA,SAAAA,CAAA,IAAAD,CAAA,IAAAA,CAAA,CAAAK,UAAA,SAAAL,CAAA,MAAAM,CAAA,EAAAC,CAAA,EAAAC,CAAA,KAAAC,SAAA,QAAAC,OAAA,EAAAV,CAAA,iBAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,SAAAQ,CAAA,MAAAF,CAAA,GAAAL,CAAA,GAAAG,CAAA,GAAAD,CAAA,QAAAG,CAAA,CAAAK,GAAA,CAAAX,CAAA,UAAAM,CAAA,CAAAM,GAAA,CAAAZ,CAAA,GAAAM,CAAA,CAAAO,GAAA,CAAAb,CAAA,EAAAQ,CAAA,gBAAAP,CAAA,IAAAD,CAAA,gBAAAC,CAAA,OAAAa,cAAA,CAAAC,IAAA,CAAAf,CAAA,EAAAC,CAAA,OAAAM,CAAA,IAAAD,CAAA,GAAAU,MAAA,CAAAC,cAAA,KAAAD,MAAA,CAAAE,wBAAA,CAAAlB,CAAA,EAAAC,CAAA,OAAAM,CAAA,CAAAK,GAAA,IAAAL,CAAA,CAAAM,GAAA,IAAAP,CAAA,CAAAE,CAAA,EAAAP,CAAA,EAAAM,CAAA,IAAAC,CAAA,CAAAP,CAAA,IAAAD,CAAA,CAAAC,CAAA,WAAAO,CAAA,KAAAR,CAAA,EAAAC,CAAA;AAErD;;AAEe,MAAMkB,UAAU,SAASC,WAAW,CAAC;EAClDC,WAAWA,CAAA,EAAG;IACZ,KAAK,CAAC,CAAC;IAAC,IAAAC,gBAAA,CAAAZ,OAAA,+BAMY,MAAM;MAC1B,IAAI,IAAI,CAACa,kBAAkB,EAAE;MAC7B,IAAI,CAACA,kBAAkB,GAAG,IAAI;MAE9BC,qBAAqB,CAAC,MAAM;QAC1B,IAAI,IAAI,CAACC,aAAa,EAAE;UACtB,IAAI,CAACA,aAAa,CAACC,UAAU,CAAC,CAAC;QACjC;QAEA,IAAAC,yBAAU,EAAC,IAAI,CAAC;QAChB,IAAI,CAACJ,kBAAkB,GAAG,KAAK;QAE/BK,UAAU,CAAC,MAAM;UACf,IAAI,IAAI,CAACH,aAAa,EAAE;YACtB,IAAI,CAACA,aAAa,CAACI,OAAO,CAAC,IAAI,EAAE;cAC/BC,SAAS,EAAE,IAAI;cACfC,OAAO,EAAE,IAAI;cACbC,aAAa,EAAE;YACjB,CAAC,CAAC;UACJ;QACF,CAAC,EAAE,EAAE,CAAC;MACR,CAAC,CAAC;IACJ,CAAC;IA3BC,IAAI,CAACC,KAAK,GAAG,IAAI;IACjB,IAAI,CAACR,aAAa,GAAG,IAAI;IACzB,IAAI,CAACF,kBAAkB,GAAG,KAAK;EACjC;EA0BAW,iBAAiBA,CAAA,EAAG;IAClB,IAAI,IAAI,CAACT,aAAa,EAAE;IAExB,IAAI,CAACA,aAAa,GAAG,IAAIU,gBAAgB,CAAC,MAAM;MAC9C,IAAI,CAACC,mBAAmB,CAAC,CAAC;IAC5B,CAAC,CAAC;IAEF,IAAI,CAACX,aAAa,CAACI,OAAO,CAAC,IAAI,EAAE;MAC/BC,SAAS,EAAE,IAAI;MACfC,OAAO,EAAE,IAAI;MACbC,aAAa,EAAE;IACjB,CAAC,CAAC;EACJ;EAEAK,uBAAuBA,CAAA,EAAG;IACxB,IAAI,IAAI,CAACZ,aAAa,EAAE;MACtB,IAAI,CAACA,aAAa,CAACC,UAAU,CAAC,CAAC;MAC/B,IAAI,CAACD,aAAa,GAAG,IAAI;IAC3B;EACF;EAEA,IAAIa,KAAKA,CAACC,CAAC,EAAE;IACX,IAAI,CAACC,MAAM,GAAGD,CAAC;IACf,IAAI,CAACE,qBAAqB,CAAC,CAAC;IAC5B,IAAI,CAACC,OAAO,CAAC,CAAC;IACd,IAAI,CAACC,QAAQ,CAAC,WAAW,CAAC;EAC5B;EAEA,IAAIC,OAAOA,CAACC,CAAC,EAAE;IACb,IAAI,CAACC,QAAQ,GAAGD,CAAC;IACjB,IAAI,CAACJ,qBAAqB,CAAC,CAAC;IAC5B,IAAI,CAACC,OAAO,CAAC,CAAC;EAChB;EAEA,IAAIE,OAAOA,CAAA,EAAG;IACZ,OAAO,IAAI,CAACE,QAAQ;EACtB;EAEAC,iBAAiBA,CAAA,EAAG;IAClB,IAAI,CAACb,iBAAiB,CAAC,CAAC;IACxB,IAAI,CAACQ,OAAO,CAAC,CAAC;EAChB;EAEAM,UAAUA,CAAA,EAAG;IACX,OAAO,IAAI,CAACF,QAAQ,GAAG,CAAC,IAAI,CAACA,QAAQ,CAACG,MAAM,IAAI,EAAE,EAAEC,MAAM,GAAG,CAAC,GAAG,KAAK;EACxE;EAEAP,QAAQA,CAACQ,IAAI,EAAE;IACb,IAAI,CAACC,aAAa,CAChB,IAAIC,WAAW,CAACF,IAAI,EAAE;MACpBG,OAAO,EAAE,IAAI;MACbC,MAAM,EAAE;QACNC,QAAQ,EAAE,IAAI,CAACR,UAAU,CAAC;MAC5B;IACF,CAAC,CACH,CAAC;EACH;EAEAS,sBAAsBA,CAAA,EAAG;IACvB,IAAI,CAACd,QAAQ,CAAC,iBAAiB,CAAC;EAClC;EAEAe,UAAUA,CAACC,IAAI,EAAE;IACf,IAAI,CAAC,IAAI,CAACb,QAAQ,EAAE;MAClB;IACF;IAEA,IAAI,CAACA,QAAQ,CAACG,MAAM,GAAG,IAAI,CAACH,QAAQ,CAACG,MAAM,IAAI,EAAE;IACjD,IAAI,CAACH,QAAQ,CAACG,MAAM,CAACW,IAAI,CAAC,IAAAC,8BAAe,EAACF,IAAI,CAAC,CAAC;IAChD,IAAI,CAACF,sBAAsB,CAAC,CAAC;IAC7B,IAAI,CAACf,OAAO,CAAC,CAAC;EAChB;EAEAoB,WAAWA,CAACC,KAAK,EAAEC,EAAE,EAAEC,QAAQ,EAAE;IAC/B,IAAIhB,MAAM,GAAG,IAAI,CAACH,QAAQ,CAACG,MAAM,CAACc,KAAK,CAAC;IAExC,IAAI,CAACd,MAAM,EAAE;MACX,MAAM,IAAIiB,KAAK,CAAC,8BAA8B,EAAEH,KAAK,CAAC;IACxD;IAEA,IAAIC,EAAE,CAACb,IAAI,KAAK,MAAM,IAAIc,QAAQ,CAACE,IAAI,KAAKF,QAAQ,CAACG,KAAK,EAAE;MAC1D,IAAI,CAAC1B,OAAO,CAAC,CAAC;MACd;IACF;;IAEA;IACAsB,EAAE,CAACC,QAAQ,GAAGA,QAAQ;IAEtB,IAAII,MAAM,GAAGL,EAAE,CAACb,IAAI,KAAK,MAAM,IAAI,IAAAmB,6BAAc,EAACN,EAAE,CAAC,GAAG,IAAAO,8BAAe,EAACP,EAAE,CAAC,GAAGA,EAAE;IAEhF,IAAI,CAAClB,QAAQ,CAACG,MAAM,CAACuB,MAAM,CAACT,KAAK,EAAE,CAAC,EAAE,IAAAF,8BAAe,EAACQ,MAAM,CAAC,CAAC;IAE9D,IAAI,CAACZ,sBAAsB,CAAC,CAAC;IAC7B,IAAI,CAACf,OAAO,CAAC,CAAC;EAChB;EAEA+B,cAAcA,CAACC,OAAO,EAAE;IACtB,IAAI,CAAC5B,QAAQ,CAACG,MAAM,GAAG,IAAI,CAACH,QAAQ,CAACG,MAAM,CAAC0B,MAAM,CAAC,CAACC,CAAC,EAAEb,KAAK,KAAK;MAC/D,OAAO,CAACW,OAAO,CAACG,IAAI,CAAEC,CAAC,IAAKA,CAAC,KAAKf,KAAK,CAAC;IAC1C,CAAC,CAAC;IACF,IAAI,CAACN,sBAAsB,CAAC,CAAC;IAC7B,IAAI,CAACf,OAAO,CAAC,CAAC;EAChB;EAEAqC,WAAWA,CAAA,EAAG;IACZ,IAAI,CAACjC,QAAQ,CAACG,MAAM,CAAC+B,GAAG,CAAC,CAAC;IAC1B,IAAI,CAACvB,sBAAsB,CAAC,CAAC;IAC7B,IAAI,CAACf,OAAO,CAAC,CAAC;EAChB;EAEAuC,aAAaA,CAAA,EAAG;IACd,IAAI,CAACnC,QAAQ,CAACG,MAAM,GAAG,EAAE;IACzB,IAAI,CAACQ,sBAAsB,CAAC,CAAC;IAC7B,IAAI,CAACf,OAAO,CAAC,CAAC;EAChB;EAEAD,qBAAqBA,CAAA,EAAG;IACtB,IACE,IAAI,CAACD,MAAM,IACX,IAAI,CAACA,MAAM,CAAC0C,KAAK,IACjB,IAAI,CAAC1C,MAAM,CAAC0C,KAAK,CAACC,eAAe,IACjC,IAAI,CAACrC,QAAQ,KACZ,CAAC,IAAI,CAACA,QAAQ,CAACG,MAAM,IAAI,CAAC,IAAI,CAACH,QAAQ,CAACG,MAAM,CAACC,MAAM,CAAC,EACvD;MACA,IAAI,CAACJ,QAAQ,CAACG,MAAM,GAAG,IAAAmC,mBAAS,EAAC,IAAI,CAAC5C,MAAM,CAAC0C,KAAK,CAACC,eAAe,CAAC;IACrE;EACF;EAEAzC,OAAOA,CAAA,EAAG;IACR,IAAI,IAAI,CAACF,MAAM,IAAI,IAAI,CAACM,QAAQ,EAAE;MAChC,IAAI,CAAC,IAAI,CAACA,QAAQ,CAACG,MAAM,EAAE;QACzB,IAAI,CAACR,qBAAqB,CAAC,CAAC;MAC9B;MAEA,IAAIQ,MAAM,GAAG,CAAC,IAAI,CAACH,QAAQ,CAACG,MAAM,IAAI,EAAE,EAAEoC,GAAG,CAACC,4BAAa,CAAC;MAC5D,IAAIhD,KAAK,GAAG,IAAA8C,mBAAS,EAAC,IAAI,CAAC5C,MAAM,CAAC;MAClCF,KAAK,CAACiD,eAAe,GAAGjD,KAAK,CAACiD,eAAe,IAAIjD,KAAK,CAACiD,eAAe,CAACF,GAAG,CAACC,4BAAa,CAAC;MAEzF,IAAIE,KAAK,GAAG;QACVlD,KAAK;QACLW,MAAM;QACNwC,YAAY,EAAE,IAAI,CAAC/B,UAAU,CAACgC,IAAI,CAAC,IAAI,CAAC;QACxCC,aAAa,EAAE,IAAI,CAAC7B,WAAW,CAAC4B,IAAI,CAAC,IAAI,CAAC;QAC1CE,gBAAgB,EAAE,IAAI,CAACnB,cAAc,CAACiB,IAAI,CAAC,IAAI,CAAC;QAChDG,aAAa,EAAE,IAAI,CAACd,WAAW,CAACW,IAAI,CAAC,IAAI,CAAC;QAC1CI,eAAe,EAAE,IAAI,CAACb,aAAa,CAACS,IAAI,CAAC,IAAI;MAC/C,CAAC;MAED,IAAI1B,EAAE,gBAAG+B,cAAK,CAACC,aAAa,CAACC,mBAAa,EAAET,KAAK,CAAC;MAElD,IAAI,CAAC,IAAI,CAACvD,KAAK,EAAE;QACf,IAAI,CAACA,KAAK,GAAG,IAAAiE,kBAAU,EAAC,IAAI,CAAC;MAC/B;MACA,IAAI,CAACjE,KAAK,CAACkE,MAAM,CAACnC,EAAE,CAAC;;MAErB;MACA,IAAI,CAAC5B,mBAAmB,CAAC,CAAC;IAC5B;EACF;EAEAgE,oBAAoBA,CAAA,EAAG;IACrB,IAAI,CAAC/D,uBAAuB,CAAC,CAAC;IAC9B,IAAI,IAAI,CAACJ,KAAK,EAAE;MACd,IAAI,CAACA,KAAK,CAACoE,OAAO,CAAC,CAAC;IACtB;EACF;AACF;AAAC/G,OAAA,CAAAoB,OAAA,GAAAS,UAAA","ignoreList":[]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.selected = exports.incorrect = exports.correct = void 0;
|
|
7
|
+
var _renderUi = require("@pie-lib/render-ui");
|
|
8
|
+
const selected = exports.selected = _renderUi.color.primaryDark();
|
|
9
|
+
const correct = exports.correct = _renderUi.color.correct();
|
|
10
|
+
const incorrect = exports.incorrect = _renderUi.color.incorrect();
|
|
11
|
+
//# sourceMappingURL=colors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"colors.js","names":["_renderUi","require","selected","exports","color","primaryDark","correct","incorrect"],"sources":["../../src/number-line/colors.js"],"sourcesContent":["import { color } from '@pie-lib/render-ui';\n\nexport const selected = color.primaryDark();\nexport const correct = color.correct();\nexport const incorrect = color.incorrect();\n"],"mappings":";;;;;;AAAA,IAAAA,SAAA,GAAAC,OAAA;AAEO,MAAMC,QAAQ,GAAAC,OAAA,CAAAD,QAAA,GAAGE,eAAK,CAACC,WAAW,CAAC,CAAC;AACpC,MAAMC,OAAO,GAAAH,OAAA,CAAAG,OAAA,GAAGF,eAAK,CAACE,OAAO,CAAC,CAAC;AAC/B,MAAMC,SAAS,GAAAJ,OAAA,CAAAI,SAAA,GAAGH,eAAK,CAACG,SAAS,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = void 0;
|
|
8
|
+
var _icons = require("@pie-lib/icons");
|
|
9
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
10
|
+
var _renderUi = require("@pie-lib/render-ui");
|
|
11
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
12
|
+
var _reactTransitionGroup = require("react-transition-group");
|
|
13
|
+
var _styles = require("@mui/material/styles");
|
|
14
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
|
|
15
|
+
let getIcon = t => {
|
|
16
|
+
switch (t) {
|
|
17
|
+
case 'unanswered':
|
|
18
|
+
return _icons.NothingSubmitted;
|
|
19
|
+
case 'correct':
|
|
20
|
+
return _icons.Correct;
|
|
21
|
+
case 'incorrect':
|
|
22
|
+
return _icons.Incorrect;
|
|
23
|
+
case 'partial':
|
|
24
|
+
return _icons.PartiallyCorrect;
|
|
25
|
+
case 'info':
|
|
26
|
+
return _icons.ShowRationale;
|
|
27
|
+
default:
|
|
28
|
+
return undefined;
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
const FeedbackContainer = (0, _styles.styled)('div')(({
|
|
32
|
+
$type
|
|
33
|
+
}) => ({
|
|
34
|
+
marginTop: '10px',
|
|
35
|
+
backgroundColor: '#dddddd',
|
|
36
|
+
padding: '10px',
|
|
37
|
+
display: 'flex',
|
|
38
|
+
alignItems: 'center',
|
|
39
|
+
...($type === 'correct' && {
|
|
40
|
+
backgroundColor: _renderUi.color.correct()
|
|
41
|
+
}),
|
|
42
|
+
...($type === 'incorrect' && {
|
|
43
|
+
backgroundColor: _renderUi.color.incorrect()
|
|
44
|
+
}),
|
|
45
|
+
'& svg': {
|
|
46
|
+
height: '30px'
|
|
47
|
+
},
|
|
48
|
+
'& h1': {
|
|
49
|
+
padding: '0px',
|
|
50
|
+
margin: '0px'
|
|
51
|
+
}
|
|
52
|
+
}));
|
|
53
|
+
const Message = (0, _styles.styled)('span')({
|
|
54
|
+
paddingLeft: '5px',
|
|
55
|
+
userSelect: 'none'
|
|
56
|
+
});
|
|
57
|
+
const Feedback = props => {
|
|
58
|
+
const {
|
|
59
|
+
type,
|
|
60
|
+
width,
|
|
61
|
+
message
|
|
62
|
+
} = props;
|
|
63
|
+
let Icon = getIcon(type);
|
|
64
|
+
const nodeRef = (0, _react.useRef)(null);
|
|
65
|
+
return /*#__PURE__*/_react.default.createElement(_reactTransitionGroup.TransitionGroup, null, /*#__PURE__*/_react.default.createElement(_reactTransitionGroup.CSSTransition, {
|
|
66
|
+
classNames: 'fb',
|
|
67
|
+
key: "fb",
|
|
68
|
+
timeout: 300,
|
|
69
|
+
nodeRef: nodeRef
|
|
70
|
+
}, /*#__PURE__*/_react.default.createElement(FeedbackContainer, {
|
|
71
|
+
ref: nodeRef,
|
|
72
|
+
key: "panel",
|
|
73
|
+
$type: type,
|
|
74
|
+
style: {
|
|
75
|
+
width
|
|
76
|
+
}
|
|
77
|
+
}, /*#__PURE__*/_react.default.createElement(Icon, {
|
|
78
|
+
iconSet: "emoji",
|
|
79
|
+
shape: "square"
|
|
80
|
+
}), /*#__PURE__*/_react.default.createElement(Message, {
|
|
81
|
+
dangerouslySetInnerHTML: {
|
|
82
|
+
__html: message
|
|
83
|
+
}
|
|
84
|
+
}))));
|
|
85
|
+
};
|
|
86
|
+
Feedback.propTypes = {
|
|
87
|
+
width: _propTypes.default.number,
|
|
88
|
+
message: _propTypes.default.string,
|
|
89
|
+
type: _propTypes.default.string
|
|
90
|
+
};
|
|
91
|
+
var _default = exports.default = Feedback;
|
|
92
|
+
//# sourceMappingURL=feedback.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"feedback.js","names":["_icons","require","_propTypes","_interopRequireDefault","_renderUi","_react","_interopRequireWildcard","_reactTransitionGroup","_styles","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","getIcon","NothingSubmitted","Correct","Incorrect","PartiallyCorrect","ShowRationale","undefined","FeedbackContainer","styled","$type","marginTop","backgroundColor","padding","display","alignItems","color","correct","incorrect","height","margin","Message","paddingLeft","userSelect","Feedback","props","type","width","message","Icon","nodeRef","useRef","createElement","TransitionGroup","CSSTransition","classNames","key","timeout","ref","style","iconSet","shape","dangerouslySetInnerHTML","__html","propTypes","PropTypes","number","string","_default","exports"],"sources":["../../src/number-line/feedback.jsx"],"sourcesContent":["import { Correct, Incorrect, NothingSubmitted, PartiallyCorrect, ShowRationale } from '@pie-lib/icons';\nimport PropTypes from 'prop-types';\nimport { color } from '@pie-lib/render-ui';\n\nimport React, { useRef } from 'react';\nimport { TransitionGroup, CSSTransition } from 'react-transition-group';\nimport { styled } from '@mui/material/styles';\n\nlet getIcon = (t) => {\n switch (t) {\n case 'unanswered':\n return NothingSubmitted;\n case 'correct':\n return Correct;\n case 'incorrect':\n return Incorrect;\n case 'partial':\n return PartiallyCorrect;\n case 'info':\n return ShowRationale;\n default:\n return undefined;\n }\n};\n\nconst FeedbackContainer = styled('div')(({ $type }) => ({\n marginTop: '10px',\n backgroundColor: '#dddddd',\n padding: '10px',\n display: 'flex',\n alignItems: 'center',\n ...($type === 'correct' && {\n backgroundColor: color.correct(),\n }),\n ...($type === 'incorrect' && {\n backgroundColor: color.incorrect(),\n }),\n '& svg': {\n height: '30px',\n },\n '& h1': {\n padding: '0px',\n margin: '0px',\n },\n}));\n\nconst Message = styled('span')({\n paddingLeft: '5px',\n userSelect: 'none',\n});\n\nconst Feedback = (props) => {\n const { type, width, message } = props;\n let Icon = getIcon(type);\n const nodeRef = useRef(null);\n\n return (\n <TransitionGroup>\n <CSSTransition classNames={'fb'} key=\"fb\" timeout={300} nodeRef={nodeRef}>\n <FeedbackContainer ref={nodeRef} key=\"panel\" $type={type} style={{ width }}>\n <Icon iconSet=\"emoji\" shape=\"square\" />\n <Message dangerouslySetInnerHTML={{ __html: message }} />\n </FeedbackContainer>\n </CSSTransition>\n </TransitionGroup>\n );\n};\n\nFeedback.propTypes = {\n width: PropTypes.number,\n message: PropTypes.string,\n type: PropTypes.string,\n};\n\nexport default Feedback;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.Arrow = Arrow;
|
|
8
|
+
exports.default = void 0;
|
|
9
|
+
var _react = _interopRequireDefault(require("react"));
|
|
10
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
11
|
+
var _styles = require("@mui/material/styles");
|
|
12
|
+
var _renderUi = require("@pie-lib/render-ui");
|
|
13
|
+
const StyledPath = (0, _styles.styled)('path')({
|
|
14
|
+
fill: _renderUi.color.primary()
|
|
15
|
+
});
|
|
16
|
+
function Arrow({
|
|
17
|
+
x,
|
|
18
|
+
y,
|
|
19
|
+
direction,
|
|
20
|
+
className
|
|
21
|
+
}) {
|
|
22
|
+
let transform = `translate(${x || 0},${y})`;
|
|
23
|
+
if (direction && direction === 'right') {
|
|
24
|
+
transform += ' rotate(180)';
|
|
25
|
+
}
|
|
26
|
+
return /*#__PURE__*/_react.default.createElement(StyledPath, {
|
|
27
|
+
d: "m 0,0 8,-5 0,10 -8,-5",
|
|
28
|
+
transform: transform,
|
|
29
|
+
className: className
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
Arrow.propTypes = {
|
|
33
|
+
y: _propTypes.default.number,
|
|
34
|
+
x: _propTypes.default.number,
|
|
35
|
+
direction: _propTypes.default.oneOf(['left', 'right']),
|
|
36
|
+
className: _propTypes.default.string
|
|
37
|
+
};
|
|
38
|
+
Arrow.defaultProps = {
|
|
39
|
+
y: 0,
|
|
40
|
+
x: 0,
|
|
41
|
+
direction: 'left'
|
|
42
|
+
};
|
|
43
|
+
var _default = exports.default = Arrow;
|
|
44
|
+
//# sourceMappingURL=arrow.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"arrow.js","names":["_react","_interopRequireDefault","require","_propTypes","_styles","_renderUi","StyledPath","styled","fill","color","primary","Arrow","x","y","direction","className","transform","default","createElement","d","propTypes","PropTypes","number","oneOf","string","defaultProps","_default","exports"],"sources":["../../../src/number-line/graph/arrow.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { styled } from '@mui/material/styles';\nimport { color } from '@pie-lib/render-ui';\n\nconst StyledPath = styled('path')({\n fill: color.primary(),\n});\n\nexport function Arrow({ x, y, direction, className }) {\n let transform = `translate(${x || 0},${y})`;\n\n if (direction && direction === 'right') {\n transform += ' rotate(180)';\n }\n\n return <StyledPath d=\"m 0,0 8,-5 0,10 -8,-5\" transform={transform} className={className} />;\n}\n\nArrow.propTypes = {\n y: PropTypes.number,\n x: PropTypes.number,\n direction: PropTypes.oneOf(['left', 'right']),\n className: PropTypes.string,\n};\n\nArrow.defaultProps = {\n y: 0,\n x: 0,\n direction: 'left',\n};\n\nexport default Arrow;\n"],"mappings":";;;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,UAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,OAAA,GAAAF,OAAA;AACA,IAAAG,SAAA,GAAAH,OAAA;AAEA,MAAMI,UAAU,GAAG,IAAAC,cAAM,EAAC,MAAM,CAAC,CAAC;EAChCC,IAAI,EAAEC,eAAK,CAACC,OAAO,CAAC;AACtB,CAAC,CAAC;AAEK,SAASC,KAAKA,CAAC;EAAEC,CAAC;EAAEC,CAAC;EAAEC,SAAS;EAAEC;AAAU,CAAC,EAAE;EACpD,IAAIC,SAAS,GAAG,aAAaJ,CAAC,IAAI,CAAC,IAAIC,CAAC,GAAG;EAE3C,IAAIC,SAAS,IAAIA,SAAS,KAAK,OAAO,EAAE;IACtCE,SAAS,IAAI,cAAc;EAC7B;EAEA,oBAAOhB,MAAA,CAAAiB,OAAA,CAAAC,aAAA,CAACZ,UAAU;IAACa,CAAC,EAAC,uBAAuB;IAACH,SAAS,EAAEA,SAAU;IAACD,SAAS,EAAEA;EAAU,CAAE,CAAC;AAC7F;AAEAJ,KAAK,CAACS,SAAS,GAAG;EAChBP,CAAC,EAAEQ,kBAAS,CAACC,MAAM;EACnBV,CAAC,EAAES,kBAAS,CAACC,MAAM;EACnBR,SAAS,EAAEO,kBAAS,CAACE,KAAK,CAAC,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;EAC7CR,SAAS,EAAEM,kBAAS,CAACG;AACvB,CAAC;AAEDb,KAAK,CAACc,YAAY,GAAG;EACnBZ,CAAC,EAAE,CAAC;EACJD,CAAC,EAAE,CAAC;EACJE,SAAS,EAAE;AACb,CAAC;AAAC,IAAAY,QAAA,GAAAC,OAAA,CAAAV,OAAA,GAEaN,KAAK","ignoreList":[]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.basePropTypes = void 0;
|
|
8
|
+
var _react = _interopRequireDefault(require("react"));
|
|
9
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
10
|
+
//eslint-disable-line
|
|
11
|
+
|
|
12
|
+
const basePropTypes = () => ({
|
|
13
|
+
interval: _propTypes.default.number.isRequired,
|
|
14
|
+
domain: _propTypes.default.shape({
|
|
15
|
+
min: _propTypes.default.number.isRequired,
|
|
16
|
+
max: _propTypes.default.number.isRequired
|
|
17
|
+
})
|
|
18
|
+
});
|
|
19
|
+
exports.basePropTypes = basePropTypes;
|
|
20
|
+
//# sourceMappingURL=base.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base.js","names":["_react","_interopRequireDefault","require","_propTypes","basePropTypes","interval","PropTypes","number","isRequired","domain","shape","min","max","exports"],"sources":["../../../../src/number-line/graph/elements/base.js"],"sourcesContent":["import React from 'react'; //eslint-disable-line\nimport PropTypes from 'prop-types';\n\nexport const basePropTypes = () => ({\n interval: PropTypes.number.isRequired,\n domain: PropTypes.shape({\n min: PropTypes.number.isRequired,\n max: PropTypes.number.isRequired,\n }),\n});\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,UAAA,GAAAF,sBAAA,CAAAC,OAAA;AAD2B;;AAGpB,MAAME,aAAa,GAAGA,CAAA,MAAO;EAClCC,QAAQ,EAAEC,kBAAS,CAACC,MAAM,CAACC,UAAU;EACrCC,MAAM,EAAEH,kBAAS,CAACI,KAAK,CAAC;IACtBC,GAAG,EAAEL,kBAAS,CAACC,MAAM,CAACC,UAAU;IAChCI,GAAG,EAAEN,kBAAS,CAACC,MAAM,CAACC;EACxB,CAAC;AACH,CAAC,CAAC;AAACK,OAAA,CAAAT,aAAA,GAAAA,aAAA","ignoreList":[]}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.buildElementModel = buildElementModel;
|
|
7
|
+
function buildElementModel(position, elementType, domain, interval) {
|
|
8
|
+
if (elementType.startsWith('p')) {
|
|
9
|
+
return {
|
|
10
|
+
position: position,
|
|
11
|
+
type: 'point',
|
|
12
|
+
pointType: elementType.endsWith('e') ? 'empty' : 'full'
|
|
13
|
+
};
|
|
14
|
+
} else if (elementType.startsWith('l')) {
|
|
15
|
+
let left = position + interval <= domain.max ? position : position - interval;
|
|
16
|
+
let right = left + interval;
|
|
17
|
+
return {
|
|
18
|
+
type: 'line',
|
|
19
|
+
leftPoint: elementType.charAt(1) === 'e' ? 'empty' : 'full',
|
|
20
|
+
rightPoint: elementType.charAt(2) === 'e' ? 'empty' : 'full',
|
|
21
|
+
position: {
|
|
22
|
+
left,
|
|
23
|
+
right
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
} else if (elementType.startsWith('r')) {
|
|
27
|
+
let full = elementType.charAt(1) === 'f';
|
|
28
|
+
let positive = elementType.charAt(2) === 'p';
|
|
29
|
+
return {
|
|
30
|
+
type: 'ray',
|
|
31
|
+
direction: positive ? 'positive' : 'negative',
|
|
32
|
+
pointType: full ? 'full' : 'empty',
|
|
33
|
+
position: position
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=builder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"builder.js","names":["buildElementModel","position","elementType","domain","interval","startsWith","type","pointType","endsWith","left","max","right","leftPoint","charAt","rightPoint","full","positive","direction"],"sources":["../../../../src/number-line/graph/elements/builder.js"],"sourcesContent":["export function buildElementModel(position, elementType, domain, interval) {\n if (elementType.startsWith('p')) {\n return {\n position: position,\n type: 'point',\n pointType: elementType.endsWith('e') ? 'empty' : 'full',\n };\n } else if (elementType.startsWith('l')) {\n let left = position + interval <= domain.max ? position : position - interval;\n let right = left + interval;\n return {\n type: 'line',\n leftPoint: elementType.charAt(1) === 'e' ? 'empty' : 'full',\n rightPoint: elementType.charAt(2) === 'e' ? 'empty' : 'full',\n position: { left, right },\n };\n } else if (elementType.startsWith('r')) {\n let full = elementType.charAt(1) === 'f';\n let positive = elementType.charAt(2) === 'p';\n return {\n type: 'ray',\n direction: positive ? 'positive' : 'negative',\n pointType: full ? 'full' : 'empty',\n position: position,\n };\n }\n}\n"],"mappings":";;;;;;AAAO,SAASA,iBAAiBA,CAACC,QAAQ,EAAEC,WAAW,EAAEC,MAAM,EAAEC,QAAQ,EAAE;EACzE,IAAIF,WAAW,CAACG,UAAU,CAAC,GAAG,CAAC,EAAE;IAC/B,OAAO;MACLJ,QAAQ,EAAEA,QAAQ;MAClBK,IAAI,EAAE,OAAO;MACbC,SAAS,EAAEL,WAAW,CAACM,QAAQ,CAAC,GAAG,CAAC,GAAG,OAAO,GAAG;IACnD,CAAC;EACH,CAAC,MAAM,IAAIN,WAAW,CAACG,UAAU,CAAC,GAAG,CAAC,EAAE;IACtC,IAAII,IAAI,GAAGR,QAAQ,GAAGG,QAAQ,IAAID,MAAM,CAACO,GAAG,GAAGT,QAAQ,GAAGA,QAAQ,GAAGG,QAAQ;IAC7E,IAAIO,KAAK,GAAGF,IAAI,GAAGL,QAAQ;IAC3B,OAAO;MACLE,IAAI,EAAE,MAAM;MACZM,SAAS,EAAEV,WAAW,CAACW,MAAM,CAAC,CAAC,CAAC,KAAK,GAAG,GAAG,OAAO,GAAG,MAAM;MAC3DC,UAAU,EAAEZ,WAAW,CAACW,MAAM,CAAC,CAAC,CAAC,KAAK,GAAG,GAAG,OAAO,GAAG,MAAM;MAC5DZ,QAAQ,EAAE;QAAEQ,IAAI;QAAEE;MAAM;IAC1B,CAAC;EACH,CAAC,MAAM,IAAIT,WAAW,CAACG,UAAU,CAAC,GAAG,CAAC,EAAE;IACtC,IAAIU,IAAI,GAAGb,WAAW,CAACW,MAAM,CAAC,CAAC,CAAC,KAAK,GAAG;IACxC,IAAIG,QAAQ,GAAGd,WAAW,CAACW,MAAM,CAAC,CAAC,CAAC,KAAK,GAAG;IAC5C,OAAO;MACLP,IAAI,EAAE,KAAK;MACXW,SAAS,EAAED,QAAQ,GAAG,UAAU,GAAG,UAAU;MAC7CT,SAAS,EAAEQ,IAAI,GAAG,MAAM,GAAG,OAAO;MAClCd,QAAQ,EAAEA;IACZ,CAAC;EACH;AACF","ignoreList":[]}
|
|
@@ -0,0 +1,259 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = exports.Line = void 0;
|
|
8
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
9
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
10
|
+
var _react = _interopRequireDefault(require("react"));
|
|
11
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
12
|
+
var _styles = require("@mui/material/styles");
|
|
13
|
+
var _lodashEs = require("lodash-es");
|
|
14
|
+
var _renderUi = require("@pie-lib/render-ui");
|
|
15
|
+
var _draggable = require("../../../draggable");
|
|
16
|
+
var _point = _interopRequireDefault(require("./point"));
|
|
17
|
+
var _base = require("./base");
|
|
18
|
+
const duration = '150ms';
|
|
19
|
+
const StyledLineGroup = (0, _styles.styled)('g')(({
|
|
20
|
+
$disabled,
|
|
21
|
+
$selected,
|
|
22
|
+
$correct
|
|
23
|
+
}) => ({
|
|
24
|
+
'& .line-handle': {
|
|
25
|
+
stroke: _renderUi.color.primary(),
|
|
26
|
+
cursor: 'pointer',
|
|
27
|
+
strokeWidth: '5px',
|
|
28
|
+
transition: `opacity ${duration} linear,
|
|
29
|
+
stroke-width ${duration} linear,
|
|
30
|
+
stroke ${duration} linear`
|
|
31
|
+
},
|
|
32
|
+
// was ".react-draggable-dragging" in the old version
|
|
33
|
+
'&.dnd-kit-dragging': {
|
|
34
|
+
opacity: 0.6,
|
|
35
|
+
'& .line-handle': {
|
|
36
|
+
opacity: 1.0,
|
|
37
|
+
strokeWidth: '12px'
|
|
38
|
+
}
|
|
39
|
+
},
|
|
40
|
+
...($disabled && {
|
|
41
|
+
cursor: 'not-allowed',
|
|
42
|
+
opacity: 0.8
|
|
43
|
+
}),
|
|
44
|
+
...($selected && {
|
|
45
|
+
'& .line-handle': {
|
|
46
|
+
stroke: _renderUi.color.primaryDark()
|
|
47
|
+
}
|
|
48
|
+
}),
|
|
49
|
+
...($correct === true && {
|
|
50
|
+
'& .line-handle': {
|
|
51
|
+
cursor: 'inherit',
|
|
52
|
+
stroke: _renderUi.color.correct()
|
|
53
|
+
}
|
|
54
|
+
}),
|
|
55
|
+
...($correct === false && {
|
|
56
|
+
'& .line-handle': {
|
|
57
|
+
cursor: 'inherit',
|
|
58
|
+
stroke: _renderUi.color.incorrect()
|
|
59
|
+
}
|
|
60
|
+
})
|
|
61
|
+
}));
|
|
62
|
+
class Line extends _react.default.Component {
|
|
63
|
+
constructor(props) {
|
|
64
|
+
super(props);
|
|
65
|
+
this.state = {
|
|
66
|
+
left: null,
|
|
67
|
+
right: null
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
UNSAFE_componentWillReceiveProps(nextProps) {
|
|
71
|
+
if (nextProps) {
|
|
72
|
+
const {
|
|
73
|
+
position
|
|
74
|
+
} = nextProps;
|
|
75
|
+
this.setState({
|
|
76
|
+
left: position.left,
|
|
77
|
+
right: position.right
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
onDrag(side, p) {
|
|
82
|
+
const {
|
|
83
|
+
domain
|
|
84
|
+
} = this.props;
|
|
85
|
+
if (p >= domain.min && p <= domain.max) {
|
|
86
|
+
const newState = {};
|
|
87
|
+
newState[side] = p;
|
|
88
|
+
this.setState(newState);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
onMove(side, d) {
|
|
92
|
+
const {
|
|
93
|
+
position: p
|
|
94
|
+
} = this.props;
|
|
95
|
+
const newPosition = {
|
|
96
|
+
left: p.left,
|
|
97
|
+
right: p.right
|
|
98
|
+
};
|
|
99
|
+
newPosition[side] = d;
|
|
100
|
+
this.props.onMoveLine(newPosition);
|
|
101
|
+
}
|
|
102
|
+
render() {
|
|
103
|
+
const {
|
|
104
|
+
interval,
|
|
105
|
+
empty,
|
|
106
|
+
position,
|
|
107
|
+
domain,
|
|
108
|
+
y,
|
|
109
|
+
selected,
|
|
110
|
+
disabled,
|
|
111
|
+
correct
|
|
112
|
+
} = this.props;
|
|
113
|
+
const {
|
|
114
|
+
xScale
|
|
115
|
+
} = this.context;
|
|
116
|
+
const {
|
|
117
|
+
onDrag,
|
|
118
|
+
onMove
|
|
119
|
+
} = this;
|
|
120
|
+
const onMoveLeft = onMove.bind(this, 'left');
|
|
121
|
+
const onMoveRight = onMove.bind(this, 'right');
|
|
122
|
+
const onDragLeft = onDrag.bind(this, 'left');
|
|
123
|
+
const onDragRight = onDrag.bind(this, 'right');
|
|
124
|
+
const left = (0, _lodashEs.isNumber)(this.state.left) ? this.state.left : position.left;
|
|
125
|
+
const right = (0, _lodashEs.isNumber)(this.state.right) ? this.state.right : position.right;
|
|
126
|
+
const is = xScale(interval) - xScale(0);
|
|
127
|
+
const onMouseDown = e => e.nativeEvent.preventDefault();
|
|
128
|
+
const onLineClick = () => {
|
|
129
|
+
// click on the line toggles selection
|
|
130
|
+
this.props.onToggleSelect();
|
|
131
|
+
};
|
|
132
|
+
const onRectClick = () => {
|
|
133
|
+
this.props.onToggleSelect();
|
|
134
|
+
};
|
|
135
|
+
|
|
136
|
+
// dnd-kit drag stop handler (receives pixel deltaX from LocalDraggableDndKit)
|
|
137
|
+
const onLineDragStop = deltaX => {
|
|
138
|
+
// small movement -> treat as click (same threshold as before: is / 10)
|
|
139
|
+
const deltaAbs = Math.abs(deltaX);
|
|
140
|
+
if (deltaAbs < is / 10) {
|
|
141
|
+
this.props.onToggleSelect();
|
|
142
|
+
return;
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
// convert pixel delta to domain delta (same math as before)
|
|
146
|
+
const invertedX = xScale.invert(deltaX + xScale(0));
|
|
147
|
+
const newPosition = {
|
|
148
|
+
left: position.left + invertedX,
|
|
149
|
+
right: position.right + invertedX
|
|
150
|
+
};
|
|
151
|
+
if (!(0, _lodashEs.isEqual)(newPosition, this.props.position)) {
|
|
152
|
+
this.props.onMoveLine(newPosition);
|
|
153
|
+
}
|
|
154
|
+
};
|
|
155
|
+
const scaledLineBounds = {
|
|
156
|
+
left: (domain.min - position.left) / interval * is,
|
|
157
|
+
right: (domain.max - position.right) / interval * is
|
|
158
|
+
};
|
|
159
|
+
const common = {
|
|
160
|
+
interval,
|
|
161
|
+
selected,
|
|
162
|
+
disabled,
|
|
163
|
+
correct
|
|
164
|
+
};
|
|
165
|
+
|
|
166
|
+
// unique-ish id for this line; if you already have an id prop, use that instead
|
|
167
|
+
const draggableId = `line-${position.left}-${position.right}-${y}`;
|
|
168
|
+
return /*#__PURE__*/_react.default.createElement(_draggable.Draggable, {
|
|
169
|
+
id: draggableId,
|
|
170
|
+
disabled: disabled,
|
|
171
|
+
grid: [is],
|
|
172
|
+
bounds: scaledLineBounds,
|
|
173
|
+
onMouseDown: onMouseDown,
|
|
174
|
+
onDragEnd: onLineDragStop
|
|
175
|
+
}, ({
|
|
176
|
+
setNodeRef,
|
|
177
|
+
attributes,
|
|
178
|
+
listeners,
|
|
179
|
+
translateX,
|
|
180
|
+
isDragging,
|
|
181
|
+
onMouseDown: handleMouseDown
|
|
182
|
+
}) => /*#__PURE__*/_react.default.createElement(StyledLineGroup, (0, _extends2.default)({
|
|
183
|
+
ref: setNodeRef,
|
|
184
|
+
$disabled: disabled,
|
|
185
|
+
$selected: selected,
|
|
186
|
+
$correct: correct,
|
|
187
|
+
className: isDragging ? 'dnd-kit-dragging' : undefined,
|
|
188
|
+
onMouseDown: handleMouseDown
|
|
189
|
+
}, attributes), /*#__PURE__*/_react.default.createElement("g", {
|
|
190
|
+
transform: `translate(${translateX}, ${y})`
|
|
191
|
+
}, /*#__PURE__*/_react.default.createElement("rect", {
|
|
192
|
+
x: xScale(left),
|
|
193
|
+
width: Math.abs(xScale(right) - xScale(left)),
|
|
194
|
+
fill: "red",
|
|
195
|
+
fillOpacity: "0.0",
|
|
196
|
+
y: "-8",
|
|
197
|
+
height: 16,
|
|
198
|
+
onClick: onRectClick
|
|
199
|
+
}), /*#__PURE__*/_react.default.createElement("line", (0, _extends2.default)({
|
|
200
|
+
className: "line-handle",
|
|
201
|
+
x1: xScale(left),
|
|
202
|
+
x2: xScale(right),
|
|
203
|
+
onClick: onLineClick
|
|
204
|
+
// this is your "handle": only dragging when grabbing this line
|
|
205
|
+
}, listeners)), /*#__PURE__*/_react.default.createElement(_point.default, (0, _extends2.default)({}, common, {
|
|
206
|
+
empty: empty.left,
|
|
207
|
+
bounds: {
|
|
208
|
+
left: domain.min - position.left,
|
|
209
|
+
right: domain.max - position.left
|
|
210
|
+
},
|
|
211
|
+
position: position.left,
|
|
212
|
+
onDrag: onDragLeft,
|
|
213
|
+
onMove: onMoveLeft,
|
|
214
|
+
onClick: onRectClick
|
|
215
|
+
})), /*#__PURE__*/_react.default.createElement(_point.default, (0, _extends2.default)({}, common, {
|
|
216
|
+
empty: empty.right,
|
|
217
|
+
bounds: {
|
|
218
|
+
left: domain.min - position.right,
|
|
219
|
+
right: domain.max - position.right
|
|
220
|
+
},
|
|
221
|
+
position: position.right,
|
|
222
|
+
onDrag: onDragRight,
|
|
223
|
+
onMove: onMoveRight,
|
|
224
|
+
onClick: onRectClick
|
|
225
|
+
})))));
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
exports.Line = Line;
|
|
229
|
+
(0, _defineProperty2.default)(Line, "propTypes", {
|
|
230
|
+
...(0, _base.basePropTypes)(),
|
|
231
|
+
empty: _propTypes.default.shape({
|
|
232
|
+
left: _propTypes.default.bool.isRequired,
|
|
233
|
+
right: _propTypes.default.bool.isRequired
|
|
234
|
+
}).isRequired,
|
|
235
|
+
position: _propTypes.default.shape({
|
|
236
|
+
left: _propTypes.default.number.isRequired,
|
|
237
|
+
right: _propTypes.default.number.isRequired
|
|
238
|
+
}).isRequired,
|
|
239
|
+
y: _propTypes.default.number,
|
|
240
|
+
selected: _propTypes.default.bool,
|
|
241
|
+
disabled: _propTypes.default.bool,
|
|
242
|
+
correct: _propTypes.default.bool,
|
|
243
|
+
onMoveLine: _propTypes.default.func.isRequired,
|
|
244
|
+
onToggleSelect: _propTypes.default.func.isRequired,
|
|
245
|
+
onDragStart: _propTypes.default.func,
|
|
246
|
+
onDragStop: _propTypes.default.func
|
|
247
|
+
});
|
|
248
|
+
(0, _defineProperty2.default)(Line, "defaultProps", {
|
|
249
|
+
selected: false,
|
|
250
|
+
y: 0,
|
|
251
|
+
disabled: false,
|
|
252
|
+
correct: undefined
|
|
253
|
+
});
|
|
254
|
+
(0, _defineProperty2.default)(Line, "contextTypes", {
|
|
255
|
+
xScale: _propTypes.default.func.isRequired,
|
|
256
|
+
snapValue: _propTypes.default.func.isRequired
|
|
257
|
+
});
|
|
258
|
+
var _default = exports.default = Line;
|
|
259
|
+
//# sourceMappingURL=line.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"line.js","names":["_react","_interopRequireDefault","require","_propTypes","_styles","_lodashEs","_renderUi","_draggable","_point","_base","duration","StyledLineGroup","styled","$disabled","$selected","$correct","stroke","color","primary","cursor","strokeWidth","transition","opacity","primaryDark","correct","incorrect","Line","React","Component","constructor","props","state","left","right","UNSAFE_componentWillReceiveProps","nextProps","position","setState","onDrag","side","p","domain","min","max","newState","onMove","d","newPosition","onMoveLine","render","interval","empty","y","selected","disabled","xScale","context","onMoveLeft","bind","onMoveRight","onDragLeft","onDragRight","isNumber","is","onMouseDown","e","nativeEvent","preventDefault","onLineClick","onToggleSelect","onRectClick","onLineDragStop","deltaX","deltaAbs","Math","abs","invertedX","invert","isEqual","scaledLineBounds","common","draggableId","default","createElement","Draggable","id","grid","bounds","onDragEnd","setNodeRef","attributes","listeners","translateX","isDragging","handleMouseDown","_extends2","ref","className","undefined","transform","x","width","fill","fillOpacity","height","onClick","x1","x2","exports","_defineProperty2","basePropTypes","PropTypes","shape","bool","isRequired","number","func","onDragStart","onDragStop","snapValue","_default"],"sources":["../../../../src/number-line/graph/elements/line.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { styled } from '@mui/material/styles';\nimport { isEqual, isNumber } from 'lodash-es';\nimport { color } from '@pie-lib/render-ui';\nimport { Draggable } from '../../../draggable';\n\nimport Point from './point';\nimport { basePropTypes } from './base';\n\nconst duration = '150ms';\n\nconst StyledLineGroup = styled('g')(({ $disabled, $selected, $correct }) => ({\n '& .line-handle': {\n stroke: color.primary(),\n cursor: 'pointer',\n strokeWidth: '5px',\n transition: `opacity ${duration} linear, \n stroke-width ${duration} linear,\n stroke ${duration} linear`,\n },\n // was \".react-draggable-dragging\" in the old version\n '&.dnd-kit-dragging': {\n opacity: 0.6,\n '& .line-handle': {\n opacity: 1.0,\n strokeWidth: '12px',\n },\n },\n ...($disabled && {\n cursor: 'not-allowed',\n opacity: 0.8,\n }),\n ...($selected && {\n '& .line-handle': {\n stroke: color.primaryDark(),\n },\n }),\n ...($correct === true && {\n '& .line-handle': {\n cursor: 'inherit',\n stroke: color.correct(),\n },\n }),\n ...($correct === false && {\n '& .line-handle': {\n cursor: 'inherit',\n stroke: color.incorrect(),\n },\n }),\n}));\n\nexport class Line extends React.Component {\n static propTypes = {\n ...basePropTypes(),\n empty: PropTypes.shape({\n left: PropTypes.bool.isRequired,\n right: PropTypes.bool.isRequired,\n }).isRequired,\n position: PropTypes.shape({\n left: PropTypes.number.isRequired,\n right: PropTypes.number.isRequired,\n }).isRequired,\n y: PropTypes.number,\n selected: PropTypes.bool,\n disabled: PropTypes.bool,\n correct: PropTypes.bool,\n onMoveLine: PropTypes.func.isRequired,\n onToggleSelect: PropTypes.func.isRequired,\n onDragStart: PropTypes.func,\n onDragStop: PropTypes.func,\n };\n\n static defaultProps = {\n selected: false,\n y: 0,\n disabled: false,\n correct: undefined,\n };\n\n static contextTypes = {\n xScale: PropTypes.func.isRequired,\n snapValue: PropTypes.func.isRequired,\n };\n\n constructor(props) {\n super(props);\n this.state = {\n left: null,\n right: null,\n };\n }\n\n UNSAFE_componentWillReceiveProps(nextProps) {\n if (nextProps) {\n const { position } = nextProps;\n this.setState({ left: position.left, right: position.right });\n }\n }\n\n onDrag(side, p) {\n const { domain } = this.props;\n if (p >= domain.min && p <= domain.max) {\n const newState = {};\n newState[side] = p;\n this.setState(newState);\n }\n }\n\n onMove(side, d) {\n const { position: p } = this.props;\n const newPosition = { left: p.left, right: p.right };\n newPosition[side] = d;\n this.props.onMoveLine(newPosition);\n }\n\n render() {\n const { interval, empty, position, domain, y, selected, disabled, correct } = this.props;\n\n const { xScale } = this.context;\n\n const { onDrag, onMove } = this;\n const onMoveLeft = onMove.bind(this, 'left');\n const onMoveRight = onMove.bind(this, 'right');\n const onDragLeft = onDrag.bind(this, 'left');\n const onDragRight = onDrag.bind(this, 'right');\n\n const left = isNumber(this.state.left) ? this.state.left : position.left;\n const right = isNumber(this.state.right) ? this.state.right : position.right;\n\n const is = xScale(interval) - xScale(0);\n\n const onMouseDown = (e) => e.nativeEvent.preventDefault();\n\n const onLineClick = () => {\n // click on the line toggles selection\n this.props.onToggleSelect();\n };\n\n const onRectClick = () => {\n this.props.onToggleSelect();\n };\n\n // dnd-kit drag stop handler (receives pixel deltaX from LocalDraggableDndKit)\n const onLineDragStop = (deltaX) => {\n // small movement -> treat as click (same threshold as before: is / 10)\n const deltaAbs = Math.abs(deltaX);\n if (deltaAbs < is / 10) {\n this.props.onToggleSelect();\n return;\n }\n\n // convert pixel delta to domain delta (same math as before)\n const invertedX = xScale.invert(deltaX + xScale(0));\n const newPosition = {\n left: position.left + invertedX,\n right: position.right + invertedX,\n };\n\n if (!isEqual(newPosition, this.props.position)) {\n this.props.onMoveLine(newPosition);\n }\n };\n\n const scaledLineBounds = {\n left: ((domain.min - position.left) / interval) * is,\n right: ((domain.max - position.right) / interval) * is,\n };\n\n const common = {\n interval,\n selected,\n disabled,\n correct,\n };\n\n // unique-ish id for this line; if you already have an id prop, use that instead\n const draggableId = `line-${position.left}-${position.right}-${y}`;\n\n return (\n <Draggable\n id={draggableId}\n disabled={disabled}\n grid={[is]}\n bounds={scaledLineBounds}\n onMouseDown={onMouseDown}\n onDragEnd={onLineDragStop}\n >\n {({ setNodeRef, attributes, listeners, translateX, isDragging, onMouseDown: handleMouseDown }) => (\n <StyledLineGroup\n ref={setNodeRef}\n $disabled={disabled}\n $selected={selected}\n $correct={correct}\n className={isDragging ? 'dnd-kit-dragging' : undefined}\n onMouseDown={handleMouseDown}\n {...attributes}\n >\n <g transform={`translate(${translateX}, ${y})`}>\n <rect\n x={xScale(left)}\n width={Math.abs(xScale(right) - xScale(left))}\n fill=\"red\"\n fillOpacity=\"0.0\"\n y=\"-8\"\n height={16}\n onClick={onRectClick}\n />\n <line\n className=\"line-handle\"\n x1={xScale(left)}\n x2={xScale(right)}\n onClick={onLineClick}\n // this is your \"handle\": only dragging when grabbing this line\n {...listeners}\n />\n <Point\n {...common}\n empty={empty.left}\n bounds={{\n left: domain.min - position.left,\n right: domain.max - position.left,\n }}\n position={position.left}\n onDrag={onDragLeft}\n onMove={onMoveLeft}\n onClick={onRectClick}\n />\n <Point\n {...common}\n empty={empty.right}\n bounds={{\n left: domain.min - position.right,\n right: domain.max - position.right,\n }}\n position={position.right}\n onDrag={onDragRight}\n onMove={onMoveRight}\n onClick={onRectClick}\n />\n </g>\n </StyledLineGroup>\n )}\n </Draggable>\n );\n }\n}\n\nexport default Line;\n"],"mappings":"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","ignoreList":[]}
|