@coopenomics/desktop 2.2.10 → 2025.5.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (366) hide show
  1. package/.env-example +6 -1
  2. package/.env-testnet +8 -0
  3. package/Dockerfile +12 -0
  4. package/alias-resolver.js +35 -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 +14 -7
  11. package/quasar.config.cjs +28 -15
  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/router.ts +4 -3
  16. package/src/app/providers/routes/index.ts +19 -34
  17. package/src/app/styles/style.css +4 -0
  18. package/src/boot/init.ts +6 -0
  19. package/src/boot/sentry.ts +14 -14
  20. package/src/desktops/index.ts +0 -6
  21. package/src/entities/Account/model/index.ts +1 -1
  22. package/src/entities/Agenda/api/index.ts +20 -0
  23. package/src/entities/Agenda/index.ts +2 -0
  24. package/src/entities/Agenda/model/index.ts +2 -0
  25. package/src/entities/Agenda/model/store.ts +36 -0
  26. package/src/entities/Agenda/model/types.ts +4 -0
  27. package/src/entities/Branch/model/index.ts +1 -1
  28. package/src/entities/Desktop/api/index.ts +16 -1
  29. package/src/entities/Desktop/model/store.ts +112 -106
  30. package/src/entities/Desktop/model/types.ts +14 -1
  31. package/src/entities/Document/api/index.ts +24 -0
  32. package/src/entities/Document/index.ts +2 -0
  33. package/src/entities/Document/model/store.ts +117 -0
  34. package/src/entities/Document/model/types.ts +18 -0
  35. package/src/entities/Meet/api/index.ts +58 -0
  36. package/src/entities/Meet/index.ts +2 -0
  37. package/src/entities/Meet/model/store.ts +72 -0
  38. package/src/entities/Meet/types/index.ts +7 -0
  39. package/src/entities/Payment/api/index.ts +20 -0
  40. package/src/entities/Payment/model/index.ts +2 -0
  41. package/src/entities/Payment/model/store.ts +62 -0
  42. package/src/entities/Payment/model/types.ts +7 -0
  43. package/src/entities/Session/model/store.ts +4 -4
  44. package/src/entities/System/model/store.ts +1 -1
  45. package/src/entities/User/model/stores.ts +3 -1
  46. package/src/entities/Wallet/api/index.ts +15 -33
  47. package/src/entities/Wallet/model/stores.ts +3 -23
  48. package/src/entities/Wallet/model/types.ts +2 -3
  49. package/src/env.d.ts +2 -0
  50. package/src/features/Agreementer/SignAgreementDialog/ui/SignAgreementDialog.vue +1 -1
  51. package/src/features/Branch/SelectBranch/index.ts +2 -0
  52. package/src/features/Branch/SelectBranch/ui/SelectBranchOverlay.vue +52 -105
  53. package/src/features/Decision/CreateProject/ui/CreateProjectFreeDecisionButton.vue +1 -1
  54. package/src/features/Decision/ParticipantApplication/model/index.ts +38 -0
  55. package/src/features/FreeDecision/CreateProject/model/index.ts +92 -0
  56. package/src/features/FreeDecision/CreateProject/ui/CreateProjectFreeDecisionButton.vue +51 -0
  57. package/src/features/FreeDecision/CreateProject/ui/index.ts +1 -0
  58. package/src/features/FreeDecision/GenerateDecision/index.ts +1 -0
  59. package/src/features/FreeDecision/GenerateDecision/model/index.ts +36 -0
  60. package/src/features/FreeDecision/index.ts +2 -0
  61. package/src/features/Meet/CloseMeetWithDecision/index.ts +1 -0
  62. package/src/features/Meet/CloseMeetWithDecision/model/index.ts +92 -0
  63. package/src/features/Meet/CreateMeet/index.ts +2 -0
  64. package/src/features/Meet/CreateMeet/model/index.ts +65 -0
  65. package/src/features/Meet/CreateMeet/ui/CreateMeet.vue +34 -0
  66. package/src/features/Meet/CreateMeet/ui/CreateMeetForm.vue +136 -0
  67. package/src/features/Meet/CreateMeet/ui/index.ts +2 -0
  68. package/src/features/Meet/GenerateAgenda/index.ts +1 -0
  69. package/src/features/Meet/GenerateAgenda/model/index.ts +18 -0
  70. package/src/features/Meet/GenerateBallot/index.ts +1 -0
  71. package/src/features/Meet/GenerateBallot/model/index.ts +18 -0
  72. package/src/features/Meet/GenerateNotification/index.ts +1 -0
  73. package/src/features/Meet/GenerateNotification/model/index.ts +18 -0
  74. package/src/features/Meet/GenerateSovietDecision/index.ts +1 -0
  75. package/src/features/Meet/GenerateSovietDecision/model/index.ts +48 -0
  76. package/src/features/Meet/MeetDetailsManagement/index.ts +1 -0
  77. package/src/features/Meet/MeetDetailsManagement/model/index.ts +121 -0
  78. package/src/features/Meet/RestartMeet/index.ts +2 -0
  79. package/src/features/Meet/RestartMeet/model/index.ts +54 -0
  80. package/src/features/Meet/RestartMeet/ui/RestartMeet.vue +46 -0
  81. package/src/features/Meet/RestartMeet/ui/RestartMeetForm.vue +92 -0
  82. package/src/features/Meet/RestartMeet/ui/index.ts +2 -0
  83. package/src/features/Meet/VoteOnMeet/index.ts +1 -0
  84. package/src/features/Meet/VoteOnMeet/model/index.ts +18 -0
  85. package/src/features/Payment/SetStatus/api/index.ts +20 -0
  86. package/src/features/Payment/SetStatus/index.ts +1 -0
  87. package/src/features/Payment/SetStatus/model/index.ts +30 -0
  88. package/src/features/{Order → Payment}/SetStatus/ui/SetOrderPaidStatusButton/SetOrderPaidStatusButton.vue +7 -3
  89. package/src/features/PaymentMethod/AddPaymentMethod/model/index.ts +2 -2
  90. package/src/features/PaymentMethod/AddPaymentMethod/ui/AddPaymentButton.vue +1 -1
  91. package/src/features/PaymentMethod/DeletePaymentMethod/model/index.ts +1 -1
  92. package/src/features/PaymentMethod/DeletePaymentMethod/ui/DeletePaymentMethodButton.vue +3 -1
  93. package/src/features/Request/CancelRequest/ui/CancelButton.vue +1 -1
  94. package/src/features/Request/ConfirmRecieveOnRequest/ui/ConfirmRecieveOnRequest.vue +1 -1
  95. package/src/features/Request/CreateParentOffer/ui/CreateParentOfferForm/CreateParentOfferForm.vue +4 -5
  96. package/src/features/Request/CreateParentOffer/ui/ImageUploaderWithPreview/ImageUploaderWithPreview.vue +5 -3
  97. package/src/features/Request/DisputeOnRequest/ui/DisputeOnRequestButton.vue +1 -1
  98. package/src/features/Request/ModerateRequest/ui/ModerateRequestButton.vue +2 -2
  99. package/src/features/Request/PublishRequest/ui/PublishRequestButton.vue +1 -1
  100. package/src/features/Request/RecieveOnRequest/ui/RecieveOnRequestButton.vue +1 -1
  101. package/src/features/Request/UnpublishRequest/ui/UnpublishRequestButton.vue +1 -1
  102. package/src/features/Union/AddCooperative/model/index.ts +5 -5
  103. package/src/features/Union/AddCooperative/ui/AddCooperativeForm.vue +6 -9
  104. package/src/features/User/AddUser/ui/AddUserDialog/AddUserDialog.vue +4 -4
  105. package/src/features/User/LoginUser/model/index.ts +3 -7
  106. package/src/features/User/LoginUser/ui/LoginForm/LoginForm.vue +0 -6
  107. package/src/features/User/Logout/model/index.ts +2 -1
  108. package/src/features/Wallet/DepositToWallet/ui/DepositButton/DepositButton.vue +10 -7
  109. package/src/features/Wallet/WithdrawFromWallet/ui/withdrawButton.vue +7 -6
  110. package/src/pages/Blank/index.ts +1 -0
  111. package/src/pages/Contacts/ContactsPage.vue +64 -0
  112. package/src/{widgets/Cooperative/Contacts → pages/Cooperative/ChangeContacts}/ui/index.ts +0 -1
  113. package/src/{widgets/Cooperative/Contributions/ui/ChangeContributions.vue → pages/Cooperative/ChangeRegisterPayments/ui/ChangeRegisterPayments.vue} +12 -11
  114. package/src/pages/Cooperative/ChangeRegisterPayments/ui/index.ts +1 -0
  115. package/src/pages/Cooperative/ListOfAgenda/index.ts +1 -0
  116. package/src/pages/Cooperative/ListOfAgenda/ui/ListOfAgendaQuestions.vue +118 -0
  117. package/src/pages/Cooperative/ListOfAgenda/ui/index.ts +1 -0
  118. package/src/pages/Cooperative/ListOfDocuments/ListOfDocumentsPage.vue +24 -0
  119. package/src/pages/Cooperative/ListOfMeets/model/index.ts +1 -0
  120. package/src/pages/Cooperative/ListOfMeets/model/model.ts +117 -0
  121. package/src/pages/Cooperative/ListOfMeets/ui/ListOfMeetsPage.vue +90 -0
  122. package/src/pages/Cooperative/ListOfMeets/ui/index.ts +1 -0
  123. package/src/pages/Cooperative/ListOfOrders/index.ts +1 -1
  124. package/src/pages/Cooperative/ListOfOrders/ui/ListOfOrdersPage.vue +0 -4
  125. package/src/pages/Cooperative/ListOfParticipants/ui/ListOfParticipantsPage.vue +61 -10
  126. package/src/pages/Cooperative/ListOfParticipants/ui/index.ts +1 -1
  127. package/src/pages/Cooperative/MeetDetails/ui/MeetDetailsPage.vue +88 -0
  128. package/src/pages/Cooperative/MeetDetails/ui/index.ts +1 -0
  129. package/src/pages/Cooperative/MemberBranchList/ui/index.ts +1 -0
  130. package/src/pages/Cooperative/Payments/index.ts +1 -0
  131. package/src/pages/Cooperative/Payments/ui/PaymentsPage.vue +7 -0
  132. package/src/pages/{ExtStore → ExtensionStore}/ExtensionPage/ExtensionPage.vue +51 -24
  133. package/src/pages/{ExtStore → ExtensionStore}/ExtensionsShowcase/ExtensionsShowcase.vue +2 -2
  134. package/src/pages/{ExtStore → ExtensionStore}/InstalledExtensions/InstalledExtensions.vue +2 -2
  135. package/src/pages/Marketplace/OfferPage/ui/OfferPage.vue +1 -1
  136. package/src/pages/Marketplace/Showcase/ui/ShowcasePage.vue +1 -1
  137. package/src/pages/Marketplace/SuppliesList/ui/SuppliesListPage.vue +1 -1
  138. package/src/pages/Marketplace/UserParentOffers/ui/UserParentOffersPage.vue +1 -1
  139. package/src/pages/Marketplace/UserSuppliesList/ui/UserSuppliesListPage.vue +1 -1
  140. package/src/pages/PermissionDenied/index.ts +1 -0
  141. package/src/pages/Registrator/SignUp/EmailInput.vue +4 -3
  142. package/src/pages/Registrator/SignUp/GenerateAccount.vue +2 -3
  143. package/src/pages/Registrator/SignUp/PayInitial.vue +1 -1
  144. package/src/pages/Registrator/SignUp/ReadStatement.vue +2 -2
  145. package/src/pages/Registrator/SignUp/SelectBranch.vue +2 -2
  146. package/src/pages/Registrator/SignUp/SignStatement.vue +2 -2
  147. package/src/pages/Registrator/SignUp/SignUp.vue +5 -12
  148. package/src/pages/Registrator/SignUp/WaitingRegistration.vue +1 -5
  149. package/src/pages/Registrator/SignUp/Welcome.vue +6 -3
  150. package/src/pages/Union/ConnectionAgreement/index.ts +1 -0
  151. package/src/pages/Union/ListOfCooperatives/ui/UnionPageListOfCooperatives.vue +139 -6
  152. package/src/pages/User/DocumentsPage/UserDocumentsPage.vue +23 -0
  153. package/src/pages/User/DocumentsPage/index.ts +1 -0
  154. package/src/pages/User/PaymentsPage/ui/UserPayments.vue +11 -0
  155. package/src/pages/User/PaymentsPage/ui/index.ts +1 -0
  156. package/src/pages/User/ProfilePage/index.ts +1 -0
  157. package/src/pages/User/ProfilePage/ui/ProfilePage.vue +114 -0
  158. package/src/pages/User/ProfilePage/ui/index.ts +1 -0
  159. package/src/pages/User/SettingsPage/ui/index.ts +1 -1
  160. package/src/pages/User/WalletPage/index.ts +1 -0
  161. package/src/pages/User/WalletPage/ui/WalletPage.vue +72 -0
  162. package/src/pages/User/WalletPage/ui/index.ts +1 -0
  163. package/src/processes/init-app/index.ts +28 -0
  164. package/src/processes/init-installed-extensions/index.ts +25 -0
  165. package/src/processes/init-wallet/index.ts +40 -0
  166. package/src/processes/navigation-guard-setup/index.ts +45 -0
  167. package/src/processes/process-decisions/index.ts +275 -0
  168. package/src/processes/select-branch/index.ts +80 -0
  169. package/src/processes/watch-branch-overlay/index.ts +38 -0
  170. package/src/processes/watch-desktop-health/index.ts +33 -0
  171. package/src/shared/api/alerts.ts +2 -6
  172. package/src/shared/api/axios.ts +5 -5
  173. package/src/shared/api/client.ts +4 -4
  174. package/src/shared/api/eosio.ts +2 -2
  175. package/src/shared/api/indexDB.ts +3 -0
  176. package/src/shared/api/utils.ts +2 -2
  177. package/src/shared/config/Environment.ts +68 -0
  178. package/src/shared/config/index.ts +2 -1
  179. package/src/shared/hooks/index.ts +2 -0
  180. package/src/shared/hooks/useAgendaPoints.ts +24 -0
  181. package/src/shared/hooks/useWindowSize.ts +13 -0
  182. package/src/shared/lib/composables/useDisplayName.ts +34 -0
  183. package/src/shared/lib/navigation/index.ts +2 -0
  184. package/src/shared/lib/navigation/routeUtils.ts +51 -0
  185. package/src/shared/lib/navigation/useBackButton.ts +63 -0
  186. package/src/shared/lib/proxy/dicebear-collection.cjs +21 -0
  187. package/src/shared/lib/proxy/dicebear-core.cjs +20 -0
  188. package/src/shared/lib/proxy/email-regex.cjs +19 -0
  189. package/src/shared/lib/utils/dates/validateDateWithinRange.ts +23 -0
  190. package/src/shared/ui/BaseDocument/BaseDocument.vue +120 -90
  191. package/src/{components/menu/blockchainStatus.vue → shared/ui/BlockchainStatusBar/BlockchainStatusBar.vue} +1 -0
  192. package/src/shared/ui/BlockchainStatusBar/index.ts +1 -0
  193. package/src/shared/ui/CardStyles/index.scss +61 -0
  194. package/src/shared/ui/ClientOnly/ClientOnly.vue +15 -0
  195. package/src/shared/ui/ClientOnly/index.ts +1 -0
  196. package/src/shared/ui/ComplexDocument/ComplexDocument.vue +31 -8
  197. package/src/shared/ui/CopyableInput/index.ts +1 -0
  198. package/src/shared/ui/CopyableInput/ui/CopyableInput.vue +62 -0
  199. package/src/shared/ui/EditableEntrepreneurCard/EditableEntrepreneurCard.vue +9 -8
  200. package/src/shared/ui/EditableIndividualCard/EditableIndividualCard.vue +10 -10
  201. package/src/shared/ui/EditableOrganizationCard/EditableOrganizationCard.vue +57 -47
  202. package/src/shared/ui/Form/Form.vue +3 -1
  203. package/src/shared/ui/InputStyles/index.scss +29 -0
  204. package/src/shared/ui/TabStyles/index.scss +53 -0
  205. package/src/shared/ui/index.ts +1 -0
  206. package/src/{components/history/AccountEvents.vue → widgets/AccountActions/AccountActionsPage.vue} +2 -2
  207. package/src/widgets/AccountActions/index.ts +1 -0
  208. package/src/widgets/BankDetailsCard/ui/BankDetailsCard.vue +2 -2
  209. package/src/widgets/BranchCard/ui/BranchCard.vue +2 -2
  210. package/src/widgets/Cooperative/Documents/ListOfDocuments/ui/DocumentCard.vue +48 -0
  211. package/src/widgets/Cooperative/Documents/ListOfDocuments/ui/DocumentsTable.vue +162 -0
  212. package/src/widgets/Cooperative/Documents/ListOfDocuments/ui/ListOfDocumentsWidget.vue +77 -120
  213. package/src/widgets/Cooperative/Documents/ListOfDocuments/ui/index.ts +3 -1
  214. package/src/widgets/Cooperative/Orders/ListOfOrders/ui/ListOfOrdersWidget.vue +135 -128
  215. package/src/widgets/Cooperative/Orders/ListOfOrders/ui/OrderCard.vue +74 -0
  216. package/src/widgets/Cooperative/Orders/ListOfOrders/ui/index.ts +2 -1
  217. package/src/widgets/Cooperative/Payments/ListOfPayments/ui/ListOfPaymentsWidget.vue +216 -0
  218. package/src/widgets/Cooperative/Payments/ListOfPayments/ui/PaymentCard.vue +73 -0
  219. package/src/widgets/Cooperative/Payments/ListOfPayments/ui/index.ts +2 -0
  220. package/src/widgets/Cooperative/Payments/index.ts +1 -0
  221. package/src/widgets/Desktop/LeftDrawerMenu/LeftDrawerMenu.vue +3 -2
  222. package/src/widgets/Desktop/SecondLevelMenuList/SecondLevelMenuList.vue +58 -91
  223. package/src/widgets/Desktop/WorkspaceMenu/WorkspaceMenu.vue +114 -59
  224. package/src/widgets/{ExtStore/ExtensionCard → ExtensionCard}/ExtensionCard.vue +12 -7
  225. package/src/widgets/Header/BackButton/BackButton.vue +25 -0
  226. package/src/widgets/Header/BackButton/index.ts +1 -0
  227. package/src/widgets/Header/CommonHeader/CooperativeSettingsHeader.vue +34 -0
  228. package/src/widgets/Header/CommonHeader/ExtstoreHeader.vue +41 -0
  229. package/src/widgets/Header/CommonHeader/Header.vue +33 -198
  230. package/src/widgets/Header/CommonHeader/HeaderStyles.scss +22 -0
  231. package/src/widgets/Header/CommonHeader/MainHeader.vue +88 -0
  232. package/src/widgets/Header/CommonHeader/UserSettingsHeader.vue +29 -0
  233. package/src/widgets/Header/CommonHeader/index.ts +1 -1
  234. package/src/widgets/Header/SettingsDropdown/SettingsDropdown.vue +0 -6
  235. package/src/widgets/{Request → Marketplace}/SupplyOrderRequestCard/ui/Base/Base.vue +2 -2
  236. package/src/widgets/Meets/MeetDetailsActions/MeetDetailsActions.vue +51 -0
  237. package/src/widgets/Meets/MeetDetailsActions/index.ts +1 -0
  238. package/src/widgets/Meets/MeetDetailsActions/model.ts +46 -0
  239. package/src/widgets/Meets/MeetDetailsAgenda/MeetDetailsAgenda.vue +29 -0
  240. package/src/widgets/Meets/MeetDetailsAgenda/index.ts +1 -0
  241. package/src/widgets/Meets/MeetDetailsHeader/MeetDetailsHeader.vue +40 -0
  242. package/src/widgets/Meets/MeetDetailsHeader/index.ts +1 -0
  243. package/src/widgets/Meets/MeetDetailsVoting/MeetDetailsVoting.vue +77 -0
  244. package/src/widgets/Meets/MeetDetailsVoting/index.ts +1 -0
  245. package/src/widgets/Meets/MeetDetailsVoting/model.ts +117 -0
  246. package/src/widgets/Meets/MeetInfoCard/ui/MeetInfoCard.vue +38 -0
  247. package/src/widgets/Meets/MeetInfoCard/ui/index.ts +1 -0
  248. package/src/widgets/Meets/MeetsTable/ui/MeetsTable.vue +118 -0
  249. package/src/widgets/Meets/MeetsTable/ui/index.ts +1 -0
  250. package/src/widgets/Participants/index.ts +1 -0
  251. package/src/widgets/Participants/ui/ParticipantCard.vue +89 -0
  252. package/src/widgets/Participants/ui/ParticipantDetails.vue +79 -0
  253. package/src/widgets/Participants/ui/ParticipantsTable.vue +129 -0
  254. package/src/widgets/Participants/ui/index.ts +4 -0
  255. package/src/widgets/Questions/index.ts +3 -0
  256. package/src/widgets/Questions/ui/QuestionCard/QuestionCard.vue +109 -0
  257. package/src/widgets/Questions/ui/QuestionCard/index.ts +1 -0
  258. package/src/widgets/Questions/ui/QuestionsTable/QuestionsTable.vue +177 -0
  259. package/src/widgets/Questions/ui/QuestionsTable/index.ts +1 -0
  260. package/src/widgets/Questions/ui/VotingButtons/VotingButtons.vue +75 -0
  261. package/src/widgets/Questions/ui/VotingButtons/index.ts +1 -0
  262. package/src/widgets/Questions/ui/index.ts +3 -0
  263. package/src/widgets/RequireAgreements/index.ts +1 -0
  264. package/src/widgets/User/PaymentMethods/ui/PaymentMethods.vue +81 -85
  265. package/src-ssr/middlewares/injectEnv.ts +49 -0
  266. package/tsconfig.json +1 -1
  267. package/extensions/powerup/boot.ts +0 -17
  268. package/src/app/providers/card/store.ts +0 -42
  269. package/src/boot/branch-selector.ts +0 -40
  270. package/src/boot/init-stores.ts +0 -51
  271. package/src/boot/navigation-guards.ts +0 -46
  272. package/src/components/menu/footerMobileMenu.vue +0 -79
  273. package/src/components/soviet/index.vue +0 -76
  274. package/src/components/soviet/staff.vue +0 -274
  275. package/src/desktops/User/index.ts +0 -1
  276. package/src/desktops/User/model/index.ts +0 -329
  277. package/src/entities/Menu/model/store.ts +0 -69
  278. package/src/entities/Menu/model/types.ts +0 -11
  279. package/src/entities/Menu/ui/index.ts +0 -1
  280. package/src/entities/Order/api/index.ts +0 -14
  281. package/src/entities/Order/model/store.ts +0 -87
  282. package/src/features/Order/SetStatus/api/index.ts +0 -7
  283. package/src/features/Order/SetStatus/model/index.ts +0 -23
  284. package/src/pages/Cooperative/Contacts/ui/ContactsPage.vue +0 -7
  285. package/src/pages/Cooperative/ListOfBranches/ui/index.ts +0 -1
  286. package/src/pages/Documentor/ListOfDocuments/ListOfDocumentsPage.vue +0 -12
  287. package/src/pages/Union/Connection/index.ts +0 -1
  288. package/src/pages/_layouts/blank.vue +0 -24
  289. package/src/pages/_layouts/default.vue +0 -79
  290. package/src/types/index.ts +0 -3
  291. package/src/widgets/Commutator/Commutator.vue +0 -7
  292. package/src/widgets/Commutator/index.ts +0 -1
  293. package/src/widgets/Cooperative/Agenda/ListOfQuestions/ui/ListOfQuestions.vue +0 -273
  294. package/src/widgets/Cooperative/Agenda/ListOfQuestions/ui/index.ts +0 -1
  295. package/src/widgets/Cooperative/Contacts/ui/Contacts.vue +0 -52
  296. package/src/widgets/Cooperative/Contributions/ui/index.ts +0 -1
  297. package/src/widgets/Cooperative/Description/ui/SetDescription.vue +0 -4
  298. package/src/widgets/Cooperative/Description/ui/index.ts +0 -1
  299. package/src/widgets/Cooperative/Participants/ListOfParticipants/ui/ListOfParticipantsWidget.vue +0 -186
  300. package/src/widgets/Cooperative/Participants/ListOfParticipants/ui/index.ts +0 -1
  301. package/src/widgets/Desktop/SecondLevelMenu/SecondLevelMenu.vue +0 -59
  302. package/src/widgets/Desktop/SecondLevelMenu/index.ts +0 -1
  303. package/src/widgets/IndividualCard/ui/IndividualCard.vue +0 -170
  304. package/src/widgets/IndividualCard/ui/index.ts +0 -1
  305. package/src/widgets/OrganizationCard/ui/OrganizationCard.vue +0 -44
  306. package/src/widgets/OrganizationCard/ui/index.ts +0 -1
  307. package/src/widgets/Union/ListOfCooperatives/ui/UnionListOfCooperatives.vue +0 -136
  308. package/src/widgets/Union/ListOfCooperatives/ui/index.ts +0 -1
  309. package/src/entities/{Menu → Document}/model/index.ts +0 -0
  310. package/src/entities/{Order → Meet}/model/index.ts +0 -0
  311. package/src/entities/{Order → Payment}/index.ts +0 -0
  312. package/src/features/{Order/SetStatus → Decision/ParticipantApplication}/index.ts +0 -0
  313. package/src/{widgets/Request/SupplyOrderRequestCard → features/FreeDecision/CreateProject}/index.ts +0 -0
  314. package/src/features/{Order → Payment}/SetStatus/ui/SetOrderCompletedStatusButton/SetOrderCompletedStatusButton.vue +0 -0
  315. package/src/features/{Order → Payment}/SetStatus/ui/SetOrderCompletedStatusButton/index.ts +0 -0
  316. package/src/features/{Order → Payment}/SetStatus/ui/SetOrderPaidStatusButton/index.ts +0 -0
  317. package/src/features/{Order → Payment}/SetStatus/ui/SetOrderRefundedStatusButton/SetOrderRefundedStatusButton.vue +0 -0
  318. package/src/features/{Order → Payment}/SetStatus/ui/SetOrderRefundedStatusButton/index.ts +0 -0
  319. package/src/pages/{blank/blank.vue → Blank/BlankPage.vue} +0 -0
  320. package/src/pages/{Cooperative/Contacts/ui → Contacts}/index.ts +0 -0
  321. package/src/pages/Cooperative/{Contacts → ChangeContacts}/index.ts +0 -0
  322. package/src/{widgets/Cooperative/Contacts → pages/Cooperative/ChangeContacts}/ui/ChangeContacts.vue +0 -0
  323. package/src/pages/Cooperative/{ListOfBranches → ChangeRegisterPayments}/index.ts +0 -0
  324. package/src/pages/{Documentor → Cooperative}/ListOfDocuments/index.ts +0 -0
  325. package/src/pages/{Installer → Cooperative/ListOfMeets}/index.ts +0 -0
  326. package/src/{widgets/Cooperative/Agenda/ListOfQuestions → pages/Cooperative/MeetDetails}/index.ts +0 -0
  327. package/src/{widgets/Cooperative/Contacts → pages/Cooperative/MemberBranchList}/index.ts +0 -0
  328. package/src/pages/Cooperative/{ListOfBranches/ui/ListOfBranchesPage.vue → MemberBranchList/ui/MemberBranchListPage.vue} +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,73 @@
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 № {{ payment.id }}
6
+ div.text-caption Сумма: {{ payment.amount }}
7
+
8
+ q-separator
9
+
10
+ q-card-section.q-py-xs
11
+ div.row.items-center
12
+ div.col-6 Тип платежа:
13
+ div.col-6.text-right
14
+ q-badge(v-if="payment.details.data.includes('registration')") регистрационный
15
+ q-badge(v-else) паевой
16
+
17
+ div.row.items-center.q-mt-sm
18
+ div.col-6 От кого:
19
+ div.col-6.text-right {{ payment.username }}
20
+
21
+ div.row.items-center.q-mt-sm
22
+ div.col-6 Статус:
23
+ div.col-6.text-right
24
+ q-badge(v-if="payment.status ==='COMPLETED'" color="teal") обработан
25
+ q-badge(v-if="payment.status ==='PENDING'" color="orange") ожидание оплаты
26
+ q-badge(v-if="payment.status ==='FAILED'" color="red") ошибка
27
+ q-badge(v-if="payment.status ==='PAID'" color="orange") оплачен
28
+ q-badge(v-if="payment.status ==='REFUNDED'" color="grey") отменён
29
+ q-badge(v-if="payment.status ==='EXPIRED'" color="grey") истёк
30
+
31
+ q-card-actions(align="right")
32
+ q-btn(
33
+ v-if="payment.message"
34
+ size="sm"
35
+ flat
36
+ icon="expand_more"
37
+ @click="$emit('toggle-expand')"
38
+ )
39
+ | {{ expanded ? 'Скрыть' : 'Подробнее' }}
40
+
41
+ q-btn-dropdown(v-if="!hideActions" size="sm" label="действия" color="primary")
42
+ q-list(dense)
43
+ SetOrderPaidStatusButton(:id="payment.id" @close="$emit('close-dropdown')")
44
+ SetOrderRefundedStatusButton(:id="payment.id" @close="$emit('close-dropdown')")
45
+
46
+ q-slide-transition
47
+ div(v-show="expanded && payment.message")
48
+ q-separator
49
+ q-card-section
50
+ p Причина ошибки: {{payment.message}}
51
+ </template>
52
+
53
+ <script setup lang="ts">
54
+ import { SetOrderPaidStatusButton } from 'src/features/Payment/SetStatus/ui/SetOrderPaidStatusButton';
55
+ import { SetOrderRefundedStatusButton } from 'src/features/Payment/SetStatus/ui/SetOrderRefundedStatusButton';
56
+
57
+ defineProps({
58
+ payment: {
59
+ type: Object,
60
+ required: true
61
+ },
62
+ expanded: {
63
+ type: Boolean,
64
+ default: false
65
+ },
66
+ hideActions: {
67
+ type: Boolean,
68
+ default: false
69
+ }
70
+ })
71
+
72
+ defineEmits(['toggle-expand', 'close-dropdown'])
73
+ </script>
@@ -0,0 +1,2 @@
1
+ export { default as PaymentCard } from './PaymentCard.vue'
2
+ export { default as ListOfPaymentsWidget } from './ListOfPaymentsWidget.vue'
@@ -0,0 +1 @@
1
+ export * from './ListOfPayments'
@@ -1,10 +1,11 @@
1
1
  <template lang="pug">
