@nixweb/nixloc-ui 1.17.0 → 1.19.0

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 (288) hide show
  1. package/.github/workflows/publish-npm.yml +32 -32
  2. package/@nixweb/nixloc-ui/.github/workflows/publish-npm.yml +32 -32
  3. package/@nixweb/nixloc-ui/README.md +24 -24
  4. package/@nixweb/nixloc-ui/babel.config.js +5 -5
  5. package/@nixweb/nixloc-ui/config/dev.env.js +8 -8
  6. package/@nixweb/nixloc-ui/config/index.js +69 -69
  7. package/@nixweb/nixloc-ui/config/prod.env.js +5 -5
  8. package/@nixweb/nixloc-ui/docs/src/component/template/ViewTemplateReportPreview.drawio +209 -209
  9. package/@nixweb/nixloc-ui/docs/src/store/modulos/relatorio.drawio +36 -36
  10. package/@nixweb/nixloc-ui/package.json +88 -88
  11. package/@nixweb/nixloc-ui/public/index.html +19 -19
  12. package/@nixweb/nixloc-ui/public/styles/app.css +52 -52
  13. package/@nixweb/nixloc-ui/src/App.vue +13 -13
  14. package/@nixweb/nixloc-ui/src/component/forms/Button.vue +163 -163
  15. package/@nixweb/nixloc-ui/src/component/forms/ButtonFilter.vue +74 -74
  16. package/@nixweb/nixloc-ui/src/component/forms/ButtonGroup.vue +66 -66
  17. package/@nixweb/nixloc-ui/src/component/forms/ButtonSub.vue +97 -97
  18. package/@nixweb/nixloc-ui/src/component/forms/ButtonToggle.vue +76 -76
  19. package/@nixweb/nixloc-ui/src/component/forms/CheckboxGroup.vue +69 -69
  20. package/@nixweb/nixloc-ui/src/component/forms/CheckboxServer.vue +192 -192
  21. package/@nixweb/nixloc-ui/src/component/forms/CheckboxSimple.vue +60 -60
  22. package/@nixweb/nixloc-ui/src/component/forms/Color.vue +38 -38
  23. package/@nixweb/nixloc-ui/src/component/forms/DateTime.vue +170 -170
  24. package/@nixweb/nixloc-ui/src/component/forms/DateYearMonth.vue +193 -193
  25. package/@nixweb/nixloc-ui/src/component/forms/Dropdown.vue +236 -236
  26. package/@nixweb/nixloc-ui/src/component/forms/EditorHtml.vue +132 -132
  27. package/@nixweb/nixloc-ui/src/component/forms/FileUpload.vue +170 -170
  28. package/@nixweb/nixloc-ui/src/component/forms/ImageUpload.vue +214 -214
  29. package/@nixweb/nixloc-ui/src/component/forms/IncrementDecrement.vue +148 -148
  30. package/@nixweb/nixloc-ui/src/component/forms/InputAddressGoogle.vue +171 -171
  31. package/@nixweb/nixloc-ui/src/component/forms/InputCallToAction.vue +135 -135
  32. package/@nixweb/nixloc-ui/src/component/forms/InputDecimal.vue +153 -153
  33. package/@nixweb/nixloc-ui/src/component/forms/InputDecimalDiscount.vue +77 -77
  34. package/@nixweb/nixloc-ui/src/component/forms/InputNumber.vue +160 -160
  35. package/@nixweb/nixloc-ui/src/component/forms/InputPassword.vue +148 -148
  36. package/@nixweb/nixloc-ui/src/component/forms/InputTag.vue +124 -124
  37. package/@nixweb/nixloc-ui/src/component/forms/InputText.vue +174 -174
  38. package/@nixweb/nixloc-ui/src/component/forms/InputTextEdit.vue +69 -69
  39. package/@nixweb/nixloc-ui/src/component/forms/InputWhatsApp.vue +47 -47
  40. package/@nixweb/nixloc-ui/src/component/forms/Modal.vue +57 -57
  41. package/@nixweb/nixloc-ui/src/component/forms/RadioGroup.vue +91 -91
  42. package/@nixweb/nixloc-ui/src/component/forms/Select.vue +378 -378
  43. package/@nixweb/nixloc-ui/src/component/forms/SelectStatic.vue +198 -198
  44. package/@nixweb/nixloc-ui/src/component/forms/SideBar.vue +99 -99
  45. package/@nixweb/nixloc-ui/src/component/forms/Slider.vue +18 -18
  46. package/@nixweb/nixloc-ui/src/component/forms/TextArea.vue +138 -138
  47. package/@nixweb/nixloc-ui/src/component/forms/Toggle.vue +72 -72
  48. package/@nixweb/nixloc-ui/src/component/layout/Account.vue +131 -131
  49. package/@nixweb/nixloc-ui/src/component/layout/Alert.vue +88 -88
  50. package/@nixweb/nixloc-ui/src/component/layout/Badge.vue +111 -111
  51. package/@nixweb/nixloc-ui/src/component/layout/BarFloating.vue +67 -67
  52. package/@nixweb/nixloc-ui/src/component/layout/FixedBar.vue +103 -103
  53. package/@nixweb/nixloc-ui/src/component/layout/Gantt.vue +128 -128
  54. package/@nixweb/nixloc-ui/src/component/layout/Header.vue +56 -56
  55. package/@nixweb/nixloc-ui/src/component/layout/HideShow.vue +61 -61
  56. package/@nixweb/nixloc-ui/src/component/layout/IconMolded.vue +58 -58
  57. package/@nixweb/nixloc-ui/src/component/layout/LoadingFullPage.vue +27 -27
  58. package/@nixweb/nixloc-ui/src/component/layout/Menu.vue +287 -287
  59. package/@nixweb/nixloc-ui/src/component/layout/Molded.vue +30 -30
  60. package/@nixweb/nixloc-ui/src/component/layout/NewAccount.vue +136 -136
  61. package/@nixweb/nixloc-ui/src/component/layout/NewHeader.vue +59 -59
  62. package/@nixweb/nixloc-ui/src/component/layout/NewIconMolded.vue +70 -70
  63. package/@nixweb/nixloc-ui/src/component/layout/NewMenu.vue +455 -455
  64. package/@nixweb/nixloc-ui/src/component/layout/Panel.vue +185 -185
  65. package/@nixweb/nixloc-ui/src/component/layout/Popover.vue +126 -126
  66. package/@nixweb/nixloc-ui/src/component/layout/ScrollBar.vue +57 -57
  67. package/@nixweb/nixloc-ui/src/component/layout/Tab.vue +135 -135
  68. package/@nixweb/nixloc-ui/src/component/layout/Tag.vue +97 -97
  69. package/@nixweb/nixloc-ui/src/component/layout/Wizard.vue +211 -211
  70. package/@nixweb/nixloc-ui/src/component/rental/DisplayCalculatePeriod.vue +48 -48
  71. package/@nixweb/nixloc-ui/src/component/rental/DisplayPeriodRent.vue +55 -55
  72. package/@nixweb/nixloc-ui/src/component/rental/DisplayTotalization.vue +86 -86
  73. package/@nixweb/nixloc-ui/src/component/report/Fields.vue +108 -108
  74. package/@nixweb/nixloc-ui/src/component/report/Report.vue +313 -313
  75. package/@nixweb/nixloc-ui/src/component/report/ReportTable.vue +111 -111
  76. package/@nixweb/nixloc-ui/src/component/report/Totalization.vue +33 -33
  77. package/@nixweb/nixloc-ui/src/component/shared/CodeEditor.vue +128 -128
  78. package/@nixweb/nixloc-ui/src/component/shared/Collapse.vue +131 -131
  79. package/@nixweb/nixloc-ui/src/component/shared/Confirmation.vue +74 -74
  80. package/@nixweb/nixloc-ui/src/component/shared/DocumentEditor.vue +99 -99
  81. package/@nixweb/nixloc-ui/src/component/shared/DocumentPreview.vue +81 -81
  82. package/@nixweb/nixloc-ui/src/component/shared/DocumentPublic.vue +33 -33
  83. package/@nixweb/nixloc-ui/src/component/shared/ExportExcel.vue +56 -56
  84. package/@nixweb/nixloc-ui/src/component/shared/ExportPDF.vue +116 -116
  85. package/@nixweb/nixloc-ui/src/component/shared/FullCalendar.vue +173 -173
  86. package/@nixweb/nixloc-ui/src/component/shared/HeaderReport.vue +47 -47
  87. package/@nixweb/nixloc-ui/src/component/shared/HorizontalFilter.vue +64 -64
  88. package/@nixweb/nixloc-ui/src/component/shared/ListNotifications.vue +70 -70
  89. package/@nixweb/nixloc-ui/src/component/shared/Loading.vue +107 -107
  90. package/@nixweb/nixloc-ui/src/component/shared/LoadingCard.vue +64 -64
  91. package/@nixweb/nixloc-ui/src/component/shared/LoadingMoreButton.vue +23 -23
  92. package/@nixweb/nixloc-ui/src/component/shared/Messages.vue +109 -109
  93. package/@nixweb/nixloc-ui/src/component/shared/PDFViewer.vue +24 -24
  94. package/@nixweb/nixloc-ui/src/component/shared/Pagination.vue +108 -108
  95. package/@nixweb/nixloc-ui/src/component/shared/ParameterLegend.vue +169 -169
  96. package/@nixweb/nixloc-ui/src/component/shared/ProgressBar.vue +25 -25
  97. package/@nixweb/nixloc-ui/src/component/shared/QueryButton.vue +66 -66
  98. package/@nixweb/nixloc-ui/src/component/shared/Report.vue +200 -200
  99. package/@nixweb/nixloc-ui/src/component/shared/SaveCancel.vue +99 -99
  100. package/@nixweb/nixloc-ui/src/component/shared/Search.vue +174 -174
  101. package/@nixweb/nixloc-ui/src/component/shared/SelectOption.vue +162 -162
  102. package/@nixweb/nixloc-ui/src/component/shared/Table.vue +174 -174
  103. package/@nixweb/nixloc-ui/src/component/shared/TableButton.vue +36 -36
  104. package/@nixweb/nixloc-ui/src/component/shared/TableDraggable.vue +117 -117
  105. package/@nixweb/nixloc-ui/src/component/shared/TableImport.vue +93 -93
  106. package/@nixweb/nixloc-ui/src/component/shared/TableItem.vue +214 -214
  107. package/@nixweb/nixloc-ui/src/component/shared/TableTotalPerPage.vue +77 -77
  108. package/@nixweb/nixloc-ui/src/component/shared/TableTotalRecords.vue +44 -44
  109. package/@nixweb/nixloc-ui/src/component/shared/TableTotalization.vue +47 -47
  110. package/@nixweb/nixloc-ui/src/component/shared/TimeLine.vue +41 -41
  111. package/@nixweb/nixloc-ui/src/component/shared/Timer.vue +77 -77
  112. package/@nixweb/nixloc-ui/src/component/shared/Tip.vue +42 -42
  113. package/@nixweb/nixloc-ui/src/component/shared/Toast.vue +69 -69
  114. package/@nixweb/nixloc-ui/src/component/shared/ToggleTheme.vue +127 -127
  115. package/@nixweb/nixloc-ui/src/component/shared/TotalizationReport.vue +86 -86
  116. package/@nixweb/nixloc-ui/src/component/shared/VerticalFilter.vue +97 -97
  117. package/@nixweb/nixloc-ui/src/component/shared/automation/ActivitiesList.vue +43 -43
  118. package/@nixweb/nixloc-ui/src/component/shared/automation/AddRule.vue +60 -60
  119. package/@nixweb/nixloc-ui/src/component/shared/automation/AutomationBuilder.vue +26 -26
  120. package/@nixweb/nixloc-ui/src/component/shared/automation/DynamicComponentList.vue +85 -85
  121. package/@nixweb/nixloc-ui/src/component/shared/automation/SelectRule.vue +97 -97
  122. package/@nixweb/nixloc-ui/src/component/shared/automation/components/BillingByRent.vue +97 -97
  123. package/@nixweb/nixloc-ui/src/component/shared/automation/components/SendEmail.vue +93 -93
  124. package/@nixweb/nixloc-ui/src/component/shared/file-manager/FileManager.vue +390 -390
  125. package/@nixweb/nixloc-ui/src/component/shared/filter-builder/FilterBuilder.vue +220 -220
  126. package/@nixweb/nixloc-ui/src/component/shared/filter-builder/FilterQuery.vue +94 -94
  127. package/@nixweb/nixloc-ui/src/component/shared/query-builder/AddRule.vue +203 -203
  128. package/@nixweb/nixloc-ui/src/component/shared/query-builder/ConvertToOdata.js +86 -86
  129. package/@nixweb/nixloc-ui/src/component/shared/query-builder/DynamicComponent.vue +161 -161
  130. package/@nixweb/nixloc-ui/src/component/shared/query-builder/DynamicComponentList.vue +70 -70
  131. package/@nixweb/nixloc-ui/src/component/shared/query-builder/Fields.vue +93 -93
  132. package/@nixweb/nixloc-ui/src/component/shared/query-builder/QueryBuilder.vue +69 -69
  133. package/@nixweb/nixloc-ui/src/component/shared/query-builder/Rules.vue +68 -68
  134. package/@nixweb/nixloc-ui/src/component/shared/query-builder/SelectRule.vue +97 -97
  135. package/@nixweb/nixloc-ui/src/component/shared/query-builder/Tags.vue +59 -59
  136. package/@nixweb/nixloc-ui/src/component/shared/query-builder/utilities.js +21 -21
  137. package/@nixweb/nixloc-ui/src/component/signature/Payment.vue +160 -160
  138. package/@nixweb/nixloc-ui/src/component/signature/Warning.vue +75 -75
  139. package/@nixweb/nixloc-ui/src/component/template/ListViewWithDataHandler.vue +429 -429
  140. package/@nixweb/nixloc-ui/src/component/template/ReportCreateUpdate.vue +110 -110
  141. package/@nixweb/nixloc-ui/src/component/template/ViewTemplateConfiguration.vue +64 -64
  142. package/@nixweb/nixloc-ui/src/component/template/ViewTemplateDocumentView.vue +213 -213
  143. package/@nixweb/nixloc-ui/src/component/template/ViewTemplateImportFile.vue +347 -347
  144. package/@nixweb/nixloc-ui/src/component/template/ViewTemplateReportList.vue +217 -217
  145. package/@nixweb/nixloc-ui/src/component/template/ViewTemplateReportPreview.vue +432 -432
  146. package/@nixweb/nixloc-ui/src/component/template/ViewTemplateSelectOption.vue +46 -46
  147. package/@nixweb/nixloc-ui/src/component/template/ViewTemplateWithSalveCancel.vue +32 -32
  148. package/@nixweb/nixloc-ui/src/component/template/ViewTemplateWithTable.vue +62 -62
  149. package/@nixweb/nixloc-ui/src/component/template/model/Report.js +5 -5
  150. package/@nixweb/nixloc-ui/src/component/training/Course.vue +343 -343
  151. package/@nixweb/nixloc-ui/src/component/training/CourseView.vue +189 -189
  152. package/@nixweb/nixloc-ui/src/component/value-objects/Address.js +10 -10
  153. package/@nixweb/nixloc-ui/src/component/value-objects/Address.vue +157 -157
  154. package/@nixweb/nixloc-ui/src/component/value-objects/Contact.js +6 -6
  155. package/@nixweb/nixloc-ui/src/component/value-objects/Contact.vue +106 -106
  156. package/@nixweb/nixloc-ui/src/component/value-objects/Person.js +10 -10
  157. package/@nixweb/nixloc-ui/src/component/value-objects/Person.vue +129 -129
  158. package/@nixweb/nixloc-ui/src/config/axios.js +9 -9
  159. package/@nixweb/nixloc-ui/src/config/dicas.js +14 -14
  160. package/@nixweb/nixloc-ui/src/config/router.js +13 -13
  161. package/@nixweb/nixloc-ui/src/config/token.js +14 -14
  162. package/@nixweb/nixloc-ui/src/main.js +23 -23
  163. package/@nixweb/nixloc-ui/src/store/modules/automation.js +30 -30
  164. package/@nixweb/nixloc-ui/src/store/modules/generic.js +815 -815
  165. package/@nixweb/nixloc-ui/src/store/modules/report.js +277 -277
  166. package/@nixweb/nixloc-ui/src/store/modules/user.js +66 -66
  167. package/@nixweb/nixloc-ui/src/store/modules/util.js +25 -25
  168. package/@nixweb/nixloc-ui/src/store/modules/validation.js +38 -38
  169. package/@nixweb/nixloc-ui/src/store/store.js +13 -13
  170. package/README.md +24 -24
  171. package/babel.config.js +5 -5
  172. package/config/dev.env.js +8 -8
  173. package/config/index.js +69 -69
  174. package/config/prod.env.js +5 -5
  175. package/docs/src/component/template/ViewTemplateReportPreview.drawio +209 -209
  176. package/docs/src/store/modulos/relatorio.drawio +36 -36
  177. package/package.json +88 -88
  178. package/public/index.html +19 -19
  179. package/public/styles/app.css +52 -52
  180. package/src/component/forms/ButtonFilter.vue +104 -104
  181. package/src/component/forms/ButtonGroup.vue +66 -66
  182. package/src/component/forms/ButtonGroupInline.vue +210 -210
  183. package/src/component/forms/ButtonSub.vue +97 -97
  184. package/src/component/forms/ButtonToggle.vue +76 -76
  185. package/src/component/forms/DateYearMonth.vue +192 -192
  186. package/src/component/forms/ImageUpload.vue +214 -214
  187. package/src/component/forms/IncrementDecrement.vue +151 -151
  188. package/src/component/forms/InputAddressGoogle.vue +171 -171
  189. package/src/component/forms/InputCallToAction.vue +135 -135
  190. package/src/component/forms/InputDecimalDiscount.vue +146 -146
  191. package/src/component/forms/InputTag.vue +124 -124
  192. package/src/component/forms/InputTextEdit.vue +69 -69
  193. package/src/component/forms/InputWhatsApp.vue +47 -47
  194. package/src/component/forms/SideBar.vue +99 -99
  195. package/src/component/forms/Toggle.vue +72 -72
  196. package/src/component/layout/Account.vue +131 -131
  197. package/src/component/layout/AnimatedPhrase.vue +68 -68
  198. package/src/component/layout/BarFloating.vue +67 -67
  199. package/src/component/layout/BottomActionsBar.vue +205 -205
  200. package/src/component/layout/ColorPicker.vue +175 -175
  201. package/src/component/layout/Gantt.vue +128 -128
  202. package/src/component/layout/HideShow.vue +61 -61
  203. package/src/component/layout/IconMolded.vue +58 -58
  204. package/src/component/layout/IconPicker.vue +161 -161
  205. package/src/component/layout/NewAccount.vue +136 -136
  206. package/src/component/layout/NewHeader.vue +59 -59
  207. package/src/component/layout/NewIconMolded.vue +70 -70
  208. package/src/component/layout/NewMenu.vue +472 -472
  209. package/src/component/layout/ScrollBar.vue +21 -8
  210. package/src/component/layout/Tab.vue +259 -259
  211. package/src/component/layout/Tag.vue +97 -97
  212. package/src/component/layout/Tooltip.vue +155 -155
  213. package/src/component/layout/Zoom.vue +111 -111
  214. package/src/component/rental/DisplayCalculatePeriod.vue +48 -48
  215. package/src/component/rental/DisplayPeriodRent.vue +55 -55
  216. package/src/component/rental/DisplayTotalization.vue +86 -86
  217. package/src/component/report/Fields.vue +108 -108
  218. package/src/component/report/Report.vue +377 -377
  219. package/src/component/report/ReportTable.vue +111 -111
  220. package/src/component/report/Totalization.vue +33 -33
  221. package/src/component/shared/CodeEditor.vue +128 -128
  222. package/src/component/shared/Confirmation.vue +74 -74
  223. package/src/component/shared/DocumentEditor.vue +99 -99
  224. package/src/component/shared/DocumentPreview.vue +105 -105
  225. package/src/component/shared/DocumentPublic.vue +33 -33
  226. package/src/component/shared/ExportExcel.vue +56 -56
  227. package/src/component/shared/FullCalendar.vue +175 -175
  228. package/src/component/shared/HeaderReport.vue +47 -47
  229. package/src/component/shared/ListNotifications.vue +70 -70
  230. package/src/component/shared/Loading.vue +4 -1
  231. package/src/component/shared/LoadingCard.vue +64 -64
  232. package/src/component/shared/ParameterLegend.vue +169 -169
  233. package/src/component/shared/Report.vue +250 -250
  234. package/src/component/shared/SaveCancel.vue +117 -99
  235. package/src/component/shared/SelectOption.vue +162 -162
  236. package/src/component/shared/TableDraggable.vue +117 -117
  237. package/src/component/shared/TableImport.vue +93 -93
  238. package/src/component/shared/TableItem.vue +228 -228
  239. package/src/component/shared/TableTotalPerPage.vue +114 -114
  240. package/src/component/shared/TableTotalRecords.vue +44 -44
  241. package/src/component/shared/TimeLine.vue +41 -41
  242. package/src/component/shared/Timer.vue +77 -77
  243. package/src/component/shared/ToggleTheme.vue +127 -127
  244. package/src/component/shared/TotalizationReport.vue +86 -86
  245. package/src/component/shared/actions/ActionButtons.vue +53 -53
  246. package/src/component/shared/actions/ActionErrorContent.vue +103 -103
  247. package/src/component/shared/actions/ActionFooter.vue +99 -93
  248. package/src/component/shared/actions/ActionHeader.vue +110 -110
  249. package/src/component/shared/actions/ActionItemList.vue +143 -143
  250. package/src/component/shared/actions/ActionsOptions.vue +209 -209
  251. package/src/component/shared/actions/ActionsSelected.vue +262 -262
  252. package/src/component/shared/automation/ActivitiesList.vue +43 -43
  253. package/src/component/shared/automation/AddRule.vue +60 -60
  254. package/src/component/shared/automation/AutomationBuilder.vue +26 -26
  255. package/src/component/shared/automation/DynamicComponentList.vue +85 -85
  256. package/src/component/shared/automation/SelectRule.vue +97 -97
  257. package/src/component/shared/automation/components/BillingByRent.vue +97 -97
  258. package/src/component/shared/automation/components/SendEmail.vue +93 -93
  259. package/src/component/shared/file-manager/FileManager.vue +390 -390
  260. package/src/component/shared/filter-builder/FilterBuilder.vue +220 -220
  261. package/src/component/shared/filter-builder/FilterQuery.vue +95 -95
  262. package/src/component/shared/query-builder/ConvertToOdata.js +86 -86
  263. package/src/component/shared/query-builder/DynamicComponent.vue +161 -161
  264. package/src/component/shared/query-builder/Fields.vue +93 -93
  265. package/src/component/shared/query-builder/Rules.vue +68 -68
  266. package/src/component/shared/query-builder/SelectRule.vue +97 -97
  267. package/src/component/shared/query-builder/Tags.vue +59 -59
  268. package/src/component/signature/Payment.vue +160 -160
  269. package/src/component/signature/Warning.vue +75 -75
  270. package/src/component/template/ReportCreateUpdate.vue +110 -110
  271. package/src/component/template/ViewTemplateDocumentView.vue +213 -213
  272. package/src/component/template/ViewTemplateImportFile.vue +347 -347
  273. package/src/component/template/ViewTemplateReportList.vue +240 -240
  274. package/src/component/template/ViewTemplateReportPreview.vue +521 -521
  275. package/src/component/template/ViewTemplateSelectOption.vue +46 -46
  276. package/src/component/template/model/Report.js +5 -5
  277. package/src/component/training/Course.vue +343 -343
  278. package/src/component/training/CourseView.vue +198 -198
  279. package/src/component/value-objects/Address.js +10 -10
  280. package/src/component/value-objects/Address.vue +173 -173
  281. package/src/component/value-objects/Contact.js +6 -6
  282. package/src/component/value-objects/Contact.vue +106 -106
  283. package/src/component/value-objects/Person.js +10 -10
  284. package/src/component/value-objects/Person.vue +130 -130
  285. package/src/store/modules/automation.js +30 -30
  286. package/src/store/modules/report.js +277 -277
  287. package/src/store/modules/user.js +69 -69
  288. package/src/store/modules/util.js +25 -25
