@operato/input 7.1.3 → 8.0.0-alpha.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/CHANGELOG.md +5 -7
- package/dist/src/ox-input-signature.d.ts +1 -5
- package/dist/src/ox-input-signature.js +32 -46
- package/dist/src/ox-input-signature.js.map +1 -1
- package/dist/stories/ox-input-/bsignature.stories.d.ts +2 -4
- package/dist/stories/ox-input-/bsignature.stories.js +4 -8
- package/dist/stories/ox-input-/bsignature.stories.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +7 -7
- package/src/ox-input-signature.ts +32 -49
- package/stories/ox-input-/bsignature.stories.ts +6 -10
package/CHANGELOG.md
CHANGED
@@ -3,23 +3,21 @@
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
5
5
|
|
6
|
-
|
6
|
+
## [8.0.0-alpha.1](https://github.com/hatiolab/operato/compare/v8.0.0-alpha.0...v8.0.0-alpha.1) (2024-09-04)
|
7
7
|
|
8
8
|
|
9
9
|
### :bug: Bug Fix
|
10
10
|
|
11
|
-
*
|
12
|
-
*
|
11
|
+
* input signature ([7ff5330](https://github.com/hatiolab/operato/commit/7ff53307b2f0b5ffb41027dd1066fefbc341e628))
|
12
|
+
* support signature-input type for dataset ([613de5d](https://github.com/hatiolab/operato/commit/613de5dc5c14cc8288d2d19431dda5475c4b3303))
|
13
13
|
|
14
14
|
|
15
15
|
|
16
|
-
|
16
|
+
## [8.0.0-alpha.0](https://github.com/hatiolab/operato/compare/v7.1.1...v8.0.0-alpha.0) (2024-09-01)
|
17
17
|
|
18
|
+
**Note:** Version bump only for package @operato/input
|
18
19
|
|
19
|
-
### :bug: Bug Fix
|
20
20
|
|
21
|
-
* input signature ([aff132e](https://github.com/hatiolab/operato/commit/aff132e06f794c18430ec3cb31691f82e01e7f28))
|
22
|
-
* support signature-input type for dataset ([f9e758e](https://github.com/hatiolab/operato/commit/f9e758eeb5efd6926af9d3526f0d7374e0c1b081))
|
23
21
|
|
24
22
|
|
25
23
|
|
@@ -6,13 +6,9 @@ export declare class OxInputSignature extends OxFormField {
|
|
6
6
|
value: string | null;
|
7
7
|
private ctx;
|
8
8
|
private canvas;
|
9
|
-
private dialog;
|
10
|
-
private previewDiv;
|
11
|
-
private previewCtx;
|
12
9
|
render(): import("lit-html").TemplateResult<1>;
|
13
10
|
firstUpdated(): void;
|
14
|
-
|
15
|
-
closeDialog(): void;
|
11
|
+
updated(changedProperties: Map<string | number | symbol, unknown>): void;
|
16
12
|
startDrawing(event: MouseEvent | TouchEvent): void;
|
17
13
|
stopDrawing(): void;
|
18
14
|
draw(event: MouseEvent | TouchEvent): void;
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { __decorate } from "tslib";
|
2
2
|
import '@material/web/icon/icon.js';
|
3
|
-
import { css, html } from 'lit';
|
3
|
+
import { css, html, nothing } from 'lit';
|
4
4
|
import { customElement, property } from 'lit/decorators.js';
|
5
5
|
import { OxFormField } from './ox-form-field.js';
|
6
6
|
let OxInputSignature = class OxInputSignature extends OxFormField {
|
@@ -31,19 +31,9 @@ let OxInputSignature = class OxInputSignature extends OxFormField {
|
|
31
31
|
overflow: hidden;
|
32
32
|
}
|
33
33
|
|
34
|
-
|
35
|
-
flex: 1;
|
36
|
-
|
37
|
-
border: 1px solid var(--md-sys-color-outline);
|
38
|
-
background-size: contain;
|
39
|
-
background-repeat: no-repeat;
|
40
|
-
background-position: center;
|
41
|
-
}
|
42
|
-
|
43
|
-
dialog canvas {
|
34
|
+
canvas {
|
44
35
|
width: 100%;
|
45
|
-
|
46
|
-
border: 1px solid var(--md-sys-color-outline);
|
36
|
+
border: 1px solid #000;
|
47
37
|
}
|
48
38
|
|
49
39
|
.controls {
|
@@ -53,47 +43,40 @@ let OxInputSignature = class OxInputSignature extends OxFormField {
|
|
53
43
|
]; }
|
54
44
|
render() {
|
55
45
|
return html `
|
56
|
-
<
|
46
|
+
<canvas
|
47
|
+
width="400"
|
48
|
+
height="200"
|
49
|
+
@mousedown=${this.startDrawing}
|
50
|
+
@mouseup=${this.stopDrawing}
|
51
|
+
@mousemove=${this.draw}
|
52
|
+
@mouseleave=${this.stopDrawing}
|
53
|
+
@touchstart=${this.startDrawing}
|
54
|
+
@touchend=${this.stopDrawing}
|
55
|
+
@touchmove=${this.draw}
|
56
|
+
></canvas>
|
57
57
|
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
@mousemove=${this.draw}
|
65
|
-
@mouseleave=${this.stopDrawing}
|
66
|
-
@touchstart=${this.startDrawing}
|
67
|
-
@touchend=${this.stopDrawing}
|
68
|
-
@touchmove=${this.draw}
|
69
|
-
></canvas>
|
70
|
-
<div class="controls">
|
71
|
-
<button @click="${this.clearCanvas}">Clear</button>
|
72
|
-
<button @click="${this.saveSignature}">Save</button>
|
73
|
-
<button @click="${this.closeDialog}">Close</button>
|
74
|
-
</div>
|
75
|
-
</dialog>
|
58
|
+
${!this.disabled
|
59
|
+
? html ` <div class="controls">
|
60
|
+
<button @click="${this.clearCanvas}">Clear</button>
|
61
|
+
<button @click="${this.saveSignature}">Save</button>
|
62
|
+
</div>`
|
63
|
+
: nothing}
|
76
64
|
`;
|
77
65
|
}
|
78
66
|
firstUpdated() {
|
79
|
-
this.
|
80
|
-
this.dialog = this.shadowRoot.querySelector('dialog');
|
81
|
-
this.canvas = this.dialog.querySelector('canvas');
|
67
|
+
this.canvas = this.shadowRoot.querySelector('canvas');
|
82
68
|
this.ctx = this.canvas.getContext('2d');
|
83
69
|
this.ctx.strokeStyle = '#000';
|
84
70
|
this.ctx.lineWidth = 2;
|
85
|
-
// 처음 로딩 시 서명 데이터를
|
71
|
+
// 처음 로딩 시 서명 데이터를 캔버스에 표시
|
86
72
|
if (this.value) {
|
87
73
|
this.loadSignature(this.value);
|
88
74
|
}
|
89
75
|
}
|
90
|
-
|
91
|
-
if (this.
|
92
|
-
|
93
|
-
|
94
|
-
}
|
95
|
-
closeDialog() {
|
96
|
-
this.dialog.close();
|
76
|
+
updated(changedProperties) {
|
77
|
+
if (changedProperties.has('value') && this.value) {
|
78
|
+
this.loadSignature(this.value);
|
79
|
+
}
|
97
80
|
}
|
98
81
|
startDrawing(event) {
|
99
82
|
if (this.disabled) {
|
@@ -120,11 +103,14 @@ let OxInputSignature = class OxInputSignature extends OxFormField {
|
|
120
103
|
saveSignature() {
|
121
104
|
this.value = this.canvas.toDataURL();
|
122
105
|
this._notifyChange();
|
123
|
-
this.previewDiv.style.backgroundImage = `url(${this.value})`;
|
124
|
-
this.closeDialog();
|
125
106
|
}
|
126
107
|
loadSignature(dataUrl) {
|
127
|
-
|
108
|
+
const image = new Image();
|
109
|
+
image.onload = () => {
|
110
|
+
this.ctx.clearRect(0, 0, this.canvas.width, this.canvas.height); // 이전 내용을 지움
|
111
|
+
this.ctx.drawImage(image, 0, 0); // 이미지를 캔버스에 그림
|
112
|
+
};
|
113
|
+
image.src = dataUrl;
|
128
114
|
}
|
129
115
|
getEventPosition(event) {
|
130
116
|
const rect = this.canvas.getBoundingClientRect();
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"ox-input-signature.js","sourceRoot":"","sources":["../../src/ox-input-signature.ts"],"names":[],"mappings":";AAAA,OAAO,4BAA4B,CAAA;AAEnC,OAAO,EAAE,GAAG,EAAE,IAAI,
|
1
|
+
{"version":3,"file":"ox-input-signature.js","sourceRoot":"","sources":["../../src/ox-input-signature.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\n\nimport { css, html, nothing } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\nimport { OxFormField } from './ox-form-field.js'\n\n@customElement('ox-input-signature')\nexport class OxInputSignature extends OxFormField {\n static styles = [\n css`\n :host {\n position: relative;\n box-sizing: border-box;\n\n display: flex;\n flex-direction: column;\n place-content: center;\n border-radius: var(--border-radius);\n padding: var(--padding-default, 9px);\n min-height: 100px;\n text-transform: capitalize;\n\n border: var(--file-uploader-border);\n background-color: var(--md-sys-color-background);\n font: var(--file-uploader-font) !important;\n color: var(--file-uploader-color);\n\n overflow: hidden;\n }\n\n canvas {\n width: 100%;\n border: 1px solid #000;\n }\n\n .controls {\n margin-top: 10px;\n }\n `\n ]\n\n @property({ type: Boolean }) isDrawing = false\n @property({ type: String }) value: string | null = null\n\n private ctx!: CanvasRenderingContext2D\n private canvas!: HTMLCanvasElement\n\n render() {\n return html`\n <canvas\n width=\"400\"\n height=\"200\"\n @mousedown=${this.startDrawing}\n @mouseup=${this.stopDrawing}\n @mousemove=${this.draw}\n @mouseleave=${this.stopDrawing}\n @touchstart=${this.startDrawing}\n @touchend=${this.stopDrawing}\n @touchmove=${this.draw}\n ></canvas>\n\n ${!this.disabled\n ? html` <div class=\"controls\">\n <button @click=\"${this.clearCanvas}\">Clear</button>\n <button @click=\"${this.saveSignature}\">Save</button>\n </div>`\n : nothing}\n `\n }\n\n firstUpdated() {\n this.canvas = this.shadowRoot!.querySelector('canvas')!\n this.ctx = this.canvas.getContext('2d')!\n this.ctx.strokeStyle = '#000'\n this.ctx.lineWidth = 2\n\n // 처음 로딩 시 서명 데이터를 캔버스에 표시\n if (this.value) {\n this.loadSignature(this.value)\n }\n }\n\n updated(changedProperties: Map<string | number | symbol, unknown>) {\n if (changedProperties.has('value') && this.value) {\n this.loadSignature(this.value)\n }\n }\n\n startDrawing(event: MouseEvent | TouchEvent) {\n if (this.disabled) {\n return\n }\n\n this.isDrawing = true\n this.ctx.beginPath()\n const position = this.getEventPosition(event)\n this.ctx.moveTo(position.x, position.y)\n }\n\n stopDrawing() {\n this.isDrawing = false\n }\n\n draw(event: MouseEvent | TouchEvent) {\n if (!this.isDrawing) return\n const position = this.getEventPosition(event)\n this.ctx.lineTo(position.x, position.y)\n this.ctx.stroke()\n }\n\n clearCanvas() {\n this.ctx.clearRect(0, 0, this.canvas.width, this.canvas.height)\n }\n\n saveSignature() {\n this.value = this.canvas.toDataURL()\n this._notifyChange()\n }\n\n loadSignature(dataUrl: string) {\n const image = new Image()\n image.onload = () => {\n this.ctx.clearRect(0, 0, this.canvas.width, this.canvas.height) // 이전 내용을 지움\n this.ctx.drawImage(image, 0, 0) // 이미지를 캔버스에 그림\n }\n image.src = dataUrl\n }\n\n getEventPosition(event: MouseEvent | TouchEvent) {\n const rect = this.canvas.getBoundingClientRect()\n\n // 캔버스의 실제 크기와 CSS 크기 간의 비율을 계산\n const scaleX = this.canvas.width / rect.width\n const scaleY = this.canvas.height / rect.height\n\n // 실제 좌표 계산\n const isTouchEvent = event instanceof TouchEvent\n const x = (isTouchEvent ? event.touches[0].clientX - rect.left : (event as MouseEvent).clientX - rect.left) * scaleX\n const y = (isTouchEvent ? event.touches[0].clientY - rect.top : (event as MouseEvent).clientY - rect.top) * scaleY\n\n return { x, y }\n }\n\n _notifyChange() {\n this.dispatchEvent(\n new CustomEvent('change', {\n bubbles: true,\n composed: true,\n detail: this.value\n })\n )\n }\n}\n"]}
|
@@ -7,9 +7,6 @@ declare const _default: {
|
|
7
7
|
disabled: {
|
8
8
|
control: string;
|
9
9
|
};
|
10
|
-
value: {
|
11
|
-
control: string;
|
12
|
-
};
|
13
10
|
};
|
14
11
|
};
|
15
12
|
export default _default;
|
@@ -19,7 +16,8 @@ interface Story<T> {
|
|
19
16
|
argTypes?: Record<string, unknown>;
|
20
17
|
}
|
21
18
|
interface ArgTypes {
|
22
|
-
|
19
|
+
label?: string;
|
20
|
+
name?: string;
|
23
21
|
disabled?: boolean;
|
24
22
|
}
|
25
23
|
export declare const Regular: Story<ArgTypes>;
|
@@ -5,11 +5,10 @@ export default {
|
|
5
5
|
title: 'ox-input-signature',
|
6
6
|
component: 'ox-input-signature',
|
7
7
|
argTypes: {
|
8
|
-
disabled: { control: 'boolean' }
|
9
|
-
value: { control: 'text' }
|
8
|
+
disabled: { control: 'boolean' }
|
10
9
|
}
|
11
10
|
};
|
12
|
-
const Template = ({
|
11
|
+
const Template = ({ label = 'signature', name = 'signature', disabled }) => html `
|
13
12
|
<link href="https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap" rel="stylesheet" />
|
14
13
|
|
15
14
|
<link href="/themes/light.css" rel="stylesheet" />
|
@@ -35,7 +34,7 @@ const Template = ({ value, disabled }) => html `
|
|
35
34
|
|
36
35
|
<style>
|
37
36
|
.container {
|
38
|
-
height:
|
37
|
+
height: 500px;
|
39
38
|
text-align: center;
|
40
39
|
padding: 20px;
|
41
40
|
|
@@ -46,7 +45,6 @@ const Template = ({ value, disabled }) => html `
|
|
46
45
|
|
47
46
|
<div class="container md-typescale-body-large-prominent">
|
48
47
|
<ox-input-signature
|
49
|
-
.value=${value || ''}
|
50
48
|
?disabled=${disabled}
|
51
49
|
@change=${(e) => console.log(e.target.value)}
|
52
50
|
>
|
@@ -54,7 +52,5 @@ const Template = ({ value, disabled }) => html `
|
|
54
52
|
</div>
|
55
53
|
`;
|
56
54
|
export const Regular = Template.bind({});
|
57
|
-
Regular.args = {
|
58
|
-
value: ''
|
59
|
-
};
|
55
|
+
Regular.args = {};
|
60
56
|
//# sourceMappingURL=ox-input-%08signature.stories.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"ox-input-\bsignature.stories.js","sourceRoot":"","sources":["../../stories/ox-input-\bsignature.stories.ts"],"names":[],"mappings":"AAAA,OAAO,8BAA8B,CAAA;AAErC,OAAO,EAAE,IAAI,EAAkB,MAAM,KAAK,CAAA;AAC1C,OAAO,EAAE,MAAM,IAAI,iBAAiB,EAAE,MAAM,8CAA8C,CAAA;AAE1F,eAAe;IACb,KAAK,EAAE,oBAAoB;IAC3B,SAAS,EAAE,oBAAoB;IAC/B,QAAQ,EAAE;QACR,QAAQ,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE;
|
1
|
+
{"version":3,"file":"ox-input-\bsignature.stories.js","sourceRoot":"","sources":["../../stories/ox-input-\bsignature.stories.ts"],"names":[],"mappings":"AAAA,OAAO,8BAA8B,CAAA;AAErC,OAAO,EAAE,IAAI,EAAkB,MAAM,KAAK,CAAA;AAC1C,OAAO,EAAE,MAAM,IAAI,iBAAiB,EAAE,MAAM,8CAA8C,CAAA;AAE1F,eAAe;IACb,KAAK,EAAE,oBAAoB;IAC3B,SAAS,EAAE,oBAAoB;IAC/B,QAAQ,EAAE;QACR,QAAQ,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE;KACjC;CACF,CAAA;AAcD,MAAM,QAAQ,GAAoB,CAAC,EAAE,KAAK,GAAG,WAAW,EAAE,IAAI,GAAG,WAAW,EAAE,QAAQ,EAAY,EAAE,EAAE,CAAC,IAAI,CAAA;;;;;;;;;;;;;;;;;;;;;MAqBrG,iBAAiB,CAAC,OAAO;;;;;;;;;;;;;;;;kBAgBb,QAAQ;gBACV,CAAC,CAAQ,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAG,CAAiB,CAAC,MAAe,CAAC,KAAK,CAAC;;;;CAInF,CAAA;AAED,MAAM,CAAC,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;AACxC,OAAO,CAAC,IAAI,GAAG,EAAE,CAAA","sourcesContent":["import '../src/ox-input-signature.js'\n\nimport { html, TemplateResult } from 'lit'\nimport { styles as MDTypeScaleStyles } from '@material/web/typography/md-typescale-styles'\n\nexport default {\n title: 'ox-input-signature',\n component: 'ox-input-signature',\n argTypes: {\n disabled: { control: 'boolean' }\n }\n}\n\ninterface Story<T> {\n (args: T): TemplateResult\n args?: Partial<T>\n argTypes?: Record<string, unknown>\n}\n\ninterface ArgTypes {\n label?: string\n name?: string\n disabled?: boolean\n}\n\nconst Template: Story<ArgTypes> = ({ label = 'signature', name = 'signature', disabled }: ArgTypes) => html`\n <link href=\"https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap\" rel=\"stylesheet\" />\n\n <link href=\"/themes/light.css\" rel=\"stylesheet\" />\n <link href=\"/themes/dark.css\" rel=\"stylesheet\" />\n <link href=\"/themes/spacing.css\" rel=\"stylesheet\" />\n\n <link\n href=\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL@20..48,100..700,0..1\"\n rel=\"stylesheet\"\n />\n <link\n href=\"https://fonts.googleapis.com/css2?family=Material+Symbols+Rounded:opsz,wght,FILL@20..48,100..700,0..1\"\n rel=\"stylesheet\"\n />\n <link\n href=\"https://fonts.googleapis.com/css2?family=Material+Symbols+Sharp:opsz,wght,FILL@20..48,100..700,0..1\"\n rel=\"stylesheet\"\n />\n\n <style>\n ${MDTypeScaleStyles.cssText}\n </style>\n\n <style>\n .container {\n height: 500px;\n text-align: center;\n padding: 20px;\n\n background-color: var(--md-sys-color-primary-container);\n color: var(--md-sys-color-on-primary-container);\n }\n </style>\n\n <div class=\"container md-typescale-body-large-prominent\">\n <ox-input-signature\n ?disabled=${disabled}\n @change=${(e: Event) => console.log(((e as CustomEvent).target as any)!.value)}\n >\n </ox-input-signature>\n </div>\n`\n\nexport const Regular = Template.bind({})\nRegular.args = {}\n"]}
|