glass-easel-devtools-panel 0.9.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 (63) hide show
  1. package/.eslintignore +2 -0
  2. package/dist/app.d.ts +0 -0
  3. package/dist/bootstrap.d.ts +5 -0
  4. package/dist/bootstrap.js +3 -0
  5. package/dist/bootstrap.js.LICENSE.txt +1 -0
  6. package/dist/events.d.ts +41 -0
  7. package/dist/global_components/image/image.d.ts +1 -0
  8. package/dist/global_components/index.d.ts +2 -0
  9. package/dist/global_components/view/view.d.ts +1 -0
  10. package/dist/index.css +17 -0
  11. package/dist/message_channel.d.ts +11 -0
  12. package/dist/pages/detail/detail.d.ts +1 -0
  13. package/dist/pages/detail/section.d.ts +0 -0
  14. package/dist/pages/detail/value.d.ts +1 -0
  15. package/dist/pages/index/index.d.ts +1 -0
  16. package/dist/pages/store.d.ts +9 -0
  17. package/dist/pages/tree/element.d.ts +1 -0
  18. package/dist/resources/logo_256.png +0 -0
  19. package/dist/utils.d.ts +4 -0
  20. package/package.json +21 -0
  21. package/src/app.ts +1 -0
  22. package/src/app.wxss +1 -0
  23. package/src/bootstrap.ts +80 -0
  24. package/src/events.ts +97 -0
  25. package/src/global_components/image/image.json +3 -0
  26. package/src/global_components/image/image.ts +1 -0
  27. package/src/global_components/image/image.wxml +1 -0
  28. package/src/global_components/image/image.wxss +3 -0
  29. package/src/global_components/index.ts +12 -0
  30. package/src/global_components/view/view.json +3 -0
  31. package/src/global_components/view/view.ts +40 -0
  32. package/src/global_components/view/view.wxml +14 -0
  33. package/src/global_components/view/view.wxss +0 -0
  34. package/src/message_channel.ts +70 -0
  35. package/src/pages/common.wxss +12 -0
  36. package/src/pages/detail/detail.json +7 -0
  37. package/src/pages/detail/detail.ts +190 -0
  38. package/src/pages/detail/detail.wxml +179 -0
  39. package/src/pages/detail/detail.wxss +84 -0
  40. package/src/pages/detail/section.json +3 -0
  41. package/src/pages/detail/section.ts +17 -0
  42. package/src/pages/detail/section.wxml +8 -0
  43. package/src/pages/detail/section.wxss +47 -0
  44. package/src/pages/detail/value.json +3 -0
  45. package/src/pages/detail/value.ts +107 -0
  46. package/src/pages/detail/value.wxml +7 -0
  47. package/src/pages/detail/value.wxss +44 -0
  48. package/src/pages/index/index.json +6 -0
  49. package/src/pages/index/index.ts +121 -0
  50. package/src/pages/index/index.wxml +29 -0
  51. package/src/pages/index/index.wxss +75 -0
  52. package/src/pages/store.ts +33 -0
  53. package/src/pages/tree/element.json +6 -0
  54. package/src/pages/tree/element.ts +295 -0
  55. package/src/pages/tree/element.wxml +47 -0
  56. package/src/pages/tree/element.wxss +113 -0
  57. package/src/resources/logo_256.png +0 -0
  58. package/src/utils.ts +16 -0
  59. package/src.d.ts +10 -0
  60. package/tsconfig.json +11 -0
  61. package/typings/miniprogram.d.ts +6 -0
  62. package/webpack.config.js +79 -0
  63. package/webpack.dev.config.js +12 -0
