@coopenomics/desktop 2.2.9 → 2025.4.29

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 (366) hide show
  1. package/.env-example +6 -1
  2. package/.env-testnet +8 -0
  3. package/CHANGELOG.md +11 -0
  4. package/Dockerfile +12 -0
  5. package/extensions/market/install.ts +78 -0
  6. package/extensions/market-admin/install.ts +42 -0
  7. package/extensions/participant/install.ts +125 -0
  8. package/extensions/powerup/install.ts +20 -0
  9. package/extensions/soviet/install.ts +83 -0
  10. package/package.json +6 -5
  11. package/quasar.config.cjs +5 -12
  12. package/src/app/App.vue +44 -73
  13. package/src/app/layouts/default.vue +40 -0
  14. package/src/app/layouts/useDefaultLayoutLogic.ts +59 -0
  15. package/src/app/providers/routes/index.ts +19 -34
  16. package/src/app/styles/style.css +4 -0
  17. package/src/boot/init.ts +6 -0
  18. package/src/boot/sentry.ts +1 -2
  19. package/src/desktops/index.ts +0 -6
  20. package/src/entities/Account/api/index.ts +11 -2
  21. package/src/entities/Account/model/index.ts +1 -1
  22. package/src/entities/Account/model/store.ts +15 -5
  23. package/src/entities/Account/types/index.ts +9 -1
  24. package/src/entities/Agenda/api/index.ts +20 -0
  25. package/src/entities/Agenda/index.ts +2 -0
  26. package/src/entities/Agenda/model/index.ts +2 -0
  27. package/src/entities/Agenda/model/store.ts +36 -0
  28. package/src/entities/Agenda/model/types.ts +4 -0
  29. package/src/entities/Branch/model/index.ts +1 -1
  30. package/src/entities/Desktop/api/index.ts +16 -1
  31. package/src/entities/Desktop/model/store.ts +112 -106
  32. package/src/entities/Desktop/model/types.ts +14 -1
  33. package/src/entities/Document/api/index.ts +24 -0
  34. package/src/entities/Document/index.ts +2 -0
  35. package/src/entities/Document/model/store.ts +117 -0
  36. package/src/entities/Document/model/types.ts +18 -0
  37. package/src/entities/Meet/api/index.ts +58 -0
  38. package/src/entities/Meet/index.ts +2 -0
  39. package/src/entities/Meet/model/store.ts +72 -0
  40. package/src/entities/Meet/types/index.ts +7 -0
  41. package/src/entities/Payment/api/index.ts +20 -0
  42. package/src/entities/Payment/model/index.ts +2 -0
  43. package/src/entities/Payment/model/store.ts +62 -0
  44. package/src/entities/Payment/model/types.ts +7 -0
  45. package/src/entities/Session/model/store.ts +5 -6
  46. package/src/entities/System/model/store.ts +1 -1
  47. package/src/entities/User/model/stores.ts +3 -1
  48. package/src/entities/Wallet/api/index.ts +15 -33
  49. package/src/entities/Wallet/model/stores.ts +3 -23
  50. package/src/entities/Wallet/model/types.ts +2 -3
  51. package/src/features/Account/UpdateAccount/api/index.ts +14 -0
  52. package/src/features/Account/UpdateAccount/index.ts +1 -0
  53. package/src/features/Account/UpdateAccount/model/index.ts +16 -0
  54. package/src/features/Agreementer/SignAgreementDialog/ui/SignAgreementDialog.vue +1 -1
  55. package/src/features/Branch/SelectBranch/index.ts +2 -0
  56. package/src/features/Branch/SelectBranch/ui/SelectBranchOverlay.vue +52 -104
  57. package/src/features/Decision/CreateProject/ui/CreateProjectFreeDecisionButton.vue +1 -1
  58. package/src/features/Decision/ParticipantApplication/model/index.ts +38 -0
  59. package/src/features/FreeDecision/CreateProject/model/index.ts +92 -0
  60. package/src/features/FreeDecision/CreateProject/ui/CreateProjectFreeDecisionButton.vue +51 -0
  61. package/src/features/FreeDecision/CreateProject/ui/index.ts +1 -0
  62. package/src/features/FreeDecision/GenerateDecision/index.ts +1 -0
  63. package/src/features/FreeDecision/GenerateDecision/model/index.ts +36 -0
  64. package/src/features/FreeDecision/index.ts +2 -0
  65. package/src/features/Meet/CloseMeetWithDecision/index.ts +1 -0
  66. package/src/features/Meet/CloseMeetWithDecision/model/index.ts +92 -0
  67. package/src/features/Meet/CreateMeet/index.ts +2 -0
  68. package/src/features/Meet/CreateMeet/model/index.ts +65 -0
  69. package/src/features/Meet/CreateMeet/ui/CreateMeet.vue +34 -0
  70. package/src/features/Meet/CreateMeet/ui/CreateMeetForm.vue +136 -0
  71. package/src/features/Meet/CreateMeet/ui/index.ts +2 -0
  72. package/src/features/Meet/GenerateAgenda/index.ts +1 -0
  73. package/src/features/Meet/GenerateAgenda/model/index.ts +18 -0
  74. package/src/features/Meet/GenerateBallot/index.ts +1 -0
  75. package/src/features/Meet/GenerateBallot/model/index.ts +18 -0
  76. package/src/features/Meet/GenerateNotification/index.ts +1 -0
  77. package/src/features/Meet/GenerateNotification/model/index.ts +18 -0
  78. package/src/features/Meet/GenerateSovietDecision/index.ts +1 -0
  79. package/src/features/Meet/GenerateSovietDecision/model/index.ts +48 -0
  80. package/src/features/Meet/MeetDetailsManagement/index.ts +1 -0
  81. package/src/features/Meet/MeetDetailsManagement/model/index.ts +121 -0
  82. package/src/features/Meet/RestartMeet/index.ts +2 -0
  83. package/src/features/Meet/RestartMeet/model/index.ts +54 -0
  84. package/src/features/Meet/RestartMeet/ui/RestartMeet.vue +46 -0
  85. package/src/features/Meet/RestartMeet/ui/RestartMeetForm.vue +92 -0
  86. package/src/features/Meet/RestartMeet/ui/index.ts +2 -0
  87. package/src/features/Meet/VoteOnMeet/index.ts +1 -0
  88. package/src/features/Meet/VoteOnMeet/model/index.ts +18 -0
  89. package/src/features/Payment/SetStatus/api/index.ts +20 -0
  90. package/src/features/Payment/SetStatus/index.ts +1 -0
  91. package/src/features/Payment/SetStatus/model/index.ts +30 -0
  92. package/src/features/{Order → Payment}/SetStatus/ui/SetOrderPaidStatusButton/SetOrderPaidStatusButton.vue +7 -3
  93. package/src/features/PaymentMethod/AddPaymentMethod/model/index.ts +2 -2
  94. package/src/features/PaymentMethod/AddPaymentMethod/ui/AddPaymentButton.vue +1 -1
  95. package/src/features/PaymentMethod/DeletePaymentMethod/model/index.ts +1 -1
  96. package/src/features/PaymentMethod/DeletePaymentMethod/ui/DeletePaymentMethodButton.vue +3 -1
  97. package/src/features/Request/CancelRequest/ui/CancelButton.vue +1 -1
  98. package/src/features/Request/ConfirmRecieveOnRequest/ui/ConfirmRecieveOnRequest.vue +1 -1
  99. package/src/features/Request/CreateParentOffer/ui/CreateParentOfferForm/CreateParentOfferForm.vue +3 -5
  100. package/src/features/Request/CreateParentOffer/ui/ImageUploaderWithPreview/ImageUploaderWithPreview.vue +4 -3
  101. package/src/features/Request/DisputeOnRequest/ui/DisputeOnRequestButton.vue +1 -1
  102. package/src/features/Request/ModerateRequest/ui/ModerateRequestButton.vue +2 -2
  103. package/src/features/Request/PublishRequest/ui/PublishRequestButton.vue +1 -1
  104. package/src/features/Request/RecieveOnRequest/ui/RecieveOnRequestButton.vue +1 -1
  105. package/src/features/Request/UnpublishRequest/ui/UnpublishRequestButton.vue +1 -1
  106. package/src/features/Union/AddCooperative/model/index.ts +4 -5
  107. package/src/features/Union/AddCooperative/ui/AddCooperativeForm.vue +5 -6
  108. package/src/features/User/AddUser/ui/AddUserDialog/AddUserDialog.vue +7 -4
  109. package/src/features/User/LoginUser/model/index.ts +3 -3
  110. package/src/features/User/LoginUser/ui/LoginForm/LoginForm.vue +0 -6
  111. package/src/features/User/Logout/model/index.ts +5 -3
  112. package/src/features/Wallet/DepositToWallet/ui/DepositButton/DepositButton.vue +8 -7
  113. package/src/features/Wallet/WithdrawFromWallet/ui/withdrawButton.vue +6 -7
  114. package/src/pages/Blank/index.ts +1 -0
  115. package/src/pages/Contacts/ContactsPage.vue +64 -0
  116. package/src/{widgets/Cooperative/Contacts → pages/Cooperative/ChangeContacts}/ui/index.ts +0 -1
  117. package/src/{widgets/Cooperative/Contributions/ui/ChangeContributions.vue → pages/Cooperative/ChangeRegisterPayments/ui/ChangeRegisterPayments.vue} +10 -11
  118. package/src/pages/Cooperative/ChangeRegisterPayments/ui/index.ts +1 -0
  119. package/src/pages/Cooperative/ListOfAgenda/index.ts +1 -0
  120. package/src/pages/Cooperative/ListOfAgenda/ui/ListOfAgendaQuestions.vue +118 -0
  121. package/src/pages/Cooperative/ListOfAgenda/ui/index.ts +1 -0
  122. package/src/pages/Cooperative/ListOfDocuments/ListOfDocumentsPage.vue +24 -0
  123. package/src/pages/Cooperative/ListOfMeets/model/index.ts +1 -0
  124. package/src/pages/Cooperative/ListOfMeets/model/model.ts +117 -0
  125. package/src/pages/Cooperative/ListOfMeets/ui/ListOfMeetsPage.vue +90 -0
  126. package/src/pages/Cooperative/ListOfMeets/ui/index.ts +1 -0
  127. package/src/pages/Cooperative/ListOfOrders/index.ts +1 -1
  128. package/src/pages/Cooperative/ListOfOrders/ui/ListOfOrdersPage.vue +0 -4
  129. package/src/pages/Cooperative/ListOfParticipants/ui/ListOfParticipantsPage.vue +61 -10
  130. package/src/pages/Cooperative/ListOfParticipants/ui/index.ts +1 -1
  131. package/src/pages/Cooperative/MeetDetails/ui/MeetDetailsPage.vue +88 -0
  132. package/src/pages/Cooperative/MeetDetails/ui/index.ts +1 -0
  133. package/src/pages/Cooperative/{ListOfBranches/ui/ListOfBranchesPage.vue → MemberBranchList/ui/MemberBranchListPage.vue} +2 -4
  134. package/src/pages/Cooperative/MemberBranchList/ui/index.ts +1 -0
  135. package/src/pages/Cooperative/Payments/index.ts +1 -0
  136. package/src/pages/Cooperative/Payments/ui/PaymentsPage.vue +7 -0
  137. package/src/pages/{ExtStore → ExtensionStore}/ExtensionPage/ExtensionPage.vue +35 -20
  138. package/src/pages/{ExtStore → ExtensionStore}/ExtensionsShowcase/ExtensionsShowcase.vue +2 -2
  139. package/src/pages/{ExtStore → ExtensionStore}/InstalledExtensions/InstalledExtensions.vue +2 -2
  140. package/src/pages/Marketplace/OfferPage/ui/OfferPage.vue +1 -1
  141. package/src/pages/Marketplace/Showcase/ui/ShowcasePage.vue +1 -1
  142. package/src/pages/Marketplace/SuppliesList/ui/SuppliesListPage.vue +1 -1
  143. package/src/pages/Marketplace/UserParentOffers/ui/UserParentOffersPage.vue +1 -1
  144. package/src/pages/Marketplace/UserSuppliesList/ui/UserSuppliesListPage.vue +1 -1
  145. package/src/pages/PermissionDenied/index.ts +1 -0
  146. package/src/pages/Registrator/SignUp/EmailInput.vue +2 -3
  147. package/src/pages/Registrator/SignUp/GenerateAccount.vue +2 -3
  148. package/src/pages/Registrator/SignUp/PayInitial.vue +1 -1
  149. package/src/pages/Registrator/SignUp/ReadStatement.vue +2 -2
  150. package/src/pages/Registrator/SignUp/SelectBranch.vue +2 -2
  151. package/src/pages/Registrator/SignUp/SignStatement.vue +2 -2
  152. package/src/pages/Registrator/SignUp/SignUp.vue +5 -12
  153. package/src/pages/Registrator/SignUp/WaitingRegistration.vue +1 -5
  154. package/src/pages/Registrator/SignUp/Welcome.vue +4 -3
  155. package/src/pages/Union/ConnectionAgreement/index.ts +1 -0
  156. package/src/pages/Union/ListOfCooperatives/ui/UnionPageListOfCooperatives.vue +139 -6
  157. package/src/pages/User/DocumentsPage/UserDocumentsPage.vue +23 -0
  158. package/src/pages/User/DocumentsPage/index.ts +1 -0
  159. package/src/pages/User/PaymentsPage/ui/UserPayments.vue +11 -0
  160. package/src/pages/User/PaymentsPage/ui/index.ts +1 -0
  161. package/src/pages/User/ProfilePage/index.ts +1 -0
  162. package/src/pages/User/ProfilePage/ui/ProfilePage.vue +114 -0
  163. package/src/pages/User/ProfilePage/ui/index.ts +1 -0
  164. package/src/pages/User/SettingsPage/ui/index.ts +1 -1
  165. package/src/pages/User/WalletPage/index.ts +1 -0
  166. package/src/pages/User/WalletPage/ui/WalletPage.vue +72 -0
  167. package/src/pages/User/WalletPage/ui/index.ts +1 -0
  168. package/src/processes/init-app/index.ts +28 -0
  169. package/src/processes/init-installed-extensions/index.ts +25 -0
  170. package/src/processes/init-wallet/index.ts +40 -0
  171. package/src/processes/navigation-guard-setup/index.ts +45 -0
  172. package/src/processes/process-decisions/index.ts +275 -0
  173. package/src/processes/select-branch/index.ts +80 -0
  174. package/src/processes/watch-branch-overlay/index.ts +38 -0
  175. package/src/processes/watch-desktop-health/index.ts +33 -0
  176. package/src/shared/api/alerts.ts +2 -6
  177. package/src/shared/api/axios.ts +4 -5
  178. package/src/shared/api/client.ts +3 -4
  179. package/src/shared/api/eosio.ts +1 -2
  180. package/src/shared/api/utils.ts +1 -3
  181. package/src/shared/config/index.ts +0 -1
  182. package/src/shared/hooks/index.ts +2 -0
  183. package/src/shared/hooks/useAgendaPoints.ts +24 -0
  184. package/src/shared/hooks/useWindowSize.ts +13 -0
  185. package/src/shared/lib/composables/useDisplayName.ts +34 -0
  186. package/src/shared/lib/composables/useEditableData.ts +1 -1
  187. package/src/shared/lib/navigation/index.ts +2 -0
  188. package/src/shared/lib/navigation/routeUtils.ts +51 -0
  189. package/src/shared/lib/navigation/useBackButton.ts +63 -0
  190. package/src/shared/lib/utils/dates/validateDateWithinRange.ts +23 -0
  191. package/src/shared/ui/BaseDocument/BaseDocument.vue +120 -90
  192. package/src/{components/menu/blockchainStatus.vue → shared/ui/BlockchainStatusBar/BlockchainStatusBar.vue} +1 -0
  193. package/src/shared/ui/BlockchainStatusBar/index.ts +1 -0
  194. package/src/shared/ui/CardStyles/index.scss +61 -0
  195. package/src/shared/ui/ComplexDocument/ComplexDocument.vue +31 -8
  196. package/src/shared/ui/CopyableInput/index.ts +1 -0
  197. package/src/shared/ui/CopyableInput/ui/CopyableInput.vue +62 -0
  198. package/src/shared/ui/EditableEntrepreneurCard/EditableEntrepreneurCard.vue +171 -0
  199. package/src/shared/ui/EditableEntrepreneurCard/index.ts +1 -0
  200. package/src/{widgets/IndividualCard/ui/IndividualCard.vue → shared/ui/EditableIndividualCard/EditableIndividualCard.vue} +101 -68
  201. package/src/shared/ui/EditableIndividualCard/index.ts +1 -0
  202. package/src/shared/ui/EditableOrganizationCard/EditableOrganizationCard.vue +225 -0
  203. package/src/shared/ui/EditableOrganizationCard/index.ts +1 -0
  204. package/src/shared/ui/Form/Form.vue +3 -1
  205. package/src/shared/ui/InputStyles/index.scss +29 -0
  206. package/src/shared/ui/TabStyles/index.scss +53 -0
  207. package/src/shared/ui/UserDataForm/OrganizationDataForm/OrganizationDataForm.vue +1 -0
  208. package/src/shared/ui/index.ts +1 -0
  209. package/src/{components/history/AccountEvents.vue → widgets/AccountActions/AccountActionsPage.vue} +2 -2
  210. package/src/widgets/AccountActions/index.ts +1 -0
  211. package/src/widgets/BankDetailsCard/ui/BankDetailsCard.vue +2 -2
  212. package/src/widgets/BranchCard/ui/BranchCard.vue +2 -2
  213. package/src/widgets/Cooperative/Documents/ListOfDocuments/ui/DocumentCard.vue +48 -0
  214. package/src/widgets/Cooperative/Documents/ListOfDocuments/ui/DocumentsTable.vue +162 -0
  215. package/src/widgets/Cooperative/Documents/ListOfDocuments/ui/ListOfDocumentsWidget.vue +77 -120
  216. package/src/widgets/Cooperative/Documents/ListOfDocuments/ui/index.ts +3 -1
  217. package/src/widgets/Cooperative/Orders/ListOfOrders/ui/ListOfOrdersWidget.vue +135 -128
  218. package/src/widgets/Cooperative/Orders/ListOfOrders/ui/OrderCard.vue +74 -0
  219. package/src/widgets/Cooperative/Orders/ListOfOrders/ui/index.ts +2 -1
  220. package/src/widgets/Cooperative/Payments/ListOfPayments/ui/ListOfPaymentsWidget.vue +216 -0
  221. package/src/widgets/Cooperative/Payments/ListOfPayments/ui/PaymentCard.vue +73 -0
  222. package/src/widgets/Cooperative/Payments/ListOfPayments/ui/index.ts +2 -0
  223. package/src/widgets/Cooperative/Payments/index.ts +1 -0
  224. package/src/widgets/Desktop/LeftDrawerMenu/LeftDrawerMenu.vue +3 -2
  225. package/src/widgets/Desktop/SecondLevelMenuList/SecondLevelMenuList.vue +58 -91
  226. package/src/widgets/Desktop/WorkspaceMenu/WorkspaceMenu.vue +114 -59
  227. package/src/widgets/{ExtStore/ExtensionCard → ExtensionCard}/ExtensionCard.vue +12 -7
  228. package/src/widgets/Header/BackButton/BackButton.vue +25 -0
  229. package/src/widgets/Header/BackButton/index.ts +1 -0
  230. package/src/widgets/Header/CommonHeader/CooperativeSettingsHeader.vue +34 -0
  231. package/src/widgets/Header/CommonHeader/ExtstoreHeader.vue +41 -0
  232. package/src/widgets/Header/CommonHeader/Header.vue +33 -198
  233. package/src/widgets/Header/CommonHeader/HeaderStyles.scss +22 -0
  234. package/src/widgets/Header/CommonHeader/MainHeader.vue +87 -0
  235. package/src/widgets/Header/CommonHeader/UserSettingsHeader.vue +29 -0
  236. package/src/widgets/Header/CommonHeader/index.ts +1 -1
  237. package/src/widgets/Header/SettingsDropdown/SettingsDropdown.vue +0 -6
  238. package/src/widgets/{Request → Marketplace}/SupplyOrderRequestCard/ui/Base/Base.vue +1 -2
  239. package/src/widgets/Meets/MeetDetailsActions/MeetDetailsActions.vue +51 -0
  240. package/src/widgets/Meets/MeetDetailsActions/index.ts +1 -0
  241. package/src/widgets/Meets/MeetDetailsActions/model.ts +46 -0
  242. package/src/widgets/Meets/MeetDetailsAgenda/MeetDetailsAgenda.vue +29 -0
  243. package/src/widgets/Meets/MeetDetailsAgenda/index.ts +1 -0
  244. package/src/widgets/Meets/MeetDetailsHeader/MeetDetailsHeader.vue +40 -0
  245. package/src/widgets/Meets/MeetDetailsHeader/index.ts +1 -0
  246. package/src/widgets/Meets/MeetDetailsVoting/MeetDetailsVoting.vue +77 -0
  247. package/src/widgets/Meets/MeetDetailsVoting/index.ts +1 -0
  248. package/src/widgets/Meets/MeetDetailsVoting/model.ts +117 -0
  249. package/src/widgets/Meets/MeetInfoCard/ui/MeetInfoCard.vue +38 -0
  250. package/src/widgets/Meets/MeetInfoCard/ui/index.ts +1 -0
  251. package/src/widgets/Meets/MeetsTable/ui/MeetsTable.vue +118 -0
  252. package/src/widgets/Meets/MeetsTable/ui/index.ts +1 -0
  253. package/src/widgets/Participants/index.ts +1 -0
  254. package/src/widgets/Participants/ui/ParticipantCard.vue +89 -0
  255. package/src/widgets/Participants/ui/ParticipantDetails.vue +79 -0
  256. package/src/widgets/Participants/ui/ParticipantsTable.vue +129 -0
  257. package/src/widgets/Participants/ui/index.ts +4 -0
  258. package/src/widgets/Questions/index.ts +3 -0
  259. package/src/widgets/Questions/ui/QuestionCard/QuestionCard.vue +109 -0
  260. package/src/widgets/Questions/ui/QuestionCard/index.ts +1 -0
  261. package/src/widgets/Questions/ui/QuestionsTable/QuestionsTable.vue +177 -0
  262. package/src/widgets/Questions/ui/QuestionsTable/index.ts +1 -0
  263. package/src/widgets/Questions/ui/VotingButtons/VotingButtons.vue +75 -0
  264. package/src/widgets/Questions/ui/VotingButtons/index.ts +1 -0
  265. package/src/widgets/Questions/ui/index.ts +3 -0
  266. package/src/widgets/RequireAgreements/index.ts +1 -0
  267. package/src/widgets/User/PaymentMethods/ui/PaymentMethods.vue +81 -85
  268. package/tsconfig.json +1 -1
  269. package/extensions/powerup/boot.ts +0 -17
  270. package/src/app/providers/card/store.ts +0 -42
  271. package/src/boot/branch-selector.ts +0 -40
  272. package/src/boot/init-stores.ts +0 -45
  273. package/src/boot/navigation-guards.ts +0 -46
  274. package/src/components/menu/footerMobileMenu.vue +0 -79
  275. package/src/components/soviet/index.vue +0 -76
  276. package/src/components/soviet/staff.vue +0 -274
  277. package/src/desktops/User/index.ts +0 -1
  278. package/src/desktops/User/model/index.ts +0 -328
  279. package/src/entities/Menu/model/store.ts +0 -69
  280. package/src/entities/Menu/model/types.ts +0 -11
  281. package/src/entities/Menu/ui/index.ts +0 -1
  282. package/src/entities/Order/api/index.ts +0 -14
  283. package/src/entities/Order/model/store.ts +0 -87
  284. package/src/features/Order/SetStatus/api/index.ts +0 -7
  285. package/src/features/Order/SetStatus/model/index.ts +0 -23
  286. package/src/pages/Cooperative/Contacts/ui/ContactsPage.vue +0 -7
  287. package/src/pages/Cooperative/ListOfBranches/ui/index.ts +0 -1
  288. package/src/pages/Documentor/ListOfDocuments/ListOfDocumentsPage.vue +0 -12
  289. package/src/pages/Union/Connection/index.ts +0 -1
  290. package/src/pages/_layouts/blank.vue +0 -24
  291. package/src/pages/_layouts/default.vue +0 -79
  292. package/src/types/index.ts +0 -3
  293. package/src/widgets/Commutator/Commutator.vue +0 -7
  294. package/src/widgets/Commutator/index.ts +0 -1
  295. package/src/widgets/Cooperative/Agenda/ListOfQuestions/ui/ListOfQuestions.vue +0 -273
  296. package/src/widgets/Cooperative/Agenda/ListOfQuestions/ui/index.ts +0 -1
  297. package/src/widgets/Cooperative/Contacts/ui/Contacts.vue +0 -52
  298. package/src/widgets/Cooperative/Contributions/ui/index.ts +0 -1
  299. package/src/widgets/Cooperative/Description/ui/SetDescription.vue +0 -4
  300. package/src/widgets/Cooperative/Description/ui/index.ts +0 -1
  301. package/src/widgets/Cooperative/Participants/ListOfParticipants/ui/ListOfParticipantsWidget.vue +0 -103
  302. package/src/widgets/Cooperative/Participants/ListOfParticipants/ui/index.ts +0 -1
  303. package/src/widgets/Desktop/SecondLevelMenu/SecondLevelMenu.vue +0 -59
  304. package/src/widgets/Desktop/SecondLevelMenu/index.ts +0 -1
  305. package/src/widgets/IndividualCard/ui/index.ts +0 -1
  306. package/src/widgets/OrganizationCard/ui/OrganizationCard.vue +0 -44
  307. package/src/widgets/OrganizationCard/ui/index.ts +0 -1
  308. package/src/widgets/Union/ListOfCooperatives/ui/UnionListOfCooperatives.vue +0 -136
  309. package/src/widgets/Union/ListOfCooperatives/ui/index.ts +0 -1
  310. package/src/entities/{Menu → Document}/model/index.ts +0 -0
  311. package/src/entities/{Order → Meet}/model/index.ts +0 -0
  312. package/src/entities/{Order → Payment}/index.ts +0 -0
  313. package/src/features/{Order/SetStatus → Decision/ParticipantApplication}/index.ts +0 -0
  314. package/src/{widgets/Request/SupplyOrderRequestCard → features/FreeDecision/CreateProject}/index.ts +0 -0
  315. package/src/features/{Order → Payment}/SetStatus/ui/SetOrderCompletedStatusButton/SetOrderCompletedStatusButton.vue +0 -0
  316. package/src/features/{Order → Payment}/SetStatus/ui/SetOrderCompletedStatusButton/index.ts +0 -0
  317. package/src/features/{Order → Payment}/SetStatus/ui/SetOrderPaidStatusButton/index.ts +0 -0
  318. package/src/features/{Order → Payment}/SetStatus/ui/SetOrderRefundedStatusButton/SetOrderRefundedStatusButton.vue +0 -0
  319. package/src/features/{Order → Payment}/SetStatus/ui/SetOrderRefundedStatusButton/index.ts +0 -0
  320. package/src/pages/{blank/blank.vue → Blank/BlankPage.vue} +0 -0
  321. package/src/pages/{Cooperative/Contacts/ui → Contacts}/index.ts +0 -0
  322. package/src/pages/Cooperative/{Contacts → ChangeContacts}/index.ts +0 -0
  323. package/src/{widgets/Cooperative/Contacts → pages/Cooperative/ChangeContacts}/ui/ChangeContacts.vue +0 -0
  324. package/src/pages/Cooperative/{ListOfBranches → ChangeRegisterPayments}/index.ts +0 -0
  325. package/src/pages/{Documentor → Cooperative}/ListOfDocuments/index.ts +0 -0
  326. package/src/pages/{Installer → Cooperative/ListOfMeets}/index.ts +0 -0
  327. package/src/{widgets/Cooperative/Agenda/ListOfQuestions → pages/Cooperative/MeetDetails}/index.ts +0 -0
  328. package/src/{widgets/Cooperative/Contacts → pages/Cooperative/MemberBranchList}/index.ts +0 -0
  329. package/src/pages/{ExtStore → ExtensionStore}/BaseRoute/ExtensionStoreBase.vue +0 -0
  330. package/src/pages/{ExtStore → ExtensionStore}/BaseRoute/index.ts +0 -0
  331. package/src/pages/{ExtStore → ExtensionStore}/ExtensionPage/index.ts +0 -0
  332. package/src/pages/{ExtStore → ExtensionStore}/ExtensionsShowcase/index.ts +0 -0
  333. package/src/pages/{ExtStore → ExtensionStore}/InstalledExtensions/index.ts +0 -0
  334. package/src/pages/{_layouts/permissionDenied.vue → PermissionDenied/PermissionDenied.vue} +0 -0
  335. package/src/pages/Union/{Connection/ConnectionPage.vue → ConnectionAgreement/ConnectionAgreementPage.vue} +0 -0
  336. package/src/{widgets/Cooperative/Contributions → pages/Union/InstallCooperative}/index.ts +0 -0
  337. package/src/pages/{Installer → Union/InstallCooperative}/ui/InstallCooperativePage.vue +0 -0
  338. package/src/pages/{Installer → Union/InstallCooperative}/ui/index.ts +0 -0
  339. package/src/{widgets/Cooperative/Participants/ListOfParticipants → pages/User/PaymentsPage}/index.ts +0 -0
  340. package/src/{components/history → widgets/AccountActions}/AccountLink.vue +0 -0
  341. package/src/{components/history → widgets/AccountActions}/ActionCell.vue +0 -0
  342. package/src/{components/history → widgets/AccountActions}/DataCell.vue +0 -0
  343. package/src/widgets/{IndividualCard → Cooperative/Payments/ListOfPayments}/index.ts +0 -0
  344. package/src/widgets/{ExtStore/ExtensionCard → ExtensionCard}/index.ts +0 -0
  345. package/src/widgets/{Request → Marketplace}/CreateChildOrderCard/CreateChildOrderCard.vue +0 -0
  346. package/src/widgets/{Request → Marketplace}/CreateChildOrderCard/index.ts +0 -0
  347. package/src/widgets/{Request → Marketplace}/RequestCard/RequestCard.vue +0 -0
  348. package/src/widgets/{Request → Marketplace}/RequestCard/index.ts +0 -0
  349. package/src/{entities/Menu → widgets/Marketplace/SupplyOrderRequestCard}/index.ts +1 -1
  350. /package/src/widgets/{Request → Marketplace}/SupplyOrderRequestCard/model/index.ts +0 -0
  351. /package/src/widgets/{Request → Marketplace}/SupplyOrderRequestCard/model/types.ts +0 -0
  352. /package/src/widgets/{Request → Marketplace}/SupplyOrderRequestCard/ui/Base/index.ts +0 -0
  353. /package/src/widgets/{Request → Marketplace}/SupplyOrderRequestCard/ui/Steps/EightStep.vue +0 -0
  354. /package/src/widgets/{Request → Marketplace}/SupplyOrderRequestCard/ui/Steps/FifthStep.vue +0 -0
  355. /package/src/widgets/{Request → Marketplace}/SupplyOrderRequestCard/ui/Steps/FirstStep.vue +0 -0
  356. /package/src/widgets/{Request → Marketplace}/SupplyOrderRequestCard/ui/Steps/FourthStep.vue +0 -0
  357. /package/src/widgets/{Request → Marketplace}/SupplyOrderRequestCard/ui/Steps/SecondStep.vue +0 -0
  358. /package/src/widgets/{Request → Marketplace}/SupplyOrderRequestCard/ui/Steps/SeventhStep.vue +0 -0
  359. /package/src/widgets/{Request → Marketplace}/SupplyOrderRequestCard/ui/Steps/SixthStep.vue +0 -0
  360. /package/src/widgets/{Request → Marketplace}/SupplyOrderRequestCard/ui/Steps/ThirdStep.vue +0 -0
  361. /package/src/widgets/{Request → Marketplace}/SupplyOrderRequestCard/ui/Steps/index.ts +0 -0
  362. /package/src/widgets/{Request → Marketplace}/SupplyOrderRequestCard/ui/index.ts +0 -0
  363. /package/src/widgets/{OrganizationCard → Meets/MeetInfoCard}/index.ts +0 -0
  364. /package/src/widgets/{Union/ListOfCooperatives → Meets/MeetsTable}/index.ts +0 -0
  365. /package/src/widgets/{Agreementer/RequireAgreements → RequireAgreements}/ui/RequireAgreements.vue +0 -0
  366. /package/src/widgets/{Agreementer/RequireAgreements → RequireAgreements}/ui/index.ts +0 -0
