TheDynamics.vue 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292
  1. <script setup lang="ts">
  2. import { useStore } from '@/util/store'
  3. import { computed, ref } from 'vue';
  4. import { UABaseNode } from '@/ua/UABaseNode';
  5. import { ReferenceTypeIds } from '@/ua/opcua_node_ids';
  6. import type { UAReferenceType } from '@/ua/UAReferenceType';
  7. import { ObjectTypeIds } from '@/ua/opcua_node_ids';
  8. import type { UAObjectType } from '@/ua/UAObjectType';
  9. import { VariableTypeIds } from '@/ua/opcua_node_ids';
  10. import type { UAVariableType } from '@/ua/UAVariableType';
  11. import { UAReference } from '@/ua/UAReference';
  12. import { UAObject } from '@/ua/UAObject';
  13. import { UAVariable } from '@/ua/UAVariable';
  14. import { DynamicNode, ComponentPair} from '@/ua/DynamicNode';
  15. import { storeToRefs } from 'pinia';
  16. const store = useStore();
  17. const { selectedNode} = storeToRefs(store)
  18. const nameSpaceName = computed(() => {
  19. if(!selectedNode.value)
  20. return "";
  21. let nsIdx=selectedNode.value.nodeId.namespace;
  22. return store.addressSpace?.nst.getUri(nsIdx);
  23. })
  24. let opt = {
  25. ident: "...",
  26. namespaceUri:"MyNamespace",
  27. parentNodeId: "MyNodeId",
  28. checkInterval:100,
  29. nodeClass:"Object",
  30. typeNodeId:"ns=0;i=88",
  31. name:"...",
  32. startIndex:0
  33. };
  34. let dynNode = new DynamicNode(opt);
  35. function filter(fnode: UABaseNode) {
  36. if(selectedNode.value?.nodeClass==="Variable") {
  37. if(fnode.nodeClass!="Object")
  38. return true;
  39. }
  40. return false;
  41. }
  42. function getRefTypes():UABaseNode[] {
  43. let list=(store.addressSpace?.getSubTreeAsList("ns=0;i="+ReferenceTypeIds.HierarchicalReferences)||[]) as UAReferenceType[];
  44. list=list.filter((node) => node.isAbstract==false)
  45. return list;
  46. }
  47. function getObjTypes(flag:any):UABaseNode[] {
  48. let list = [];
  49. if(flag){
  50. list=(store.addressSpace?.getSubTreeAsList("ns=0;i=89")||[]) as UAVariableType[];
  51. }else{
  52. list=(store.addressSpace?.getSubTreeAsList("ns=0;i=88")||[]) as UAObjectType[];
  53. }
  54. list=list.filter((node) => node.isAbstract==false)
  55. return list;
  56. }
  57. function defType(flag:any ):String{
  58. let lab = "ObjectType";
  59. if(flag){
  60. lab = "VariableType";
  61. }
  62. return lab;
  63. }
  64. function getInstanceDecl(nid="ns=0;i=84"){
  65. if(nid==""){nid="ns=0;i=84"}
  66. let component_refs:String[] = [];
  67. let res_man:any[] = [];
  68. let res_opt:any[] = [];
  69. dynNode.mandatory = [];
  70. dynNode.optionals = [];
  71. let res:any[] = [];
  72. let node = (store.addressSpace?.findNode(nid)) as UABaseNode;
  73. let refs = node.references;
  74. let list = (store.addressSpace?.getSubTreeAsList("ns=0;i="+ReferenceTypeIds.Aggregates)||[]) as UABaseNode[];
  75. list.forEach((item) => {
  76. component_refs.push(item.browseName);
  77. })
  78. refs.forEach((item) => {
  79. if(component_refs.includes(item.referenceType) && item.isForward){
  80. let mr = "";
  81. if(item.toNode.nodeClass == "Object"){
  82. let i = item.toNode as UAObject;
  83. mr = i.getModellingRule()||"";
  84. }else if(item.toNode.nodeClass == "Variable"){
  85. let i = item.toNode as UAVariable;
  86. mr = i.getModellingRule()||"";
  87. }
  88. if(mr == "Mandatory"){
  89. const newItem = new ComponentPair(item.toNode.displayName , true);
  90. res_man.push(item.toNode.displayName);
  91. }else{
  92. const newItem = new ComponentPair(item.toNode.displayName , false);
  93. res_opt.push(item.toNode.displayName);
  94. }
  95. dynNode.mandatory = res_man;
  96. dynNode.optionals = res_opt;
  97. dynNode.o_check = new Array(res_opt.length).fill(false);
  98. }
  99. })
  100. return res;
  101. }
  102. function getComponents(nid:string):DynamicNode{
  103. getInstanceDecl(nid);
  104. return dynNode;
  105. }
  106. function getNodeVersion(nid:string, dynNode:DynamicNode){
  107. let node = (store.addressSpace?.findNode(nid)) as UABaseNode;
  108. let refs = node.references;
  109. let res = "";
  110. refs.forEach((ref)=>{
  111. if(ref.toNode.displayName == "NodeVersion"){
  112. res= ref.toNode.nodeId.toString()
  113. dynNode.nodeVersionId= res;
  114. return res;
  115. }else if(ref.fromNode.displayName == "NodeVersion"){
  116. res= ref.fromNode.nodeId.toString()
  117. dynNode.nodeVersionId= res;
  118. return res;
  119. }
  120. })
  121. dynNode.nodeVersionId= res;
  122. return res;
  123. }
  124. async function createDynamic() {
  125. //dynNode.namespaceUri = nameSpaceName.value;
  126. //dynNode.parentNodeId = selectedNode.value?.nodeId.toString();
  127. dynNode.typeNodeId = typedef.value.toString();
  128. // console.log(dynNode);
  129. //console.log(c_man);
  130. //console.log(c_opt.value);
  131. console.log(dynNode.optionals)
  132. console.log(dynNode.o_check)
  133. //dynNode = new DynamicNode(opt);
  134. /*
  135. const blob = await store.addressSpace?.exportProject();
  136. if ('dynamics' in sconfig){
  137. sconfig.dynamics.push("hello");
  138. }else{
  139. sconfig.dynamics = [];
  140. }
  141. */
  142. }
  143. const checked = ref("")
  144. const c_man = ref([])
  145. const c_opt = ref([])
  146. const typedef = ref("")
  147. </script>
  148. <template>
  149. <div class="card">
  150. <div class="card-body" v-if="selectedNode != null && dynNode != null">
  151. <h5 class="card-title">Dynamic Node</h5>
  152. <div class="card-text">
  153. <div class="input-group mb-3">
  154. <div class="input-group-prepend">
  155. <span class="input-group-text" id="inputGroup-sizing-default">Parent Node</span>
  156. </div>
  157. <input type="text" class="form-control" aria-label="Default"
  158. aria-describedby="inputGroup-sizing-default" v-model="selectedNode.nodeId" disabled>
  159. </div>
  160. <div class="input-group mb-3">
  161. <div class="input-group-prepend">
  162. <span class="input-group-text" id="inputGroup-sizing-default">Namespace</span>
  163. </div>
  164. <input type="text" class="form-control" aria-label="Default" aria-describedby="inputGroup-sizing-default" v-model="nameSpaceName" disabled>
  165. </div>
  166. <div class="input-group mb-3">
  167. <div class="input-group-prepend">
  168. <span class="input-group-text" id="inputGroup-sizing-default">Name Dynamic Definition</span>
  169. </div>
  170. <input type="text" class="form-control" aria-label="Default"
  171. aria-describedby="inputGroup-sizing-default" v-model="dynNode.name" v-bind:key="'...'">
  172. </div>
  173. <div class="input-group mb-3">
  174. <div class="input-group-prepend">
  175. <span class="input-group-text" id="inputGroup-sizing-default">Update Interval in ms</span>
  176. </div>
  177. <input type="text" class="form-control" aria-label="Default"
  178. aria-describedby="inputGroup-sizing-default" v-model="dynNode.checkInterval" v-bind:key="1000">
  179. </div>
  180. <div class="input-group mb-3">
  181. <div class="input-group-prepend">
  182. <span class="input-group-text" id="inputGroup-sizing-default">NodeVersion</span>
  183. </div>
  184. <input type="text" class="form-control" aria-label="Default"
  185. aria-describedby="inputGroup-sizing-default" :value="getNodeVersion(selectedNode.nodeId.toString(), dynNode)" disabled>
  186. </div>
  187. <div class="input-group mb-3">
  188. <div class="input-group-prepend">
  189. <span class="input-group-text" id="inputGroup-sizing-default">Reference</span>
  190. </div>
  191. <select class="form-select" aria-label="Default select example">
  192. <option v-for="option in getRefTypes()" :value="option.nodeId.toString()" v-bind:key="option.nodeId.toString()">
  193. {{ option.displayName }}
  194. </option>
  195. </select>
  196. </div>
  197. <div class="input-group mb-3">
  198. <div class="input-group-prepend">
  199. <span class="input-group-text" id="inputGroup-sizing-default">Ident</span>
  200. </div>
  201. <input type="text" class="form-control" aria-label="Default"
  202. aria-describedby="inputGroup-sizing-default" v-model="dynNode.ident" v-bind:key="'...'">
  203. </div>
  204. <div class="input-group mb-3">
  205. <div class="input-group-prepend">
  206. <input type="checkbox" id="checkbox" v-model="checked" />
  207. <label for="checkbox">{{ defType(checked) }}</label>
  208. </div>
  209. </div>
  210. <div class="input-group mb-3">
  211. <div class="input-group-prepend">
  212. <span class="input-group-text" id="inputGroup-sizing-default">Type Definition</span>
  213. </div>
  214. <select v-model="typedef" class="form-select" aria-label="Default select example" >
  215. <option v-for="option1 in getObjTypes(checked)" :value="option1.nodeId.toString()" v-bind:key="option1.nodeId.toString()">
  216. {{ option1.displayName }}
  217. </option>
  218. </select>
  219. </div>
  220. <div class="input-group mb-3">
  221. <ul class="no-bullets"><b>Mandatory Components</b>
  222. <li v-for="item of getComponents(typedef).mandatory">
  223. <input type="checkbox" id="checkbox-digg-{{ item }}" :checked="true" :disabled="true">
  224. <label for="checkbox-digg-{{ item}}">{{ item}}</label>
  225. </li>
  226. </ul>
  227. </div>
  228. <div>
  229. <ul class="no-bullets"><b>Optional Components</b>
  230. <li v-for="(item1,index) of getComponents(typedef).optionals" :key="typedef">
  231. <input type="checkbox" id="checkbox-digg-{{ item1 }}" v-model="dynNode.o_check![index]" :value="item1" :checked="dynNode.o_check![index]">
  232. <label for="checkbox-digg-{{ item1 }}">{{ item1 }}</label>
  233. </li>
  234. </ul>
  235. </div>
  236. <div>
  237. <button class="btn btn-light" @click.prevent="createDynamic()">OK</button>
  238. </div>
  239. </div>
  240. </div>
  241. </div>
  242. </template>
  243. <style scoped>
  244. ul.no-bullets {
  245. list-style-type: none;
  246. margin: 0;
  247. padding: 0;
  248. }
  249. </style>