@uptime.link/statuspage 1.0.74 → 1.2.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 +5019 -519
  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 +679 -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 +846 -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 +373 -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 +937 -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 +549 -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 +408 -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 +397 -62
  40. package/dist_ts_web/elements/upl-statuspage-statusmonth.d.ts +17 -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 +662 -103
  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 +102 -0
  57. package/dist_ts_web/styles/shared.styles.js +494 -0
  58. package/dist_watch/bundle.js +52265 -32033
  59. package/dist_watch/bundle.js.map +4 -4
  60. package/dist_watch/index.html +1 -0
  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 +600 -18
  71. package/ts_web/elements/upl-statuspage-footer.demo.ts +744 -0
  72. package/ts_web/elements/upl-statuspage-footer.ts +662 -30
  73. package/ts_web/elements/upl-statuspage-header.demo.ts +241 -0
  74. package/ts_web/elements/upl-statuspage-header.ts +289 -52
  75. package/ts_web/elements/upl-statuspage-incidents.demo.ts +1216 -0
  76. package/ts_web/elements/upl-statuspage-incidents.ts +840 -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 +478 -0
  81. package/ts_web/elements/upl-statuspage-statusbar.demo.ts +393 -0
  82. package/ts_web/elements/upl-statuspage-statusbar.ts +332 -20
  83. package/ts_web/elements/upl-statuspage-statusdetails.demo.ts +754 -0
  84. package/ts_web/elements/upl-statuspage-statusdetails.ts +321 -37
  85. package/ts_web/elements/upl-statuspage-statusmonth.demo.ts +876 -0
  86. package/ts_web/elements/upl-statuspage-statusmonth.ts +584 -79
  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 +531 -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