@@ -0,0 +1,225 @@
1
+ <template lang="pug">
2
+ q-form(ref="form" v-if="data")
3
+ q-input(
4
+ dense
5
+ v-model="data.email"
6
+ standout="bg-teal text-white"
7
+ label="Email"
8
+ :readonly="readonly"
9
+ :rules="[val => validEmail(val)]"
10
+ autocomplete="off"
11
+ )
12
+ q-select(
13
+ dense
14
+ v-model="data.type"
15
+ standout="bg-teal text-white"
16
+ label="Тип организации"
17
+ :options="[{ label: 'Потребительский Кооператив', value: 'coop' }, { label: 'Производственный Кооператив', value: 'prodcoop' }, { label: 'ООО', value: 'ooo' }]"
18
+ emit-value
19
+ map-options
20
+ :rules="[val => notEmpty(val)]"
21
+ :readonly="readonly"
22
+ )
23
+
24
+ q-input(
25
+ dense
26
+ v-model="data.short_name"
27
+ standout="bg-teal text-white"
28
+ label="Краткое наименование"
29
+ :rules="[val => notEmpty(val)]"
30
+ :readonly="readonly"
31
+ autocomplete="off"
32
+ )
33
+ q-input(
34
+ dense
35
+ v-model="data.full_name"
36
+ standout="bg-teal text-white"
37
+ label="Полное наименование"
38
+ :rules="[val => notEmpty(val)]"
39
+ :readonly="readonly"
40
+ autocomplete="off"
41
+ )
42
+
43
+ q-input(
44
+ dense
45
+ v-model="data.represented_by.last_name"
46
+ standout="bg-teal text-white"
47
+ label="Фамилия представителя"
48
+ :rules="[val => notEmpty(val), val => validatePersonalName(val)]"
49
+ :readonly="readonly"
50
+ autocomplete="off"
51
+ )
52
+ q-input(
53
+ dense
54
+ v-model="data.represented_by.first_name"
55
+ standout="bg-teal text-white"
56
+ label="Имя представителя"
57
+ :rules="[val => notEmpty(val), val => validatePersonalName(val)]"
58
+ :readonly="readonly"
59
+ autocomplete="off"
60
+ )
61
+ q-input(
62
+ dense
63
+ v-model="data.represented_by.middle_name"
64
+ standout="bg-teal text-white"
65
+ label="Отчество представителя"
66
+ :rules="[val => validatePersonalName(val)]"
67
+ :readonly="readonly"
68
+ autocomplete="off"
69
+ )
70
+ q-input(
71
+ dense
72
+ v-model="data.represented_by.based_on"
73
+ standout="bg-teal text-white"
74
+ label="На основании"
75
+ :rules="[val => notEmpty(val)]"
76
+ :readonly="readonly"
77
+ autocomplete="off"
78
+ )
79
+ q-input(
80
+ dense
81
+ v-model="data.represented_by.position"
82
+ standout="bg-teal text-white"
83
+ label="Должность представителя"
84
+ :rules="[val => notEmpty(val)]"
85
+ :readonly="readonly"
86
+ autocomplete="off"
87
+ )
88
+
89
+ q-input(
90
+ dense
91
+ v-model="data.phone"
92
+ standout="bg-teal text-white"
93
+ label="Телефон"
94
+ mask="+7 (###) ###-##-##"
95
+ fill-mask
96
+ :rules="[val => notEmpty(val), val => notEmptyPhone(val)]"
97
+ :readonly="readonly"
98
+ autocomplete="off"
99
+ )
100
+
101
+ q-input(
102
+ dense
103
+ v-model="data.country"
104
+ standout="bg-teal text-white"
105
+ label="Страна"
106
+ :rules="[val => notEmpty(val)]"
107
+ :readonly="readonly"
108
+ autocomplete="off"
109
+ )
110
+ q-input(
111
+ dense
112
+ v-model="data.city"
113
+ standout="bg-teal text-white"
114
+ label="Город"
115
+ :rules="[val => notEmpty(val)]"
116
+ :readonly="readonly"
117
+ autocomplete="off"
118
+ )
119
+ q-input(
120
+ dense
121
+ v-model="data.full_address"
122
+ standout="bg-teal text-white"
123
+ label="Юридический адрес"
124
+ :rules="[val => notEmpty(val)]"
125
+ :readonly="readonly"
126
+ autocomplete="off"
127
+ )
128
+ q-input(
129
+ dense
130
+ v-model="data.fact_address"
131
+ standout="bg-teal text-white"
132
+ label="Фактический адрес"
133
+ :rules="[val => notEmpty(val)]"
134
+ :readonly="readonly"
135
+ autocomplete="off"
136
+ )
137
+
138
+ q-input(
139
+ dense
140
+ v-model="data.details.inn"
141
+ standout="bg-teal text-white"
142
+ mask="############"
143
+ label="ИНН"
144
+ :rules="[val => notEmpty(val), val => (val.length === 10 || val.length === 12) || 'ИНН должен содержать 10 или 12 цифр']"
145
+ :readonly="readonly"
146
+ autocomplete="off"
147
+ )
148
+ q-input(
149
+ dense
150
+ v-model="data.details.ogrn"
151
+ standout="bg-teal text-white"
152
+ mask="###############"
153
+ label="ОГРН"
154
+ :rules="[val => notEmpty(val), val => (val.length === 13 || val.length === 15) || 'ОГРН должен содержать 13 или 15 цифр']"
155
+ :readonly="readonly"
156
+ autocomplete="off"
157
+ )
158
+ q-input(
159
+ dense
160
+ v-model="data.details.kpp"
161
+ standout="bg-teal text-white"
162
+ mask="#########"
163
+ label="КПП"
164
+ :rules="[val => notEmpty(val), val => val.length === 9 || 'КПП должен содержать 9 цифр']"
165
+ :readonly="readonly"
166
+ autocomplete="off"
167
+ )
168
+
169
+ EditableActions(
170
+ v-if="!readonly"
171
+ :isEditing="isEditing"
172
+ :isDisabled="isDisabled"
173
+ @save="saveChanges"
174
+ @cancel="cancelChanges"
175
+ )
176
+ </template>
177
+
178
+ <script lang="ts" setup>
179
+ import { ref } from 'vue';
180
+ import { useEditableData } from 'src/shared/lib/composables/useEditableData';
181
+ import { notEmpty, notEmptyPhone, validatePersonalName } from 'src/shared/lib/utils';
182
+ import { FailAlert, SuccessAlert } from 'src/shared/api';
183
+ import { EditableActions } from 'src/shared/ui/EditableActions';
184
+ import { type IUpdateAccountInput, useUpdateAccount } from 'src/features/Account/UpdateAccount/model';
185
+ import { type IOrganizationData } from 'src/entities/Account/types';
186
+ import { validEmail } from 'src/shared/lib/utils/validEmailRule';
187
+ import 'src/shared/ui/InputStyles/index.scss';
188
+
189
+ const emit = defineEmits(['update']);
190
+ const { updateAccount } = useUpdateAccount();
191
+
192
+ const props = defineProps({
193
+ participantData: {
194
+ type: Object as () => IOrganizationData,
195
+ required: true
196
+ },
197
+ readonly: {
198
+ type: Boolean,
199
+ default: false
200
+ }
201
+ });
202
+
203
+ const localOrganizationData = ref(props.participantData);
204
+ const form = ref();
205
+
206
+ const handleSave = async () => {
207
+ try {
208
+ const account_data: IUpdateAccountInput = {
209
+ username: props.participantData.username,
210
+ organization_data: data.value,
211
+ };
212
+ await updateAccount(account_data);
213
+ emit('update', JSON.parse(JSON.stringify(data.value)));
214
+ SuccessAlert('Данные аккаунта обновлены');
215
+ } catch (e) {
216
+ console.log(e);
217
+ FailAlert(e);
218
+ }
219
+ };
220
+ const { editableData: data, isEditing, isDisabled, saveChanges, cancelChanges } = useEditableData(
221
+ localOrganizationData.value,
222
+ handleSave,
223
+ form
224
+ );
225
+ </script>
@@ -0,0 +1 @@
1
+ export {default as EditableOrganizationCard} from './EditableOrganizationCard.vue'
@@ -7,6 +7,7 @@ interface IFormProps {
7
7
  showCancel?: boolean
8
8
  buttonSubmitTxt?: string
9
9
  buttonCancelTxt?: string
10
+ disabled?: boolean
10
11
  }
