@flowuent-org/diagramming-core 1.0.5

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 (838) hide show
  1. package/.editorconfig +13 -0
  2. package/.eslintignore +1 -0
  3. package/.eslintrc.json +35 -0
  4. package/.prettierignore +4 -0
  5. package/.prettierrc +3 -0
  6. package/.vscode/settings.json +6 -0
  7. package/README.md +95 -0
  8. package/apps/authentication/tsconfig.app.json +23 -0
  9. package/apps/authentication/tsconfig.json +21 -0
  10. package/apps/authentication/tsconfig.spec.json +28 -0
  11. package/apps/authentication/vite.config.ts +0 -0
  12. package/apps/diagramming/.eslintrc.json +18 -0
  13. package/apps/diagramming/index.html +16 -0
  14. package/apps/diagramming/project.json +53 -0
  15. package/apps/diagramming/public/aws-icons/compute/App Runner.svg +18 -0
  16. package/apps/diagramming/public/aws-icons/compute/Application Auto Scaling.svg +18 -0
  17. package/apps/diagramming/public/aws-icons/compute/Batch.svg +18 -0
  18. package/apps/diagramming/public/aws-icons/compute/Bottlerocket.svg +20 -0
  19. package/apps/diagramming/public/aws-icons/compute/Compute Optimizer.svg +18 -0
  20. package/apps/diagramming/public/aws-icons/compute/EC2 Auto Scaling.svg +18 -0
  21. package/apps/diagramming/public/aws-icons/compute/EC2 Image Builder.svg +18 -0
  22. package/apps/diagramming/public/aws-icons/compute/EC2.svg +18 -0
  23. package/apps/diagramming/public/aws-icons/compute/Elastic Beanstalk.svg +18 -0
  24. package/apps/diagramming/public/aws-icons/compute/Elastic Fabric Adapter.svg +18 -0
  25. package/apps/diagramming/public/aws-icons/compute/Fargate.svg +20 -0
  26. package/apps/diagramming/public/aws-icons/compute/Genomics CLI.svg +18 -0
  27. package/apps/diagramming/public/aws-icons/compute/Lambda.svg +18 -0
  28. package/apps/diagramming/public/aws-icons/compute/Local Zones.svg +18 -0
  29. package/apps/diagramming/public/aws-icons/compute/NICE DCV.svg +18 -0
  30. package/apps/diagramming/public/aws-icons/compute/NICE EnginFrame.svg +18 -0
  31. package/apps/diagramming/public/aws-icons/compute/Nitro Enclaves.svg +18 -0
  32. package/apps/diagramming/public/aws-icons/compute/Outposts family.svg +18 -0
  33. package/apps/diagramming/public/aws-icons/compute/Outposts rack.svg +18 -0
  34. package/apps/diagramming/public/aws-icons/compute/Outposts servers.svg +18 -0
  35. package/apps/diagramming/public/aws-icons/compute/ParallelCluster.svg +18 -0
  36. package/apps/diagramming/public/aws-icons/compute/Serverless Application Repository.svg +18 -0
  37. package/apps/diagramming/public/aws-icons/compute/SimSpace Weaver.svg +18 -0
  38. package/apps/diagramming/public/aws-icons/compute/Thinkbox Deadline.svg +18 -0
  39. package/apps/diagramming/public/aws-icons/compute/Thinkbox Frost.svg +18 -0
  40. package/apps/diagramming/public/aws-icons/compute/Thinkbox Sequoia.svg +18 -0
  41. package/apps/diagramming/public/aws-icons/compute/Thinkbox Stoke.svg +18 -0
  42. package/apps/diagramming/public/aws-icons/compute/Thinkbox XMesh.svg +18 -0
  43. package/apps/diagramming/public/aws-icons/compute/VMware Cloud on AWS.svg +18 -0
  44. package/apps/diagramming/public/aws-icons/compute/Wavelength.svg +18 -0
  45. package/apps/diagramming/public/aws-icons/container/ECS Anywhere.svg +18 -0
  46. package/apps/diagramming/public/aws-icons/container/EKS Anywhere.svg +18 -0
  47. package/apps/diagramming/public/aws-icons/container/EKS Cloud.svg +18 -0
  48. package/apps/diagramming/public/aws-icons/container/EKS Distro.svg +18 -0
  49. package/apps/diagramming/public/aws-icons/container/Elastic Container Registry.svg +18 -0
  50. package/apps/diagramming/public/aws-icons/container/Elastic Container Service.svg +18 -0
  51. package/apps/diagramming/public/aws-icons/container/Elastic Kubernetes Service.svg +18 -0
  52. package/apps/diagramming/public/aws-icons/container/Fargate.svg +20 -0
  53. package/apps/diagramming/public/aws-icons/container/Red Hat OpenShift Service on AWS.svg +18 -0
  54. package/apps/diagramming/public/aws-icons/database/Aurora.svg +18 -0
  55. package/apps/diagramming/public/aws-icons/database/Database Migration Service.svg +18 -0
  56. package/apps/diagramming/public/aws-icons/database/DocumentDB.svg +18 -0
  57. package/apps/diagramming/public/aws-icons/database/ElastiCache.svg +18 -0
  58. package/apps/diagramming/public/aws-icons/database/Keyspaces.svg +16 -0
  59. package/apps/diagramming/public/aws-icons/database/MemoryDB for Redis.svg +18 -0
  60. package/apps/diagramming/public/aws-icons/database/Neptune.svg +18 -0
  61. package/apps/diagramming/public/aws-icons/database/RDS on VMware.svg +18 -0
  62. package/apps/diagramming/public/aws-icons/database/RDS.svg +18 -0
  63. package/apps/diagramming/public/aws-icons/database/Timestream.svg +18 -0
  64. package/apps/diagramming/public/aws-icons/networking/App Mesh.svg +18 -0
  65. package/apps/diagramming/public/aws-icons/networking/Client VPN.svg +18 -0
  66. package/apps/diagramming/public/aws-icons/networking/Cloud Directory.svg +18 -0
  67. package/apps/diagramming/public/aws-icons/networking/Cloud Map.svg +18 -0
  68. package/apps/diagramming/public/aws-icons/networking/Cloud WAN.svg +18 -0
  69. package/apps/diagramming/public/aws-icons/networking/CloudFront.svg +18 -0
  70. package/apps/diagramming/public/aws-icons/networking/Direct Connect.svg +18 -0
  71. package/apps/diagramming/public/aws-icons/networking/Elastic Load Balancing.svg +18 -0
  72. package/apps/diagramming/public/aws-icons/networking/Global Accelerator.svg +18 -0
  73. package/apps/diagramming/public/aws-icons/networking/Private 5G.svg +18 -0
  74. package/apps/diagramming/public/aws-icons/networking/PrivateLink.svg +18 -0
  75. package/apps/diagramming/public/aws-icons/networking/Route 53.svg +18 -0
  76. package/apps/diagramming/public/aws-icons/networking/Site to Site VPN.svg +18 -0
  77. package/apps/diagramming/public/aws-icons/networking/Transit Gateway.svg +18 -0
  78. package/apps/diagramming/public/aws-icons/networking/VPC Lattice.svg +18 -0
  79. package/apps/diagramming/public/aws-icons/networking/Verified Access.svg +18 -0
  80. package/apps/diagramming/public/aws-icons/networking/Virtual Private Cloud.svg +18 -0
  81. package/apps/diagramming/public/aws-icons/security/Artifact.svg +18 -0
  82. package/apps/diagramming/public/aws-icons/security/Audit Manager.svg +18 -0
  83. package/apps/diagramming/public/aws-icons/security/Certificate Manager.svg +18 -0
  84. package/apps/diagramming/public/aws-icons/security/CloudHSM.svg +18 -0
  85. package/apps/diagramming/public/aws-icons/security/Cognito.svg +18 -0
  86. package/apps/diagramming/public/aws-icons/security/Detective.svg +18 -0
  87. package/apps/diagramming/public/aws-icons/security/Directory Service.svg +18 -0
  88. package/apps/diagramming/public/aws-icons/security/Firewall Manager.svg +18 -0
  89. package/apps/diagramming/public/aws-icons/security/GuardDuty.svg +18 -0
  90. package/apps/diagramming/public/aws-icons/security/IAM Identity Center.svg +18 -0
  91. package/apps/diagramming/public/aws-icons/security/Identity and Access Management.svg +18 -0
  92. package/apps/diagramming/public/aws-icons/security/Inspector.svg +18 -0
  93. package/apps/diagramming/public/aws-icons/security/Key Management Service.svg +18 -0
  94. package/apps/diagramming/public/aws-icons/security/Macie.svg +18 -0
  95. package/apps/diagramming/public/aws-icons/security/Network Firewall.svg +18 -0
  96. package/apps/diagramming/public/aws-icons/security/Private Certificate Authority.svg +1 -0
  97. package/apps/diagramming/public/aws-icons/security/Resource Access Manager.svg +18 -0
  98. package/apps/diagramming/public/aws-icons/security/Secrets Manager.svg +18 -0
  99. package/apps/diagramming/public/aws-icons/security/Security Hub.svg +18 -0
  100. package/apps/diagramming/public/aws-icons/security/Security Lake.svg +18 -0
  101. package/apps/diagramming/public/aws-icons/security/Shield.svg +18 -0
  102. package/apps/diagramming/public/aws-icons/security/Signer.svg +18 -0
  103. package/apps/diagramming/public/aws-icons/security/Verified Permissions.svg +18 -0
  104. package/apps/diagramming/public/aws-icons/security/WAF.svg +18 -0
  105. package/apps/diagramming/public/aws-icons/storage/Backup.svg +18 -0
  106. package/apps/diagramming/public/aws-icons/storage/EFS.svg +18 -0
  107. package/apps/diagramming/public/aws-icons/storage/Elastic Block Store.svg +18 -0
  108. package/apps/diagramming/public/aws-icons/storage/Elastic Disaster Recovery.svg +16 -0
  109. package/apps/diagramming/public/aws-icons/storage/FSx for Lustre.svg +18 -0
  110. package/apps/diagramming/public/aws-icons/storage/FSx for NetApp ONTAP.svg +18 -0
  111. package/apps/diagramming/public/aws-icons/storage/FSx for OpenZFS.svg +18 -0
  112. package/apps/diagramming/public/aws-icons/storage/FSx for WFS.svg +18 -0
  113. package/apps/diagramming/public/aws-icons/storage/FSx.svg +18 -0
  114. package/apps/diagramming/public/aws-icons/storage/File Cache.svg +18 -0
  115. package/apps/diagramming/public/aws-icons/storage/S3 on Outposts.svg +18 -0
  116. package/apps/diagramming/public/aws-icons/storage/Simple Storage Service Glacier.svg +18 -0
  117. package/apps/diagramming/public/aws-icons/storage/Simple Storage Service.svg +18 -0
  118. package/apps/diagramming/public/aws-icons/storage/Snowball Edge.svg +18 -0
  119. package/apps/diagramming/public/aws-icons/storage/Snowball.svg +18 -0
  120. package/apps/diagramming/public/aws-icons/storage/Snowcone.svg +18 -0
  121. package/apps/diagramming/public/aws-icons/storage/Snowmobile.svg +18 -0
  122. package/apps/diagramming/public/aws-icons/storage/Storage Gateway.svg +18 -0
  123. package/apps/diagramming/public/azure-icons/compute/00195-icon-service-Maintenance-Configuration.svg +1 -0
  124. package/apps/diagramming/public/azure-icons/compute/00328-icon-service-Host-Pools.svg +1 -0
  125. package/apps/diagramming/public/azure-icons/compute/00329-icon-service-Application-Group.svg +1 -0
  126. package/apps/diagramming/public/azure-icons/compute/00330-icon-service-Workspaces.svg +1 -0
  127. package/apps/diagramming/public/azure-icons/compute/00398-icon-service-Disk-Encryption-Sets.svg +1 -0
  128. package/apps/diagramming/public/azure-icons/compute/00400-icon-service-Workspaces.svg +1 -0
  129. package/apps/diagramming/public/azure-icons/compute/02112-icon-service-Automanaged-VM.svg +2 -0
  130. package/apps/diagramming/public/azure-icons/compute/02370-icon-service-Managed-Service-Fabric.svg +1 -0
  131. package/apps/diagramming/public/azure-icons/compute/02409-icon-service-Metrics-Advisor.svg +1 -0
  132. package/apps/diagramming/public/azure-icons/compute/02634-icon-service-Image-Templates.svg +1 -0
  133. package/apps/diagramming/public/azure-icons/compute/02817-icon-service-Restore-Points.svg +1 -0
  134. package/apps/diagramming/public/azure-icons/compute/02818-icon-service-Restore-Points-Collections.svg +1 -0
  135. package/apps/diagramming/public/azure-icons/compute/02864-icon-service-Azure-Compute-Galleries.svg +1 -0
  136. package/apps/diagramming/public/azure-icons/compute/03487-icon-service-Compute-Fleet.svg +1 -0
  137. package/apps/diagramming/public/azure-icons/compute/03543-icon-service-AKS-Automatic.svg +1 -0
  138. package/apps/diagramming/public/azure-icons/compute/10021-icon-service-Virtual-Machine.svg +1 -0
  139. package/apps/diagramming/public/azure-icons/compute/10023-icon-service-Kubernetes-Services.svg +1 -0
  140. package/apps/diagramming/public/azure-icons/compute/10024-icon-service-Mesh-Applications.svg +1 -0
  141. package/apps/diagramming/public/azure-icons/compute/10025-icon-service-Availability-Sets.svg +1 -0
  142. package/apps/diagramming/public/azure-icons/compute/10026-icon-service-Disks-Snapshots.svg +1 -0
  143. package/apps/diagramming/public/azure-icons/compute/10027-icon-service-OS-Images-(Classic).svg +1 -0
  144. package/apps/diagramming/public/azure-icons/compute/10028-icon-service-Virtual-Machines-(Classic).svg +1 -0
  145. package/apps/diagramming/public/azure-icons/compute/10029-icon-service-Function-Apps.svg +1 -0
  146. package/apps/diagramming/public/azure-icons/compute/10030-icon-service-Cloud-Services-(Classic).svg +1 -0
  147. package/apps/diagramming/public/azure-icons/compute/10031-icon-service-Batch-Accounts.svg +1 -0
  148. package/apps/diagramming/public/azure-icons/compute/10032-icon-service-Disks.svg +1 -0
  149. package/apps/diagramming/public/azure-icons/compute/10033-icon-service-Images.svg +1 -0
  150. package/apps/diagramming/public/azure-icons/compute/10034-icon-service-VM-Scale-Sets.svg +1 -0
  151. package/apps/diagramming/public/azure-icons/compute/10035-icon-service-App-Services.svg +1 -0
  152. package/apps/diagramming/public/azure-icons/compute/10036-icon-service-Service-Fabric-Clusters.svg +1 -0
  153. package/apps/diagramming/public/azure-icons/compute/10037-icon-service-Image-Definitions.svg +1 -0
  154. package/apps/diagramming/public/azure-icons/compute/10038-icon-service-Image-Versions.svg +1 -0
  155. package/apps/diagramming/public/azure-icons/compute/10039-icon-service-Shared-Image-Galleries.svg +1 -0
  156. package/apps/diagramming/public/azure-icons/compute/10040-icon-service-VM-Images-(Classic).svg +1 -0
  157. package/apps/diagramming/public/azure-icons/compute/10041-icon-service-Disks-(Classic).svg +1 -0
  158. package/apps/diagramming/public/azure-icons/compute/10049-icon-service-Container-Services-(Deprecated).svg +1 -0
  159. package/apps/diagramming/public/azure-icons/compute/10104-icon-service-Container-Instances.svg +1 -0
  160. package/apps/diagramming/public/azure-icons/compute/10346-icon-service-Host-Groups.svg +1 -0
  161. package/apps/diagramming/public/azure-icons/compute/10347-icon-service-Hosts.svg +1 -0
  162. package/apps/diagramming/public/azure-icons/compute/10370-icon-service-Azure-Spring-Apps.svg +1 -0
  163. package/apps/diagramming/public/azure-icons/containers/03331-icon-service-Azure-Red-Hat-OpenShift.svg +1 -0
  164. package/apps/diagramming/public/azure-icons/containers/10023-icon-service-Kubernetes-Services.svg +1 -0
  165. package/apps/diagramming/public/azure-icons/containers/10031-icon-service-Batch-Accounts.svg +1 -0
  166. package/apps/diagramming/public/azure-icons/containers/10035-icon-service-App-Services.svg +1 -0
  167. package/apps/diagramming/public/azure-icons/containers/10036-icon-service-Service-Fabric-Clusters.svg +1 -0
  168. package/apps/diagramming/public/azure-icons/containers/10104-icon-service-Container-Instances.svg +1 -0
  169. package/apps/diagramming/public/azure-icons/containers/10105-icon-service-Container-Registries.svg +1 -0
  170. package/apps/diagramming/public/azure-icons/databases/00036-icon-service-SQL-Data-Warehouses.svg +1 -0
  171. package/apps/diagramming/public/azure-icons/databases/00606-icon-service-Azure-Synapse-Analytics.svg +1 -0
  172. package/apps/diagramming/public/azure-icons/databases/02390-icon-service-Azure-SQL.svg +2 -0
  173. package/apps/diagramming/public/azure-icons/databases/02392-icon-service-SSIS-Lift-And-Shift-IR.svg +2 -0
  174. package/apps/diagramming/public/azure-icons/databases/02517-icon-service-Azure-Purview-Accounts.svg +1 -0
  175. package/apps/diagramming/public/azure-icons/databases/02750-icon-service-Azure-SQL-Edge.svg +1 -0
  176. package/apps/diagramming/public/azure-icons/databases/02827-icon-service-Azure-Database-PostgreSQL-Server-Group.svg +1 -0
  177. package/apps/diagramming/public/azure-icons/databases/03490-icon-service-Oracle-Database.svg +1 -0
  178. package/apps/diagramming/public/azure-icons/databases/10121-icon-service-Azure-Cosmos-DB.svg +1 -0
  179. package/apps/diagramming/public/azure-icons/databases/10122-icon-service-Azure-Database-MySQL-Server.svg +1 -0
  180. package/apps/diagramming/public/azure-icons/databases/10123-icon-service-Azure-Database-MariaDB-Server.svg +1 -0
  181. package/apps/diagramming/public/azure-icons/databases/10124-icon-service-Azure-SQL-VM.svg +1 -0
  182. package/apps/diagramming/public/azure-icons/databases/10126-icon-service-Data-Factories.svg +1 -0
  183. package/apps/diagramming/public/azure-icons/databases/10127-icon-service-Virtual-Clusters.svg +1 -0
  184. package/apps/diagramming/public/azure-icons/databases/10128-icon-service-Elastic-Job-Agents.svg +1 -0
  185. package/apps/diagramming/public/azure-icons/databases/10130-icon-service-SQL-Database.svg +1 -0
  186. package/apps/diagramming/public/azure-icons/databases/10131-icon-service-Azure-Database-PostgreSQL-Server.svg +1 -0
  187. package/apps/diagramming/public/azure-icons/databases/10132-icon-service-SQL-Server.svg +1 -0
  188. package/apps/diagramming/public/azure-icons/databases/10133-icon-service-Azure-Database-Migration-Services.svg +1 -0
  189. package/apps/diagramming/public/azure-icons/databases/10134-icon-service-SQL-Elastic-Pools.svg +1 -0
  190. package/apps/diagramming/public/azure-icons/databases/10135-icon-service-Managed-Database.svg +1 -0
  191. package/apps/diagramming/public/azure-icons/databases/10136-icon-service-SQL-Managed-Instance.svg +1 -0
  192. package/apps/diagramming/public/azure-icons/databases/10137-icon-service-Azure-SQL-Server-Stretch-Databases.svg +1 -0
  193. package/apps/diagramming/public/azure-icons/databases/10137-icon-service-Cache-Redis.svg +1 -0
  194. package/apps/diagramming/public/azure-icons/databases/10139-icon-service-Instance-Pools.svg +1 -0
  195. package/apps/diagramming/public/azure-icons/databases/10145-icon-service-Azure-Data-Explorer-Clusters.svg +1 -0
  196. package/apps/diagramming/public/azure-icons/databases/10351-icon-service-SQL-Server-Registries.svg +1 -0
  197. package/apps/diagramming/public/azure-icons/networking/00056-icon-service-CDN-Profiles.svg +1 -0
  198. package/apps/diagramming/public/azure-icons/networking/00271-icon-service-Azure-Firewall-Manager.svg +1 -0
  199. package/apps/diagramming/public/azure-icons/networking/00272-icon-service-Azure-Firewall-Policy.svg +1 -0
  200. package/apps/diagramming/public/azure-icons/networking/00427-icon-service-Private-Link.svg +1 -0
  201. package/apps/diagramming/public/azure-icons/networking/00701-icon-service-IP-Groups.svg +1 -0
  202. package/apps/diagramming/public/azure-icons/networking/00860-icon-service-Virtual-WAN-Hub.svg +1 -0
  203. package/apps/diagramming/public/azure-icons/networking/01105-icon-service-Private-Link-Service.svg +1 -0
  204. package/apps/diagramming/public/azure-icons/networking/02145-icon-service-Resource-Management-Private-Link.svg +2 -0
  205. package/apps/diagramming/public/azure-icons/networking/02209-icon-service-Private-Link-Services.svg +1 -0
  206. package/apps/diagramming/public/azure-icons/networking/02302-icon-service-Load-Balancer-Hub.svg +1 -0
  207. package/apps/diagramming/public/azure-icons/networking/02422-icon-service-Bastions.svg +1 -0
  208. package/apps/diagramming/public/azure-icons/networking/02496-icon-service-Virtual-Router.svg +1 -0
  209. package/apps/diagramming/public/azure-icons/networking/02509-icon-service-Connected-Cache.svg +1 -0
  210. package/apps/diagramming/public/azure-icons/networking/02692-icon-service-Spot-VMSS.svg +1 -0
  211. package/apps/diagramming/public/azure-icons/networking/02695-icon-service-Spot-VM.svg +1 -0
  212. package/apps/diagramming/public/azure-icons/networking/02742-icon-service-Subnet.svg +1 -0
  213. package/apps/diagramming/public/azure-icons/networking/02882-icon-service-DNS-Private-Resolver.svg +1 -0
  214. package/apps/diagramming/public/azure-icons/networking/03311-icon-service-Azure-Communications-Gateway.svg +1 -0
  215. package/apps/diagramming/public/azure-icons/networking/03328-icon-service-Application-Gateway-Containers.svg +1 -0
  216. package/apps/diagramming/public/azure-icons/networking/03368-icon-service-DNS-Security-Policy.svg +1 -0
  217. package/apps/diagramming/public/azure-icons/networking/03459-icon-service-DNS-Multistack.svg +1 -0
  218. package/apps/diagramming/public/azure-icons/networking/03460-icon-service-ATM-Multistack.svg +1 -0
  219. package/apps/diagramming/public/azure-icons/networking/03461-icon-service-IP-Address-manager.svg +1 -0
  220. package/apps/diagramming/public/azure-icons/networking/10061-icon-service-Virtual-Networks.svg +1 -0
  221. package/apps/diagramming/public/azure-icons/networking/10062-icon-service-Load-Balancers.svg +1 -0
  222. package/apps/diagramming/public/azure-icons/networking/10063-icon-service-Virtual-Network-Gateways.svg +1 -0
  223. package/apps/diagramming/public/azure-icons/networking/10064-icon-service-DNS-Zones.svg +1 -0
  224. package/apps/diagramming/public/azure-icons/networking/10065-icon-service-Traffic-Manager-Profiles.svg +1 -0
  225. package/apps/diagramming/public/azure-icons/networking/10066-icon-service-Network-Watcher.svg +1 -0
  226. package/apps/diagramming/public/azure-icons/networking/10067-icon-service-Network-Security-Groups.svg +1 -0
  227. package/apps/diagramming/public/azure-icons/networking/10068-icon-service-Public-IP-Addresses-(Classic).svg +1 -0
  228. package/apps/diagramming/public/azure-icons/networking/10069-icon-service-Public-IP-Addresses.svg +1 -0
  229. package/apps/diagramming/public/azure-icons/networking/10070-icon-service-On-Premises-Data-Gateways.svg +1 -0
  230. package/apps/diagramming/public/azure-icons/networking/10071-icon-service-Route-Filters.svg +1 -0
  231. package/apps/diagramming/public/azure-icons/networking/10072-icon-service-DDoS-Protection-Plans.svg +1 -0
  232. package/apps/diagramming/public/azure-icons/networking/10073-icon-service-Front-Door-and-CDN-Profiles.svg +1 -0
  233. package/apps/diagramming/public/azure-icons/networking/10075-icon-service-Virtual-Networks-(Classic).svg +1 -0
  234. package/apps/diagramming/public/azure-icons/networking/10076-icon-service-Application-Gateways.svg +1 -0
  235. package/apps/diagramming/public/azure-icons/networking/10077-icon-service-Local-Network-Gateways.svg +1 -0
  236. package/apps/diagramming/public/azure-icons/networking/10079-icon-service-ExpressRoute-Circuits.svg +1 -0
  237. package/apps/diagramming/public/azure-icons/networking/10080-icon-service-Network-Interfaces.svg +1 -0
  238. package/apps/diagramming/public/azure-icons/networking/10081-icon-service-Connections.svg +1 -0
  239. package/apps/diagramming/public/azure-icons/networking/10082-icon-service-Route-Tables.svg +1 -0
  240. package/apps/diagramming/public/azure-icons/networking/10084-icon-service-Firewalls.svg +1 -0
  241. package/apps/diagramming/public/azure-icons/networking/10085-icon-service-Service-Endpoint-Policies.svg +1 -0
  242. package/apps/diagramming/public/azure-icons/networking/10310-icon-service-NAT.svg +1 -0
  243. package/apps/diagramming/public/azure-icons/networking/10353-icon-service-Virtual-WANs.svg +1 -0
  244. package/apps/diagramming/public/azure-icons/networking/10362-icon-service-Web-Application-Firewall-Policies(WAF).svg +1 -0
  245. package/apps/diagramming/public/azure-icons/networking/10365-icon-service-Proximity-Placement-Groups.svg +1 -0
  246. package/apps/diagramming/public/azure-icons/networking/10371-icon-service-Reserved-IP-Addresses-(Classic).svg +1 -0
  247. package/apps/diagramming/public/azure-icons/networking/10372-icon-service-Public-IP-Prefixes.svg +1 -0
  248. package/apps/diagramming/public/azure-icons/security/00378-icon-service-Detonation.svg +1 -0
  249. package/apps/diagramming/public/azure-icons/security/02247-icon-service-Microsoft-Defender-for-IoT.svg +2 -0
  250. package/apps/diagramming/public/azure-icons/security/03336-icon-service-Microsoft-Defender-EASM.svg +1 -0
  251. package/apps/diagramming/public/azure-icons/security/03340-icon-service-Identity-Secure-Score.svg +1 -0
  252. package/apps/diagramming/public/azure-icons/security/03341-icon-service-Entra-Identity-Risky-Signins.svg +1 -0
  253. package/apps/diagramming/public/azure-icons/security/03342-icon-service-Entra-Identity-Risky-Users.svg +1 -0
  254. package/apps/diagramming/public/azure-icons/security/03344-icon-service-Multifactor-Authentication.svg +1 -0
  255. package/apps/diagramming/public/azure-icons/security/10229-icon-service-Azure-Information-Protection.svg +1 -0
  256. package/apps/diagramming/public/azure-icons/security/10233-icon-service-Conditional-Access.svg +1 -0
  257. package/apps/diagramming/public/azure-icons/security/10241-icon-service-Microsoft-Defender-for-Cloud.svg +1 -0
  258. package/apps/diagramming/public/azure-icons/security/10244-icon-service-Application-Security-Groups.svg +1 -0
  259. package/apps/diagramming/public/azure-icons/security/10245-icon-service-Key-Vaults.svg +1 -0
  260. package/apps/diagramming/public/azure-icons/security/10248-icon-service-Azure-Sentinel.svg +1 -0
  261. package/apps/diagramming/public/azure-icons/security/10433-icon-service-User-Settings.svg +1 -0
  262. package/apps/diagramming/public/azure-icons/security/10572-icon-service-ExtendedSecurityUpdates.svg +1 -0
  263. package/apps/diagramming/public/azure-icons/storage/00017-icon-service-Recovery-Services-Vaults.svg +1 -0
  264. package/apps/diagramming/public/azure-icons/storage/00691-icon-service-Azure-Databox-Gateway.svg +1 -0
  265. package/apps/diagramming/public/azure-icons/storage/00776-icon-service-Azure-HCP-Cache.svg +1 -0
  266. package/apps/diagramming/public/azure-icons/storage/03502-icon-service-Storage-Actions.svg +1 -0
  267. package/apps/diagramming/public/azure-icons/storage/03549-icon-service-Managed-File-Shares.svg +1 -0
  268. package/apps/diagramming/public/azure-icons/storage/10086-icon-service-Storage-Accounts.svg +1 -0
  269. package/apps/diagramming/public/azure-icons/storage/10087-icon-service-Storage-Accounts-(Classic).svg +1 -0
  270. package/apps/diagramming/public/azure-icons/storage/10089-icon-service-StorSimple-Device-Managers.svg +1 -0
  271. package/apps/diagramming/public/azure-icons/storage/10090-icon-service-Data-Lake-Storage-Gen1.svg +1 -0
  272. package/apps/diagramming/public/azure-icons/storage/10091-icon-service-Storage-Explorer.svg +1 -0
  273. package/apps/diagramming/public/azure-icons/storage/10092-icon-service-StorSimple-Data-Managers.svg +1 -0
  274. package/apps/diagramming/public/azure-icons/storage/10093-icon-service-Storage-Sync-Services.svg +1 -0
  275. package/apps/diagramming/public/azure-icons/storage/10094-icon-service-Data-Box.svg +1 -0
  276. package/apps/diagramming/public/azure-icons/storage/10095-icon-service-Azure-Stack-Edge.svg +1 -0
  277. package/apps/diagramming/public/azure-icons/storage/10096-icon-service-Azure-NetApp-Files.svg +1 -0
  278. package/apps/diagramming/public/azure-icons/storage/10097-icon-service-Data-Share-Invitations.svg +1 -0
  279. package/apps/diagramming/public/azure-icons/storage/10098-icon-service-Data-Shares.svg +1 -0
  280. package/apps/diagramming/public/azure-icons/storage/10100-icon-service-Import-Export-Jobs.svg +1 -0
  281. package/apps/diagramming/public/azure-icons/storage/10400-icon-service-Azure-Fileshares.svg +1 -0
  282. package/apps/diagramming/public/block.png +0 -0
  283. package/apps/diagramming/public/common/users.svg +7 -0
  284. package/apps/diagramming/public/favicon.ico +0 -0
  285. package/apps/diagramming/public/gcp-icons/compute/appengine.svg +1 -0
  286. package/apps/diagramming/public/gcp-icons/compute/cloud-functions.svg +1 -0
  287. package/apps/diagramming/public/gcp-icons/compute/cloud-gpu.svg +1 -0
  288. package/apps/diagramming/public/gcp-icons/compute/compute-engine.svg +1 -0
  289. package/apps/diagramming/public/gcp-icons/compute/container-optimized-os.svg +1 -0
  290. package/apps/diagramming/public/gcp-icons/database&storage/cloud-bigtable.svg +1 -0
  291. package/apps/diagramming/public/gcp-icons/database&storage/cloud-spanner.svg +1 -0
  292. package/apps/diagramming/public/gcp-icons/database&storage/cloud-sql.svg +1 -0
  293. package/apps/diagramming/public/gcp-icons/database&storage/cloud-storage.svg +1 -0
  294. package/apps/diagramming/public/gcp-icons/database&storage/filestore.svg +1 -0
  295. package/apps/diagramming/public/gcp-icons/networking/cloud-cdn.svg +1 -0
  296. package/apps/diagramming/public/gcp-icons/networking/cloud-dns.svg +1 -0
  297. package/apps/diagramming/public/gcp-icons/networking/cloud-firewall-rules.svg +1 -0
  298. package/apps/diagramming/public/gcp-icons/networking/cloud-interconnect.svg +1 -0
  299. package/apps/diagramming/public/gcp-icons/networking/cloud-load-balancing.svg +1 -0
  300. package/apps/diagramming/public/gcp-icons/networking/cloud-network.svg +1 -0
  301. package/apps/diagramming/public/gcp-icons/networking/cloud-router.svg +1 -0
  302. package/apps/diagramming/public/gcp-icons/networking/cloud-routes.svg +1 -0
  303. package/apps/diagramming/public/gcp-icons/networking/cloud-vpn.svg +1 -0
  304. package/apps/diagramming/public/gcp-icons/networking/virtual-private-cloud.svg +1 -0
  305. package/apps/diagramming/public/gcp-icons/security/beyondcorp.svg +1 -0
  306. package/apps/diagramming/public/gcp-icons/security/data-loss-prevention-api.svg +1 -0
  307. package/apps/diagramming/public/gcp-icons/security/iam.svg +1 -0
  308. package/apps/diagramming/public/gcp-icons/security/key-access-justifications.svg +1 -0
  309. package/apps/diagramming/public/gcp-icons/security/security-command-center.svg +1 -0
  310. package/apps/diagramming/public/gcp-icons/security/web-security-scanner.svg +1 -0
  311. package/apps/diagramming/public/sample-node-complete.json +63 -0
  312. package/apps/diagramming/public/sample-node-data.json +63 -0
  313. package/apps/diagramming/public/text.png +0 -0
  314. package/apps/diagramming/src/AutomationDiagramData.ts +541 -0
  315. package/apps/diagramming/src/CollaborationDiagramData.ts +127 -0
  316. package/apps/diagramming/src/CustomIconExamples.ts +233 -0
  317. package/apps/diagramming/src/DiagramTabs.tsx +205 -0
  318. package/apps/diagramming/src/Pages/DevPlayground.tsx +3 -0
  319. package/apps/diagramming/src/Pages/Home.tsx +112 -0
  320. package/apps/diagramming/src/SequenceDiagramData.ts +215 -0
  321. package/apps/diagramming/src/StateMachineDiagramData.ts +64 -0
  322. package/apps/diagramming/src/UseCaseDiagramData.ts +52 -0
  323. package/apps/diagramming/src/cloud-data.ts +371 -0
  324. package/apps/diagramming/src/components/AddNodeView.tsx +252 -0
  325. package/apps/diagramming/src/createSelecors.tsx +17 -0
  326. package/apps/diagramming/src/index.scss +13 -0
  327. package/apps/diagramming/src/main.tsx +463 -0
  328. package/apps/diagramming/src/node-data.ts +664 -0
  329. package/apps/diagramming/src/sample-workflow-content.ts +54 -0
  330. package/apps/diagramming/src/stencil-items.ts +31 -0
  331. package/apps/diagramming/src/style.css +13 -0
  332. package/apps/diagramming/src/tabsStore.tsx +152 -0
  333. package/apps/diagramming/src/vite-env.d.ts +1 -0
  334. package/apps/diagramming/tsconfig.app.json +23 -0
  335. package/apps/diagramming/tsconfig.json +21 -0
  336. package/apps/diagramming/tsconfig.spec.json +28 -0
  337. package/apps/diagramming/vite.config.ts +34 -0
  338. package/apps/diagramming/webpack.config.js +13 -0
  339. package/apps/workflow/.eslintrc.json +18 -0
  340. package/apps/workflow/group/group-form-hooks/index.ts +3 -0
  341. package/apps/workflow/group/group-form-hooks/useFormValidation.ts +20 -0
  342. package/apps/workflow/group/group-form-schema/SettingsTabFormSchema.ts +7 -0
  343. package/apps/workflow/group/group-form-schema/index.ts +3 -0
  344. package/apps/workflow/i18n.ts +19 -0
  345. package/apps/workflow/index.html +16 -0
  346. package/apps/workflow/locales/en/translation.json +713 -0
  347. package/apps/workflow/project.json +8 -0
  348. package/apps/workflow/public/favicon.ico +0 -0
  349. package/apps/workflow/src/app/app.module.css +1 -0
  350. package/apps/workflow/src/app/app.spec.tsx +15 -0
  351. package/apps/workflow/src/app/app.tsx +370 -0
  352. package/apps/workflow/src/assets/.gitkeep +0 -0
  353. package/apps/workflow/src/main.tsx +13 -0
  354. package/apps/workflow/src/styles.css +1 -0
  355. package/apps/workflow/src/theme/index.ts +546 -0
  356. package/apps/workflow/tsconfig.app.json +23 -0
  357. package/apps/workflow/tsconfig.json +21 -0
  358. package/apps/workflow/tsconfig.spec.json +28 -0
  359. package/apps/workflow/vite.config.ts +51 -0
  360. package/nx.json +58 -0
  361. package/package.json +116 -0
  362. package/packages/api/.babelrc +12 -0
  363. package/packages/api/.eslintrc.json +18 -0
  364. package/packages/api/README.md +7 -0
  365. package/packages/api/project.json +8 -0
  366. package/packages/api/src/index.ts +3 -0
  367. package/packages/api/src/lib/jsonPlaceholderService/endpoints.ts +3 -0
  368. package/packages/api/src/lib/jsonPlaceholderService/service.ts +13 -0
  369. package/packages/api/tsconfig.json +17 -0
  370. package/packages/api/tsconfig.lib.json +24 -0
  371. package/packages/atoms/.babelrc +12 -0
  372. package/packages/atoms/.eslintrc.json +18 -0
  373. package/packages/atoms/README.md +7 -0
  374. package/packages/atoms/forms/AuthenticationTabForm/authenticationTabForm.json +224 -0
  375. package/packages/atoms/forms/AuthenticationTabForm/index.tsx +255 -0
  376. package/packages/atoms/forms/SettingsTabForm/index.tsx +85 -0
  377. package/packages/atoms/forms/SettingsTabForm/settingTabForm.json +27 -0
  378. package/packages/atoms/forms/index.ts +4 -0
  379. package/packages/atoms/project.json +8 -0
  380. package/packages/atoms/src/index.ts +33 -0
  381. package/packages/atoms/src/lib/Accordion/Accordion.module.css +7 -0
  382. package/packages/atoms/src/lib/Accordion/Accordion.spec.tsx +13 -0
  383. package/packages/atoms/src/lib/Accordion/Accordion.tsx +29 -0
  384. package/packages/atoms/src/lib/Alert/Alert.module.css +7 -0
  385. package/packages/atoms/src/lib/Alert/Alert.spec.tsx +10 -0
  386. package/packages/atoms/src/lib/Alert/Alert.tsx +19 -0
  387. package/packages/atoms/src/lib/Avatar/Avatar.module.css +7 -0
  388. package/packages/atoms/src/lib/Avatar/Avatar.spec.tsx +10 -0
  389. package/packages/atoms/src/lib/Avatar/Avatar.tsx +22 -0
  390. package/packages/atoms/src/lib/Box/Box.module.css +7 -0
  391. package/packages/atoms/src/lib/Box/Box.spec.tsx +10 -0
  392. package/packages/atoms/src/lib/Box/Box.tsx +19 -0
  393. package/packages/atoms/src/lib/BulkEdit/BulkEdit.module.css +7 -0
  394. package/packages/atoms/src/lib/BulkEdit/BulkEdit.spec.tsx +10 -0
  395. package/packages/atoms/src/lib/BulkEdit/BulkEdit.tsx +15 -0
  396. package/packages/atoms/src/lib/Button/Button.module.css +7 -0
  397. package/packages/atoms/src/lib/Button/Button.spec.tsx +10 -0
  398. package/packages/atoms/src/lib/Button/Button.tsx +78 -0
  399. package/packages/atoms/src/lib/Card/Card.module.css +7 -0
  400. package/packages/atoms/src/lib/Card/Card.spec.tsx +10 -0
  401. package/packages/atoms/src/lib/Card/Card.tsx +19 -0
  402. package/packages/atoms/src/lib/CardContent/CardContent.module.css +7 -0
  403. package/packages/atoms/src/lib/CardContent/CardContent.spec.tsx +10 -0
  404. package/packages/atoms/src/lib/CardContent/CardContent.tsx +22 -0
  405. package/packages/atoms/src/lib/FormTextField/FormTextField.module.css +7 -0
  406. package/packages/atoms/src/lib/FormTextField/FormTextField.spec.tsx +10 -0
  407. package/packages/atoms/src/lib/FormTextField/FormTextField.tsx +35 -0
  408. package/packages/atoms/src/lib/Grid/Grid.module.css +7 -0
  409. package/packages/atoms/src/lib/Grid/Grid.spec.tsx +10 -0
  410. package/packages/atoms/src/lib/Grid/Grid.tsx +19 -0
  411. package/packages/atoms/src/lib/Stack/Stack.module.css +7 -0
  412. package/packages/atoms/src/lib/Stack/Stack.spec.tsx +10 -0
  413. package/packages/atoms/src/lib/Stack/Stack.tsx +19 -0
  414. package/packages/atoms/src/lib/Switch/Switch.module.css +7 -0
  415. package/packages/atoms/src/lib/Switch/Switch.spec.tsx +10 -0
  416. package/packages/atoms/src/lib/Switch/Switch.tsx +46 -0
  417. package/packages/atoms/src/lib/TableView/TableView.module.css +7 -0
  418. package/packages/atoms/src/lib/TableView/TableView.spec.tsx +10 -0
  419. package/packages/atoms/src/lib/TableView/TableView.tsx +88 -0
  420. package/packages/atoms/src/lib/TextField/TextField.module.css +7 -0
  421. package/packages/atoms/src/lib/TextField/TextField.spec.tsx +10 -0
  422. package/packages/atoms/src/lib/TextField/TextField.tsx +17 -0
  423. package/packages/atoms/src/lib/Typography/Typography.module.css +7 -0
  424. package/packages/atoms/src/lib/Typography/Typography.spec.tsx +10 -0
  425. package/packages/atoms/src/lib/Typography/Typography.tsx +22 -0
  426. package/packages/atoms/tsconfig.json +17 -0
  427. package/packages/atoms/tsconfig.lib.json +30 -0
  428. package/packages/common/.babelrc +12 -0
  429. package/packages/common/.eslintrc.json +18 -0
  430. package/packages/common/README.md +7 -0
  431. package/packages/common/project.json +8 -0
  432. package/packages/common/src/index.ts +4 -0
  433. package/packages/common/src/lib/generateRandomProfilePic.ts +3 -0
  434. package/packages/common/src/lib/generateValidationSchema.ts +46 -0
  435. package/packages/common/tsconfig.json +17 -0
  436. package/packages/common/tsconfig.lib.json +24 -0
  437. package/packages/contexts/.babelrc +12 -0
  438. package/packages/contexts/.eslintrc.json +18 -0
  439. package/packages/contexts/README.md +7 -0
  440. package/packages/contexts/project.json +8 -0
  441. package/packages/contexts/src/index.ts +2 -0
  442. package/packages/contexts/tsconfig.json +17 -0
  443. package/packages/contexts/tsconfig.lib.json +24 -0
  444. package/packages/diagrams/.babelrc +12 -0
  445. package/packages/diagrams/.ctirc +208 -0
  446. package/packages/diagrams/.eslintrc.json +17 -0
  447. package/packages/diagrams/CUSTOM_ICONS.md +232 -0
  448. package/packages/diagrams/GOOGLE_SHEETS_IMPLEMENTATION.md +233 -0
  449. package/packages/diagrams/NODE_DATA_UPDATE_API.md +430 -0
  450. package/packages/diagrams/README.md +7 -0
  451. package/packages/diagrams/UNDO_REDO_API.md +306 -0
  452. package/packages/diagrams/package.json +45 -0
  453. package/packages/diagrams/project.json +38 -0
  454. package/packages/diagrams/rollup.config.js +31 -0
  455. package/packages/diagrams/src/DiagramFlow.tsx +7 -0
  456. package/packages/diagrams/src/declarations.d.ts +7 -0
  457. package/packages/diagrams/src/index.ts +113 -0
  458. package/packages/diagrams/src/index.ts.bak +99 -0
  459. package/packages/diagrams/src/lib/assets/markers/markers.param.tsx +101 -0
  460. package/packages/diagrams/src/lib/assets/markers/markers.type.ts +10 -0
  461. package/packages/diagrams/src/lib/atoms/ActorNode.tsx +124 -0
  462. package/packages/diagrams/src/lib/atoms/AddNodeAnchor.tsx +97 -0
  463. package/packages/diagrams/src/lib/atoms/AddParallelColButton.tsx +26 -0
  464. package/packages/diagrams/src/lib/atoms/BendpointNode.tsx +71 -0
  465. package/packages/diagrams/src/lib/atoms/CardBlockTypeSelector.tsx +35 -0
  466. package/packages/diagrams/src/lib/atoms/CardEditableTitle.tsx +76 -0
  467. package/packages/diagrams/src/lib/atoms/CardMainContent.tsx +19 -0
  468. package/packages/diagrams/src/lib/atoms/ContentAssist.tsx +341 -0
  469. package/packages/diagrams/src/lib/atoms/DiagramControls.tsx +57 -0
  470. package/packages/diagrams/src/lib/atoms/ExpressionInput.tsx +437 -0
  471. package/packages/diagrams/src/lib/atoms/FloatingConnectionLine.tsx +73 -0
  472. package/packages/diagrams/src/lib/atoms/LazyIcon.tsx +31 -0
  473. package/packages/diagrams/src/lib/atoms/MarkerSelector.tsx +106 -0
  474. package/packages/diagrams/src/lib/atoms/MultiSelectInput.tsx +87 -0
  475. package/packages/diagrams/src/lib/atoms/ParameterInput.tsx +199 -0
  476. package/packages/diagrams/src/lib/atoms/PropertyInput.tsx +114 -0
  477. package/packages/diagrams/src/lib/atoms/StyledBox.tsx +69 -0
  478. package/packages/diagrams/src/lib/atoms/ValidationError.tsx +37 -0
  479. package/packages/diagrams/src/lib/atoms/ValidationMessage.tsx +63 -0
  480. package/packages/diagrams/src/lib/components/AiButton.tsx +52 -0
  481. package/packages/diagrams/src/lib/components/ControlEdgeList.tsx +304 -0
  482. package/packages/diagrams/src/lib/components/CreateFunctionModal.tsx +265 -0
  483. package/packages/diagrams/src/lib/components/CustomCodeModal.tsx +288 -0
  484. package/packages/diagrams/src/lib/components/DiagramPanel.tsx +331 -0
  485. package/packages/diagrams/src/lib/components/FunctionModalTooltip.tsx +31 -0
  486. package/packages/diagrams/src/lib/components/GraphQLCustomCodeModal.tsx +210 -0
  487. package/packages/diagrams/src/lib/components/Header.tsx +143 -0
  488. package/packages/diagrams/src/lib/components/MiniMapCommon.tsx +24 -0
  489. package/packages/diagrams/src/lib/components/ResizeIcon.tsx +82 -0
  490. package/packages/diagrams/src/lib/components/SideBar.tsx +40 -0
  491. package/packages/diagrams/src/lib/components/automation/AutomationAISuggestionNode.tsx +241 -0
  492. package/packages/diagrams/src/lib/components/automation/AutomationApiNode.tsx +519 -0
  493. package/packages/diagrams/src/lib/components/automation/AutomationEndNode.tsx +318 -0
  494. package/packages/diagrams/src/lib/components/automation/AutomationExecutionPanel.tsx +439 -0
  495. package/packages/diagrams/src/lib/components/automation/AutomationFormattingNode.tsx +557 -0
  496. package/packages/diagrams/src/lib/components/automation/AutomationNoteNode.tsx +168 -0
  497. package/packages/diagrams/src/lib/components/automation/AutomationSheetsNode.tsx +831 -0
  498. package/packages/diagrams/src/lib/components/automation/AutomationStartNode.tsx +319 -0
  499. package/packages/diagrams/src/lib/components/automation/index.ts +8 -0
  500. package/packages/diagrams/src/lib/contexts/CardDataProvider.tsx +111 -0
  501. package/packages/diagrams/src/lib/contexts/DiagramProvider.tsx +375 -0
  502. package/packages/diagrams/src/lib/contexts/diagramStoreTypes.tsx +132 -0
  503. package/packages/diagrams/src/lib/contexts/onConnect.ts +39 -0
  504. package/packages/diagrams/src/lib/contexts/onDragStart.ts +28 -0
  505. package/packages/diagrams/src/lib/contexts/onNodeDragEnd.ts +85 -0
  506. package/packages/diagrams/src/lib/contexts/onNodesChange.ts +385 -0
  507. package/packages/diagrams/src/lib/contexts/onWorkflowNodeDelete.ts +65 -0
  508. package/packages/diagrams/src/lib/contexts/setContentHeight.ts +14 -0
  509. package/packages/diagrams/src/lib/contexts/setDiagramType.ts +10 -0
  510. package/packages/diagrams/src/lib/contexts/setEdgeShapeType.ts +7 -0
  511. package/packages/diagrams/src/lib/contexts/setEdges.ts +9 -0
  512. package/packages/diagrams/src/lib/contexts/setLayoutDirection.ts +9 -0
  513. package/packages/diagrams/src/lib/contexts/setNodeSetting.ts +17 -0
  514. package/packages/diagrams/src/lib/contexts/setNodes.ts +10 -0
  515. package/packages/diagrams/src/lib/contexts/setPannable.ts +7 -0
  516. package/packages/diagrams/src/lib/contexts/setSelectedEdge.ts +7 -0
  517. package/packages/diagrams/src/lib/contexts/setSelectedNode.ts +7 -0
  518. package/packages/diagrams/src/lib/contexts/undo.ts +163 -0
  519. package/packages/diagrams/src/lib/contexts/updateNodeSetting.ts +17 -0
  520. package/packages/diagrams/src/lib/examples/GoogleSheetsConfigurationExamples.ts +306 -0
  521. package/packages/diagrams/src/lib/examples/TwilioWhatsAppConfigExample.ts +128 -0
  522. package/packages/diagrams/src/lib/externals.ts +4 -0
  523. package/packages/diagrams/src/lib/hooks/customUseReactFlow.tsx +90 -0
  524. package/packages/diagrams/src/lib/hooks/updateNodes.ts +45 -0
  525. package/packages/diagrams/src/lib/hooks/useAddChildButton.tsx +61 -0
  526. package/packages/diagrams/src/lib/hooks/useAddSwitchCase.ts +75 -0
  527. package/packages/diagrams/src/lib/hooks/useAutoRegisterFunctions.ts +135 -0
  528. package/packages/diagrams/src/lib/hooks/useAutoRegisterVariables.ts +286 -0
  529. package/packages/diagrams/src/lib/hooks/useDeleteNodeByEvent.ts +64 -0
  530. package/packages/diagrams/src/lib/hooks/useDragCallbacks.tsx +122 -0
  531. package/packages/diagrams/src/lib/hooks/useFormValidation.ts +349 -0
  532. package/packages/diagrams/src/lib/hooks/useFunctionFormCallbacks.ts +136 -0
  533. package/packages/diagrams/src/lib/hooks/useIsSelectedNode.ts +11 -0
  534. package/packages/diagrams/src/lib/hooks/useModalControls.ts +13 -0
  535. package/packages/diagrams/src/lib/hooks/useNodeDragHandlers.ts +43 -0
  536. package/packages/diagrams/src/lib/hooks/useNodeSelection.ts +55 -0
  537. package/packages/diagrams/src/lib/hooks/useRenderDividers.tsx +20 -0
  538. package/packages/diagrams/src/lib/hooks/useRenderPins.tsx +75 -0
  539. package/packages/diagrams/src/lib/hooks/useResizeObserver.ts +21 -0
  540. package/packages/diagrams/src/lib/hooks/useTreeChildNode.ts +536 -0
  541. package/packages/diagrams/src/lib/hooks/useWorkflowNodeActiont.ts +384 -0
  542. package/packages/diagrams/src/lib/molecules/AddingBlock.tsx +147 -0
  543. package/packages/diagrams/src/lib/molecules/AvailableVariablesDisplay.tsx +57 -0
  544. package/packages/diagrams/src/lib/molecules/Block.tsx +143 -0
  545. package/packages/diagrams/src/lib/molecules/BlockProvider.tsx +28 -0
  546. package/packages/diagrams/src/lib/molecules/BlockWrapper.tsx +14 -0
  547. package/packages/diagrams/src/lib/molecules/ConditionRule.tsx +132 -0
  548. package/packages/diagrams/src/lib/molecules/DraggablePane.tsx +198 -0
  549. package/packages/diagrams/src/lib/molecules/EntityNodeBlocks.tsx +66 -0
  550. package/packages/diagrams/src/lib/molecules/SideHandles.tsx +50 -0
  551. package/packages/diagrams/src/lib/molecules/StencilItem.tsx +85 -0
  552. package/packages/diagrams/src/lib/molecules/WorkflowNodeActionButtons.tsx +62 -0
  553. package/packages/diagrams/src/lib/molecules/animated-add-button.tsx +83 -0
  554. package/packages/diagrams/src/lib/molecules/json-viewer.tsx +107 -0
  555. package/packages/diagrams/src/lib/organisms/AddNodeView.tsx +102 -0
  556. package/packages/diagrams/src/lib/organisms/Card/EntityNode.tsx +259 -0
  557. package/packages/diagrams/src/lib/organisms/Card/card.params.ts +29 -0
  558. package/packages/diagrams/src/lib/organisms/Card/card.types.ts +5 -0
  559. package/packages/diagrams/src/lib/organisms/CodeModal.tsx +105 -0
  560. package/packages/diagrams/src/lib/organisms/ConditionRuleGroup.tsx +139 -0
  561. package/packages/diagrams/src/lib/organisms/CustomEdge/EdgeMarkers.tsx +51 -0
  562. package/packages/diagrams/src/lib/organisms/CustomEdge/custom-edge-generator.tsx +130 -0
  563. package/packages/diagrams/src/lib/organisms/CustomEdge/custom-edge.params.ts +6 -0
  564. package/packages/diagrams/src/lib/organisms/CustomEdge/custom-edge.type.ts +15 -0
  565. package/packages/diagrams/src/lib/organisms/CustomEdge/useCreateBendPoint.tsx +119 -0
  566. package/packages/diagrams/src/lib/organisms/CustomEdge/useEdgeModal.ts +37 -0
  567. package/packages/diagrams/src/lib/organisms/CustomEdge/useEdgePath.tsx +99 -0
  568. package/packages/diagrams/src/lib/organisms/DownloadPanel.tsx +345 -0
  569. package/packages/diagrams/src/lib/organisms/EdgeModal.tsx +243 -0
  570. package/packages/diagrams/src/lib/organisms/HistoryPane.tsx +118 -0
  571. package/packages/diagrams/src/lib/organisms/NodeContextMenu.tsx +259 -0
  572. package/packages/diagrams/src/lib/organisms/PropertiesPane.tsx +276 -0
  573. package/packages/diagrams/src/lib/organisms/SmartDynamicForm.tsx +226 -0
  574. package/packages/diagrams/src/lib/organisms/Stencil.tsx +60 -0
  575. package/packages/diagrams/src/lib/organisms/UseDiagramStore.tsx +4 -0
  576. package/packages/diagrams/src/lib/organisms/WorkFlowNode/NodeActionButtons.tsx +45 -0
  577. package/packages/diagrams/src/lib/organisms/WorkFlowNode/NodeTypeDisplay.tsx +26 -0
  578. package/packages/diagrams/src/lib/organisms/WorkflowNode.tsx +484 -0
  579. package/packages/diagrams/src/lib/services/GoogleSheetsService.ts +961 -0
  580. package/packages/diagrams/src/lib/services/SlackService.ts +134 -0
  581. package/packages/diagrams/src/lib/services/TwilioWhatsAppService.ts +273 -0
  582. package/packages/diagrams/src/lib/styles.css +3 -0
  583. package/packages/diagrams/src/lib/templates/DiagramContainer.tsx +17 -0
  584. package/packages/diagrams/src/lib/templates/DiagramContent.tsx +310 -0
  585. package/packages/diagrams/src/lib/templates/Diagramming.tsx +178 -0
  586. package/packages/diagrams/src/lib/templates/PageLinks.tsx +13 -0
  587. package/packages/diagrams/src/lib/templates/arch/ArchDiagram.tsx +793 -0
  588. package/packages/diagrams/src/lib/templates/arch/components/EdgeDialog.tsx +83 -0
  589. package/packages/diagrams/src/lib/templates/arch/components/EdgeSettings.tsx +82 -0
  590. package/packages/diagrams/src/lib/templates/arch/components/GroupControls.tsx +60 -0
  591. package/packages/diagrams/src/lib/templates/arch/components/GroupSizeDialog.tsx +82 -0
  592. package/packages/diagrams/src/lib/templates/arch/components/NodeDialog.tsx +215 -0
  593. package/packages/diagrams/src/lib/templates/arch/components/nodeTypes.ts +92 -0
  594. package/packages/diagrams/src/lib/templates/arch/controls/ArchDiagramControls.tsx +350 -0
  595. package/packages/diagrams/src/lib/templates/arch/data/templatee-data.ts +213 -0
  596. package/packages/diagrams/src/lib/templates/cloud-arch/components/CloudArchitectureDiagram.tsx +3912 -0
  597. package/packages/diagrams/src/lib/templates/cloud-arch/components/FormatConverter.tsx +810 -0
  598. package/packages/diagrams/src/lib/templates/cloud-arch/components/FragmentImporter.tsx +277 -0
  599. package/packages/diagrams/src/lib/templates/cloud-arch/components/PropertiesPanel.tsx +1063 -0
  600. package/packages/diagrams/src/lib/templates/cloud-arch/components/ServiceIconPicker.tsx +138 -0
  601. package/packages/diagrams/src/lib/templates/cloud-arch/components/SettingsSidebar.tsx +657 -0
  602. package/packages/diagrams/src/lib/templates/cloud-arch/components/SubnetSelector.tsx +469 -0
  603. package/packages/diagrams/src/lib/templates/cloud-arch/components/nodes/ServiceNode.tsx +310 -0
  604. package/packages/diagrams/src/lib/templates/cloud-arch/components/nodes/SubnetNode.tsx +475 -0
  605. package/packages/diagrams/src/lib/templates/cloud-arch/components/nodes/UsersNode.tsx +278 -0
  606. package/packages/diagrams/src/lib/templates/cloud-arch/data/diagramManager.ts +365 -0
  607. package/packages/diagrams/src/lib/templates/cloud-arch/data/types.ts +184 -0
  608. package/packages/diagrams/src/lib/templates/cloud-arch/integration/diagramValidator.ts +379 -0
  609. package/packages/diagrams/src/lib/templates/cloud-arch/messages/errorMessages.json +96 -0
  610. package/packages/diagrams/src/lib/templates/cloud-arch/types/localization.ts +369 -0
  611. package/packages/diagrams/src/lib/templates/cloud-arch/types/validation.ts +73 -0
  612. package/packages/diagrams/src/lib/templates/cloud-arch/utils/aws-icons.ts +558 -0
  613. package/packages/diagrams/src/lib/templates/cloud-arch/utils/awsValidation.ts +447 -0
  614. package/packages/diagrams/src/lib/templates/cloud-arch/utils/azure-icons.ts +803 -0
  615. package/packages/diagrams/src/lib/templates/cloud-arch/utils/azureValidation.ts +496 -0
  616. package/packages/diagrams/src/lib/templates/cloud-arch/utils/cloudValidation.ts +930 -0
  617. package/packages/diagrams/src/lib/templates/cloud-arch/utils/errorMessages.ts +284 -0
  618. package/packages/diagrams/src/lib/templates/cloud-arch/utils/gcp-icons.ts +187 -0
  619. package/packages/diagrams/src/lib/templates/cloud-arch/utils/gcpValidation.ts +312 -0
  620. package/packages/diagrams/src/lib/templates/cloud-arch/utils/genericValidation.ts +690 -0
  621. package/packages/diagrams/src/lib/templates/cloud-arch/utils/iconMapping.ts +384 -0
  622. package/packages/diagrams/src/lib/templates/cloud-arch/utils/idGenerator.ts +221 -0
  623. package/packages/diagrams/src/lib/templates/cloud-arch/utils/localizationManager.ts +301 -0
  624. package/packages/diagrams/src/lib/templates/cloud-arch/utils/restrictionEngine.ts +551 -0
  625. package/packages/diagrams/src/lib/templates/cloud-arch/utils/restrictionValidator.ts +401 -0
  626. package/packages/diagrams/src/lib/templates/cloud-arch/utils/serviceIcons.tsx +129 -0
  627. package/packages/diagrams/src/lib/templates/cloud-arch/utils/serviceMapping.ts +331 -0
  628. package/packages/diagrams/src/lib/templates/cloud-arch/utils/translations.ts +55 -0
  629. package/packages/diagrams/src/lib/templates/cloud-arch/utils/validationExtractor.ts +342 -0
  630. package/packages/diagrams/src/lib/templates/collaborationDiagram/CollaborationDiagram.tsx +16 -0
  631. package/packages/diagrams/src/lib/templates/collaborationDiagram/components/AddCollabEdgeDialog.tsx +182 -0
  632. package/packages/diagrams/src/lib/templates/collaborationDiagram/components/CollabLayout.ts +182 -0
  633. package/packages/diagrams/src/lib/templates/collaborationDiagram/components/CollabObjectNodeSettings.tsx +87 -0
  634. package/packages/diagrams/src/lib/templates/collaborationDiagram/components/CollaborationDiagramFlow.tsx +731 -0
  635. package/packages/diagrams/src/lib/templates/collaborationDiagram/components/DraggableEdgeLabel.tsx +124 -0
  636. package/packages/diagrams/src/lib/templates/collaborationDiagram/controls/CollaborationControls.tsx +132 -0
  637. package/packages/diagrams/src/lib/templates/collaborationDiagram/nodes/CollabEdge.tsx +171 -0
  638. package/packages/diagrams/src/lib/templates/collaborationDiagram/nodes/CollabObjectNode.tsx +179 -0
  639. package/packages/diagrams/src/lib/templates/home.style.css +16 -0
  640. package/packages/diagrams/src/lib/templates/node-forms/ApiForm.tsx +416 -0
  641. package/packages/diagrams/src/lib/templates/node-forms/CallForm.tsx +370 -0
  642. package/packages/diagrams/src/lib/templates/node-forms/ForLoopNode.tsx +313 -0
  643. package/packages/diagrams/src/lib/templates/node-forms/FunctionForm.tsx +211 -0
  644. package/packages/diagrams/src/lib/templates/node-forms/GraphQLForm.tsx +679 -0
  645. package/packages/diagrams/src/lib/templates/node-forms/IfNodeForm.tsx +97 -0
  646. package/packages/diagrams/src/lib/templates/node-forms/LetNodeForm.tsx +533 -0
  647. package/packages/diagrams/src/lib/templates/node-forms/LoopNode.tsx +149 -0
  648. package/packages/diagrams/src/lib/templates/node-forms/NodeForm.tsx +383 -0
  649. package/packages/diagrams/src/lib/templates/node-forms/ReturnNodeForm.tsx +96 -0
  650. package/packages/diagrams/src/lib/templates/node-forms/SetNodeForm.tsx +141 -0
  651. package/packages/diagrams/src/lib/templates/node-forms/SwitchNodeForm.tsx +249 -0
  652. package/packages/diagrams/src/lib/templates/node-forms/TryCatchForm.tsx +167 -0
  653. package/packages/diagrams/src/lib/templates/nodeFormSchema.json +84 -0
  654. package/packages/diagrams/src/lib/templates/sequence/SequenceDiagram.tsx +22 -0
  655. package/packages/diagrams/src/lib/templates/sequence/components/ActivationBarNode.tsx +33 -0
  656. package/packages/diagrams/src/lib/templates/sequence/components/AddMessageDialog.tsx +302 -0
  657. package/packages/diagrams/src/lib/templates/sequence/components/CombinedFragmentNode.tsx +65 -0
  658. package/packages/diagrams/src/lib/templates/sequence/components/EntitySettings.tsx +559 -0
  659. package/packages/diagrams/src/lib/templates/sequence/components/FragmentSettings.tsx +116 -0
  660. package/packages/diagrams/src/lib/templates/sequence/components/SequenceComponents.tsx +14 -0
  661. package/packages/diagrams/src/lib/templates/sequence/components/SequenceDiagramFlow.tsx +1361 -0
  662. package/packages/diagrams/src/lib/templates/sequence/components/SequenceEntityNode.tsx +394 -0
  663. package/packages/diagrams/src/lib/templates/sequence/components/SequenceMessageEdge.tsx +272 -0
  664. package/packages/diagrams/src/lib/templates/sequence/components/SimpleEntitySettings.tsx +90 -0
  665. package/packages/diagrams/src/lib/templates/sequence/controls/DiagramControls.tsx +707 -0
  666. package/packages/diagrams/src/lib/templates/sequence/data/template-data.ts +635 -0
  667. package/packages/diagrams/src/lib/templates/stateMachine/StateMachineDiagram.tsx +67 -0
  668. package/packages/diagrams/src/lib/templates/stateMachine/components/CompositeStateNodeSettings.tsx +639 -0
  669. package/packages/diagrams/src/lib/templates/stateMachine/components/CustomEdge.tsx +221 -0
  670. package/packages/diagrams/src/lib/templates/stateMachine/components/EdgeSettings.tsx +194 -0
  671. package/packages/diagrams/src/lib/templates/stateMachine/components/SelfConnectingEdge.tsx +42 -0
  672. package/packages/diagrams/src/lib/templates/stateMachine/components/StateMachineComponents.tsx +50 -0
  673. package/packages/diagrams/src/lib/templates/stateMachine/components/StateMachineDiagramFlow.tsx +1238 -0
  674. package/packages/diagrams/src/lib/templates/stateMachine/components/StateMachineLayout.ts +350 -0
  675. package/packages/diagrams/src/lib/templates/stateMachine/components/StateNodeSettings.tsx +189 -0
  676. package/packages/diagrams/src/lib/templates/stateMachine/components/useSelfTransition.ts +114 -0
  677. package/packages/diagrams/src/lib/templates/stateMachine/controls/StateDiagramControls.tsx +488 -0
  678. package/packages/diagrams/src/lib/templates/stateMachine/data/template-data.ts +4 -0
  679. package/packages/diagrams/src/lib/templates/stateMachine/nodes/ChoicePointNode.tsx +54 -0
  680. package/packages/diagrams/src/lib/templates/stateMachine/nodes/CompositeStateNode.tsx +225 -0
  681. package/packages/diagrams/src/lib/templates/stateMachine/nodes/EntryPointNode.tsx +31 -0
  682. package/packages/diagrams/src/lib/templates/stateMachine/nodes/ExitPointNode.tsx +44 -0
  683. package/packages/diagrams/src/lib/templates/stateMachine/nodes/FinalStateNode.tsx +41 -0
  684. package/packages/diagrams/src/lib/templates/stateMachine/nodes/ForkJoinNode.tsx +53 -0
  685. package/packages/diagrams/src/lib/templates/stateMachine/nodes/HistoryStateNode.tsx +36 -0
  686. package/packages/diagrams/src/lib/templates/stateMachine/nodes/InitialStateNode.tsx +29 -0
  687. package/packages/diagrams/src/lib/templates/stateMachine/nodes/JunctionPointNode.tsx +33 -0
  688. package/packages/diagrams/src/lib/templates/stateMachine/nodes/PinPointNode.tsx +112 -0
  689. package/packages/diagrams/src/lib/templates/stateMachine/nodes/StateNode.tsx +124 -0
  690. package/packages/diagrams/src/lib/templates/stateMachine/nodes/bendPoint.tsx +71 -0
  691. package/packages/diagrams/src/lib/templates/systemFlow/SystemFlowDiagram.tsx +67 -0
  692. package/packages/diagrams/src/lib/templates/systemFlow/components/EdgeSettings.tsx +330 -0
  693. package/packages/diagrams/src/lib/templates/systemFlow/components/FloatingEdge.tsx +219 -0
  694. package/packages/diagrams/src/lib/templates/systemFlow/components/SystemFlowComponents.tsx +28 -0
  695. package/packages/diagrams/src/lib/templates/systemFlow/components/SystemFlowDiagramFlow.tsx +1179 -0
  696. package/packages/diagrams/src/lib/templates/systemFlow/components/SystemFlowNodeSettings.tsx +151 -0
  697. package/packages/diagrams/src/lib/templates/systemFlow/controls/SystemFlowControls.tsx +435 -0
  698. package/packages/diagrams/src/lib/templates/systemFlow/data/template-data.ts +308 -0
  699. package/packages/diagrams/src/lib/templates/systemFlow/demo.tsx +91 -0
  700. package/packages/diagrams/src/lib/templates/systemFlow/index.ts +5 -0
  701. package/packages/diagrams/src/lib/templates/systemFlow/nodes/BendpointNode.tsx +80 -0
  702. package/packages/diagrams/src/lib/templates/systemFlow/nodes/SystemNode.tsx +92 -0
  703. package/packages/diagrams/src/lib/templates/systemFlow/nodes/TreeSystemNode.tsx +755 -0
  704. package/packages/diagrams/src/lib/templates/useCaseDiagram/UseCaseDiagram.tsx +16 -0
  705. package/packages/diagrams/src/lib/templates/useCaseDiagram/components/ActorNodeSettings.tsx +104 -0
  706. package/packages/diagrams/src/lib/templates/useCaseDiagram/components/AddRelationshipDialog.tsx +187 -0
  707. package/packages/diagrams/src/lib/templates/useCaseDiagram/components/PackageNodeSettings.tsx +206 -0
  708. package/packages/diagrams/src/lib/templates/useCaseDiagram/components/UseCaseDiagramFlow.tsx +637 -0
  709. package/packages/diagrams/src/lib/templates/useCaseDiagram/components/UseCaseNodeSettings.tsx +121 -0
  710. package/packages/diagrams/src/lib/templates/useCaseDiagram/controls/UseCaseControls.tsx +289 -0
  711. package/packages/diagrams/src/lib/templates/useCaseDiagram/nodes/PackageNode.tsx +84 -0
  712. package/packages/diagrams/src/lib/templates/useCaseDiagram/nodes/UseCaseEdge.tsx +116 -0
  713. package/packages/diagrams/src/lib/templates/useCaseDiagram/nodes/UseCaseNode.tsx +231 -0
  714. package/packages/diagrams/src/lib/templates/validationSchema.json +277 -0
  715. package/packages/diagrams/src/lib/theme.ts +439 -0
  716. package/packages/diagrams/src/lib/types/FunctionSignature.ts +11 -0
  717. package/packages/diagrams/src/lib/types/SmartDynamicFormField.ts +37 -0
  718. package/packages/diagrams/src/lib/types/automation-node-data-types.ts +295 -0
  719. package/packages/diagrams/src/lib/types/available-variables.ts +18 -0
  720. package/packages/diagrams/src/lib/types/card-node.ts +68 -0
  721. package/packages/diagrams/src/lib/types/collaboration-types.ts +114 -0
  722. package/packages/diagrams/src/lib/types/colors.ts +25 -0
  723. package/packages/diagrams/src/lib/types/condition-builder.ts +19 -0
  724. package/packages/diagrams/src/lib/types/diagram-types.ts +14 -0
  725. package/packages/diagrams/src/lib/types/edge-types.ts +22 -0
  726. package/packages/diagrams/src/lib/types/function-execution.ts +35 -0
  727. package/packages/diagrams/src/lib/types/hooks.types.ts +6 -0
  728. package/packages/diagrams/src/lib/types/ndoe-form-types.ts +139 -0
  729. package/packages/diagrams/src/lib/types/node-types.ts +29 -0
  730. package/packages/diagrams/src/lib/types/sequence-types.ts +178 -0
  731. package/packages/diagrams/src/lib/types/shared-node-types.ts +21 -0
  732. package/packages/diagrams/src/lib/types/state-machine-types.ts +225 -0
  733. package/packages/diagrams/src/lib/types/stencil-item.ts +7 -0
  734. package/packages/diagrams/src/lib/types/structures.ts +80 -0
  735. package/packages/diagrams/src/lib/types/system-flow-types.ts +129 -0
  736. package/packages/diagrams/src/lib/types/usecase-types.ts +84 -0
  737. package/packages/diagrams/src/lib/types/validation-types.ts +134 -0
  738. package/packages/diagrams/src/lib/types/workflow-content-dynamic-form-type.ts +23 -0
  739. package/packages/diagrams/src/lib/types/workflow-node-data-types.ts +172 -0
  740. package/packages/diagrams/src/lib/utils/AutomationExecutionEngine.ts +1162 -0
  741. package/packages/diagrams/src/lib/utils/add-new-block.ts +34 -0
  742. package/packages/diagrams/src/lib/utils/add-new-node.ts +52 -0
  743. package/packages/diagrams/src/lib/utils/addToHistory.ts +15 -0
  744. package/packages/diagrams/src/lib/utils/automation-flow-processor.ts +619 -0
  745. package/packages/diagrams/src/lib/utils/closestPoint.ts +45 -0
  746. package/packages/diagrams/src/lib/utils/color-options.tsx +26 -0
  747. package/packages/diagrams/src/lib/utils/compress-img.ts +59 -0
  748. package/packages/diagrams/src/lib/utils/configLoader.ts +329 -0
  749. package/packages/diagrams/src/lib/utils/constant-lengths.ts +8 -0
  750. package/packages/diagrams/src/lib/utils/create-updated.tsx +40 -0
  751. package/packages/diagrams/src/lib/utils/createHistoryChange.ts +3 -0
  752. package/packages/diagrams/src/lib/utils/dividerUtils.tsx +60 -0
  753. package/packages/diagrams/src/lib/utils/edge-hooks.ts +53 -0
  754. package/packages/diagrams/src/lib/utils/elkLayout.ts +297 -0
  755. package/packages/diagrams/src/lib/utils/event-hooks.ts +69 -0
  756. package/packages/diagrams/src/lib/utils/event-store.ts +58 -0
  757. package/packages/diagrams/src/lib/utils/flow-node-hooks.ts +28 -0
  758. package/packages/diagrams/src/lib/utils/flow-to-js.ts +1465 -0
  759. package/packages/diagrams/src/lib/utils/functionGenerator.ts +38 -0
  760. package/packages/diagrams/src/lib/utils/helpers.types.ts +10 -0
  761. package/packages/diagrams/src/lib/utils/iconMapper.tsx +76 -0
  762. package/packages/diagrams/src/lib/utils/logger.ts +5 -0
  763. package/packages/diagrams/src/lib/utils/model-hooks.ts +129 -0
  764. package/packages/diagrams/src/lib/utils/node-hooks.ts +78 -0
  765. package/packages/diagrams/src/lib/utils/nodeutils.ts +242 -0
  766. package/packages/diagrams/src/lib/utils/object.ts +13 -0
  767. package/packages/diagrams/src/lib/utils/useDebounce.ts +19 -0
  768. package/packages/diagrams/src/lib/utils/utilities.ts +105 -0
  769. package/packages/diagrams/src/lib/utils/validationEngine.ts +610 -0
  770. package/packages/diagrams/src/lib/utils/vhToPixels.ts +9 -0
  771. package/packages/diagrams/tsconfig.json +21 -0
  772. package/packages/diagrams/tsconfig.lib.json +27 -0
  773. package/packages/diagrams/webpack.config.js +17 -0
  774. package/packages/interfaces/.babelrc +12 -0
  775. package/packages/interfaces/.eslintrc.json +18 -0
  776. package/packages/interfaces/README.md +7 -0
  777. package/packages/interfaces/project.json +8 -0
  778. package/packages/interfaces/src/index.ts +21 -0
  779. package/packages/interfaces/src/lib/Button.tsx +1 -0
  780. package/packages/interfaces/src/lib/DataGrid.ts +14 -0
  781. package/packages/interfaces/src/lib/StyledBox.tsx +1 -0
  782. package/packages/interfaces/src/lib/ToolbarItem.ts +7 -0
  783. package/packages/interfaces/src/lib/UserCard.ts +8 -0
  784. package/packages/interfaces/src/lib/yup.ts +3 -0
  785. package/packages/interfaces/tsconfig.json +17 -0
  786. package/packages/interfaces/tsconfig.lib.json +24 -0
  787. package/packages/molecules/.babelrc +12 -0
  788. package/packages/molecules/.eslintrc.json +18 -0
  789. package/packages/molecules/README.md +7 -0
  790. package/packages/molecules/project.json +8 -0
  791. package/packages/molecules/src/index.ts +22 -0
  792. package/packages/molecules/src/lib/ActionTextField/ActionTextField.module.css +7 -0
  793. package/packages/molecules/src/lib/ActionTextField/ActionTextField.spec.tsx +10 -0
  794. package/packages/molecules/src/lib/ActionTextField/ActionTextField.tsx +33 -0
  795. package/packages/molecules/src/lib/ClosableButton/CloseableButton.module.css +7 -0
  796. package/packages/molecules/src/lib/ClosableButton/CloseableButton.spec.tsx +11 -0
  797. package/packages/molecules/src/lib/ClosableButton/CloseableButton.tsx +69 -0
  798. package/packages/molecules/src/lib/EditorTab/EditorTab.module.css +7 -0
  799. package/packages/molecules/src/lib/EditorTab/EditorTab.spec.tsx +10 -0
  800. package/packages/molecules/src/lib/EditorTab/EditorTab.tsx +42 -0
  801. package/packages/molecules/src/lib/EditorTab/TabPanel.tsx +25 -0
  802. package/packages/molecules/src/lib/ParamsActionField/ParamsActionField.module.css +7 -0
  803. package/packages/molecules/src/lib/ParamsActionField/ParamsActionField.spec.tsx +10 -0
  804. package/packages/molecules/src/lib/ParamsActionField/ParamsActionField.tsx +24 -0
  805. package/packages/molecules/src/lib/TableWithInlineView/TableWithInlineView.module.css +7 -0
  806. package/packages/molecules/src/lib/TableWithInlineView/TableWithInlineView.spec.tsx +10 -0
  807. package/packages/molecules/src/lib/TableWithInlineView/TableWithInlineView.tsx +47 -0
  808. package/packages/molecules/src/lib/UserCard/UserCard.module.css +7 -0
  809. package/packages/molecules/src/lib/UserCard/UserCard.spec.tsx +11 -0
  810. package/packages/molecules/src/lib/UserCard/UserCard.tsx +22 -0
  811. package/packages/molecules/src/lib/VerbSelection/HTTPVerbSelection.module.css +7 -0
  812. package/packages/molecules/src/lib/VerbSelection/HTTPVerbSelection.spec.tsx +10 -0
  813. package/packages/molecules/src/lib/VerbSelection/HTTPVerbSelection.tsx +72 -0
  814. package/packages/molecules/tsconfig.json +17 -0
  815. package/packages/molecules/tsconfig.lib.json +30 -0
  816. package/packages/organisms/.babelrc +12 -0
  817. package/packages/organisms/.eslintrc.json +18 -0
  818. package/packages/organisms/README.md +7 -0
  819. package/packages/organisms/project.json +8 -0
  820. package/packages/organisms/src/index.ts +4 -0
  821. package/packages/organisms/src/lib/EditorToolbar/EditorToolbar.module.css +7 -0
  822. package/packages/organisms/src/lib/EditorToolbar/EditorToolbar.spec.tsx +10 -0
  823. package/packages/organisms/src/lib/EditorToolbar/EditorToolbar.tsx +117 -0
  824. package/packages/organisms/src/lib/EditorToolbar/SortableItem.tsx +51 -0
  825. package/packages/organisms/src/lib/UserList/UserList.module.css +7 -0
  826. package/packages/organisms/src/lib/UserList/UserList.spec.tsx +11 -0
  827. package/packages/organisms/src/lib/UserList/UserList.tsx +48 -0
  828. package/packages/organisms/src/lib/UserList/store.ts +49 -0
  829. package/packages/organisms/tsconfig.json +17 -0
  830. package/packages/organisms/tsconfig.lib.json +24 -0
  831. package/packages/zustand/.babelrc +12 -0
  832. package/packages/zustand/.eslintrc.json +18 -0
  833. package/packages/zustand/README.md +7 -0
  834. package/packages/zustand/project.json +8 -0
  835. package/packages/zustand/src/index.ts +4 -0
  836. package/packages/zustand/tsconfig.json +17 -0
  837. package/packages/zustand/tsconfig.lib.json +24 -0
  838. package/tsconfig.base.json +30 -0
