@things-factory/integration-ui 6.2.34 → 6.2.35
Sign up to get free protection for your applications and to get access to all the features.
- package/client/pages/state-register.ts +260 -0
- package/client/route.ts +4 -0
- package/client/viewparts/scenario-instance-log-view.ts +15 -1
- package/dist-client/pages/state-register.d.ts +45 -0
- package/dist-client/pages/state-register.js +250 -0
- package/dist-client/pages/state-register.js.map +1 -0
- package/dist-client/route.js +3 -0
- package/dist-client/route.js.map +1 -1
- package/dist-client/tsconfig.tsbuildinfo +1 -1
- package/dist-client/viewparts/scenario-instance-log-view.js +15 -1
- package/dist-client/viewparts/scenario-instance-log-view.js.map +1 -1
- package/helps/integration/ui/state-register.ja.md +29 -0
- package/helps/integration/ui/state-register.ko.md +29 -0
- package/helps/integration/ui/state-register.md +29 -0
- package/helps/integration/ui/state-register.ms.md +32 -0
- package/helps/integration/ui/state-register.zh.md +29 -0
- package/package.json +3 -3
- package/things-factory.config.js +4 -0
- package/translations/en.json +5 -1
- package/translations/ja.json +22 -18
- package/translations/ko.json +5 -1
- package/translations/ms.json +5 -1
- package/translations/zh.json +5 -1
- package/dist-client/editors/operato-select-scenario.d.ts +0 -14
- package/dist-client/editors/operato-select-scenario.js +0 -72
- package/dist-client/editors/operato-select-scenario.js.map +0 -1
@@ -20,7 +20,11 @@ let ScenarioInstanceLogView = class ScenarioInstanceLogView extends connect(stor
|
|
20
20
|
return html `
|
21
21
|
<div options></div>
|
22
22
|
<div content>
|
23
|
-
${logs.map(({ timestamp, message, level }) => html `
|
23
|
+
${logs.map(({ timestamp, message, level }) => html `
|
24
|
+
<div class="${level}">
|
25
|
+
<span>${new Date(timestamp).toLocaleString()}</span> <strong>${level}</strong> ${message}
|
26
|
+
</div>
|
27
|
+
`)}
|
24
28
|
</div>
|
25
29
|
`;
|
26
30
|
}
|
@@ -68,6 +72,7 @@ ScenarioInstanceLogView.styles = [
|
|
68
72
|
background-color: var(--theme-white-color);
|
69
73
|
padding: var(--padding-wide);
|
70
74
|
}
|
75
|
+
|
71
76
|
:host([active]) {
|
72
77
|
padding: 0;
|
73
78
|
}
|
@@ -81,6 +86,15 @@ ScenarioInstanceLogView.styles = [
|
|
81
86
|
|
82
87
|
font-size: var(--fontsize-small);
|
83
88
|
}
|
89
|
+
|
90
|
+
div.error {
|
91
|
+
color: red;
|
92
|
+
}
|
93
|
+
|
94
|
+
div.warn {
|
95
|
+
color: orange;
|
96
|
+
}
|
97
|
+
|
84
98
|
span {
|
85
99
|
color: var(--secondary-text-color);
|
86
100
|
}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"scenario-instance-log-view.js","sourceRoot":"","sources":["../../client/viewparts/scenario-instance-log-view.ts"],"names":[],"mappings":";AAAA,OAAO,GAAG,MAAM,aAAa,CAAA;AAC7B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAS,MAAM,mBAAmB,CAAA;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAA;AAEnD,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAA;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAG1C,IAAM,uBAAuB,GAA7B,MAAM,uBAAwB,SAAQ,OAAO,CAAC,KAAK,CAAC,CAAC,UAAU,CAAC;
|
1
|
+
{"version":3,"file":"scenario-instance-log-view.js","sourceRoot":"","sources":["../../client/viewparts/scenario-instance-log-view.ts"],"names":[],"mappings":";AAAA,OAAO,GAAG,MAAM,aAAa,CAAA;AAC7B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAS,MAAM,mBAAmB,CAAA;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAA;AAEnD,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAA;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAG1C,IAAM,uBAAuB,GAA7B,MAAM,uBAAwB,SAAQ,OAAO,CAAC,KAAK,CAAC,CAAC,UAAU,CAAC;IA6CrE,YAAY;QACV,IAAI,CAAC,IAAI,GAAG,EAAE,CAAA;QACd,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAED,oBAAoB;QAClB,KAAK,CAAC,oBAAoB,EAAE,CAAA;QAC5B,IAAI,CAAC,aAAa,EAAE,CAAA;IACtB,CAAC;IAED,MAAM;QACJ,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,EAAE,CAAA;QAE5B,OAAO,IAAI,CAAA;;;UAGL,IAAI,CAAC,GAAG,CACR,CAAC,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,CAChC,IAAI,CAAA;4BACY,KAAK;wBACT,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,cAAc,EAAE,mBAAmB,KAAK,aAAa,OAAO;;aAE3F,CACJ;;KAEJ,CAAA;IACH,CAAC;IAED,KAAK,CAAC,cAAc;QAClB,IAAI,CAAC,YAAY,GAAG,MAAM,SAAS,CACjC;YACE,KAAK,EAAE,GAAG,CAAA;;;;;;;;SAQT;YACD,SAAS,EAAE;gBACT,YAAY,EAAE,IAAI,CAAC,YAAY;gBAC/B,YAAY,EAAE,IAAI,CAAC,YAAY;aAChC;SACF,EACD;YACE,IAAI,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE;gBACvB,IAAI,SAAS,GAAG,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,KAAK,IAAI,CAAC,YAAY,CAAA;gBAExE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;gBACxB,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAA;gBAC3C,IAAI,CAAC,aAAa,EAAE,CAAA;gBAEpB,IAAI,SAAS,EAAE;oBACb,6DAA6D;oBAC7D,MAAM,IAAI,CAAC,cAAc,CAAA;oBACzB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAA;iBACvD;YACH,CAAC;SACF,CACF,CAAA;IACH,CAAC;IAED,KAAK,CAAC,aAAa;;QACjB,MAAM,CAAA,MAAA,IAAI,CAAC,YAAY,0CAAE,WAAW,EAAE,CAAA,CAAA;QACtC,OAAO,IAAI,CAAC,YAAY,CAAA;IAC1B,CAAC;;AA9GM,8BAAM,GAAG;IACd,eAAe;IACf,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAiCF;CACF,CAAA;AAED;IAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;6DAAsB;AACjD;IAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;6DAAsB;AACjD;IAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;;qDAAU;AAzCzB,uBAAuB;IADnC,aAAa,CAAC,4BAA4B,CAAC;GAC/B,uBAAuB,CAgHnC;SAhHY,uBAAuB","sourcesContent":["import gql from 'graphql-tag'\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\nimport { connect } from 'pwa-helpers/connect-mixin'\n\nimport { subscribe } from '@operato/graphql'\nimport { store } from '@operato/shell'\nimport { ScrollbarStyles } from '@operato/styles'\n\n@customElement('scenario-instance-log-view')\nexport class ScenarioInstanceLogView extends connect(store)(LitElement) {\n static styles = [\n ScrollbarStyles,\n css`\n :host {\n display: flex;\n flex-direction: column;\n background-color: var(--theme-white-color);\n padding: var(--padding-wide);\n }\n\n :host([active]) {\n padding: 0;\n }\n\n [content] {\n flex: 1;\n\n display: flex;\n flex-direction: column;\n overflow: auto;\n\n font-size: var(--fontsize-small);\n }\n\n div.error {\n color: red;\n }\n\n div.warn {\n color: orange;\n }\n\n span {\n color: var(--secondary-text-color);\n }\n `\n ]\n\n @property({ type: String }) scenarioName?: string\n @property({ type: String }) instanceName?: string\n @property({ type: Array }) logs: any\n\n subscription: any\n\n firstUpdated() {\n this.logs = []\n this.startSubscribe()\n }\n\n disconnectedCallback() {\n super.disconnectedCallback()\n this.stopSubscribe()\n }\n\n render() {\n const logs = this.logs || []\n\n return html`\n <div options></div>\n <div content>\n ${logs.map(\n ({ timestamp, message, level }) =>\n html`\n <div class=\"${level}\">\n <span>${new Date(timestamp).toLocaleString()}</span> <strong>${level}</strong> ${message}\n </div>\n `\n )}\n </div>\n `\n }\n\n async startSubscribe() {\n this.subscription = await subscribe(\n {\n query: gql`\n subscription ($instanceName: String, $scenarioName: String, $level: String) {\n log: scenarioInstanceLog(instanceName: $instanceName, scenarioName: $scenarioName, level: $level) {\n level\n message\n timestamp\n }\n }\n `,\n variables: {\n instanceName: this.instanceName,\n scenarioName: this.scenarioName\n }\n },\n {\n next: async ({ data }) => {\n var wasBottom = this.scrollHeight - this.scrollTop === this.clientHeight\n\n this.logs.push(data.log)\n this.logs.length > 100 && this.logs.shift()\n this.requestUpdate()\n\n if (wasBottom) {\n /* this is not proved yet - to keep bottom scroll position */\n await this.updateComplete\n this.scrollTop = this.scrollHeight - this.clientHeight\n }\n }\n }\n )\n }\n\n async stopSubscribe() {\n await this.subscription?.unsubscribe()\n delete this.subscription\n }\n}\n"]}
|
@@ -0,0 +1,29 @@
|
|
1
|
+
# 状態登録簿 (StateRegister)
|
2
|
+
|
3
|
+
[状態登録簿(state-register)](../concept/state-register.md)は、特定の意味を持つ状態の値を定義する画面です。
|
4
|
+
|
5
|
+
- この機能は通常、[シナリオ](../concept/scenario.md)の[state-write](../task/state-write.md)、[state-read](../task/state-read.md)タスクによって使用されます。
|
6
|
+
|
7
|
+
## 属性(properties)
|
8
|
+
|
9
|
+
- 名前(name)
|
10
|
+
- 状態の名前を指定
|
11
|
+
- 名前はユニークである必要があります
|
12
|
+
- 説明(description)
|
13
|
+
- 区分(type)
|
14
|
+
- 任意のテキストを入力でき、各状態をユーザーが区別するための目的です
|
15
|
+
- TTL (Time To Live)
|
16
|
+
- 状態値が有効な時間を秒単位で定義できます。
|
17
|
+
- TTL 値が 0 より大きい場合、TTL が設定されていると判断されます。
|
18
|
+
- 最後に設定された状態値は、TTL 時間が経過すると無効になります
|
19
|
+
- 状態値(state)
|
20
|
+
- この状態が持つ現在の値を意味します。
|
21
|
+
- 修改日時(wrote at)
|
22
|
+
- 状態値が最終的に修正された時間
|
23
|
+
|
24
|
+
## 操作
|
25
|
+
|
26
|
+
- 保存(save state-register)
|
27
|
+
- 状態登録の変更を保存します。
|
28
|
+
- 削除(delete state-register)
|
29
|
+
- 選択された状態登録を削除します。
|
@@ -0,0 +1,29 @@
|
|
1
|
+
# 상태등록부 (StateRegister)
|
2
|
+
|
3
|
+
[상태등록부(state-register)](../concept/state-register.md)는 특정 의미를 가지는 상태의 값을 정의하는 화면이다.
|
4
|
+
|
5
|
+
- 이 기능은 보통 [시나리오](../concept/scenario.md)의 [state-write](../task/state-write.md), [state-read](../task/state-read.md) 태스크에 의해서 사용된다.
|
6
|
+
|
7
|
+
## 속성(properties)
|
8
|
+
|
9
|
+
- 이름(name)
|
10
|
+
- 상태의 이름을 지정
|
11
|
+
- 이름은 유니크해야함
|
12
|
+
- 설명(description)
|
13
|
+
- 구분(type)
|
14
|
+
- 임의의 텍스트를 입력할 수 있으며, 각 상태들을 사용자가 구분하고자 하는 목적이다
|
15
|
+
- TTL (Time To Live)
|
16
|
+
- 상태값이 유효한 시간을 초단위로 정의할 수 있다.
|
17
|
+
- TTL 값이 0보다 크면, TTL이 설정된 것으로 판단한다.
|
18
|
+
- 마지막에 설정된 상태값이 TTL 시간이 지나면 무효화된다
|
19
|
+
- 상태값(state)
|
20
|
+
- 이 상태가 가지는 현재의 값을 의미한다.
|
21
|
+
- 수정일시(wrote at)
|
22
|
+
- 상태값이 수정된 최종 시간
|
23
|
+
|
24
|
+
## operations
|
25
|
+
|
26
|
+
- 저장(save state-register)
|
27
|
+
- 상태등록 수정사항을 저장한다.
|
28
|
+
- 삭제(delete state-register)
|
29
|
+
- 선택된 상태등록을 삭제한다.
|
@@ -0,0 +1,29 @@
|
|
1
|
+
# StateRegister
|
2
|
+
|
3
|
+
[State-register(state-register)](../concept/state-register.md) is a screen that defines values for states with specific meanings.
|
4
|
+
|
5
|
+
- This function is usually used by tasks in [scenario](../concept/scenario.md) such as [state-write](../task/state-write.md), [state-read](../task/state-read.md).
|
6
|
+
|
7
|
+
## Properties
|
8
|
+
|
9
|
+
- Name (name)
|
10
|
+
- Specifies the name of the state
|
11
|
+
- Name must be unique
|
12
|
+
- Description (description)
|
13
|
+
- Type (type)
|
14
|
+
- Arbitrary text can be entered, and it is for the purpose of users differentiating among the states
|
15
|
+
- TTL (Time To Live)
|
16
|
+
- The valid time of the state value can be defined in seconds.
|
17
|
+
- If the TTL value is greater than 0, it is considered set.
|
18
|
+
- The last set state value becomes invalid after the TTL time has passed
|
19
|
+
- State Value (state)
|
20
|
+
- Refers to the current value of this state.
|
21
|
+
- Last Modified (wrote at)
|
22
|
+
- The last time the state value was modified
|
23
|
+
|
24
|
+
## Operations
|
25
|
+
|
26
|
+
- Save (save state-register)
|
27
|
+
- Saves changes in the state register.
|
28
|
+
- Delete (delete state-register)
|
29
|
+
- Deletes the selected state register.
|
@@ -0,0 +1,32 @@
|
|
1
|
+
# Daftar Keadaan (StateRegister)
|
2
|
+
|
3
|
+
[Daftar keadaan(state-register)](../concept/state-register.md) adalah skrin yang mentakrif nilai-nilai keadaan dengan makna tertentu.
|
4
|
+
|
5
|
+
- Fungsi ini biasanya digunakan oleh tugas [senario](../concept/scenario.md) seperti [state-write](../task/state-write.md), [state-read](../task/state-read.md).
|
6
|
+
|
7
|
+
## Sifat-sifat (properties)
|
8
|
+
|
9
|
+
- Nama (name)
|
10
|
+
- Menentukan nama keadaan
|
11
|
+
- Nama harus unik
|
12
|
+
- Deskripsi (description)
|
13
|
+
- Jenis (type)
|
14
|
+
- Boleh memasukkan teks bebas, bertujuan untuk pengguna membezakan antara keadaan-keadaan
|
15
|
+
- TTL (Time To Live)
|
16
|
+
- Boleh menentukan masa sah nilai keadaan dalam unit detik.
|
17
|
+
- Jika nilai TTL lebih dari 0, maka dianggap telah
|
18
|
+
|
19
|
+
menetapkan TTL.
|
20
|
+
|
21
|
+
- Nilai keadaan yang terakhir ditetapkan akan tidak sah setelah masa TTL berlalu
|
22
|
+
- Nilai keadaan (state)
|
23
|
+
- Maksudnya nilai semasa keadaan itu.
|
24
|
+
- Tarikh pengubahsuaian (wrote at)
|
25
|
+
- Masa terakhir nilai keadaan diubah
|
26
|
+
|
27
|
+
## Operasi
|
28
|
+
|
29
|
+
- Simpan (save state-register)
|
30
|
+
- Menyimpan perubahan dalam daftar keadaan.
|
31
|
+
- Padam (delete state-register)
|
32
|
+
- Menghapus daftar keadaan yang dipilih.
|
@@ -0,0 +1,29 @@
|
|
1
|
+
# 状态登记册 (StateRegister)
|
2
|
+
|
3
|
+
[状态登记册(state-register)](../concept/state-register.md)是一个定义具有特定意义状态值的界面。
|
4
|
+
|
5
|
+
- 这个功能通常由[场景](../concept/scenario.md)中的[state-write](../task/state-write.md)、[state-read](../task/state-read.md)任务使用。
|
6
|
+
|
7
|
+
## 属性 (properties)
|
8
|
+
|
9
|
+
- 名称(name)
|
10
|
+
- 指定状态的名称
|
11
|
+
- 名称必须是唯一的
|
12
|
+
- 描述(description)
|
13
|
+
- 类型(type)
|
14
|
+
- 可以输入任意文本,用于用户区分各个状态的目的
|
15
|
+
- TTL (Time To Live)
|
16
|
+
- 可以以秒为单位定义状态值的有效时间。
|
17
|
+
- 如果 TTL 值大于 0,则认为设置了 TTL。
|
18
|
+
- 最后设置的状态值在 TTL 时间过后将失效
|
19
|
+
- 状态值(state)
|
20
|
+
- 指当前该状态的值。
|
21
|
+
- 修改时间(wrote at)
|
22
|
+
- 状态值最后修改的时间
|
23
|
+
|
24
|
+
## 操作
|
25
|
+
|
26
|
+
- 保存(save state-register)
|
27
|
+
- 保存状态登记的修改。
|
28
|
+
- 删除(delete state-register)
|
29
|
+
- 删除选定的状态登记。
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@things-factory/integration-ui",
|
3
|
-
"version": "6.2.
|
3
|
+
"version": "6.2.35",
|
4
4
|
"main": "dist-server/index.js",
|
5
5
|
"browser": "dist-client/index.js",
|
6
6
|
"things-factory": true,
|
@@ -39,9 +39,9 @@
|
|
39
39
|
"@operato/utils": "^1.0.1",
|
40
40
|
"@things-factory/export-base": "^6.2.34",
|
41
41
|
"@things-factory/import-base": "^6.2.34",
|
42
|
-
"@things-factory/integration-base": "^6.2.
|
42
|
+
"@things-factory/integration-base": "^6.2.35",
|
43
43
|
"d3": "^7.8.5",
|
44
44
|
"moment-timezone": "^0.5.40"
|
45
45
|
},
|
46
|
-
"gitHead": "
|
46
|
+
"gitHead": "7f44fa314cdfcb84faf99e3db9d188efb53c2423"
|
47
47
|
}
|
package/things-factory.config.js
CHANGED
package/translations/en.json
CHANGED
@@ -18,9 +18,12 @@
|
|
18
18
|
"field.rounds": "rounds",
|
19
19
|
"field.schedule": "schedule",
|
20
20
|
"field.skip": "skip",
|
21
|
+
"field.state-value": "state value",
|
21
22
|
"field.task": "task",
|
22
23
|
"field.timezone": "timezone",
|
24
|
+
"field.ttl-seconds": "TTL(seconds)",
|
23
25
|
"field.type": "type",
|
26
|
+
"field.wrote-at": "wrote at",
|
24
27
|
"label.address": "address",
|
25
28
|
"label.auth-client": "oauth2 client",
|
26
29
|
"label.authtype": "auth-type",
|
@@ -120,5 +123,6 @@
|
|
120
123
|
"title.scenario-detail": "scenario detail",
|
121
124
|
"title.scenario-instance": "scenario instance",
|
122
125
|
"title.scenario-log": "scenario log",
|
123
|
-
"title.select entity": "select entity"
|
126
|
+
"title.select entity": "select entity",
|
127
|
+
"title.state-register": "state register"
|
124
128
|
}
|
package/translations/ja.json
CHANGED
@@ -4,6 +4,7 @@
|
|
4
4
|
"button.save": "保存",
|
5
5
|
"button.start monitor": "モニタリング開始",
|
6
6
|
"button.stop monitor": "モニタリング終了",
|
7
|
+
"field.active": "アクティブ化",
|
7
8
|
"field.api_url": "API URL",
|
8
9
|
"field.break_main": "BreakMain",
|
9
10
|
"field.connection": "連結",
|
@@ -18,16 +19,19 @@
|
|
18
19
|
"field.rounds": "回目",
|
19
20
|
"field.schedule": "スケジュール",
|
20
21
|
"field.skip": "スキップ",
|
22
|
+
"field.state-value": "状態値",
|
21
23
|
"field.task": "タスク",
|
22
|
-
"field.type": "分類",
|
23
|
-
"field.active": "アクティブ化",
|
24
24
|
"field.timezone": "タイムゾーン",
|
25
|
+
"field.ttl-seconds": "TTL(秒)",
|
26
|
+
"field.type": "分類",
|
27
|
+
"field.wrote-at": "作成日時",
|
25
28
|
"label.address": "アドレス",
|
26
|
-
"label.authtype": "認証タイプ",
|
27
29
|
"label.auth-client": "oauth2クライアント",
|
30
|
+
"label.authtype": "認証タイプ",
|
28
31
|
"label.body": "body",
|
29
32
|
"label.cases": "cases",
|
30
33
|
"label.clear": "クリア",
|
34
|
+
"label.clientlib-path": "クライアント位置",
|
31
35
|
"label.confirm": "確認",
|
32
36
|
"label.daily": "日間",
|
33
37
|
"label.database": "データベース",
|
@@ -47,8 +51,8 @@
|
|
47
51
|
"label.level": "レベル",
|
48
52
|
"label.mapping-rule": "マッピング規則",
|
49
53
|
"label.message": "メッセージ",
|
50
|
-
"label.minute by minute": "分単位",
|
51
54
|
"label.minute": "分",
|
55
|
+
"label.minute by minute": "分単位",
|
52
56
|
"label.module": "モジュール",
|
53
57
|
"label.month": "月",
|
54
58
|
"label.monthly": "月間",
|
@@ -56,17 +60,21 @@
|
|
56
60
|
"label.number of bytes": "バイトの長さ",
|
57
61
|
"label.object-type": "オブジェクト タイプ",
|
58
62
|
"label.operation": "動作",
|
63
|
+
"label.parameters": "パラメータ",
|
59
64
|
"label.params": "パラメータ",
|
60
65
|
"label.priority": "優先順位",
|
61
66
|
"label.procedure": "プロシージャ",
|
67
|
+
"label.procedure-code": "手順コード",
|
68
|
+
"label.procedure-name": "手順名",
|
62
69
|
"label.product-id": "製品ID.",
|
63
70
|
"label.quantity": "数量",
|
64
71
|
"label.query": "Query",
|
72
|
+
"label.reject-unauthorized": "証明書使用",
|
65
73
|
"label.scenario": "シナリオ",
|
66
74
|
"label.script": "スクリプト",
|
67
75
|
"label.search-params": "search params",
|
68
|
-
"label.second by second": "秒単位",
|
69
76
|
"label.second": "秒",
|
77
|
+
"label.second by second": "秒単位",
|
70
78
|
"label.selectors": "selectors",
|
71
79
|
"label.timeout": "タイムアウト",
|
72
80
|
"label.username": "ユーザー名",
|
@@ -74,17 +82,12 @@
|
|
74
82
|
"label.wait-for": "待機時間",
|
75
83
|
"label.weekly": "週間",
|
76
84
|
"label.yearly": "年間",
|
77
|
-
"label.reject-unauthorized": "証明書使用",
|
78
|
-
"label.clientlib-path": "クライアント位置",
|
79
|
-
"label.procedure-code": "手順コード",
|
80
|
-
"label.procedure-name": "手順名",
|
81
|
-
"label.parameters": "パラメータ",
|
82
85
|
"text.10 am on every payday": "給料日の午前10時ごとに",
|
83
86
|
"text.allowed values": "許された値",
|
84
87
|
"text.alternative single values": "代替値",
|
85
88
|
"text.any value": "任意の値",
|
86
|
-
"text.connection list": "コネクション リスト",
|
87
89
|
"text.connection": "コネクション",
|
90
|
+
"text.connection list": "コネクション リスト",
|
88
91
|
"text.copy": "コピー",
|
89
92
|
"text.delete": "削除",
|
90
93
|
"text.every 12 hours": "12時間ごとに",
|
@@ -97,29 +100,30 @@
|
|
97
100
|
"text.every christmas": "毎クリスマスに",
|
98
101
|
"text.every day": "毎日",
|
99
102
|
"text.every half hour": "30分ごとに",
|
100
|
-
"text.every hour during working time": "勤務時間中時間ごとに",
|
101
103
|
"text.every hour": "毎時間",
|
104
|
+
"text.every hour during working time": "勤務時間中時間ごとに",
|
102
105
|
"text.every minute": "毎分",
|
103
106
|
"text.every second": "毎秒",
|
104
107
|
"text.every sunday": "毎週日曜日に",
|
105
108
|
"text.every weekday": "平日ごとに",
|
106
109
|
"text.info_x_successfully": "{x}に成功しました.",
|
110
|
+
"text.integration analysis": "統合分析 ",
|
111
|
+
"text.integration monitor": "インテグレーション モニタ",
|
107
112
|
"text.no properties to set": "プロパティの設定は必要ありません.",
|
108
113
|
"text.range of values": "値の範囲",
|
109
|
-
"text.scenario list": "シナリオリスト",
|
110
114
|
"text.scenario": "シナリオ",
|
111
|
-
"text.
|
112
|
-
"text.integration monitor": "インテグレーション モニタ",
|
115
|
+
"text.scenario list": "シナリオリスト",
|
113
116
|
"text.step values": "ステップ値",
|
114
117
|
"text.sure_to_x": "{x}しますか?",
|
115
118
|
"text.the first day of every month": "毎月1日ごとに",
|
116
119
|
"text.the first day of every year": "毎年1月1日ごとに",
|
117
120
|
"text.value list separator": "値区切り文字",
|
118
121
|
"title.edit privilege": "編集権限",
|
122
|
+
"title.import connection": "インポート接続",
|
123
|
+
"title.import scenario": "シナリオ読み込み",
|
119
124
|
"title.scenario-detail": "シナリオ詳細ステップ",
|
120
|
-
"title.select entity": "エンティティ選択",
|
121
125
|
"title.scenario-instance": "シナリオ インスタンス",
|
122
126
|
"title.scenario-log": "シナリオ ログ",
|
123
|
-
"title.
|
124
|
-
"title.
|
127
|
+
"title.select entity": "エンティティ選択",
|
128
|
+
"title.state-register": "状態登録簿"
|
125
129
|
}
|
package/translations/ko.json
CHANGED
@@ -19,9 +19,12 @@
|
|
19
19
|
"field.rounds": "회차",
|
20
20
|
"field.schedule": "스케줄",
|
21
21
|
"field.skip": "건너뛰기",
|
22
|
+
"field.state-value": "상태값",
|
22
23
|
"field.task": "작업",
|
23
24
|
"field.timezone": "타임존",
|
25
|
+
"field.ttl-seconds": "TTL(초)",
|
24
26
|
"field.type": "분류",
|
27
|
+
"field.wrote-at": "작성일시",
|
25
28
|
"label.address": "주소",
|
26
29
|
"label.auth-client": "oauth2 클라이언트",
|
27
30
|
"label.authtype": "인증 유형",
|
@@ -121,5 +124,6 @@
|
|
121
124
|
"title.scenario-detail": "시나리오 상세스텝",
|
122
125
|
"title.scenario-instance": "시나리오 인스턴스",
|
123
126
|
"title.scenario-log": "시나리오 로그",
|
124
|
-
"title.select entity": "엔티티 선택"
|
127
|
+
"title.select entity": "엔티티 선택",
|
128
|
+
"title.state-register": "상태 등록부"
|
125
129
|
}
|
package/translations/ms.json
CHANGED
@@ -19,9 +19,12 @@
|
|
19
19
|
"field.rounds": "pusingan",
|
20
20
|
"field.schedule": "jadual",
|
21
21
|
"field.skip": "langkau",
|
22
|
+
"field.state-value": "nilai keadaan",
|
22
23
|
"field.task": "tugas",
|
23
24
|
"field.timezone": "zon masa",
|
25
|
+
"field.ttl-seconds": "TTL(detik)",
|
24
26
|
"field.type": "jenis",
|
27
|
+
"field.wrote-at": "tarikh & masa penulisan",
|
25
28
|
"label.address": "alamat",
|
26
29
|
"label.auth-client": "klien oauth2",
|
27
30
|
"label.authtype": "jenis autentikasi",
|
@@ -121,5 +124,6 @@
|
|
121
124
|
"title.scenario-detail": "perincian senario",
|
122
125
|
"title.scenario-instance": "contoh senario",
|
123
126
|
"title.scenario-log": "log senario",
|
124
|
-
"title.select entity": "pilih entiti"
|
127
|
+
"title.select entity": "pilih entiti",
|
128
|
+
"title.state-register": "daftar keadaan"
|
125
129
|
}
|
package/translations/zh.json
CHANGED
@@ -18,9 +18,12 @@
|
|
18
18
|
"field.rounds": "回合",
|
19
19
|
"field.schedule": "日程",
|
20
20
|
"field.skip": "跳过",
|
21
|
+
"field.state-value": "状态值",
|
21
22
|
"field.task": "任务",
|
22
23
|
"field.timezone": "时区",
|
24
|
+
"field.ttl-seconds": "TTL(秒)",
|
23
25
|
"field.type": "类型",
|
26
|
+
"field.wrote-at": "编写日期和时间",
|
24
27
|
"label.address": "地址",
|
25
28
|
"label.auth-client": "认证客户端",
|
26
29
|
"label.authtype": "授权类型",
|
@@ -120,5 +123,6 @@
|
|
120
123
|
"title.scenario-detail": "方案详细信息",
|
121
124
|
"title.scenario-instance": "场景实例",
|
122
125
|
"title.scenario-log": "场景日志",
|
123
|
-
"title.select entity": "选择实体"
|
126
|
+
"title.select entity": "选择实体",
|
127
|
+
"title.state-register": "状态登记表"
|
124
128
|
}
|
@@ -1,14 +0,0 @@
|
|
1
|
-
import '@operato/data-grist';
|
2
|
-
import { OxPropertyEditor } from '@operato/property-editor';
|
3
|
-
export declare class OperatoSelectScenarioEditor extends OxPropertyEditor {
|
4
|
-
static get styles(): import("lit").CSSResult[];
|
5
|
-
value: string;
|
6
|
-
host: any;
|
7
|
-
scenarios: {
|
8
|
-
id: string;
|
9
|
-
name: string;
|
10
|
-
description: string;
|
11
|
-
}[];
|
12
|
-
connectedCallback(): Promise<void>;
|
13
|
-
editorTemplate(props: any): import("lit-html").TemplateResult<1>;
|
14
|
-
}
|
@@ -1,72 +0,0 @@
|
|
1
|
-
import { __decorate, __metadata } from "tslib";
|
2
|
-
import '@operato/data-grist';
|
3
|
-
import gql from 'graphql-tag';
|
4
|
-
import { html } from 'lit';
|
5
|
-
import { customElement, property, state } from 'lit/decorators.js';
|
6
|
-
import { OxPropertyEditor } from '@operato/property-editor';
|
7
|
-
import { notifyChangeEvent } from '@things-factory/utils';
|
8
|
-
let OperatoSelectScenarioEditor = class OperatoSelectScenarioEditor extends OxPropertyEditor {
|
9
|
-
constructor() {
|
10
|
-
super(...arguments);
|
11
|
-
this.value = '';
|
12
|
-
this.scenarios = [];
|
13
|
-
}
|
14
|
-
static get styles() {
|
15
|
-
return [...OxPropertyEditor.styles];
|
16
|
-
}
|
17
|
-
async connectedCallback() {
|
18
|
-
var _a;
|
19
|
-
super.connectedCallback();
|
20
|
-
var { connection: client } = this.host; /* connection must be OperatoConnector and ApolloLink to operato service */
|
21
|
-
const response = await client.query({
|
22
|
-
query: gql `
|
23
|
-
{
|
24
|
-
scenarios {
|
25
|
-
id
|
26
|
-
name
|
27
|
-
description
|
28
|
-
}
|
29
|
-
}
|
30
|
-
`
|
31
|
-
});
|
32
|
-
this.scenarios = (_a = response.data) === null || _a === void 0 ? void 0 : _a.scenarios;
|
33
|
-
}
|
34
|
-
editorTemplate(props) {
|
35
|
-
const value = this.value;
|
36
|
-
const scenarios = this.scenarios || [];
|
37
|
-
return html `
|
38
|
-
<ox-select
|
39
|
-
fullwidth
|
40
|
-
name=${name}
|
41
|
-
.value=${value}
|
42
|
-
@change=${(e) => {
|
43
|
-
e.stopPropagation();
|
44
|
-
this.value = e.target.value;
|
45
|
-
notifyChangeEvent(this, this.value);
|
46
|
-
}}
|
47
|
-
>
|
48
|
-
<ox-popup-list with-search>
|
49
|
-
<div option value=""> </div>
|
50
|
-
${scenarios.map(({ name }) => html `<div option value=${name}>${name}</div>`)}
|
51
|
-
</ox-popup-list>
|
52
|
-
</ox-select>
|
53
|
-
`;
|
54
|
-
}
|
55
|
-
};
|
56
|
-
__decorate([
|
57
|
-
property({ type: String }),
|
58
|
-
__metadata("design:type", String)
|
59
|
-
], OperatoSelectScenarioEditor.prototype, "value", void 0);
|
60
|
-
__decorate([
|
61
|
-
property({ type: Object }),
|
62
|
-
__metadata("design:type", Object)
|
63
|
-
], OperatoSelectScenarioEditor.prototype, "host", void 0);
|
64
|
-
__decorate([
|
65
|
-
state(),
|
66
|
-
__metadata("design:type", Array)
|
67
|
-
], OperatoSelectScenarioEditor.prototype, "scenarios", void 0);
|
68
|
-
OperatoSelectScenarioEditor = __decorate([
|
69
|
-
customElement('operato-select-scenario')
|
70
|
-
], OperatoSelectScenarioEditor);
|
71
|
-
export { OperatoSelectScenarioEditor };
|
72
|
-
//# sourceMappingURL=operato-select-scenario.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"operato-select-scenario.js","sourceRoot":"","sources":["../../client/editors/operato-select-scenario.ts"],"names":[],"mappings":";AAAA,OAAO,qBAAqB,CAAA;AAE5B,OAAO,GAAG,MAAM,aAAa,CAAA;AAC7B,OAAO,EAAO,IAAI,EAAc,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAS,KAAK,EAAE,MAAM,mBAAmB,CAAA;AAEzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAA;AAC3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAA;AAGlD,IAAM,2BAA2B,GAAjC,MAAM,2BAA4B,SAAQ,gBAAgB;IAA1D;;QAKuB,UAAK,GAAW,EAAE,CAAA;QAGrC,cAAS,GAAwD,EAAE,CAAA;IA4C9E,CAAC;IAnDC,MAAM,KAAK,MAAM;QACf,OAAO,CAAC,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAA;IACrC,CAAC;IAOD,KAAK,CAAC,iBAAiB;;QACrB,KAAK,CAAC,iBAAiB,EAAE,CAAA;QAEzB,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,IAAI,CAAA,CAAC,2EAA2E;QAElH,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC;YAClC,KAAK,EAAE,GAAG,CAAA;;;;;;;;OAQT;SACF,CAAC,CAAA;QAEF,IAAI,CAAC,SAAS,GAAG,MAAA,QAAQ,CAAC,IAAI,0CAAE,SAAS,CAAA;IAC3C,CAAC;IAED,cAAc,CAAC,KAAK;QAClB,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAA;QACxB,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,IAAI,EAAE,CAAA;QAEtC,OAAO,IAAI,CAAA;;;eAGA,IAAI;iBACF,KAAK;kBACJ,CAAC,CAAc,EAAE,EAAE;YAC3B,CAAC,CAAC,eAAe,EAAE,CAAA;YACnB,IAAI,CAAC,KAAK,GAAI,CAAC,CAAC,MAAc,CAAC,KAAK,CAAA;YACpC,iBAAiB,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,CAAA;QACrC,CAAC;;;;YAIG,SAAS,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAA,qBAAqB,IAAI,IAAI,IAAI,QAAQ,CAAC;;;KAGjF,CAAA;IACH,CAAC;CACF,CAAA;AA/CC;IAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;0DAAmB;AAC9C;IAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;yDAAU;AAErC;IAAC,KAAK,EAAE;;8DAAoE;AARjE,2BAA2B;IADvC,aAAa,CAAC,yBAAyB,CAAC;GAC5B,2BAA2B,CAoDvC;SApDY,2BAA2B","sourcesContent":["import '@operato/data-grist'\n\nimport gql from 'graphql-tag'\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\n\nimport { OxPropertyEditor } from '@operato/property-editor'\nimport { notifyChangeEvent } from '@things-factory/utils'\n\n@customElement('operato-select-scenario')\nexport class OperatoSelectScenarioEditor extends OxPropertyEditor {\n static get styles() {\n return [...OxPropertyEditor.styles]\n }\n\n @property({ type: String }) value: string = ''\n @property({ type: Object }) host: any\n\n @state() scenarios: { id: string; name: string; description: string }[] = []\n\n async connectedCallback() {\n super.connectedCallback()\n\n var { connection: client } = this.host /* connection must be OperatoConnector and ApolloLink to operato service */\n\n const response = await client.query({\n query: gql`\n {\n scenarios {\n id\n name\n description\n }\n }\n `\n })\n\n this.scenarios = response.data?.scenarios\n }\n\n editorTemplate(props) {\n const value = this.value\n const scenarios = this.scenarios || []\n\n return html`\n <ox-select\n fullwidth\n name=${name}\n .value=${value}\n @change=${(e: CustomEvent) => {\n e.stopPropagation()\n this.value = (e.target as any).value\n notifyChangeEvent(this, this.value)\n }}\n >\n <ox-popup-list with-search>\n <div option value=\"\"> </div>\n ${scenarios.map(({ name }) => html`<div option value=${name}>${name}</div>`)}\n </ox-popup-list>\n </ox-select>\n `\n }\n}\n"]}
|