@things-factory/board-ui 9.0.0-beta.9 → 9.0.2

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 (147) hide show
  1. package/dist-client/apptools/favorite-tool.js +12 -12
  2. package/dist-client/apptools/favorite-tool.js.map +1 -1
  3. package/dist-client/board-list/board-tile-list.js +97 -98
  4. package/dist-client/board-list/board-tile-list.js.map +1 -1
  5. package/dist-client/board-list/group-bar-styles.js +1 -0
  6. package/dist-client/board-list/group-bar-styles.js.map +1 -1
  7. package/dist-client/board-list/group-bar.d.ts +2 -0
  8. package/dist-client/board-list/group-bar.js +33 -5
  9. package/dist-client/board-list/group-bar.js.map +1 -1
  10. package/dist-client/board-list/play-group-bar.js +2 -2
  11. package/dist-client/board-list/play-group-bar.js.map +1 -1
  12. package/dist-client/board-provider.js +1 -6
  13. package/dist-client/board-provider.js.map +1 -1
  14. package/dist-client/bootstrap.js +4 -4
  15. package/dist-client/bootstrap.js.map +1 -1
  16. package/dist-client/data-grist/board-editor.d.ts +1 -1
  17. package/dist-client/data-grist/board-editor.js +39 -37
  18. package/dist-client/data-grist/board-editor.js.map +1 -1
  19. package/dist-client/data-grist/board-renderer.js +55 -46
  20. package/dist-client/data-grist/board-renderer.js.map +1 -1
  21. package/dist-client/data-grist/color-map-editor.js +7 -3
  22. package/dist-client/data-grist/color-map-editor.js.map +1 -1
  23. package/dist-client/data-grist/color-ranges-editor.js +7 -3
  24. package/dist-client/data-grist/color-ranges-editor.js.map +1 -1
  25. package/dist-client/entries/headless-scene-components.d.ts +1 -0
  26. package/dist-client/entries/headless-scene-components.js +4 -0
  27. package/dist-client/entries/headless-scene-components.js.map +1 -0
  28. package/dist-client/entries/scene-player.d.ts +5 -0
  29. package/dist-client/entries/scene-player.js +84 -0
  30. package/dist-client/entries/scene-player.js.map +1 -0
  31. package/dist-client/entries/scene-viewer.d.ts +5 -0
  32. package/dist-client/entries/scene-viewer.js +85 -0
  33. package/dist-client/entries/scene-viewer.js.map +1 -0
  34. package/dist-client/entries/things-scene-components.import +1 -0
  35. package/dist-client/graphql/board.js +9 -2
  36. package/dist-client/graphql/board.js.map +1 -1
  37. package/dist-client/graphql/index.d.ts +6 -6
  38. package/dist-client/graphql/index.js +6 -6
  39. package/dist-client/graphql/index.js.map +1 -1
  40. package/dist-client/index.d.ts +8 -8
  41. package/dist-client/index.js +8 -8
  42. package/dist-client/index.js.map +1 -1
  43. package/dist-client/pages/attachment-list-page.js +8 -9
  44. package/dist-client/pages/attachment-list-page.js.map +1 -1
  45. package/dist-client/pages/board-list-page.d.ts +12 -24
  46. package/dist-client/pages/board-list-page.js +49 -31
  47. package/dist-client/pages/board-list-page.js.map +1 -1
  48. package/dist-client/pages/board-modeller-page.js +36 -35
  49. package/dist-client/pages/board-modeller-page.js.map +1 -1
  50. package/dist-client/pages/board-player-by-name-page.d.ts +3 -2
  51. package/dist-client/pages/board-player-by-name-page.js +1 -1
  52. package/dist-client/pages/board-player-by-name-page.js.map +1 -1
  53. package/dist-client/pages/board-player-page.d.ts +2 -1
  54. package/dist-client/pages/board-player-page.js +41 -43
  55. package/dist-client/pages/board-player-page.js.map +1 -1
  56. package/dist-client/pages/board-template/board-template-list-page.d.ts +3 -1
  57. package/dist-client/pages/board-template/board-template-list-page.js +57 -29
  58. package/dist-client/pages/board-template/board-template-list-page.js.map +1 -1
  59. package/dist-client/pages/board-viewer-by-name-page.d.ts +3 -2
  60. package/dist-client/pages/board-viewer-by-name-page.js +1 -1
  61. package/dist-client/pages/board-viewer-by-name-page.js.map +1 -1
  62. package/dist-client/pages/board-viewer-page.d.ts +2 -1
  63. package/dist-client/pages/board-viewer-page.js +48 -47
  64. package/dist-client/pages/board-viewer-page.js.map +1 -1
  65. package/dist-client/pages/font-list-page.js +11 -11
  66. package/dist-client/pages/font-list-page.js.map +1 -1
  67. package/dist-client/pages/play-list-page.d.ts +3 -3
  68. package/dist-client/pages/play-list-page.js +27 -27
  69. package/dist-client/pages/play-list-page.js.map +1 -1
  70. package/dist-client/pages/printable-board-viewer-page.d.ts +1 -1
  71. package/dist-client/pages/printable-board-viewer-page.js +14 -6
  72. package/dist-client/pages/printable-board-viewer-page.js.map +1 -1
  73. package/dist-client/pages/theme/theme-editors.js +1 -1
  74. package/dist-client/pages/theme/theme-editors.js.map +1 -1
  75. package/dist-client/pages/theme/theme-list-page.js +36 -29
  76. package/dist-client/pages/theme/theme-list-page.js.map +1 -1
  77. package/dist-client/setting-let/board-view-setting-let.js +15 -17
  78. package/dist-client/setting-let/board-view-setting-let.js.map +1 -1
  79. package/dist-client/tsconfig.tsbuildinfo +1 -1
  80. package/dist-client/viewparts/board-basic-info.d.ts +1 -0
  81. package/dist-client/viewparts/board-basic-info.js +173 -133
  82. package/dist-client/viewparts/board-basic-info.js.map +1 -1
  83. package/dist-client/viewparts/board-info-link.js +15 -16
  84. package/dist-client/viewparts/board-info-link.js.map +1 -1
  85. package/dist-client/viewparts/board-info.d.ts +4 -3
  86. package/dist-client/viewparts/board-info.js +31 -28
  87. package/dist-client/viewparts/board-info.js.map +1 -1
  88. package/dist-client/viewparts/board-template-builder.js +61 -62
  89. package/dist-client/viewparts/board-template-builder.js.map +1 -1
  90. package/dist-client/viewparts/board-template-info.d.ts +22 -0
  91. package/dist-client/viewparts/board-template-info.js +248 -0
  92. package/dist-client/viewparts/board-template-info.js.map +1 -0
  93. package/dist-client/viewparts/board-versions.js +77 -69
  94. package/dist-client/viewparts/board-versions.js.map +1 -1
  95. package/dist-client/viewparts/group-info-basic.js +103 -103
  96. package/dist-client/viewparts/group-info-basic.js.map +1 -1
  97. package/dist-client/viewparts/group-info-import.js +54 -54
  98. package/dist-client/viewparts/group-info-import.js.map +1 -1
  99. package/dist-client/viewparts/group-info.d.ts +2 -2
  100. package/dist-client/viewparts/group-info.js +25 -25
  101. package/dist-client/viewparts/group-info.js.map +1 -1
  102. package/dist-client/viewparts/index.d.ts +3 -3
  103. package/dist-client/viewparts/index.js +3 -3
  104. package/dist-client/viewparts/index.js.map +1 -1
  105. package/dist-client/viewparts/link-builder.js +77 -79
  106. package/dist-client/viewparts/link-builder.js.map +1 -1
  107. package/dist-client/viewparts/play-group-info-basic.js +105 -105
  108. package/dist-client/viewparts/play-group-info-basic.js.map +1 -1
  109. package/dist-client/viewparts/play-group-info-link.js +13 -14
  110. package/dist-client/viewparts/play-group-info-link.js.map +1 -1
  111. package/dist-client/viewparts/play-group-info.d.ts +2 -2
  112. package/dist-client/viewparts/play-group-info.js +23 -24
  113. package/dist-client/viewparts/play-group-info.js.map +1 -1
  114. package/dist-server/tsconfig.tsbuildinfo +1 -1
  115. package/helps/board-modeller/effects/hover-event.ko.md +3 -3
  116. package/helps/board-modeller/effects/hover-event.md +6 -4
  117. package/helps/board-modeller/effects/hover-event.zh.md +3 -3
  118. package/package.json +20 -19
  119. package/things-factory.config.js +12 -48
  120. package/translations/en.json +25 -3
  121. package/translations/ja.json +24 -2
  122. package/translations/ko.json +24 -2
  123. package/translations/ms.json +13 -6
  124. package/translations/zh.json +24 -2
  125. package/assets/images/bg-blue.png +0 -0
  126. package/assets/images/bg-green.png +0 -0
  127. package/assets/images/bg-input-select.png +0 -0
  128. package/assets/images/bg-rail.png +0 -0
  129. package/assets/images/forklift.png +0 -0
  130. package/assets/images/icon-backinfo.png +0 -0
  131. package/assets/images/icon-brand.png +0 -0
  132. package/assets/images/icon-close.png +0 -0
  133. package/assets/images/icon-editor-gradient-direction.png +0 -0
  134. package/assets/images/icon-mobile-brand.png +0 -0
  135. package/assets/images/icon-nametag.png +0 -0
  136. package/assets/images/icon-properties-label.png +0 -0
  137. package/assets/images/icon-properties-line-type.png +0 -0
  138. package/assets/images/icon-properties-table.png +0 -0
  139. package/assets/images/icon-resource-select.png +0 -0
  140. package/assets/images/person.png +0 -0
  141. package/assets/images/profile.png +0 -0
  142. package/images/icon-properties-arrow-type.png +0 -0
  143. package/images/icon-properties-gradient-direction.png +0 -0
  144. package/images/icon-properties-line-type.png +0 -0
  145. package/images/icon-properties-padding.png +0 -0
  146. package/images/icon-properties-table.png +0 -0
  147. package/images/icon-shell-inspector.png +0 -0