2
2
  div
3
- //- WorkspaceMenu
3
+ WorkspaceMenu
4
+
4
5
  SecondLevelMenuList
5
6
 
6
7
  </template>
7
8
  <script setup lang="ts">
8
9
  import { SecondLevelMenuList } from '../SecondLevelMenuList';
9
-
10
+ import { WorkspaceMenu } from '../WorkspaceMenu';
10
11
  </script>
@@ -1,115 +1,82 @@
1
1
  <template lang="pug">
2
- q-list(
3
- v-if="filteredRoutes"
4
- class="second-menu"
5
- )
6
-
7
- q-item(
8
- v-for="route in filteredRoutes"
9
- :key="route.name"
10
- clickable
11
- v-ripple
12
- :active="isActive(route)"
13
- active-class="bg-gradient-dark text-white"
14
- @click="navigate(route)"
15
- )
16
-
17
- q-item-section
18
- q-item-label.no-select
19
- span {{ route.meta.title }}
20
-
21
- // показываем иконку замка с цветом если требуется роль не user
22
- q-icon(v-if="route.meta.roles && !route.meta.roles.includes('user') && route.meta.roles.length > 0" name="fa-solid fa-lock-open" :color="context.userRole == 'member' ? 'orange' : 'teal' ")
23
-
2
+ div
3
+ q-list(v-if="filteredRoutes" class="second-menu")
4
+ q-item(
5
+ v-for="route in filteredRoutes"
6
+ :key="route.name"
7
+ clickable
8
+ v-ripple
9
+ :active="isActive(route)"
10
+ active-class="bg-gradient-dark text-white"
11
+ @click="navigate(route)"
12
+ )
13
+ q-item-section
14
+ q-item-label.no-select
15
+ span {{ route.meta.title }}
16
+ //- q-icon(
17
+ //- v-if="route.meta.roles && !route.meta.roles.includes('user') && route.meta.roles.length > 0"
18
+ //- name="fa-solid fa-lock-open"
19
+ //- :color="context.userRole === 'member' ? 'orange' : 'teal'"
20
+ //- )
24
21
  </template>
