@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/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": "
|
5
|
+
"version": "8.0.0-alpha.1",
|
6
6
|
"main": "dist/src/index.js",
|
7
7
|
"module": "dist/src/index.js",
|
8
8
|
"license": "MIT",
|
@@ -210,11 +210,11 @@
|
|
210
210
|
"@ctrl/tinycolor": "^4.1.0",
|
211
211
|
"@lit/localize": "^0.12.1",
|
212
212
|
"@material/web": "^2.0.0",
|
213
|
-
"@operato/color-picker": "^
|
214
|
-
"@operato/i18n": "^
|
215
|
-
"@operato/popup": "^
|
216
|
-
"@operato/styles": "^
|
217
|
-
"@operato/utils": "^
|
213
|
+
"@operato/color-picker": "^8.0.0-alpha.0",
|
214
|
+
"@operato/i18n": "^8.0.0-alpha.0",
|
215
|
+
"@operato/popup": "^8.0.0-alpha.0",
|
216
|
+
"@operato/styles": "^8.0.0-alpha.0",
|
217
|
+
"@operato/utils": "^8.0.0-alpha.0",
|
218
218
|
"@polymer/paper-dropdown-menu": "^3.2.0",
|
219
219
|
"@polymer/paper-item": "^3.0.1",
|
220
220
|
"@thebespokepixel/es-tinycolor": "^3.1.0",
|
@@ -258,5 +258,5 @@
|
|
258
258
|
"prettier --write"
|
259
259
|
]
|
260
260
|
},
|
261
|
-
"gitHead": "
|
261
|
+
"gitHead": "7e2725314b1cb79c18f27b5a8db9dccd2461a1a3"
|
262
262
|
}
|
@@ -29,19 +29,9 @@ export class OxInputSignature extends OxFormField {
|
|
29
29
|
overflow: hidden;
|
30
30
|
}
|
31
31
|
|
32
|
-
|
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 {
|
32
|
+
canvas {
|
42
33
|
width: 100%;
|
43
|
-
|
44
|
-
border: 1px solid var(--md-sys-color-outline);
|
34
|
+
border: 1px solid #000;
|
45
35
|
}
|
46
36
|
|
47
37
|
.controls {
|
@@ -55,56 +45,46 @@ export class OxInputSignature extends OxFormField {
|
|
55
45
|
|
56
46
|
private ctx!: CanvasRenderingContext2D
|
57
47
|
private canvas!: HTMLCanvasElement
|
58
|
-
private dialog!: HTMLDialogElement
|
59
|
-
private previewDiv!: HTMLDivElement
|
60
|
-
private previewCtx!: CanvasRenderingContext2D
|
61
48
|
|
62
49
|
render() {
|
63
50
|
return html`
|
64
|
-
<
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
</div>
|
83
|
-
</dialog>
|
51
|
+
<canvas
|
52
|
+
width="400"
|
53
|
+
height="200"
|
54
|
+
@mousedown=${this.startDrawing}
|
55
|
+
@mouseup=${this.stopDrawing}
|
56
|
+
@mousemove=${this.draw}
|
57
|
+
@mouseleave=${this.stopDrawing}
|
58
|
+
@touchstart=${this.startDrawing}
|
59
|
+
@touchend=${this.stopDrawing}
|
60
|
+
@touchmove=${this.draw}
|
61
|
+
></canvas>
|
62
|
+
|
63
|
+
${!this.disabled
|
64
|
+
? html` <div class="controls">
|
65
|
+
<button @click="${this.clearCanvas}">Clear</button>
|
66
|
+
<button @click="${this.saveSignature}">Save</button>
|
67
|
+
</div>`
|
68
|
+
: nothing}
|
84
69
|
`
|
85
70
|
}
|
86
71
|
|
87
72
|
firstUpdated() {
|
88
|
-
this.
|
89
|
-
this.dialog = this.shadowRoot!.querySelector('dialog')!
|
90
|
-
this.canvas = this.dialog.querySelector('canvas')!
|
73
|
+
this.canvas = this.shadowRoot!.querySelector('canvas')!
|
91
74
|
this.ctx = this.canvas.getContext('2d')!
|
92
75
|
this.ctx.strokeStyle = '#000'
|
93
76
|
this.ctx.lineWidth = 2
|
94
77
|
|
95
|
-
// 처음 로딩 시 서명 데이터를
|
78
|
+
// 처음 로딩 시 서명 데이터를 캔버스에 표시
|
96
79
|
if (this.value) {
|
97
80
|
this.loadSignature(this.value)
|
98
81
|
}
|
99
82
|
}
|
100
83
|
|
101
|
-
|
102
|
-
if (this.
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
closeDialog() {
|
107
|
-
this.dialog.close()
|
84
|
+
updated(changedProperties: Map<string | number | symbol, unknown>) {
|
85
|
+
if (changedProperties.has('value') && this.value) {
|
86
|
+
this.loadSignature(this.value)
|
87
|
+
}
|
108
88
|
}
|
109
89
|
|
110
90
|
startDrawing(event: MouseEvent | TouchEvent) {
|
@@ -136,12 +116,15 @@ export class OxInputSignature extends OxFormField {
|
|
136
116
|
saveSignature() {
|
137
117
|
this.value = this.canvas.toDataURL()
|
138
118
|
this._notifyChange()
|
139
|
-
this.previewDiv.style.backgroundImage = `url(${this.value})`
|
140
|
-
this.closeDialog()
|
141
119
|
}
|
142
120
|
|
143
121
|
loadSignature(dataUrl: string) {
|
144
|
-
|
122
|
+
const image = new Image()
|
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
|
145
128
|
}
|
146
129
|
|
147
130
|
getEventPosition(event: MouseEvent | TouchEvent) {
|
@@ -7,8 +7,7 @@ export default {
|
|
7
7
|
title: 'ox-input-signature',
|
8
8
|
component: 'ox-input-signature',
|
9
9
|
argTypes: {
|
10
|
-
disabled: { control: 'boolean' }
|
11
|
-
value: { control: 'text' }
|
10
|
+
disabled: { control: 'boolean' }
|
12
11
|
}
|
13
12
|
}
|
14
13
|
|
@@ -19,11 +18,12 @@ interface Story<T> {
|
|
19
18
|
}
|
20
19
|
|
21
20
|
interface ArgTypes {
|
22
|
-
|
21
|
+
label?: string
|
22
|
+
name?: string
|
23
23
|
disabled?: boolean
|
24
24
|
}
|
25
25
|
|
26
|
-
const Template: Story<ArgTypes> = ({
|
26
|
+
const Template: Story<ArgTypes> = ({ label = 'signature', name = 'signature', 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> = ({ value, disabled }: ArgTypes) => html`
|
|
49
49
|
|
50
50
|
<style>
|
51
51
|
.container {
|
52
|
-
height:
|
52
|
+
height: 500px;
|
53
53
|
text-align: center;
|
54
54
|
padding: 20px;
|
55
55
|
|
@@ -60,7 +60,6 @@ const Template: Story<ArgTypes> = ({ value, disabled }: ArgTypes) => html`
|
|
60
60
|
|
61
61
|
<div class="container md-typescale-body-large-prominent">
|
62
62
|
<ox-input-signature
|
63
|
-
.value=${value || ''}
|
64
63
|
?disabled=${disabled}
|
65
64
|
@change=${(e: Event) => console.log(((e as CustomEvent).target as any)!.value)}
|
66
65
|
>
|
@@ -69,7 +68,4 @@ const Template: Story<ArgTypes> = ({ value, disabled }: ArgTypes) => html`
|
|
69
68
|
`
|
70
69
|
|
71
70
|
export const Regular = Template.bind({})
|
72
|
-
Regular.args = {
|
73
|
-
value:
|
74
|
-
''
|
75
|
-
}
|
71
|
+
Regular.args = {}
|