@@ -0,0 +1,793 @@
1
+ import { useCallback, useState, useEffect } from 'react';
2
+ import {
3
+ ReactFlow,
4
+ addEdge,
5
+ Background,
6
+ useNodesState,
7
+ useEdgesState,
8
+ Controls,
9
+ Connection,
10
+ Edge,
11
+ Panel,
12
+ Node,
13
+ useReactFlow,
14
+ ReactFlowProvider,
15
+ MarkerType,
16
+ } from '@xyflow/react';
17
+ import { Box, Button, Paper, ClickAwayListener } from '@mui/material';
18
+ import UndoIcon from '@mui/icons-material/Undo';
19
+ import RedoIcon from '@mui/icons-material/Redo';
20
+ import DownloadIcon from '@mui/icons-material/Download';
21
+ import UploadIcon from '@mui/icons-material/Upload';
22
+
23
+ import NodeDialog from './components/NodeDialog';
24
+ import EdgeSettings from './components/EdgeSettings';
25
+ import GroupSizeDialog from './components/GroupSizeDialog';
26
+ import ArchDiagramControls from './controls/ArchDiagramControls';
27
+
28
+ import '@xyflow/react/dist/style.css';
29
+ import {
30
+ eventDrivenTemplate,
31
+ microservicesTemplate,
32
+ nodeColors,
33
+ threeTierTemplate,
34
+ } from './data/templatee-data';
35
+ import {
36
+ animatedEdgeStyle,
37
+ defaultEdgeStyle,
38
+ EdgeData,
39
+ edgeStyles,
40
+ NodeData,
41
+ nodeTypes,
42
+ NodeTypes,
43
+ } from './components/nodeTypes';
44
+
45
+ const ArchDiagramInner = ({
46
+ archNodes,
47
+ archEdges,
48
+ }: {
49
+ archNodes: Node<NodeData>[];
50
+ archEdges: Edge<EdgeData>[];
51
+ }) => {
52
+ const [nodes, setNodes, onNodesChange] = useNodesState<Node<NodeData>>([]);
53
+ const [edges, setEdges, onEdgesChange] = useEdgesState<Edge<EdgeData>>([]);
54
+ const [history, setHistory] = useState<
55
+ { nodes: Node<NodeData>[]; edges: Edge<EdgeData>[] }[]
56
+ >([{ nodes: [], edges: [] }]);
57
+ const [historyIndex, setHistoryIndex] = useState(0);
58
+ const [isDialogOpen, setIsDialogOpen] = useState(false);
59
+ const [selectedNode, setSelectedNode] = useState<Node<NodeData> | null>(null);
60
+ const [newNodeType, setNewNodeType] = useState<keyof NodeTypes>('service');
61
+ const [newNodeLabel, setNewNodeLabel] = useState('');
62
+ const [selectedColor, setSelectedColor] = useState<string>('blue');
63
+ const [groupWidth, setGroupWidth] = useState(600);
64
+ const [groupHeight, setGroupHeight] = useState(200);
65
+ const [selectedEdge, setSelectedEdge] = useState<Edge<EdgeData> | null>(null);
66
+ const [edgeLabel, setEdgeLabel] = useState('');
67
+ const [isEdgeAnimated, setIsEdgeAnimated] = useState(false);
68
+ const [isInitialized, setIsInitialized] = useState(false);
69
+
70
+ const { getNodes, getViewport } = useReactFlow();
71
+
72
+ useEffect(() => {
73
+ if (archNodes && archEdges) {
74
+ // Ensure nodes have valid positions and styles
75
+ const validNodes = archNodes.map(node => {
76
+ // Handle different node types
77
+ const nodeType = node.type;
78
+
79
+ let nodeStyle;
80
+ if (nodeType === 'subnetNode') {
81
+ nodeStyle = {
82
+ backgroundColor: node.data?.color || 'transparent',
83
+ border: `1px solid ${node.data?.borderColor || '#777'}`,
84
+ borderRadius: '8px',
85
+ padding: '20px',
86
+ width: node.data?.width || 500,
87
+ height: node.data?.height || 250,
88
+ zIndex: node.style?.zIndex || 1,
89
+ } as const;
90
+ } else if (nodeType === 'serviceNode') {
91
+ nodeStyle = {
92
+ backgroundColor: node.data?.color || nodeColors.blue,
93
+ border: '1px solid #777',
94
+ borderRadius: '8px',
95
+ padding: '10px',
96
+ width: 130,
97
+ height: 80,
98
+ zIndex: node.style?.zIndex || 2,
99
+ } as const;
100
+ } else {
101
+ nodeStyle = {
102
+ backgroundColor: node.data?.color || nodeColors.blue,
103
+ border: '1px solid #777',
104
+ borderRadius: '8px',
105
+ padding: '10px',
106
+ width: node.style?.width || 130,
107
+ height: node.style?.height || 80,
108
+ zIndex: node.style?.zIndex || 1,
109
+ } as const;
110
+ }
111
+
112
+ return {
113
+ ...node,
114
+ position: node.position || { x: 0, y: 0 },
115
+ style: nodeStyle as React.CSSProperties,
116
+ data: {
117
+ ...node.data,
118
+ label: node.data?.label || 'New Node',
119
+ }
120
+ } as Node<NodeData>;
121
+ });
122
+
123
+ // Ensure edges have proper styling
124
+ const validEdges = archEdges.map(edge => {
125
+ const edgeStyle = {
126
+ stroke: edge.style?.stroke || '#555',
127
+ strokeWidth: edge.style?.strokeWidth || 2,
128
+ };
129
+
130
+ return {
131
+ ...edge,
132
+ type: edge.type || 'smoothstep',
133
+ animated: edge.animated || false,
134
+ style: edgeStyle,
135
+ markerEnd: {
136
+ type: MarkerType.ArrowClosed,
137
+ width: 20,
138
+ height: 20,
139
+ color: edgeStyle.stroke,
140
+ },
141
+ } as Edge<EdgeData>;
142
+ });
143
+
144
+ setNodes(validNodes);
145
+ setEdges(validEdges);
146
+ setHistory([{ nodes: validNodes, edges: validEdges }]);
147
+ setIsInitialized(true);
148
+ }
149
+ }, [archNodes, archEdges]);
150
+
151
+ const findCenterPosition = useCallback(() => {
152
+ // Default center position
153
+ const defaultPosition = {
154
+ x: window.innerWidth / 2,
155
+ y: window.innerHeight / 2,
156
+ };
157
+
158
+ if (!isInitialized) {
159
+ return defaultPosition;
160
+ }
161
+
162
+ try {
163
+ const viewport = getViewport();
164
+ if (
165
+ !viewport ||
166
+ typeof viewport.x === 'undefined' ||
167
+ typeof viewport.y === 'undefined' ||
168
+ typeof viewport.zoom === 'undefined'
169
+ ) {
170
+ return defaultPosition;
171
+ }
172
+
173
+ const centerX =
174
+ -viewport.x / viewport.zoom + window.innerWidth / (2 * viewport.zoom);
175
+ const centerY =
176
+ -viewport.y / viewport.zoom + window.innerHeight / (2 * viewport.zoom);
177
+
178
+ const existingNodes = getNodes();
179
+ if (!existingNodes || existingNodes.length === 0) {
180
+ return { x: centerX, y: centerY };
181
+ }
182
+
183
+ const centerThreshold = 100;
184
+ const centeredNodes = existingNodes.filter((node) => {
185
+ if (
186
+ !node ||
187
+ !node.position ||
188
+ typeof node.position.x === 'undefined' ||
189
+ typeof node.position.y === 'undefined'
190
+ ) {
191
+ return false;
192
+ }
193
+ const dx = Math.abs(node.position.x - centerX);
194
+ const dy = Math.abs(node.position.y - centerY);
195
+ return dx < centerThreshold && dy < centerThreshold;
196
+ });
197
+
198
+ if (centeredNodes.length > 0) {
199
+ const leftmostX = Math.min(
200
+ ...centeredNodes.map((node) => node.position?.x || 0),
201
+ );
202
+ return {
203
+ x: leftmostX - 200,
204
+ y: centerY,
205
+ };
206
+ }
207
+
208
+ return { x: centerX, y: centerY };
209
+ } catch (error) {
210
+ console.error('Error calculating center position:', error);
211
+ return defaultPosition;
212
+ }
213
+ }, [getViewport, getNodes, isInitialized]);
214
+
215
+ const onConnect = useCallback(
216
+ (connection: Connection) => {
217
+ const newEdge = {
218
+ ...connection,
219
+ id: `edge-${Date.now()}`,
220
+ ...(isEdgeAnimated ? animatedEdgeStyle : edgeStyles),
221
+ type: 'smoothstep',
222
+ label: '',
223
+ labelStyle: {
224
+ ...defaultEdgeStyle.labelStyle,
225
+ display: edgeLabel ? 'block' : 'none',
226
+ },
227
+ labelBgStyle: defaultEdgeStyle.labelBgStyle,
228
+ };
229
+ setEdges((eds) => addEdge(newEdge as Edge<EdgeData>, eds));
230
+ },
231
+ [isEdgeAnimated, edgeLabel],
232
+ );
233
+
234
+ const toggleEdgeAnimation = useCallback((edgeId: string) => {
235
+ setEdges((eds) =>
236
+ eds.map((edge) => {
237
+ if (edge.id === edgeId) {
238
+ const isCurrentlyAnimated = edge.animated;
239
+ return {
240
+ ...edge,
241
+ ...(isCurrentlyAnimated ? edgeStyles : animatedEdgeStyle),
242
+ };
243
+ }
244
+ return edge;
245
+ }),
246
+ );
247
+ }, []);
248
+
249
+ const onDragOver = useCallback((event: React.DragEvent) => {
250
+ event.preventDefault();
251
+ event.dataTransfer.dropEffect = 'move';
252
+ }, []);
253
+
254
+ const handleGroupSizeChange = useCallback(
255
+ (width: number, height: number) => {
256
+ if (!selectedNode?.data?.isGroup) return;
257
+
258
+ setGroupWidth(width);
259
+ setGroupHeight(height);
260
+
261
+ setNodes((nds) =>
262
+ nds.map((node) =>
263
+ node.id === selectedNode.id
264
+ ? {
265
+ ...node,
266
+ style: {
267
+ ...node.style,
268
+ width,
269
+ height,
270
+ },
271
+ }
272
+ : node,
273
+ ),
274
+ );
275
+ },
276
+ [selectedNode, setNodes],
277
+ );
278
+
279
+ const onNodeClick = (event: React.MouseEvent, node: Node<NodeData>) => {
280
+ if ((event.target as HTMLElement).classList.contains('nodrag')) {
281
+ return;
282
+ }
283
+
284
+ setSelectedNode(node);
285
+ setNewNodeLabel(node.data?.label || '');
286
+
287
+ if (!node.data?.isGroup) {
288
+ setIsDialogOpen(true);
289
+ }
290
+ };
291
+
292
+ const handleAddGroupNode = () => {
293
+ const position = findCenterPosition();
294
+
295
+ const newNode = {
296
+ id: `group-${Date.now()}`,
297
+ type: 'group',
298
+ data: {
299
+ label: newNodeLabel || 'New Group',
300
+ isGroup: true,
301
+ },
302
+ position,
303
+ style: {
304
+ width: groupWidth,
305
+ height: groupHeight,
306
+ backgroundColor: 'rgba(240, 240, 240, 0.5)',
307
+ border: '1px dashed #777',
308
+ borderRadius: '8px',
309
+ padding: '20px',
310
+ zIndex: -1,
311
+ },
312
+ selectable: true,
313
+ draggable: true,
314
+ };
315
+
316
+ const groupNode = newNode as Node<NodeData>;
317
+ setNodes((nds) => [...nds, groupNode]);
318
+ setNewNodeLabel('');
319
+ setIsDialogOpen(false);
320
+ };
321
+
322
+ useEffect(() => {
323
+ setNodes((nds) =>
324
+ nds.map((node) => {
325
+ if (node.data?.isGroup) {
326
+ return {
327
+ ...node,
328
+ style: {
329
+ ...node.style,
330
+ zIndex: -1,
331
+ },
332
+ draggable: true,
333
+ };
334
+ }
335
+ return node;
336
+ }),
337
+ );
338
+ }, []);
339
+
340
+ const handleAddNode = (type: string, color: string) => {
341
+ const nodeInfo = nodeTypes[type as keyof NodeTypes];
342
+ const position = findCenterPosition();
343
+
344
+ const newNode = {
345
+ id: `${type}-${Date.now()}`,
346
+ type,
347
+ data: { label: `New ${nodeInfo.label}` },
348
+ position,
349
+ draggable: true,
350
+ style: {
351
+ background: color,
352
+ border: '1px solid #777',
353
+ borderRadius: '8px',
354
+ padding: '10px',
355
+ width: 130,
356
+ },
357
+ };
358
+ setNodes((nds) => [...nds, newNode as Node<NodeData>]);
359
+ };
360
+
361
+ const handleAddChildNode = (parentId: string) => {
362
+ const parent = nodes.find((node) => node.id === parentId);
363
+ if (!parent || !parent.data?.isGroup) return;
364
+
365
+ // Calculate position relative to parent
366
+ const childPosition = {
367
+ x: parent.position.x + 50,
368
+ y: parent.position.y + 50,
369
+ };
370
+
371
+ const newNode = {
372
+ id: `service-${Date.now()}`,
373
+ type: 'service',
374
+ data: {
375
+ label: 'New Service',
376
+ parentId: parentId,
377
+ },
378
+ position: childPosition,
379
+ draggable: true,
380
+ style: {
381
+ background: nodeColors.blue,
382
+ border: '1px solid #777',
383
+ borderRadius: '8px',
384
+ padding: '10px',
385
+ width: 130,
386
+ },
387
+ };
388
+
389
+ setNodes((nds) => [...nds, newNode as Node<NodeData>]);
390
+ setIsDialogOpen(false);
391
+ };
392
+
393
+ const handleUpdateLabel = () => {
394
+ if (!selectedNode) return;
395
+
396
+ setNodes((nds) =>
397
+ nds.map((node) =>
398
+ node.id === selectedNode.id
399
+ ? { ...node, data: { ...node.data, label: newNodeLabel } }
400
+ : node,
401
+ ),
402
+ );
403
+ setIsDialogOpen(false);
404
+ };
405
+
406
+ const onEdgeClick = useCallback(
407
+ (event: React.MouseEvent, edge: Edge<EdgeData>) => {
408
+ event.preventDefault();
409
+ if (event.shiftKey) {
410
+ // Toggle animation when clicking with shift key
411
+ toggleEdgeAnimation(edge.id);
412
+ return;
413
+ }
414
+ setSelectedEdge(edge);
415
+ setEdgeLabel(String(edge.label || edge.data?.label || ''));
416
+ setIsEdgeAnimated(!!edge.animated);
417
+ },
418
+ [toggleEdgeAnimation],
419
+ );
420
+
421
+ const handleEdgeUpdate = useCallback(() => {
422
+ if (!selectedEdge) return;
423
+
424
+ setEdges((eds) =>
425
+ eds.map((edge) => {
426
+ if (edge.id === selectedEdge.id) {
427
+ const updatedEdge = {
428
+ ...edge,
429
+ label: edgeLabel || '',
430
+ data: {
431
+ ...edge.data,
432
+ label: edgeLabel || '',
433
+ } as EdgeData,
434
+ style: {
435
+ ...(edge.animated ? animatedEdgeStyle.style : edgeStyles.style),
436
+ },
437
+ labelStyle: {
438
+ ...defaultEdgeStyle.labelStyle,
439
+ display: edgeLabel ? 'block' : 'none',
440
+ },
441
+ labelBgStyle: defaultEdgeStyle.labelBgStyle,
442
+ };
443
+ return updatedEdge;
444
+ }
445
+ return edge;
446
+ }),
447
+ );
448
+ setSelectedEdge(null);
449
+ setEdgeLabel('');
450
+ }, [selectedEdge, edgeLabel]);
451
+
452
+ const handleLoadTemplate = useCallback((templateType: string) => {
453
+ let template;
454
+ switch (templateType) {
455
+ case 'microservices':
456
+ template = microservicesTemplate;
457
+ break;
458
+ case 'three-tier':
459
+ template = threeTierTemplate;
460
+ break;
461
+ case 'event-driven':
462
+ template = eventDrivenTemplate;
463
+ break;
464
+ default:
465
+ return;
466
+ }
467
+ setNodes(template.nodes as Node<NodeData>[]);
468
+ setEdges(template.edges as Edge<EdgeData>[]);
469
+ }, []);
470
+
471
+ // Handle undo
472
+ const handleUndo = useCallback(() => {
473
+ if (historyIndex > 0) {
474
+ const newIndex = historyIndex - 1;
475
+ const previousState = history[newIndex];
476
+ setNodes(previousState.nodes);
477
+ setEdges(previousState.edges);
478
+ setHistoryIndex(newIndex);
479
+ }
480
+ }, [history, historyIndex]);
481
+
482
+ // Handle redo
483
+ const handleRedo = useCallback(() => {
484
+ if (historyIndex < history.length - 1) {
485
+ const newIndex = historyIndex + 1;
486
+ const nextState = history[newIndex];
487
+ setNodes(nextState.nodes);
488
+ setEdges(nextState.edges);
489
+ setHistoryIndex(newIndex);
490
+ }
491
+ }, [history, historyIndex]);
492
+
493
+ // Export diagram
494
+ const exportDiagram = useCallback(() => {
495
+ const diagramData = {
496
+ nodes,
497
+ edges,
498
+ };
499
+ const dataStr = JSON.stringify(diagramData, null, 2);
500
+ const dataUri =
501
+ 'data:application/json;charset=utf-8,' + encodeURIComponent(dataStr);
502
+ const exportFileDefaultName = 'diagram.json';
503
+
504
+ const linkElement = document.createElement('a');
505
+ linkElement.setAttribute('href', dataUri);
506
+ linkElement.setAttribute('download', exportFileDefaultName);
507
+ linkElement.click();
508
+ }, [nodes, edges]);
509
+
510
+ // Import diagram
511
+ const importDiagram = useCallback(
512
+ (event: React.ChangeEvent<HTMLInputElement>) => {
513
+ const file = event.target.files?.[0];
514
+ if (file) {
515
+ const reader = new FileReader();
516
+ reader.onload = (e) => {
517
+ try {
518
+ const content = e.target?.result as string;
519
+ const { nodes: importedNodes, edges: importedEdges } =
520
+ JSON.parse(content);
521
+ setNodes(importedNodes);
522
+ setEdges(importedEdges);
523
+ // Add to history
524
+ const newHistory = history.slice(0, historyIndex + 1);
525
+ newHistory.push({ nodes: importedNodes, edges: importedEdges });
526
+ setHistory(newHistory);
527
+ setHistoryIndex(newHistory.length - 1);
528
+ } catch (error) {
529
+ console.error('Error importing diagram:', error);
530
+ }
531
+ };
532
+ reader.readAsText(file);
533
+ }
534
+ },
535
+ [history, historyIndex],
536
+ );
537
+
538
+ // Update history when nodes or edges change
539
+ useEffect(() => {
540
+ const currentState = { nodes, edges };
541
+ if (
542
+ JSON.stringify(currentState) !==
543
+ JSON.stringify(history[history.length - 1])
544
+ ) {
545
+ const newHistory = history.slice(0, historyIndex + 1);
546
+ newHistory.push(currentState);
547
+ setHistory(newHistory);
548
+ setHistoryIndex(newHistory.length - 1);
549
+ }
550
+ }, [nodes, edges]);
551
+
552
+ const handleClickAway = () => {
553
+ setIsDialogOpen(false);
554
+ setSelectedNode(null);
555
+ setSelectedEdge(null);
556
+ setEdgeLabel('');
557
+ };
558
+
559
+ // Add handler for diagram pane clicks
560
+ const handlePaneClick = useCallback(() => {
561
+ handleClickAway();
562
+ }, []);
563
+
564
+ return (
565
+ <div style={{ width: '100vw', height: '100vh' }}>
566
+ <ReactFlow<Node<NodeData>, Edge<EdgeData>>
567
+ nodes={nodes}
568
+ edges={edges}
569
+ onNodesChange={onNodesChange}
570
+ onEdgesChange={onEdgesChange}
571
+ onConnect={onConnect}
572
+ onNodeClick={onNodeClick}
573
+ onEdgeClick={onEdgeClick}
574
+ onPaneClick={handlePaneClick}
575
+ onDragOver={onDragOver}
576
+ className="react-flow-subflows-example"
577
+ fitView
578
+ minZoom={0.2}
579
+ maxZoom={1.5}
580
+ defaultEdgeOptions={{
581
+ type: 'smoothstep',
582
+ animated: false,
583
+ style: edgeStyles,
584
+ }}
585
+ nodesDraggable={true}
586
+ nodesConnectable={true}
587
+ elementsSelectable={true}
588
+ edgesFocusable={true}
589
+ onInit={() => setIsInitialized(true)}
590
+ >
591
+ <Panel position="top-left">
592
+ <Box sx={{ display: 'flex', gap: 2, alignItems: 'flex-start' }}>
593
+ <ArchDiagramControls
594
+ onAddNode={handleAddNode}
595
+ onAddGroup={handleAddGroupNode}
596
+ onUndo={handleUndo}
597
+ onRedo={handleRedo}
598
+ canUndo={historyIndex > 0}
599
+ canRedo={historyIndex < history.length - 1}
600
+ onLoadTemplate={handleLoadTemplate}
601
+ />
602
+ </Box>
603
+ </Panel>
604
+
605
+ {/* Edge Settings */}
606
+ {selectedEdge && (
607
+ <ClickAwayListener
608
+ onClickAway={handleClickAway}
609
+ mouseEvent="onMouseDown"
610
+ touchEvent="onTouchStart"
611
+ >
612
+ <EdgeSettings
613
+ selectedEdge={selectedEdge}
614
+ edgeLabel={edgeLabel}
615
+ onEdgeLabelChange={setEdgeLabel}
616
+ onEdgeUpdate={handleEdgeUpdate}
617
+ isAnimated={isEdgeAnimated}
618
+ onAnimationToggle={(checked) => {
619
+ setIsEdgeAnimated(checked);
620
+ if (selectedEdge) {
621
+ toggleEdgeAnimation(selectedEdge.id);
622
+ }
623
+ }}
624
+ />
625
+ </ClickAwayListener>
626
+ )}
627
+
628
+ {/* Add GroupSizeDialog */}
629
+ <GroupSizeDialog
630
+ selectedNode={selectedNode}
631
+ groupWidth={groupWidth}
632
+ groupHeight={groupHeight}
633
+ onGroupSizeChange={handleGroupSizeChange}
634
+ />
635
+
636
+ <Panel position="bottom-right">
637
+ <Paper
638
+ elevation={3}
639
+ sx={{
640
+ p: 1.5,
641
+ borderRadius: 2,
642
+ bgcolor: 'background.paper',
643
+ maxWidth: '480px',
644
+ }}
645
+ >
646
+ <Box
647
+ sx={{
648
+ display: 'flex',
649
+ flexDirection: 'row',
650
+ gap: 1,
651
+ justifyContent: 'space-between',
652
+ }}
653
+ >
654
+ <Button
655
+ variant="contained"
656
+ color="primary"
657
+ size="small"
658
+ onClick={() => {
659
+ const clearedState = { nodes: [], edges: [] };
660
+ const newHistory = history.slice(0, historyIndex + 1);
661
+ newHistory.push(clearedState);
662
+ setNodes([]);
663
+ setEdges([]);
664
+ setHistory(newHistory);
665
+ setHistoryIndex(newHistory.length - 1);
666
+ }}
667
+ >
668
+ Clear
669
+ </Button>
670
+
671
+ <Box sx={{ display: 'flex', gap: 1 }}>
672
+ <Button
673
+ variant="contained"
674
+ color="primary"
675
+ size="small"
676
+ startIcon={<UndoIcon />}
677
+ onClick={handleUndo}
678
+ disabled={historyIndex <= 0}
679
+ sx={{
680
+ minWidth: '40px',
681
+ px: 1,
682
+ }}
683
+ >
684
+ Undo
685
+ </Button>
686
+ <Button
687
+ variant="contained"
688
+ color="primary"
689
+ size="small"
690
+ startIcon={<RedoIcon />}
691
+ onClick={handleRedo}
692
+ disabled={historyIndex >= history.length - 1}
693
+ sx={{
694
+ minWidth: '40px',
695
+ px: 1,
696
+ }}
697
+ >
698
+ Redo
699
+ </Button>
700
+ </Box>
701
+
702
+ <Box sx={{ display: 'flex', gap: 1 }}>
703
+ <Button
704
+ variant="outlined"
705
+ size="small"
706
+ onClick={exportDiagram}
707
+ startIcon={<DownloadIcon />}
708
+ sx={{
709
+ minWidth: '40px',
710
+ px: 1,
711
+ }}
712
+ >
713
+ Export
714
+ </Button>
715
+ <Button
716
+ variant="outlined"
717
+ component="label"
718
+ size="small"
719
+ startIcon={<UploadIcon />}
720
+ sx={{
721
+ minWidth: '40px',
722
+ px: 1,
723
+ }}
724
+ >
725
+ Import
726
+ <input
727
+ type="file"
728
+ onChange={importDiagram}
729
+ accept=".json"
730
+ style={{ display: 'none' }}
731
+ />
732
+ </Button>
733
+ </Box>
734
+ </Box>
735
+ </Paper>
736
+ </Panel>
737
+
738
+ <Controls />
739
+ <Background color="#E6E6E6" gap={16} />
740
+ </ReactFlow>
741
+
742
+ {/* Node Dialog with ClickAwayListener */}
743
+ {isDialogOpen && (
744
+ <ClickAwayListener
745
+ onClickAway={handleClickAway}
746
+ mouseEvent="onMouseDown"
747
+ touchEvent="onTouchStart"
748
+ >
749
+ <NodeDialog
750
+ open={isDialogOpen}
751
+ onClose={() => setIsDialogOpen(false)}
752
+ selectedNode={selectedNode}
753
+ newNodeType={newNodeType}
754
+ newNodeLabel={newNodeLabel}
755
+ selectedColor={selectedColor}
756
+ nodeTypes={nodeTypes}
757
+ colorOptions={[
758
+ { value: 'blue', label: 'Blue', color: nodeColors.blue },
759
+ { value: 'green', label: 'Green', color: nodeColors.green },
760
+ { value: 'orange', label: 'Orange', color: nodeColors.orange },
761
+ { value: 'purple', label: 'Purple', color: nodeColors.purple },
762
+ { value: 'pink', label: 'Pink', color: nodeColors.pink },
763
+ ]}
764
+ onNodeTypeChange={setNewNodeType}
765
+ onColorChange={setSelectedColor}
766
+ onLabelChange={setNewNodeLabel}
767
+ onAddNode={() =>
768
+ handleAddNode(
769
+ newNodeType,
770
+ nodeColors[selectedColor as keyof typeof nodeColors],
771
+ )
772
+ }
773
+ onUpdateLabel={handleUpdateLabel}
774
+ onAddChildNode={handleAddChildNode}
775
+ />
776
+ </ClickAwayListener>
777
+ )}
778
+ </div>
779
+ );
780
+ };
781
+
782
+ const ArchDiagram = (props: {
783
+ archNodes: Node<NodeData>[];
784
+ archEdges: Edge<EdgeData>[];
785
+ }) => {
786
+ return (
787
+ <ReactFlowProvider>
788
+ <ArchDiagramInner {...props} />
789
+ </ReactFlowProvider>
790
+ );
791
+ };
792
+
793
+ export default ArchDiagram;