@@ -1,24 +1,55 @@
1
1
  import { __decorate, __metadata } from "tslib";
2
2
  import '@operato/board/ox-board-selector.js';
3
- import './board-renderer';
3
+ import './board-renderer.js';
4
4
  import { css, html } from 'lit';
5
5
  import { customElement, property } from 'lit/decorators.js';
6
6
  import { OxGristEditor } from '@operato/data-grist';
7
7
  import { i18next } from '@operato/i18n';
8
8
  import { openPopup } from '@operato/layout';
9
9
  let BoardEditor = class BoardEditor extends OxGristEditor {
10
+ static { this.styles = [
11
+ css `
12
+ :host {
13
+ display: flex;
14
+ flex-flow: row nowrap;
15
+ align-items: center;
16
+
17
+ box-sizing: border-box;
18
+
19
+ width: 100%;
20
+ height: 100%;
21
+
22
+ border: 0;
23
+ background-color: transparent;
24
+
25
+ font: var(--grist-object-editor-font);
26
+ color: var(--grist-object-editor-color);
27
+
28
+ justify-content: inherit;
29
+ }
30
+
31
+ board-renderer {
32
+ display: flex;
33
+ flex: auto;
34
+
35
+ justify-content: inherit;
36
+ }
37
+ `
38
+ ]; }
10
39
  render() {
11
40
  var { boardViewerPage } = this.column.record.options || {};
12
- return html ` <board-renderer .value=${this.value} .boardViewerPage=${boardViewerPage}></board-renderer> `;
41
+ return html `
42
+ <board-renderer
43
+ .value=${this.value}
44
+ .boardViewerPage=${boardViewerPage}
45
+ @click=${this.openSelector}
46
+ ></board-renderer>
47
+ `;
13
48
  }
14
49
  async firstUpdated() {
15
50
  this.value = this.record[this.column.name];
16
- await this.updateComplete;
17
- this.renderRoot.addEventListener('click', e => {
18
- e.stopPropagation();
19
- this.openSelector();
20
- });
21
- this.openSelector();
51
+ // await this.updateComplete
52
+ // this.openSelector()
22
53
  }
23
54
  openSelector() {
24
55
  if (this.popup) {
@@ -58,35 +89,6 @@ let BoardEditor = class BoardEditor extends OxGristEditor {
58
89
  });
59
90
  }
60
91
  };