@@ -0,0 +1,15 @@
1
+ import { DeesElement, type TemplateResult } from '@design.estate/dees-element';
2
+ declare global {
3
+ interface HTMLElementTagNameMap {
4
+ 'upl-statuspage-pagetitle': UplStatuspagePagetitle;
5
+ }
6
+ }
7
+ export declare class UplStatuspagePagetitle extends DeesElement {
8
+ static demo: () => TemplateResult<1>;
9
+ accessor pageTitle: string;
10
+ accessor pageSubtitle: string;
11
+ accessor centered: boolean;
12
+ constructor();
13
+ static styles: import("@design.estate/dees-element").CSSResult[];
14
+ render(): TemplateResult;
15
+ }
@@ -0,0 +1 @@
1
+ export declare const demoFunc: () => import("@design.estate/dees-element").TemplateResult<1>;
@@ -0,0 +1,25 @@
1
+ import { html } from '@design.estate/dees-element';
2
+ export const demoFunc = () => html `
3
+ <style>
4
+ .demo-container {
5
+ background: #fafafa;
6
+ padding: 40px 0;
7
+ min-height: 400px;
8
+ }
9
+ </style>
10
+ <div class="demo-container">
11
+ <upl-statuspage-pagetitle
12
+ .pageTitle=${'System Status'}
13
+ .pageSubtitle=${'Real-time operational status and incident reports for all services'}
14
+ ></upl-statuspage-pagetitle>
15
+
16
+ <br>
17
+
18
+ <upl-statuspage-pagetitle
19
+ .pageTitle=${'API Documentation'}
20
+ .pageSubtitle=${'Comprehensive guides and references for integrating with our platform'}
21
+ .centered=${true}
22
+ ></upl-statuspage-pagetitle>
23
+ </div>
24
+ `;
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBsLXN0YXR1c3BhZ2UtcGFnZXRpdGxlLmRlbW8uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90c193ZWIvZWxlbWVudHMvdXBsLXN0YXR1c3BhZ2UtcGFnZXRpdGxlLmRlbW8udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBRW5ELE1BQU0sQ0FBQyxNQUFNLFFBQVEsR0FBRyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUE7Ozs7Ozs7Ozs7bUJBVWYsZUFBZTtzQkFDWixvRUFBb0U7Ozs7OzttQkFNdkUsbUJBQW1CO3NCQUNoQix1RUFBdUU7a0JBQzNFLElBQUk7OztDQUdyQixDQUFDIn0=
@@ -0,0 +1,148 @@
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;
27
+ };
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;
34
+ };
35
+ import { DeesElement, property, html, customElement, css, cssManager, unsafeCSS } from '@design.estate/dees-element';
36
+ import * as domtools from '@design.estate/dees-domtools';
37
+ import * as sharedStyles from '../styles/shared.styles.js';
38
+ import { demoFunc } from './upl-statuspage-pagetitle.demo.js';
39
+ let UplStatuspagePagetitle = (() => {
40
+ let _classDecorators = [customElement('upl-statuspage-pagetitle')];
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 _pageSubtitle_decorators;
49
+ let _pageSubtitle_initializers = [];
50
+ let _pageSubtitle_extraInitializers = [];
51
+ let _centered_decorators;
52
+ let _centered_initializers = [];
53
+ let _centered_extraInitializers = [];
54
+ var UplStatuspagePagetitle = class extends _classSuper {
55
+ static { _classThis = this; }
56
+ static {
57
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
58
+ _pageTitle_decorators = [property({ type: String })];
59
+ _pageSubtitle_decorators = [property({ type: String })];
60
+ _centered_decorators = [property({ type: Boolean })];
61
+ __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);
62
+ __esDecorate(this, null, _pageSubtitle_decorators, { kind: "accessor", name: "pageSubtitle", static: false, private: false, access: { has: obj => "pageSubtitle" in obj, get: obj => obj.pageSubtitle, set: (obj, value) => { obj.pageSubtitle = value; } }, metadata: _metadata }, _pageSubtitle_initializers, _pageSubtitle_extraInitializers);
63
+ __esDecorate(this, null, _centered_decorators, { kind: "accessor", name: "centered", static: false, private: false, access: { has: obj => "centered" in obj, get: obj => obj.centered, set: (obj, value) => { obj.centered = value; } }, metadata: _metadata }, _centered_initializers, _centered_extraInitializers);
64
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
65
+ UplStatuspagePagetitle = _classThis = _classDescriptor.value;
66
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
67
+ }
68
+ static demo = demoFunc;
69
+ #pageTitle_accessor_storage = __runInitializers(this, _pageTitle_initializers, 'System Status');
70
+ get pageTitle() { return this.#pageTitle_accessor_storage; }
71
+ set pageTitle(value) { this.#pageTitle_accessor_storage = value; }
72
+ #pageSubtitle_accessor_storage = (__runInitializers(this, _pageTitle_extraInitializers), __runInitializers(this, _pageSubtitle_initializers, ''));
73
+ get pageSubtitle() { return this.#pageSubtitle_accessor_storage; }
74
+ set pageSubtitle(value) { this.#pageSubtitle_accessor_storage = value; }
75
+ #centered_accessor_storage = (__runInitializers(this, _pageSubtitle_extraInitializers), __runInitializers(this, _centered_initializers, false));
76
+ get centered() { return this.#centered_accessor_storage; }
77
+ set centered(value) { this.#centered_accessor_storage = value; }
78
+ constructor() {
79
+ super();
80
+ __runInitializers(this, _centered_extraInitializers);
81
+ }
82
+ static styles = [
83
+ domtools.elementBasic.staticStyles,
84
+ css `
85
+ :host {
86
+ display: block;
87
+ font-family: ${unsafeCSS(sharedStyles.fonts.base)};
88
+ }
89
+
90
+ .title-container {
91
+ max-width: 1200px;
92
+ margin: 0 auto;
93
+ padding: ${unsafeCSS(sharedStyles.spacing.lg)};
94
+ }
95
+
96
+ .title-container.centered {
97
+ text-align: center;
98
+ }
99
+
100
+ h1 {
101
+ font-size: 48px;
102
+ font-weight: 700;
103
+ letter-spacing: -0.03em;
104
+ line-height: 1.1;
105
+ color: ${sharedStyles.colors.text.primary};
106
+ margin: 0 0 ${unsafeCSS(sharedStyles.spacing.md)} 0;
107
+ }
108
+
109
+ p {
110
+ font-size: 18px;
111
+ color: ${sharedStyles.colors.text.secondary};
112
+ margin: 0;
113
+ line-height: 1.6;
114
+ }
115
+
116
+ @media (max-width: 640px) {
117
+ .title-container {
118
+ padding: ${unsafeCSS(sharedStyles.spacing.lg)} ${unsafeCSS(sharedStyles.spacing.md)};
119
+ }
120
+
121
+ h1 {
122
+ font-size: 32px;
123
+ }
124
+
125
+ p {
126
+ font-size: 16px;
127
+ }
128
+ }
129
+ `
130
+ ];
131
+ render() {
132
+ return html `
133
+ <div class="title-container ${this.centered ? 'centered' : ''}">
134
+ <h1>${this.pageTitle}</h1>
135
+ ${this.pageSubtitle ? html `
136
+ <p>${this.pageSubtitle}</p>
137
+ ` : ''}
138
+ </div>
139
+ `;
140
+ }
141
+ static {
142
+ __runInitializers(_classThis, _classExtraInitializers);
143
+ }
144
+ };
145
+ return UplStatuspagePagetitle = _classThis;
146
+ })();
147
+ export { UplStatuspagePagetitle };
148
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBsLXN0YXR1c3BhZ2UtcGFnZXRpdGxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vdHNfd2ViL2VsZW1lbnRzL3VwbC1zdGF0dXNwYWdlLXBhZ2V0aXRsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLGFBQWEsRUFBdUIsR0FBRyxFQUFFLFVBQVUsRUFBRSxTQUFTLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUMxSSxPQUFPLEtBQUssUUFBUSxNQUFNLDhCQUE4QixDQUFDO0FBQ3pELE9BQU8sS0FBSyxZQUFZLE1BQU0sNEJBQTRCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0lBU2pELHNCQUFzQjs0QkFEbEMsYUFBYSxDQUFDLDBCQUEwQixDQUFDOzs7O3NCQUNFLFdBQVc7Ozs7Ozs7Ozs7c0NBQW5CLFNBQVEsV0FBVzs7OztxQ0FHcEQsUUFBUSxDQUFDLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxDQUFDO3dDQUcxQixRQUFRLENBQUMsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLENBQUM7b0NBRzFCLFFBQVEsQ0FBQyxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsQ0FBQztZQUw1QixnTEFBUyxTQUFTLDZCQUFULFNBQVMsNkZBQTJCO1lBRzdDLHlMQUFTLFlBQVksNkJBQVosWUFBWSxtR0FBYztZQUduQyw2S0FBUyxRQUFRLDZCQUFSLFFBQVEsMkZBQWtCO1lBVnJDLDZLQTRFQzs7OztRQTNFUSxNQUFNLENBQUMsSUFBSSxHQUFHLFFBQVEsQ0FBQztRQUc5QiwrRUFBNkIsZUFBZSxFQUFDO1FBQTdDLElBQVMsU0FBUywrQ0FBMkI7UUFBN0MsSUFBUyxTQUFTLHFEQUEyQjtRQUc3Qyw2SUFBZ0MsRUFBRSxHQUFDO1FBQW5DLElBQVMsWUFBWSxrREFBYztRQUFuQyxJQUFTLFlBQVksd0RBQWM7UUFHbkMsd0lBQTZCLEtBQUssR0FBQztRQUFuQyxJQUFTLFFBQVEsOENBQWtCO1FBQW5DLElBQVMsUUFBUSxvREFBa0I7UUFFbkM7WUFDRSxLQUFLLEVBQUUsQ0FBQzs7U0FDVDtRQUVNLE1BQU0sQ0FBQyxNQUFNLEdBQUc7WUFDckIsUUFBUSxDQUFDLFlBQVksQ0FBQyxZQUFZO1lBQ2xDLEdBQUcsQ0FBQTs7O3VCQUdnQixTQUFTLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUM7Ozs7OzttQkFNdEMsU0FBUyxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDOzs7Ozs7Ozs7Ozs7aUJBWXBDLFlBQVksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU87c0JBQzNCLFNBQVMsQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQzs7Ozs7aUJBS3ZDLFlBQVksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVM7Ozs7Ozs7cUJBTzlCLFNBQVMsQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxJQUFJLFNBQVMsQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQzs7Ozs7Ozs7Ozs7S0FXeEY7U0FDRixDQUFBO1FBRU0sTUFBTTtZQUNYLE9BQU8sSUFBSSxDQUFBO29DQUNxQixJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLEVBQUU7Y0FDckQsSUFBSSxDQUFDLFNBQVM7VUFDbEIsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFBO2VBQ25CLElBQUksQ0FBQyxZQUFZO1NBQ3ZCLENBQUMsQ0FBQyxDQUFDLEVBQUU7O0tBRVQsQ0FBQztRQUNKLENBQUM7O1lBM0VVLHVEQUFzQjs7Ozs7U0FBdEIsc0JBQXNCIn0=
@@ -0,0 +1,23 @@
1
+ import { DeesElement, type TemplateResult } from '@design.estate/dees-element';
2
+ import './internal/uplinternal-miniheading.js';
3
+ declare global {
4
+ interface HTMLElementTagNameMap {
5
+ 'upl-statuspage-statsgrid': UplStatuspageStatsgrid;
6
+ }
7
+ }
8
+ export declare class UplStatuspageStatsgrid extends DeesElement {
9
+ static demo: () => TemplateResult<1>;
10
+ accessor uptime: number;
11
+ accessor avgResponseTime: number;
12
+ accessor totalIncidents: number;
13
+ accessor affectedServices: number;
14
+ accessor totalServices: number;
15
+ accessor currentStatus: string;
16
+ accessor loading: boolean;
17
+ accessor timePeriod: string;
18
+ constructor();
19
+ static styles: import("@design.estate/dees-element").CSSResult[];
20
+ render(): TemplateResult;
21
+ private formatStatus;
22
+ private renderResponseChange;
23
+ }
@@ -0,0 +1 @@
1
+ export declare const demoFunc: () => import("@design.estate/dees-element").TemplateResult<1>;
@@ -0,0 +1,295 @@
1
+ import { html } from '@design.estate/dees-element';
2
+ export const demoFunc = () => html `
3
+ <style>
4
+ .demo-container {
5
+ display: flex;
6
+ flex-direction: column;
7
+ gap: 20px;
8
+ }
9
+ .demo-section {
10
+ border: 1px solid #ddd;
11
+ border-radius: 8px;
12
+ padding: 20px;
13
+ background: #f5f5f5;
14
+ }
15
+ .demo-title {
16
+ font-size: 14px;
17
+ font-weight: 600;
18
+ margin-bottom: 16px;
19
+ color: #333;
20
+ }
21
+ .demo-controls {
22
+ display: flex;
23
+ gap: 10px;
24
+ margin-top: 16px;
25
+ flex-wrap: wrap;
26
+ }
27
+ .demo-button {
28
+ padding: 6px 12px;
29
+ border: 1px solid #ddd;
30
+ background: white;
31
+ border-radius: 4px;
32
+ cursor: pointer;
33
+ font-size: 13px;
34
+ }
35
+ .demo-button:hover {
36
+ background: #f0f0f0;
37
+ }
38
+ .demo-button.active {
39
+ background: #2196F3;
40
+ color: white;
41
+ border-color: #2196F3;
42
+ }
43
+ </style>
44
+
45
+ <div class="demo-container">
46
+ <!-- Normal Operation -->
47
+ <div class="demo-section">
48
+ <div class="demo-title">Normal Operation</div>
49
+ <dees-demowrapper
50
+ .runAfterRender=${async (wrapperElement) => {
51
+ const statsGrid = wrapperElement.querySelector('upl-statuspage-statsgrid');
52
+ // Set initial values
53
+ statsGrid.currentStatus = 'operational';
54
+ statsGrid.uptime = 99.95;
55
+ statsGrid.avgResponseTime = 125;
56
+ statsGrid.totalIncidents = 0;
57
+ statsGrid.affectedServices = 0;
58
+ statsGrid.totalServices = 12;
59
+ statsGrid.timePeriod = '90 days';
60
+ }}
61
+ >
62
+ <upl-statuspage-statsgrid></upl-statuspage-statsgrid>
63
+ </dees-demowrapper>
64
+ </div>
65
+
66
+ <!-- Degraded Performance -->
67
+ <div class="demo-section">
68
+ <div class="demo-title">Degraded Performance</div>
69
+ <dees-demowrapper
70
+ .runAfterRender=${async (wrapperElement) => {
71
+ const statsGrid = wrapperElement.querySelector('upl-statuspage-statsgrid');
72
+ statsGrid.currentStatus = 'degraded';
73
+ statsGrid.uptime = 98.50;
74
+ statsGrid.avgResponseTime = 450;
75
+ statsGrid.totalIncidents = 3;
76
+ statsGrid.affectedServices = 2;
77
+ statsGrid.totalServices = 12;
78
+ statsGrid.timePeriod = '30 days';
79
+ }}
80
+ >
81
+ <upl-statuspage-statsgrid></upl-statuspage-statsgrid>
82
+ </dees-demowrapper>
83
+ </div>
84
+
85
+ <!-- Major Outage -->
86
+ <div class="demo-section">
87
+ <div class="demo-title">Major Outage</div>
88
+ <dees-demowrapper
89
+ .runAfterRender=${async (wrapperElement) => {
90
+ const statsGrid = wrapperElement.querySelector('upl-statuspage-statsgrid');
91
+ statsGrid.currentStatus = 'major_outage';
92
+ statsGrid.uptime = 95.20;
93
+ statsGrid.avgResponseTime = 1250;
94
+ statsGrid.totalIncidents = 8;
95
+ statsGrid.affectedServices = 7;
96
+ statsGrid.totalServices = 12;
97
+ statsGrid.timePeriod = '7 days';
98
+ }}
99
+ >
100
+ <upl-statuspage-statsgrid></upl-statuspage-statsgrid>
101
+ </dees-demowrapper>
102
+ </div>
103
+
104
+ <!-- Interactive Demo -->
105
+ <div class="demo-section">
106
+ <div class="demo-title">Interactive Demo</div>
107
+ <dees-demowrapper
108
+ .runAfterRender=${async (wrapperElement) => {
109
+ const statsGrid = wrapperElement.querySelector('upl-statuspage-statsgrid');
110
+ // Initial state
111
+ statsGrid.currentStatus = 'operational';
112
+ statsGrid.uptime = 99.99;
113
+ statsGrid.avgResponseTime = 85;
114
+ statsGrid.totalIncidents = 0;
115
+ statsGrid.affectedServices = 0;
116
+ statsGrid.totalServices = 15;
117
+ statsGrid.timePeriod = '90 days';
118
+ // Create controls
119
+ const controls = document.createElement('div');
120
+ controls.className = 'demo-controls';
121
+ // Status buttons
122
+ const statuses = ['operational', 'degraded', 'partial_outage', 'major_outage', 'maintenance'];
123
+ statuses.forEach((status, index) => {
124
+ const button = document.createElement('button');
125
+ button.className = 'demo-button' + (index === 0 ? ' active' : '');
126
+ button.textContent = status.replace(/_/g, ' ').replace(/\b\w/g, l => l.toUpperCase());
127
+ button.onclick = () => {
128
+ controls.querySelectorAll('.demo-button').forEach(btn => btn.classList.remove('active'));
129
+ button.classList.add('active');
130
+ statsGrid.currentStatus = status;
131
+ // Adjust other values based on status
132
+ switch (status) {
133
+ case 'operational':
134
+ statsGrid.uptime = 99.99;
135
+ statsGrid.avgResponseTime = 85;
136
+ statsGrid.totalIncidents = 0;
137
+ statsGrid.affectedServices = 0;
138
+ break;
139
+ case 'degraded':
140
+ statsGrid.uptime = 98.50;
141
+ statsGrid.avgResponseTime = 350;
142
+ statsGrid.totalIncidents = 2;
143
+ statsGrid.affectedServices = 1;
144
+ break;
145
+ case 'partial_outage':
146
+ statsGrid.uptime = 97.00;
147
+ statsGrid.avgResponseTime = 750;
148
+ statsGrid.totalIncidents = 5;
149
+ statsGrid.affectedServices = 3;
150
+ break;
151
+ case 'major_outage':
152
+ statsGrid.uptime = 94.50;
153
+ statsGrid.avgResponseTime = 1500;
154
+ statsGrid.totalIncidents = 10;
155
+ statsGrid.affectedServices = 8;
156
+ break;
157
+ case 'maintenance':
158
+ statsGrid.uptime = 99.00;
159
+ statsGrid.avgResponseTime = 150;
160
+ statsGrid.totalIncidents = 1;
161
+ statsGrid.affectedServices = 2;
162
+ break;
163
+ }
164
+ };
165
+ controls.appendChild(button);
166
+ });
167
+ wrapperElement.appendChild(controls);
168
+ // Add time period selector
169
+ const timePeriodControls = document.createElement('div');
170
+ timePeriodControls.className = 'demo-controls';
171
+ timePeriodControls.style.marginTop = '10px';
172
+ const periods = ['24 hours', '7 days', '30 days', '90 days'];
173
+ periods.forEach((period, index) => {
174
+ const button = document.createElement('button');
175
+ button.className = 'demo-button' + (index === 3 ? ' active' : '');
176
+ button.textContent = period;
177
+ button.onclick = () => {
178
+ timePeriodControls.querySelectorAll('.demo-button').forEach(btn => btn.classList.remove('active'));
179
+ button.classList.add('active');
180
+ statsGrid.timePeriod = period;
181
+ };
182
+ timePeriodControls.appendChild(button);
183
+ });
184
+ wrapperElement.appendChild(timePeriodControls);
185
+ }}
186
+ >
187
+ <upl-statuspage-statsgrid></upl-statuspage-statsgrid>
188
+ </dees-demowrapper>
189
+ </div>
190
+
191
+ <!-- Loading State -->
192
+ <div class="demo-section">
193
+ <div class="demo-title">Loading State</div>
194
+ <dees-demowrapper
195
+ .runAfterRender=${async (wrapperElement) => {
196
+ const statsGrid = wrapperElement.querySelector('upl-statuspage-statsgrid');
197
+ statsGrid.loading = true;
198
+ // Create toggle button
199
+ const controls = document.createElement('div');
200
+ controls.className = 'demo-controls';
201
+ const toggleButton = document.createElement('button');
202
+ toggleButton.className = 'demo-button';
203
+ toggleButton.textContent = 'Toggle Loading';
204
+ toggleButton.onclick = () => {
205
+ statsGrid.loading = !statsGrid.loading;
206
+ if (!statsGrid.loading) {
207
+ statsGrid.currentStatus = 'operational';
208
+ statsGrid.uptime = 99.95;
209
+ statsGrid.avgResponseTime = 125;
210
+ statsGrid.totalIncidents = 0;
211
+ statsGrid.affectedServices = 0;
212
+ statsGrid.totalServices = 12;
213
+ }
214
+ };
215
+ controls.appendChild(toggleButton);
216
+ wrapperElement.appendChild(controls);
217
+ }}
218
+ >
219
+ <upl-statuspage-statsgrid></upl-statuspage-statsgrid>
220
+ </dees-demowrapper>
221
+ </div>
222
+
223
+ <!-- Real-time Updates -->
224
+ <div class="demo-section">
225
+ <div class="demo-title">Real-time Updates</div>
226
+ <dees-demowrapper
227
+ .runAfterRender=${async (wrapperElement) => {
228
+ const statsGrid = wrapperElement.querySelector('upl-statuspage-statsgrid');
229
+ // Initial values
230
+ statsGrid.currentStatus = 'operational';
231
+ statsGrid.uptime = 99.95;
232
+ statsGrid.avgResponseTime = 100;
233
+ statsGrid.totalIncidents = 0;
234
+ statsGrid.affectedServices = 0;
235
+ statsGrid.totalServices = 10;
236
+ statsGrid.timePeriod = '24 hours';
237
+ // Simulate real-time updates
238
+ let interval = setInterval(() => {
239
+ // Slight variations in response time
240
+ statsGrid.avgResponseTime = Math.floor(80 + Math.random() * 40);
241
+ // Occasionally change status
242
+ if (Math.random() < 0.1) {
243
+ const statuses = ['operational', 'degraded'];
244
+ statsGrid.currentStatus = statuses[Math.floor(Math.random() * statuses.length)];
245
+ if (statsGrid.currentStatus === 'degraded') {
246
+ statsGrid.avgResponseTime = Math.floor(300 + Math.random() * 200);
247
+ statsGrid.totalIncidents = Math.min(statsGrid.totalIncidents + 1, 5);
248
+ statsGrid.affectedServices = Math.min(Math.floor(Math.random() * 3) + 1, statsGrid.totalServices);
249
+ statsGrid.uptime = Math.max(99.0, statsGrid.uptime - 0.05);
250
+ }
251
+ else {
252
+ statsGrid.affectedServices = 0;
253
+ }
254
+ }
255
+ }, 2000);
256
+ // Add control button
257
+ const controls = document.createElement('div');
258
+ controls.className = 'demo-controls';
259
+ const toggleButton = document.createElement('button');
260
+ toggleButton.className = 'demo-button active';
261
+ toggleButton.textContent = 'Stop Updates';
262
+ toggleButton.onclick = () => {
263
+ if (interval) {
264
+ clearInterval(interval);
265
+ interval = null;
266
+ toggleButton.textContent = 'Start Updates';
267
+ toggleButton.classList.remove('active');
268
+ }
269
+ else {
270
+ interval = setInterval(() => {
271
+ statsGrid.avgResponseTime = Math.floor(80 + Math.random() * 40);
272
+ if (Math.random() < 0.1) {
273
+ const statuses = ['operational', 'degraded'];
274
+ statsGrid.currentStatus = statuses[Math.floor(Math.random() * statuses.length)];
275
+ }
276
+ }, 2000);
277
+ toggleButton.textContent = 'Stop Updates';
278
+ toggleButton.classList.add('active');
279
+ }
280
+ };
281
+ controls.appendChild(toggleButton);
282
+ wrapperElement.appendChild(controls);
283
+ // Cleanup on unmount
284
+ wrapperElement.addEventListener('remove', () => {
285
+ if (interval)
286
+ clearInterval(interval);
287
+ });
288
+ }}
289
+ >
290
+ <upl-statuspage-statsgrid></upl-statuspage-statsgrid>
291
+ </dees-demowrapper>
292
+ </div>
293
+ </div>
294
+ `;
295
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBsLXN0YXR1c3BhZ2Utc3RhdHNncmlkLmRlbW8uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90c193ZWIvZWxlbWVudHMvdXBsLXN0YXR1c3BhZ2Utc3RhdHNncmlkLmRlbW8udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBRW5ELE1BQU0sQ0FBQyxNQUFNLFFBQVEsR0FBRyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OzswQkFnRFIsS0FBSyxFQUFFLGNBQW1CLEVBQUUsRUFBRTtJQUM5QyxNQUFNLFNBQVMsR0FBRyxjQUFjLENBQUMsYUFBYSxDQUFDLDBCQUEwQixDQUFRLENBQUM7SUFFbEYscUJBQXFCO0lBQ3JCLFNBQVMsQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFDO0lBQ3hDLFNBQVMsQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDO0lBQ3pCLFNBQVMsQ0FBQyxlQUFlLEdBQUcsR0FBRyxDQUFDO0lBQ2hDLFNBQVMsQ0FBQyxjQUFjLEdBQUcsQ0FBQyxDQUFDO0lBQzdCLFNBQVMsQ0FBQyxnQkFBZ0IsR0FBRyxDQUFDLENBQUM7SUFDL0IsU0FBUyxDQUFDLGFBQWEsR0FBRyxFQUFFLENBQUM7SUFDN0IsU0FBUyxDQUFDLFVBQVUsR0FBRyxTQUFTLENBQUM7QUFDbkMsQ0FBQzs7Ozs7Ozs7OzswQkFVaUIsS0FBSyxFQUFFLGNBQW1CLEVBQUUsRUFBRTtJQUM5QyxNQUFNLFNBQVMsR0FBRyxjQUFjLENBQUMsYUFBYSxDQUFDLDBCQUEwQixDQUFRLENBQUM7SUFFbEYsU0FBUyxDQUFDLGFBQWEsR0FBRyxVQUFVLENBQUM7SUFDckMsU0FBUyxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7SUFDekIsU0FBUyxDQUFDLGVBQWUsR0FBRyxHQUFHLENBQUM7SUFDaEMsU0FBUyxDQUFD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