@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,198 +1,198 @@
1
- <template>
2
- <div>
3
- <label>
4
- <span class="title">{{ title }} </span>
5
- <span class="required" v-if="required">*</span>
6
- </label>
7
- <div>
8
- <div class="select" :class="{ border: showBorder, classCss }">
9
- <multiselect @open="onOpen" @select="onSelected" @search-change="onSearch" :options="data"
10
- v-model.trim="currentValue" :custom-label="label" :disabled="disabled" placeholder :showLabels="true"
11
- :noResult="false" ref="multiselect" selectLabel deselectLabel selectedLabel>
12
- <div slot="beforeList" class="after-list">
13
- <Button v-if="showBtnClean" key="cleanSelect" title="Limpar" type="warning" classIcon="fas fa-broom"
14
- size="small" :clicked="cleanSelectStatic" />
15
- </div>
16
- </multiselect>
17
- </div>
18
- </div>
19
- </div>
20
- </template>
21
- <script>
22
- import Multiselect from "vue-multiselect";
23
- import Button from "./Button";
24
-
25
- import { mapMutations, mapGetters } from "vuex";
26
-
27
- export default {
28
- name: "SelectStatic",
29
- props: {
30
- title: String,
31
- formName: String,
32
- classCss: String,
33
- field: String,
34
- initialFieldTarget: Object,
35
- fieldTarget: String,
36
- required: Boolean,
37
- initialValue: Object,
38
- disabled: {
39
- type: Boolean,
40
- default: false,
41
- },
42
- onlyQuery: {
43
- type: Boolean,
44
- default: false,
45
- },
46
- showBorder: {
47
- type: Boolean,
48
- default: true,
49
- },
50
- showBtnClean: {
51
- type: Boolean,
52
- default: false,
53
- },
54
- markFormDirty: {
55
- type: Boolean,
56
- default: false,
57
- },
58
- data: Array,
59
- value: Object,
60
- },
61
- components: {
62
- Multiselect,
63
- Button,
64
- },
65
- data() {
66
- return {
67
- currentValue: this.initialValue,
68
- notifications: [],
69
- };
70
- },
71
- created() {
72
- this.validate();
73
- },
74
- mounted() {
75
- let el = this.$el.getElementsByClassName("multiselect")[0];
76
- if (el) {
77
- el.tabIndex = 0;
78
- }
79
-
80
- if (this.initialFieldTarget.id) {
81
- let value = this.initialFieldTarget.id;
82
- let obj = { tag: `${this.title}: ${value}`, fieldTarget: this.fieldTarget, value: value };
83
- this.addFilter(obj);
84
- }
85
-
86
- },
87
- computed: {
88
- ...mapGetters("generic", ["event"]),
89
- },
90
- methods: {
91
- ...mapMutations("generic", ["addFilter", "removeLoading"]),
92
- ...mapMutations("validation", [
93
- "addValidation",
94
- "removeValidation",
95
- "resetValidation",
96
- "updateFormDirty",
97
- ]),
98
- onOpen() { },
99
- onSelected(value) {
100
- this.$emit("input", value);
101
- let obj = { fieldTarget: this.fieldTarget, value: value.id };
102
- if (!this.onlyQuery) this.addFilter(obj);
103
- if (this.fieldTarget && this.fieldTarget != "totalPerPage") {
104
- let obj = { tag: `${this.title}: ${value.content}`, fieldTarget: this.fieldTarget, value: value.id };
105
- this.addFilter(obj);
106
- }
107
-
108
- if (this.markFormDirty) this.updateFormDirty(true);
109
- },
110
- onSearch(value) { },
111
- label(value) {
112
- return `${value.content}`;
113
- },
114
- cleanSelectStatic() {
115
- let obj = { content: "", id: "" };
116
- this.currentValue = obj;
117
- this.$emit("input", obj);
118
- this.$refs.multiselect.deactivate();
119
- this.removeLoading(["cleanSelectStatic"]);
120
-
121
- if (this.fieldTarget) {
122
- let obj = { fieldTarget: this.fieldTarget, value: "" };
123
- this.addFilter(obj);
124
- }
125
- },
126
-
127
- validate() {
128
- this.notifications = [];
129
- if (this.required && !this.value.id) {
130
- var message = `${this.title} não pode ser vazio!`;
131
- this.notifications.push(message);
132
- }
133
- },
134
- },
135
- watch: {
136
- event: {
137
- handler(event) {
138
- if (event.name == "tagRemoved") {
139
- if (this.fieldTarget == event.data) this.cleanSelectStatic();
140
- }
141
-
142
- },
143
- deep: true,
144
- },
145
- "value.id": function () {
146
- this.validate();
147
- this.formDirty = true;
148
- if (this.markFormDirty) this.updateFormDirty(true);
149
- this.currentValue = { id: this.value.id, content: this.value.content };
150
- },
151
- notifications() {
152
- let self = this;
153
- this.notifications.forEach(function (notification) {
154
- let obj = {
155
- key: self.field + "&" + self.formName,
156
- formName: self.formName,
157
- notification: notification,
158
- };
159
- self.addValidation(obj);
160
- });
161
-
162
- if (this.notifications.length == 0) {
163
- let obj = {
164
- key: self.field + "&" + self.formName,
165
- formName: self.formName,
166
- };
167
- self.removeValidation(obj);
168
- }
169
- },
170
- "initialValue.id": function () {
171
- this.currentValue = { id: this.value.id, content: this.value.content };
172
- },
173
- },
174
- };
175
- </script>
176
-
177
- <style scoped>
178
- .title {
179
- font-size: 14px !important;
180
- font-weight: 400 !important;
181
- color: #0a0a0a;
182
- letter-spacing: 0.5px !important;
183
- }
184
-
185
- div.after-list {
186
- padding: 8px;
187
- }
188
-
189
- .select {
190
- height: 38px;
191
- border-radius: 5px !important;
192
- margin-bottom: 20px;
193
- }
194
-
195
- .border {
196
- border: 1px solid #dbdee0 !important;
197
- }
198
- </style>
1
+ <template>
2
+ <div>
3
+ <label>
4
+ <span class="title">{{ title }} </span>
5
+ <span class="required" v-if="required">*</span>
6
+ </label>
7
+ <div>
8
+ <div class="select" :class="{ border: showBorder, classCss }">
9
+ <multiselect @open="onOpen" @select="onSelected" @search-change="onSearch" :options="data"
10
+ v-model.trim="currentValue" :custom-label="label" :disabled="disabled" placeholder :showLabels="true"
11
+ :noResult="false" ref="multiselect" selectLabel deselectLabel selectedLabel>
12
+ <div slot="beforeList" class="after-list">
13
+ <Button v-if="showBtnClean" key="cleanSelect" title="Limpar" type="warning" classIcon="fas fa-broom"
14
+ size="small" :clicked="cleanSelectStatic" />
15
+ </div>
16
+ </multiselect>
17
+ </div>
18
+ </div>
19
+ </div>
20
+ </template>
21
+ <script>
22
+ import Multiselect from "vue-multiselect";
23
+ import Button from "./Button";
24
+
25
+ import { mapMutations, mapGetters } from "vuex";
26
+
27
+ export default {
28
+ name: "SelectStatic",
29
+ props: {
30
+ title: String,
31
+ formName: String,
32
+ classCss: String,
33
+ field: String,
34
+ initialFieldTarget: Object,
35
+ fieldTarget: String,
36
+ required: Boolean,
37
+ initialValue: Object,
38
+ disabled: {
39
+ type: Boolean,
40
+ default: false,
41
+ },
42
+ onlyQuery: {
43
+ type: Boolean,
44
+ default: false,
45
+ },
46
+ showBorder: {
47
+ type: Boolean,
48
+ default: true,
49
+ },
50
+ showBtnClean: {
51
+ type: Boolean,
52
+ default: false,
53
+ },
54
+ markFormDirty: {
55
+ type: Boolean,
56
+ default: false,
57
+ },
58
+ data: Array,
59
+ value: Object,
60
+ },
61
+ components: {
62
+ Multiselect,
63
+ Button,
64
+ },
65
+ data() {
66
+ return {
67
+ currentValue: this.initialValue,
68
+ notifications: [],
69
+ };
70
+ },
71
+ created() {
72
+ this.validate();
73
+ },
74
+ mounted() {
75
+ let el = this.$el.getElementsByClassName("multiselect")[0];
76
+ if (el) {
77
+ el.tabIndex = 0;
78
+ }
79
+
80
+ if (this.initialFieldTarget.id) {
81
+ let value = this.initialFieldTarget.id;
82
+ let obj = { tag: `${this.title}: ${value}`, fieldTarget: this.fieldTarget, value: value };
83
+ this.addFilter(obj);
84
+ }
85
+
86
+ },
87
+ computed: {
88
+ ...mapGetters("generic", ["event"]),
89
+ },
90
+ methods: {
91
+ ...mapMutations("generic", ["addFilter", "removeLoading"]),
92
+ ...mapMutations("validation", [
93
+ "addValidation",
94
+ "removeValidation",
95
+ "resetValidation",
96
+ "updateFormDirty",
97
+ ]),
98
+ onOpen() { },
99
+ onSelected(value) {
100
+ this.$emit("input", value);
101
+ let obj = { fieldTarget: this.fieldTarget, value: value.id };
102
+ if (!this.onlyQuery) this.addFilter(obj);
103
+ if (this.fieldTarget && this.fieldTarget != "totalPerPage") {
104
+ let obj = { tag: `${this.title}: ${value.content}`, fieldTarget: this.fieldTarget, value: value.id };
105
+ this.addFilter(obj);
106
+ }
107
+
108
+ if (this.markFormDirty) this.updateFormDirty(true);
109
+ },
110
+ onSearch(value) { },
111
+ label(value) {
112
+ return `${value.content}`;
113
+ },
114
+ cleanSelectStatic() {
115
+ let obj = { content: "", id: "" };
116
+ this.currentValue = obj;
117
+ this.$emit("input", obj);
118
+ this.$refs.multiselect.deactivate();
119
+ this.removeLoading(["cleanSelectStatic"]);
120
+
121
+ if (this.fieldTarget) {
122
+ let obj = { fieldTarget: this.fieldTarget, value: "" };
123
+ this.addFilter(obj);
124
+ }
125
+ },
126
+
127
+ validate() {
128
+ this.notifications = [];
129
+ if (this.required && !this.value.id) {
130
+ var message = `${this.title} não pode ser vazio!`;
131
+ this.notifications.push(message);
132
+ }
133
+ },
134
+ },
135
+ watch: {
136
+ event: {
137
+ handler(event) {
138
+ if (event.name == "tagRemoved") {
139
+ if (this.fieldTarget == event.data) this.cleanSelectStatic();
140
+ }
141
+
142
+ },
143
+ deep: true,
144
+ },
145
+ "value.id": function () {
146
+ this.validate();
147
+ this.formDirty = true;
148
+ if (this.markFormDirty) this.updateFormDirty(true);
149
+ this.currentValue = { id: this.value.id, content: this.value.content };
150
+ },
151
+ notifications() {
152
+ let self = this;
153
+ this.notifications.forEach(function (notification) {
154
+ let obj = {
155
+ key: self.field + "&" + self.formName,
156
+ formName: self.formName,
157
+ notification: notification,
158
+ };
159
+ self.addValidation(obj);
160
+ });
161
+
162
+ if (this.notifications.length == 0) {
163
+ let obj = {
164
+ key: self.field + "&" + self.formName,
165
+ formName: self.formName,
166
+ };
167
+ self.removeValidation(obj);
168
+ }
169
+ },
170
+ "initialValue.id": function () {
171
+ this.currentValue = { id: this.value.id, content: this.value.content };
172
+ },
173
+ },
174
+ };
175
+ </script>
176
+
177
+ <style scoped>
178
+ .title {
179
+ font-size: 14px !important;
180
+ font-weight: 400 !important;
181
+ color: #0a0a0a;
182
+ letter-spacing: 0.5px !important;
183
+ }
184
+
185
+ div.after-list {
186
+ padding: 8px;
187
+ }
188
+
189
+ .select {
190
+ height: 38px;
191
+ border-radius: 5px !important;
192
+ margin-bottom: 20px;
193
+ }
194
+
195
+ .border {
196
+ border: 1px solid #dbdee0 !important;
197
+ }
198
+ </style>
@@ -1,100 +1,100 @@
1
- <template>
2
- <div>
3
- <b-sidebar id="my-sidebar" :title="title" width="90%" bg-variant="white" no-header right backdrop-variant="dark"
4
- @hidden="hideSideBar" backdrop shadow>
5
- <div class="margin-side-bar">
6
- <div>
7
- <Messages />
8
- <b-row>
9
- <b-col sm="6">
10
- <div class="title-side-bar">{{ title }}</div>
11
- </b-col>
12
- <b-col sm="6">
13
- <div class="text-right" @click="hideSideBar">
14
- <i class="fa-solid fa-circle-xmark icon-side-bar"></i>
15
- </div>
16
- </b-col>
17
- </b-row>
18
- </div>
19
- <br />
20
- <slot></slot>
21
- </div>
22
- </b-sidebar>
23
- </div>
24
- </template>
25
-
26
- <script>
27
- import Messages from "@nixweb/nixloc-ui/src/component/shared/Messages";
28
- import { mapState, mapMutations } from "vuex";
29
-
30
- export default {
31
- name: "SideBar",
32
- components: {
33
- Messages,
34
- },
35
- props: {
36
- title: String,
37
- },
38
- computed: {
39
- ...mapState("generic", ["sideBar"]),
40
- },
41
- methods: {
42
- ...mapMutations("generic", ["hideSideBar"]),
43
- hide() {
44
- this.$root.$emit("bv::toggle::collapse", "my-sidebar");
45
- this.hideSideBar();
46
- },
47
- },
48
- watch: {
49
- sideBar: {
50
- handler(sideBar) {
51
- this.$root.$emit("bv::toggle::collapse", "my-sidebar");
52
- },
53
- deep: true,
54
- },
55
- },
56
- };
57
- </script>
58
- <style>
59
- .b-sidebar {
60
- border-radius: 15px 15px 0px 0px !important;
61
- margin-top: 20px !important;
62
- margin-right: 5% !important;
63
- padding-top: 20px !important;
64
- }
65
-
66
- .b-sidebar>.b-sidebar-body {
67
- overflow-y: scroll !important;
68
- }
69
-
70
- .b-sidebar>.b-sidebar-body::-webkit-scrollbar-track {
71
- background-color: white;
72
- border-radius: 20px;
73
- }
74
-
75
- .b-sidebar>.b-sidebar-body::-webkit-scrollbar {
76
- width: 6px;
77
- background-color: #b9babb;
78
- border-radius: 20px;
79
- }
80
-
81
- .b-sidebar>.b-sidebar-body::-webkit-scrollbar-thumb {
82
- background-color: #b9babb;
83
- border-radius: 20px;
84
- }
85
-
86
- .title-side-bar {
87
- font-size: 20px;
88
- }
89
-
90
- .icon-side-bar {
91
- font-size: 30px;
92
- cursor: pointer;
93
- }
94
-
95
- .margin-side-bar {
96
- margin-top: 20px;
97
- margin-left: 30px;
98
- margin-right: 20px;
99
- }
1
+ <template>
2
+ <div>
3
+ <b-sidebar id="my-sidebar" :title="title" width="90%" bg-variant="white" no-header right backdrop-variant="dark"
4
+ @hidden="hideSideBar" backdrop shadow>
5
+ <div class="margin-side-bar">
6
+ <div>
7
+ <Messages />
8
+ <b-row>
9
+ <b-col sm="6">
10
+ <div class="title-side-bar">{{ title }}</div>
11
+ </b-col>
12
+ <b-col sm="6">
13
+ <div class="text-right" @click="hideSideBar">
14
+ <i class="fa-solid fa-circle-xmark icon-side-bar"></i>
15
+ </div>
16
+ </b-col>
17
+ </b-row>
18
+ </div>
19
+ <br />
20
+ <slot></slot>
21
+ </div>
22
+ </b-sidebar>
23
+ </div>
24
+ </template>
25
+
26
+ <script>
27
+ import Messages from "@nixweb/nixloc-ui/src/component/shared/Messages";
28
+ import { mapState, mapMutations } from "vuex";
29
+
30
+ export default {
31
+ name: "SideBar",
32
+ components: {
33
+ Messages,
34
+ },
35
+ props: {
36
+ title: String,
37
+ },
38
+ computed: {
39
+ ...mapState("generic", ["sideBar"]),
40
+ },
41
+ methods: {
42
+ ...mapMutations("generic", ["hideSideBar"]),
43
+ hide() {
44
+ this.$root.$emit("bv::toggle::collapse", "my-sidebar");
45
+ this.hideSideBar();
46
+ },
47
+ },
48
+ watch: {
49
+ sideBar: {
50
+ handler(sideBar) {
51
+ this.$root.$emit("bv::toggle::collapse", "my-sidebar");
52
+ },
53
+ deep: true,
54
+ },
55
+ },
56
+ };
57
+ </script>
58
+ <style>
59
+ .b-sidebar {
60
+ border-radius: 15px 15px 0px 0px !important;
61
+ margin-top: 20px !important;
62
+ margin-right: 5% !important;
63
+ padding-top: 20px !important;
64
+ }
65
+
66
+ .b-sidebar>.b-sidebar-body {
67
+ overflow-y: scroll !important;
68
+ }
69
+
70
+ .b-sidebar>.b-sidebar-body::-webkit-scrollbar-track {
71
+ background-color: white;
72
+ border-radius: 20px;
73
+ }
74
+
75
+ .b-sidebar>.b-sidebar-body::-webkit-scrollbar {
76
+ width: 6px;
77
+ background-color: #b9babb;
78
+ border-radius: 20px;
79
+ }
80
+
81
+ .b-sidebar>.b-sidebar-body::-webkit-scrollbar-thumb {
82
+ background-color: #b9babb;
83
+ border-radius: 20px;
84
+ }
85
+
86
+ .title-side-bar {
87
+ font-size: 20px;
88
+ }
89
+
90
+ .icon-side-bar {
91
+ font-size: 30px;
92
+ cursor: pointer;
93
+ }
94
+
95
+ .margin-side-bar {
96
+ margin-top: 20px;
97
+ margin-left: 30px;
98
+ margin-right: 20px;
99
+ }
100
100
  </style>
@@ -1,18 +1,18 @@
1
- <template>
2
- <div>
3
- <vue-slider :data="[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]"></vue-slider>
4
- </div>
5
- </template>
6
- <script>
7
- import VueSlider from "vue-slider-component";
8
-
9
- export default {
10
- name: "Slider",
11
- components: {
12
- VueSlider,
13
- },
14
- data() {
15
- return {};
16
- },
17
- };
18
- </script>
1
+ <template>
2
+ <div>
3
+ <vue-slider :data="[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]"></vue-slider>
4
+ </div>
5
+ </template>
6
+ <script>
7
+ import VueSlider from "vue-slider-component";
8
+
9
+ export default {
10
+ name: "Slider",
11
+ components: {
12
+ VueSlider,
13
+ },
14
+ data() {
15
+ return {};
16
+ },
17
+ };
18
+ </script>