@operato/input 8.0.0-alpha.1 → 8.0.0-alpha.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.md +10 -0
- package/dist/src/ox-input-signature.d.ts +5 -1
- package/dist/src/ox-input-signature.js +46 -32
- package/dist/src/ox-input-signature.js.map +1 -1
- package/dist/stories/ox-input-/bsignature.stories.d.ts +4 -2
- package/dist/stories/ox-input-/bsignature.stories.js +8 -4
- package/dist/stories/ox-input-/bsignature.stories.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +2 -2
- package/src/ox-input-signature.ts +49 -32
- package/stories/ox-input-/bsignature.stories.ts +10 -6
package/package.json
CHANGED
@@ -2,7 +2,7 @@
|
|
2
2
|
"name": "@operato/input",
|
3
3
|
"description": "Webcomponents for input following open-wc recommendations",
|
4
4
|
"author": "heartyoh@hatiolab.com",
|
5
|
-
"version": "8.0.0-alpha.
|
5
|
+
"version": "8.0.0-alpha.2",
|
6
6
|
"main": "dist/src/index.js",
|
7
7
|
"module": "dist/src/index.js",
|
8
8
|
"license": "MIT",
|
@@ -258,5 +258,5 @@
|
|
258
258
|
"prettier --write"
|
259
259
|
]
|
260
260
|
},
|
261
|
-
"gitHead": "
|
261
|
+
"gitHead": "868f7fd1dfcf1758b0fd8f8c7f198489b3b3bbf8"
|
262
262
|
}
|
@@ -29,9 +29,19 @@ export class OxInputSignature extends OxFormField {
|
|
29
29
|
overflow: hidden;
|
30
30
|
}
|
31
31
|
|
32
|
-
|
32
|
+
.signature-preview {
|
33
|
+
flex: 1;
|
34
|
+
|
35
|
+
border: 1px solid var(--md-sys-color-outline);
|
36
|
+
background-size: contain;
|
37
|
+
background-repeat: no-repeat;
|
38
|
+
background-position: center;
|
39
|
+
}
|
40
|
+
|
41
|
+
dialog canvas {
|
33
42
|
width: 100%;
|
34
|
-
|
43
|
+
height: 100%;
|
44
|
+
border: 1px solid var(--md-sys-color-outline);
|
35
45
|
}
|
36
46
|
|
37
47
|
.controls {
|
@@ -45,46 +55,56 @@ export class OxInputSignature extends OxFormField {
|
|
45
55
|
|
46
56
|
private ctx!: CanvasRenderingContext2D
|
47
57
|
private canvas!: HTMLCanvasElement
|
58
|
+
private dialog!: HTMLDialogElement
|
59
|
+
private previewDiv!: HTMLDivElement
|
60
|
+
private previewCtx!: CanvasRenderingContext2D
|
48
61
|
|
49
62
|
render() {
|
50
63
|
return html`
|
51
|
-
<
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
</
|
68
|
-
|
64
|
+
<div class="signature-preview" @click=${this.openDialog}></div>
|
65
|
+
|
66
|
+
<dialog>
|
67
|
+
<canvas
|
68
|
+
width="800"
|
69
|
+
height="400"
|
70
|
+
@mousedown=${this.startDrawing}
|
71
|
+
@mouseup=${this.stopDrawing}
|
72
|
+
@mousemove=${this.draw}
|
73
|
+
@mouseleave=${this.stopDrawing}
|
74
|
+
@touchstart=${this.startDrawing}
|
75
|
+
@touchend=${this.stopDrawing}
|
76
|
+
@touchmove=${this.draw}
|
77
|
+
></canvas>
|
78
|
+
<div class="controls">
|
79
|
+
<button @click="${this.clearCanvas}">Clear</button>
|
80
|
+
<button @click="${this.saveSignature}">Save</button>
|
81
|
+
<button @click="${this.closeDialog}">Close</button>
|
82
|
+
</div>
|
83
|
+
</dialog>
|
69
84
|
`
|
70
85
|
}
|
71
86
|
|
72
87
|
firstUpdated() {
|
73
|
-
this.
|
88
|
+
this.previewDiv = this.shadowRoot!.querySelector('.signature-preview')!
|
89
|
+
this.dialog = this.shadowRoot!.querySelector('dialog')!
|
90
|
+
this.canvas = this.dialog.querySelector('canvas')!
|
74
91
|
this.ctx = this.canvas.getContext('2d')!
|
75
92
|
this.ctx.strokeStyle = '#000'
|
76
93
|
this.ctx.lineWidth = 2
|
77
94
|
|
78
|
-
// 처음 로딩 시 서명 데이터를
|
95
|
+
// 처음 로딩 시 서명 데이터를 미리보기 div에 표시
|
79
96
|
if (this.value) {
|
80
97
|
this.loadSignature(this.value)
|
81
98
|
}
|
82
99
|
}
|
83
100
|
|
84
|
-
|
85
|
-
if (
|
86
|
-
|
87
|
-
|
101
|
+
openDialog() {
|
102
|
+
if (this.disabled) return
|
103
|
+
this.dialog.showModal()
|
104
|
+
}
|
105
|
+
|
106
|
+
closeDialog() {
|
107
|
+
this.dialog.close()
|
88
108
|
}
|
89
109
|
|
90
110
|
startDrawing(event: MouseEvent | TouchEvent) {
|
@@ -116,15 +136,12 @@ export class OxInputSignature extends OxFormField {
|
|
116
136
|
saveSignature() {
|
117
137
|
this.value = this.canvas.toDataURL()
|
118
138
|
this._notifyChange()
|
139
|
+
this.previewDiv.style.backgroundImage = `url(${this.value})`
|
140
|
+
this.closeDialog()
|
119
141
|
}
|
120
142
|
|
121
143
|
loadSignature(dataUrl: string) {
|
122
|
-
|
123
|
-
image.onload = () => {
|
124
|
-
this.ctx.clearRect(0, 0, this.canvas.width, this.canvas.height) // 이전 내용을 지움
|
125
|
-
this.ctx.drawImage(image, 0, 0) // 이미지를 캔버스에 그림
|
126
|
-
}
|
127
|
-
image.src = dataUrl
|
144
|
+
this.previewDiv.style.backgroundImage = `url(${dataUrl})`
|
128
145
|
}
|
129
146
|
|
130
147
|
getEventPosition(event: MouseEvent | TouchEvent) {
|
@@ -7,7 +7,8 @@ export default {
|
|
7
7
|
title: 'ox-input-signature',
|
8
8
|
component: 'ox-input-signature',
|
9
9
|
argTypes: {
|
10
|
-
disabled: { control: 'boolean' }
|
10
|
+
disabled: { control: 'boolean' },
|
11
|
+
value: { control: 'text' }
|
11
12
|
}
|
12
13
|
}
|
13
14
|
|
@@ -18,12 +19,11 @@ interface Story<T> {
|
|
18
19
|
}
|
19
20
|
|
20
21
|
interface ArgTypes {
|
21
|
-
|
22
|
-
name?: string
|
22
|
+
value?: string
|
23
23
|
disabled?: boolean
|
24
24
|
}
|
25
25
|
|
26
|
-
const Template: Story<ArgTypes> = ({
|
26
|
+
const Template: Story<ArgTypes> = ({ value, disabled }: ArgTypes) => html`
|
27
27
|
<link href="https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap" rel="stylesheet" />
|
28
28
|
|
29
29
|
<link href="/themes/light.css" rel="stylesheet" />
|
@@ -49,7 +49,7 @@ const Template: Story<ArgTypes> = ({ label = 'signature', name = 'signature', di
|
|
49
49
|
|
50
50
|
<style>
|
51
51
|
.container {
|
52
|
-
height:
|
52
|
+
height: 600px;
|
53
53
|
text-align: center;
|
54
54
|
padding: 20px;
|
55
55
|
|
@@ -60,6 +60,7 @@ const Template: Story<ArgTypes> = ({ label = 'signature', name = 'signature', di
|
|
60
60
|
|
61
61
|
<div class="container md-typescale-body-large-prominent">
|
62
62
|
<ox-input-signature
|
63
|
+
.value=${value || ''}
|
63
64
|
?disabled=${disabled}
|
64
65
|
@change=${(e: Event) => console.log(((e as CustomEvent).target as any)!.value)}
|
65
66
|
>
|
@@ -68,4 +69,7 @@ const Template: Story<ArgTypes> = ({ label = 'signature', name = 'signature', di
|
|
68
69
|
`
|
69
70
|
|
70
71
|
export const Regular = Template.bind({})
|
71
|
-
Regular.args = {
|
72
|
+
Regular.args = {
|
73
|
+
value:
|
74
|
+
''
|
75
|
+
}
|