511 lines
33 KiB
JavaScript
511 lines
33 KiB
JavaScript
var __esDecorate = (this && this.__esDecorate) || function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
|
|
function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
|
|
var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
|
|
var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
|
|
var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
|
|
var _, done = false;
|
|
for (var i = decorators.length - 1; i >= 0; i--) {
|
|
var context = {};
|
|
for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
|
|
for (var p in contextIn.access) context.access[p] = contextIn.access[p];
|
|
context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
|
|
var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
|
|
if (kind === "accessor") {
|
|
if (result === void 0) continue;
|
|
if (result === null || typeof result !== "object") throw new TypeError("Object expected");
|
|
if (_ = accept(result.get)) descriptor.get = _;
|
|
if (_ = accept(result.set)) descriptor.set = _;
|
|
if (_ = accept(result.init)) initializers.unshift(_);
|
|
}
|
|
else if (_ = accept(result)) {
|
|
if (kind === "field") initializers.unshift(_);
|
|
else descriptor[key] = _;
|
|
}
|
|
}
|
|
if (target) Object.defineProperty(target, contextIn.name, descriptor);
|
|
done = true;
|
|
};
|
|
var __runInitializers = (this && this.__runInitializers) || function (thisArg, initializers, value) {
|
|
var useValue = arguments.length > 2;
|
|
for (var i = 0; i < initializers.length; i++) {
|
|
value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
|
|
}
|
|
return useValue ? value : void 0;
|
|
};
|
|
import * as plugins from '../../plugins.js';
|
|
import { DeesElement, property, html, customElement, css, cssManager, unsafeCSS, state, } from '@design.estate/dees-element';
|
|
import * as sharedStyles from '../../styles/shared.styles.js';
|
|
import { demoFunc } from './upladmin-incident-update.demo.js';
|
|
let UpladminIncidentUpdate = (() => {
|
|
let _classDecorators = [customElement('upladmin-incident-update')];
|
|
let _classDescriptor;
|
|
let _classExtraInitializers = [];
|
|
let _classThis;
|
|
let _classSuper = DeesElement;
|
|
let _incident_decorators;
|
|
let _incident_initializers = [];
|
|
let _incident_extraInitializers = [];
|
|
let _loading_decorators;
|
|
let _loading_initializers = [];
|
|
let _loading_extraInitializers = [];
|
|
let _formData_decorators;
|
|
let _formData_initializers = [];
|
|
let _formData_extraInitializers = [];
|
|
let _errors_decorators;
|
|
let _errors_initializers = [];
|
|
let _errors_extraInitializers = [];
|
|
var UpladminIncidentUpdate = class extends _classSuper {
|
|
static { _classThis = this; }
|
|
static {
|
|
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
_incident_decorators = [property({ type: Object })];
|
|
_loading_decorators = [property({ type: Boolean })];
|
|
_formData_decorators = [state()];
|
|
_errors_decorators = [state()];
|
|
__esDecorate(this, null, _incident_decorators, { kind: "accessor", name: "incident", static: false, private: false, access: { has: obj => "incident" in obj, get: obj => obj.incident, set: (obj, value) => { obj.incident = value; } }, metadata: _metadata }, _incident_initializers, _incident_extraInitializers);
|
|
__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);
|
|
__esDecorate(this, null, _formData_decorators, { kind: "accessor", name: "formData", static: false, private: false, access: { has: obj => "formData" in obj, get: obj => obj.formData, set: (obj, value) => { obj.formData = value; } }, metadata: _metadata }, _formData_initializers, _formData_extraInitializers);
|
|
__esDecorate(this, null, _errors_decorators, { kind: "accessor", name: "errors", static: false, private: false, access: { has: obj => "errors" in obj, get: obj => obj.errors, set: (obj, value) => { obj.errors = value; } }, metadata: _metadata }, _errors_initializers, _errors_extraInitializers);
|
|
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
|
|
UpladminIncidentUpdate = _classThis = _classDescriptor.value;
|
|
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
}
|
|
static demo = demoFunc;
|
|
#incident_accessor_storage = __runInitializers(this, _incident_initializers, null);
|
|
get incident() { return this.#incident_accessor_storage; }
|
|
set incident(value) { this.#incident_accessor_storage = value; }
|
|
#loading_accessor_storage = (__runInitializers(this, _incident_extraInitializers), __runInitializers(this, _loading_initializers, false));
|
|
get loading() { return this.#loading_accessor_storage; }
|
|
set loading(value) { this.#loading_accessor_storage = value; }
|
|
#formData_accessor_storage = (__runInitializers(this, _loading_extraInitializers), __runInitializers(this, _formData_initializers, {
|
|
status: 'investigating',
|
|
message: '',
|
|
author: '',
|
|
}));
|
|
get formData() { return this.#formData_accessor_storage; }
|
|
set formData(value) { this.#formData_accessor_storage = value; }
|
|
#errors_accessor_storage = (__runInitializers(this, _formData_extraInitializers), __runInitializers(this, _errors_initializers, {}));
|
|
get errors() { return this.#errors_accessor_storage; }
|
|
set errors(value) { this.#errors_accessor_storage = value; }
|
|
statusIcons = (__runInitializers(this, _errors_extraInitializers), {
|
|
investigating: 'lucide:Search',
|
|
identified: 'lucide:Target',
|
|
monitoring: 'lucide:Eye',
|
|
resolved: 'lucide:CheckCircle',
|
|
postmortem: 'lucide:FileText',
|
|
});
|
|
static styles = [
|
|
plugins.domtools.elementBasic.staticStyles,
|
|
sharedStyles.commonStyles,
|
|
css `
|
|
:host {
|
|
display: block;
|
|
font-family: ${unsafeCSS(sharedStyles.fonts.base)};
|
|
}
|
|
|
|
.update-container {
|
|
background: ${sharedStyles.colors.background.secondary};
|
|
border: 1px solid ${sharedStyles.colors.border.default};
|
|
border-radius: ${unsafeCSS(sharedStyles.borderRadius.lg)};
|
|
overflow: hidden;
|
|
}
|
|
|
|
.update-header {
|
|
padding: ${unsafeCSS(sharedStyles.spacing.lg)};
|
|
border-bottom: 1px solid ${sharedStyles.colors.border.default};
|
|
background: ${sharedStyles.colors.background.muted};
|
|
}
|
|
|
|
.update-title-row {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: ${unsafeCSS(sharedStyles.spacing.md)};
|
|
margin-bottom: ${unsafeCSS(sharedStyles.spacing.sm)};
|
|
}
|
|
|
|
.update-title-row dees-icon {
|
|
--icon-color: ${cssManager.bdTheme('#3b82f6', '#60a5fa')};
|
|
}
|
|
|
|
.update-title {
|
|
font-size: 18px;
|
|
font-weight: 600;
|
|
color: ${sharedStyles.colors.text.primary};
|
|
margin: 0;
|
|
}
|
|
|
|
.incident-info {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: ${unsafeCSS(sharedStyles.spacing.sm)};
|
|
padding-left: 36px;
|
|
}
|
|
|
|
.incident-name {
|
|
font-size: 14px;
|
|
color: ${sharedStyles.colors.text.secondary};
|
|
}
|
|
|
|
.severity-badge {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
gap: 6px;
|
|
padding: 4px 10px;
|
|
font-size: 11px;
|
|
font-weight: 500;
|
|
border-radius: 9999px;
|
|
text-transform: uppercase;
|
|
}
|
|
|
|
.severity-badge dees-icon {
|
|
font-size: 12px;
|
|
}
|
|
|
|
.severity-badge.critical {
|
|
background: ${cssManager.bdTheme('rgba(239, 68, 68, 0.1)', 'rgba(239, 68, 68, 0.2)')};
|
|
color: ${sharedStyles.colors.status.majorOutage};
|
|
--icon-color: ${sharedStyles.colors.status.majorOutage};
|
|
}
|
|
|
|
.severity-badge.major {
|
|
background: ${cssManager.bdTheme('rgba(249, 115, 22, 0.1)', 'rgba(249, 115, 22, 0.2)')};
|
|
color: ${sharedStyles.colors.status.partialOutage};
|
|
--icon-color: ${sharedStyles.colors.status.partialOutage};
|
|
}
|
|
|
|
.severity-badge.minor {
|
|
background: ${cssManager.bdTheme('rgba(234, 179, 8, 0.1)', 'rgba(234, 179, 8, 0.2)')};
|
|
color: ${sharedStyles.colors.status.degraded};
|
|
--icon-color: ${sharedStyles.colors.status.degraded};
|
|
}
|
|
|
|
.severity-badge.maintenance {
|
|
background: ${cssManager.bdTheme('rgba(59, 130, 246, 0.1)', 'rgba(59, 130, 246, 0.2)')};
|
|
color: ${sharedStyles.colors.status.maintenance};
|
|
--icon-color: ${sharedStyles.colors.status.maintenance};
|
|
}
|
|
|
|
.update-body {
|
|
display: grid;
|
|
gap: ${unsafeCSS(sharedStyles.spacing.lg)};
|
|
padding: ${unsafeCSS(sharedStyles.spacing.lg)};
|
|
}
|
|
|
|
dees-form {
|
|
display: contents;
|
|
}
|
|
|
|
.status-grid {
|
|
display: grid;
|
|
grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
|
|
gap: ${unsafeCSS(sharedStyles.spacing.sm)};
|
|
}
|
|
|
|
.status-option {
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
gap: 10px;
|
|
padding: 18px 14px;
|
|
background: ${sharedStyles.colors.background.primary};
|
|
border: 2px solid ${sharedStyles.colors.border.default};
|
|
border-radius: ${unsafeCSS(sharedStyles.borderRadius.base)};
|
|
cursor: pointer;
|
|
transition: all ${unsafeCSS(sharedStyles.durations.fast)} ${unsafeCSS(sharedStyles.easings.default)};
|
|
text-align: center;
|
|
}
|
|
|
|
.status-option:hover {
|
|
border-color: ${sharedStyles.colors.border.strong};
|
|
background: ${sharedStyles.colors.background.muted};
|
|
}
|
|
|
|
.status-option.selected {
|
|
border-color: ${sharedStyles.colors.accent.primary};
|
|
background: ${cssManager.bdTheme('rgba(59, 130, 246, 0.05)', 'rgba(96, 165, 250, 0.1)')};
|
|
}
|
|
|
|
.status-option input {
|
|
display: none;
|
|
}
|
|
|
|
.status-option.investigating dees-icon { --icon-color: ${sharedStyles.colors.status.partialOutage}; }
|
|
.status-option.identified dees-icon { --icon-color: ${sharedStyles.colors.status.degraded}; }
|
|
.status-option.monitoring dees-icon { --icon-color: ${sharedStyles.colors.status.maintenance}; }
|
|
.status-option.resolved dees-icon { --icon-color: ${sharedStyles.colors.status.operational}; }
|
|
.status-option.postmortem dees-icon { --icon-color: #a855f7; }
|
|
|
|
.status-label {
|
|
font-size: 13px;
|
|
font-weight: 600;
|
|
color: ${sharedStyles.colors.text.primary};
|
|
}
|
|
|
|
.status-desc {
|
|
font-size: 11px;
|
|
color: ${sharedStyles.colors.text.muted};
|
|
line-height: 1.3;
|
|
}
|
|
|
|
.field-label {
|
|
display: block;
|
|
font-size: 13px;
|
|
font-weight: 500;
|
|
color: ${sharedStyles.colors.text.primary};
|
|
margin-bottom: ${unsafeCSS(sharedStyles.spacing.xs)};
|
|
}
|
|
|
|
.field-label.required::after {
|
|
content: ' *';
|
|
color: ${sharedStyles.colors.accent.danger};
|
|
}
|
|
|
|
.template-section {
|
|
margin-bottom: ${unsafeCSS(sharedStyles.spacing.sm)};
|
|
}
|
|
|
|
.template-label {
|
|
font-size: 12px;
|
|
color: ${sharedStyles.colors.text.muted};
|
|
margin-bottom: 8px;
|
|
}
|
|
|
|
.template-buttons {
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
gap: 8px;
|
|
}
|
|
|
|
.template-btn {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
gap: 6px;
|
|
padding: 8px 14px;
|
|
font-size: 12px;
|
|
font-weight: 500;
|
|
font-family: ${unsafeCSS(sharedStyles.fonts.base)};
|
|
color: ${sharedStyles.colors.text.secondary};
|
|
background: ${sharedStyles.colors.background.primary};
|
|
border: 1px solid ${sharedStyles.colors.border.default};
|
|
border-radius: ${unsafeCSS(sharedStyles.borderRadius.base)};
|
|
cursor: pointer;
|
|
transition: all ${unsafeCSS(sharedStyles.durations.fast)} ${unsafeCSS(sharedStyles.easings.default)};
|
|
}
|
|
|
|
.template-btn:hover {
|
|
background: ${sharedStyles.colors.background.muted};
|
|
border-color: ${sharedStyles.colors.border.strong};
|
|
color: ${sharedStyles.colors.text.primary};
|
|
}
|
|
|
|
.template-btn dees-icon {
|
|
--icon-color: currentColor;
|
|
opacity: 0.6;
|
|
}
|
|
|
|
.update-actions {
|
|
display: flex;
|
|
justify-content: flex-end;
|
|
gap: ${unsafeCSS(sharedStyles.spacing.sm)};
|
|
padding: ${unsafeCSS(sharedStyles.spacing.md)} ${unsafeCSS(sharedStyles.spacing.lg)};
|
|
border-top: 1px solid ${sharedStyles.colors.border.default};
|
|
background: ${sharedStyles.colors.background.muted};
|
|
}
|
|
|
|
/* Style dees-input components */
|
|
dees-input-text {
|
|
--dees-input-background: ${sharedStyles.colors.background.primary};
|
|
--dees-input-border-color: ${sharedStyles.colors.border.default};
|
|
}
|
|
`
|
|
];
|
|
async connectedCallback() {
|
|
await super.connectedCallback();
|
|
if (this.incident) {
|
|
this.formData = {
|
|
...this.formData,
|
|
status: this.incident.status,
|
|
};
|
|
}
|
|
}
|
|
updated(changedProperties) {
|
|
if (changedProperties.has('incident') && this.incident) {
|
|
this.formData = {
|
|
...this.formData,
|
|
status: this.incident.status,
|
|
};
|
|
}
|
|
}
|
|
render() {
|
|
if (!this.incident) {
|
|
return html `<div class="update-container">No incident selected</div>`;
|
|
}
|
|
const statusOptions = [
|
|
{ value: 'investigating', label: 'Investigating', desc: 'Looking into the issue' },
|
|
{ value: 'identified', label: 'Identified', desc: 'Root cause found' },
|
|
{ value: 'monitoring', label: 'Monitoring', desc: 'Fix applied, watching' },
|
|
{ value: 'resolved', label: 'Resolved', desc: 'Issue is fixed' },
|
|
{ value: 'postmortem', label: 'Postmortem', desc: 'Analysis complete' },
|
|
];
|
|
const templates = [
|
|
{ icon: 'lucide:Search', label: 'Started investigating', message: 'We are currently investigating this issue.' },
|
|
{ icon: 'lucide:Target', label: 'Issue identified', message: 'We have identified the root cause and are working on a fix.' },
|
|
{ icon: 'lucide:Rocket', label: 'Fix deployed', message: 'A fix has been deployed. We are monitoring the results.' },
|
|
{ icon: 'lucide:CheckCircle', label: 'Resolved', message: 'This incident has been resolved. All systems are operating normally.' },
|
|
];
|
|
const severityIcons = {
|
|
critical: 'lucide:AlertCircle',
|
|
major: 'lucide:AlertTriangle',
|
|
minor: 'lucide:Info',
|
|
maintenance: 'lucide:Wrench',
|
|
};
|
|
return html `
|
|
<div class="update-container">
|
|
<div class="update-header">
|
|
<div class="update-title-row">
|
|
<dees-icon .icon=${'lucide:MessageSquarePlus'} .iconSize=${24}></dees-icon>
|
|
<h2 class="update-title">Post Update</h2>
|
|
</div>
|
|
<div class="incident-info">
|
|
<span class="severity-badge ${this.incident.severity}">
|
|
<dees-icon .icon=${severityIcons[this.incident.severity]} .iconSize=${12}></dees-icon>
|
|
${this.incident.severity}
|
|
</span>
|
|
<span class="incident-name">${this.incident.title}</span>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="update-body">
|
|
<dees-form>
|
|
<div>
|
|
<label class="field-label required">Status</label>
|
|
<div class="status-grid">
|
|
${statusOptions.map(opt => html `
|
|
<label
|
|
class="status-option ${opt.value} ${this.formData.status === opt.value ? 'selected' : ''}"
|
|
@click="${() => this.handleStatusChange(opt.value)}"
|
|
>
|
|
<input
|
|
type="radio"
|
|
name="status"
|
|
value="${opt.value}"
|
|
?checked="${this.formData.status === opt.value}"
|
|
/>
|
|
<dees-icon .icon=${this.statusIcons[opt.value]} .iconSize=${24}></dees-icon>
|
|
<span class="status-label">${opt.label}</span>
|
|
<span class="status-desc">${opt.desc}</span>
|
|
</label>
|
|
`)}
|
|
</div>
|
|
</div>
|
|
|
|
<div>
|
|
<label class="field-label required">Update Message</label>
|
|
<div class="template-section">
|
|
<div class="template-label">Quick templates:</div>
|
|
<div class="template-buttons">
|
|
${templates.map(tpl => html `
|
|
<button type="button" class="template-btn" @click="${() => this.applyTemplate(tpl.message)}">
|
|
<dees-icon .icon=${tpl.icon} .iconSize=${12}></dees-icon>
|
|
${tpl.label}
|
|
</button>
|
|
`)}
|
|
</div>
|
|
</div>
|
|
<dees-input-text
|
|
key="message"
|
|
inputType="textarea"
|
|
.value="${this.formData.message}"
|
|
placeholder="Provide an update on the incident status..."
|
|
required
|
|
@changeSubject="${this.handleMessageChange}"
|
|
></dees-input-text>
|
|
</div>
|
|
|
|
<dees-input-text
|
|
key="author"
|
|
label="Author (Optional)"
|
|
.value="${this.formData.author || ''}"
|
|
placeholder="Your name or team name"
|
|
@changeSubject="${this.handleAuthorChange}"
|
|
></dees-input-text>
|
|
</dees-form>
|
|
</div>
|
|
|
|
<div class="update-actions">
|
|
<dees-button type="discreet" @click="${this.handleCancel}" ?disabled="${this.loading}">
|
|
Cancel
|
|
</dees-button>
|
|
${this.formData.status === 'resolved' ? html `
|
|
<dees-button type="highlighted" @click="${this.handlePost}" ?disabled="${this.loading}" style="--dees-button-background: ${sharedStyles.colors.status.operational}">
|
|
${this.loading ? html `<dees-spinner .size=${16}></dees-spinner>` : html `<dees-icon .icon=${'lucide:CheckCircle'} .iconSize=${16}></dees-icon>`}
|
|
Resolve Incident
|
|
</dees-button>
|
|
` : html `
|
|
<dees-button type="highlighted" @click="${this.handlePost}" ?disabled="${this.loading}">
|
|
${this.loading ? html `<dees-spinner .size=${16}></dees-spinner>` : html `<dees-icon .icon=${'lucide:Send'} .iconSize=${16}></dees-icon>`}
|
|
Post Update
|
|
</dees-button>
|
|
`}
|
|
</div>
|
|
</div>
|
|
`;
|
|
}
|
|
handleMessageChange(e) {
|
|
this.formData = { ...this.formData, message: e.detail };
|
|
if (this.errors.message) {
|
|
this.errors = { ...this.errors, message: '' };
|
|
}
|
|
}
|
|
handleAuthorChange(e) {
|
|
this.formData = { ...this.formData, author: e.detail };
|
|
}
|
|
handleStatusChange(status) {
|
|
this.formData = { ...this.formData, status };
|
|
}
|
|
applyTemplate(message) {
|
|
this.formData = { ...this.formData, message };
|
|
}
|
|
validate() {
|
|
const errors = {};
|
|
if (!this.formData.message?.trim()) {
|
|
errors.message = 'Update message is required';
|
|
}
|
|
this.errors = errors;
|
|
return Object.keys(errors).length === 0;
|
|
}
|
|
handlePost() {
|
|
if (!this.validate()) {
|
|
return;
|
|
}
|
|
this.dispatchEvent(new CustomEvent('updatePost', {
|
|
detail: {
|
|
incidentId: this.incident?.id,
|
|
update: { ...this.formData }
|
|
},
|
|
bubbles: true,
|
|
composed: true
|
|
}));
|
|
}
|
|
handleCancel() {
|
|
this.dispatchEvent(new CustomEvent('updateCancel', {
|
|
bubbles: true,
|
|
composed: true
|
|
}));
|
|
}
|
|
reset() {
|
|
this.formData = {
|
|
status: this.incident?.status || 'investigating',
|
|
message: '',
|
|
author: '',
|
|
};
|
|
this.errors = {};
|
|
}
|
|
static {
|
|
__runInitializers(_classThis, _classExtraInitializers);
|
|
}
|
|
};
|
|
return UpladminIncidentUpdate = _classThis;
|
|
})();
|
|
export { UpladminIncidentUpdate };
|
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upladmin-incident-update.js","sourceRoot":"","sources":["../../../ts_web/elements/upladmin-incident-update/upladmin-incident-update.ts"],"names":[],"mappings":"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"}
|