25
22
 
26
23
  <script lang="ts" setup>
27
- import { useCurrentUserStore } from 'src/entities/User';
28
- import { computed } from 'vue';
29
- import { useRoute, useRouter } from 'vue-router';
30
- import { useDesktopStore } from 'src/entities/Desktop/model';
31
- import { type IRoute } from 'src/entities/Desktop/model/types';
32
- import { useSystemStore } from 'src/entities/System/model';
33
-
34
- const desktop = useDesktopStore();
35
- const route = useRoute();
36
- const router = useRouter();
37
- const user = useCurrentUserStore();
38
- const { info } = useSystemStore();
39
-
24
+ import { useCurrentUserStore } from 'src/entities/User'
25
+ import { computed } from 'vue'
26
+ import { useRouter } from 'vue-router'
27
+ import { useDesktopStore } from 'src/entities/Desktop/model'
28
+ import { useSystemStore } from 'src/entities/System/model'
29
+ import type { IRoute } from 'src/entities/Desktop/model/types'
30
+
31
+ const desktop = useDesktopStore()
32
+ const router = useRouter()
33
+ const user = useCurrentUserStore()
34
+ const { info } = useSystemStore()
35
+
36
+ // Функция для проверки условия
40
37
  const evaluateCondition = (condition: string, context: Record<string, any>): boolean => {
41
38
  try {
42
- const func = new Function(...Object.keys(context), `return ${condition};`);
43
- return func(...Object.values(context));
39
+ const func = new Function(...Object.keys(context), `return ${condition};`)
40
+ return func(...Object.values(context))
44
41
  } catch (error) {
45
- console.error('Error evaluating condition:', error);
46
- return false;
42
+ console.error('Error evaluating condition:', error)
43
+ return false
47
44
  }
48
- };
45
+ }
49
46
 
