@operato/chart 7.0.0 → 7.0.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.
Files changed (55) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/dist/src/chartjs/config-converter.js +7 -1
  3. package/dist/src/chartjs/config-converter.js.map +1 -1
  4. package/dist/src/editors/configurer.d.ts +2 -2
  5. package/dist/src/editors/configurer.js +0 -1
  6. package/dist/src/editors/configurer.js.map +1 -1
  7. package/dist/src/editors/input-chart-abstract.js +3 -2
  8. package/dist/src/editors/input-chart-abstract.js.map +1 -1
  9. package/dist/src/progress/ox-progress-circle.d.ts +41 -0
  10. package/dist/src/progress/ox-progress-circle.js +169 -0
  11. package/dist/src/progress/ox-progress-circle.js.map +1 -0
  12. package/dist/src/scichart/ox-scichart.d.ts +4 -2
  13. package/dist/src/scichart/ox-scichart.js +77 -23
  14. package/dist/src/scichart/ox-scichart.js.map +1 -1
  15. package/dist/src/scichart/scichart-builder.d.ts +1 -1
  16. package/dist/src/scichart/scichart-builder.js +216 -22
  17. package/dist/src/scichart/scichart-builder.js.map +1 -1
  18. package/dist/stories/common.d.ts +1 -1
  19. package/dist/stories/common.js +31 -9
  20. package/dist/stories/common.js.map +1 -1
  21. package/dist/stories/ox-input-chart-bar.stories.js +32 -47
  22. package/dist/stories/ox-input-chart-bar.stories.js.map +1 -1
  23. package/dist/stories/ox-input-chart-doughnut.stories.js +1 -1
  24. package/dist/stories/ox-input-chart-doughnut.stories.js.map +1 -1
  25. package/dist/stories/ox-input-chart-hbar.stories.js +1 -1
  26. package/dist/stories/ox-input-chart-hbar.stories.js.map +1 -1
  27. package/dist/stories/ox-input-chart-line.stories.js +1 -1
  28. package/dist/stories/ox-input-chart-line.stories.js.map +1 -1
  29. package/dist/stories/ox-input-chart-pie.stories.js +1 -1
  30. package/dist/stories/ox-input-chart-pie.stories.js.map +1 -1
  31. package/dist/stories/ox-input-chart-polar-area.stories.js +1 -1
  32. package/dist/stories/ox-input-chart-polar-area.stories.js.map +1 -1
  33. package/dist/stories/ox-input-chart-radar.stories.js +1 -1
  34. package/dist/stories/ox-input-chart-radar.stories.js.map +1 -1
  35. package/dist/stories/ox-input-chart-timeseries.stories.js +77 -53
  36. package/dist/stories/ox-input-chart-timeseries.stories.js.map +1 -1
  37. package/dist/tsconfig.tsbuildinfo +1 -1
  38. package/package.json +3 -2
  39. package/src/chartjs/config-converter.ts +12 -4
  40. package/src/editors/configurer.ts +0 -1
  41. package/src/editors/input-chart-abstract.ts +3 -2
  42. package/src/progress/ox-progress-circle.ts +133 -0
  43. package/src/scichart/custom-point-markers.ts.xxx +178 -0
  44. package/src/scichart/ox-scichart.ts +83 -32
  45. package/src/scichart/scichart-builder.ts +272 -34
  46. package/src/types.d.ts +14 -2
  47. package/stories/common.ts +36 -9
  48. package/stories/ox-input-chart-bar.stories.ts +31 -45
  49. package/stories/ox-input-chart-doughnut.stories.ts +1 -1
  50. package/stories/ox-input-chart-hbar.stories.ts +1 -1
  51. package/stories/ox-input-chart-line.stories.ts +1 -1
  52. package/stories/ox-input-chart-pie.stories.ts +1 -1
  53. package/stories/ox-input-chart-polar-area.stories.ts +1 -1
  54. package/stories/ox-input-chart-radar.stories.ts +1 -1
  55. package/stories/ox-input-chart-timeseries.stories.ts +76 -51
