Skip to content

Commit

Permalink
added support for blur / focus events
Browse files Browse the repository at this point in the history
  • Loading branch information
floodfx committed Feb 3, 2022
1 parent 5c2f636 commit 9a5e9c4
Show file tree
Hide file tree
Showing 15 changed files with 27 additions and 18 deletions.
4 changes: 2 additions & 2 deletions coverage/clover.xml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<coverage generated="1643683810006" clover="3.2.0">
<project timestamp="1643683810006" name="All files">
<coverage generated="1643846724828" clover="3.2.0">
<project timestamp="1643846724828" name="All files">
<metrics statements="51" coveredstatements="49" conditionals="14" coveredconditionals="11" methods="19" coveredmethods="18" elements="84" coveredelements="78" complexity="0" loc="51" ncloc="51" packages="4" files="5" classes="5"/>
<package name="examples.autocomplete">
<metrics statements="5" coveredstatements="4" conditionals="1" coveredconditionals="0" methods="2" coveredmethods="2"/>
Expand Down
2 changes: 1 addition & 1 deletion coverage/lcov-report/examples/autocomplete/data.ts.html
Original file line number Diff line number Diff line change
Expand Up @@ -3106,7 +3106,7 @@ <h1><a href="../../index.html">All files</a> / <a href="index.html">examples/aut
<div class='footer quiet pad2 space-top1 center small'>
Code coverage generated by
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
at Mon Jan 31 2022 19:50:09 GMT-0700 (Mountain Standard Time)
at Wed Feb 02 2022 17:05:24 GMT-0700 (Mountain Standard Time)
</div>
<script src="../../prettify.js"></script>
<script>
Expand Down
2 changes: 1 addition & 1 deletion coverage/lcov-report/examples/autocomplete/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,7 @@ <h1><a href="../../index.html">All files</a> examples/autocomplete</h1>
<div class='footer quiet pad2 space-top1 center small'>
Code coverage generated by
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
at Mon Jan 31 2022 19:50:09 GMT-0700 (Mountain Standard Time)
at Wed Feb 02 2022 17:05:24 GMT-0700 (Mountain Standard Time)
</div>
<script src="../../prettify.js"></script>
<script>
Expand Down
2 changes: 1 addition & 1 deletion coverage/lcov-report/examples/live-search/data.ts.html
Original file line number Diff line number Diff line change
Expand Up @@ -331,7 +331,7 @@ <h1><a href="../../index.html">All files</a> / <a href="index.html">examples/liv
<div class='footer quiet pad2 space-top1 center small'>
Code coverage generated by
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
at Mon Jan 31 2022 19:50:09 GMT-0700 (Mountain Standard Time)
at Wed Feb 02 2022 17:05:24 GMT-0700 (Mountain Standard Time)
</div>
<script src="../../prettify.js"></script>
<script>
Expand Down
2 changes: 1 addition & 1 deletion coverage/lcov-report/examples/live-search/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,7 @@ <h1><a href="../../index.html">All files</a> examples/live-search</h1>
<div class='footer quiet pad2 space-top1 center small'>
Code coverage generated by
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
at Mon Jan 31 2022 19:50:09 GMT-0700 (Mountain Standard Time)
at Wed Feb 02 2022 17:05:24 GMT-0700 (Mountain Standard Time)
</div>
<script src="../../prettify.js"></script>
<script>
Expand Down
2 changes: 1 addition & 1 deletion coverage/lcov-report/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -146,7 +146,7 @@ <h1>All files</h1>
<div class='footer quiet pad2 space-top1 center small'>
Code coverage generated by
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
at Mon Jan 31 2022 19:50:09 GMT-0700 (Mountain Standard Time)
at Wed Feb 02 2022 17:05:24 GMT-0700 (Mountain Standard Time)
</div>
<script src="prettify.js"></script>
<script>
Expand Down
2 changes: 1 addition & 1 deletion coverage/lcov-report/misc/erlang/Erlang.js.html
Original file line number Diff line number Diff line change
Expand Up @@ -3616,7 +3616,7 @@ <h1><a href="../../index.html">All files</a> / <a href="index.html">misc/erlang<
<div class='footer quiet pad2 space-top1 center small'>
Code coverage generated by
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
at Mon Jan 31 2022 19:50:09 GMT-0700 (Mountain Standard Time)
at Wed Feb 02 2022 17:05:24 GMT-0700 (Mountain Standard Time)
</div>
<script src="../../prettify.js"></script>
<script>
Expand Down
2 changes: 1 addition & 1 deletion coverage/lcov-report/misc/erlang/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -116,7 +116,7 @@ <h1><a href="../../index.html">All files</a> misc/erlang</h1>
<div class='footer quiet pad2 space-top1 center small'>
Code coverage generated by
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
at Mon Jan 31 2022 19:50:09 GMT-0700 (Mountain Standard Time)
at Wed Feb 02 2022 17:05:24 GMT-0700 (Mountain Standard Time)
</div>
<script src="../../prettify.js"></script>
<script>
Expand Down
2 changes: 1 addition & 1 deletion coverage/lcov-report/misc/erlang/index.ts.html
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,7 @@ <h1><a href="../../index.html">All files</a> / <a href="index.html">misc/erlang<
<div class='footer quiet pad2 space-top1 center small'>
Code coverage generated by
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
at Mon Jan 31 2022 19:50:09 GMT-0700 (Mountain Standard Time)
at Wed Feb 02 2022 17:05:24 GMT-0700 (Mountain Standard Time)
</div>
<script src="../../prettify.js"></script>
<script>
Expand Down
2 changes: 1 addition & 1 deletion coverage/lcov-report/server/templates/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,7 @@ <h1><a href="../../index.html">All files</a> server/templates</h1>
<div class='footer quiet pad2 space-top1 center small'>
Code coverage generated by
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
at Mon Jan 31 2022 19:50:09 GMT-0700 (Mountain Standard Time)
at Wed Feb 02 2022 17:05:24 GMT-0700 (Mountain Standard Time)
</div>
<script src="../../prettify.js"></script>
<script>
Expand Down
2 changes: 1 addition & 1 deletion coverage/lcov-report/server/templates/index.ts.html
Original file line number Diff line number Diff line change
Expand Up @@ -394,7 +394,7 @@ <h1><a href="../../index.html">All files</a> / <a href="index.html">server/templ
<div class='footer quiet pad2 space-top1 center small'>
Code coverage generated by
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
at Mon Jan 31 2022 19:50:09 GMT-0700 (Mountain Standard Time)
at Wed Feb 02 2022 17:05:24 GMT-0700 (Mountain Standard Time)
</div>
<script src="../../prettify.js"></script>
<script>
Expand Down
1 change: 0 additions & 1 deletion src/examples/live-search/component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,6 @@ export class SearchLiveViewComponent extends BaseLiveViewComponent<SearchContext
};

