@uptime.link/statuspage 1.0.73 → 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 (96) 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 +54534 -26433
  59. package/dist_watch/bundle.js.map +4 -4
  60. package/dist_watch/index.html +3 -10
  61. package/npmextra.json +9 -3
  62. package/package.json +19 -19
  63. package/readme.hints.md +292 -0
  64. package/readme.md +326 -149
  65. package/readme.plan.md +261 -0
  66. package/ts_web/00_commitinfo_data.ts +1 -1
  67. package/ts_web/elements/index.ts +6 -0
  68. package/ts_web/elements/internal/uplinternal-miniheading.ts +24 -17
  69. package/ts_web/elements/upl-statuspage-assetsselector.demo.ts +607 -0
  70. package/ts_web/elements/upl-statuspage-assetsselector.ts +526 -18
  71. package/ts_web/elements/upl-statuspage-footer.demo.ts +744 -0
  72. package/ts_web/elements/upl-statuspage-footer.ts +608 -30
  73. package/ts_web/elements/upl-statuspage-header.demo.ts +241 -0
  74. package/ts_web/elements/upl-statuspage-header.ts +220 -52
  75. package/ts_web/elements/upl-statuspage-incidents.demo.ts +1216 -0
  76. package/ts_web/elements/upl-statuspage-incidents.ts +649 -26
  77. package/ts_web/elements/upl-statuspage-pagetitle.demo.ts +25 -0
  78. package/ts_web/elements/upl-statuspage-pagetitle.ts +89 -0
  79. package/ts_web/elements/upl-statuspage-statsgrid.demo.ts +315 -0
  80. package/ts_web/elements/upl-statuspage-statsgrid.ts +306 -0
  81. package/ts_web/elements/upl-statuspage-statusbar.demo.ts +393 -0
  82. package/ts_web/elements/upl-statuspage-statusbar.ts +281 -20
  83. package/ts_web/elements/upl-statuspage-statusdetails.demo.ts +754 -0
  84. package/ts_web/elements/upl-statuspage-statusdetails.ts +297 -38
  85. package/ts_web/elements/upl-statuspage-statusmonth.demo.ts +876 -0
  86. package/ts_web/elements/upl-statuspage-statusmonth.ts +397 -76
  87. package/ts_web/interfaces/index.ts +95 -0
  88. package/ts_web/pages/index.ts +4 -1
  89. package/ts_web/pages/statuspage-allgreen.ts +412 -0
  90. package/ts_web/pages/statuspage-demo.ts +653 -0
  91. package/ts_web/pages/statuspage-maintenance.ts +570 -0
  92. package/ts_web/pages/statuspage-outage.ts +568 -0
  93. package/ts_web/styles/shared.styles.ts +367 -0
  94. package/dist_ts_web/pages/page1.d.ts +0 -1
  95. package/dist_ts_web/pages/page1.js +0 -11
  96. package/ts_web/pages/page1.ts +0 -11
@@ -1,109 +1,336 @@
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
- import { DeesElement, property, html, customElement, css, cssManager } from '@design.estate/dees-element';
35
+ import { DeesElement, property, html, customElement, css, cssManager, unsafeCSS } from '@design.estate/dees-element';
11
36
  import * as domtools from '@design.estate/dees-domtools';