@@ -0,0 +1 @@
1
+ /*! For license information please see index.js.LICENSE.txt */
@@ -0,0 +1,41 @@
1
+ import { type builder } from 'glass-easel-miniprogram-adapter/dist/glass_easel_miniprogram_adapter';
2
+ import { type protocol } from './message_channel';
3
+ export declare class EventDispatcher<N extends string, K extends string | number, T extends {
4
+ [k in N]: K;
5
+ }> {
6
+ private keyName;
7
+ private listeners;
8
+ constructor(keyName: N);
9
+ addListener(key: K, func: (args: T) => void): void;
10
+ removeListener(key: K, func: (args: T) => void): void;
11
+ bindComponentLifetimes(ctx: builder.BuilderContext<any, any, any>, getKey: () => K, func: (args: T) => void): void;
12
+ dispatch(args: T): void;
13
+ }
14
+ export declare const childNodeCountUpdated: EventDispatcher<"nodeId", number, {
15
+ nodeId: protocol.NodeId;
16
+ childNodeCount: number;
17
+ }>;
18
+ export declare const setChildNodes: EventDispatcher<"parentId", number, {
19
+ parentId: protocol.NodeId;
20
+ nodes: protocol.dom.Node[];
21
+ }>;
22
+ export declare const childNodeInserted: EventDispatcher<"parentNodeId", number, {
23
+ parentNodeId: protocol.NodeId;
24
+ previousNodeId: protocol.NodeId;
25
+ node: protocol.dom.Node;
26
+ }>;
27
+ export declare const childNodeRemoved: EventDispatcher<"parentNodeId", number, {
28
+ parentNodeId: protocol.NodeId;
29
+ nodeId: protocol.NodeId;
30
+ }>;
31
+ export declare const characterDataModified: EventDispatcher<"nodeId", number, {
32
+ nodeId: protocol.NodeId;
33
+ characterData: string;
34
+ }>;
35
+ export declare const attributeModified: EventDispatcher<"nodeId", number, {
36
+ nodeId: protocol.NodeId;
37
+ name: string;
38
+ value: string;
39
+ detail: protocol.GlassEaselVar;
40
+ nameType: "basic" | "attribute" | "component-property" | "slot-value" | "dataset" | "mark" | "external-class";
41
+ }>;
@@ -0,0 +1 @@
1
+ export declare const componentDefinition: {};
@@ -0,0 +1,2 @@
1
+ import { type CodeSpace } from 'glass-easel-miniprogram-adapter';
2
+ export declare const loadGlobalComponents: (codeSpace: CodeSpace) => void;
@@ -0,0 +1 @@
1
+ export declare const componentDefinition: {};
package/dist/index.css ADDED
@@ -0,0 +1,17 @@
1
+ [wx-host="A"]{display:block;}
2
+
3
+ [wx-host="C"]{display:block;}
4
+
5
+ [wx-host="E"]{display:block;}
6
+
7
+ [wx-host="G"]{display:block;}
8
+
9
+ @keyframes update-ani{from{background:#dd8;}to{background:transparent;}}.A--updated{background:#dd8;animation-duration:1s;animation-fill-mode:both;animation-name:update-ani;animation-timing-function:ease;}.A--tag{color:#888;white-space:nowrap;}.A--fold-arrow{display:inline-block;width:1em;height:1em;line-height:1em;color:#444;text-align:center;}.A--fold-arrow-icon{width:1em;transition:transform 200ms ease;}.A--fold-arrow-icon_open{transform:rotate(90deg);}.A--tag-body{display:inline-block;}.A--tag-body_hover{background:#ace;}.A--tag-body_selected{background:#add;}.A--tag-body_highlight{background-color:rgba(0,128,192,0.25);}.A--tag-text{display:inline;}.A--tag-name{display:inline-block;color:#408;}.A--tag-var-name-wrapper{display:inline;}.A--tag-var-name{display:inline-block;margin-left:0.25em;height:1em;line-height:1em;min-width:1em;text-align:center;font-size:0.8em;font-style:italic;color:#222;}.A--tag-var-name_hover{background:#ace;}.A--attribute{display:inline-block;margin-left:0.5em;}.A--attribute-name{display:inline-block;color:#084;}.A--attribute-name_property{color:#06a;}.A--attribute-value{display:inline-block;color:#840;}.A--children{margin-left:1em;}.A--virtual-tag-name{display:inline-block;font-style:italic;}.A--virtual-tag-name_hover{background:#add;}.A--text-content{color:#222;padding:1px 0;}
10
+ body{margin:0;height:100vh;}.wrapper{font-family:monospace;font-size:12px;background:#eee;height:100%;cursor:default;user-select:none;}.empty{color:#888;font-style:italic;padding:5px;}.main{height:100%;}.tree-detail{display:flex;height:100%;overflow:hidden;}.tree-detail-split{width:2px;background-color:#888;cursor:w-resize;}.left{flex:1 1 0;display:flex;flex-direction:column;overflow-x:hidden;}.toolbar{flex:none;background:#ccc;color:#222;border-bottom:2px solid#888;display:flex;}.tool-space{flex:auto;}.tool{flex:none;display:inline-block;padding:5px 10px;}.tool_hover{background:#ace;}.tool_active{background:#add;}.tree{flex:auto;margin:5px;overflow:auto;user-select:text;}.detail{flex:none;box-sizing:border-box;overflow:auto;}
11
+ .C--title{padding:0 5px;background:#ccc;color:#222;line-height:1.5;white-space:nowrap;}.C--title-text{display:inline-block;}.C--title-refresh{display:inline-block;font-size:1.5em;width:1em;height:1em;line-height:1;text-align:center;margin-left:0.5em;}.C--title-refresh_hover{background-color:#ace;}.C--arrow{display:inline-block;width:1em;height:1.5em;text-align:center;transition:transform 200ms ease;margin-right:0.25em;}.C--arrow_open{transform:rotate(90deg);}.C--body{padding:0 5px;overflow:hidden;}.C--body_collapsed{height:0;}
12
+ @keyframes value-update-ani{from{background:#dd8;}to{background:transparent;}}.D--updated{background:#dd8;animation-duration:1s;animation-fill-mode:both;animation-name:value-update-ani;animation-timing-function:ease;}.D--wrapper{display:inline-block;}.D--slice{display:inline;color:#888;}.D--slice_dynamic{color:#840;}.D--var-name{display:inline-block;margin-left:0.25em;height:1em;line-height:1em;min-width:1em;text-align:center;font-size:0.8em;font-style:italic;color:#222;}.D--var-name_hover{background:#ace;}
13
+ .E--section{margin-bottom:5px;color:#888;}.E--section-item{white-space:nowrap;user-select:text;}.E--section-key{display:inline;color:#06a;}.E--section-key-core{display:inline;color:#084;}.E--section-value{display:inline;color:#840;}.E--section-value-extra{color:#222;}.E--section-empty{text-align:center;font-style:italic;}.E--box-model{margin:0 auto;}.E--box-model-text{flex:none;text-align:center;white-space:nowrap;color:#222;margin:1px;}.E--box-model-content{display:flex;border:1px solid#888;padding:1px;}.E--box-model-padding{border:1px solid#888;padding:1px;background:#eee;}.E--box-model-border{border:1px solid#888;padding:1px;background:#ccc;}.E--box-model-margin{padding:1px;}.E--box-model-line{display:flex;justify-content:center;align-items:center;}.E--style-rule{padding-left:1em;margin:5px 0;}.E--style-rule_inactive{text-decoration:line-through#222;}.E--style-rule-prefix{margin-left:-1em;font-style:italic;}.E--style-rule-title{margin-left:-1em;color:#222;}
14
+
15
+
16
+
17
+ /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.css","mappings":"AAAA,cAAc,aAAa,CAAC;;AAE5B,cAAc,aAAa,CAAC;;AAE5B,cAAc,aAAa,CAAC;;AAE5B,cAAc,aAAa,CAAC,C;;ACJ5B,sBACE,KACE,gBADF,CAGA,GACE,uBADF,CAJF,CAQA,YACE,gBACA,sBACA,yBACA,0BACA,+BALF,CAYA,QACE,WACA,mBAFF,CAKA,eACE,qBACA,UACA,WACA,gBACA,WACA,kBANF,CAQA,oBACE,UACA,gCAFF,CAIA,yBACE,wBADF,CAIA,aACE,qBADF,CAGA,mBACE,gBADF,CAGA,sBACE,gBADF,CAGA,uBACE,sCADF,CAGA,aACE,eADF,CAGA,aACE,qBACA,WAFF,CAKA,yBACE,eADF,CAGA,iBACE,qBACA,mBACA,WACA,gBACA,cACA,kBACA,gBACA,kBACA,WATF,CAWA,uBACE,gBADF,CAIA,cACE,qBACA,kBAFF,CAIA,mBACE,qBACA,WAFF,CAIA,4BACE,WADF,CAGA,oBACE,qBACA,WAFF,CAKA,aACE,gBADF,CAIA,qBACE,qBACA,kBAFF,CAIA,2BACE,gBADF,CAIA,iBACE,WACA,cAFF,C;AC3GA,KACE,SACA,aAFF,CAKA,SACE,sBACA,eACA,gBACA,YACA,eACA,iBANF,CAQA,OACE,WACA,kBACA,YAHF,CAMA,MACE,YADF,CAGA,aACE,aACA,YACA,gBAHF,CAKA,mBACE,UACA,sBACA,gBAHF,CAKA,MACE,WACA,aACA,sBACA,kBAJF,CAOA,SACE,UACA,gBACA,WACA,4BACA,aALF,CAOA,YACE,UADF,CAGA,MACE,UACA,qBACA,iBAHF,CAKA,YACE,gBADF,CAGA,aACE,gBADF,CAIA,MACE,UACA,WACA,cACA,iBAJF,CAOA,QACE,UACA,sBACA,cAHF,C;AChEA,UACE,cACA,gBACA,WACA,gBACA,mBALF,CAOA,eACE,qBADF,CAGA,kBACE,qBACA,gBACA,UACA,WACA,cACA,kBACA,kBAPF,CASA,wBACE,sBADF,CAGA,UACE,qBACA,UACA,aACA,kBACA,gCACA,oBANF,CAQA,eACE,wBADF,CAIA,SACE,cACA,gBAFF,CAIA,mBACE,SADF,C;AC1CA,4BACE,KACE,gBADF,CAGA,GACE,uBADF,CAJF,CAQA,YACE,gBACA,sBACA,yBACA,gCACA,+BALF,CAQA,YACE,qBADF,CAIA,UACE,eACA,WAFF,CAIA,kBACE,WADF,CAIA,aACE,qBACA,mBACA,WACA,gBACA,cACA,kBACA,gBACA,kBACA,WATF,CAWA,mBACE,gBADF,C;ACnCA,YACE,kBACA,WAFF,CAIA,iBACE,mBACA,iBAFF,CAIA,gBACE,eACA,WAFF,CAIA,qBACE,eACA,WAFF,CAIA,kBACE,eACA,WAFF,CAIA,wBACE,WADF,CAIA,kBACE,kBACA,kBAFF,CAKA,cACE,cADF,CAGA,mBACE,UACA,kBACA,mBACA,WACA,WALF,CAOA,sBACE,aACA,qBACA,YAHF,CAKA,sBACE,qBACA,YACA,gBAHF,CAKA,qBACE,qBACA,YACA,gBAHF,CAKA,qBACE,YADF,CAGA,mBACE,aACA,uBACA,mBAHF,CAMA,eACE,iBACA,aAFF,CAIA,wBACE,iCADF,CAGA,sBACE,iBACA,kBAFF,CAIA,qBACE,iBACA,WAFF,C","sources":["webpack://glass-easel-devtools-panel/./src/__glass_easel_host_styles__.wxss","webpack://glass-easel-devtools-panel/./src/pages/tree/element.wxss","webpack://glass-easel-devtools-panel/./src/pages/index/index.wxss","webpack://glass-easel-devtools-panel/./src/pages/detail/section.wxss","webpack://glass-easel-devtools-panel/./src/pages/detail/value.wxss","webpack://glass-easel-devtools-panel/./src/pages/detail/detail.wxss"],"sourcesContent":["[wx-host=\"A\"]{display:block;}\n\n[wx-host=\"C\"]{display:block;}\n\n[wx-host=\"E\"]{display:block;}\n\n[wx-host=\"G\"]{display:block;}","@import url('../common.wxss');\n\n@keyframes update-ani {\n  from {\n    background: @update-bg;\n  }\n  to {\n    background: transparent;\n  }\n}\n.updated {\n  background: @update-bg;\n  animation-duration: 1s;\n  animation-fill-mode: both;\n  animation-name: update-ani;\n  animation-timing-function: ease;\n}\n\n:host {\n  display: block;\n}\n\n.tag {\n  color: @common-text;\n  white-space: nowrap;\n}\n\n.fold-arrow {\n  display: inline-block;\n  width: 1em;\n  height: 1em;\n  line-height: 1em;\n  color: #444;\n  text-align: center;\n}\n.fold-arrow-icon {\n  width: 1em;\n  transition: transform 200ms ease;\n}\n.fold-arrow-icon_open {\n  transform: rotate(90deg);\n}\n\n.tag-body {\n  display: inline-block;\n}\n.tag-body_hover {\n  background: @hover-bg;\n}\n.tag-body_selected {\n  background: @selected-bg;\n}\n.tag-body_highlight {\n  background-color: rgba(0, 128, 192, 0.25);\n}\n.tag-text {\n  display: inline;\n}\n.tag-name {\n  display: inline-block;\n  color: @tag-name;\n}\n\n.tag-var-name-wrapper {\n  display: inline;\n}\n.tag-var-name {\n  display: inline-block;\n  margin-left: 0.25em;\n  height: 1em;\n  line-height: 1em;\n  min-width: 1em;\n  text-align: center;\n  font-size: 0.8em;\n  font-style: italic;\n  color: @important-text;\n}\n.tag-var-name_hover {\n  background: @hover-bg;\n}\n\n.attribute {\n  display: inline-block;\n  margin-left: 0.5em;\n}\n.attribute-name {\n  display: inline-block;\n  color: @core-attribute-name;\n}\n.attribute-name_property {\n  color: @property-name;\n}\n.attribute-value {\n  display: inline-block;\n  color: @attribute-value;\n}\n\n.children {\n  margin-left: 1em;\n}\n\n.virtual-tag-name {\n  display: inline-block;\n  font-style: italic;\n}\n.virtual-tag-name_hover {\n  background: @selected-bg;\n}\n\n.text-content {\n  color: @important-text;\n  padding: 1px 0;\n}\n","@import url('../common.wxss');\n\nbody {\n  margin: 0;\n  height: 100vh;\n}\n\n.wrapper {\n  font-family: monospace;\n  font-size: 12px;\n  background: @primary-bg;\n  height: 100%;\n  cursor: default;\n  user-select: none;\n}\n.empty {\n  color: @common-text;\n  font-style: italic;\n  padding: 5px;\n}\n\n.main {\n  height: 100%;\n}\n.tree-detail {\n  display: flex;\n  height: 100%;\n  overflow: hidden;\n}\n.tree-detail-split {\n  width: 2px;\n  background-color: #888;\n  cursor: w-resize;\n}\n.left {\n  flex: 1 1 0;\n  display: flex;\n  flex-direction: column;\n  overflow-x: hidden;\n}\n\n.toolbar {\n  flex: none;\n  background: @secondary-bg;\n  color: @important-text;\n  border-bottom: 2px solid #888;\n  display: flex;\n}\n.tool-space {\n  flex: auto;\n}\n.tool {\n  flex: none;\n  display: inline-block;\n  padding: 5px 10px;\n}\n.tool_hover {\n  background: @hover-bg;\n}\n.tool_active {\n  background: @selected-bg;\n}\n\n.tree {\n  flex: auto;\n  margin: 5px;\n  overflow: auto;\n  user-select: text;\n}\n\n.detail {\n  flex: none;\n  box-sizing: border-box;\n  overflow: auto;\n}\n","@import url('../common.wxss');\n\n:host {\n  display: block;\n}\n\n.title {\n  padding: 0 5px;\n  background: @secondary-bg;\n  color: @important-text;\n  line-height: 1.5;\n  white-space: nowrap;\n}\n.title-text {\n  display: inline-block;\n}\n.title-refresh {\n  display: inline-block;\n  font-size: 1.5em;\n  width: 1em;\n  height: 1em;\n  line-height: 1;\n  text-align: center;\n  margin-left: 0.5em;\n}\n.title-refresh_hover {\n  background-color: @hover-bg;\n}\n.arrow {\n  display: inline-block;\n  width: 1em;\n  height: 1.5em;\n  text-align: center;\n  transition: transform 200ms ease;\n  margin-right: 0.25em;\n}\n.arrow_open {\n  transform: rotate(90deg);\n}\n\n.body {\n  padding: 0 5px;\n  overflow: hidden;\n}\n.body_collapsed {\n  height: 0;\n}\n","@import url('../common.wxss');\n\n@keyframes value-update-ani {\n  from {\n    background: @update-bg;\n  }\n  to {\n    background: transparent;\n  }\n}\n.updated {\n  background: @update-bg;\n  animation-duration: 1s;\n  animation-fill-mode: both;\n  animation-name: value-update-ani;\n  animation-timing-function: ease;\n}\n\n.wrapper {\n  display: inline-block;\n}\n\n.slice {\n  display: inline;\n  color: @common-text;\n}\n.slice_dynamic {\n  color: @attribute-value;\n}\n\n.var-name {\n  display: inline-block;\n  margin-left: 0.25em;\n  height: 1em;\n  line-height: 1em;\n  min-width: 1em;\n  text-align: center;\n  font-size: 0.8em;\n  font-style: italic;\n  color: @important-text;\n}\n.var-name_hover {\n  background: @hover-bg;\n}\n","@import url('../common.wxss');\n\n:host {\n  display: block;\n}\n\n.section {\n  margin-bottom: 5px;\n  color: @common-text;\n}\n.section-item {\n  white-space: nowrap;\n  user-select: text;\n}\n.section-key {\n  display: inline;\n  color: @property-name;\n}\n.section-key-core {\n  display: inline;\n  color: @core-attribute-name;\n}\n.section-value {\n  display: inline;\n  color: @attribute-value;\n}\n.section-value-extra {\n  color: @important-text;\n}\n\n.section-empty {\n  text-align: center;\n  font-style: italic;\n}\n\n.box-model {\n  margin: 0 auto;\n}\n.box-model-text {\n  flex: none;\n  text-align: center;\n  white-space: nowrap;\n  color: @important-text;\n  margin: 1px;\n}\n.box-model-content {\n  display: flex;\n  border: 1px solid #888;\n  padding: 1px;\n}\n.box-model-padding {\n  border: 1px solid #888;\n  padding: 1px;\n  background: @primary-bg;\n}\n.box-model-border {\n  border: 1px solid #888;\n  padding: 1px;\n  background: @secondary-bg;\n}\n.box-model-margin {\n  padding: 1px;\n}\n.box-model-line {\n  display: flex;\n  justify-content: center;\n  align-items: center;\n}\n\n.style-rule {\n  padding-left: 1em;\n  margin: 5px 0;\n}\n.style-rule_inactive {\n  text-decoration: line-through @important-text;\n}\n.style-rule-prefix {\n  margin-left: -1em;\n  font-style: italic;\n}\n.style-rule-title {\n  margin-left: -1em;\n  color: @important-text;\n}\n"],"names":[],"sourceRoot":""}*/
@@ -0,0 +1,11 @@
1
+ import type { protocol } from 'glass-easel-devtools-agent';
2
+ export { protocol } from 'glass-easel-devtools-agent';
3
+ export type PanelRecvMessage = protocol.AgentSendMessage;
4
+ export type PanelSendMessage = protocol.AgentRecvMessage;
5
+ export interface MessageChannel {
6
+ send(data: PanelSendMessage): void;
7
+ recv(listener: (data: PanelRecvMessage) => void): void;
8
+ }
9
+ export declare const setMessageChannel: (mc: MessageChannel) => void;
10
+ export declare const setEventHandler: <T extends keyof protocol.AgentEventKind>(name: T, handler: (detail: protocol.AgentEventKind[T]["detail"]) => void) => void;
11
+ export declare const sendRequest: <T extends keyof protocol.AgentRequestKind>(name: T, detail: protocol.AgentRequestKind[T]["request"]) => Promise<protocol.AgentRequestKind[T]["response"]>;
@@ -0,0 +1 @@
1
+ export {};
File without changes
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1 @@
1
+ export declare const componentDefinition: {};
@@ -0,0 +1,9 @@
1
+ import { type protocol } from 'glass-easel-devtools-agent';
2
+ export declare const store: {
3
+ selectedNodeId: protocol.NodeId;
4
+ highlightNodeId: protocol.NodeId;
5
+ sideBarShown: boolean;
6
+ selectNode(n: protocol.NodeId): void;
7
+ hideSideBar(): void;
8
+ setHighlightNode(n: protocol.NodeId): void;
9
+ };
@@ -0,0 +1 @@
1
+ export declare const compDef: {};
Binary file
@@ -0,0 +1,4 @@
1
+ export declare const DEV: boolean;
2
+ export declare const error: (msg: string, ...args: unknown[]) => void;
3
+ export declare const warn: (msg: string, ...args: unknown[]) => void;
4
+ export declare const debug: (msg: string, ...args: unknown[]) => void;
package/package.json ADDED
@@ -0,0 +1,21 @@
1
+ {
2
+ "name": "glass-easel-devtools-panel",
3
+ "version": "0.9.0",
4
+ "main": "dist/bootstrap.js",
5
+ "dependencies": {},
6
+ "devDependencies": {
7
+ "css-loader": "^7.1.2",
8
+ "glass-easel": "^0.9.0",
9
+ "glass-easel-miniprogram-adapter": "^0.9.0",
10
+ "glass-easel-miniprogram-webpack-plugin": "^0.9.0",
11
+ "less-loader": "^12.2.0",
12
+ "mini-css-extract-plugin": "^2.9.0",
13
+ "mobx-miniprogram": "^6.12.3",
14
+ "mobx-miniprogram-bindings": "^3.0.1",
15
+ "glass-easel-devtools-agent": "0.9.0"
16
+ },
17
+ "scripts": {
18
+ "build": "webpack --config webpack.config.js",
19
+ "dev": "webpack --config webpack.dev.config.js --watch"
20
+ }
21
+ }
package/src/app.ts ADDED
@@ -0,0 +1 @@
1
+ // this file is always executed on startup
package/src/app.wxss ADDED
@@ -0,0 +1 @@
1
+ /* this is the global stylesheet */
@@ -0,0 +1,80 @@
1
+ import { glassEasel, type Root } from 'glass-easel-miniprogram-adapter'
2
+ import { codeSpace, initWithBackend, registerGlobalEventListener } from '../src' // import the plugin-generated code
3
+ import { type MessageChannel, setMessageChannel } from './message_channel'
4
+ import { componentDefinition } from './pages/index'
5
+ import { warn } from './utils'
6
+ import { loadGlobalComponents } from './global_components'
7
+
8
+ export { MessageChannel, PanelRecvMessage, PanelSendMessage } from './message_channel'
9
+
10
+ let root: Root | null = null
11
+
12
+ const insertInto = (
13
+ backendContext: glassEasel.GeneralBackendContext,
14
+ backendElement: glassEasel.GeneralBackendElement,
15
+ ) => {
16
+ // create the backend context
17
+ registerGlobalEventListener(backendContext)
18
+ const ab = initWithBackend(backendContext)
19
+
20
+ // add global using components
21
+ loadGlobalComponents(codeSpace)
22
+
23
+ // create a mini-program page
24
+ root = ab.createRoot(
25
+ 'glass-easel-root', // the tag name of the mount point
26
+ codeSpace,
27
+ 'pages/index/index', // the mini-program page to load
28
+ )
29
+
30
+ // insert the page into backend
31
+ let placeholder: glassEasel.GeneralBackendElement
32
+ if (backendContext.mode === glassEasel.BackendMode.Composed) {
33
+ const ctx = backendContext
34
+ const parent = backendElement as glassEasel.composedBackend.Element
35
+ placeholder = ctx.createElement('glass-easel-devtools-panel', 'glass-easel-devtools-panel')
36
+ parent.appendChild(placeholder)
37
+ } else if (backendContext.mode === glassEasel.BackendMode.Domlike) {
38
+ const ctx = backendContext
39
+ const parent = backendElement as glassEasel.domlikeBackend.Element
40
+ placeholder = ctx.document.createElement('glass-easel-devtools-panel')
41
+ parent.appendChild(placeholder)
42
+ } else if (backendContext.mode === glassEasel.BackendMode.Shadow) {
43
+ const parent = backendElement as glassEasel.backend.Element
44
+ const sr = parent.getShadowRoot()
45
+ if (!sr) throw new Error('the host element should be inside of a shadow tree')
46
+ placeholder = sr.createElement('glass-easel-devtools-panel', 'glass-easel-devtools-panel')
47
+ parent.appendChild(placeholder)
48
+ } else {
49
+ throw new Error('unrecognized host backend mode')
50
+ }
51
+ root.attach(
52
+ backendElement as unknown as glassEasel.GeneralBackendElement,
53
+ placeholder as unknown as glassEasel.GeneralBackendElement,
54
+ )
55
+ if (
56
+ backendContext.mode === glassEasel.BackendMode.Composed ||
57
+ backendContext.mode === glassEasel.BackendMode.Shadow
58
+ ) {
59
+ const elem = placeholder as glassEasel.composedBackend.Element | glassEasel.backend.Element
60
+ elem.release()
61
+ }
62
+ }
63
+
64
+ export const startup = (
65
+ hostContext: glassEasel.GeneralBackendContext,
66
+ hostElement: glassEasel.GeneralBackendElement,
67
+ messageChannel: MessageChannel,
68
+ ) => {
69
+ setMessageChannel(messageChannel)
70
+ insertInto(hostContext, hostElement)
71
+ }
72
+
73
+ export const restart = () => {
74
+ if (!root) {
75
+ warn('cannot restart panel before startup')
76
+ return
77
+ }
78
+ const comp = root.get().asInstanceOf(componentDefinition)
79
+ comp?.restart()
80
+ }
package/src/events.ts ADDED
@@ -0,0 +1,97 @@
1
+ import { type builder } from 'glass-easel-miniprogram-adapter/dist/glass_easel_miniprogram_adapter'
2
+ import { type protocol, setEventHandler } from './message_channel'
3
+
4
+ export class EventDispatcher<
5
+ N extends string,
6
+ K extends string | number,
7
+ T extends { [k in N]: K },
8
+ > {
9
+ private keyName: N
10
+ private listeners = Object.create(null) as { [key: string | number]: ((args: T) => void)[] }
11
+
12
+ constructor(keyName: N) {
13
+ this.keyName = keyName
14
+ }
15
+
16
+ addListener(key: K, func: (args: T) => void) {
17
+ if (this.listeners[key]) this.listeners[key].push(func)
18
+ else this.listeners[key] = [func]
19
+ }
20
+
21
+ removeListener(key: K, func: (args: T) => void) {
22
+ if (this.listeners[key]) this.listeners[key] = this.listeners[key].filter((x) => x !== func)
23
+ }
24
+
25
+ bindComponentLifetimes(
26
+ ctx: builder.BuilderContext<any, any, any>,
27
+ getKey: () => K,
28
+ func: (args: T) => void,
29
+ ) {
30
+ const { lifetime } = ctx
31
+ lifetime('attached', () => {
32
+ this.addListener(getKey(), func)
33
+ })
34
+ lifetime('detached', () => {
35
+ this.removeListener(getKey(), func)
36
+ })
37
+ }
38
+
39
+ dispatch(args: T) {
40
+ const funcArr = this.listeners[args[this.keyName]]
41
+ funcArr?.forEach((f) => f(args))
42
+ }
43
+ }
44
+
45
+ export const childNodeCountUpdated = new EventDispatcher<
46
+ 'nodeId',
47
+ protocol.NodeId,
48
+ protocol.dom.ChildNodeCountUpdated['detail']
49
+ >('nodeId')
50
+ setEventHandler('DOM.childNodeCountUpdated', (args) => {
51
+ childNodeCountUpdated.dispatch(args)
52
+ })
53
+
54
+ export const setChildNodes = new EventDispatcher<
55
+ 'parentId',
56
+ protocol.NodeId,
57
+ protocol.dom.SetChildNodes['detail']
58
+ >('parentId')
59
+ setEventHandler('DOM.setChildNodes', (args) => {
60
+ setChildNodes.dispatch(args)
61
+ })
62
+
63
+ export const childNodeInserted = new EventDispatcher<
64
+ 'parentNodeId',
65
+ protocol.NodeId,
66
+ protocol.dom.ChildNodeInserted['detail']
67
+ >('parentNodeId')
68
+ setEventHandler('DOM.childNodeInserted', (args) => {
69
+ childNodeInserted.dispatch(args)
70
+ })
71
+
72
+ export const childNodeRemoved = new EventDispatcher<
73
+ 'parentNodeId',
74
+ protocol.NodeId,
75
+ protocol.dom.ChildNodeRemoved['detail']
76
+ >('parentNodeId')
77
+ setEventHandler('DOM.childNodeRemoved', (args) => {
78
+ childNodeRemoved.dispatch(args)
79
+ })
80
+
81
+ export const characterDataModified = new EventDispatcher<
82
+ 'nodeId',
83
+ protocol.NodeId,
84
+ protocol.dom.CharacterDataModified['detail']
85
+ >('nodeId')
86
+ setEventHandler('DOM.characterDataModified', (args) => {
87
+ characterDataModified.dispatch(args)
88
+ })
89
+
90
+ export const attributeModified = new EventDispatcher<
91
+ 'nodeId',
92
+ protocol.NodeId,
93
+ protocol.dom.AttributeModified['detail']
94
+ >('nodeId')
95
+ setEventHandler('DOM.attributeModified', (args) => {
96
+ attributeModified.dispatch(args)
97
+ })
@@ -0,0 +1,3 @@
1
+ {
2
+ "component": true
3
+ }
@@ -0,0 +1 @@
1
+ export const componentDefinition = Component().property('src', String).register()
@@ -0,0 +1 @@
1
+ <img src="{{ src }}" />
@@ -0,0 +1,3 @@
1
+ :host {
2
+ display: block;
3
+ }
@@ -0,0 +1,12 @@
1
+ import { type glassEasel, type CodeSpace } from 'glass-easel-miniprogram-adapter'
2
+ import * as view from './view/view'
3
+
4
+ const getCompDef = (def: unknown): glassEasel.GeneralComponentDefinition => {
5
+ const d = def as { _$: glassEasel.GeneralComponentDefinition }
6
+ return d._$
7
+ }
8
+
9
+ export const loadGlobalComponents = (codeSpace: CodeSpace) => {
10
+ const space = codeSpace.getComponentSpace()
11
+ space.setGlobalUsingComponent('view', getCompDef(view.componentDefinition))
12
+ }
@@ -0,0 +1,3 @@
1
+ {
2
+ "component": true
3
+ }
@@ -0,0 +1,40 @@
1
+ export const componentDefinition = Component()
2
+ .options({
3
+ virtualHost: true,
4
+ })
5
+ .externalClasses(['class', 'hover-class'])
6
+ .property('style', String)
7
+ .property('hidden', Boolean)
8
+ .data(() => ({
9
+ hover: false,
10
+ }))
11
+ .init(({ self, setData, listener }) => {
12
+ const hoverStart = listener((ev) => {
13
+ setData({ hover: true })
14
+ self.triggerEvent('mouseenter', ev.detail, {})
15
+ })
16
+ const hoverEnd = listener((ev) => {
17
+ setData({ hover: false })
18
+ self.triggerEvent('mouseleave', ev.detail, {})
19
+ })
20
+ const mousedown = listener((ev) => {
21
+ self.triggerEvent('mousedown', ev.detail, {})
22
+ })
23
+ const mousemove = listener((ev) => {
24
+ self.triggerEvent('mousemove', ev.detail, {})
25
+ })
26
+ const mouseup = listener((ev) => {
27
+ self.triggerEvent('mouseup', ev.detail, {})
28
+ })
29
+ const touchstart = listener((ev) => {
30
+ self.triggerEvent('touchstart', ev.detail, {})
31
+ })
32
+ const touchmove = listener((ev) => {
33
+ self.triggerEvent('touchmove', ev.detail, {})
34
+ })
35
+ const touchend = listener((ev) => {
36
+ self.triggerEvent('touchend', ev.detail, {})
37
+ })
38
+ return { hoverStart, hoverEnd, mousedown, mousemove, mouseup, touchstart, touchmove, touchend }
39
+ })
40
+ .register()
@@ -0,0 +1,14 @@
1
+ <div
2
+ class="class {{ hover ? 'hover-class' : '' }}"
3
+ style="{{ hidden ? 'display: none;' : '' }}{{ style }}"
4
+ bind:mouseenter="hoverStart"
5
+ bind:mouseleave="hoverEnd"
6
+ bind:mousedown="mousedown"
7
+ bind:mousemove="mousemove"
8
+ bind:mouseup="mouseup"
9
+ bind:touchstart="touchstart"
10
+ bind:touchmove="touchmove"
11
+ bind:touchend="touchend"
12
+ >
13
+ <slot/>
14
+ </div>
File without changes
@@ -0,0 +1,70 @@
1
+ import type { protocol } from 'glass-easel-devtools-agent'
2
+ import { error, warn, debug } from './utils'
3
+
4
+ export { protocol } from 'glass-easel-devtools-agent'
5
+
6
+ export type PanelRecvMessage = protocol.AgentSendMessage
7
+ export type PanelSendMessage = protocol.AgentRecvMessage
8
+
9
+ export interface MessageChannel {
10
+ send(data: PanelSendMessage): void
11
+ recv(listener: (data: PanelRecvMessage) => void): void
12
+ }
13
+
14
+ let messageChannel: MessageChannel | null = null
15
+ const eventHandlers = Object.create(null) as Record<string, (data: any) => void>
16
+ const requestCallbacks = Object.create(null) as Record<number, (data: any) => void>
17
+ let requestIdInc = 1
18
+
19
+ export const setMessageChannel = (mc: MessageChannel) => {
20
+ messageChannel = mc
21
+ messageChannel.recv((data) => {
22
+ if (data.kind === 'event') {
23
+ const handler = eventHandlers[data.name]
24
+ if (!handler) {
25
+ warn(`missing event handler for ${data.name}`)
26
+ } else {
27
+ debug(`recv event`, data.name, data.detail)
28
+ handler(data.detail)
29
+ }
30
+ } else if (data.kind === 'response') {
31
+ const requestId = data.id
32
+ const callback = requestCallbacks[requestId]
33
+ if (!callback) {
34
+ warn(`illegal response for request ${requestId}`)
35
+ } else {
36
+ delete requestCallbacks[requestId]
37
+ debug(`recv response ${requestId}`, data.detail)
38
+ callback(data.detail)
39
+ }
40
+ } else if (data.kind === 'error') {
41
+ const requestId = data.id
42
+ const callback = requestCallbacks[requestId]
43
+ if (!callback) {
44
+ warn(`illegal error response for request ${requestId}`)
45
+ } else {
46
+ error(`request error for request ${requestId}: ${data.message || '(unknown)'}`, data.stack)
47
+ }
48
+ }
49
+ })
50
+ }
51
+
52
+ export const setEventHandler = <T extends keyof protocol.AgentEventKind>(
53
+ name: T,
54
+ handler: (detail: protocol.AgentEventKind[T]['detail']) => void,
55
+ ) => {
56
+ eventHandlers[name] = handler
57
+ }
58
+
59
+ export const sendRequest = <T extends keyof protocol.AgentRequestKind>(
60
+ name: T,
61
+ detail: protocol.AgentRequestKind[T]['request'],
62
+ ): Promise<protocol.AgentRequestKind[T]['response']> => {
63
+ const requestId = requestIdInc
64
+ requestIdInc += 1
65
+ return new Promise((resolve): void => {
66
+ requestCallbacks[requestId] = resolve
67
+ debug(`send request ${requestId}`, name, detail)
68
+ messageChannel?.send({ kind: 'request', id: requestId, name, detail })
69
+ })
70
+ }
@@ -0,0 +1,12 @@
1
+ @common-text: #888;
2
+ @important-text: #222;
3
+ @primary-bg: #eee;
4
+ @secondary-bg: #ccc;
5
+ @selected-bg: #add;
6
+ @hover-bg: #ace;
7
+ @update-bg: #dd8;
8
+
9
+ @tag-name: #408;
10
+ @core-attribute-name: #084;
11
+ @property-name: #06a;
12
+ @attribute-value: #840;
@@ -0,0 +1,7 @@
1
+ {
2
+ "component": true,
3
+ "usingComponents": {
4
+ "value": "./value",
5
+ "detail-section": "./section"
6
+ }
7
+ }