@uptime.link/statuspage 1.0.74 → 1.1.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.
Files changed (95) hide show
  1. package/dist_bundle/bundle.js +4096 -504
  2. package/dist_bundle/bundle.js.map +4 -4
  3. package/dist_ts_web/00_commitinfo_data.js +2 -2
  4. package/dist_ts_web/elements/index.d.ts +3 -0
  5. package/dist_ts_web/elements/index.js +6 -1
  6. package/dist_ts_web/elements/internal/uplinternal-miniheading.d.ts +1 -0
  7. package/dist_ts_web/elements/internal/uplinternal-miniheading.js +78 -28
  8. package/dist_ts_web/elements/upl-statuspage-assetsselector.d.ts +14 -0
  9. package/dist_ts_web/elements/upl-statuspage-assetsselector.demo.d.ts +1 -0
  10. package/dist_ts_web/elements/upl-statuspage-assetsselector.demo.js +575 -0
  11. package/dist_ts_web/elements/upl-statuspage-assetsselector.js +605 -43
  12. package/dist_ts_web/elements/upl-statuspage-footer.d.ts +46 -2
  13. package/dist_ts_web/elements/upl-statuspage-footer.demo.d.ts +1 -0
  14. package/dist_ts_web/elements/upl-statuspage-footer.demo.js +679 -0
  15. package/dist_ts_web/elements/upl-statuspage-footer.js +792 -61
  16. package/dist_ts_web/elements/upl-statuspage-header.d.ts +5 -1
  17. package/dist_ts_web/elements/upl-statuspage-header.demo.d.ts +1 -0
  18. package/dist_ts_web/elements/upl-statuspage-header.demo.js +220 -0
  19. package/dist_ts_web/elements/upl-statuspage-header.js +313 -86
  20. package/dist_ts_web/elements/upl-statuspage-incidents.d.ts +22 -4
  21. package/dist_ts_web/elements/upl-statuspage-incidents.demo.d.ts +1 -0
  22. package/dist_ts_web/elements/upl-statuspage-incidents.demo.js +1147 -0
  23. package/dist_ts_web/elements/upl-statuspage-incidents.js +750 -74
  24. package/dist_ts_web/elements/upl-statuspage-pagetitle.d.ts +15 -0
  25. package/dist_ts_web/elements/upl-statuspage-pagetitle.demo.d.ts +1 -0
  26. package/dist_ts_web/elements/upl-statuspage-pagetitle.demo.js +25 -0
  27. package/dist_ts_web/elements/upl-statuspage-pagetitle.js +148 -0
  28. package/dist_ts_web/elements/upl-statuspage-statsgrid.d.ts +23 -0
  29. package/dist_ts_web/elements/upl-statuspage-statsgrid.demo.d.ts +1 -0
  30. package/dist_ts_web/elements/upl-statuspage-statsgrid.demo.js +295 -0
  31. package/dist_ts_web/elements/upl-statuspage-statsgrid.js +374 -0
  32. package/dist_ts_web/elements/upl-statuspage-statusbar.d.ts +4 -0
  33. package/dist_ts_web/elements/upl-statuspage-statusbar.demo.d.ts +1 -0
  34. package/dist_ts_web/elements/upl-statuspage-statusbar.demo.js +365 -0
  35. package/dist_ts_web/elements/upl-statuspage-statusbar.js +357 -44
  36. package/dist_ts_web/elements/upl-statuspage-statusdetails.d.ts +14 -0
  37. package/dist_ts_web/elements/upl-statuspage-statusdetails.demo.d.ts +1 -0
  38. package/dist_ts_web/elements/upl-statuspage-statusdetails.demo.js +706 -0
  39. package/dist_ts_web/elements/upl-statuspage-statusdetails.js +373 -63
  40. package/dist_ts_web/elements/upl-statuspage-statusmonth.d.ts +15 -0
  41. package/dist_ts_web/elements/upl-statuspage-statusmonth.demo.d.ts +1 -0
  42. package/dist_ts_web/elements/upl-statuspage-statusmonth.demo.js +798 -0
  43. package/dist_ts_web/elements/upl-statuspage-statusmonth.js +474 -100
  44. package/dist_ts_web/interfaces/index.d.ts +84 -0
  45. package/dist_ts_web/interfaces/index.js +4 -0
  46. package/dist_ts_web/pages/index.d.ts +4 -1
  47. package/dist_ts_web/pages/index.js +5 -2
  48. package/dist_ts_web/pages/statuspage-allgreen.d.ts +1 -0
  49. package/dist_ts_web/pages/statuspage-allgreen.js +386 -0
  50. package/dist_ts_web/pages/statuspage-demo.d.ts +1 -0
  51. package/dist_ts_web/pages/statuspage-demo.js +616 -0
  52. package/dist_ts_web/pages/statuspage-maintenance.d.ts +1 -0
  53. package/dist_ts_web/pages/statuspage-maintenance.js +544 -0
  54. package/dist_ts_web/pages/statuspage-outage.d.ts +1 -0
  55. package/dist_ts_web/pages/statuspage-outage.js +543 -0
  56. package/dist_ts_web/styles/shared.styles.d.ts +80 -0
  57. package/dist_ts_web/styles/shared.styles.js +351 -0
  58. package/dist_watch/bundle.js +51691 -32432
  59. package/dist_watch/bundle.js.map +4 -4
  60. package/npmextra.json +9 -3
  61. package/package.json +19 -19
  62. package/readme.hints.md +292 -0
  63. package/readme.md +326 -149
  64. package/readme.plan.md +261 -0
  65. package/ts_web/00_commitinfo_data.ts +1 -1
  66. package/ts_web/elements/index.ts +6 -0
  67. package/ts_web/elements/internal/uplinternal-miniheading.ts +24 -17
  68. package/ts_web/elements/upl-statuspage-assetsselector.demo.ts +607 -0
  69. package/ts_web/elements/upl-statuspage-assetsselector.ts +526 -18
  70. package/ts_web/elements/upl-statuspage-footer.demo.ts +744 -0
  71. package/ts_web/elements/upl-statuspage-footer.ts +608 -30
  72. package/ts_web/elements/upl-statuspage-header.demo.ts +241 -0
  73. package/ts_web/elements/upl-statuspage-header.ts +220 -52
  74. package/ts_web/elements/upl-statuspage-incidents.demo.ts +1216 -0
  75. package/ts_web/elements/upl-statuspage-incidents.ts +649 -26
  76. package/ts_web/elements/upl-statuspage-pagetitle.demo.ts +25 -0
  77. package/ts_web/elements/upl-statuspage-pagetitle.ts +89 -0
  78. package/ts_web/elements/upl-statuspage-statsgrid.demo.ts +315 -0
  79. package/ts_web/elements/upl-statuspage-statsgrid.ts +306 -0
  80. package/ts_web/elements/upl-statuspage-statusbar.demo.ts +393 -0
  81. package/ts_web/elements/upl-statuspage-statusbar.ts +281 -20
  82. package/ts_web/elements/upl-statuspage-statusdetails.demo.ts +754 -0
  83. package/ts_web/elements/upl-statuspage-statusdetails.ts +297 -38
  84. package/ts_web/elements/upl-statuspage-statusmonth.demo.ts +876 -0
  85. package/ts_web/elements/upl-statuspage-statusmonth.ts +397 -76
  86. package/ts_web/interfaces/index.ts +95 -0
  87. package/ts_web/pages/index.ts +4 -1
  88. package/ts_web/pages/statuspage-allgreen.ts +412 -0
  89. package/ts_web/pages/statuspage-demo.ts +653 -0
  90. package/ts_web/pages/statuspage-maintenance.ts +570 -0
  91. package/ts_web/pages/statuspage-outage.ts +568 -0
  92. package/ts_web/styles/shared.styles.ts +367 -0
  93. package/dist_ts_web/pages/page1.d.ts +0 -1
  94. package/dist_ts_web/pages/page1.js +0 -11
  95. package/ts_web/pages/page1.ts +0 -11