47
+ // Контекст для evaluateCondition и проверки ролей
50
48
  const context = computed(() => {
51
- const isCoop = user.userAccount?.type === 'organization' &&
52
- user.userAccount?.private_data &&
53
- 'type' in user.userAccount.private_data &&
54
- user.userAccount.private_data.type === 'coop';
55
-
56
- const userRole = user.userAccount?.role || 'user';
57
-
58
- return {
59
- isCoop,
60
- userRole,
61
- userAccount: user.userAccount,
62
- coopname: info.coopname,
63
- };
64
- });
65
-
66
- const filteredRoutes = computed(() => {
67
- const secondLevelRoutes = desktop.getSecondLevel(route) as unknown as IRoute[];
68
- return secondLevelRoutes.filter((route) => {
69
- const rolesMatch = route.meta?.roles?.includes(context.value.userRole) || route.meta?.roles?.length === 0;
70
- const conditionMatch = route.meta?.conditions
71
- ? evaluateCondition(route.meta.conditions, context.value)
72
- : true; // Если условия нет, пропускаем проверку
49
+ const isCoop = user.userAccount?.type === 'organization'
50
+ && user.userAccount?.private_data
51
+ && 'type' in user.userAccount.private_data
52
+ && user.userAccount.private_data.type === 'coop'
53
+ const userRole = user.userAccount?.role || 'user'
54
+ return { isCoop, userRole, userAccount: user.userAccount, coopname: info.coopname }
55
+ })
56
+
57
+ // Используем активный второй уровень из store
58
+ const filteredRoutes = computed<IRoute[]>(() => {
59
+ return (desktop.activeSecondLevelRoutes as unknown as IRoute[]).filter(r => {
60
+ const rolesMatch = r.meta?.roles?.includes(context.value.userRole) || (r.meta?.roles && r.meta.roles.length === 0);
61
+ const conditionMatch = r.meta?.conditions ? evaluateCondition(r.meta.conditions, context.value) : true;
73
62
  return rolesMatch && conditionMatch;
74
63
  });
75
64
  });
76
65
 
77
- // Функция проверки активного маршрута
66
+
67
+ // Проверка активного маршрута
78
68
  const isActive = (routeToCheck: IRoute) => {
79
- return route.name === routeToCheck.name;
80
- };
69
+ return router.currentRoute.value.name === routeToCheck.name
70
+ }
81
71
 
82
- // Функция навигации при клике на элемент
72
+ // Навигация при клике
83
73
  const navigate = (routeToNavigate: IRoute) => {
84
- router.push({ name: routeToNavigate.name, params: { coopname: info.coopname } });
85
- };
74
+ router.push({ name: routeToNavigate.name, params: { coopname: info.coopname } })
75
+ }
86
76
  </script>
