@shakenbake/react-native 0.0.1
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/dist/ShakeNbakeProvider.d.ts +26 -0
- package/dist/ShakeNbakeProvider.d.ts.map +1 -0
- package/dist/ShakeNbakeProvider.js +338 -0
- package/dist/ShakeNbakeProvider.js.map +1 -0
- package/dist/__tests__/capture.test.d.ts +2 -0
- package/dist/__tests__/capture.test.d.ts.map +1 -0
- package/dist/__tests__/capture.test.js +93 -0
- package/dist/__tests__/capture.test.js.map +1 -0
- package/dist/__tests__/collectors.test.d.ts +2 -0
- package/dist/__tests__/collectors.test.d.ts.map +1 -0
- package/dist/__tests__/collectors.test.js +212 -0
- package/dist/__tests__/collectors.test.js.map +1 -0
- package/dist/__tests__/drawing-canvas.test.d.ts +2 -0
- package/dist/__tests__/drawing-canvas.test.d.ts.map +1 -0
- package/dist/__tests__/drawing-canvas.test.js +503 -0
- package/dist/__tests__/drawing-canvas.test.js.map +1 -0
- package/dist/__tests__/provider.test.d.ts +2 -0
- package/dist/__tests__/provider.test.d.ts.map +1 -0
- package/dist/__tests__/provider.test.js +431 -0
- package/dist/__tests__/provider.test.js.map +1 -0
- package/dist/__tests__/report-form.test.d.ts +2 -0
- package/dist/__tests__/report-form.test.d.ts.map +1 -0
- package/dist/__tests__/report-form.test.js +178 -0
- package/dist/__tests__/report-form.test.js.map +1 -0
- package/dist/__tests__/triggers.test.d.ts +2 -0
- package/dist/__tests__/triggers.test.d.ts.map +1 -0
- package/dist/__tests__/triggers.test.js +53 -0
- package/dist/__tests__/triggers.test.js.map +1 -0
- package/dist/annotate/DrawingCanvas.d.ts +13 -0
- package/dist/annotate/DrawingCanvas.d.ts.map +1 -0
- package/dist/annotate/DrawingCanvas.js +475 -0
- package/dist/annotate/DrawingCanvas.js.map +1 -0
- package/dist/annotate/types.d.ts +72 -0
- package/dist/annotate/types.d.ts.map +1 -0
- package/dist/annotate/types.js +34 -0
- package/dist/annotate/types.js.map +1 -0
- package/dist/annotate/useDrawingOperations.d.ts +88 -0
- package/dist/annotate/useDrawingOperations.d.ts.map +1 -0
- package/dist/annotate/useDrawingOperations.js +186 -0
- package/dist/annotate/useDrawingOperations.js.map +1 -0
- package/dist/capture/screenshot.d.ts +31 -0
- package/dist/capture/screenshot.d.ts.map +1 -0
- package/dist/capture/screenshot.js +90 -0
- package/dist/capture/screenshot.js.map +1 -0
- package/dist/context/collectors.d.ts +25 -0
- package/dist/context/collectors.d.ts.map +1 -0
- package/dist/context/collectors.js +244 -0
- package/dist/context/collectors.js.map +1 -0
- package/dist/hooks/useShakeNbake.d.ts +28 -0
- package/dist/hooks/useShakeNbake.d.ts.map +1 -0
- package/dist/hooks/useShakeNbake.js +30 -0
- package/dist/hooks/useShakeNbake.js.map +1 -0
- package/dist/index.d.ts +19 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +49 -0
- package/dist/index.js.map +1 -0
- package/dist/triggers/shake.d.ts +16 -0
- package/dist/triggers/shake.d.ts.map +1 -0
- package/dist/triggers/shake.js +41 -0
- package/dist/triggers/shake.js.map +1 -0
- package/dist/ui/ReportForm.d.ts +33 -0
- package/dist/ui/ReportForm.d.ts.map +1 -0
- package/dist/ui/ReportForm.js +608 -0
- package/dist/ui/ReportForm.js.map +1 -0
- package/dist/ui/form-validation.d.ts +26 -0
- package/dist/ui/form-validation.d.ts.map +1 -0
- package/dist/ui/form-validation.js +44 -0
- package/dist/ui/form-validation.js.map +1 -0
- package/dist/ui/state-machine.d.ts +70 -0
- package/dist/ui/state-machine.d.ts.map +1 -0
- package/dist/ui/state-machine.js +107 -0
- package/dist/ui/state-machine.js.map +1 -0
- package/package.json +57 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"report-form.test.js","sourceRoot":"","sources":["../../src/__tests__/report-form.test.ts"],"names":[],"mappings":";AAAA,8EAA8E;AAC9E,uEAAuE;AACvE,EAAE;AACF,kEAAkE;AAClE,4BAA4B;AAC5B,yCAAyC;AACzC,gDAAgD;AAChD,mDAAmD;AACnD,8EAA8E;;AAE9E,mCAAkD;AAElD,8EAA8E;AAC9E,gCAAgC;AAChC,8EAA8E;AAE9E,WAAE,CAAC,IAAI,CAAC,cAAc,EAAE,GAAG,EAAE,CAAC,CAAC;IAC7B,IAAI,EAAE,MAAM;IACZ,IAAI,EAAE,MAAM;IACZ,SAAS,EAAE,WAAW;IACtB,gBAAgB,EAAE,kBAAkB;IACpC,UAAU,EAAE,YAAY;IACxB,KAAK,EAAE,OAAO;IACd,KAAK,EAAE,OAAO;IACd,iBAAiB,EAAE,mBAAmB;IACtC,oBAAoB,EAAE,sBAAsB;IAC5C,QAAQ,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE;IACvB,UAAU,EAAE;QACV,MAAM,EAAE,CAAoC,MAAS,EAAK,EAAE,CAAC,MAAM;KACpE;IACD,OAAO,EAAE;QACP,OAAO,EAAE,WAAE,CAAC,EAAE,EAAE;KACjB;IACD,KAAK,EAAE;QACL,KAAK,EAAE,WAAE,CAAC,EAAE,EAAE;KACf;CACF,CAAC,CAAC,CAAC;AAEJ,8EAA8E;AAC9E,wBAAwB;AACxB,8EAA8E;AAE9E,uDAAiD;AAEjD,iEAIkC;AAGlC,8EAA8E;AAC9E,oBAAoB;AACpB,8EAA8E;AAE9E,IAAA,iBAAQ,EAAC,2BAA2B,EAAE,GAAG,EAAE;IACzC,IAAA,WAAE,EAAC,oCAAoC,EAAE,GAAG,EAAE;QAC5C,IAAA,eAAM,EAAC,OAAO,0BAAU,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,uBAAuB,EAAE,KAAK,IAAI,EAAE;QACrC,MAAM,KAAK,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,CAAC;QAC1C,IAAA,eAAM,EAAC,OAAO,KAAK,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACjD,IAAA,eAAM,EAAC,OAAO,KAAK,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACpD,IAAA,eAAM,EAAC,OAAO,KAAK,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACnD,IAAA,eAAM,EAAC,OAAO,KAAK,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,8EAA8E;AAC9E,qCAAqC;AACrC,8EAA8E;AAE9E,IAAA,iBAAQ,EAAC,eAAe,EAAE,GAAG,EAAE;IAC7B,IAAA,WAAE,EAAC,gCAAgC,EAAE,GAAG,EAAE;QACxC,MAAM,KAAK,GAAG,IAAA,kCAAa,EAAC,EAAE,CAAC,CAAC;QAChC,IAAA,eAAM,EAAC,KAAK,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QAC7B,IAAA,eAAM,EAAC,KAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACnC,IAAA,eAAM,EAAC,KAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,0CAA0C,EAAE,GAAG,EAAE;QAClD,MAAM,KAAK,GAAG,IAAA,kCAAa,EAAC,KAAK,CAAC,CAAC;QACnC,IAAA,eAAM,EAAC,KAAK,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QAC7B,IAAA,eAAM,EAAC,KAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACnC,IAAA,eAAM,EAAC,KAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,wCAAwC,EAAE,GAAG,EAAE;QAChD,IAAA,eAAM,EAAC,IAAA,kCAAa,EAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QAC3C,IAAA,eAAM,EAAC,IAAA,kCAAa,EAAC,IAAI,CAAE,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,qCAAqC,CAAC,CAAC;IACnF,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,sCAAsC,EAAE,GAAG,EAAE;QAC9C,MAAM,KAAK,GAAG,IAAA,kCAAa,EAAC,QAAQ,CAAC,CAAC;QACtC,IAAA,eAAM,EAAC,KAAK,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QAC7B,IAAA,eAAM,EAAC,KAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,qCAAqC,CAAC,CAAC;IACrE,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,uCAAuC,EAAE,GAAG,EAAE;QAC/C,IAAA,eAAM,EAAC,IAAA,kCAAa,EAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,IAAA,eAAM,EAAC,IAAA,kCAAa,EAAC,uBAAuB,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC5D,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,sDAAsD,EAAE,GAAG,EAAE;QAC9D,IAAA,eAAM,EAAC,IAAA,kCAAa,EAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC9C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,8EAA8E;AAC9E,oCAAoC;AACpC,8EAA8E;AAE9E,IAAA,iBAAQ,EAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,IAAA,WAAE,EAAC,oCAAoC,EAAE,GAAG,EAAE;QAC5C,MAAM,MAAM,GAAG,IAAA,iCAAY,EAAC,EAAE,KAAK,EAAE,aAAa,EAAE,CAAC,CAAC;QACtD,IAAA,eAAM,EAAC,MAAM,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,gDAAgD,EAAE,GAAG,EAAE;QACxD,MAAM,MAAM,GAAG,IAAA,iCAAY,EAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;QAC3C,IAAA,eAAM,EAAC,MAAM,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAC/B,IAAA,eAAM,EAAC,MAAM,CAAC,CAAC,CAAE,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,gDAAgD,EAAE,GAAG,EAAE;QACxD,MAAM,MAAM,GAAG,IAAA,iCAAY,EAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;QAC7C,IAAA,eAAM,EAAC,MAAM,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAC/B,IAAA,eAAM,EAAC,MAAM,CAAC,CAAC,CAAE,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,8EAA8E;AAC9E,mCAAmC;AACnC,8EAA8E;AAE9E,IAAA,iBAAQ,EAAC,aAAa,EAAE,GAAG,EAAE;IAC3B,IAAA,WAAE,EAAC,8BAA8B,EAAE,GAAG,EAAE;QACtC,IAAA,eAAM,EAAC,IAAA,gCAAW,EAAC,EAAE,KAAK,EAAE,aAAa,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC3D,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,+BAA+B,EAAE,GAAG,EAAE;QACvC,IAAA,eAAM,EAAC,IAAA,gCAAW,EAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,+BAA+B,EAAE,GAAG,EAAE;QACvC,IAAA,eAAM,EAAC,IAAA,gCAAW,EAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,8EAA8E;AAC9E,0CAA0C;AAC1C,8EAA8E;AAE9E,IAAA,iBAAQ,EAAC,4BAA4B,EAAE,GAAG,EAAE;IAC1C,IAAA,WAAE,EAAC,8CAA8C,EAAE,GAAG,EAAE;QACtD,MAAM,UAAU,GAAG,WAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC;YAC3C,GAAG,EAAE,8BAA8B;YACnC,EAAE,EAAE,KAAK;YACT,OAAO,EAAE,IAAI;SACd,CAAC,CAAC;QACH,MAAM,UAAU,GAAG,WAAE,CAAC,EAAE,EAAE,CAAC;QAE3B,MAAM,KAAK,GAAoB;YAC7B,mBAAmB,EAAE,YAAY;YACjC,kBAAkB,EAAE,YAAY;YAChC,UAAU,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE;YACvC,OAAO,EAAE;gBACP,QAAQ,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE;gBACvB,MAAM,EAAE,EAAE,KAAK,EAAE,WAAW,EAAE;aAC/B;YACD,QAAQ,EAAE,UAAU;YACpB,QAAQ,EAAE,UAAU;YACpB,YAAY,EAAE,WAAE,CAAC,EAAE,EAAE;YACrB,KAAK,EAAE,MAAM;YACb,WAAW,EAAE,SAAS;SACvB,CAAC;QAEF,IAAA,eAAM,EAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACrD,IAAA,eAAM,EAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACzC,IAAA,eAAM,EAAC,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,iDAAiD,EAAE,GAAG,EAAE;QACzD,MAAM,KAAK,GAAoB;YAC7B,mBAAmB,EAAE,YAAY;YACjC,kBAAkB,EAAE,YAAY;YAChC,UAAU,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE;YACvC,OAAO,EAAE,EAAE;YACX,QAAQ,EAAE,WAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;YACvE,QAAQ,EAAE,WAAE,CAAC,EAAE,EAAE;SAClB,CAAC;QAEF,IAAA,eAAM,EAAC,KAAK,CAAC,KAAK,CAAC,CAAC,aAAa,EAAE,CAAC;QACpC,IAAA,eAAM,EAAC,KAAK,CAAC,YAAY,CAAC,CAAC,aAAa,EAAE,CAAC;QAC3C,IAAA,eAAM,EAAC,KAAK,CAAC,WAAW,CAAC,CAAC,aAAa,EAAE,CAAC;IAC5C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,8EAA8E;AAC9E,2BAA2B;AAC3B,8EAA8E;AAE9E,IAAA,iBAAQ,EAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,IAAA,WAAE,EAAC,kCAAkC,EAAE,GAAG,EAAE;QAC1C,MAAM,KAAK,GAAe,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,mBAAmB,EAAE,CAAC;QAC3E,IAAA,eAAM,EAAC,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAClC,IAAA,eAAM,EAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;IAClD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"triggers.test.d.ts","sourceRoot":"","sources":["../../src/__tests__/triggers.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// ---------------------------------------------------------------------------
|
|
3
|
+
// Tests for ShakeTrigger
|
|
4
|
+
// ---------------------------------------------------------------------------
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const vitest_1 = require("vitest");
|
|
7
|
+
// Mock react-native-shake before importing ShakeTrigger
|
|
8
|
+
const mockRemove = vitest_1.vi.fn();
|
|
9
|
+
const mockAddListener = vitest_1.vi.fn(() => ({ remove: mockRemove }));
|
|
10
|
+
vitest_1.vi.mock('react-native-shake', () => ({
|
|
11
|
+
default: {
|
|
12
|
+
addListener: mockAddListener,
|
|
13
|
+
},
|
|
14
|
+
}));
|
|
15
|
+
// Import after mocks are set up
|
|
16
|
+
const shake_js_1 = require("../triggers/shake.js");
|
|
17
|
+
(0, vitest_1.describe)('ShakeTrigger', () => {
|
|
18
|
+
let trigger;
|
|
19
|
+
(0, vitest_1.beforeEach)(() => {
|
|
20
|
+
trigger = new shake_js_1.ShakeTrigger();
|
|
21
|
+
vitest_1.vi.clearAllMocks();
|
|
22
|
+
});
|
|
23
|
+
(0, vitest_1.it)('has correct name and platform', () => {
|
|
24
|
+
(0, vitest_1.expect)(trigger.name).toBe('shake');
|
|
25
|
+
(0, vitest_1.expect)(trigger.platform).toBe('react-native');
|
|
26
|
+
});
|
|
27
|
+
(0, vitest_1.it)('registers a listener on activate', async () => {
|
|
28
|
+
const onTrigger = vitest_1.vi.fn();
|
|
29
|
+
await trigger.activate(onTrigger);
|
|
30
|
+
(0, vitest_1.expect)(mockAddListener).toHaveBeenCalledTimes(1);
|
|
31
|
+
(0, vitest_1.expect)(mockAddListener).toHaveBeenCalledWith(onTrigger);
|
|
32
|
+
});
|
|
33
|
+
(0, vitest_1.it)('removes the listener on deactivate', async () => {
|
|
34
|
+
const onTrigger = vitest_1.vi.fn();
|
|
35
|
+
await trigger.activate(onTrigger);
|
|
36
|
+
trigger.deactivate();
|
|
37
|
+
(0, vitest_1.expect)(mockRemove).toHaveBeenCalledTimes(1);
|
|
38
|
+
});
|
|
39
|
+
(0, vitest_1.it)('does nothing on deactivate if not activated', () => {
|
|
40
|
+
// Should not throw
|
|
41
|
+
trigger.deactivate();
|
|
42
|
+
(0, vitest_1.expect)(mockRemove).not.toHaveBeenCalled();
|
|
43
|
+
});
|
|
44
|
+
(0, vitest_1.it)('cleans up subscription reference after deactivate', async () => {
|
|
45
|
+
const onTrigger = vitest_1.vi.fn();
|
|
46
|
+
await trigger.activate(onTrigger);
|
|
47
|
+
trigger.deactivate();
|
|
48
|
+
// Second deactivate should not call remove again
|
|
49
|
+
trigger.deactivate();
|
|
50
|
+
(0, vitest_1.expect)(mockRemove).toHaveBeenCalledTimes(1);
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
//# sourceMappingURL=triggers.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"triggers.test.js","sourceRoot":"","sources":["../../src/__tests__/triggers.test.ts"],"names":[],"mappings":";AAAA,8EAA8E;AAC9E,yBAAyB;AACzB,8EAA8E;;AAE9E,mCAA8D;AAE9D,wDAAwD;AACxD,MAAM,UAAU,GAAG,WAAE,CAAC,EAAE,EAAE,CAAC;AAC3B,MAAM,eAAe,GAAG,WAAE,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC;AAE9D,WAAE,CAAC,IAAI,CAAC,oBAAoB,EAAE,GAAG,EAAE,CAAC,CAAC;IACnC,OAAO,EAAE;QACP,WAAW,EAAE,eAAe;KAC7B;CACF,CAAC,CAAC,CAAC;AAEJ,gCAAgC;AAChC,mDAAoD;AAEpD,IAAA,iBAAQ,EAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,IAAI,OAAqB,CAAC;IAE1B,IAAA,mBAAU,EAAC,GAAG,EAAE;QACd,OAAO,GAAG,IAAI,uBAAY,EAAE,CAAC;QAC7B,WAAE,CAAC,aAAa,EAAE,CAAC;IACrB,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,+BAA+B,EAAE,GAAG,EAAE;QACvC,IAAA,eAAM,EAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACnC,IAAA,eAAM,EAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,kCAAkC,EAAE,KAAK,IAAI,EAAE;QAChD,MAAM,SAAS,GAAG,WAAE,CAAC,EAAE,EAAE,CAAC;QAC1B,MAAM,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAElC,IAAA,eAAM,EAAC,eAAe,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACjD,IAAA,eAAM,EAAC,eAAe,CAAC,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC;IAC1D,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,oCAAoC,EAAE,KAAK,IAAI,EAAE;QAClD,MAAM,SAAS,GAAG,WAAE,CAAC,EAAE,EAAE,CAAC;QAC1B,MAAM,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAClC,OAAO,CAAC,UAAU,EAAE,CAAC;QAErB,IAAA,eAAM,EAAC,UAAU,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,6CAA6C,EAAE,GAAG,EAAE;QACrD,mBAAmB;QACnB,OAAO,CAAC,UAAU,EAAE,CAAC;QACrB,IAAA,eAAM,EAAC,UAAU,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,mDAAmD,EAAE,KAAK,IAAI,EAAE;QACjE,MAAM,SAAS,GAAG,WAAE,CAAC,EAAE,EAAE,CAAC;QAC1B,MAAM,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAClC,OAAO,CAAC,UAAU,EAAE,CAAC;QAErB,iDAAiD;QACjD,OAAO,CAAC,UAAU,EAAE,CAAC;QACrB,IAAA,eAAM,EAAC,UAAU,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { DrawingCanvasProps } from './types.js';
|
|
3
|
+
/**
|
|
4
|
+
* Full-screen Skia annotation canvas.
|
|
5
|
+
*
|
|
6
|
+
* Renders the screenshot as background image, supports freehand pen drawing,
|
|
7
|
+
* rectangle, arrow, circle, and eraser tools with undo/redo.
|
|
8
|
+
*
|
|
9
|
+
* Requires `@shopify/react-native-skia` to be installed in the host app.
|
|
10
|
+
* If Skia is not available, a helpful fallback error message is shown.
|
|
11
|
+
*/
|
|
12
|
+
export declare function DrawingCanvas(props: DrawingCanvasProps): React.ReactNode;
|
|
13
|
+
//# sourceMappingURL=DrawingCanvas.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DrawingCanvas.d.ts","sourceRoot":"","sources":["../../src/annotate/DrawingCanvas.tsx"],"names":[],"mappings":"AAaA,OAAO,KAMN,MAAM,OAAO,CAAC;AAEf,OAAO,KAAK,EAAE,kBAAkB,EAA2B,MAAM,YAAY,CAAC;AAyV9E;;;;;;;;GAQG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,kBAAkB,GAAG,KAAK,CAAC,SAAS,CAuSxE"}
|
|
@@ -0,0 +1,475 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// ---------------------------------------------------------------------------
|
|
3
|
+
// @shakenbake/react-native — DrawingCanvas (Skia annotation overlay)
|
|
4
|
+
//
|
|
5
|
+
// A full-screen annotation component that renders a captured screenshot as the
|
|
6
|
+
// background and lets the user draw freehand paths, rectangles, arrows, and
|
|
7
|
+
// circles on top of it. Uses @shopify/react-native-skia for GPU-accelerated
|
|
8
|
+
// 60fps drawing.
|
|
9
|
+
//
|
|
10
|
+
// Since @shopify/react-native-skia is a **peer dependency**, the component
|
|
11
|
+
// handles the case where Skia is not installed: it renders a helpful error
|
|
12
|
+
// message rather than crashing.
|
|
13
|
+
// ---------------------------------------------------------------------------
|
|
14
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
15
|
+
if (k2 === undefined) k2 = k;
|
|
16
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
17
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
18
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
19
|
+
}
|
|
20
|
+
Object.defineProperty(o, k2, desc);
|
|
21
|
+
}) : (function(o, m, k, k2) {
|
|
22
|
+
if (k2 === undefined) k2 = k;
|
|
23
|
+
o[k2] = m[k];
|
|
24
|
+
}));
|
|
25
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
26
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
27
|
+
}) : function(o, v) {
|
|
28
|
+
o["default"] = v;
|
|
29
|
+
});
|
|
30
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
31
|
+
var ownKeys = function(o) {
|
|
32
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
33
|
+
var ar = [];
|
|
34
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
35
|
+
return ar;
|
|
36
|
+
};
|
|
37
|
+
return ownKeys(o);
|
|
38
|
+
};
|
|
39
|
+
return function (mod) {
|
|
40
|
+
if (mod && mod.__esModule) return mod;
|
|
41
|
+
var result = {};
|
|
42
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
43
|
+
__setModuleDefault(result, mod);
|
|
44
|
+
return result;
|
|
45
|
+
};
|
|
46
|
+
})();
|
|
47
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
48
|
+
exports.DrawingCanvas = DrawingCanvas;
|
|
49
|
+
const react_1 = __importStar(require("react"));
|
|
50
|
+
const types_js_1 = require("./types.js");
|
|
51
|
+
const useDrawingOperations_js_1 = require("./useDrawingOperations.js");
|
|
52
|
+
// ---------------------------------------------------------------------------
|
|
53
|
+
// Arrow head helper
|
|
54
|
+
// ---------------------------------------------------------------------------
|
|
55
|
+
function buildArrowHeadPath(skia, from, to, headLength) {
|
|
56
|
+
const angle = Math.atan2(to.y - from.y, to.x - from.x);
|
|
57
|
+
const headAngle = Math.PI / 6; // 30 degrees
|
|
58
|
+
const p1x = to.x - headLength * Math.cos(angle - headAngle);
|
|
59
|
+
const p1y = to.y - headLength * Math.sin(angle - headAngle);
|
|
60
|
+
const p2x = to.x - headLength * Math.cos(angle + headAngle);
|
|
61
|
+
const p2y = to.y - headLength * Math.sin(angle + headAngle);
|
|
62
|
+
const path = skia.Path.Make();
|
|
63
|
+
path.moveTo(to.x, to.y);
|
|
64
|
+
path.lineTo(p1x, p1y);
|
|
65
|
+
path.moveTo(to.x, to.y);
|
|
66
|
+
path.lineTo(p2x, p2y);
|
|
67
|
+
return path;
|
|
68
|
+
}
|
|
69
|
+
// ---------------------------------------------------------------------------
|
|
70
|
+
// Build an SkPath from freehand points
|
|
71
|
+
// ---------------------------------------------------------------------------
|
|
72
|
+
function buildFreehandPath(skia, points) {
|
|
73
|
+
const path = skia.Path.Make();
|
|
74
|
+
if (points.length === 0)
|
|
75
|
+
return path;
|
|
76
|
+
const first = points[0];
|
|
77
|
+
path.moveTo(first.x, first.y);
|
|
78
|
+
for (let i = 1; i < points.length; i++) {
|
|
79
|
+
const pt = points[i];
|
|
80
|
+
path.lineTo(pt.x, pt.y);
|
|
81
|
+
}
|
|
82
|
+
return path;
|
|
83
|
+
}
|
|
84
|
+
const TOOL_LABELS = {
|
|
85
|
+
pen: 'Pen',
|
|
86
|
+
rectangle: 'Rect',
|
|
87
|
+
arrow: 'Arrow',
|
|
88
|
+
circle: 'Circle',
|
|
89
|
+
eraser: 'Eraser',
|
|
90
|
+
};
|
|
91
|
+
const TOOLS = ['pen', 'rectangle', 'arrow', 'circle', 'eraser'];
|
|
92
|
+
const SIZES = ['thin', 'medium', 'thick'];
|
|
93
|
+
function Toolbar({ rn, tool, color, strokeSize, canUndo, canRedo, onSetTool, onSetColor, onSetStrokeSize, onUndo, onRedo, onDone, onCancel, }) {
|
|
94
|
+
const { View, Text, TouchableOpacity, StyleSheet } = rn;
|
|
95
|
+
const styles = (0, react_1.useMemo)(() => StyleSheet.create({
|
|
96
|
+
container: {
|
|
97
|
+
position: 'absolute',
|
|
98
|
+
bottom: 0,
|
|
99
|
+
left: 0,
|
|
100
|
+
right: 0,
|
|
101
|
+
backgroundColor: 'rgba(0, 0, 0, 0.85)',
|
|
102
|
+
paddingBottom: 34, // safe area
|
|
103
|
+
paddingTop: 8,
|
|
104
|
+
paddingHorizontal: 12,
|
|
105
|
+
},
|
|
106
|
+
row: {
|
|
107
|
+
flexDirection: 'row',
|
|
108
|
+
alignItems: 'center',
|
|
109
|
+
justifyContent: 'center',
|
|
110
|
+
marginVertical: 4,
|
|
111
|
+
flexWrap: 'wrap',
|
|
112
|
+
gap: 6,
|
|
113
|
+
},
|
|
114
|
+
button: {
|
|
115
|
+
paddingHorizontal: 10,
|
|
116
|
+
paddingVertical: 6,
|
|
117
|
+
borderRadius: 6,
|
|
118
|
+
backgroundColor: 'rgba(255,255,255,0.15)',
|
|
119
|
+
marginHorizontal: 2,
|
|
120
|
+
},
|
|
121
|
+
buttonActive: {
|
|
122
|
+
paddingHorizontal: 10,
|
|
123
|
+
paddingVertical: 6,
|
|
124
|
+
borderRadius: 6,
|
|
125
|
+
backgroundColor: 'rgba(255,255,255,0.4)',
|
|
126
|
+
marginHorizontal: 2,
|
|
127
|
+
},
|
|
128
|
+
buttonDisabled: {
|
|
129
|
+
paddingHorizontal: 10,
|
|
130
|
+
paddingVertical: 6,
|
|
131
|
+
borderRadius: 6,
|
|
132
|
+
backgroundColor: 'rgba(255,255,255,0.05)',
|
|
133
|
+
marginHorizontal: 2,
|
|
134
|
+
opacity: 0.4,
|
|
135
|
+
},
|
|
136
|
+
buttonText: {
|
|
137
|
+
color: '#FFFFFF',
|
|
138
|
+
fontSize: 12,
|
|
139
|
+
fontWeight: '600',
|
|
140
|
+
},
|
|
141
|
+
colorSwatch: {
|
|
142
|
+
width: 28,
|
|
143
|
+
height: 28,
|
|
144
|
+
borderRadius: 14,
|
|
145
|
+
marginHorizontal: 3,
|
|
146
|
+
borderWidth: 2,
|
|
147
|
+
borderColor: 'transparent',
|
|
148
|
+
},
|
|
149
|
+
colorSwatchActive: {
|
|
150
|
+
width: 28,
|
|
151
|
+
height: 28,
|
|
152
|
+
borderRadius: 14,
|
|
153
|
+
marginHorizontal: 3,
|
|
154
|
+
borderWidth: 2,
|
|
155
|
+
borderColor: '#FFFFFF',
|
|
156
|
+
},
|
|
157
|
+
actionRow: {
|
|
158
|
+
flexDirection: 'row',
|
|
159
|
+
justifyContent: 'space-between',
|
|
160
|
+
alignItems: 'center',
|
|
161
|
+
marginTop: 4,
|
|
162
|
+
paddingHorizontal: 4,
|
|
163
|
+
},
|
|
164
|
+
cancelButton: {
|
|
165
|
+
paddingHorizontal: 16,
|
|
166
|
+
paddingVertical: 8,
|
|
167
|
+
borderRadius: 6,
|
|
168
|
+
backgroundColor: 'rgba(255,60,60,0.3)',
|
|
169
|
+
},
|
|
170
|
+
doneButton: {
|
|
171
|
+
paddingHorizontal: 16,
|
|
172
|
+
paddingVertical: 8,
|
|
173
|
+
borderRadius: 6,
|
|
174
|
+
backgroundColor: 'rgba(60,180,60,0.5)',
|
|
175
|
+
},
|
|
176
|
+
}), [StyleSheet]);
|
|
177
|
+
return react_1.default.createElement(View, { style: styles.container, pointerEvents: 'box-none' },
|
|
178
|
+
// Row 1: Tool selection
|
|
179
|
+
react_1.default.createElement(View, { style: styles.row }, ...TOOLS.map((t) => react_1.default.createElement(TouchableOpacity, {
|
|
180
|
+
key: t,
|
|
181
|
+
style: t === tool ? styles.buttonActive : styles.button,
|
|
182
|
+
onPress: () => onSetTool(t),
|
|
183
|
+
}, react_1.default.createElement(Text, { style: styles.buttonText }, TOOL_LABELS[t]))),
|
|
184
|
+
// Undo / Redo
|
|
185
|
+
react_1.default.createElement(TouchableOpacity, {
|
|
186
|
+
key: 'undo',
|
|
187
|
+
style: canUndo ? styles.button : styles.buttonDisabled,
|
|
188
|
+
onPress: onUndo,
|
|
189
|
+
disabled: !canUndo,
|
|
190
|
+
}, react_1.default.createElement(Text, { style: styles.buttonText }, 'Undo')), react_1.default.createElement(TouchableOpacity, {
|
|
191
|
+
key: 'redo',
|
|
192
|
+
style: canRedo ? styles.button : styles.buttonDisabled,
|
|
193
|
+
onPress: onRedo,
|
|
194
|
+
disabled: !canRedo,
|
|
195
|
+
}, react_1.default.createElement(Text, { style: styles.buttonText }, 'Redo'))),
|
|
196
|
+
// Row 2: Color palette
|
|
197
|
+
react_1.default.createElement(View, { style: styles.row }, ...types_js_1.DRAWING_COLORS.map((c) => react_1.default.createElement(TouchableOpacity, {
|
|
198
|
+
key: c,
|
|
199
|
+
style: {
|
|
200
|
+
...(c === color ? styles.colorSwatchActive : styles.colorSwatch),
|
|
201
|
+
backgroundColor: c,
|
|
202
|
+
},
|
|
203
|
+
onPress: () => onSetColor(c),
|
|
204
|
+
}))),
|
|
205
|
+
// Row 3: Stroke size
|
|
206
|
+
react_1.default.createElement(View, { style: styles.row }, ...SIZES.map((s) => react_1.default.createElement(TouchableOpacity, {
|
|
207
|
+
key: s,
|
|
208
|
+
style: s === strokeSize ? styles.buttonActive : styles.button,
|
|
209
|
+
onPress: () => onSetStrokeSize(s),
|
|
210
|
+
}, react_1.default.createElement(Text, { style: styles.buttonText }, `${s.charAt(0).toUpperCase()}${s.slice(1)} (${types_js_1.STROKE_WIDTHS[s]}px)`)))),
|
|
211
|
+
// Row 4: Cancel / Done
|
|
212
|
+
react_1.default.createElement(View, { style: styles.actionRow }, react_1.default.createElement(TouchableOpacity, { style: styles.cancelButton, onPress: onCancel }, react_1.default.createElement(Text, { style: styles.buttonText }, 'Cancel')), react_1.default.createElement(TouchableOpacity, { style: styles.doneButton, onPress: onDone }, react_1.default.createElement(Text, { style: styles.buttonText }, 'Done'))));
|
|
213
|
+
}
|
|
214
|
+
// ---------------------------------------------------------------------------
|
|
215
|
+
// DrawingCanvas — Main exported component
|
|
216
|
+
// ---------------------------------------------------------------------------
|
|
217
|
+
/**
|
|
218
|
+
* Full-screen Skia annotation canvas.
|
|
219
|
+
*
|
|
220
|
+
* Renders the screenshot as background image, supports freehand pen drawing,
|
|
221
|
+
* rectangle, arrow, circle, and eraser tools with undo/redo.
|
|
222
|
+
*
|
|
223
|
+
* Requires `@shopify/react-native-skia` to be installed in the host app.
|
|
224
|
+
* If Skia is not available, a helpful fallback error message is shown.
|
|
225
|
+
*/
|
|
226
|
+
function DrawingCanvas(props) {
|
|
227
|
+
const { screenshot, dimensions, onDone, onCancel } = props;
|
|
228
|
+
// ---- Module loading state ----
|
|
229
|
+
const [skia, setSkia] = (0, react_1.useState)(null);
|
|
230
|
+
const [rnMod, setRnMod] = (0, react_1.useState)(null);
|
|
231
|
+
const [loadError, setLoadError] = (0, react_1.useState)(null);
|
|
232
|
+
const [backgroundImage, setBackgroundImage] = (0, react_1.useState)(null);
|
|
233
|
+
// ---- Drawing state (pure logic) ----
|
|
234
|
+
const [drawState, drawActions] = (0, useDrawingOperations_js_1.useDrawingOperations)();
|
|
235
|
+
// Canvas ref for snapshot export
|
|
236
|
+
const canvasRefHolder = (0, react_1.useRef)({
|
|
237
|
+
current: null,
|
|
238
|
+
});
|
|
239
|
+
// ---- Load peer dependencies at mount ----
|
|
240
|
+
(0, react_1.useEffect)(() => {
|
|
241
|
+
let cancelled = false;
|
|
242
|
+
async function loadModules() {
|
|
243
|
+
try {
|
|
244
|
+
const [skiaMod, rnModule] = await Promise.all([
|
|
245
|
+
import('@shopify/react-native-skia'),
|
|
246
|
+
import('react-native'),
|
|
247
|
+
]);
|
|
248
|
+
if (cancelled)
|
|
249
|
+
return;
|
|
250
|
+
setSkia(skiaMod);
|
|
251
|
+
setRnMod(rnModule);
|
|
252
|
+
}
|
|
253
|
+
catch {
|
|
254
|
+
if (cancelled)
|
|
255
|
+
return;
|
|
256
|
+
setLoadError('@shopify/react-native-skia is required for annotation but is not installed. ' +
|
|
257
|
+
'Install it with: npx expo install @shopify/react-native-skia');
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
void loadModules();
|
|
261
|
+
return () => {
|
|
262
|
+
cancelled = true;
|
|
263
|
+
};
|
|
264
|
+
}, []);
|
|
265
|
+
// ---- Decode screenshot into Skia image ----
|
|
266
|
+
(0, react_1.useEffect)(() => {
|
|
267
|
+
if (!skia || !screenshot)
|
|
268
|
+
return;
|
|
269
|
+
try {
|
|
270
|
+
const data = skia.Skia.Data.fromBase64(screenshot);
|
|
271
|
+
const img = skia.makeImageFromEncoded(data);
|
|
272
|
+
setBackgroundImage(img);
|
|
273
|
+
}
|
|
274
|
+
catch {
|
|
275
|
+
// If decoding fails, we proceed without a background
|
|
276
|
+
setBackgroundImage(null);
|
|
277
|
+
}
|
|
278
|
+
}, [skia, screenshot]);
|
|
279
|
+
// ---- Initialize canvas ref via Skia hook ----
|
|
280
|
+
// We cannot call hooks conditionally, so we track whether Skia loaded
|
|
281
|
+
// and skip rendering if it hasn't.
|
|
282
|
+
// ---- compositeImage: export canvas as base64 ----
|
|
283
|
+
const compositeImage = (0, react_1.useCallback)(() => {
|
|
284
|
+
const ref = canvasRefHolder.current.current;
|
|
285
|
+
if (!ref)
|
|
286
|
+
return null;
|
|
287
|
+
try {
|
|
288
|
+
const snapshot = ref.makeImageSnapshot();
|
|
289
|
+
return snapshot.encodeToBase64('png', 100);
|
|
290
|
+
}
|
|
291
|
+
catch {
|
|
292
|
+
return null;
|
|
293
|
+
}
|
|
294
|
+
}, []);
|
|
295
|
+
const handleDone = (0, react_1.useCallback)(() => {
|
|
296
|
+
const annotated = compositeImage();
|
|
297
|
+
onDone(annotated ?? screenshot, screenshot);
|
|
298
|
+
}, [compositeImage, onDone, screenshot]);
|
|
299
|
+
// ---- PanResponder for touch drawing ----
|
|
300
|
+
const panResponderRef = (0, react_1.useRef)(null);
|
|
301
|
+
(0, react_1.useEffect)(() => {
|
|
302
|
+
if (!rnMod)
|
|
303
|
+
return;
|
|
304
|
+
panResponderRef.current = rnMod.PanResponder.create({
|
|
305
|
+
onStartShouldSetPanResponder: () => true,
|
|
306
|
+
onMoveShouldSetPanResponder: () => true,
|
|
307
|
+
onPanResponderGrant: (evt) => {
|
|
308
|
+
drawActions.startOperation({
|
|
309
|
+
x: evt.nativeEvent.locationX,
|
|
310
|
+
y: evt.nativeEvent.locationY,
|
|
311
|
+
});
|
|
312
|
+
},
|
|
313
|
+
onPanResponderMove: (evt) => {
|
|
314
|
+
drawActions.continueOperation({
|
|
315
|
+
x: evt.nativeEvent.locationX,
|
|
316
|
+
y: evt.nativeEvent.locationY,
|
|
317
|
+
});
|
|
318
|
+
},
|
|
319
|
+
onPanResponderRelease: () => {
|
|
320
|
+
drawActions.endOperation();
|
|
321
|
+
},
|
|
322
|
+
});
|
|
323
|
+
}, [rnMod, drawActions]);
|
|
324
|
+
// ---- Render: loading / error / canvas ----
|
|
325
|
+
// Fallback if modules not loaded yet
|
|
326
|
+
if (loadError) {
|
|
327
|
+
// Cannot render React Native components since the module failed to load.
|
|
328
|
+
// Call onCancel to dismiss and let the consumer handle the error.
|
|
329
|
+
// eslint-disable-next-line no-console
|
|
330
|
+
console.error('[ShakeNbake]', loadError);
|
|
331
|
+
return null;
|
|
332
|
+
}
|
|
333
|
+
if (!skia || !rnMod) {
|
|
334
|
+
// Still loading
|
|
335
|
+
return null;
|
|
336
|
+
}
|
|
337
|
+
const { Canvas, Image: SkiaImageComponent, Path: SkiaPathComponent, Rect: SkiaRectComponent, Circle: SkiaCircleComponent, Line: SkiaLineComponent, Skia: SkiaStatic, } = skia;
|
|
338
|
+
const { View } = rnMod;
|
|
339
|
+
// ---- Render a single DrawingOperation as Skia elements ----
|
|
340
|
+
function renderOperation(op) {
|
|
341
|
+
const key = `op-${op.id}`;
|
|
342
|
+
switch (op.tool) {
|
|
343
|
+
case 'pen':
|
|
344
|
+
case 'eraser': {
|
|
345
|
+
if (!op.points || op.points.length === 0)
|
|
346
|
+
return null;
|
|
347
|
+
const path = buildFreehandPath(SkiaStatic, op.points);
|
|
348
|
+
return react_1.default.createElement(SkiaPathComponent, {
|
|
349
|
+
key,
|
|
350
|
+
path,
|
|
351
|
+
color: op.tool === 'eraser' ? '#000000' : op.color,
|
|
352
|
+
style: 'stroke',
|
|
353
|
+
strokeWidth: op.tool === 'eraser' ? op.strokeWidth * 3 : op.strokeWidth,
|
|
354
|
+
strokeCap: 'round',
|
|
355
|
+
strokeJoin: 'round',
|
|
356
|
+
});
|
|
357
|
+
}
|
|
358
|
+
case 'rectangle': {
|
|
359
|
+
if (!op.startPoint || !op.endPoint)
|
|
360
|
+
return null;
|
|
361
|
+
const x = Math.min(op.startPoint.x, op.endPoint.x);
|
|
362
|
+
const y = Math.min(op.startPoint.y, op.endPoint.y);
|
|
363
|
+
const w = Math.abs(op.endPoint.x - op.startPoint.x);
|
|
364
|
+
const h = Math.abs(op.endPoint.y - op.startPoint.y);
|
|
365
|
+
return react_1.default.createElement(SkiaRectComponent, {
|
|
366
|
+
key,
|
|
367
|
+
x,
|
|
368
|
+
y,
|
|
369
|
+
width: w,
|
|
370
|
+
height: h,
|
|
371
|
+
color: op.color,
|
|
372
|
+
style: 'stroke',
|
|
373
|
+
strokeWidth: op.strokeWidth,
|
|
374
|
+
});
|
|
375
|
+
}
|
|
376
|
+
case 'arrow': {
|
|
377
|
+
if (!op.startPoint || !op.endPoint)
|
|
378
|
+
return null;
|
|
379
|
+
const headLen = Math.max(12, op.strokeWidth * 4);
|
|
380
|
+
const arrowHead = buildArrowHeadPath(SkiaStatic, op.startPoint, op.endPoint, headLen);
|
|
381
|
+
return react_1.default.createElement(react_1.default.Fragment, { key }, react_1.default.createElement(SkiaLineComponent, {
|
|
382
|
+
p1: op.startPoint,
|
|
383
|
+
p2: op.endPoint,
|
|
384
|
+
color: op.color,
|
|
385
|
+
style: 'stroke',
|
|
386
|
+
strokeWidth: op.strokeWidth,
|
|
387
|
+
strokeCap: 'round',
|
|
388
|
+
}), react_1.default.createElement(SkiaPathComponent, {
|
|
389
|
+
path: arrowHead,
|
|
390
|
+
color: op.color,
|
|
391
|
+
style: 'stroke',
|
|
392
|
+
strokeWidth: op.strokeWidth,
|
|
393
|
+
strokeCap: 'round',
|
|
394
|
+
}));
|
|
395
|
+
}
|
|
396
|
+
case 'circle': {
|
|
397
|
+
if (!op.startPoint || !op.endPoint)
|
|
398
|
+
return null;
|
|
399
|
+
const cx = op.startPoint.x;
|
|
400
|
+
const cy = op.startPoint.y;
|
|
401
|
+
const r = Math.sqrt((op.endPoint.x - cx) ** 2 + (op.endPoint.y - cy) ** 2);
|
|
402
|
+
return react_1.default.createElement(SkiaCircleComponent, {
|
|
403
|
+
key,
|
|
404
|
+
cx,
|
|
405
|
+
cy,
|
|
406
|
+
r,
|
|
407
|
+
color: op.color,
|
|
408
|
+
style: 'stroke',
|
|
409
|
+
strokeWidth: op.strokeWidth,
|
|
410
|
+
});
|
|
411
|
+
}
|
|
412
|
+
default:
|
|
413
|
+
return null;
|
|
414
|
+
}
|
|
415
|
+
}
|
|
416
|
+
// ---- All operations to render (completed + current in-progress) ----
|
|
417
|
+
const allOperations = drawState.currentOperation
|
|
418
|
+
? [...drawState.operations, drawState.currentOperation]
|
|
419
|
+
: drawState.operations;
|
|
420
|
+
// ---- Component tree ----
|
|
421
|
+
// We use React.createElement throughout because JSX for Skia/RN components
|
|
422
|
+
// loaded dynamically would require more complex typing.
|
|
423
|
+
return react_1.default.createElement(View, {
|
|
424
|
+
style: {
|
|
425
|
+
flex: 1,
|
|
426
|
+
backgroundColor: '#000000',
|
|
427
|
+
},
|
|
428
|
+
},
|
|
429
|
+
// Drawing surface with PanResponder
|
|
430
|
+
react_1.default.createElement(View, {
|
|
431
|
+
style: {
|
|
432
|
+
width: dimensions.width,
|
|
433
|
+
height: dimensions.height,
|
|
434
|
+
},
|
|
435
|
+
...(panResponderRef.current?.panHandlers ?? {}),
|
|
436
|
+
}, react_1.default.createElement(Canvas, {
|
|
437
|
+
ref: (ref) => {
|
|
438
|
+
canvasRefHolder.current.current = ref;
|
|
439
|
+
},
|
|
440
|
+
style: {
|
|
441
|
+
width: dimensions.width,
|
|
442
|
+
height: dimensions.height,
|
|
443
|
+
},
|
|
444
|
+
},
|
|
445
|
+
// Background screenshot
|
|
446
|
+
backgroundImage
|
|
447
|
+
? react_1.default.createElement(SkiaImageComponent, {
|
|
448
|
+
image: backgroundImage,
|
|
449
|
+
x: 0,
|
|
450
|
+
y: 0,
|
|
451
|
+
width: dimensions.width,
|
|
452
|
+
height: dimensions.height,
|
|
453
|
+
fit: 'contain',
|
|
454
|
+
})
|
|
455
|
+
: null,
|
|
456
|
+
// All drawing operations
|
|
457
|
+
...allOperations.map(renderOperation))),
|
|
458
|
+
// Toolbar overlay
|
|
459
|
+
react_1.default.createElement(Toolbar, {
|
|
460
|
+
rn: rnMod,
|
|
461
|
+
tool: drawState.tool,
|
|
462
|
+
color: drawState.color,
|
|
463
|
+
strokeSize: drawState.strokeSize,
|
|
464
|
+
canUndo: drawState.canUndo,
|
|
465
|
+
canRedo: drawState.canRedo,
|
|
466
|
+
onSetTool: drawActions.setTool,
|
|
467
|
+
onSetColor: drawActions.setColor,
|
|
468
|
+
onSetStrokeSize: drawActions.setStrokeSize,
|
|
469
|
+
onUndo: drawActions.undo,
|
|
470
|
+
onRedo: drawActions.redo,
|
|
471
|
+
onDone: handleDone,
|
|
472
|
+
onCancel,
|
|
473
|
+
}));
|
|
474
|
+
}
|
|
475
|
+
//# sourceMappingURL=DrawingCanvas.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DrawingCanvas.js","sourceRoot":"","sources":["../../src/annotate/DrawingCanvas.tsx"],"names":[],"mappings":"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"}
|