Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 | 112x 112x 112x 112x 112x 112x 15996x 15996x 15996x 15996x 15996x 15996x 112x 112x 395x 2x 1x 1x 1x 1x 2x 395x 112x 112x 112x 112x 112x 112x 112x 112x 112x 6338x 6338x 6338x 6338x 6338x 6338x 6338x 6338x 112x 9938x 9938x 112x 112x 6236x 6236x 6236x 2816x 1611x 2588x 180x 1204x 1025x 1025x 2816x 6236x 112x 112x 5379x 1206x 1x 1206x 180x 1204x 1025x 1025x 1206x 5379x 5379x 112x 112x 5987x 5987x 5987x 5987x 5987x 112x 112x 10009x 10009x 10009x 10009x 10009x 112x 112x 3x 2x 2x 1x 1x 1x 1x 3x 112x 112x 394x 394x 394x 394x 394x 394x 394x 394x 394x 112x 112x 1x 1x 1x 112x 112x 1922x 1x 1x 1922x 1922x 1922x 1922x 1922x 1922x 1922x 1922x 1922x 112x 112x 2864x 2864x 2864x 2474x 2474x 2474x 2x 2472x 2472x 2472x 2472x 2472x 2472x 2472x 2472x 2472x 2472x 2472x 2472x 2472x 2472x 2472x 2472x 2472x 2472x 2472x 112x 3x 5x 5x 5x 4x 4x 5x 2x 3x 3x 3x 112x 112x 21x 21x 1x 1x 21x 20x 21x 19x 19x 21x 20x 112x 112x 1x 1x 1x 1x 1x 1x 112x 112x 112x 79x 79x 112x 112x | import { LitElement, PropertyValueMap } from 'lit';
import { CustomEventType } from './interfaces';
import { Color, log } from './utils';
import { property } from 'lit/decorators.js';
const showUpdates = (
ele: HTMLElement,
changes: Map<PropertyKey, unknown>,
firstUpdated = false
) => {
if (ele['DEBUG_UPDATES'] || ele['DEBUG']) {
if (changes.size > 0) {
const fromto = {};
for (const key of changes.keys()) {
fromto[key] = [changes[key], ele[key]];
}
log(ele.tagName, Color.PURPLE, [
firstUpdated ? '<first-updated>' : '<updated>',
fromto
]);
}
}
};
const showEvent = (ele: HTMLElement, type: string, details = undefined) => {
if (ele['DEBUG_EVENTS'] || ele['DEBUG']) {
if (details !== undefined) {
log(ele.tagName, Color.GREEN, [type, details]);
} else {
log(ele.tagName, Color.GREEN, [type]);
}
}
};
export interface EventHandler {
event: string;
method: EventListener;
isDocument?: boolean;
isWindow?: boolean;
}
export class RapidElement extends LitElement {
DEBUG = false;
DEBUG_UPDATES = false;
DEBUG_EVENTS = false;
@property({ type: String })
service: string;
private eles: { [selector: string]: HTMLDivElement } = {};
public getEventHandlers(): EventHandler[] {
return [];
}
connectedCallback() {
super.connectedCallback();
for (const handler of this.getEventHandlers()) {
if (handler.isDocument) {
document.addEventListener(handler.event, handler.method.bind(this));
} else if (handler.isWindow) {
window.addEventListener(handler.event, handler.method.bind(this));
} else {
this.addEventListener(handler.event, handler.method.bind(this));
}
}
}
disconnectedCallback() {
for (const handler of this.getEventHandlers()) {
if (handler.isDocument) {
document.removeEventListener(handler.event, handler.method);
} else if (handler.isWindow) {
window.removeEventListener(handler.event, handler.method);
} else {
this.removeEventListener(handler.event, handler.method);
}
}
super.disconnectedCallback();
}
protected firstUpdated(
changes: PropertyValueMap<any> | Map<PropertyKey, unknown>
): void {
super.firstUpdated(changes);
showUpdates(this, changes, true);
}
protected updated(
changes: PropertyValueMap<any> | Map<PropertyKey, unknown>
): void {
super.updated(changes);
showUpdates(this, changes, false);
}
public getHeaders() {
if (!this.service) {
return {};
}
return {
'X-Temba-Service-Org': this.service
};
}
public fireEvent(type: string): any {
showEvent(this, type);
return this.dispatchEvent(
new Event(type, {
bubbles: true,
composed: true
})
);
}
swallowEvent(event: Event) {
event.stopPropagation();
event.preventDefault();
}
public fireCustomEvent(type: CustomEventType, detail: any = {}): any {
if (this['DEBUG_EVENTS']) {
showEvent(this, type, detail);
}
const event = new CustomEvent(type, {
detail,
bubbles: true,
composed: true
});
return this.dispatchEvent(event);
}
public dispatchEvent(event: any): any {
super.dispatchEvent(event);
const ele = event.target;
if (ele) {
// lookup events with - prefix and try to invoke them
const eventFire = (ele as any)['-' + event.type];
if (eventFire) {
return eventFire(event);
} else {
const func = new Function(
'event',
`
with(document) {
with(this) {
let handler = ${ele.getAttribute('-' + event.type)};
if(typeof handler === 'function') {
handler(event);
}
}
}
`
);
return func.call(ele, event);
}
}
}
public closestElement(selector: string, base: Element = this) {
function __closestFrom(el: Element | Window | Document): Element {
if (!el || el === document || el === window) return null;
if ((el as any).assignedSlot) el = (el as any).assignedSlot;
const found = (el as Element).closest(selector);
return found
? found
: __closestFrom(((el as Element).getRootNode() as ShadowRoot).host);
}
return __closestFrom(base);
}
public getDiv(selector: string) {
let ele = this.eles[selector];
if (ele) {
return ele;
}
ele = this.shadowRoot.querySelector(selector);
if (ele) {
this.eles[selector] = ele;
}
return ele;
}
public stopEvent(event: Event) {
if (event) {
event.stopPropagation();
event.preventDefault();
}
}
public isMobile() {
const win = window as any;
if (win.isMobile) {
return win.isMobile();
}
return false;
}
}
|