@@ -1,90 +1,400 @@
1
- var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
- return c > 3 && r && Object.defineProperty(target, key, r), r;
1
+ var __esDecorate = (this && this.__esDecorate) || function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
2
+ function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
3
+ var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
4
+ var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
5
+ var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
6
+ var _, done = false;
7
+ for (var i = decorators.length - 1; i >= 0; i--) {
8
+ var context = {};
9
+ for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
10
+ for (var p in contextIn.access) context.access[p] = contextIn.access[p];
11
+ context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
12
+ var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
13
+ if (kind === "accessor") {
14
+ if (result === void 0) continue;
15
+ if (result === null || typeof result !== "object") throw new TypeError("Object expected");
16
+ if (_ = accept(result.get)) descriptor.get = _;
17
+ if (_ = accept(result.set)) descriptor.set = _;
18
+ if (_ = accept(result.init)) initializers.unshift(_);
19
+ }
20
+ else if (_ = accept(result)) {
21
+ if (kind === "field") initializers.unshift(_);
22
+ else descriptor[key] = _;
23
+ }
24
+ }
25
+ if (target) Object.defineProperty(target, contextIn.name, descriptor);
26
+ done = true;
6
27
  };
7
- var __metadata = (this && this.__metadata) || function (k, v) {
8
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
28
+ var __runInitializers = (this && this.__runInitializers) || function (thisArg, initializers, value) {
29
+ var useValue = arguments.length > 2;
30
+ for (var i = 0; i < initializers.length; i++) {
31
+ value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
32
+ }
33
+ return useValue ? value : void 0;
9
34
  };
10
35
  import * as plugins from '../plugins.js';
11
- import { DeesElement, property, html, customElement, css, cssManager, } from '@design.estate/dees-element';
36
+ import { DeesElement, property, html, customElement, css, cssManager, unsafeCSS, } from '@design.estate/dees-element';
37
+ import * as sharedStyles from '../styles/shared.styles.js';
12
38
  import './internal/uplinternal-miniheading.js';
13
- let UplStatuspageStatusdetails = class UplStatuspageStatusdetails extends DeesElement {
14
- static { this.demo = () => html ` <upl-statuspage-statusdetails></upl-statuspage-statusdetails> `; }
15
- constructor() {
16
- super();
17
- }
18
- static { this.styles = [
19
- plugins.domtools.elementBasic.staticStyles,
20
- css `
39
+ import { demoFunc } from './upl-statuspage-statusdetails.demo.js';
40
+ let UplStatuspageStatusdetails = (() => {
41
+ let _classDecorators = [customElement('upl-statuspage-statusdetails')];
42
+ let _classDescriptor;
43
+ let _classExtraInitializers = [];
44
+ let _classThis;
45
+ let _classSuper = DeesElement;
46
+ let _historyData_decorators;
47
+ let _historyData_initializers = [];
48
+ let _historyData_extraInitializers = [];
49
+ let _dataPoints_decorators;
50
+ let _dataPoints_initializers = [];
51
+ let _dataPoints_extraInitializers = [];
52
+ let _serviceId_decorators;
53
+ let _serviceId_initializers = [];
54
+ let _serviceId_extraInitializers = [];
55
+ let _serviceName_decorators;
56
+ let _serviceName_initializers = [];
57
+ let _serviceName_extraInitializers = [];
58
+ let _loading_decorators;
59
+ let _loading_initializers = [];
60
+ let _loading_extraInitializers = [];
61
+ let _hoursToShow_decorators;
62
+ let _hoursToShow_initializers = [];
63
+ let _hoursToShow_extraInitializers = [];
64
+ var UplStatuspageStatusdetails = class extends _classSuper {
65
+ static { _classThis = this; }
66
+ static {
67
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
68
+ _historyData_decorators = [property({ type: Array })];
69
+ _dataPoints_decorators = [property({ type: Array })];
70
+ _serviceId_decorators = [property({ type: String })];
71
+ _serviceName_decorators = [property({ type: String })];
72
+ _loading_decorators = [property({ type: Boolean })];
73
+ _hoursToShow_decorators = [property({ type: Number })];
74
+ __esDecorate(this, null, _historyData_decorators, { kind: "accessor", name: "historyData", static: false, private: false, access: { has: obj => "historyData" in obj, get: obj => obj.historyData, set: (obj, value) => { obj.historyData = value; } }, metadata: _metadata }, _historyData_initializers, _historyData_extraInitializers);
75
+ __esDecorate(this, null, _dataPoints_decorators, { kind: "accessor", name: "dataPoints", static: false, private: false, access: { has: obj => "dataPoints" in obj, get: obj => obj.dataPoints, set: (obj, value) => { obj.dataPoints = value; } }, metadata: _metadata }, _dataPoints_initializers, _dataPoints_extraInitializers);
76
+ __esDecorate(this, null, _serviceId_decorators, { kind: "accessor", name: "serviceId", static: false, private: false, access: { has: obj => "serviceId" in obj, get: obj => obj.serviceId, set: (obj, value) => { obj.serviceId = value; } }, metadata: _metadata }, _serviceId_initializers, _serviceId_extraInitializers);
77
+ __esDecorate(this, null, _serviceName_decorators, { kind: "accessor", name: "serviceName", static: false, private: false, access: { has: obj => "serviceName" in obj, get: obj => obj.serviceName, set: (obj, value) => { obj.serviceName = value; } }, metadata: _metadata }, _serviceName_initializers, _serviceName_extraInitializers);
78
+ __esDecorate(this, null, _loading_decorators, { kind: "accessor", name: "loading", static: false, private: false, access: { has: obj => "loading" in obj, get: obj => obj.loading, set: (obj, value) => { obj.loading = value; } }, metadata: _metadata }, _loading_initializers, _loading_extraInitializers);
79
+ __esDecorate(this, null, _hoursToShow_decorators, { kind: "accessor", name: "hoursToShow", static: false, private: false, access: { has: obj => "hoursToShow" in obj, get: obj => obj.hoursToShow, set: (obj, value) => { obj.hoursToShow = value; } }, metadata: _metadata }, _hoursToShow_initializers, _hoursToShow_extraInitializers);
80
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
81
+ UplStatuspageStatusdetails = _classThis = _classDescriptor.value;
82
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
83
+ }
84
+ static demo = demoFunc;
85
+ #historyData_accessor_storage = __runInitializers(this, _historyData_initializers, []);
86
+ get historyData() { return this.#historyData_accessor_storage; }
87
+ set historyData(value) { this.#historyData_accessor_storage = value; }
88
+ #dataPoints_accessor_storage = (__runInitializers(this, _historyData_extraInitializers), __runInitializers(this, _dataPoints_initializers, []));
89
+ get dataPoints() { return this.#dataPoints_accessor_storage; }
90
+ set dataPoints(value) { this.#dataPoints_accessor_storage = value; }
91
+ #serviceId_accessor_storage = (__runInitializers(this, _dataPoints_extraInitializers), __runInitializers(this, _serviceId_initializers, ''));
92
+ get serviceId() { return this.#serviceId_accessor_storage; }
93
+ set serviceId(value) { this.#serviceId_accessor_storage = value; }
94
+ #serviceName_accessor_storage = (__runInitializers(this, _serviceId_extraInitializers), __runInitializers(this, _serviceName_initializers, 'Service'));
95
+ get serviceName() { return this.#serviceName_accessor_storage; }
96
+ set serviceName(value) { this.#serviceName_accessor_storage = value; }
97
+ #loading_accessor_storage = (__runInitializers(this, _serviceName_extraInitializers), __runInitializers(this, _loading_initializers, false));
98
+ get loading() { return this.#loading_accessor_storage; }
99
+ set loading(value) { this.#loading_accessor_storage = value; }
100
+ #hoursToShow_accessor_storage = (__runInitializers(this, _loading_extraInitializers), __runInitializers(this, _hoursToShow_initializers, 48));
101
+ get hoursToShow() { return this.#hoursToShow_accessor_storage; }
102
+ set hoursToShow(value) { this.#hoursToShow_accessor_storage = value; }
103
+ constructor() {
104
+ super();
105
+ __runInitializers(this, _hoursToShow_extraInitializers);
106
+ }
107
+ static styles = [
108
+ plugins.domtools.elementBasic.staticStyles,
109
+ sharedStyles.commonStyles,
110
+ css `
21
111
  :host {
22
112
  position: relative;
23
- padding: 0px 0px 15px 0px;
24
113
  display: block;
25
- background: ${cssManager.bdTheme('#eeeeeb', '#222222')};;
26
- font-family: Inter;
27
- color: #fff;
114
+ background: transparent;
115
+ font-family: ${unsafeCSS(sharedStyles.fonts.base)};
116
+ color: ${sharedStyles.colors.text.primary};
117
+ }
118
+
119
+ .container {
120
+ max-width: 1200px;
121
+ margin: 0 auto;
122
+ padding: 0 ${unsafeCSS(sharedStyles.spacing.lg)} ${unsafeCSS(sharedStyles.spacing.lg)} ${unsafeCSS(sharedStyles.spacing.lg)};
123
+ }
124
+
125
+ .graph-wrapper {
126
+ display: flex;
127
+ flex-direction: column;
128
+ gap: 4px;
129
+ }
130
+
131
+ .graph-container {
132
+ position: relative;
28
133
  }
29
134
 
30
135
  .mainbox {
31
- margin: auto;
32
- max-width: 900px;
33
- text-align: right;
34
- background: ${cssManager.bdTheme('#ffffff', '#333333')};;
35
- line-height: 50px;
36
- border-radius: 3px;
136
+ background: transparent;
137
+ border: none;
138
+ border-radius: 0;
139
+ padding: 0;
37
140
  }
38
141
 
39
142
  .mainbox .barContainer {
40
143
  position: relative;
41
144
  display: flex;
42
- padding: 6px;
145
+ gap: 2px;
146
+ padding: ${unsafeCSS(sharedStyles.spacing.sm)};
147
+ background: ${cssManager.bdTheme('#fafafa', '#0a0a0a')};
148
+ border: 1px solid ${cssManager.bdTheme('#e5e7eb', '#27272a')};
149
+ border-radius: ${unsafeCSS(sharedStyles.borderRadius.base)};
43
150
  overflow: hidden;
151
+ height: 40px;
44
152
  }
45
153
 
46
154
  .mainbox .barContainer .bar {
47
- margin: 4px;
48
- width: 11px;
49
- border-radius: 3px;
50
- height: 40px;
51
- background: #2deb51;
155
+ flex: 1;
156
+ height: 100%;
157
+ cursor: pointer;
158
+ transition: all 0.15s ease;
159
+ position: relative;
160
+ border-radius: 2px;
161
+ }
162
+
163
+ .mainbox .barContainer .bar:hover {
164
+ transform: scaleY(1.1);
165
+ box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
166
+ }
167
+
168
+ .mainbox .barContainer .bar.operational {
169
+ background: ${cssManager.bdTheme('#22c55e', '#22c55e')};
170
+ }
171
+
172
+ .mainbox .barContainer .bar.degraded {
173
+ background: ${cssManager.bdTheme('#fbbf24', '#fbbf24')};
174
+ }
175
+
176
+ .mainbox .barContainer .bar.partial_outage {
177
+ background: ${cssManager.bdTheme('#f87171', '#f87171')};
178
+ }
179
+
180
+ .mainbox .barContainer .bar.major_outage {
181
+ background: ${cssManager.bdTheme('#ef4444', '#ef4444')};
182
+ }
183
+
184
+ .mainbox .barContainer .bar.maintenance {
185
+ background: ${cssManager.bdTheme('#60a5fa', '#60a5fa')};
186
+ }
187
+
188
+ .mainbox .barContainer .bar.no-data {
189
+ background: ${cssManager.bdTheme('#e5e7eb', '#27272a')};
190
+ opacity: 0.6;
191
+ }
192
+
193
+
194
+ .time-labels {
195
+ display: flex;
196
+ justify-content: space-between;
197
+ padding: 0;
198
+ margin-top: ${unsafeCSS(sharedStyles.spacing.xs)};
199
+ font-size: 10px;
200
+ color: ${cssManager.bdTheme('#9ca3af', '#71717a')};
201
+ font-family: ${unsafeCSS(sharedStyles.fonts.base)};
202
+ opacity: 0.8;
52
203
  }
53
- .timeIndicator {
204
+
205
+ .tooltip {
54
206
  position: absolute;
55
- width: 11px;
56
- height: 11px;
57
- background: #FF9800;
58
- top: 56px;
59
- left: 400px;
60
- transform: rotate(45deg);
207
+ background: ${cssManager.bdTheme('#0a0a0a', '#fafafa')};
208
+ color: ${cssManager.bdTheme('#fafafa', '#0a0a0a')};
209
+ padding: 6px 10px;
210
+ border-radius: 4px;
211
+ font-size: 11px;
212
+ pointer-events: none;
213
+ opacity: 0;
214
+ transition: opacity 0.15s;
215
+ z-index: 50;
216
+ white-space: nowrap;
217
+ box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
218
+ line-height: 1.4;
219
+ }
220
+
221
+ .tooltip.visible {
222
+ opacity: 1;
223
+ }
224
+
225
+ .tooltip-time {
226
+ font-weight: 600;
227
+ display: block;
228
+ margin-bottom: 2px;
229
+ }
230
+
231
+ .tooltip-stat {
232
+ font-size: 10px;
233
+ opacity: 0.9;
234
+ }
235
+
236
+ .loading-skeleton {
237
+ display: flex;
238
+ gap: 1px;
239
+ height: 24px;
240
+ }
241
+
242
+ .loading-skeleton .skeleton-bar {
243
+ flex: 1;
244
+ height: 100%;
245
+ background: ${cssManager.bdTheme('#f3f4f6', '#27272a')};
246
+ animation: pulse 2s infinite;
247
+ }
248
+
249
+ @keyframes pulse {
250
+ 0%, 100% { opacity: 1; }
251
+ 50% { opacity: 0.5; }
252
+ }
253
+
254
+ @keyframes loading {
255
+ 0% { background-position: 200% 0; }
256
+ 100% { background-position: -200% 0; }
257
+ }
258
+
259
+
260
+ @media (max-width: 640px) {
261
+ .container {
262
+ padding: 0 ${unsafeCSS(sharedStyles.spacing.md)} ${unsafeCSS(sharedStyles.spacing.md)} ${unsafeCSS(sharedStyles.spacing.md)};
263
+ }
264
+
265
+ .graph-container {
266
+ padding: ${unsafeCSS(sharedStyles.spacing.sm)};
267
+ }
268
+
269
+ .mainbox .barContainer {
270
+ height: 32px;
271
+ padding: ${unsafeCSS(sharedStyles.spacing.xs)};
272
+ }
273
+
274
+ .time-labels {
275
+ font-size: 9px;
276
+ }
277
+
278
+ .stats-row {
279
+ font-size: 11px;
280
+ flex-direction: column;
281
+ gap: ${unsafeCSS(sharedStyles.spacing.sm)};
282
+ align-items: flex-start;
283
+ }
61
284
  }
62
285
  `,
63
- ]; }
64
- render() {
65
- return html `
66
- <style></style>
67
- <uplinternal-miniheading>Yesterday & Today</uplinternal-miniheading>
68
- <div class="mainbox">
69
- <div class="barContainer">
70
- ${(() => {
71
- let counter = 0;
72
- const returnArray = [];
73
- while (counter < 48) {
74
- counter++;
75
- returnArray.push(html ` <div class="bar"></div> `);
76
- }
77
- return returnArray;
78
- })()}
79
- <div class="timeIndicator"></div>
286
+ ];
287
+ render() {
288
+ return html `
289
+ <div class="container">
290
+ <uplinternal-miniheading>${this.serviceName} - Last ${this.hoursToShow} Hours</uplinternal-miniheading>
291
+ <div class="mainbox">
292
+ ${this.loading ? html `
293
+ <div class="graph-container">
294
+ <div class="barContainer" style="background: ${cssManager.bdTheme('#fafafa', '#0a0a0a')}; border: 1px solid ${cssManager.bdTheme('#f3f4f6', '#1f1f1f')}; border-radius: ${sharedStyles.borderRadius.base}; padding: ${sharedStyles.spacing.sm}; height: 40px;">
295
+ <div class="loading-skeleton">
296
+ ${Array(this.hoursToShow).fill(0).map(() => html `<div class="skeleton-bar"></div>`)}
297
+ </div>
298
+ </div>
299
+ </div>
300
+ ` : html `
301
+ <div class="graph-container">
302
+ <div class="barContainer" @mouseleave=${this.hideTooltip}>
303
+ ${this.renderBars()}
304
+ </div>
305
+ </div>
306
+ <div class="time-labels">
307
+ <span>${this.getTimeLabel(this.hoursToShow - 1)}</span>
308
+ <span>${this.getTimeLabel(Math.floor(this.hoursToShow * 3 / 4))}</span>
309
+ <span>${this.getTimeLabel(Math.floor(this.hoursToShow / 2))}</span>
310
+ <span>${this.getTimeLabel(Math.floor(this.hoursToShow / 4))}</span>
311
+ <span>now</span>
312
+ </div>
313
+ `}
80
314
  </div>
315
+ <div class="tooltip" id="tooltip"></div>
81
316
  </div>
82
317
  `;
83
- }
84
- };
85
- UplStatuspageStatusdetails = __decorate([
86
- customElement('upl-statuspage-statusdetails'),
87
- __metadata("design:paramtypes", [])
88
- ], UplStatuspageStatusdetails);
318
+ }
319
+ renderBars() {
320
+ const bars = [];
321
+ const now = Date.now();
322
+ for (let i = 0; i < this.hoursToShow; i++) {
323
+ const hourIndex = this.hoursToShow - 1 - i;
324
+ const timestamp = now - (hourIndex * 60 * 60 * 1000);
325
+ const dataPoint = this.findDataPointForTime(timestamp);
326
+ const status = dataPoint?.status || 'no-data';
327
+ const responseTime = dataPoint?.responseTime || 0;
328
+ bars.push(html `
329
+ <div
330
+ class="bar ${status}"
331
+ @mouseenter=${(e) => this.showTooltip(e, timestamp, status, responseTime)}
332
+ @click=${() => this.handleBarClick(timestamp, status, responseTime)}
333
+ ></div>
334
+ `);
335
+ }
336
+ return bars;
337
+ }
338
+ getData() {
339
+ return this.dataPoints?.length > 0 ? this.dataPoints : this.historyData || [];
340
+ }
341
+ findDataPointForTime(timestamp) {
342
+ const data = this.getData();
343
+ if (!data || data.length === 0)
344
+ return undefined;
345
+ // Find the closest data point within the same hour
346
+ const targetHour = new Date(timestamp).getHours();
347
+ const targetDate = new Date(timestamp).toDateString();
348
+ return data.find(point => {
349
+ const pointDate = new Date(point.timestamp);
350
+ return pointDate.toDateString() === targetDate &&
351
+ pointDate.getHours() === targetHour;
352
+ });
353
+ }
354
+ getTimeLabel(hoursAgo) {
355
+ const date = new Date(Date.now() - (hoursAgo * 60 * 60 * 1000));
356
+ if (hoursAgo >= 24) {
357
+ return `${date.getMonth() + 1}/${date.getDate()}`;
358
+ }
359
+ return `${date.getHours()}h`;
360
+ }
361
+ showTooltip(event, timestamp, status, responseTime) {
362
+ const tooltip = this.shadowRoot?.getElementById('tooltip');
363
+ if (!tooltip)
364
+ return;
365
+ const date = new Date(timestamp);
366
+ const timeStr = date.toLocaleString();
367
+ const statusStr = status.replace(/_/g, ' ').replace('no-data', 'No Data');
368
+ tooltip.innerHTML = `
369
+ <div class="tooltip-time">${timeStr}</div>
370
+ <div class="tooltip-stat">Status: ${statusStr}</div>
371
+ ${responseTime > 0 ? `<div class="tooltip-stat">Response Time: ${responseTime.toFixed(0)}ms</div>` : ''}
372
+ `;
373
+ const rect = event.target.getBoundingClientRect();
374
+ const containerRect = this.getBoundingClientRect();
375
+ tooltip.style.left = `${rect.left - containerRect.left + rect.width / 2}px`;
376
+ tooltip.style.top = `${rect.top - containerRect.top - 10}px`;
377
+ tooltip.style.transform = 'translate(-50%, -100%)';
378
+ tooltip.classList.add('visible');
379
+ }
380
+ hideTooltip() {
381
+ const tooltip = this.shadowRoot?.getElementById('tooltip');
382
+ if (tooltip) {
383
+ tooltip.classList.remove('visible');
384
+ }
385
+ }
386
+ handleBarClick(timestamp, status, responseTime) {
387
+ this.dispatchEvent(new CustomEvent('barClick', {
388
+ detail: { timestamp, status, responseTime, serviceId: this.serviceId },
389
+ bubbles: true,
390
+ composed: true
391
+ }));
392
+ }
393
+ static {
394
+ __runInitializers(_classThis, _classExtraInitializers);
395
+ }
396
+ };
397
+ return UplStatuspageStatusdetails = _classThis;
398
+ })();
89
399
  export { UplStatuspageStatusdetails };