61
- BoardEditor.styles = [
62
- css `
63
- :host {
64
- display: flex;
65
- flex-flow: row nowrap;
66
- align-items: center;
67
-
68
- box-sizing: border-box;
69
-
70
- width: 100%;
71
- height: 100%;
72
-
73
- border: 0;
74
- background-color: transparent;
75
-
76
- font: var(--grist-object-editor-font);
77
- color: var(--grist-object-editor-color);
78
-
79
- justify-content: inherit;
80
- }
81
-
82
- board-renderer {
83
- display: flex;
84
- flex: auto;
85
-
86
- justify-content: inherit;
87
- }
88
- `
89
- ];
90
92
  __decorate([
91
93
  property({ type: Object }),
92
94
  __metadata("design:type", Object)
@@ -1 +1 @@
1
- {"version":3,"file":"board-editor.js","sourceRoot":"","sources":["../../client/data-grist/board-editor.ts"],"names":[],"mappings":"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","sourcesContent":["import '@operato/board/ox-board-selector.js'\nimport './board-renderer'\n\nimport { css, html } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\n\nimport { OxGristEditor } from '@operato/data-grist'\nimport { i18next } from '@operato/i18n'\nimport { openPopup } from '@operato/layout'\n\n@customElement('board-editor')\nexport class BoardEditor extends OxGristEditor {\n static styles = [\n css`\n :host {\n display: flex;\n flex-flow: row nowrap;\n align-items: center;\n\n box-sizing: border-box;\n\n width: 100%;\n height: 100%;\n\n border: 0;\n background-color: transparent;\n\n font: var(--grist-object-editor-font);\n color: var(--grist-object-editor-color);\n\n justify-content: inherit;\n }\n\n board-renderer {\n display: flex;\n flex: auto;\n\n justify-content: inherit;\n }\n `\n ]\n\n @property({ type: Object }) value: any\n @property({ type: Object }) column: any\n @property({ type: Object }) record: any\n @property({ type: Number }) row?: number\n\n popup\n\n render() {\n var { boardViewerPage } = this.column.record.options || {}\n return html` <board-renderer .value=${this.value} .boardViewerPage=${boardViewerPage}></board-renderer> `\n }\n\n async firstUpdated() {\n this.value = this.record[this.column.name]\n\n await this.updateComplete\n\n this.renderRoot.addEventListener('click', e => {\n e.stopPropagation()\n\n this.openSelector()\n })\n\n this.openSelector()\n }\n\n openSelector() {\n if (this.popup) {\n delete this.popup\n }\n\n /*\n * 기존 설정된 보드가 선택된 상태가 되게 하기 위해서는 selector에 value를 전달해줄 필요가 있음.\n * 주의. value는 object일 수도 있고, string일 수도 있다.\n * string인 경우에는 해당 보드의 id로 해석한다.\n */\n var value = this.value || {}\n\n var template = html`\n <ox-board-selector\n .creatable=${true}\n .value=${this.value}\n @board-selected=${async e => {\n var board = e.detail.board\n\n this.dispatchEvent(\n new CustomEvent('field-change', {\n bubbles: true,\n composed: true,\n detail: {\n before: this.value,\n after: this.column.type == 'board' ? board : board.id || '',\n record: this.record,\n column: this.column,\n row: this.row\n }\n })\n )\n\n this.popup && this.popup.close()\n }}\n ></ox-board-selector>\n `\n\n this.popup = openPopup(template, {\n backdrop: true,\n size: 'large',\n title: i18next.t('title.select board')\n })\n }\n}\n"]}
1
+ {"version":3,"file":"board-editor.js","sourceRoot":"","sources":["../../client/data-grist/board-editor.ts"],"names":[],"mappings":";AAAA,OAAO,qCAAqC,CAAA;AAC5C,OAAO,qBAAqB,CAAA;AAE5B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAA;AAC/B,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAS,MAAM,mBAAmB,CAAA;AAElE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAA;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AACvC,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAA;AAGpC,IAAM,WAAW,GAAjB,MAAM,WAAY,SAAQ,aAAa;aACrC,WAAM,GAAG;QACd,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;KA0BF;KACF,AA5BY,CA4BZ;IASD,MAAM;QACJ,IAAI,EAAE,eAAe,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,IAAI,EAAE,CAAA;QAC1D,OAAO,IAAI,CAAA;;iBAEE,IAAI,CAAC,KAAK;2BACA,eAAe;iBACzB,IAAI,CAAC,YAAY;;KAE7B,CAAA;IACH,CAAC;IAED,KAAK,CAAC,YAAY;QAChB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;QAE1C,4BAA4B;QAE5B,sBAAsB;IACxB,CAAC;IAED,YAAY;QACV,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YACf,OAAO,IAAI,CAAC,KAAK,CAAA;QACnB,CAAC;QAED;;;;WAIG;QACH,IAAI,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,EAAE,CAAA;QAE5B,IAAI,QAAQ,GAAG,IAAI,CAAA;;qBAEF,IAAI;iBACR,IAAI,CAAC,KAAK;0BACD,KAAK,EAAC,CAAC,EAAC,EAAE;YAC1B,IAAI,KAAK,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAA;YAE1B,IAAI,CAAC,aAAa,CAChB,IAAI,WAAW,CAAC,cAAc,EAAE;gBAC9B,OAAO,EAAE,IAAI;gBACb,QAAQ,EAAE,IAAI;gBACd,MAAM,EAAE;oBACN,MAAM,EAAE,IAAI,CAAC,KAAK;oBAClB,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE;oBAC3D,MAAM,EAAE,IAAI,CAAC,MAAM;oBACnB,MAAM,EAAE,IAAI,CAAC,MAAM;oBACnB,GAAG,EAAE,IAAI,CAAC,GAAG;iBACd;aACF,CAAC,CACH,CAAA;YAED,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAA;QAClC,CAAC;;KAEJ,CAAA;QAED,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC,QAAQ,EAAE;YAC/B,QAAQ,EAAE,IAAI;YACd,IAAI,EAAE,OAAO;YACb,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,oBAAoB,CAAC;SACvC,CAAC,CAAA;IACJ,CAAC;;AArE2B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;0CAAW;AACV;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;2CAAY;AACX;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;2CAAY;AACX;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;wCAAa;AAlC7B,WAAW;IADvB,aAAa,CAAC,cAAc,CAAC;GACjB,WAAW,CAqGvB","sourcesContent":["import '@operato/board/ox-board-selector.js'\nimport './board-renderer.js'\n\nimport { css, html } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\n\nimport { OxGristEditor } from '@operato/data-grist'\nimport { i18next } from '@operato/i18n'\nimport { openPopup } from '@operato/layout'\n\n@customElement('board-editor')\nexport class BoardEditor extends OxGristEditor {\n static styles = [\n css`\n :host {\n display: flex;\n flex-flow: row nowrap;\n align-items: center;\n\n box-sizing: border-box;\n\n width: 100%;\n height: 100%;\n\n border: 0;\n background-color: transparent;\n\n font: var(--grist-object-editor-font);\n color: var(--grist-object-editor-color);\n\n justify-content: inherit;\n }\n\n board-renderer {\n display: flex;\n flex: auto;\n\n justify-content: inherit;\n }\n `\n ]\n\n @property({ type: Object }) value: any\n @property({ type: Object }) column: any\n @property({ type: Object }) record: any\n @property({ type: Number }) row?: number\n\n popup\n\n render() {\n var { boardViewerPage } = this.column.record.options || {}\n return html`\n <board-renderer\n .value=${this.value}\n .boardViewerPage=${boardViewerPage}\n @click=${this.openSelector}\n ></board-renderer>\n `\n }\n\n async firstUpdated() {\n this.value = this.record[this.column.name]\n\n // await this.updateComplete\n\n // this.openSelector()\n }\n\n openSelector() {\n if (this.popup) {\n delete this.popup\n }\n\n /*\n * 기존 설정된 보드가 선택된 상태가 되게 하기 위해서는 selector에 value를 전달해줄 필요가 있음.\n * 주의. value는 object일 수도 있고, string일 수도 있다.\n * string인 경우에는 해당 보드의 id로 해석한다.\n */\n var value = this.value || {}\n\n var template = html`\n <ox-board-selector\n .creatable=${true}\n .value=${this.value}\n @board-selected=${async e => {\n var board = e.detail.board\n\n this.dispatchEvent(\n new CustomEvent('field-change', {\n bubbles: true,\n composed: true,\n detail: {\n before: this.value,\n after: this.column.type == 'board' ? board : board.id || '',\n record: this.record,\n column: this.column,\n row: this.row\n }\n })\n )\n\n this.popup && this.popup.close()\n }}\n ></ox-board-selector>\n `\n\n this.popup = openPopup(template, {\n backdrop: true,\n size: 'large',\n title: i18next.t('title.select board')\n })\n }\n}\n"]}
@@ -18,51 +18,8 @@ const FETCH_BOARD_GQL = id => {
18
18
  `;
19
19
  };
20
20
  let BoardRendererElement = class BoardRendererElement extends LitElement {
21
- async updated(changes) {
22
- if (changes.has('value')) {
23
- if (typeof this.value == 'string' && this.value) {
24
- /* fetchBoard..., */
25
- try {
26
- var response = await client.query({
27
- query: FETCH_BOARD_GQL(this.value),
28
- context: gqlContext()
29
- });
30
- this._value = (response && response.data && response.data.board) || {};
31
- }
32
- catch (e) {
33
- console.error(e);
34
- }
35
- }
36
- else {
37
- this._value = this.value || {};
38
- }
39
- }
40
- }
41
- render() {
42
- var { id, name = '', thumbnail = 'image/gif' } = this._value || {};
43
- return id
44
- ? html `
45
- <span>${name}</span>
46
- <img src=${thumbnail} alt="no thumbnail!" />
47
- <md-icon view @mousedown=${e => this.onClickViewer(e, id)}>search</md-icon>
48
- <md-icon edit @mousedown=${e => this.onClickModeler(e, id)}>edit</md-icon>
49
- `
50
- : html ` choose board.. `;
51
- }
52
- onClickViewer(e, id) {
53
- e.preventDefault();
54
- e.stopPropagation();
55
- var boardViewerPage = this.boardViewerPage || 'board-viewer';
56
- navigate(`${boardViewerPage}/${id}${window.location.search}`);
57
- }
58
- onClickModeler(e, id) {
59
- e.preventDefault();
60
- e.stopPropagation();
61
- navigate(`board-modeller/${id}${window.location.search}`);
62
- }
63
- };
64
- BoardRendererElement.styles = [
65
- css `
21
+ static { this.styles = [
22
+ css `
66
23
  :host {
67
24
  display: flex;
68
25
  justify-content: center;
@@ -99,18 +56,70 @@ BoardRendererElement.styles = [
99
56
  height: var(--board-renderer-icon-size);
100
57
  font: var(--board-renderer-font);
101
58
  }
59
+
60
+ md-icon:hover {
61
+ background-color: var(--md-sys-color-secondary-container);
62
+ color: var(--md-sys-color-on-secondary-container);
63
+ cursor: pointer;
64
+ }
65
+
102
66
  md-icon[edit] {
103
67
  right: 0;
104
68
 
105
69
  border-bottom-left-radius: var(--board-renderer-icon-border-radius);
106
70
  }
71
+
107
72
  md-icon[view] {
108
73
  left: 0;
109
74
 
110
75
  border-bottom-right-radius: var(--board-renderer-icon-border-radius);
111
76
  }
112
77
  `
113
- ];
78
+ ]; }
79
+ async updated(changes) {
80
+ if (changes.has('value')) {
81
+ if (typeof this.value == 'string' && this.value) {
82
+ /* fetchBoard..., */
83
+ try {
84
+ var response = await client.query({
85
+ query: FETCH_BOARD_GQL(this.value),
86
+ context: gqlContext()
87
+ });
88
+ this._value = (response && response.data && response.data.board) || {};
89
+ }
90
+ catch (e) {
91
+ console.error(e);
92
+ }
93
+ }
94
+ else {
95
+ this._value = this.value || {};
96
+ }
97
+ }
98
+ }
99
+ render() {
100
+ var { id, name = '', thumbnail = 'image/gif' } = this._value || {};
101
+ return id
102
+ ? html `
103
+ <span>${name}</span>
104
+ <img src=${thumbnail} alt="no thumbnail!" />
105
+
106
+ <md-icon view @click=${e => this.onClickViewer(e, id)}>search</md-icon>
107
+ <md-icon edit @click=${e => this.onClickModeler(e, id)}>edit</md-icon>
108
+ `
109
+ : html ` choose board.. `;
110
+ }
111
+ onClickViewer(e, id) {
112
+ e.preventDefault();
113
+ e.stopPropagation();
114
+ var boardViewerPage = this.boardViewerPage || 'board-viewer';
115
+ navigate(`${boardViewerPage}/${id}${window.location.search}`);
116
+ }
117
+ onClickModeler(e, id) {
118
+ e.preventDefault();
119
+ e.stopPropagation();
120
+ navigate(`board-modeller/${id}${window.location.search}`);
121
+ }
122
+ };
114
123
  __decorate([
115
124
  property({ type: Object }),
116
125
  __metadata("design:type", Object)
@@ -1 +1 @@
1
- {"version":3,"file":"board-renderer.js","sourceRoot":"","sources":["../../client/data-grist/board-renderer.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\n\nimport gql from 'graphql-tag'\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\n\nimport { navigate } from '@operato/shell'\nimport { client, gqlContext } from '@operato/graphql'\n\nconst FETCH_BOARD_GQL = id => {\n return gql`\n {\n board(id:\"${id}\") {\n id\n name\n description\n thumbnail\n }\n }\n`\n}\n\n@customElement('board-renderer')\nclass BoardRendererElement extends LitElement {\n static styles = [\n css`\n :host {\n display: flex;\n justify-content: center;\n position: relative;\n\n max-width: var(--board-renderer-max-width);\n border: var(--board-renderer-border);\n\n width: 100%;\n }\n span {\n position: absolute;\n bottom: 0;\n width: 100%;\n text-indent: 5px;\n\n font: var(--board-renderer-name-font);\n color: var(--md-sys-color-on-primary);\n background-color: var(--md-sys-color-primary);\n }\n img {\n object-fit: contain;\n max-width: 100%;\n max-height: 100%;\n }\n md-icon {\n position: absolute;\n top: 0;\n text-align: center;\n color: var(--md-sys-color-on-primary);\n background-color: var(--md-sys-color-primary);\n\n width: var(--board-renderer-icon-size);\n height: var(--board-renderer-icon-size);\n font: var(--board-renderer-font);\n }\n md-icon[edit] {\n right: 0;\n\n border-bottom-left-radius: var(--board-renderer-icon-border-radius);\n }\n md-icon[view] {\n left: 0;\n\n border-bottom-right-radius: var(--board-renderer-icon-border-radius);\n }\n `\n ]\n\n @property({ type: Object }) value: any\n @property({ type: String }) boardViewerPage?: string\n @property({ type: Object }) _value: any\n\n async updated(changes) {\n if (changes.has('value')) {\n if (typeof this.value == 'string' && this.value) {\n /* fetchBoard..., */\n try {\n var response = await client.query({\n query: FETCH_BOARD_GQL(this.value),\n context: gqlContext()\n })\n\n this._value = (response && response.data && response.data.board) || {}\n } catch (e) {\n console.error(e)\n }\n } else {\n this._value = this.value || {}\n }\n }\n }\n\n render() {\n var { id, name = '', thumbnail = 'image/gif' } = this._value || {}\n\n return id\n ? html`\n <span>${name}</span>\n <img src=${thumbnail} alt=\"no thumbnail!\" />\n <md-icon view @mousedown=${e => this.onClickViewer(e, id)}>search</md-icon>\n <md-icon edit @mousedown=${e => this.onClickModeler(e, id)}>edit</md-icon>\n `\n : html` choose board.. `\n }\n\n onClickViewer(e, id) {\n e.preventDefault()\n e.stopPropagation()\n\n var boardViewerPage = this.boardViewerPage || 'board-viewer'\n\n navigate(`${boardViewerPage}/${id}${window.location.search}`)\n }\n\n onClickModeler(e, id) {\n e.preventDefault()\n e.stopPropagation()\n\n navigate(`board-modeller/${id}${window.location.search}`)\n }\n}\n\nexport const BoardRenderer = (value, column, record) => {\n var { boardViewerPage = '' } = column.record.options || {}\n\n return html` <board-renderer .value=${value} .boardViewerPage=${boardViewerPage}></board-renderer> `\n}\n"]}
1
+ {"version":3,"file":"board-renderer.js","sourceRoot":"","sources":["../../client/data-grist/board-renderer.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\n\nimport gql from 'graphql-tag'\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\n\nimport { navigate } from '@operato/shell'\nimport { client, gqlContext } from '@operato/graphql'\n\nconst FETCH_BOARD_GQL = id => {\n return gql`\n {\n board(id:\"${id}\") {\n id\n name\n description\n thumbnail\n }\n }\n`\n}\n\n@customElement('board-renderer')\nclass BoardRendererElement extends LitElement {\n static styles = [\n css`\n :host {\n display: flex;\n justify-content: center;\n position: relative;\n\n max-width: var(--board-renderer-max-width);\n border: var(--board-renderer-border);\n\n width: 100%;\n }\n span {\n position: absolute;\n bottom: 0;\n width: 100%;\n text-indent: 5px;\n\n font: var(--board-renderer-name-font);\n color: var(--md-sys-color-on-primary);\n background-color: var(--md-sys-color-primary);\n }\n img {\n object-fit: contain;\n max-width: 100%;\n max-height: 100%;\n }\n md-icon {\n position: absolute;\n top: 0;\n text-align: center;\n color: var(--md-sys-color-on-primary);\n background-color: var(--md-sys-color-primary);\n\n width: var(--board-renderer-icon-size);\n height: var(--board-renderer-icon-size);\n font: var(--board-renderer-font);\n }\n\n md-icon:hover {\n background-color: var(--md-sys-color-secondary-container);\n color: var(--md-sys-color-on-secondary-container);\n cursor: pointer;\n }\n\n md-icon[edit] {\n right: 0;\n\n border-bottom-left-radius: var(--board-renderer-icon-border-radius);\n }\n\n md-icon[view] {\n left: 0;\n\n border-bottom-right-radius: var(--board-renderer-icon-border-radius);\n }\n `\n ]\n\n @property({ type: Object }) value: any\n @property({ type: String }) boardViewerPage?: string\n @property({ type: Object }) _value: any\n\n async updated(changes) {\n if (changes.has('value')) {\n if (typeof this.value == 'string' && this.value) {\n /* fetchBoard..., */\n try {\n var response = await client.query({\n query: FETCH_BOARD_GQL(this.value),\n context: gqlContext()\n })\n\n this._value = (response && response.data && response.data.board) || {}\n } catch (e) {\n console.error(e)\n }\n } else {\n this._value = this.value || {}\n }\n }\n }\n\n render() {\n var { id, name = '', thumbnail = 'image/gif' } = this._value || {}\n\n return id\n ? html`\n <span>${name}</span>\n <img src=${thumbnail} alt=\"no thumbnail!\" />\n\n <md-icon view @click=${e => this.onClickViewer(e, id)}>search</md-icon>\n <md-icon edit @click=${e => this.onClickModeler(e, id)}>edit</md-icon>\n `\n : html` choose board.. `\n }\n\n onClickViewer(e, id) {\n e.preventDefault()\n e.stopPropagation()\n\n var boardViewerPage = this.boardViewerPage || 'board-viewer'\n\n navigate(`${boardViewerPage}/${id}${window.location.search}`)\n }\n\n onClickModeler(e, id) {\n e.preventDefault()\n e.stopPropagation()\n\n navigate(`board-modeller/${id}${window.location.search}`)\n }\n}\n\nexport const BoardRenderer = (value, column, record) => {\n var { boardViewerPage = '' } = column.record.options || {}\n\n return html` <board-renderer .value=${value} .boardViewerPage=${boardViewerPage}></board-renderer> `\n}\n"]}
@@ -3,9 +3,13 @@ import { customElement } from 'lit/decorators.js';
3
3
  import { OxGristEditorValueMap } from '@operato/grist-editor/ox-grist-editor-value-map.js';
4
4
  let ColorMapEditor = class ColorMapEditor extends OxGristEditorValueMap {
5
5
  get options() {
6
- var _a;
7
- const overidable = ((_a = this.column.record) === null || _a === void 0 ? void 0 : _a.options) || {};
8
- return Object.assign({ name: `Color Map : ${this.record.name}`, valuetype: 'color', objectified: true }, overidable);
6
+ const overidable = this.column.record?.options || {};
7
+ return {
8
+ name: `Color Map : ${this.record.name}`,
9
+ valuetype: 'color',
10
+ objectified: true,
11
+ ...overidable
12
+ };
9
13
  }
10
14
  };
11
15
  ColorMapEditor = __decorate([
@@ -1 +1 @@
1
- {"version":3,"file":"color-map-editor.js","sourceRoot":"","sources":["../../client/data-grist/color-map-editor.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AAEjD,OAAO,EAAE,qBAAqB,EAAE,MAAM,oDAAoD,CAAA;AAGnF,IAAM,cAAc,GAApB,MAAM,cAAe,SAAQ,qBAAqB;IACvD,IAAI,OAAO;;QACT,MAAM,UAAU,GAAG,CAAA,MAAA,IAAI,CAAC,MAAM,CAAC,MAAM,0CAAE,OAAO,KAAI,EAAE,CAAA;QAEpD,uBACE,IAAI,EAAE,eAAe,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,EACvC,SAAS,EAAE,OAAO,EAClB,WAAW,EAAE,IAAI,IACd,UAAU,EACd;IACH,CAAC;CACF,CAAA;AAXY,cAAc;IAD1B,aAAa,CAAC,kBAAkB,CAAC;GACrB,cAAc,CAW1B","sourcesContent":["import { customElement } from 'lit/decorators.js'\n\nimport { OxGristEditorValueMap } from '@operato/grist-editor/ox-grist-editor-value-map.js'\n\n@customElement('color-map-editor')\nexport class ColorMapEditor extends OxGristEditorValueMap {\n get options() {\n const overidable = this.column.record?.options || {}\n\n return {\n name: `Color Map : ${this.record.name}`,\n valuetype: 'color',\n objectified: true,\n ...overidable\n }\n }\n}\n"]}
1
+ {"version":3,"file":"color-map-editor.js","sourceRoot":"","sources":["../../client/data-grist/color-map-editor.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AAEjD,OAAO,EAAE,qBAAqB,EAAE,MAAM,oDAAoD,CAAA;AAGnF,IAAM,cAAc,GAApB,MAAM,cAAe,SAAQ,qBAAqB;IACvD,IAAI,OAAO;QACT,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,IAAI,EAAE,CAAA;QAEpD,OAAO;YACL,IAAI,EAAE,eAAe,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE;YACvC,SAAS,EAAE,OAAO;YAClB,WAAW,EAAE,IAAI;YACjB,GAAG,UAAU;SACd,CAAA;IACH,CAAC;CACF,CAAA;AAXY,cAAc;IAD1B,aAAa,CAAC,kBAAkB,CAAC;GACrB,cAAc,CAW1B","sourcesContent":["import { customElement } from 'lit/decorators.js'\n\nimport { OxGristEditorValueMap } from '@operato/grist-editor/ox-grist-editor-value-map.js'\n\n@customElement('color-map-editor')\nexport class ColorMapEditor extends OxGristEditorValueMap {\n get options() {\n const overidable = this.column.record?.options || {}\n\n return {\n name: `Color Map : ${this.record.name}`,\n valuetype: 'color',\n objectified: true,\n ...overidable\n }\n }\n}\n"]}
@@ -3,9 +3,13 @@ import { customElement } from 'lit/decorators.js';
3
3
  import { OxGristEditorValueRanges } from '@operato/grist-editor/ox-grist-editor-value-ranges.js';
4
4
  let ColorRangesEditor = class ColorRangesEditor extends OxGristEditorValueRanges {
5
5
  get options() {
6
- var _a;
7
- const overidable = ((_a = this.column.record) === null || _a === void 0 ? void 0 : _a.options) || {};
8
- return Object.assign({ name: `Color Ranges : ${this.record.name}`, valuetype: 'color', objectified: true }, overidable);
6
+ const overidable = this.column.record?.options || {};
7
+ return {
8
+ name: `Color Ranges : ${this.record.name}`,
9
+ valuetype: 'color',
10
+ objectified: true,
11
+ ...overidable
12
+ };
9
13
  }
10
14
  };
11
15
  ColorRangesEditor = __decorate([
@@ -1 +1 @@
1
- {"version":3,"file":"color-ranges-editor.js","sourceRoot":"","sources":["../../client/data-grist/color-ranges-editor.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AAEjD,OAAO,EAAE,wBAAwB,EAAE,MAAM,uDAAuD,CAAA;AAGzF,IAAM,iBAAiB,GAAvB,MAAM,iBAAkB,SAAQ,wBAAwB;IAC7D,IAAI,OAAO;;QACT,MAAM,UAAU,GAAG,CAAA,MAAA,IAAI,CAAC,MAAM,CAAC,MAAM,0CAAE,OAAO,KAAI,EAAE,CAAA;QAEpD,uBACE,IAAI,EAAE,kBAAkB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,EAC1C,SAAS,EAAE,OAAO,EAClB,WAAW,EAAE,IAAI,IACd,UAAU,EACd;IACH,CAAC;CACF,CAAA;AAXY,iBAAiB;IAD7B,aAAa,CAAC,qBAAqB,CAAC;GACxB,iBAAiB,CAW7B","sourcesContent":["import { customElement } from 'lit/decorators.js'\n\nimport { OxGristEditorValueRanges } from '@operato/grist-editor/ox-grist-editor-value-ranges.js'\n\n@customElement('color-ranges-editor')\nexport class ColorRangesEditor extends OxGristEditorValueRanges {\n get options() {\n const overidable = this.column.record?.options || {}\n\n return {\n name: `Color Ranges : ${this.record.name}`,\n valuetype: 'color',\n objectified: true,\n ...overidable\n }\n }\n}\n"]}
1
+ {"version":3,"file":"color-ranges-editor.js","sourceRoot":"","sources":["../../client/data-grist/color-ranges-editor.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AAEjD,OAAO,EAAE,wBAAwB,EAAE,MAAM,uDAAuD,CAAA;AAGzF,IAAM,iBAAiB,GAAvB,MAAM,iBAAkB,SAAQ,wBAAwB;IAC7D,IAAI,OAAO;QACT,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,IAAI,EAAE,CAAA;QAEpD,OAAO;YACL,IAAI,EAAE,kBAAkB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE;YAC1C,SAAS,EAAE,OAAO;YAClB,WAAW,EAAE,IAAI;YACjB,GAAG,UAAU;SACd,CAAA;IACH,CAAC;CACF,CAAA;AAXY,iBAAiB;IAD7B,aAAa,CAAC,qBAAqB,CAAC;GACxB,iBAAiB,CAW7B","sourcesContent":["import { customElement } from 'lit/decorators.js'\n\nimport { OxGristEditorValueRanges } from '@operato/grist-editor/ox-grist-editor-value-ranges.js'\n\n@customElement('color-ranges-editor')\nexport class ColorRangesEditor extends OxGristEditorValueRanges {\n get options() {\n const overidable = this.column.record?.options || {}\n\n return {\n name: `Color Ranges : ${this.record.name}`,\n valuetype: 'color',\n objectified: true,\n ...overidable\n }\n }\n}\n"]}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,4 @@
1
+ import 'core-js/stable';
2
+ import 'regenerator-runtime/runtime';
3
+ import './things-scene-components.import';
4
+ //# sourceMappingURL=headless-scene-components.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"headless-scene-components.js","sourceRoot":"","sources":["../../client/entries/headless-scene-components.js"],"names":[],"mappings":"AAAA,OAAO,gBAAgB,CAAA;AACvB,OAAO,6BAA6B,CAAA;AACpC,OAAO,kCAAkC,CAAA","sourcesContent":["import 'core-js/stable'\nimport 'regenerator-runtime/runtime'\nimport './things-scene-components.import'\n"]}
@@ -0,0 +1,5 @@
1
+ export const provider: ReferenceMap<any>;
2
+ export function startSubscribingForAutoRefresh(playGroupId: any, callback: any): Promise<void>;
3
+ export function stopSubscribing(): Promise<void>;
4
+ import { ReferenceMap } from '@hatiolab/things-scene';
5
+ export { BoardViewer, BoardPlayer } from "@operato/board";
@@ -0,0 +1,84 @@
1
+ import './headless-scene-components.js';
2
+ import gql from 'graphql-tag';
3
+ import { ReferenceMap, create, error } from '@hatiolab/things-scene';
4
+ export { BoardViewer, BoardPlayer } from '@operato/board';
5
+ import { client, gqlContext, subscribe } from '@operato/graphql';
6
+ export const provider = new ReferenceMap(async (boardId, resolve, reject) => {
7
+ try {
8
+ const response = await client.query({
9
+ query: gql `
10
+ query FetchBoardById($id: String!) {
11
+ board(id: $id) {
12
+ model
13
+ }
14
+ }
15
+ `,
16
+ variables: { id: boardId },
17
+ context: gqlContext()
18
+ });
19
+ const board = response.data.board;
20
+ var model = JSON.parse(board.model);
21
+ var scene;
22
+ try {
23
+ scene = await provider.get(boardId);
24
+ console.warn('Board fetched more than twice.', boardId);
25
+ }
26
+ catch (e) {
27
+ scene = create({
28
+ model,
29
+ mode: 0,
30
+ refProvider: provider
31
+ });
32
+ // s.app.baseUrl = undefined;
33
+ }
34
+ resolve(scene);
35
+ }
36
+ catch (e) {
37
+ error(e);
38
+ reject(e);
39
+ }
40
+ }, async (id, ref) => {
41
+ ref.dispose();
42
+ });
43
+ var subscriptionForAutoRefresh;
44
+ export const startSubscribingForAutoRefresh = async (playGroupId, callback) => {
45
+ if (!playGroupId) {
46
+ return;
47
+ }
48
+ await stopSubscribing();
49
+ subscriptionForAutoRefresh = await subscribe({
50
+ query: gql `
51
+ subscription ($id: String!) {
52
+ playGroup(id: $id) {
53
+ id
54
+ boards {
55
+ id
56
+ model
57
+ }
58
+ }
59
+ }
60
+ `,
61
+ variables: {
62
+ id: playGroupId
63
+ }
64
+ }, {
65
+ next: async ({ data }) => {
66
+ const { id, boards = '{}' } = data.playGroup;
67
+ if (data) {
68
+ callback &&
69
+ (await callback({
70
+ id,
71
+ boards
72
+ }));
73
+ }
74
+ }
75
+ });
76
+ };
77
+ export const stopSubscribing = async () => {
78
+ await subscriptionForAutoRefresh?.unsubscribe();
79
+ subscriptionForAutoRefresh = null;
80
+ };
81
+ window['headlessSceneProvider'] = provider;
82
+ window['startSubscribingForAutoRefresh'] = startSubscribingForAutoRefresh;
83
+ window['stopSubscribing'] = stopSubscribing;
84
+ //# sourceMappingURL=scene-player.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scene-player.js","sourceRoot":"","sources":["../../client/entries/scene-player.js"],"names":[],"mappings":"AAAA,OAAO,gCAAgC,CAAA;AACvC,OAAO,GAAG,MAAM,aAAa,CAAA;AAE7B,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,wBAAwB,CAAA;AAEpE,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AACzD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AAEhE,MAAM,CAAC,MAAM,QAAQ,GAAG,IAAI,YAAY,CACtC,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE;IACjC,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC;YAClC,KAAK,EAAE,GAAG,CAAA;;;;;;SAMT;YACD,SAAS,EAAE,EAAE,EAAE,EAAE,OAAO,EAAE;YAC1B,OAAO,EAAE,UAAU,EAAE;SACtB,CAAC,CAAA;QAEF,MAAM,KAAK,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAA;QAEjC,IAAI,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QAEnC,IAAI,KAAK,CAAA;QAET,IAAI,CAAC;YACH,KAAK,GAAG,MAAM,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;YACnC,OAAO,CAAC,IAAI,CAAC,gCAAgC,EAAE,OAAO,CAAC,CAAA;QACzD,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,KAAK,GAAG,MAAM,CAAC;gBACb,KAAK;gBACL,IAAI,EAAE,CAAC;gBACP,WAAW,EAAE,QAAQ;aACtB,CAAC,CAAA;YAEF,6BAA6B;QAC/B,CAAC;QAED,OAAO,CAAC,KAAK,CAAC,CAAA;IAChB,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,KAAK,CAAC,CAAC,CAAC,CAAA;QACR,MAAM,CAAC,CAAC,CAAC,CAAA;IACX,CAAC;AACH,CAAC,EACD,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE;IAChB,GAAG,CAAC,OAAO,EAAE,CAAA;AACf,CAAC,CACF,CAAA;AAED,IAAI,0BAA0B,CAAA;AAE9B,MAAM,CAAC,MAAM,8BAA8B,GAAG,KAAK,EAAE,WAAW,EAAE,QAAQ,EAAE,EAAE;IAC5E,IAAI,CAAC,WAAW,EAAE,CAAC;QACjB,OAAM;IACR,CAAC;IAED,MAAM,eAAe,EAAE,CAAA;IAEvB,0BAA0B,GAAG,MAAM,SAAS,CAC1C;QACE,KAAK,EAAE,GAAG,CAAA;;;;;;;;;;OAUT;QACD,SAAS,EAAE;YACT,EAAE,EAAE,WAAW;SAChB;KACF,EACD;QACE,IAAI,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE;YACvB,MAAM,EAAE,EAAE,EAAE,MAAM,GAAG,IAAI,EAAE,GAAG,IAAI,CAAC,SAAS,CAAA;YAE5C,IAAI,IAAI,EAAE,CAAC;gBACT,QAAQ;oBACN,CAAC,MAAM,QAAQ,CAAC;wBACd,EAAE;wBACF,MAAM;qBACP,CAAC,CAAC,CAAA;YACP,CAAC;QACH,CAAC;KACF,CACF,CAAA;AACH,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,eAAe,GAAG,KAAK,IAAI,EAAE;IACxC,MAAM,0BAA0B,EAAE,WAAW,EAAE,CAAA;IAC/C,0BAA0B,GAAG,IAAI,CAAA;AACnC,CAAC,CAAA;AAED,MAAM,CAAC,uBAAuB,CAAC,GAAG,QAAQ,CAAA;AAC1C,MAAM,CAAC,gCAAgC,CAAC,GAAG,8BAA8B,CAAA;AACzE,MAAM,CAAC,iBAAiB,CAAC,GAAG,eAAe,CAAA","sourcesContent":["import './headless-scene-components.js'\nimport gql from 'graphql-tag'\n\nimport { ReferenceMap, create, error } from '@hatiolab/things-scene'\n\nexport { BoardViewer, BoardPlayer } from '@operato/board'\nimport { client, gqlContext, subscribe } from '@operato/graphql'\n\nexport const provider = new ReferenceMap(\n async (boardId, resolve, reject) => {\n try {\n const response = await client.query({\n query: gql`\n query FetchBoardById($id: String!) {\n board(id: $id) {\n model\n }\n }\n `,\n variables: { id: boardId },\n context: gqlContext()\n })\n\n const board = response.data.board\n\n var model = JSON.parse(board.model)\n\n var scene\n\n try {\n scene = await provider.get(boardId)\n console.warn('Board fetched more than twice.', boardId)\n } catch (e) {\n scene = create({\n model,\n mode: 0,\n refProvider: provider\n })\n\n // s.app.baseUrl = undefined;\n }\n\n resolve(scene)\n } catch (e) {\n error(e)\n reject(e)\n }\n },\n async (id, ref) => {\n ref.dispose()\n }\n)\n\nvar subscriptionForAutoRefresh\n\nexport const startSubscribingForAutoRefresh = async (playGroupId, callback) => {\n if (!playGroupId) {\n return\n }\n\n await stopSubscribing()\n\n subscriptionForAutoRefresh = await subscribe(\n {\n query: gql`\n subscription ($id: String!) {\n playGroup(id: $id) {\n id\n boards {\n id\n model\n }\n }\n }\n `,\n variables: {\n id: playGroupId\n }\n },\n {\n next: async ({ data }) => {\n const { id, boards = '{}' } = data.playGroup\n\n if (data) {\n callback &&\n (await callback({\n id,\n boards\n }))\n }\n }\n }\n )\n}\n\nexport const stopSubscribing = async () => {\n await subscriptionForAutoRefresh?.unsubscribe()\n subscriptionForAutoRefresh = null\n}\n\nwindow['headlessSceneProvider'] = provider\nwindow['startSubscribingForAutoRefresh'] = startSubscribingForAutoRefresh\nwindow['stopSubscribing'] = stopSubscribing\n"]}
@@ -0,0 +1,5 @@
1
+ export { BoardViewer } from "@operato/board";
2
+ export const provider: ReferenceMap<any>;
3
+ export function startSubscribingForAutoRefresh(boardId: any, callback: any): Promise<void>;
4
+ export function stopSubscribing(): Promise<void>;
5
+ import { ReferenceMap } from '@hatiolab/things-scene';
@@ -0,0 +1,85 @@
1
+ import './headless-scene-components.js';
2
+ import { ReferenceMap, create, error } from '@hatiolab/things-scene';
3
+ import { client, gqlContext, subscribe } from '@operato/graphql';
4
+ import gql from 'graphql-tag';
5
+ export { BoardViewer } from '@operato/board';
6
+ export const provider = new ReferenceMap(async (boardId, resolve, reject) => {
7
+ try {
8
+ const response = await client.query({
9
+ query: gql `
10
+ query FetchBoardById($id: String!) {
11
+ board(id: $id) {
12
+ model
13
+ }
14
+ }
15
+ `,
16
+ variables: { id: boardId },
17
+ context: gqlContext()
18
+ });
19
+ const board = response.data.board;
20
+ var model = JSON.parse(board.model);
21
+ var scene;
22
+ try {
23
+ scene = await provider.get(boardId);
24
+ console.warn('Board fetched more than twice.', boardId);
25
+ }
26
+ catch (e) {
27
+ scene = create({
28
+ model,
29
+ mode: 0,
30
+ refProvider: provider
31
+ });
32
+ // s.app.baseUrl = undefined;
33
+ }
34
+ resolve(scene);
35
+ // resolve(scene, {
36
+ // ...board,
37
+ // model
38
+ // })
39
+ }
40
+ catch (e) {
41
+ error(e);
42
+ reject(e);
43
+ }
44
+ }, async (id, ref) => {
45
+ ref.dispose();
46
+ });
47
+ var subscriptionForAutoRefresh;
48
+ export const startSubscribingForAutoRefresh = async (boardId, callback) => {
49
+ if (!boardId) {
50
+ return;
51
+ }
52
+ await stopSubscribing();
53
+ subscriptionForAutoRefresh = await subscribe({
54
+ query: gql `
55
+ subscription ($id: String!) {
56
+ board(id: $id) {
57
+ id
58
+ model
59
+ }
60
+ }
61
+ `,
62
+ variables: {
63
+ id: boardId
64
+ }
65
+ }, {
66
+ next: async ({ data }) => {
67
+ const { id, model = '{}' } = data.board;
68
+ if (data) {
69
+ callback &&
70
+ (await callback({
71
+ id,
72
+ model: JSON.parse(model)
73
+ }));
74
+ }
75
+ }
76
+ });
77
+ };
78
+ export const stopSubscribing = async () => {
79
+ await subscriptionForAutoRefresh?.unsubscribe();
80
+ subscriptionForAutoRefresh = null;
81
+ };
82
+ window['headlessSceneProvider'] = provider;
83
+ window['startSubscribingForAutoRefresh'] = startSubscribingForAutoRefresh;
84
+ window['stopSubscribing'] = stopSubscribing;
85
+ //# sourceMappingURL=scene-viewer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scene-viewer.js","sourceRoot":"","sources":["../../client/entries/scene-viewer.js"],"names":[],"mappings":"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","sourcesContent":["import './headless-scene-components.js'\n\nimport { ReferenceMap, create, error } from '@hatiolab/things-scene'\nimport { client, gqlContext, subscribe } from '@operato/graphql'\n\nimport gql from 'graphql-tag'\n\nexport { BoardViewer } from '@operato/board'\n\nexport const provider = new ReferenceMap(\n async (boardId, resolve, reject) => {\n try {\n const response = await client.query({\n query: gql`\n query FetchBoardById($id: String!) {\n board(id: $id) {\n model\n }\n }\n `,\n variables: { id: boardId },\n context: gqlContext()\n })\n\n const board = response.data.board\n\n var model = JSON.parse(board.model)\n\n var scene\n\n try {\n scene = await provider.get(boardId)\n console.warn('Board fetched more than twice.', boardId)\n } catch (e) {\n scene = create({\n model,\n mode: 0,\n refProvider: provider\n })\n\n // s.app.baseUrl = undefined;\n }\n\n resolve(scene)\n\n // resolve(scene, {\n // ...board,\n // model\n // })\n } catch (e) {\n error(e)\n reject(e)\n }\n },\n async (id, ref) => {\n ref.dispose()\n }\n)\n\nvar subscriptionForAutoRefresh\n\nexport const startSubscribingForAutoRefresh = async (boardId, callback) => {\n if (!boardId) {\n return\n }\n\n await stopSubscribing()\n\n subscriptionForAutoRefresh = await subscribe(\n {\n query: gql`\n subscription ($id: String!) {\n board(id: $id) {\n id\n model\n }\n }\n `,\n variables: {\n id: boardId\n }\n },\n {\n next: async ({ data }) => {\n const { id, model = '{}' } = data.board\n\n if (data) {\n callback &&\n (await callback({\n id,\n model: JSON.parse(model)\n }))\n }\n }\n }\n )\n}\n\nexport const stopSubscribing = async () => {\n await subscriptionForAutoRefresh?.unsubscribe()\n subscriptionForAutoRefresh = null\n}\n\nwindow['headlessSceneProvider'] = provider\nwindow['startSubscribingForAutoRefresh'] = startSubscribingForAutoRefresh\nwindow['stopSubscribing'] = stopSubscribing\n"]}
@@ -0,0 +1 @@
1
+ /* 이 파일은 node_modules/@things-scene 아래에 설치된 컴포넌트들의 리스트를 스캔해서 자동으로 import 하기위해 things-scene-webpack-loader 에 의해 로드되는 파일이다. */
@@ -62,6 +62,7 @@ export async function createBoard(board) {
62
62
  name : String!
63
63
  description : String
64
64
  model : String!
65
+ type : String!
65
66
  groupId : String!
66
67
  }
67
68
  */
@@ -73,6 +74,7 @@ export async function createBoard(board) {
73
74
  id
74
75
  name
75
76
  description
77
+ type
76
78
  model
77
79
  state
78
80
  version
@@ -95,6 +97,7 @@ export async function cloneBoard({ id, name, description, targetSubdomain, targe
95
97
  id
96
98
  name
97
99
  description
100
+ type
98
101
  model
99
102
  group {
100
103
  id
@@ -125,6 +128,7 @@ export async function releaseBoard(board) {
125
128
  id
126
129
  name
127
130
  description
131
+ type
128
132
  model
129
133
  group {
130
134
  id
@@ -165,9 +169,11 @@ export async function updateBoard(board) {
165
169
  name : String
166
170
  description : String
167
171
  model : String
172
+ groupId : String
173
+ type : String
168
174
  }
169
175
  */
170
- var { id, name, description, model, groupId } = board;
176
+ var { id, name, description, model, groupId, type } = board;
171
177
  model = JSON.stringify(model);
172
178
  const response = await client.mutate({
173
179
  mutation: gql `
@@ -181,6 +187,7 @@ export async function updateBoard(board) {
181
187
  id
182
188
  name
183
189
  }
190
+ type
184
191
  state
185
192
  version
186
193
  createdAt
@@ -190,7 +197,7 @@ export async function updateBoard(board) {
190
197
  `,
191
198
  variables: {
192
199
  id,
193
- patch: { name, description, model, groupId }
200
+ patch: { name, description, model, groupId, type }
194
201
  }
195
202
  });
196
203
  return response.data;