handleEvent(event: "zip-search", params: { zip: string }, socket: LiveViewSocket<SearchContext>) {
// console.log("event:", event, params, socket);
const { zip } = params;
// wait 100ms to send the message
setTimeout(() => {
Expand Down
9 changes: 7 additions & 2 deletions src/server/socket/component_manager.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { WebSocket } from "ws";
import { BaseLiveViewComponent, LiveViewComponent, LiveViewSocket, StringPropertyValues } from "..";
import { newHeartbeatReply, newPhxReply, PhxClickPayload, PhxDiffReply, PhxFormPayload, PhxHeartbeatIncoming, PhxIncomingMessage, PhxJoinIncoming, PhxLivePatchIncoming, PhxOutgoingLivePatchPush, PhxOutgoingMessage, PhxKeyDownPayload, PhxKeyUpPayload } from "./types";
import { newHeartbeatReply, newPhxReply, PhxClickPayload, PhxDiffReply, PhxFormPayload, PhxHeartbeatIncoming, PhxIncomingMessage, PhxJoinIncoming, PhxLivePatchIncoming, PhxOutgoingLivePatchPush, PhxOutgoingMessage, PhxKeyDownPayload, PhxKeyUpPayload, PhxBlurPayload, PhxFocusPayload } from "./types";
import jwt from 'jsonwebtoken';
import { SessionData } from "express-session";

Expand Down Expand Up @@ -68,7 +68,7 @@ export class LiveViewComponentManager {
this.sendPhxReply(ws, newHeartbeatReply(message));
}

onEvent(ws: WebSocket, message: PhxIncomingMessage<PhxClickPayload | PhxFormPayload | PhxKeyUpPayload | PhxKeyDownPayload>) {
onEvent(ws: WebSocket, message: PhxIncomingMessage<PhxClickPayload | PhxFormPayload | PhxKeyUpPayload | PhxKeyDownPayload | PhxBlurPayload | PhxFocusPayload>) {
const [joinRef, messageRef, topic, _, payload] = message;
const { type, event } = payload;

Expand All @@ -82,6 +82,11 @@ export class LiveViewComponentManager {
value = Object.fromEntries(new URLSearchParams(payload.value))
} else if (type === "keyup" || type === "keydown") {
value = payload.value;
} else if (type === "blur" || type === "focus") {
value = payload.value;
} else {
console.error("Unknown event type", type);
return;
}

if (isEventHandler(this.component)) {
Expand Down
4 changes: 2 additions & 2 deletions src/server/socket/message_router.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { PhxJoinIncoming, PhxHeartbeatIncoming, PhxIncomingMessage, PhxClickPayload, PhxFormPayload, PhxLivePatchIncoming, PhxKeyDownPayload, PhxKeyUpPayload } from './types';
import { PhxJoinIncoming, PhxHeartbeatIncoming, PhxIncomingMessage, PhxClickPayload, PhxFormPayload, PhxLivePatchIncoming, PhxKeyDownPayload, PhxKeyUpPayload, PhxBlurPayload, PhxFocusPayload } from './types';
import WebSocket from 'ws';
import { LiveViewComponent } from '../types';
import { LiveViewRouter } from '../types';
Expand Down Expand Up @@ -32,7 +32,7 @@ export class MessageRouter {
// lookup component manager for this topic
componentManager = this.topicComponentManager[topic];
if (componentManager) {
const message = rawPhxMessage as PhxIncomingMessage<PhxClickPayload | PhxFormPayload | PhxKeyDownPayload | PhxKeyUpPayload>;
const message = rawPhxMessage as PhxIncomingMessage<PhxClickPayload | PhxFormPayload | PhxKeyDownPayload | PhxKeyUpPayload | PhxFocusPayload | PhxBlurPayload>;
componentManager.onEvent(ws, message);
} else {
console.log("expected component manager for topic", topic);
Expand Down
7 changes: 6 additions & 1 deletion src/server/socket/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -76,13 +76,18 @@ export type PhxFormPayload = PhxEventPayload<"form", { value: string }> & PhxEve

// See https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent/key/Key_Values
// for all the string values for the key that kicked off the event
//{type: "keyup", event: "key_update", value: {key: "ArrowUp"}}
// {type: "keyup", event: "key_update", value: {key: "ArrowUp"}}
// {type: "keyup", event: "key_update", value: {key: "ArrowUp", value: ""}}
// {type: "keyup", event: "key_update", value: {key: "ArrowUp", value: "foo"}}
// NOTE: these payloads are the same for phx-window-key* events and phx-key* events
export type PhxKeyUpPayload = PhxEventPayload<"keyup", { value: { key: string, value?: string } }>;
export type PhxKeyDownPayload = PhxEventPayload<"keydown", { value: { key: string, value?: string } }>;

// Focus and Blur events
// {type: "focus", event: "focus", value: {value: ""}}
// {type: "blur", event: "blur", value: {value: ""}}
export type PhxFocusPayload = PhxEventPayload<"focus", { value: { value: string } }>;
export type PhxBlurPayload = PhxEventPayload<"blur", { value: { value: string } }>;

export const newPhxReply = (from: PhxIncomingMessage<unknown>, payload: any): PhxReply => {
return [
Expand Down

0 comments on commit 9a5e9c4

Please sign in to comment.