@@ -24,6 +24,19 @@ interface ArgTypes {
24
24
  value: OperatoChart.ChartConfig
25
25
  }
26
26
 
27
+ function showCharts(e: Event) {
28
+ const target = e.currentTarget as any
29
+ const config = target.value
30
+ const chartjs = document.querySelector('#chartjs') as HTMLElement
31
+ if (chartjs) {
32
+ ;(chartjs as any).config = { ...config }
33
+ }
34
+ const scichart = document.querySelector('#scichart') as HTMLElement
35
+ if (scichart) {
36
+ ;(scichart as any).config = config
37
+ }
38
+ }
39
+
27
40
  const Template: Story<ArgTypes> = ({ value }: ArgTypes) => html`
28
41
  <link
29
42
  href="https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL@20..48,100..700,0..1"
@@ -43,18 +56,21 @@ const Template: Story<ArgTypes> = ({ value }: ArgTypes) => html`
43
56
  <link href="/themes/spacing.css" rel="stylesheet" />
44
57
 
45
58
  <style>
46
- .container {
47
- width: 100%;
48
- height: 100%;
59
+ .desc {
60
+ color: var(--md-sys-color-background);
61
+ background-color: var(--md-sys-color-on-background);
62
+ padding: var(--spacing-small);
63
+ }
49
64
 
65
+ .container {
50
66
  display: flex;
51
67
  flex-direction: row;
52
68
  overflow-y: auto;
53
69
  padding: var(--spacing-medium);
54
- }
70
+ gap: var(--spacing-medium);
55
71
 
56
- .container.dark {
57
- background-color: black;
72
+ color: var(--md-sys-color-on-background);
73
+ background-color: var(--md-sys-color-background);
58
74
  }
59
75
 
60
76
  #editor {
@@ -66,7 +82,7 @@ const Template: Story<ArgTypes> = ({ value }: ArgTypes) => html`
66
82
 
67
83
  display: flex;
68
84
  flex-direction: column;
69
- padding: 10px;
85
+ gap: var(--spacing-medium);
70
86
  }
71
87
 
72
88
  #chartjs {
@@ -78,43 +94,18 @@ const Template: Story<ArgTypes> = ({ value }: ArgTypes) => html`
78
94
  }
79
95
  </style>
80
96
 
81
- <div style="background-color: black; color: white;">
82
- Type 'count' or 'average' for series dataKey, type 'year' for axis's dataKey
83
- </div>
97
+ <div class="desc">Type 'count' or 'average' for series dataKey, type 'timestamp' for axis's dataKey</div>
84
98
 
85
- <div class="container light">
99
+ <div class="container">
86
100
  <ox-input-chart-timeseries
87
101
  chart-type="line"
88
102
  id="editor"
89
103
  .value=${value}
90
- @change=${(e: CustomEvent) => {
91
- const target = e.currentTarget as any
92
- const config = target.value
93
- const chartjs = document.querySelector('#chartjs') as HTMLElement
94
- if (chartjs) {
95
- ;(chartjs as any).config = { ...config }
96
- }
97
- const scichart = document.querySelector('#scichart') as HTMLElement
98
- if (scichart) {
99
- ;(scichart as any).config = config
100
- }
101
-
102
- const container = document.querySelector('.container') as HTMLElement
103
- if (container) {
104
- const theme = config.options.theme
105
- if (theme == 'dark') {
106
- container.classList.remove('light')
107
- container.classList.add('dark')
108
- } else {
109
- container.classList.remove('dark')
110
- container.classList.add('light')
111
- }
112
- }
113
- }}
104
+ @change=${showCharts}
114
105
  ></ox-input-chart-timeseries>
115
106
  <div id="charts">
116
- <ox-scichart id="scichart" .data=${data} attr-x="year" attr-y="count"></ox-scichart>
117
- <ox-chart-js id="chartjs" .data=${data}></ox-chart-js>
107
+ <ox-scichart id="scichart" .data=${data} attr-x="timestamp" attr-y="count"></ox-scichart>
108
+ <!-- <ox-chart-js id="chartjs" .data=${data}></ox-chart-js> -->
118
109
  </div>
