@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,175 +1,175 @@
1
- <template>
2
- <div class="color-picker" ref="root">
3
- <div v-if="title" class="color-picker__title">{{ title }}</div>
4
-
5
- <div class="color-picker__trigger" :style="{ backgroundColor: innerValue }" role="button" tabindex="0"
6
- @click="toggle()" @keydown.enter.prevent="toggle()" @keydown.space.prevent="toggle()"
7
- aria-haspopup="listbox" :aria-expanded="open ? 'true' : 'false'"></div>
8
-
9
- <transition name="color-picker--fade">
10
- <div v-show="open" class="color-picker__menu" role="listbox" :aria-label="title || 'Escolher cor'">
11
- <div class="color-picker__grid">
12
- <div v-for="c in colors" :key="c" class="color-picker__item" :style="{ backgroundColor: c }"
13
- role="option" :aria-selected="c === innerValue ? 'true' : 'false'" tabindex="0"
14
- @click="choose(c)" @keydown.enter.prevent="choose(c)" @keydown.space.prevent="choose(c)">
15
- <span v-if="c === innerValue" class="color-picker__check"></span>
16
- </div>
17
- </div>
18
- </div>
19
- </transition>
20
- </div>
21
- </template>
22
-
23
- <script>
24
- export default {
25
- name: "ColorPicker",
26
- model: { prop: "value", event: "input" },
27
- props: {
28
- value: { type: String, default: "" },
29
- defaultColor: { type: String, default: "#64B5F6" },
30
- title: { type: String, default: "" },
31
- colors: {
32
- type: Array,
33
- default: function () {
34
- return [
35
- "#E57373", "#F06292", "#FF6F61",
36
- "#BA68C8", "#9575CD", "#8E24AA",
37
- "#64B5F6", "#4FC3F7", "#3949AB",
38
- "#039BE5", "#1976D2", "#1E88E5",
39
- "#4DB6AC", "#81C784", "#AED581",
40
- "#26A69A", "#2E7D32", "#0097A7",
41
- "#7CB342", "#C0CA33", "#9CCC65",
42
- "#FFD54F", "#FFB74D", "#FDD835",
43
- "#FB8C00", "#FF8A65", "#F4511E",
44
- "#A1887F", "#6D4C41", "#795548",
45
- "#90A4AE", "#546E7A", "#9E9E9E",
46
- "#000000", "#FFFFFF", "#B0BEC5"
47
- ];
48
- },
49
- },
50
- },
51
- data() {
52
- return { innerValue: "", open: false };
53
- },
54
- created() {
55
- this.initialize();
56
- },
57
- watch: {
58
- value(v) {
59
- if (this.isEmpty(v)) {
60
- const fallback = this.normalizeHex(this.defaultColor);
61
- this.innerValue = fallback;
62
- this.$emit("input", fallback);
63
- } else if (v !== this.innerValue) {
64
- this.innerValue = this.normalizeHex(v);
65
- }
66
- }
67
- },
68
- mounted() {
69
- document.addEventListener("click", this.onClickOutside, { passive: true });
70
- },
71
- beforeDestroy() {
72
- document.removeEventListener("click", this.onClickOutside);
73
- },
74
- methods: {
75
- initialize() {
76
- const start = this.isEmpty(this.value)
77
- ? this.normalizeHex(this.defaultColor)
78
- : this.normalizeHex(this.value);
79
- this.innerValue = start;
80
- if (this.isEmpty(this.value)) this.$emit("input", start);
81
- },
82
- isEmpty(v) {
83
- return v === null || v === undefined || String(v).trim() === "";
84
- },
85
- normalizeHex(v) {
86
- const s = String(v || "").trim().toUpperCase();
87
- const hex = /^#([0-9A-F]{6}|[0-9A-F]{3})$/i;
88
- return hex.test(s) ? s : "#64B5F6";
89
- },
90
- toggle() { this.open = !this.open; },
91
- close() { this.open = false; },
92
- choose(c) {
93
- const val = this.normalizeHex(c);
94
- this.innerValue = val;
95
- this.$emit("input", val);
96
- this.close();
97
- },
98
- onClickOutside(e) {
99
- const root = this.$refs.root;
100
- if (this.open && root && !root.contains(e.target)) this.close();
101
- },
102
- },
103
- };
104
- </script>
105
-
106
- <style scoped>
107
- .color-picker {
108
- position: relative;
109
- display: inline-grid;
110
- gap: .375rem;
111
- }
112
-
113
- .color-picker__title {
114
- font-weight: 500;
115
- }
116
-
117
- .color-picker__trigger {
118
- width: 22px;
119
- height: 22px;
120
- border-radius: 50%;
121
- cursor: pointer;
122
- user-select: none;
123
- }
124
-
125
- .color-picker__menu {
126
- position: absolute;
127
- z-index: 40;
128
- top: calc(100% + 8px);
129
- left: 0;
130
- min-width: 400px;
131
- max-width: 90vw;
132
- background: #fff;
133
- border: 1px solid #e5e7eb;
134
- border-radius: 10px;
135
- box-shadow: 0 10px 24px rgba(0, 0, 0, .12);
136
- padding: .5rem;
137
- }
138
-
139
- .color-picker__grid {
140
- display: grid;
141
- grid-template-columns: repeat(12, 28px);
142
- gap: .5rem;
143
- }
144
-
145
- .color-picker__item {
146
- width: 28px;
147
- height: 28px;
148
- border-radius: 50%;
149
- cursor: pointer;
150
- position: relative;
151
- border: 1px solid rgba(0, 0, 0, .1);
152
- }
153
-
154
- .color-picker__check {
155
- position: absolute;
156
- width: 10px;
157
- height: 10px;
158
- background: white;
159
- border-radius: 50%;
160
- top: 50%;
161
- left: 50%;
162
- transform: translate(-50%, -50%);
163
- }
164
-
165
- .color-picker--fade-enter-active,
166
- .color-picker--fade-leave-active {
167
- transition: all .14s ease;
168
- }
169
-
170
- .color-picker--fade-enter,
171
- .color-picker--fade-leave-to {
172
- opacity: 0;
173
- transform: translateY(-4px) scale(.98);
174
- }
175
- </style>
1
+ <template>
2
+ <div class="color-picker" ref="root">
3
+ <div v-if="title" class="color-picker__title">{{ title }}</div>
4
+
5
+ <div class="color-picker__trigger" :style="{ backgroundColor: innerValue }" role="button" tabindex="0"
6
+ @click="toggle()" @keydown.enter.prevent="toggle()" @keydown.space.prevent="toggle()"
7
+ aria-haspopup="listbox" :aria-expanded="open ? 'true' : 'false'"></div>
8
+
9
+ <transition name="color-picker--fade">
10
+ <div v-show="open" class="color-picker__menu" role="listbox" :aria-label="title || 'Escolher cor'">
11
+ <div class="color-picker__grid">
12
+ <div v-for="c in colors" :key="c" class="color-picker__item" :style="{ backgroundColor: c }"
13
+ role="option" :aria-selected="c === innerValue ? 'true' : 'false'" tabindex="0"
14
+ @click="choose(c)" @keydown.enter.prevent="choose(c)" @keydown.space.prevent="choose(c)">
15
+ <span v-if="c === innerValue" class="color-picker__check"></span>
16
+ </div>
17
+ </div>
18
+ </div>
19
+ </transition>
20
+ </div>
21
+ </template>
22
+
23
+ <script>
24
+ export default {
25
+ name: "ColorPicker",
26
+ model: { prop: "value", event: "input" },
27
+ props: {
28
+ value: { type: String, default: "" },
29
+ defaultColor: { type: String, default: "#64B5F6" },
30
+ title: { type: String, default: "" },
31
+ colors: {
32
+ type: Array,
33
+ default: function () {
34
+ return [
35
+ "#E57373", "#F06292", "#FF6F61",
36
+ "#BA68C8", "#9575CD", "#8E24AA",
37
+ "#64B5F6", "#4FC3F7", "#3949AB",
38
+ "#039BE5", "#1976D2", "#1E88E5",
39
+ "#4DB6AC", "#81C784", "#AED581",
40
+ "#26A69A", "#2E7D32", "#0097A7",
41
+ "#7CB342", "#C0CA33", "#9CCC65",
42
+ "#FFD54F", "#FFB74D", "#FDD835",
43
+ "#FB8C00", "#FF8A65", "#F4511E",
44
+ "#A1887F", "#6D4C41", "#795548",
45
+ "#90A4AE", "#546E7A", "#9E9E9E",
46
+ "#000000", "#FFFFFF", "#B0BEC5"
47
+ ];
48
+ },
49
+ },
50
+ },
51
+ data() {
52
+ return { innerValue: "", open: false };
53
+ },
54
+ created() {
55
+ this.initialize();
56
+ },
57
+ watch: {
58
+ value(v) {
59
+ if (this.isEmpty(v)) {
60
+ const fallback = this.normalizeHex(this.defaultColor);
61
+ this.innerValue = fallback;
62
+ this.$emit("input", fallback);
63
+ } else if (v !== this.innerValue) {
64
+ this.innerValue = this.normalizeHex(v);
65
+ }
66
+ }
67
+ },
68
+ mounted() {
69
+ document.addEventListener("click", this.onClickOutside, { passive: true });
70
+ },
71
+ beforeDestroy() {
72
+ document.removeEventListener("click", this.onClickOutside);
73
+ },
74
+ methods: {
75
+ initialize() {
76
+ const start = this.isEmpty(this.value)
77
+ ? this.normalizeHex(this.defaultColor)
78
+ : this.normalizeHex(this.value);
79
+ this.innerValue = start;
80
+ if (this.isEmpty(this.value)) this.$emit("input", start);
81
+ },
82
+ isEmpty(v) {
83
+ return v === null || v === undefined || String(v).trim() === "";
84
+ },
85
+ normalizeHex(v) {
86
+ const s = String(v || "").trim().toUpperCase();
87
+ const hex = /^#([0-9A-F]{6}|[0-9A-F]{3})$/i;
88
+ return hex.test(s) ? s : "#64B5F6";
89
+ },
90
+ toggle() { this.open = !this.open; },
91
+ close() { this.open = false; },
92
+ choose(c) {
93
+ const val = this.normalizeHex(c);
94
+ this.innerValue = val;
95
+ this.$emit("input", val);
96
+ this.close();
97
+ },
98
+ onClickOutside(e) {
99
+ const root = this.$refs.root;
100
+ if (this.open && root && !root.contains(e.target)) this.close();
101
+ },
102
+ },
103
+ };
104
+ </script>
105
+
106
+ <style scoped>
107
+ .color-picker {
108
+ position: relative;
109
+ display: inline-grid;
110
+ gap: .375rem;
111
+ }
112
+
113
+ .color-picker__title {
114
+ font-weight: 500;
115
+ }
116
+
117
+ .color-picker__trigger {
118
+ width: 22px;
119
+ height: 22px;
120
+ border-radius: 50%;
121
+ cursor: pointer;
122
+ user-select: none;
123
+ }
124
+
125
+ .color-picker__menu {
126
+ position: absolute;
127
+ z-index: 40;
128
+ top: calc(100% + 8px);
129
+ left: 0;
130
+ min-width: 400px;
131
+ max-width: 90vw;
132
+ background: #fff;
133
+ border: 1px solid #e5e7eb;
134
+ border-radius: 10px;
135
+ box-shadow: 0 10px 24px rgba(0, 0, 0, .12);
136
+ padding: .5rem;
137
+ }
138
+
139
+ .color-picker__grid {
140
+ display: grid;
141
+ grid-template-columns: repeat(12, 28px);
142
+ gap: .5rem;
143
+ }
144
+
145
+ .color-picker__item {
146
+ width: 28px;
147
+ height: 28px;
148
+ border-radius: 50%;
149
+ cursor: pointer;
150
+ position: relative;
151
+ border: 1px solid rgba(0, 0, 0, .1);
152
+ }
153
+
154
+ .color-picker__check {
155
+ position: absolute;
156
+ width: 10px;
157
+ height: 10px;
158
+ background: white;
159
+ border-radius: 50%;
160
+ top: 50%;
161
+ left: 50%;
162
+ transform: translate(-50%, -50%);
163
+ }
164
+
165
+ .color-picker--fade-enter-active,
166
+ .color-picker--fade-leave-active {
167
+ transition: all .14s ease;
168
+ }
169
+
170
+ .color-picker--fade-enter,
171
+ .color-picker--fade-leave-to {
172
+ opacity: 0;
173
+ transform: translateY(-4px) scale(.98);
174
+ }
175
+ </style>
@@ -1,128 +1,128 @@
1
- <template>
2
- <div>
3
- <div v-if="tasks.length > 0">
4
- <ButtonGroup :initialOption="initialOption" :options="options" />
5
- <slot></slot>
6
- <div class="gantt">
7
- <svg ref="gantt" />
8
- </div>
9
- </div>
10
- <div v-else>
11
- Nenhum registro encontrado!
12
- </div>
13
- </div>
14
- </template>
15
-
16
- <script>
17
- import ButtonGroup from "@nixweb/nixloc-ui/src/component/forms/ButtonGroup";
18
-
19
- import { mapGetters } from "vuex";
20
-
21
- export default {
22
- name: "FrappeGantt",
23
- components: {
24
- ButtonGroup,
25
- },
26
- props: {
27
- initialOption: String,
28
- options: Array,
29
- tasks: Array,
30
- },
31
- data() {
32
- return {
33
- gantt: {},
34
- mode: "day",
35
- viewMode: "",
36
- };
37
- },
38
- mounted() {
39
- this.setupGanttChart();
40
- },
41
- computed: {
42
- ...mapGetters("generic", ["event"]),
43
- },
44
- methods: {
45
- setupGanttChart() {
46
- this.gantt = new Gantt(this.$refs.gantt, this.tasks, {
47
- language: "ptBr",
48
- date_format: "YYYY-MM-DD",
49
- bar_corner_radius: 10,
50
- on_click: (task) => {
51
- this.$emit("task-updated", task);
52
- },
53
- on_date_change: (task, start, end) => {
54
- this.$emit("task-date-updated", { task, start, end });
55
- },
56
- on_progress_change: (task, progress) => {
57
- this.$emit("task-progress-updated", { task, progress });
58
- },
59
- //I doubt you will ever need this as the developer already knows what view mode they set.
60
- on_view_change: (mode) => {
61
- this.$emit("view-mode-updated", mode);
62
- },
63
- custom_popup_html: function (task) {
64
- return `
65
- <div class="details-container">
66
- <p class="title-details">Nº: ${task.number}</p>
67
- <p class="title-details">${task.customer ?? ""}</p>
68
- <p class="title-details">Quantidade: ${task.name}</p>
69
- <p class="title-details">${task.periodRentName}</p>
70
- </div>
71
- `;
72
- },
73
- });
74
- this.updateTasks();
75
- this.updateViewMode();
76
- },
77
-
78
- updateViewMode() {
79
- this.gantt.change_view_mode(
80
- this.viewMode[0].toUpperCase() + this.viewMode.substring(1)
81
- );
82
- },
83
- updateTasks() {
84
- this.gantt.refresh(this.tasks);
85
- },
86
- demoViewMode(viewMode) {
87
- this.mode = viewMode;
88
- this.viewMode = viewMode;
89
- },
90
- },
91
- watch: {
92
- viewMode() {
93
- this.updateViewMode();
94
- },
95
- tasks() {
96
- this.updateTasks();
97
- },
98
- event: {
99
- handler(event) {
100
- if (event.name == "demoViewMode") {
101
- if (event.data.title == "Dia") this.demoViewMode("day");
102
- if (event.data.title == "Semana") this.demoViewMode("week");
103
- if (event.data.title == "Mês") this.demoViewMode("month");
104
- }
105
- },
106
- deep: true,
107
- },
108
- },
109
- };
110
- </script>
111
- <style>
112
- .gantt {
113
- margin-top: 10px;
114
- }
115
-
116
- .details-container {
117
- background-color: white;
118
- width: 400px;
119
- padding: 10px;
120
- border: 1px solid #eaedf3;
121
- color: black;
122
- box-shadow: 0px 10px 20px -6px rgb(0 0 0 / 3%);
123
- }
124
-
125
- .title-details {
126
- font-size: 14px;
127
- }
128
- </style>
1
+ <template>
2
+ <div>
3
+ <div v-if="tasks.length > 0">
4
+ <ButtonGroup :initialOption="initialOption" :options="options" />
5
+ <slot></slot>
6
+ <div class="gantt">
7
+ <svg ref="gantt" />
8
+ </div>
9
+ </div>
10
+ <div v-else>
11
+ Nenhum registro encontrado!
12
+ </div>
13
+ </div>
14
+ </template>
15
+
16
+ <script>
17
+ import ButtonGroup from "@nixweb/nixloc-ui/src/component/forms/ButtonGroup";
18
+
19
+ import { mapGetters } from "vuex";
20
+
21
+ export default {
22
+ name: "FrappeGantt",
23
+ components: {
24
+ ButtonGroup,
25
+ },
26
+ props: {
27
+ initialOption: String,
28
+ options: Array,
29
+ tasks: Array,
30
+ },
31
+ data() {
32
+ return {
33
+ gantt: {},
34
+ mode: "day",
35
+ viewMode: "",
36
+ };
37
+ },
38
+ mounted() {
39
+ this.setupGanttChart();
40
+ },
41
+ computed: {
42
+ ...mapGetters("generic", ["event"]),
43
+ },
44
+ methods: {
45
+ setupGanttChart() {
46
+ this.gantt = new Gantt(this.$refs.gantt, this.tasks, {
47
+ language: "ptBr",
48
+ date_format: "YYYY-MM-DD",
49
+ bar_corner_radius: 10,
50
+ on_click: (task) => {
51
+ this.$emit("task-updated", task);
52
+ },
53
+ on_date_change: (task, start, end) => {
54
+ this.$emit("task-date-updated", { task, start, end });
55
+ },
56
+ on_progress_change: (task, progress) => {
57
+ this.$emit("task-progress-updated", { task, progress });
58
+ },
59
+ //I doubt you will ever need this as the developer already knows what view mode they set.
60
+ on_view_change: (mode) => {
61
+ this.$emit("view-mode-updated", mode);
62
+ },
63
+ custom_popup_html: function (task) {
64
+ return `
65
+ <div class="details-container">
66
+ <p class="title-details">Nº: ${task.number}</p>
67
+ <p class="title-details">${task.customer ?? ""}</p>
68
+ <p class="title-details">Quantidade: ${task.name}</p>
69
+ <p class="title-details">${task.periodRentName}</p>
70
+ </div>
71
+ `;
72
+ },
73
+ });
74
+ this.updateTasks();
75
+ this.updateViewMode();
76
+ },
77
+
78
+ updateViewMode() {
79
+ this.gantt.change_view_mode(
80
+ this.viewMode[0].toUpperCase() + this.viewMode.substring(1)
81
+ );
82
+ },
83
+ updateTasks() {
84
+ this.gantt.refresh(this.tasks);
85
+ },
86
+ demoViewMode(viewMode) {
87
+ this.mode = viewMode;
88
+ this.viewMode = viewMode;
89
+ },
90
+ },
91
+ watch: {
92
+ viewMode() {
93
+ this.updateViewMode();
94
+ },
95
+ tasks() {
96
+ this.updateTasks();
97
+ },
98
+ event: {
99
+ handler(event) {
100
+ if (event.name == "demoViewMode") {
101
+ if (event.data.title == "Dia") this.demoViewMode("day");
102
+ if (event.data.title == "Semana") this.demoViewMode("week");
103
+ if (event.data.title == "Mês") this.demoViewMode("month");
104
+ }
105
+ },
106
+ deep: true,
107
+ },
108
+ },
109
+ };
110
+ </script>
111
+ <style>
112
+ .gantt {
113
+ margin-top: 10px;
114
+ }
115
+
116
+ .details-container {
117
+ background-color: white;
118
+ width: 400px;
119
+ padding: 10px;
120
+ border: 1px solid #eaedf3;
121
+ color: black;
122
+ box-shadow: 0px 10px 20px -6px rgb(0 0 0 / 3%);
123
+ }
124
+
125
+ .title-details {
126
+ font-size: 14px;
127
+ }
128
+ </style>