@nixweb/nixloc-ui 1.17.0 → 1.20.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 (181) 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/layout/ScrollBar.vue +21 -8
  181. package/src/store/modules/generic.js +15 -1
@@ -1,103 +1,103 @@
1
- <template>
2
- <div>
3
- <div v-show="!isLoading('panel')" class="bar side-by-side" :style="'min-height:' + height + 'px; background-color:' + backgroundColor
4
- " :class="{
5
- top: position == 'top',
6
- footer: position == 'footer',
7
- none: position == 'none',
8
- }">
9
- <div class="size">
10
- <div :class="{ 'side-by-side': showButtonClose }">
11
- <slot></slot>
12
- </div>
13
- <div :class="{ 'side-by-side': showButtonClose }" class="close-icon" v-if="position == 'top' && showButtonClose"
14
- @click="close">
15
- <i class="fa-regular fa-xmark"></i>
16
- </div>
17
- </div>
18
- </div>
19
- </div>
20
- </template>
21
-
22
- <script>
23
- import { mapGetters, mapMutations } from "vuex";
24
-
25
- export default {
26
- name: "FixedBar",
27
- props: {
28
- showButtonClose: {
29
- type: Boolean,
30
- default: false,
31
- },
32
- position: {
33
- type: String,
34
- default: "top",
35
- },
36
- height: {
37
- type: Number,
38
- default: 70,
39
- },
40
- backgroundColor: {
41
- type: String,
42
- default: "white",
43
- },
44
- },
45
- computed: {
46
- ...mapGetters("generic", ["isLoading"]),
47
- },
48
- methods: {
49
- ...mapMutations("generic", ["addEvent"]),
50
- close() {
51
- this.addEvent({ name: "closedFixedBar" });
52
- },
53
- },
54
- };
55
- </script>
56
-
57
- <style scoped>
58
- .bar {
59
- position: fixed;
60
- width: 100%;
61
- z-index: 20;
62
- padding: 18px;
63
- padding-left: 100px;
64
- }
65
-
66
- .size {
67
- max-width: 1600px;
68
- margin: auto;
69
- }
70
-
71
- .none {
72
- left: 0;
73
- right: 0;
74
- }
75
-
76
- .top {
77
- top: 0;
78
- left: 0;
79
- right: 0;
80
- border-bottom: 0px solid #e1e1e2;
81
- box-shadow: 0px 10px 20px -6px rgb(0 0 0 / 5%);
82
- border-bottom: 0px solid #eff0f1;
83
- }
84
-
85
- .footer {
86
- left: 0;
87
- bottom: 0px;
88
- border-top: 0px solid #e1e1e2;
89
- box-shadow: 0px 10px 20px -6px rgb(0 0 0 / 5%);
90
- border-top: 0px solid #eff0f1;
91
- }
92
-
93
- .close-icon {
94
- float: right;
95
- font-size: 30px;
96
- font-weight: 400;
97
- line-height: 1;
98
- color: #b9babb;
99
- text-shadow: 0 1px 0 #fff;
100
- padding-right: 80px;
101
- cursor: pointer;
102
- }
103
- </style>
1
+ <template>
2
+ <div>
3
+ <div v-show="!isLoading('panel')" class="bar side-by-side" :style="'min-height:' + height + 'px; background-color:' + backgroundColor
4
+ " :class="{
5
+ top: position == 'top',
6
+ footer: position == 'footer',
7
+ none: position == 'none',
8
+ }">
9
+ <div class="size">
10
+ <div :class="{ 'side-by-side': showButtonClose }">
11
+ <slot></slot>
12
+ </div>
13
+ <div :class="{ 'side-by-side': showButtonClose }" class="close-icon" v-if="position == 'top' && showButtonClose"
14
+ @click="close">
15
+ <i class="fa-regular fa-xmark"></i>
16
+ </div>
17
+ </div>
18
+ </div>
19
+ </div>
20
+ </template>
21
+
22
+ <script>
23
+ import { mapGetters, mapMutations } from "vuex";
24
+
25
+ export default {
26
+ name: "FixedBar",
27
+ props: {
28
+ showButtonClose: {
29
+ type: Boolean,
30
+ default: false,
31
+ },
32
+ position: {
33
+ type: String,
34
+ default: "top",
35
+ },
36
+ height: {
37
+ type: Number,
38
+ default: 70,
39
+ },
40
+ backgroundColor: {
41
+ type: String,
42
+ default: "white",
43
+ },
44
+ },
45
+ computed: {
46
+ ...mapGetters("generic", ["isLoading"]),
47
+ },
48
+ methods: {
49
+ ...mapMutations("generic", ["addEvent"]),
50
+ close() {
51
+ this.addEvent({ name: "closedFixedBar" });
52
+ },
53
+ },
54
+ };
55
+ </script>
56
+
57
+ <style scoped>
58
+ .bar {
59
+ position: fixed;
60
+ width: 100%;
61
+ z-index: 20;
62
+ padding: 18px;
63
+ padding-left: 100px;
64
+ }
65
+
66
+ .size {
67
+ max-width: 1600px;
68
+ margin: auto;
69
+ }
70
+
71
+ .none {
72
+ left: 0;
73
+ right: 0;
74
+ }
75
+
76
+ .top {
77
+ top: 0;
78
+ left: 0;
79
+ right: 0;
80
+ border-bottom: 0px solid #e1e1e2;
81
+ box-shadow: 0px 10px 20px -6px rgb(0 0 0 / 5%);
82
+ border-bottom: 0px solid #eff0f1;
83
+ }
84
+
85
+ .footer {
86
+ left: 0;
87
+ bottom: 0px;
88
+ border-top: 0px solid #e1e1e2;
89
+ box-shadow: 0px 10px 20px -6px rgb(0 0 0 / 5%);
90
+ border-top: 0px solid #eff0f1;
91
+ }
92
+
93
+ .close-icon {
94
+ float: right;
95
+ font-size: 30px;
96
+ font-weight: 400;
97
+ line-height: 1;
98
+ color: #b9babb;
99
+ text-shadow: 0 1px 0 #fff;
100
+ padding-right: 80px;
101
+ cursor: pointer;
102
+ }
103
+ </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>
@@ -1,56 +1,56 @@
1
- <template>
2
- <div>
3
- <div class="top" :style="'background-color:' + backgroundColor">
4
- <div class="side-by-side top-space">
5
- <slot></slot>
6
- </div>
7
- </div>
8
- <br />
9
- </div>
10
- </template>
11
-
12
- <script>
13
- import { mapState, mapMutations } from "vuex";
14
-
15
- export default {
16
- name: "Top",
17
- props: {
18
- backgroundColor: {
19
- type: String,
20
- default: "#4680A5",
21
- },
22
- },
23
- };
24
- </script>
25
-
26
- <style scoped>
27
- .top {
28
- padding-left: 85px;
29
- padding-top: 4px;
30
- left: 0px;
31
- right: 0;
32
- height: 55px;
33
- top: 0;
34
- box-shadow: 0px 10px 30px -6px rgb(0 0 0 / 10%);
35
- border-bottom: 0px solid #eff0f1;
36
- position: fixed;
37
- z-index: 100;
38
- }
39
-
40
- .top-space {
41
- margin-right: 10px;
42
- width: 100%;
43
- }
44
-
45
- .top-margin {
46
- width: 100%;
47
- widows: 100%;
48
- height: 10px;
49
- margin-right: 80px;
50
- top: 0;
51
- margin-left: 120px;
52
- z-index: 1000;
53
- background-color: #fdfdfd;
54
- position: fixed;
55
- }
56
- </style>
1
+ <template>
2
+ <div>
3
+ <div class="top" :style="'background-color:' + backgroundColor">
4
+ <div class="side-by-side top-space">
5
+ <slot></slot>
6
+ </div>
7
+ </div>
8
+ <br />
9
+ </div>
10
+ </template>
11
+
12
+ <script>
13
+ import { mapState, mapMutations } from "vuex";
14
+
15
+ export default {
16
+ name: "Top",
17
+ props: {
18
+ backgroundColor: {
19
+ type: String,
20
+ default: "#4680A5",
21
+ },
22
+ },
23
+ };
24
+ </script>
25
+
26
+ <style scoped>
27
+ .top {
28
+ padding-left: 85px;
29
+ padding-top: 4px;
30
+ left: 0px;
31
+ right: 0;
32
+ height: 55px;
33
+ top: 0;
34
+ box-shadow: 0px 10px 30px -6px rgb(0 0 0 / 10%);
35
+ border-bottom: 0px solid #eff0f1;
36
+ position: fixed;
37
+ z-index: 100;
38
+ }
39
+
40
+ .top-space {
41
+ margin-right: 10px;
42
+ width: 100%;
43
+ }
44
+
45
+ .top-margin {
46
+ width: 100%;
47
+ widows: 100%;
48
+ height: 10px;
49
+ margin-right: 80px;
50
+ top: 0;
51
+ margin-left: 120px;
52
+ z-index: 1000;
53
+ background-color: #fdfdfd;
54
+ position: fixed;
55
+ }
56
+ </style>