12
- let UplStatuspageHeader = class UplStatuspageHeader extends DeesElement {
13
- // STATIC
14
- static { this.demo = () => html `
15
- <upl-statuspage-header></upl-statuspage-header>
16
- `; }
17
- constructor() {
18
- super();
37
+ import * as sharedStyles from '../styles/shared.styles.js';
38
+ import { demoFunc } from './upl-statuspage-header.demo.js';
39
+ let UplStatuspageHeader = (() => {
40
+ let _classDecorators = [customElement('upl-statuspage-header')];
41
+ let _classDescriptor;
42
+ let _classExtraInitializers = [];
43
+ let _classThis;
44
+ let _classSuper = DeesElement;
45
+ let _pageTitle_decorators;
46
+ let _pageTitle_initializers = [];
47
+ let _pageTitle_extraInitializers = [];
48
+ let _showReportButton_decorators;
49
+ let _showReportButton_initializers = [];
50
+ let _showReportButton_extraInitializers = [];
51
+ let _showSubscribeButton_decorators;
52
+ let _showSubscribeButton_initializers = [];
53
+ let _showSubscribeButton_extraInitializers = [];
54
+ let _logoUrl_decorators;
55
+ let _logoUrl_initializers = [];
56
+ let _logoUrl_extraInitializers = [];
57
+ let _loading_decorators;
58
+ let _loading_initializers = [];
59
+ let _loading_extraInitializers = [];
60
+ var UplStatuspageHeader = class extends _classSuper {
61
+ static { _classThis = this; }
62
+ static {
63
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
64
+ _pageTitle_decorators = [property({ type: String })];
65
+ _showReportButton_decorators = [property({ type: Boolean })];
66
+ _showSubscribeButton_decorators = [property({ type: Boolean })];
67
+ _logoUrl_decorators = [property({ type: String })];
68
+ _loading_decorators = [property({ type: Boolean })];
69
+ __esDecorate(this, null, _pageTitle_decorators, { kind: "accessor", name: "pageTitle", static: false, private: false, access: { has: obj => "pageTitle" in obj, get: obj => obj.pageTitle, set: (obj, value) => { obj.pageTitle = value; } }, metadata: _metadata }, _pageTitle_initializers, _pageTitle_extraInitializers);
70
+ __esDecorate(this, null, _showReportButton_decorators, { kind: "accessor", name: "showReportButton", static: false, private: false, access: { has: obj => "showReportButton" in obj, get: obj => obj.showReportButton, set: (obj, value) => { obj.showReportButton = value; } }, metadata: _metadata }, _showReportButton_initializers, _showReportButton_extraInitializers);
71
+ __esDecorate(this, null, _showSubscribeButton_decorators, { kind: "accessor", name: "showSubscribeButton", static: false, private: false, access: { has: obj => "showSubscribeButton" in obj, get: obj => obj.showSubscribeButton, set: (obj, value) => { obj.showSubscribeButton = value; } }, metadata: _metadata }, _showSubscribeButton_initializers, _showSubscribeButton_extraInitializers);
72
+ __esDecorate(this, null, _logoUrl_decorators, { kind: "accessor", name: "logoUrl", static: false, private: false, access: { has: obj => "logoUrl" in obj, get: obj => obj.logoUrl, set: (obj, value) => { obj.logoUrl = value; } }, metadata: _metadata }, _logoUrl_initializers, _logoUrl_extraInitializers);
73
+ __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);
74
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
75
+ UplStatuspageHeader = _classThis = _classDescriptor.value;
76
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
77
+ }
78
+ // STATIC
79
+ static demo = demoFunc;
80
+ #pageTitle_accessor_storage = __runInitializers(this, _pageTitle_initializers, "Statuspage Title");
19
81
  // INSTANCE
20
- this.pageTitle = "Statuspage Title";
21
- }
22
- static { this.styles = [
23
- domtools.elementBasic.staticStyles,
24
- css `
82
+ get pageTitle() { return this.#pageTitle_accessor_storage; }
83
+ set pageTitle(value) { this.#pageTitle_accessor_storage = value; }
84
+ #showReportButton_accessor_storage = (__runInitializers(this, _pageTitle_extraInitializers), __runInitializers(this, _showReportButton_initializers, true));
85
+ get showReportButton() { return this.#showReportButton_accessor_storage; }
86
+ set showReportButton(value) { this.#showReportButton_accessor_storage = value; }
87
+ #showSubscribeButton_accessor_storage = (__runInitializers(this, _showReportButton_extraInitializers), __runInitializers(this, _showSubscribeButton_initializers, true));
88
+ get showSubscribeButton() { return this.#showSubscribeButton_accessor_storage; }
89
+ set showSubscribeButton(value) { this.#showSubscribeButton_accessor_storage = value; }
90
+ #logoUrl_accessor_storage = (__runInitializers(this, _showSubscribeButton_extraInitializers), __runInitializers(this, _logoUrl_initializers, ''));
91
+ get logoUrl() { return this.#logoUrl_accessor_storage; }
92
+ set logoUrl(value) { this.#logoUrl_accessor_storage = value; }
93
+ #loading_accessor_storage = (__runInitializers(this, _logoUrl_extraInitializers), __runInitializers(this, _loading_initializers, false));
94
+ get loading() { return this.#loading_accessor_storage; }
95
+ set loading(value) { this.#loading_accessor_storage = value; }
96
+ constructor() {
97
+ super();
98
+ __runInitializers(this, _loading_extraInitializers);
99
+ }
100
+ static styles = [
101
+ domtools.elementBasic.staticStyles,
102
+ css `
25
103
  :host {
26
- display: block;
27
- background: ${cssManager.bdTheme('#eeeeeb', '#222222')};
28
- font-family: Inter;
29
- color: ${cssManager.bdTheme('#333333', '#ffffff')};
104
+ display: block;
105
+ background: ${sharedStyles.colors.background.primary};
106
+ font-family: ${unsafeCSS(sharedStyles.fonts.base)};
107
+ color: ${sharedStyles.colors.text.primary};
108
+ border-bottom: 1px solid ${sharedStyles.colors.border.default};
109
+ position: sticky;
110
+ top: 0;
111
+ z-index: 40;
112
+ backdrop-filter: blur(12px);
113
+ -webkit-backdrop-filter: blur(12px);
114
+ }
115
+
116
+ .header-container {
117
+ max-width: 1200px;
118
+ margin: 0 auto;
119
+ padding: 0 ${unsafeCSS(sharedStyles.spacing.lg)};
120
+ }
121
+
122
+ .header-nav {
123
+ display: flex;
124
+ align-items: center;
125
+ justify-content: space-between;
126
+ height: 64px;
127
+ }
128
+
129
+ .header-left {
130
+ display: flex;
131
+ align-items: center;
132
+ gap: ${unsafeCSS(sharedStyles.spacing.lg)};
133
+ }
134
+
135
+ .header-actions {
136
+ display: flex;
137
+ align-items: center;
138
+ gap: ${unsafeCSS(sharedStyles.spacing.sm)};
139
+ }
140
+
141
+ .actionButton {
142
+ font-family: ${unsafeCSS(sharedStyles.fonts.base)};
143
+ font-size: 13px;
144
+ font-weight: 500;
145
+ padding: 0 14px;
146
+ border-radius: ${unsafeCSS(sharedStyles.borderRadius.base)};
147
+ cursor: pointer;
148
+ user-select: none;
149
+ transition: all ${unsafeCSS(sharedStyles.durations.normal)} ${unsafeCSS(sharedStyles.easings.default)};
150
+ display: inline-flex;
151
+ align-items: center;
152
+ justify-content: center;
153
+ height: 36px;
154
+ background: transparent;
155
+ border: 1px solid ${sharedStyles.colors.border.default};
156
+ color: ${sharedStyles.colors.text.primary};
157
+ letter-spacing: -0.01em;
158
+ }
159
+
160
+ .actionButton:hover {
161
+ background: ${sharedStyles.colors.background.secondary};
162
+ border-color: ${sharedStyles.colors.border.muted};
163
+ box-shadow: ${unsafeCSS(sharedStyles.shadows.xs)};
164
+ }
165
+
166
+ .actionButton:active {
167
+ transform: scale(0.98);
168
+ transition-duration: ${unsafeCSS(sharedStyles.durations.fast)};
169
+ }
170
+
171
+ .actionButton:focus-visible {
172
+ outline: 2px solid ${sharedStyles.colors.accent.focus};
173
+ outline-offset: 2px;
174
+ }
175
+
176
+ .site-title {
177
+ font-size: 18px;
178
+ font-weight: 600;
179
+ letter-spacing: -0.02em;
180
+ color: ${sharedStyles.colors.text.primary};
181
+ }
182
+
183
+ .logo {
184
+ height: 28px;
185
+ width: auto;
186
+ filter: ${cssManager.bdTheme('none', 'brightness(0) invert(1)')};
187
+ transition: opacity ${unsafeCSS(sharedStyles.durations.normal)} ${unsafeCSS(sharedStyles.easings.default)};
188
+ }
189
+
190
+ .logo:hover {
191
+ opacity: 0.8;
192
+ }
193
+
194
+ .page-info {
195
+ padding: ${unsafeCSS(sharedStyles.spacing.lg)} 0 ${unsafeCSS(sharedStyles.spacing.xl)} 0;
196
+ }
197
+
198
+ .page-title {
199
+ font-size: 48px;
200
+ font-weight: 700;
201
+ letter-spacing: -0.03em;
202
+ line-height: 1.1;
203
+ color: ${sharedStyles.colors.text.primary};
204
+ margin: 0 0 16px 0;
205
+ }
206
+
207
+ .page-subtitle {
208
+ font-size: 18px;
209
+ color: ${sharedStyles.colors.text.secondary};
210
+ margin: 0;
211
+ line-height: 1.5;
212
+ }
213
+
214
+ /* Primary button variant */
215
+ .actionButton.primary {
216
+ background: ${sharedStyles.colors.accent.primary};
217
+ color: ${sharedStyles.colors.background.primary};
218
+ border-color: transparent;
219
+ }
220
+
221
+ .actionButton.primary:hover {
222
+ background: ${sharedStyles.colors.accent.hover};
223
+ box-shadow: ${unsafeCSS(sharedStyles.shadows.sm)};
224
+ }
225
+
226
+ .loading-skeleton {
227
+ height: 64px;
228
+ background: ${sharedStyles.colors.background.secondary};
229
+ border-bottom: 1px solid ${sharedStyles.colors.border.default};
230
+ position: relative;
231
+ overflow: hidden;
232
+ }
233
+
234
+ .loading-skeleton::after {
235
+ content: '';
236
+ position: absolute;
237
+ inset: 0;
238
+ background: ${cssManager.bdTheme('linear-gradient(90deg, transparent 0%, rgba(0,0,0,0.04) 50%, transparent 100%)', 'linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.04) 50%, transparent 100%)')};
239
+ animation: loading 1.5s ${unsafeCSS(sharedStyles.easings.default)} infinite;
240
+ }
241
+
242
+ @keyframes loading {
243
+ 0% { transform: translateX(-100%); }
244
+ 100% { transform: translateX(200%); }
245
+ }
246
+
247
+ @media (max-width: 768px) {
248
+ .header-container {
249
+ padding: 0 ${unsafeCSS(sharedStyles.spacing.md)};
30
250
  }
31
251
 
32
- .mainbox {
33
- margin: auto;
34
- max-width: 900px;
252
+ .header-nav {
253
+ height: 56px;
35
254
  }
36
255
 
37
- .mainbox .actions {
38
- display: flex;
39
- justify-content: flex-end;
40
- padding: 20px 0px 40px 0px;
256
+ .header-left {
257
+ gap: ${unsafeCSS(sharedStyles.spacing.md)};
41
258
  }
42
259
 
43
- .mainbox .actions .actionButton {
44
- background: ${cssManager.bdTheme('#00000000', '#ffffff00')};
45
-
260
+ .site-title {
261
+ font-size: 16px;
262
+ }
263
+
264
+ .logo {
265
+ height: 24px;
266
+ }
267
+ }
268
+
269
+ @media (max-width: 640px) {
270
+ .actionButton {
46
271
  font-size: 12px;
47
- border: 1px solid ${cssManager.bdTheme('#333', '#CCC')};
48
- padding: 6px 10px 7px 10px;
49
- margin-left: 10px;
50
- border-radius: 3px;
51
- cursor: pointer;
52
- user-select: none;
272
+ padding: 0 12px;
273
+ height: 32px;
53
274
  }
54
275
 
55
- .mainbox .actions .actionButton:hover {
56
- background: ${cssManager.bdTheme('#333333', '#efefef')};
57
- border: 1px solid ${cssManager.bdTheme('#333333', '#efefef')};
58
- color: ${cssManager.bdTheme('#fff', '#333333')};
276
+ .page-title {
277
+ font-size: 32px;
59
278
  }
60
279
 
61
- h1 {
62
- margin: 0px;
63
- text-align: center;
64
- font-weight: 600;
65
- font-size: 35px;
280
+ .page-subtitle {
281
+ font-size: 16px;
66
282
  }
67
283
 
68
- h2 {
69
- margin: 0px;
70
- margin-top: 10px;
71
- text-align: center;
72
- font-weight: 600;
73
- font-size: 18px;
284
+ .header-actions {
285
+ gap: 6px;
74
286
  }
287
+ }
75
288
  `
76
- ]; }
77
- render() {
78
- return html `
79
- ${domtools.elementBasic.styles}
80
- <style>
81
-
82
- </style>
83
- <div class="mainbox">
84
- <div class="actions">
85
- <div class="actionButton" @click=${this.dispatchReportNewIncident}>report new incident</div>
86
- <div class="actionButton" @click=${this.dispatchStatusSubscribe}>subscribe</div>
289
+ ];
290
+ render() {
291
+ if (this.loading) {
292
+ return html `
293
+ <div class="loading-skeleton"></div>
294
+ `;
295
+ }
296
+ return html `
297
+ <header>
298
+ <div class="header-container">
299
+ <nav class="header-nav">
300
+ <div class="header-left">
301
+ ${this.logoUrl ? html `
302
+ <img src="${this.logoUrl}" alt="${this.pageTitle}" class="logo">
303
+ ` : ''}
304
+ <h1 class="site-title">${this.pageTitle}</h1>
305
+ </div>
306
+ <div class="header-actions">
307
+ ${this.showReportButton ? html `
308
+ <button class="actionButton" @click=${this.dispatchReportNewIncident}>
309
+ Report Issue
310
+ </button>
311
+ ` : ''}
312
+ ${this.showSubscribeButton ? html `
313
+ <button class="actionButton primary" @click=${this.dispatchStatusSubscribe}>
314
+ Subscribe
315
+ </button>
316
+ ` : ''}
317
+ </div>
318
+ </nav>
87
319
  </div>
88
- <h1>${this.pageTitle}</h1>
89
- <h2>STATUS BOARD</h2>
90
- </div>
320
+ </header>
91
321
  `;
92
- }
93
- dispatchReportNewIncident() {
94
- this.dispatchEvent(new CustomEvent('reportNewIncident', {}));
95
- }
96
- dispatchStatusSubscribe() {
97
- this.dispatchEvent(new CustomEvent('statusSubscribe', {}));
98
- }
99
- };
100
- __decorate([
101
- property(),
102
- __metadata("design:type", String)
103
- ], UplStatuspageHeader.prototype, "pageTitle", void 0);
104
- UplStatuspageHeader = __decorate([
105
- customElement('upl-statuspage-header'),
106
- __metadata("design:paramtypes", [])
107
- ], UplStatuspageHeader);
322
+ }
323
+ dispatchReportNewIncident() {
324
+ this.dispatchEvent(new CustomEvent('reportNewIncident', {}));
325
+ }
326
+ dispatchStatusSubscribe() {
327
+ this.dispatchEvent(new CustomEvent('statusSubscribe', {}));
328
+ }
329
+ static {
330
+ __runInitializers(_classThis, _classExtraInitializers);
331
+ }
332
+ };
333
+ return UplStatuspageHeader = _classThis;
334
+ })();
108
335
  export { UplStatuspageHeader };
109
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBsLXN0YXR1c3BhZ2UtaGVhZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vdHNfd2ViL2VsZW1lbnRzL3VwbC1zdGF0dXNwYWdlLWhlYWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQSxPQUFPLEVBQUUsV0FBVyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsYUFBYSxFQUF1QixHQUFHLEVBQUUsVUFBVSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDL0gsT0FBTyxLQUFLLFFBQVEsTUFBTSw4QkFBOEIsQ0FBQztBQVNsRCxJQUFNLG1CQUFtQixHQUF6QixNQUFNLG1CQUFvQixTQUFRLFdBQVc7SUFDbEQsU0FBUzthQUNLLFNBQUksR0FBRyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUE7O0dBRTlCLEFBRmlCLENBRWhCO0lBT0Y7UUFDRSxLQUFLLEVBQUUsQ0FBQztRQU5WLFdBQVc7UUFFSixjQUFTLEdBQVcsa0JBQWtCLENBQUM7SUFLOUMsQ0FBQzthQUVhLFdBQU0sR0FBRztRQUNyQixRQUFRLENBQUMsWUFBWSxDQUFDLFlBQVk7UUFDbEMsR0FBRyxDQUFBOzs7d0JBR2lCLFVBQVUsQ0FBQyxPQUFPLENBQUMsU0FBUyxFQUFFLFNBQVMsQ0FBQzs7bUJBRTdDLFVBQVUsQ0FBQyxPQUFPLENBQUMsU0FBUyxFQUFFLFNBQVMsQ0FBQzs7Ozs7Ozs7Ozs7Ozs7O3dCQWVuQyxVQUFVLENBQUMsT0FBTyxDQUFDLFdBQVcsRUFBRSxXQUFXLENBQUM7Ozs4QkFHdEMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDOzs7Ozs7Ozs7d0JBU3hDLFVBQVUsQ0FBQyxPQUFPLENBQUMsU0FBUyxFQUFFLFNBQVMsQ0FBQzs4QkFDbEMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxTQUFTLEVBQUUsU0FBUyxDQUFDO21CQUNuRCxVQUFVLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxTQUFTLENBQUM7Ozs7Ozs7Ozs7Ozs7Ozs7O0tBaUJuRDtLQUNGLEFBdERtQixDQXNEbkI7SUFFTSxNQUFNO1FBQ1gsT0FBTyxJQUFJLENBQUE7UUFDUCxRQUFRLENBQUMsWUFBWSxDQUFDLE1BQU07Ozs7Ozs2Q0FNUyxJQUFJLENBQUMseUJBQXlCOzZDQUM5QixJQUFJLENBQUMsdUJBQXVCOztjQUUzRCxJQUFJLENBQUMsU0FBUzs7O0tBR3ZCLENBQUM7SUFDSixDQUFDO0lBRU0seUJBQXlCO1FBQzlCLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxXQUFXLENBQUMsbUJBQW1CLEVBQUUsRUFFdkQsQ0FBQyxDQUFDLENBQUE7SUFDTCxDQUFDO0lBRU0sdUJBQXVCO1FBQzVCLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxXQUFXLENBQUMsaUJBQWlCLEVBQUUsRUFFckQsQ0FBQyxDQUFDLENBQUE7SUFDTCxDQUFDOztBQTFGTTtJQUROLFFBQVEsRUFBRTs7c0RBQ21DO0FBUm5DLG1CQUFtQjtJQUQvQixhQUFhLENBQUMsdUJBQXVCLENBQUM7O0dBQzFCLG1CQUFtQixDQW1HL0IifQ==
336
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBsLXN0YXR1c3BhZ2UtaGVhZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vdHNfd2ViL2VsZW1lbnRzL3VwbC1zdGF0dXNwYWdlLWhlYWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLGFBQWEsRUFBdUIsR0FBRyxFQUFFLFVBQVUsRUFBRSxTQUFTLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUMxSSxPQUFPLEtBQUssUUFBUSxNQUFNLDhCQUE4QixDQUFDO0FBQ3pELE9BQU8sS0FBSyxZQUFZLE1BQU0sNEJBQTRCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0lBUzlDLG1CQUFtQjs0QkFEL0IsYUFBYSxDQUFDLHVCQUF1QixDQUFDOzs7O3NCQUNFLFdBQVc7Ozs7Ozs7Ozs7Ozs7Ozs7bUNBQW5CLFNBQVEsV0FBVzs7OztxQ0FLakQsUUFBUSxDQUFDLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxDQUFDOzRDQUcxQixRQUFRLENBQUMsRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLENBQUM7K0NBRzNCLFFBQVEsQ0FBQyxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsQ0FBQzttQ0FHM0IsUUFBUSxDQUFDLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxDQUFDO21DQUcxQixRQUFRLENBQUMsRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLENBQUM7WUFYNUIsZ0xBQVMsU0FBUyw2QkFBVCxTQUFTLDZGQUE4QjtZQUdoRCxxTUFBUyxnQkFBZ0IsNkJBQWhCLGdCQUFnQiwyR0FBaUI7WUFHMUMsOE1BQVMsbUJBQW1CLDZCQUFuQixtQkFBbUIsaUhBQWlCO1lBRzdDLDBLQUFTLE9BQU8sNkJBQVAsT0FBTyx5RkFBYztZQUc5QiwwS0FBUyxPQUFPLDZCQUFQ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
@@ -1,5 +1,6 @@
1
- import * as plugins from '../plugins.js';
2
1
  import { DeesElement, type TemplateResult } from '@design.estate/dees-element';
2
+ import type { IIncidentDetails } from '../interfaces/index.js';
3
+ import './internal/uplinternal-miniheading.js';
3
4
  declare global {
4
5
  interface HTMLElementTagNameMap {
5
6
  'upl-statuspage-incidents': UplStatuspageIncidents;
@@ -7,12 +8,29 @@ declare global {
7
8
  }
8
9
  export declare class UplStatuspageIncidents extends DeesElement {
9
10
  static demo: () => TemplateResult<1>;
10
- currentIncidences: plugins.uplInterfaces.data.IIncident[];
11
- pastIncidences: plugins.uplInterfaces.data.IIncident[];
12
- whitelabel: boolean;
11
+ accessor currentIncidents: IIncidentDetails[];
12
+ accessor pastIncidents: IIncidentDetails[];
13
+ accessor whitelabel: boolean;
14
+ accessor loading: boolean;
15
+ accessor daysToShow: number;
16
+ accessor subscribedIncidentIds: string[];
17
+ private accessor expandedIncidents;
18
+ private accessor subscribedIncidents;
13
19
  constructor();
20
+ connectedCallback(): Promise<void>;
21
+ updated(changedProperties: Map<string, any>): void;
14
22
  static styles: import("@design.estate/dees-element").CSSResult[];
15
23
  render(): TemplateResult;
24
+ private renderIncident;
25
+ private renderUpdate;
26
+ private getStatusIcon;
27
+ private formatDate;
28
+ private formatDuration;
29
+ private toggleIncident;
30
+ private handleIncidentClick;
31
+ private handleShowMore;
32
+ private isSubscribedToIncident;
33
+ private handleIncidentSubscribe;
16
34
  dispatchReportNewIncident(): void;
17
35
  dispatchStatusSubscribe(): void;
18
36
  }
@@ -0,0 +1 @@
1
+ export declare const demoFunc: () => import("@design.estate/dees-element").TemplateResult<1>;