90
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBsLXN0YXR1c3BhZ2Utc3RhdHVzZGV0YWlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3RzX3dlYi9lbGVtZW50cy91cGwtc3RhdHVzcGFnZS1zdGF0dXNkZXRhaWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFDTCxXQUFXLEVBQ1gsUUFBUSxFQUNSLElBQUksRUFDSixhQUFhLEVBRWIsR0FBRyxFQUNILFVBQVUsR0FDWCxNQUFNLDZCQUE2QixDQUFDO0FBRXJDLE9BQU8sdUNBQXVDLENBQUM7QUFTeEMsSUFBTSwwQkFBMEIsR0FBaEMsTUFBTSwwQkFBMkIsU0FBUSxXQUFXO2FBQzNDLFNBQUksR0FBRyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUEsaUVBQWlFLEFBQTlFLENBQStFO0lBRWpHO1FBQ0UsS0FBSyxFQUFFLENBQUM7SUFDVixDQUFDO2FBRWEsV0FBTSxHQUFHO1FBQ3JCLE9BQU8sQ0FBQyxRQUFRLENBQUMsWUFBWSxDQUFDLFlBQVk7UUFDMUMsR0FBRyxDQUFBOzs7Ozt1QkFLZ0IsVUFBVSxDQUFDLE9BQU8sQ0FBQyxTQUFTLEVBQUUsU0FBUyxDQUFDOzs7Ozs7Ozs7dUJBU3hDLFVBQVUsQ0FBQyxPQUFPLENBQUMsU0FBUyxFQUFFLFNBQVMsQ0FBQzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztLQTRCMUQ7S0FDRixBQTdDbUIsQ0E2Q2xCO0lBRUssTUFBTTtRQUNYLE9BQU8sSUFBSSxDQUFBOzs7OztZQUtILENBQUMsR0FBRyxFQUFFO1lBQ04sSUFBSSxPQUFPLEdBQUcsQ0FBQyxDQUFDO1lBQ2hCLE1BQU0sV0FBVyxHQUFxQixFQUFFLENBQUM7WUFDekMsT0FBTyxPQUFPLEdBQUcsRUFBRSxFQUFFLENBQUM7Z0JBQ3BCLE9BQU8sRUFBRSxDQUFDO2dCQUNWLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFBLDJCQUEyQixDQUFDLENBQUM7WUFDcEQsQ0FBQztZQUNELE9BQU8sV0FBVyxDQUFDO1FBQ3JCLENBQUMsQ0FBQyxFQUFFOzs7O0tBSVQsQ0FBQztJQUNKLENBQUM7O0FBekVVLDBCQUEwQjtJQUR0QyxhQUFhLENBQUMsOEJBQThCLENBQUM7O0dBQ2pDLDBCQUEwQixDQTBFdEMifQ==
400
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBsLXN0YXR1c3BhZ2Utc3RhdHVzZGV0YWlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3RzX3dlYi9lbGVtZW50cy91cGwtc3RhdHVzcGFnZS1zdGF0dXNkZXRhaWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxPQUFPLEtBQUssT0FBTyxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQ0wsV0FBVyxFQUNYLFFBQVEsRUFDUixJQUFJLEVBQ0osYUFBYSxFQUViLEdBQUcsRUFDSCxVQUFVLEVBQ1YsU0FBUyxHQUNWLE1BQU0sNkJBQTZCLENBQUM7QUFFckMsT0FBTyxLQUFLLFlBQVksTUFBTSw0QkFBNEIsQ0FBQztBQUUzRCxPQUFPLHVDQUF1QyxDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztJQVNyRCwwQkFBMEI7NEJBRHRDLGFBQWEsQ0FBQyw4QkFBOEIsQ0FBQzs7OztzQkFDRSxXQUFXOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OzBDQUFuQixTQUFRLFdBQVc7Ozs7dUNBR3hELFFBQVEsQ0FBQyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsQ0FBQztzQ0FHekIsUUFBUSxDQUFDLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxDQUFDO3FDQUd6QixRQUFRLENBQUMsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLENBQUM7dUNBRzFCLFFBQVEsQ0FBQyxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsQ0FBQzttQ0FHMUIsUUFBUSxDQUFDLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxDQUFDO3VDQUczQixRQUFRLENBQUMsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLENBQUM7WUFkM0Isc0xBQVMsV0FBVyw2QkFBWCxXQUFXLGlHQUE2QjtZQUdqRCxtTEFBUyxVQUFVLDZCQUFWLFVBQVUsK0ZBQTZCO1lBR2hELGdMQUFTLFNBQVMs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
@@ -1,4 +1,5 @@
1
1
  import { DeesElement, type TemplateResult } from '@design.estate/dees-element';
2
+ import type { IMonthlyUptime } from '../interfaces/index.js';
2
3
  import './internal/uplinternal-miniheading.js';
3
4
  declare global {
4
5
  interface HTMLElementTagNameMap {
@@ -7,7 +8,21 @@ declare global {
7
8
  }
8
9
  export declare class UplStatuspageStatusmonth extends DeesElement {
9
10
  static demo: () => TemplateResult<1>;
11
+ accessor monthlyData: IMonthlyUptime[];
12
+ accessor serviceId: string;
13
+ accessor serviceName: string;
14
+ accessor loading: boolean;
15
+ accessor showTooltip: boolean;
16
+ accessor monthsToShow: number;
10
17
  constructor();
11
18
  static styles: import("@design.estate/dees-element").CSSResult[];
12
19
  render(): TemplateResult;
20
+ private renderMonth;
21
+ private renderWeekdayLabels;
22
+ private renderEmptyDays;
23
+ private renderTrailingEmptyDays;
24
+ private renderDay;
25
+ private showDayTooltip;
26
+ private hideTooltip;
27
+ private handleDayClick;
13
28
  }
@@ -0,0 +1 @@
1
+ export declare const demoFunc: () => import("@design.estate/dees-element").TemplateResult<1>;