@@ -1,287 +1,287 @@
1
- <template>
2
- <div class="menu-container" :class="{ 'menu-open': subMenuFirstLevel }">
3
- <ul class="menu">
4
- <li v-if="false">
5
- <div class="div-logo text-center">
6
- <img :src="urlImage" />
7
- </div>
8
- </li>
9
- <li class="molded-menu">
10
- <div class="text-center div-photo" @click="editProfile">
11
- <img class="photo" :src="urlPhoto" />
12
- </div>
13
- <div
14
- class="box-main"
15
- v-for="(item, index) in menuFilter(true)"
16
- :key="index"
17
- >
18
- <a
19
- href="#"
20
- @click.prevent="openSubMenu(item.module)"
21
- :class="highlightSession(item.module)"
22
- >
23
- <div
24
- :class="{
25
- 'icon-active': menuActive == item.module,
26
- 'icon-normal': menuActive != item.module,
27
- }"
28
- >
29
- <b-row>
30
- <b-col sm="12">
31
- <div class="box-icon text-center">
32
- <i :class="item.icon"></i><br />
33
- <div class="div-title-menu">{{ item.title }}</div>
34
- </div>
35
- </b-col>
36
- </b-row>
37
-
38
- <!-- <b-row v-if="false">
39
- <b-col sm="12">
40
- <div class="div-title-menu text-center">
41
- <span
42
- :class="{
43
- 'title-active': menuActive == item.module,
44
- 'title-normal': menuActive != item.module,
45
- }"
46
- >{{ item.title }}</span
47
- >
48
- </div>
49
- </b-col>
50
- </b-row> -->
51
- </div>
52
- </a>
53
- </div>
54
- </li>
55
- </ul>
56
-
57
- <transition name="slide-fade">
58
- <div class="context-menu-container" v-if="subMenuFirstLevel">
59
- <div>
60
- <ul class="context-menu">
61
- <li v-for="(item, index) in subMenuFilter(false)" :key="index">
62
- <h5 v-if="item.type === 'group'" class="context-menu__title">
63
- <span class="sub-title"> {{ item.groupName }}</span>
64
- <span
65
- v-if="index === 0"
66
- @click.prevent="hideSubMenu"
67
- class="context-menu__btn-close icon-close"
68
- href="#"
69
- >
70
- <i class="fas fa-times-circle"></i>
71
- </span>
72
- </h5>
73
-
74
- <a
75
- v-else
76
- href="#"
77
- @click.prevent="navegateTo(item)"
78
- :class="classSubMenu(item.title)"
79
- >
80
- <b-row>
81
- <b-col sm="1">
82
- <i
83
- class="menu-icon"
84
- :style="'color:' + item.iconColor"
85
- :class="item.icon"
86
- ></i>
87
- </b-col>
88
- <b-col sm="10">
89
- <span class="title-sub"> {{ item.title }} </span>
90
- </b-col>
91
- </b-row>
92
- </a>
93
- </li>
94
- </ul>
95
- </div>
96
- </div>
97
- </transition>
98
- </div>
99
- </template>
100
-
101
- <script>
102
- import { mapState, mapMutations, mapGetters } from "vuex";
103
- export default {
104
- name: "Menu",
105
- props: {
106
- baseColor: {
107
- type: String,
108
- default: "#4680A5",
109
- },
110
- baseColorActive: {
111
- type: String,
112
- default: "#3F529B",
113
- },
114
- urlImage: String,
115
- urlPhoto: String,
116
- },
117
- data() {
118
- return {
119
- module: "",
120
- subMenuFirstLevel: false,
121
- menuActive: "Dashboard",
122
- };
123
- },
124
- methods: {
125
- ...mapMutations("generic", ["addEvent"]),
126
- editProfile() {
127
- this.addEvent({ name: "clickedProfile" });
128
- },
129
- openSubMenu(module) {
130
- this.subMenuFirstLevel = true;
131
- this.module = module;
132
- },
133
- hideSubMenu() {
134
- this.subMenuFirstLevel = false;
135
- this.menuItens = [];
136
- },
137
- highlightSession(section) {
138
- return {
139
- menu__link: true,
140
- "menu__link--active": section === this.contextSection,
141
- };
142
- },
143
- classSubMenu(subMenuName) {
144
- return {
145
- "context-menu__link": true,
146
- "context-menu__link--active": this.activeSubMenu === subMenuName,
147
- };
148
- },
149
- navegateTo(item) {
150
- this.$router.push({
151
- name: item.routeName,
152
- });
153
- this.hideSubMenu();
154
- },
155
- menuFilter(isModule) {
156
- let filter = [];
157
- this.menu.items.forEach(function (obj) {
158
- if (obj.isModule == isModule) filter.push(obj);
159
- });
160
- return filter.sort((a, b) => a.order - b.order);
161
- },
162
- subMenuFilter(isModule) {
163
- let filter = [];
164
- let self = this;
165
- let userLogged = this.userLogged.user.userName;
166
- this.menu.items.forEach(function (obj) {
167
- if (obj.isModule == isModule && obj.module === self.module) {
168
- if (obj.isVisible == "all") filter.push(obj);
169
-
170
- if (obj.isVisible == "support" && userLogged == "UserTemp")
171
- filter.push(obj);
172
- }
173
- });
174
- return filter;
175
- },
176
- },
177
- computed: {
178
- ...mapState("user", ["menu", "userLogged"]),
179
- ...mapGetters("generic", ["event"]),
180
- },
181
- watch: {
182
- event: {
183
- handler(event) {
184
- if (event.name == "closeMenu") this.hideSubMenu();
185
- },
186
- deep: true,
187
- },
188
- $route: {
189
- handler: function (router) {
190
- this.menuActive = router.matched[0].props.default.module;
191
- },
192
- deep: true,
193
- },
194
- },
195
- };
196
- </script>
197
-
198
- <style scoped>
199
- .menu-open {
200
- width: 350px;
201
- z-index: 1000;
202
- }
203
-
204
- .div-logo {
205
- padding-top: 12px;
206
- padding-left: 10px;
207
- padding-bottom: 15px;
208
- }
209
-
210
- .photo {
211
- margin: 0;
212
- border-radius: 20px;
213
- height: 40px;
214
- width: 40px;
215
- margin-top: 10px;
216
- margin-bottom: 10px;
217
- }
218
-
219
- .icon-close {
220
- margin-right: 10px;
221
- margin-top: -5px;
222
- font-size: 22px;
223
- }
224
-
225
- .icon {
226
- font-size: 20px;
227
- }
228
-
229
- .icon-dash {
230
- font-size: 22px;
231
- }
232
-
233
- .box-main {
234
- display: flex;
235
- align-items: center;
236
- justify-content: center;
237
- }
238
-
239
- .box-icon {
240
- width: 60px;
241
- border-radius: 18px;
242
- }
243
-
244
- .div-title-menu {
245
- margin-top: -10px;
246
- font-size: 12.5px;
247
- font-weight: 300;
248
- color: black;
249
- }
250
-
251
- .title-sub {
252
- margin-left: -3px;
253
- font-weight: 400;
254
- }
255
-
256
- .margin-hidden {
257
- margin-bottom: 5px;
258
- }
259
-
260
- .sub-title {
261
- font-size: 16px;
262
- font-weight: normal;
263
- }
264
-
265
- img {
266
- height: 36px;
267
- margin-top: 5px;
268
- }
269
-
270
- .menu-icon {
271
- font-size: 15px;
272
- }
273
-
274
- .molded-menu {
275
- margin-top: 5px;
276
- margin-left: 8px;
277
- padding: 5px;
278
- padding-bottom: 1px !important;
279
- background-color: white;
280
- border: 1px solid #e8eaed;
281
- border-radius: 12px !important;
282
- }
283
-
284
- .div-photo {
285
- cursor: pointer;
286
- }
287
- </style>
1
+ <template>
2
+ <div class="menu-container" :class="{ 'menu-open': subMenuFirstLevel }">
3
+ <ul class="menu">
4
+ <li v-if="false">
5
+ <div class="div-logo text-center">
6
+ <img :src="urlImage" />
7
+ </div>
8
+ </li>
9
+ <li class="molded-menu">
10
+ <div class="text-center div-photo" @click="editProfile">
11
+ <img class="photo" :src="urlPhoto" />
12
+ </div>
13
+ <div
14
+ class="box-main"
15
+ v-for="(item, index) in menuFilter(true)"
16
+ :key="index"
17
+ >
18
+ <a
19
+ href="#"
20
+ @click.prevent="openSubMenu(item.module)"
21
+ :class="highlightSession(item.module)"
22
+ >
23
+ <div
24
+ :class="{
25
+ 'icon-active': menuActive == item.module,
26
+ 'icon-normal': menuActive != item.module,
27
+ }"
28
+ >
29
+ <b-row>
30
+ <b-col sm="12">
31
+ <div class="box-icon text-center">
32
+ <i :class="item.icon"></i><br />
33
+ <div class="div-title-menu">{{ item.title }}</div>
34
+ </div>
35
+ </b-col>
36
+ </b-row>
37
+
38
+ <!-- <b-row v-if="false">
39
+ <b-col sm="12">
40
+ <div class="div-title-menu text-center">
41
+ <span
42
+ :class="{
43
+ 'title-active': menuActive == item.module,
44
+ 'title-normal': menuActive != item.module,
45
+ }"
46
+ >{{ item.title }}</span
47
+ >
48
+ </div>
49
+ </b-col>
50
+ </b-row> -->
51
+ </div>
52
+ </a>
53
+ </div>
54
+ </li>
55
+ </ul>
56
+
57
+ <transition name="slide-fade">
58
+ <div class="context-menu-container" v-if="subMenuFirstLevel">
59
+ <div>
60
+ <ul class="context-menu">
61
+ <li v-for="(item, index) in subMenuFilter(false)" :key="index">
62
+ <h5 v-if="item.type === 'group'" class="context-menu__title">
63
+ <span class="sub-title"> {{ item.groupName }}</span>
64
+ <span
65
+ v-if="index === 0"
66
+ @click.prevent="hideSubMenu"
67
+ class="context-menu__btn-close icon-close"
68
+ href="#"
69
+ >
70
+ <i class="fas fa-times-circle"></i>
71
+ </span>
72
+ </h5>
73
+
74
+ <a
75
+ v-else
76
+ href="#"
77
+ @click.prevent="navegateTo(item)"
78
+ :class="classSubMenu(item.title)"
79
+ >
80
+ <b-row>
81
+ <b-col sm="1">
82
+ <i
83
+ class="menu-icon"
84
+ :style="'color:' + item.iconColor"
85
+ :class="item.icon"
86
+ ></i>
87
+ </b-col>
88
+ <b-col sm="10">
89
+ <span class="title-sub"> {{ item.title }} </span>
90
+ </b-col>
91
+ </b-row>
92
+ </a>
93
+ </li>
94
+ </ul>
95
+ </div>
96
+ </div>
97
+ </transition>
98
+ </div>
99
+ </template>
100
+
101
+ <script>
102
+ import { mapState, mapMutations, mapGetters } from "vuex";
103
+ export default {
104
+ name: "Menu",
105
+ props: {
106
+ baseColor: {
107
+ type: String,
108
+ default: "#4680A5",
109
+ },
110
+ baseColorActive: {
111
+ type: String,
112
+ default: "#3F529B",
113
+ },
114
+ urlImage: String,
115
+ urlPhoto: String,
116
+ },
117
+ data() {
118
+ return {
119
+ module: "",
120
+ subMenuFirstLevel: false,
121
+ menuActive: "Dashboard",
122
+ };
123
+ },
124
+ methods: {
125
+ ...mapMutations("generic", ["addEvent"]),
126
+ editProfile() {
127
+ this.addEvent({ name: "clickedProfile" });
128
+ },
129
+ openSubMenu(module) {
130
+ this.subMenuFirstLevel = true;
131
+ this.module = module;
132
+ },
133
+ hideSubMenu() {
134
+ this.subMenuFirstLevel = false;
135
+ this.menuItens = [];
136
+ },
137
+ highlightSession(section) {
138
+ return {
139
+ menu__link: true,
140
+ "menu__link--active": section === this.contextSection,
141
+ };
142
+ },
143
+ classSubMenu(subMenuName) {
144
+ return {
145
+ "context-menu__link": true,
146
+ "context-menu__link--active": this.activeSubMenu === subMenuName,
147
+ };
148
+ },
149
+ navegateTo(item) {
150
+ this.$router.push({
151
+ name: item.routeName,
152
+ });
153
+ this.hideSubMenu();
154
+ },
155
+ menuFilter(isModule) {
156
+ let filter = [];
157
+ this.menu.items.forEach(function (obj) {
158
+ if (obj.isModule == isModule) filter.push(obj);
159
+ });
160
+ return filter.sort((a, b) => a.order - b.order);
161
+ },
162
+ subMenuFilter(isModule) {
163
+ let filter = [];
164
+ let self = this;
165
+ let userLogged = this.userLogged.user.userName;
166
+ this.menu.items.forEach(function (obj) {
167
+ if (obj.isModule == isModule && obj.module === self.module) {
168
+ if (obj.isVisible == "all") filter.push(obj);
169
+
170
+ if (obj.isVisible == "support" && userLogged == "UserTemp")
171
+ filter.push(obj);
172
+ }
173
+ });
174
+ return filter;
175
+ },
176
+ },
177
+ computed: {
178
+ ...mapState("user", ["menu", "userLogged"]),
179
+ ...mapGetters("generic", ["event"]),
180
+ },
181
+ watch: {
182
+ event: {
183
+ handler(event) {
184
+ if (event.name == "closeMenu") this.hideSubMenu();
185
+ },
186
+ deep: true,
187
+ },
188
+ $route: {
189
+ handler: function (router) {
190
+ this.menuActive = router.matched[0].props.default.module;
191
+ },
192
+ deep: true,
193
+ },
194
+ },
195
+ };
196
+ </script>
197
+
198
+ <style scoped>
199
+ .menu-open {
200
+ width: 350px;
201
+ z-index: 1000;
202
+ }
203
+
204
+ .div-logo {
205
+ padding-top: 12px;
206
+ padding-left: 10px;
207
+ padding-bottom: 15px;
208
+ }
209
+
210
+ .photo {
211
+ margin: 0;
212
+ border-radius: 20px;
213
+ height: 40px;
214
+ width: 40px;
215
+ margin-top: 10px;
216
+ margin-bottom: 10px;
217
+ }
218
+
219
+ .icon-close {
220
+ margin-right: 10px;
221
+ margin-top: -5px;
222
+ font-size: 22px;
223
+ }
224
+
225
+ .icon {
226
+ font-size: 20px;
227
+ }
228
+
229
+ .icon-dash {
230
+ font-size: 22px;
231
+ }
232
+
233
+ .box-main {
234
+ display: flex;
235
+ align-items: center;
236
+ justify-content: center;
237
+ }
238
+
239
+ .box-icon {
240
+ width: 60px;
241
+ border-radius: 18px;
242
+ }
243
+
244
+ .div-title-menu {
245
+ margin-top: -10px;
246
+ font-size: 12.5px;
247
+ font-weight: 300;
248
+ color: black;
249
+ }
250
+
251
+ .title-sub {
252
+ margin-left: -3px;
253
+ font-weight: 400;
254
+ }
255
+
256
+ .margin-hidden {
257
+ margin-bottom: 5px;
258
+ }
259
+
260
+ .sub-title {
261
+ font-size: 16px;
262
+ font-weight: normal;
263
+ }
264
+
265
+ img {
266
+ height: 36px;
267
+ margin-top: 5px;
268
+ }
269
+
270
+ .menu-icon {
271
+ font-size: 15px;
272
+ }
273
+
274
+ .molded-menu {
275
+ margin-top: 5px;
276
+ margin-left: 8px;
277
+ padding: 5px;
278
+ padding-bottom: 1px !important;
279
+ background-color: white;
280
+ border: 1px solid #e8eaed;
281
+ border-radius: 12px !important;
282
+ }
283
+
284
+ .div-photo {
285
+ cursor: pointer;
286
+ }
287
+ </style>
@@ -1,30 +1,30 @@
1
- <template>
2
- <div class="molded" :style="'border-radius:' + borderRadius + 'px'">
3
- <slot></slot>
4
- </div>
5
- </template>
6
-
7
- <script>
8
- export default {
9
- name: "Molded",
10
- props: {
11
- borderRadius: {
12
- type: Number,
13
- default: 6,
14
- },
15
- },
16
- };
17
- </script>
18
- <style scoped>
19
- .molded {
20
- border: 1px solid #e8eaed;
21
- background-color: white;
22
- border-radius: 10px !important;
23
- padding: 10px;
24
- padding-top: 15px;
25
- padding-left: 30px;
26
- padding-right: 30px;
27
- padding-bottom: 10px;
28
- box-shadow: 0px 10px 100px -6px rgb(0 0 0 / 5%);
29
- }
30
- </style>
1
+ <template>
2
+ <div class="molded" :style="'border-radius:' + borderRadius + 'px'">
3
+ <slot></slot>
4
+ </div>
5
+ </template>
6
+
7
+ <script>
8
+ export default {
9
+ name: "Molded",
10
+ props: {
11
+ borderRadius: {
12
+ type: Number,
13
+ default: 6,
14
+ },
15
+ },
16
+ };
17
+ </script>
18
+ <style scoped>
19
+ .molded {
20
+ border: 1px solid #e8eaed;
21
+ background-color: white;
22
+ border-radius: 10px !important;
23
+ padding: 10px;
24
+ padding-top: 15px;
25
+ padding-left: 30px;
26
+ padding-right: 30px;
27
+ padding-bottom: 10px;
28
+ box-shadow: 0px 10px 100px -6px rgb(0 0 0 / 5%);
29
+ }
30
+ </style>