119
110
  </div>
120
111
  `
@@ -132,28 +123,40 @@ WithData.args = {
132
123
  dataKey: 'count',
133
124
  label: 'Line Series count',
134
125
  type: 'line',
135
- backgroundColor: 'rgba(255, 99, 132, 0.2)',
136
- borderColor: 'rgba(255, 99, 132, 1)',
126
+ color: 'rgba(255, 99, 132, 1)',
137
127
  borderWidth: 1
138
128
  },
139
129
  {
140
130
  dataKey: 'average',
141
131
  label: 'Line Series average',
142
132
  type: 'line',
143
- borderColor: 'rgba(54, 162, 235, 1)',
144
- borderWidth: 1,
133
+ color: 'rgba(54, 162, 235, 1)',
145
134
  fill: false,
146
135
  lineTension: 0.4,
147
136
  pointStyle: 'circle',
148
137
  pointRadius: 3
149
138
  }
150
139
  ],
151
- labelDataKey: 'year'
140
+ labelDataKey: 'timestamp'
152
141
  },
153
142
  options: {
154
143
  scales: {
155
- xAxes: [{ ticks: { beginAtZero: true } }],
156
- yAxes: [{ ticks: { beginAtZero: true } }]
144
+ xAxes: [
145
+ {
146
+ axisTitle: 'timestamp',
147
+ ticks: { beginAtZero: true }
148
+ }
149
+ ],
150
+ yAxes: [
151
+ {
152
+ axisTitle: 'count',
153
+ ticks: { beginAtZero: true }
154
+ },
155
+ {
156
+ axisTitle: 'average',
157
+ ticks: { beginAtZero: true }
158
+ }
159
+ ]
157
160
  },
158
161
  legend: { display: true }
159
162
  }
@@ -164,15 +167,13 @@ export const MultiAxis = Template.bind({})
164
167
  MultiAxis.args = {
165
168
  value: {
166
169
  ...getDefaultChartConfig('line'),
167
- options: {
168
- ...getDefaultChartConfig('line').options,
169
- multiAxis: true
170
- },
171
170
  data: {
172
171
  datasets: [
173
172
  {
174
173
  label: 'Bar Series',
175
174
  type: 'bar',
175
+ dataKey: 'count',
176
+ axisTitle: 'count',
176
177
  backgroundColor: 'rgba(255, 99, 132, 0.2)',
177
178
  borderColor: 'rgba(255, 99, 132, 1)',
178
179
  borderWidth: 1,
@@ -181,16 +182,40 @@ MultiAxis.args = {
181
182
  {
182
183
  label: 'Line Series',
183
184
  type: 'line',
184
- borderColor: 'rgba(54, 162, 235, 1)',
185
+ dataKey: 'average',
186
+ axisTitle: 'average',
187
+ color: 'rgba(54, 162, 235, 1)',
185
188
  borderWidth: 1,
186
189
  fill: false,
187
190
  lineTension: 0.4,
188
- pointStyle: 'circle',
191
+ pointStyle: 'rect',
189
192
  pointRadius: 3,
190
193
  yAxisID: 'right'
191
194
  }
192
195
  ],
193
- labelDataKey: 'labels'
196
+ labelDataKey: 'timestamp'
197
+ },
198
+ options: {
199
+ scales: {
200
+ xAxes: [
201
+ {
202
+ axisTitle: 'timestamp',
203
+ ticks: { beginAtZero: true }
204
+ }
205
+ ],
206
+ yAxes: [
207
+ {
208
+ axisTitle: 'count',
209
+ ticks: { beginAtZero: true }
210
+ },
211
+ {
212
+ axisTitle: 'average',
213
+ ticks: { beginAtZero: true }
214
+ }
215
+ ]
216
+ },
217
+ multiAxis: true,
218
+ legend: { display: true }
194
219
  }
195
220
  }
196
221
  }