11
12
 
12
13
  withDefaults(defineProps<IFormProps>(), {
@@ -15,6 +16,7 @@ withDefaults(defineProps<IFormProps>(), {
15
16
  showSubmit: true,
16
17
  buttonSubmitTxt: 'Продолжить',
17
18
  buttonCancelTxt: 'Отменить',
19
+ disabled: false,
18
20
  })
19
21
 
20
22
  const cancel = (): void => {
@@ -28,6 +30,6 @@ q-form(@submit.prevent="handlerSubmit")
28
30
  slot
29
31
  div.flex
30
32
  q-btn(v-if="showCancel" flat @click="cancel" size="sm") {{ buttonCancelTxt }}
31
- q-btn(v-if="showSubmit" size="sm" type="submit" :loading="isSubmitting" color="primary") {{ buttonSubmitTxt }}
33
+ q-btn(v-if="showSubmit" size="sm" type="submit" :loading="isSubmitting" color="primary" :disabled="disabled") {{ buttonSubmitTxt }}
32
34
 
33
35
  </template>
@@ -0,0 +1,29 @@
1
+ // Стили для инпутов и валидации
2
+
3
+ // Стили для изменения цвета ошибки валидации
4
+ // .q-field__bottom--animated {
5
+ // .q-field__messages {
6
+ // color: red !important;
7
+ // font-weight: 500 !important;
8
+ // }
9
+ // }
10
+
11
+ // .q-field--error {
12
+ // .q-field__bottom {
13
+ // color: red !important;
14
+ // }
15
+
16
+ // .q-field__label {
17
+ // color: red !important;
18
+ // }
19
+
20
+ // &.q-field--highlighted {
21
+ // .q-field__control {
22
+ // color: red !important;
23
+ // }
24
+ // }
25
+
26
+ // .q-field__control {
27
+ // border-color: red !important;
28
+ // }
29
+ // }
@@ -0,0 +1,53 @@
1
+ // Стили для компактных табов
2
+ .compact-tabs {
3
+ border-radius: 8px 8px 0 0;
4
+ overflow: hidden;
5
+ background-color: rgba(0, 0, 0, 0.03);
6
+ border: 1px solid rgba(0, 0, 0, 0.05);
7
+ border-bottom: none;
8
+
9
+ .q-dark & {
10
+ background-color: rgba(255, 255, 255, 0.05);
11
+ border: 1px solid rgba(255, 255, 255, 0.08);
12
+ border-bottom: none;
13
+ }
14
+
15
+ :deep(.q-tab) {
16
+ font-size: 11px !important;
17
+ font-weight: 400;
18
+ transition: all 0.2s ease;
19
+ letter-spacing: -0.2px;
20
+ }
21
+
22
+ :deep(.q-tab__label) {
23
+ font-size: 11px !important;
24
+ transition: transform 0.2s ease;
25
+ }
26
+
27
+ :deep(.q-tab__indicator) {
28
+ height: 3px;
29
+ opacity: 0.8;
30
+ }
31
+ }
32
+
33
+ .q-tab__label {
34
+ font-size: 12px !important;
35
+ }
36
+ .q-tab {
37
+ min-height: 32px !important;
38
+ }
39
+
40
+ // Стили для панелей табов
41
+ .tab-panels-card {
42
+ font-size: 10px !important;
43
+ border-radius: 0 0 8px 8px;
44
+ background-color: rgba(0, 0, 0, 0.02);
45
+ border: 1px solid rgba(0, 0, 0, 0.05);
46
+ border-top: none;
47
+
48
+ .q-dark & {
49
+ background-color: rgba(255, 255, 255, 0.03);
50
+ border: 1px solid rgba(255, 255, 255, 0.08);
51
+ border-top: none;
52
+ }
53
+ }
@@ -7,6 +7,7 @@ div(v-if="userData.organization_data").q-gutter-sm.q-mt-md
7
7
  :options="[{ label: 'Потребительский Кооператив', value: 'coop' }, { label: 'Производственный Кооператив', value: 'prodcoop' }, { label: 'ООО', value: 'ooo' }]"
8
8
  emit-value
9
9
  map-options).q-mb-md
10
+
10
11
  q-input(v-model="userData.organization_data.short_name" standout="bg-teal text-white" hint="ПК Ромашка" label="Краткое наименование организации" :rules="[val => notEmpty(val)]" autocomplete="off")
11
12
  q-input(v-model="userData.organization_data.full_name" standout="bg-teal text-white" hint="Потребительский Кооператив 'Ромашка'" label="Полное наименование организации" :rules="[val => notEmpty(val)]" autocomplete="off")
12
13
  q-input(v-model="userData.organization_data.represented_by.last_name" standout="bg-teal text-white" label="Фамилия представителя" hint="" :rules="[val => notEmpty(val), val => validatePersonalName(val)]" autocomplete="off")
@@ -0,0 +1 @@
1
+ export * from './CopyableInput';
@@ -25,8 +25,8 @@
25
25
  import { ref, watch, onMounted } from 'vue'
26
26
  import moment from 'moment-with-locales-es6'
27
27
  import { QTableProps } from 'quasar'
28
- import ActionCell from 'src/components/explorer/ActionCell.vue'
29
- import DataCell from 'src/components/explorer/DataCell.vue'
28
+ import ActionCell from './ActionCell.vue'
29
+ import DataCell from './DataCell.vue'
30
30
 
31
31
  const props = defineProps<{
32
32
  username: string
@@ -0,0 +1 @@
1
+ export { default as AccountActionsPage } from './AccountActionsPage.vue'
@@ -75,7 +75,7 @@ import type { Zeus } from '@coopenomics/sdk';
75
75
  import { EditableActions } from 'src/shared/ui/EditableActions';
76
76
  import { notEmpty } from 'src/shared/lib/utils';
77
77
  import { useUpdateBranchBankAccount } from 'src/features/PaymentMethod/UpdateBankAccount/model';
78
- import { failAlert } from 'src/shared/api';
78
+ import { FailAlert } from 'src/shared/api';
79
79
 
80
80
  const props = defineProps({
81
81
  bankDetails: {
@@ -93,7 +93,7 @@ const handleSave = async (data: Zeus.ModelTypes['BankPaymentMethod']) => {
93
93
  const { updateBankAccount } = useUpdateBranchBankAccount();
94
94
  await updateBankAccount(data);
95
95
  } catch(e){
96
- failAlert(e)
96
+ FailAlert(e)
97
97
  }
98
98
  };
99
99
 
@@ -6,7 +6,7 @@ import type { IBranch } from 'src/entities/Branch/model';
6
6
  import { EditableActions } from 'src/shared/ui/EditableActions';
7
7
  import { ref } from 'vue';
8
8
  import { useEditBranch } from 'src/features/Branch/EditBranch';
9
- import { failAlert } from 'src/shared/api';
9
+ import { FailAlert } from 'src/shared/api';
10
10
 
11
11
  const props = defineProps({
12
12
  branch: {
@@ -22,7 +22,7 @@ const handleSave = async (updatedBranch: IBranch) => {
22
22
  try {
23
23
  await editBranch(updatedBranch)
24
24
  } catch(e){
25
- failAlert(e)
25
+ FailAlert(e)
26
26
  }
27
27
 
28
28
  };
@@ -0,0 +1,48 @@
1
+ <template lang="pug">
2
+ div.q-pa-xs.col-xs-12.col-sm-12.col-md-12.q-mt-md
3
+ q-card(bordered flat)
4
+ q-card-section.q-py-xs
5
+ div.text-subtitle2 {{ document.statement?.documentAggregate?.rawDocument?.full_title || '' }}
6
+ div.text-caption ID: {{ getDocumentHash(document).substring(0, 10) || '' }}
7
+
8
+ q-separator
9
+
10
+ q-card-actions(align="right")
11
+ q-btn(size="sm" flat icon="expand_more" @click="$emit('toggle-expand')")
12
+ | {{ expanded ? 'Скрыть' : 'Подробнее' }}
13
+
14
+ q-slide-transition
15
+ div(v-show="expanded")
16
+ q-separator
17
+ q-card-section
18
+ ComplexDocument(:documents="document")
19
+ </template>
20
+
21
+ <script setup lang="ts">
22
+ import { ComplexDocument } from 'src/shared/ui/ComplexDocument'
23
+ import type { IDocumentPackageAggregate } from 'src/entities/Document/model'
24
+
25
+ withDefaults(defineProps<{
26
+ document: IDocumentPackageAggregate
27
+ expanded?: boolean
28
+ }>(), {
29
+ expanded: false
30
+ })
31
+
32
+ defineEmits<{
33
+ (e: 'toggle-expand'): void
34
+ }>()
35
+
36
+ // Получение хеша документа из агрегата
37
+ function getDocumentHash(doc: IDocumentPackageAggregate) {
38
+ if (doc.statement?.documentAggregate?.rawDocument?.hash) {
39
+ return doc.statement.documentAggregate.rawDocument.hash
40
+ }
41
+
42
+ if (doc.decision?.documentAggregate?.rawDocument?.hash) {
43
+ return doc.decision.documentAggregate.rawDocument.hash
44
+ }
45
+
46
+ return 'нет хеша'
47
+ }
48
+ </script>
@@ -0,0 +1,162 @@
1
+ <template lang="pug">
2
+ div.scroll-area(style="height: 90vh; overflow-y: auto;")
3
+ q-table(
4
+ ref="tableRef"
5
+ flat
6
+ :grid="isMobile"
7
+ :rows="documents"
8
+ :columns="columns"
9
+ :table-colspan="9"
10
+ :loading='loading'
11
+ :no-data-label="'документы не найдены'"
12
+ :virtual-scroll="!!documents.length"
13
+ @virtual-scroll="onScroll"
14
+ :virtual-scroll-target="'.scroll-area'"
15
+ :virtual-scroll-item-size="48"
16
+ :virtual-scroll-sticky-size-start="48"
17
+ :rows-per-page-options="[0]"
18
+ :pagination="pagination"
19
+ :class="{'my-sticky-dynamic': documents.length > 0}"
20
+ class="q-mb-md"
21
+ ).documents-table
22
+ template(#top v-if="$slots.top")
23
+ slot(name="top")
24
+ template(#item="props")
25
+ DocumentCard(
26
+ :document="props.row"
27
+ :expanded="!!expanded.get(props.row?.statement?.action?.global_sequence)"
28
+ @toggle-expand="toggleExpand(props.row?.statement?.action?.global_sequence)"
29
+ )
30
+
31
+ template(#header="props")
32
+ q-tr(:props="props")
33
+ q-th(auto-width)
34
+ q-th(
35
+ v-for="col in props.cols"
36
+ :key="col.name"
37
+ :props="props"
38
+ ) {{ col.label }}
39
+
40
+ template(#body="props")
41
+ q-tr(:key="`m_${props.row?.id || props.row?.statement?.action?.global_sequence}`" :props="props")
42
+ q-td(auto-width)
43
+ q-btn(
44
+ size="sm"
45
+ color="primary"
46
+ round
47
+ dense
48
+ :icon="expanded.get(props.row?.id || props.row?.statement?.action?.global_sequence) ? 'remove' : 'add'"
49
+ @click="toggleExpand(props.row?.id || props.row?.statement?.action?.global_sequence)"
50
+ )
51
+
52
+ q-td {{ getDocumentHash(props.row).substring(0, 10) || '' }}
53
+ q-td {{ getDocumentTitle(props.row) }}
54
+
55
+ q-tr(
56
+ v-if="expanded.get(props.row?.id || props.row?.statement?.action?.global_sequence)"
57
+ :key="`e_${props.row?.id || props.row?.statement?.action?.global_sequence}`"
58
+ :props="props"
59
+ class="q-virtual-scroll--with-prev"
60
+ )
61
+ q-td(colspan="100%")
62
+ ComplexDocument(:documents="props.row")
63
+
64
+ </template>
65
+
66
+ <script setup lang="ts">
67
+ import { ref, reactive } from 'vue'
68
+ import { ComplexDocument } from 'src/shared/ui/ComplexDocument'
69
+ import { DocumentCard } from './'
70
+ import { useWindowSize } from 'src/shared/hooks'
71
+ import type { IDocumentPackageAggregate } from 'src/entities/Document/model'
72
+
73
+ // Props
74
+ const props = defineProps<{
75
+ documents: IDocumentPackageAggregate[]
76
+ loading: boolean
77
+ }>()
78
+
79
+ // Emits - определяем события, которые компонент может эмитить
80
+ const emit = defineEmits<{
81
+ (e: 'load'): void
82
+ (e: 'toggle-expand', id: string): void
83
+ }>()
84
+
85
+ // Локальное состояние
86
+ const expanded = reactive(new Map<string, boolean>())
87
+ const pagination = ref({
88
+ rowsPerPage: 0
89
+ })
90
+ const tableRef = ref(null)
91
+ const { isMobile } = useWindowSize()
92
+
93
+ // Функция обработки виртуального скролла
94
+ const onScroll = ({ to }) => {
95
+
96
+ const lastIndex = props.documents.length - 1
97
+ // Если достигли последнего элемента в списке, эмитим событие load
98
+ if (to === lastIndex) {
99
+ emit('load')
100
+ }
101
+ }
102
+
103
+ // Получение заголовка документа из агрегата
104
+ function getDocumentTitle(row: IDocumentPackageAggregate) {
105
+ // Используем документы из агрегатов
106
+ if (row.statement?.documentAggregate?.rawDocument?.full_title) {
107
+ return row.statement.documentAggregate.rawDocument.full_title
108
+ }
109
+
110
+ // Проверяем решения
111
+ if (row.decision?.documentAggregate?.rawDocument?.full_title) {
112
+ return row.decision.documentAggregate.rawDocument.full_title
113
+ }
114
+
115
+ // По умолчанию
116
+ return 'Документ без заголовка'
117
+ }
118
+
119
+ // Получение хеша документа из агрегата
120
+ function getDocumentHash(row: IDocumentPackageAggregate) {
121
+ if (row.statement?.documentAggregate?.rawDocument?.hash) {
122
+ return row.statement.documentAggregate.rawDocument.hash
123
+ }
124
+
125
+ if (row.decision?.documentAggregate?.rawDocument?.hash) {
126
+ return row.decision.documentAggregate.rawDocument.hash
127
+ }
128
+
129
+ return 'нет хеша'
130
+ }
131
+
132
+ // Колонки таблицы
133
+ const columns:any[] = [
134
+ {
135
+ name: 'hash',
136
+ align: 'left',
137
+ label: 'ID',
138
+ field: (row: any) => getDocumentHash(row).substring(0, 10) || '',
139
+ sortable: true
140
+ },
141
+ {
142
+ name: 'title',
143
+ align: 'left',
144
+ label: 'Документ',
145
+ field: (row: any) => getDocumentTitle(row),
146
+ sortable: true
147
+ },
148
+
149
+ ]
150
+
151
+ // Функция для переключения состояния развертывания
152
+ const toggleExpand = (id: any) => {
153
+ if (!id) return
154
+ expanded.set(id, !expanded.get(id))
155
+ emit('toggle-expand', id)
156
+ }
157
+ </script>
158
+ <style>
159
+ .documents-table .q-table__top{
160
+ padding: 0px !important;
161
+ }
162
+ </style>