hayun-vite 0.12.0 → 0.14.0

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.
@@ -3,10 +3,15 @@ import logo from '../logos/logo-0_mm_20w_22h_300p.png'
3
3
  const officeData = {
4
4
  name: "دفتر ارزیابی شنوایی و سمعک سروش",
5
5
  // logo: "/static/media/Daco_1154502.04df6740fbd1f11c99f8.png",
6
- logo: logo,
7
- logo1: "",
6
+ logos:
7
+ [
8
+ ""
9
+ ],
10
+ selectedLogoIndex: 0,
8
11
  addresses: ["مشهد، خیابان عارف، عارف ۲، ساختمان سینا، طبقه اول"],
9
- tels: ["۰۵۱۳۸۴۴۲۵۹۲"],
12
+ selectedAddressIndex: 0,
13
+ tels: ["051 38442592", "051 38445232"],
14
+ selectedTelIndex: 1,
10
15
  audiologists: [
11
16
  {
12
17
  name: "مهدی",
@@ -24,10 +29,11 @@ const officeData = {
24
29
  signature: "IMG2",
25
30
  },
26
31
  ],
32
+ selectedAudiologistIndex: 1,
27
33
  audiometers: ["Pejvak Ava C952", "Zodiac Z1"],
34
+ selectedAudiometrIndex: 0,
28
35
  tympanometers: ["Pejvak Ava Z71", "Intracoustic T34"],
29
-
30
-
36
+ selectedTympanometerIndex: 1,
31
37
  }
32
38
 
33
39
  const patientData = {
@@ -51,13 +57,7 @@ const patientData = {
51
57
  `کاهش شنوایی حسی عصبی ملایم تا متوسط در فرکانس بم تامیانه در گوش راست.
52
58
  کاهش شنوایی آمیخته متوسط تا شدید در گوش چپ.`,
53
59
  },
54
-
55
- // history, // رشته متن شرح‌حال بیمار
56
-
57
60
  note: "", //رشته متن بلند یادداشت
58
-
59
- // referrer: "دکتر سید علی سرابی ",
60
- // age: "25",
61
61
  audiogram: {
62
62
  R: { R_AC: { 500: '25', 1000: '35', 2000: '45', 4000: '55', 8000: '60' } },
63
63
  L: {
@@ -0,0 +1,348 @@
1
+ const templAudiometry = {
2
+ name: 'Audiometry',
3
+ label: 'ادیومتری',
4
+ // backgroundImage: 'backgroundImage',
5
+ // تعیین نمایش بوردرهای سکشن ها
6
+ sectionBorders: 'display', // display || none
7
+ boxBorders: 'none', // display || none
8
+ margin: { left: 5, top: 5, right: 5, bottom: 5 },
9
+ paper: { type: 'A4', case: 'portrait', width: 210, height: 297 },
10
+
11
+ // Printable Dimention
12
+ calc1: function () {
13
+
14
+ this.width = this.paper.width - (this.margin.left + this.margin.right);
15
+ this.height = this.paper.height - (this.margin.top + this.margin.bottom);
16
+ let width = this.width;
17
+ // ابعاد و پدینگ المنت ها
18
+
19
+ // فضای خالی
20
+ this.blank = {
21
+ name: 'blank',
22
+ w: width, h: 10,
23
+ margin: { left: 0, top: 0, right: 0, bottom: 0 },
24
+ display: 'block',
25
+ }
26
+
27
+ this.header = {
28
+ // hideContext: true,
29
+ name: 'header',
30
+ w: width, h: 15,
31
+ margin: { left: 0, top: 0, right: 0, bottom: 0 },
32
+ display: 'block',
33
+ }
34
+
35
+ this.patient = {
36
+ name: 'patient',
37
+ w: width, h: 12,
38
+ margin: { left: 1, top: 0, right: 1, bottom: 0 },
39
+ display: 'block',
40
+ boxBorder: 'none' // display || none default: none
41
+ }
42
+
43
+ this.history = {
44
+ name: 'history',
45
+ w: width, h: 24,
46
+ margin: { left: 1, top: 0, right: 1, bottom: 0 },
47
+ display: 'block',
48
+ boxBorder: 'none' // display || none
49
+ }
50
+
51
+ // Titles Common Object
52
+ this['Title'] = {
53
+ w: width, h: 7, // پهنا و ارتفاع سکشن
54
+ margin: { left: 0, top: 0, right: 0, bottom: 0 },
55
+ display: 'block',
56
+ }
57
+
58
+ // Audiogram Titles
59
+ this['Audiogram Titles'] = {
60
+ ...this['Title'],
61
+ name: 'Audiogram Titles',
62
+ stroke: true,
63
+ // محاسبه پهنا ارتفاع در تابع calc2
64
+ }
65
+
66
+ this.RAudiogram = {}
67
+ Object.assign(this.RAudiogram,
68
+ {
69
+ blank: false,
70
+ name: 'RAudiogram',
71
+ w: width / 2, h: 95, // ابعاد سکشن ادیوگرام
72
+ margin: { left: 1, top: 0, right: 2, bottom: 0 }, // در مدل باکس این برای باکس هست
73
+ display: 'inline',
74
+ borderBox: 'display', // display | none default: none بوردر
75
+ });
76
+
77
+ this.LAudiogram = {}
78
+ Object.assign(this.LAudiogram,
79
+ {
80
+ name: 'LAudiogram',
81
+ w: width / 2, h: 95, // پهنای سکشن هست
82
+ margin: { left: 2, top: 0, right: 1, bottom: 0 },
83
+ display: 'block',
84
+ // borderBox: 'none', // display | none default: none بوردر
85
+ });
86
+
87
+ // Speech Titles
88
+ this['Speech Titles'] = {
89
+ name: 'Speech Titles',
90
+ ...this['Title'],
91
+ stroke: true,
92
+ // محاسبه پهنا ارتفاع در تابع calc2
93
+ }
94
+
95
+ this.RSpeech = {
96
+ name: 'RSpeech',
97
+ w: width / 2, h: 15,
98
+ margin: { left: 1, top: 0, right: 10, bottom: 0 },
99
+ display: 'inline',
100
+ stroke: true,
101
+ }
102
+
103
+ this.LSpeech = {
104
+ name: 'LSpeech',
105
+ w: width / 2, h: 15,
106
+ margin: { left: 10, top: 0, right: 1, bottom: 0 },
107
+ display: 'block',
108
+ stroke: true
109
+ }
110
+
111
+ // Tympanogram Titles
112
+ this['Tympanogram Titles'] = {
113
+ name: 'Tympanogram Titles',
114
+ ...this['Title'],
115
+ stroke: true,
116
+ // محاسبه پهنا ارتفاع در تابع calc2
117
+ }
118
+
119
+ this.RTympanogram = {
120
+ name: 'RTympanogram',
121
+ w: width / 2, h: 60,
122
+ margin: { left: 1, top: 0, right: 10, bottom: 0 },
123
+ display: 'inline',
124
+ }
125
+
126
+ this.LTympanogram = {
127
+ name: 'LTympanogram',
128
+ w: width / 2, h: 60,
129
+ margin: { left: 10, top: 0, right: 1, bottom: 0 },
130
+ display: 'block',
131
+ }
132
+
133
+ // Reflex Titles
134
+ this['Reflex Titles'] = {
135
+ name: 'Reflex Titles',
136
+ ...this['Title'],
137
+ stroke: true,
138
+ // محاسبه پهنا ارتفاع در تابع calc2
139
+ }
140
+
141
+ this.RReflex = {
142
+ name: 'RReflex',
143
+ w: width / 2, h: 26,
144
+ margin: { left: 1, top: 0, right: 10, bottom: 1 },
145
+ display: 'inline'
146
+ }
147
+
148
+ this.LReflex = {
149
+ name: 'LReflex',
150
+ w: width / 2, h: 26,
151
+ margin: { left: 10, top: 0, right: 1, bottom: 1 },
152
+ display: 'block'
153
+ }
154
+
155
+ this.report = {
156
+ name: 'report',
157
+ w: width, h: 20,
158
+ margin: { left: 1, top: 0, right: 1, bottom: 0 },
159
+ display: 'block'
160
+ }
161
+
162
+ this.footer = {
163
+ name: 'footer',
164
+ w: width, h: 10,
165
+ margin: { left: 0, top: 0, right: 0, bottom: 0 },
166
+ display: 'block'
167
+ }
168
+ },
169
+
170
+ // محاسبه پهنا و ارتفاع رسمی بخش های فرم از روی مارجین و ابعاد کاغذ
171
+ calc2: function () {
172
+ // let dims = this.dims;
173
+ let width, height, style;
174
+
175
+ width = this.header.width = this.getWidth(this.header)
176
+ height = this.header.height = this.getHeight(this.header)
177
+
178
+ style = `
179
+ font-family: Vazir, Helvetica, sans-serif !important;
180
+ font-size: 1.5mm;
181
+ font-weight: bold;
182
+ text-anchor: start; /*تراز افقی*/
183
+ /* dominant-baseline: middle; /* تراز عمودی*/
184
+ `;
185
+
186
+ this.header.elements = [
187
+ { type: 'line', x1: 0, y1: height, x2: width, y2: height },
188
+ { type: 'text', x: 30, y: 5, value: 'تاریخ :' },
189
+ ]
190
+ this.header.inputs = [
191
+ { name: 'officeName', x: width - 16, y: height - 6, style },
192
+ { name: 'date', x: 20, y: 5, style: style + ' font-size: 0.8mm;' },
193
+ ]
194
+
195
+ width = this.patient.width = this.getWidth(this.patient)
196
+ height = this.patient.height = this.getHeight(this.patient)
197
+ this.patient.elements = [
198
+ // { type: 'line', x1: 0, y1: height, x2: width, y2: height },
199
+ { type: 'text', x: width, y: 5, value: 'نام:' },
200
+ { type: 'text', x: width - 38, y: 5, value: 'نام خانوادگی:' },
201
+ { type: 'text', x: width - 90, y: 5, value: 'سن:' },
202
+ { type: 'text', x: width - 130, y: 5, value: 'ارجاع از:' }
203
+ ]
204
+ this.patient.inputs = [
205
+ { name: 'name', x: width - 7, y: 5 },
206
+ { name: 'lastName', x: width - 59, y: 5 },
207
+ { name: 'age', x: width - 98, y: 5 },
208
+ { name: 'referrer', x: width - 143, y: 5 }
209
+ ]
210
+ this.patient.forceInputs = [
211
+ { name: 'name', x: width - 10, y: 4 },
212
+ { name: 'lastName', x: width - 47, y: 5 },
213
+ { name: 'age', x: width - 97, y: 5 },
214
+ { name: 'referrer', x: width - 142, y: 5 }
215
+ ]
216
+
217
+ width = this.history.width = this.getWidth(this.history)
218
+ height = this.history.height = this.getHeight(this.history)
219
+ this.history.elements = [
220
+ { type: 'line', x1: 0, y1: height, x2: width, y2: height },
221
+ { type: 'text', x: width, y: 5, value: 'شرح حال:' },
222
+ ]
223
+ this.history.inputs = [
224
+ { name: 'description', x: width - 16, y: 5 },
225
+ ]
226
+
227
+ width = this['Audiogram Titles'].width = this.getWidth(this['Audiogram Titles'])
228
+ height = this['Audiogram Titles'].height = this.getHeight(this['Audiogram Titles'])
229
+ style = `
230
+ text-anchor: middle;
231
+ dominant-baseline: middle;
232
+ font-size: 1.2mm
233
+ `;
234
+ this['Audiogram Titles'].elements = [
235
+ // { type: 'line', x1: 0, y1: 0, x2: width, y2: 0 },
236
+ { type: 'text', x: width / 2, y: height / 2, value: 'Audiograms', style },
237
+ { type: 'text', x: width / 4, y: 5, value: 'Right', style: 'fill: red' },
238
+ { type: 'text', x: width * 3 / 4, y: 5, value: 'Left', style: 'fill: blue' },
239
+ ]
240
+
241
+ width = this.RAudiogram.width = this.getWidth(this.RAudiogram)
242
+ this.RAudiogram.height = this.getHeight(this.RAudiogram)
243
+
244
+ width = this.LAudiogram.width = this.getWidth(this.LAudiogram)
245
+ this.LAudiogram.height = this.getHeight(this.LAudiogram)
246
+
247
+ width = this['Speech Titles'].width = this.getWidth(this['Speech Titles'])
248
+ height = this['Speech Titles'].height = this.getHeight(this['Speech Titles'])
249
+ this['Speech Titles'].elements = [
250
+ // { type: 'line', x1: 0, y1: 0, x2: width, y2: 0 },
251
+ { type: 'text', x: width / 2, y: height / 2, value: 'Speech Tests', style },
252
+ { type: 'text', x: width / 4, y: 5, value: 'Right', style: 'fill: red' },
253
+ { type: 'text', x: width * 3 / 4, y: 5, value: 'Left', style: 'fill: blue' },
254
+ ]
255
+
256
+ width = this.RSpeech.width = this.getWidth(this.RSpeech)
257
+ this.RSpeech.height = this.getHeight(this.RSpeech)
258
+ this.RSpeech.labels = ["SAT", "SRT", "MCL", "UCL", "SDS"]
259
+
260
+ width = this.LSpeech.width = this.getWidth(this.LSpeech)
261
+ this.LSpeech.height = this.getHeight(this.LSpeech)
262
+ this.LSpeech.labels = ["SAT", "SRT", "MCL", "UCL", "SDS"]
263
+
264
+ width = this['Tympanogram Titles'].width = this.getWidth(this['Tympanogram Titles'])
265
+ height = this['Tympanogram Titles'].height = this.getHeight(this['Tympanogram Titles'])
266
+ this['Tympanogram Titles'].elements = [
267
+ // { type: 'line', x1: 0, y1: 0, x2: width, y2: 0 },
268
+ { type: 'text', x: width / 2, y: height / 2, value: 'Tympanograms', style },
269
+ // { type: 'text', x: width / 4, y: 5, value: 'Right', style: 'fill: red' },
270
+ // { type: 'text', x: width * 3 / 4, y: 5, value: 'Left', style: 'fill: blue' },
271
+ ]
272
+
273
+ width = this.RTympanogram.width = this.getWidth(this.RTympanogram)
274
+ this.RTympanogram.height = this.getHeight(this.RTympanogram)
275
+ width = this.LTympanogram.width = this.getWidth(this.LTympanogram)
276
+ this.LTympanogram.height = this.getHeight(this.LTympanogram)
277
+
278
+ width = this['Reflex Titles'].width = this.getWidth(this['Reflex Titles'])
279
+ height = this['Reflex Titles'].height = this.getHeight(this['Reflex Titles'])
280
+ this['Reflex Titles'].elements = [
281
+ // { type: 'line', x1: 0, y1: 0, x2: width, y2: 0 },
282
+ { type: 'text', x: width / 2, y: height / 2, value: 'Acoustic Reflexes', style },
283
+ { type: 'text', x: width / 4, y: 5, value: 'Probe in the Right Ear', style: 'fill: red; text-anchor: middle' },
284
+ { type: 'text', x: width * 3 / 4, y: 5, value: 'Probe in the Left Ear', style: 'fill: blue; text-anchor: middle' },
285
+ ]
286
+
287
+ width = this.RReflex.width = this.getWidth(this.RReflex)
288
+ this.RReflex.height = this.getHeight(this.RReflex)
289
+ width = this.LReflex.width = this.getWidth(this.LReflex)
290
+ this.LReflex.height = this.getHeight(this.LReflex)
291
+
292
+ width = this.report.width = this.getWidth(this.report)
293
+ this.report.height = this.getHeight(this.report)
294
+ this.report.elements = [
295
+ { type: 'text', x: width, y: 5, value: 'گزارش:' },
296
+ ]
297
+ this.report.inputs = [
298
+ { name: 'description', x: width - 12, y: 5 },
299
+ ]
300
+
301
+ width = this.footer.width = this.getWidth(this.footer)
302
+ this.footer.height = this.getHeight(this.footer)
303
+ this.footer.elements = [
304
+ { type: 'line', x1: 0, y1: 0, x2: width, y2: 0 },
305
+ { type: 'text', x: width, y: 5, value: 'آدرس:' },
306
+ { type: 'text', x: width - 120, y: 5, value: 'تلفن:' },
307
+ ]
308
+ this.footer.inputs = [
309
+ { name: 'address', x: width - 10, y: 5 },
310
+ { name: 'tel', x: width - 128, y: 5 },
311
+ ]
312
+ },
313
+
314
+ getWidth: function (element) {
315
+ return (element.w - (element.margin.left + element.margin.right))
316
+ },
317
+ getHeight: function (element) {
318
+ return (element.h - (element.margin.top + element.margin.bottom))
319
+ },
320
+
321
+ calcSectionsArray: function () {
322
+ // این آرایه دقیقا ترتیب قرارگیری سکشن ها را بدون اون اوردر قبلی تعیین میکند
323
+ this.sections = [
324
+ this.header,
325
+ this.patient,
326
+ this.history,
327
+ this['Audiogram Titles'],
328
+ this.RAudiogram,
329
+ this.LAudiogram,
330
+ this['Speech Titles'],
331
+ this.RSpeech,
332
+ this.LSpeech,
333
+ this.report,
334
+ this.footer
335
+
336
+ ]
337
+ },
338
+
339
+ }
340
+
341
+ // محاسبه پهنا و ارتفاع قسمت ها با توجه به پهنا و ارتفاع محدوده چاپی و مارجین ها
342
+ templAudiometry.calc1()
343
+ templAudiometry.calc2()
344
+ templAudiometry.calcSectionsArray()
345
+ // پهنا و ارتفاع قابل استفاده منهای پد ها میشه پهنا و ارتفاع اصلی
346
+
347
+ export default templAudiometry;
348
+
@@ -1,4 +1,4 @@
1
- const template_combo = {
1
+ const templCombo = {
2
2
  name: 'combo',
3
3
  label: 'ادیومتری و تمپانوتری',
4
4
  // backgroundImage: 'backgroundImage',
@@ -343,10 +343,10 @@ const template_combo = {
343
343
  }
344
344
 
345
345
  // محاسبه پهنا و ارتفاع قسمت ها با توجه به پهنا و ارتفاع محدوده چاپی و مارجین ها
346
- template_combo.calc1()
347
- template_combo.calc2()
348
- template_combo.calcSectionsArray()
346
+ templCombo.calc1()
347
+ templCombo.calc2()
348
+ templCombo.calcSectionsArray()
349
349
  // پهنا و ارتفاع قابل استفاده منهای پد ها میشه پهنا و ارتفاع اصلی
350
350
 
351
- export default template_combo;
351
+ export default templCombo;
352
352
 
package/index.html CHANGED
@@ -1,13 +1,46 @@
1
1
  <!doctype html>
2
2
  <html lang="en">
3
- <head>
4
- <meta charset="UTF-8" />
5
- <link rel="icon" type="image/svg+xml" href="vite.svg" />
6
- <meta name="viewport" content="width=device-width, initial-scale=1.0" />
7
- <title>hayun</title>
8
- </head>
9
- <body>
10
- <div id="app"></div>
11
- <script type="module" src="/src/main.js"></script>
12
- </body>
13
- </html>
3
+
4
+ <head>
5
+ <meta charset="UTF-8" />
6
+ <link rel="icon" type="image/svg+xml" href="vite.svg" />
7
+ <link rel="stylesheet" href="/styles.css">
8
+ <style>
9
+ p,
10
+ label {
11
+ font:
12
+ 1.3rem "Fira Sans",
13
+ sans-serif;
14
+ }
15
+
16
+ input {
17
+ margin: 0.4rem;
18
+ /* user-select: none; */
19
+ }
20
+ label {
21
+ user-select: none;
22
+ }
23
+ </style>
24
+ <meta name="viewport" content="width=device-width, initial-scale=1.0" />
25
+ <title>hayun</title>
26
+ </head>
27
+
28
+ <body>
29
+ <div id="app"></div>
30
+
31
+
32
+ <script>
33
+
34
+
35
+
36
+
37
+
38
+ </script>
39
+ <!-- <script type="module" src="/src/Audiogram/test.js"></script> -->
40
+ <!-- <script type="module" src="/src/main.js"></script> -->
41
+ <script type="module" src="/src/Forms/test.js"></script>
42
+ <!-- <script type="module" src="/src/Tympanogram/test.js"></script> -->
43
+
44
+ </body>
45
+
46
+ </html>
package/index.js CHANGED
@@ -2,7 +2,9 @@ import Audiogram from './src/Audiogram/Audiogram'
2
2
  import dims from './src/Audiogram/dims'
3
3
  import { officeData, patientData } from './assets/data/sampleData'
4
4
  import Forms from './src/Forms/Forms'
5
- import combo_template from './assets/templates/template_combo'
5
+ import combo_template from './assets/templates/templCombo'
6
+ import './styles.css'
7
+
6
8
  // import rasa_aud_template from './assets/templates/rasa_audiometry'
7
9
  // import rasa_tymp_reflex_template from './assets/templates/rasa_tymp_reflex'
8
10
 
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "hayun-vite",
3
3
  "private": false,
4
- "version": "0.12.0",
4
+ "version": "0.14.0",
5
5
  "type": "module",
6
6
  "scripts": {
7
7
  "dev": "vite",
@@ -0,0 +1,37 @@
1
+ import Audiogram from "./Audiogram";
2
+
3
+ document.querySelector('#app').innerHTML = `
4
+ <div id="test"></div>
5
+ `;
6
+
7
+ const container = document.getElementById('test')
8
+
9
+ const dims = {
10
+ "blank": false,
11
+ "name": "RAudiogram",
12
+ "w": 100,
13
+ "h": 90,
14
+ "margin": {
15
+ "left": 1,
16
+ "top": 1,
17
+ "right": 1,
18
+ "bottom": 1
19
+ },
20
+ "display": "inline",
21
+ "borderBox": "display",
22
+ "width": 600,
23
+ "height": 600
24
+ }
25
+
26
+ const RAudiogram = new Audiogram({ container, side: 'R', dims })
27
+ RAudiogram.update({
28
+ data: {
29
+ // R_AC_M: { 8000: 25, 2000: 5, 1500: 0, },
30
+ R_AC: { 1000: 25, 500: 15, 750: 20, 250: 10, 6000: 35, 2000: 45 },
31
+ R_AC_NR: { 1500: 85 },
32
+ R_BC_M: { 2000: 25, 6000: 25 },
33
+ R_BC_M_NR: { 3000: 85 },
34
+ R_BC: { 1000: 20, 500: 10, 750: 15, 250: 5, 4000: 20 },
35
+ },
36
+ side: 'R',
37
+ })