87
77
 
88
78
  <style>
89
79
  .second-menu .q-item-label {
90
80
  font-size: 12px !important;
91
81
  }
92
-
93
- .custom-ripple {
94
- position: relative;
95
- overflow: hidden;
96
- }
97
-
98
- .custom-ripple::before {
99
- content: "";
100
- position: absolute;
101
- top: 0;
102
- left: 0;
103
- width: 100%;
104
- height: 100%;
105
- background: rgba(0, 0, 0, 0.1);
106
- transform: scaleX(0);
107
- transform-origin: left;
108
- transition: transform 0.4s ease-out;
109
- z-index: 0;
110
- }
111
-
112
- .custom-ripple:active::before {
113
- transform: scaleX(1);
114
- }
115
82
  </style>
@@ -1,96 +1,151 @@
1
1
  <template lang="pug">
2
2
  div
3
- q-btn(
4
- stack
5
- v-for="route in menuRoutes" :key="route.path"
6
- v-ripple
7
- flat
8
- class="cursor-pointer btn-menu"
9
- :class="headerClass(route)"
10
- @click="open(route)"
11
- align="center"
3
+ q-carousel(
4
+ v-model="slideIndex"
5
+ animated
6
+ infinite
7
+ :arrows="menuWorkspaces.length > 1"
8
+ swipeable
9
+ control-type="flat"
10
+ control-color="grey"
11
+ height="100px"
12
+ class="workspace-menu"
12
13
  )
13
-
14
- q-icon(:name="route.meta.icon").btn-icon.q-pt-sm
15
- span.btn-font {{ route.meta.title }}
16
-
14
+ q-carousel-slide(
15
+ v-for="(item, index) in menuWorkspaces"
16
+ :name="index"
17
+ :key="item.workspaceName"
18
+ class="flex flex-center"
19
+ )
20
+ q-btn(
21
+ stack
22
+ flat
23
+ v-ripple
24
+ class="cursor-pointer btn-menu"
25
+ @click="handleClick(item, index)"
26
+ align="center"
27
+ ).full-width
28
+ q-icon(:name="item.icon").btn-icon.q-pt-sm
29
+ span.btn-font {{ item.title }}
30
+
31
+ q-dialog(v-model="showDialog")
32
+ q-card(style="min-width: 300px; max-width: 90vw")
33
+ q-bar.bg-primary.text-white
34
+ span Выберите рабочий стол
35
+ q-space
36
+ q-btn(flat dense icon="close" v-close-popup)
37
+ q-tooltip Закрыть
38
+
39
+ div.row
40
+ div(
41
+ v-for="(item, index) in menuWorkspaces"
42
+ :key="item.workspaceName"
43
+ :class="{ 'col-6': !(index === menuWorkspaces.length - 1 && menuWorkspaces.length % 2 !== 0), 'col-12': index === menuWorkspaces.length - 1 && menuWorkspaces.length % 2 !== 0 }"
44
+ )
45
+ q-btn(
46
+ stack
47
+ flat
48
+ class="full-width q-pa-sm btn-menu"
49
+ :class="headerClass(item)"
50
+ @click="selectFromDialog(index)"
51
+ )
52
+ q-icon(:name="item.icon").btn-icon
53
+ div.btn-font.text-center {{ item.title }}
17
54
  </template>
18
55
 
19
56
  <script setup lang="ts">
20
- import { computed } from 'vue'
21
- import { useRouter, useRoute } from 'vue-router'
22
- import { useQuasar } from 'quasar'
23
- import { useSystemStore } from 'src/entities/System/model';
24
- const { info } = useSystemStore()
25
-
57
+ import { ref, computed, onMounted, watch } from 'vue'
58
+ import { useRouter } from 'vue-router'
59
+ import { useSystemStore } from 'src/entities/System/model'
26
60
  import { useCurrentUserStore } from 'src/entities/User'
27
- import { type IRoute } from 'src/entities/Desktop/model/types'
28
61
  import { useDesktopStore } from 'src/entities/Desktop/model'
29
-
30
- const $q = useQuasar()
31
-
32
- const isDark = computed(() => $q.dark.isActive)
62
+ import { useSessionStore } from 'src/entities/Session'
33
63
 
34
64
  const router = useRouter()
35
- const route = useRoute()
65
+ const system = useSystemStore()
36
66
  const user = useCurrentUserStore()
67
+ const session = useSessionStore()
68
+ const desktop = useDesktopStore()
69
+ const { info } = system
37
70
 
38
- const isRouteActive = (currentRoute: IRoute) => {
39
- return route.matched.find(r => r.path === currentRoute.path) || route.name == currentRoute.name
40
- }
71
+ const slideIndex = ref(0)
72
+ const showDialog = ref(false)
73
+
74
+ // workspaceMenus – список рабочих столов из store
75
+ const workspaceMenus = computed(() => desktop.workspaceMenus)
41
76
 
42
- const headerClass = (route: IRoute) => {
43
- const isActive = isRouteActive(route)
44
- return isActive ? (isDark.value ? 'text-white bg-teal' : 'text-white bg-teal') : ''
77
+ // Фильтрация по ролям (если требуется)
78
+ const menuWorkspaces = computed(() => {
79
+ const userRole = user.userAccount?.role || 'user'
80
+ return workspaceMenus.value.filter(item =>
81
+ item.meta.roles?.includes(userRole) || !item.meta.roles || item.meta.roles.length === 0
82
+ )
83
+ })
84
+
85
+ const headerClass = (item: any) => {
86
+ return desktop?.activeWorkspaceName === item.workspaceName ? 'text-white bg-teal' : ''
45
87
  }
46
88
 
47
- const desktop = useDesktopStore()
48
89
 
49
- const open = (route: IRoute) => {
50
- if (route.children)
90
+ // Функция навигации: переходим в рамках маршрутов рабочего стола
91
+ const open = (route: any) => {
92
+ if (route && route.children && route.children.length)
51
93
  router.push({ name: route.children[0].name, params: { coopname: info.coopname } })
52
- else router.push({ name: route.name, params: { coopname: info.coopname } })
53
-
94
+ else if (route)
95
+ router.push({ name: route.name, params: { coopname: info.coopname } })
54
96
  }
55
97
 
56
- const menuRoutes = computed(() => {
57
- const userRole = user.userAccount?.role || 'user';
98
+ const handleClick = (item: any, index: number) => {
99
+ if (slideIndex.value === index) {
100
+ showDialog.value = true
101
+ } else {
102
+ slideIndex.value = index
103
+ // Обновляем активный рабочий стол
104
+ desktop.selectWorkspace(item.workspaceName)
105
+ if (item.mainRoute) open(item.mainRoute)
106
+ }
107
+ }
58
108
 
59
- return desktop.firstLevel.filter(
60
- (route) => route.meta.roles.includes(userRole) || route.meta.roles.length === 0
61
- );
109
+ const selectFromDialog = (index: number) => {
110
+ showDialog.value = false
111
+ slideIndex.value = index
112
+ const item = menuWorkspaces.value[index]
113
+ desktop.selectWorkspace(item.workspaceName)
114
+ if (item.mainRoute) open(item.mainRoute)
115
+ }
62
116
 
117
+ onMounted(() => {
118
+ if (menuWorkspaces.value.length > 0 && session.isAuth && user.isRegistrationComplete) {
119
+ slideIndex.value = 0
120
+ const firstItem = menuWorkspaces.value[0]
121
+ desktop.selectWorkspace(firstItem.workspaceName)
122
+ if (firstItem.mainRoute) open(firstItem.mainRoute)
123
+ }
63
124
  })
64
125
 
126
+ // При изменении slideIndex обновляем активный рабочий стол
127
+ watch(slideIndex, (newIndex) => {
128
+ const item = menuWorkspaces.value[newIndex]
129
+ if (item) {
130
+ desktop.selectWorkspace(item.workspaceName)
131
+ if (item.mainRoute) open(item.mainRoute)
132
+ }
133
+ })
65
134
  </script>
66
135
 
67
- <style lang="scss" scoped>
136
+ <style lang="scss">
68
137
  .btn-menu {
69
138
  height: 100px;
70
139
  width: 100px;
140
+ border-radius: 0 !important;
71
141
  }
72
-
73
142
  .btn-icon {
74
143
  font-size: 20px !important;
75
144
  }
76
-
77
145
  .btn-font {
78
146
  font-size: 8px !important;
79
147
  }
80
-
81
- .logout-btn {
82
- position: fixed;
83
- bottom: 54px;
84
- width: 100%;
85
- }
86
-
87
- .menu-container {
88
- display: flex;
89
- // flex-direction: column;
90
- height: 100%;
91
- }
92
-
93
- .control-buttons {
94
- margin-top: auto;
148
+ .workspace-menu .q-carousel__slide {
149
+ padding: 0px !important;
95
150
  }
96
151
  </style>
@@ -1,22 +1,26 @@
1
1
  <template lang="pug">
2
2
  div.q-pa-md
3
3
  q-card(flat bordered @click="open").hover-card.q-pa-md
4
- q-img(v-if="extension.image" :src="extension.image")
4
+ p.text-h6.no-margin {{extension.title}}
5
+
5
6
  div
6
7
  q-chip(outline v-for="tag in extension.tags" v-bind:key="tag" dense size="sm") {{tag}}
7
8
 
8
- p.q-mt-md.text-h6 {{extension.title}}
9
+ q-img(v-if="extension.image" :src="extension.image")
10
+
9
11
 
10
- p {{extension.description}}
12
+ p.q-mt-md {{extension.description}}
11
13
  div.flex.justify-between.items-center
12
14
  div
13
- q-chip(square dense size="sm" color="green" outline v-if="extension.installed").q-ml-sm установлено
15
+ q-chip(square dense size="md" color="green" outline v-if="extension.is_installed && extension.is_available").q-ml-sm установлено
14
16
 
15
17
  div
16
- q-btn(dense size="sm" v-if="extension.available" flat @click="open")
18
+ q-btn(dense size="sm" v-if="extension.is_available" flat @click="open")
17
19
  span подробнее
18
20
  q-icon(name="fa fa-arrow-right").q-ml-sm
19
- q-chip(size="sm" dense color="orange" v-if="!extension.available" outline) в разработке
21
+
22
+ q-chip(size="md" dense color="orange" v-if="!extension.is_available" outline) в разработке
23
+
20
24
  </template>
21
25
  <script lang="ts" setup>
22
26
  import type { IExtension } from 'src/entities/Extension/model/types';
@@ -29,10 +33,11 @@ const props = defineProps({
29
33
  }
30
34
  })
31
35
 
36
+
32
37
  const router = useRouter()
33
38
 
34
39
  const open = () => {
35
- if (props.extension.available)
40
+ if (props.extension.is_available)
36
41
  router.push({name: 'one-extension', params: {name: props.extension.name}})
37
42
  }
38
43
  </script>
@@ -0,0 +1,25 @@
1
+ <!-- BackButton.vue -->
2
+ <template lang="pug">
3
+ q-btn(
4
+ v-if="backNavigationButton"
5
+ stretch
6
+ icon="fas fa-chevron-left"
7
+ flat
8
+ @click="backNavigationButton.onClick"
9
+ ).back-button
10
+ span.q-pl-sm {{ backNavigationButton.text }}
11
+ </template>
12
+
13
+ <script setup lang="ts">
14
+ import { useDesktopStore } from 'src/entities/Desktop/model'
15
+ import { computed } from 'vue'
16
+
17
+ const desktopStore = useDesktopStore()
18
+ const backNavigationButton = computed(() => desktopStore.backNavigationButton)
19
+ </script>
20
+
21
+ <style scoped lang="scss">
22
+ .back-button {
23
+ min-width: auto;
24
+ }
25
+ </style>
@@ -0,0 +1 @@
1
+ export { default as BackButton } from './BackButton.vue'
@@ -0,0 +1,34 @@
1
+ <!-- CooperativeSettingsHeader.vue -->
2
+ <template lang="pug">
3
+ q-header(bordered).bg-gradient-dark
4
+ q-toolbar
5
+ q-btn(flat icon="fas fa-chevron-left" stretch @click="open('index')")
6
+ q-tabs(
7
+ dense
8
+ switch-indicator
9
+ inline-label
10
+ align="justify"
11
+ active-class="bg-teal"
12
+ active-bg-color="teal"
13
+ active-color="white"
14
+ indicator-color="secondary"
15
+ class="header-tab-container"
16
+ )
17
+ q-route-tab(name="Совет" label="Совет" :to="{name: 'members'}" )
18
+ q-route-tab(name="Кооперативные участки" label="Кооперативные участки" :to="{name: 'branches'}" )
19
+ q-route-tab(name="Фонды накопления" label="Фонды накопления" :to="{name: 'accumulation-funds'}" )
20
+ q-route-tab(name="Фонды списания" label="Фонды списания" :to="{name: 'expense-funds'}" )
21
+ q-route-tab(name="Взносы" label="Взносы" :to="{name: 'initial-contributions'}" )
22
+ q-route-tab(name="Контакты" label="Контакты" :to="{name: 'change-contacts'}" )
23
+ </template>
24
+
25
+ <script setup lang="ts">
26
+ import { useRouter } from 'vue-router'
27
+ import './HeaderStyles.scss'
28
+
29
+ const router = useRouter()
30
+
31
+ const open = (name: string) => {
32
+ router.push({name})
33
+ }
34
+ </script>
@@ -0,0 +1,41 @@
1
+ <!-- ExtstoreHeader.vue -->
2
+ <template lang="pug">
3
+ q-header(bordered).bg-gradient-dark
4
+ q-toolbar
5
+ q-btn(flat icon="fas fa-chevron-left" stretch @click="backFromAppstore")
6
+ q-tabs(
7
+ dense
8
+ switch-indicator
9
+ inline-label
10
+ align="justify"
11
+ active-class="bg-teal"
12
+ active-bg-color="teal"
13
+ active-color="white"
14
+ indicator-color="secondary"
15
+ class="header-tab-container"
16
+ )
17
+ q-route-tab(name="Все приложения" label="Все приложения" :to="{name: 'extstore-showcase'}" )
18
+ q-route-tab(name="Установленные" label="Установленные" :to="{name: 'appstore-installed'}" )
19
+ </template>
20
+
21
+ <script setup lang="ts">
22
+ import { useRouter, useRoute } from 'vue-router'
23
+ import './HeaderStyles.scss'
24
+
25
+ const router = useRouter()
26
+ const route = useRoute()
27
+
28
+ const is = (what: string) => route.name === what
29
+
30
+ const open = (name: string) => {
31
+ router.push({name})
32
+ }
33
+
34
+ const backFromAppstore = () => {
35
+ if (is('extension-install') || is('extension-settings'))
36
+ open('one-extension')
37
+ else if (is('one-extension'))
38
+ open('extstore-showcase')
39
+ else open('index')
40
+ }
41
+ </script>