@nixweb/nixloc-ui 1.19.0 → 1.21.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 (110) hide show
  1. package/package.json +1 -1
  2. package/src/component/forms/ButtonFilter.vue +104 -104
  3. package/src/component/forms/ButtonGroup.vue +66 -66
  4. package/src/component/forms/ButtonGroupInline.vue +210 -210
  5. package/src/component/forms/ButtonSub.vue +97 -97
  6. package/src/component/forms/ButtonToggle.vue +76 -76
  7. package/src/component/forms/DateYearMonth.vue +192 -192
  8. package/src/component/forms/ImageUpload.vue +214 -214
  9. package/src/component/forms/IncrementDecrement.vue +151 -151
  10. package/src/component/forms/InputAddressGoogle.vue +171 -171
  11. package/src/component/forms/InputCallToAction.vue +135 -135
  12. package/src/component/forms/InputDecimalDiscount.vue +146 -146
  13. package/src/component/forms/InputTag.vue +124 -124
  14. package/src/component/forms/InputTextEdit.vue +69 -69
  15. package/src/component/forms/InputWhatsApp.vue +47 -47
  16. package/src/component/forms/SideBar.vue +99 -99
  17. package/src/component/forms/Toggle.vue +72 -72
  18. package/src/component/layout/Account.vue +131 -131
  19. package/src/component/layout/AnimatedPhrase.vue +68 -68
  20. package/src/component/layout/BarFloating.vue +67 -67
  21. package/src/component/layout/BottomActionsBar.vue +205 -205
  22. package/src/component/layout/ColorPicker.vue +175 -175
  23. package/src/component/layout/Gantt.vue +128 -128
  24. package/src/component/layout/HideShow.vue +61 -61
  25. package/src/component/layout/IconMolded.vue +58 -58
  26. package/src/component/layout/IconPicker.vue +161 -161
  27. package/src/component/layout/NewAccount.vue +136 -136
  28. package/src/component/layout/NewHeader.vue +59 -59
  29. package/src/component/layout/NewIconMolded.vue +70 -70
  30. package/src/component/layout/NewMenu.vue +472 -472
  31. package/src/component/layout/Tab.vue +259 -259
  32. package/src/component/layout/Tag.vue +97 -97
  33. package/src/component/layout/Tooltip.vue +155 -155
  34. package/src/component/layout/Zoom.vue +111 -111
  35. package/src/component/rental/DisplayCalculatePeriod.vue +48 -48
  36. package/src/component/rental/DisplayPeriodRent.vue +55 -55
  37. package/src/component/rental/DisplayTotalization.vue +86 -86
  38. package/src/component/report/Fields.vue +108 -108
  39. package/src/component/report/Report.vue +377 -377
  40. package/src/component/report/ReportTable.vue +111 -111
  41. package/src/component/report/Totalization.vue +33 -33
  42. package/src/component/shared/CodeEditor.vue +128 -128
  43. package/src/component/shared/Confirmation.vue +74 -74
  44. package/src/component/shared/DocumentEditor.vue +99 -99
  45. package/src/component/shared/DocumentPreview.vue +117 -105
  46. package/src/component/shared/DocumentPublic.vue +33 -33
  47. package/src/component/shared/ExportExcel.vue +56 -56
  48. package/src/component/shared/FullCalendar.vue +175 -175
  49. package/src/component/shared/HeaderReport.vue +47 -47
  50. package/src/component/shared/ListNotifications.vue +70 -70
  51. package/src/component/shared/Loading.vue +1 -4
  52. package/src/component/shared/LoadingCard.vue +64 -64
  53. package/src/component/shared/ParameterLegend.vue +169 -169
  54. package/src/component/shared/Report.vue +250 -250
  55. package/src/component/shared/SaveCancel.vue +99 -117
  56. package/src/component/shared/SelectOption.vue +162 -162
  57. package/src/component/shared/TableDraggable.vue +117 -117
  58. package/src/component/shared/TableImport.vue +93 -93
  59. package/src/component/shared/TableItem.vue +228 -228
  60. package/src/component/shared/TableTotalPerPage.vue +114 -114
  61. package/src/component/shared/TableTotalRecords.vue +44 -44
  62. package/src/component/shared/TimeLine.vue +41 -41
  63. package/src/component/shared/Timer.vue +77 -77
  64. package/src/component/shared/ToggleTheme.vue +127 -127
  65. package/src/component/shared/TotalizationReport.vue +86 -86
  66. package/src/component/shared/actions/ActionButtons.vue +53 -53
  67. package/src/component/shared/actions/ActionErrorContent.vue +103 -103
  68. package/src/component/shared/actions/ActionFooter.vue +93 -99
  69. package/src/component/shared/actions/ActionHeader.vue +110 -110
  70. package/src/component/shared/actions/ActionItemList.vue +143 -143
  71. package/src/component/shared/actions/ActionsOptions.vue +209 -209
  72. package/src/component/shared/actions/ActionsSelected.vue +262 -262
  73. package/src/component/shared/automation/ActivitiesList.vue +43 -43
  74. package/src/component/shared/automation/AddRule.vue +60 -60
  75. package/src/component/shared/automation/AutomationBuilder.vue +26 -26
  76. package/src/component/shared/automation/DynamicComponentList.vue +85 -85
  77. package/src/component/shared/automation/SelectRule.vue +97 -97
  78. package/src/component/shared/automation/components/BillingByRent.vue +97 -97
  79. package/src/component/shared/automation/components/SendEmail.vue +93 -93
  80. package/src/component/shared/file-manager/FileManager.vue +390 -390
  81. package/src/component/shared/filter-builder/FilterBuilder.vue +220 -220
  82. package/src/component/shared/filter-builder/FilterQuery.vue +95 -95
  83. package/src/component/shared/query-builder/ConvertToOdata.js +86 -86
  84. package/src/component/shared/query-builder/DynamicComponent.vue +161 -161
  85. package/src/component/shared/query-builder/Fields.vue +93 -93
  86. package/src/component/shared/query-builder/Rules.vue +68 -68
  87. package/src/component/shared/query-builder/SelectRule.vue +97 -97
  88. package/src/component/shared/query-builder/Tags.vue +59 -59
  89. package/src/component/signature/Payment.vue +160 -160
  90. package/src/component/signature/Warning.vue +75 -75
  91. package/src/component/template/ReportCreateUpdate.vue +110 -110
  92. package/src/component/template/ViewTemplateDocumentView.vue +213 -213
  93. package/src/component/template/ViewTemplateImportFile.vue +347 -347
  94. package/src/component/template/ViewTemplateReportList.vue +240 -240
  95. package/src/component/template/ViewTemplateReportPreview.vue +521 -521
  96. package/src/component/template/ViewTemplateSelectOption.vue +46 -46
  97. package/src/component/template/model/Report.js +5 -5
  98. package/src/component/training/Course.vue +343 -343
  99. package/src/component/training/CourseView.vue +198 -198
  100. package/src/component/value-objects/Address.js +10 -10
  101. package/src/component/value-objects/Address.vue +173 -173
  102. package/src/component/value-objects/Contact.js +6 -6
  103. package/src/component/value-objects/Contact.vue +106 -106
  104. package/src/component/value-objects/Person.js +10 -10
  105. package/src/component/value-objects/Person.vue +130 -130
  106. package/src/store/modules/automation.js +30 -30
  107. package/src/store/modules/generic.js +16 -6
  108. package/src/store/modules/report.js +277 -277
  109. package/src/store/modules/user.js +69 -69
  110. package/src/store/modules/util.js +25 -25
@@ -1,151 +1,151 @@
1
- <template>
2
- <div>
3
- <label v-if="title">
4
- <span class="title">{{ title }} </span>
5
- </label>
6
- <div class="wrapper">
7
- <span :class="{ disabled: disabled }" class="minus" @click="decrement">-</span>
8
- <span :class="{ disabled: disabled }" class="num" @click="showEdit = true" v-if="!showEdit">{{ number }}</span>
9
- <input v-if="showEdit" class="input" type="number" @keyup.enter.prevent="enter" :disabled="disabled"
10
- v-model="number" />
11
- <span v-if="showEdit" :class="{ disabled: disabled }" @click="showEdit = false">
12
- <i class="fa-solid fa-check"></i>
13
- </span>
14
- <span :class="{ disabled: disabled }" class="plus" @click="increment">+</span>
15
- </div>
16
- </div>
17
- </template>
18
-
19
- <script>
20
- import { mapMutations } from "vuex";
21
-
22
- export default {
23
- name: "IncrementDecrement",
24
- props: [
25
- "name",
26
- "title",
27
- "initialValue",
28
- "value",
29
- "disabled",
30
- "fieldTarget",
31
- "triggerEvent",
32
- "min",
33
- "max",
34
- "params",
35
- "changed"
36
- ],
37
- data() {
38
- return {
39
- number: 1,
40
- showEdit: false,
41
- };
42
- },
43
- mounted() {
44
- this.number = this.value;
45
- },
46
- methods: {
47
- ...mapMutations("generic", ["addFilter", "addEvent"]),
48
- increment() {
49
- if (!this.disabled) {
50
- this.number++;
51
- this.executeFilter();
52
- }
53
- },
54
- decrement() {
55
- if (!this.disabled) {
56
- this.number--;
57
- if (this.number < 0) this.number = 0;
58
- this.executeFilter();
59
- }
60
- },
61
- enter() {
62
- this.showEdit = false;
63
- if (this.changed) this.changed(this.params);
64
- },
65
- executeFilter() {
66
- if (this.fieldTarget) {
67
- let obj = { fieldTarget: this.fieldTarget, value: this.number };
68
- this.addFilter(obj);
69
- }
70
-
71
- if (this.changed) this.changed(this.params);
72
- },
73
- },
74
- watch: {
75
- number: {
76
- handler(number) {
77
- if (this.min)
78
- if (this.number < this.min) {
79
- this.number = this.min;
80
- return;
81
- }
82
- if (this.max)
83
- if (this.number > this.max) {
84
- this.number = this.max;
85
- return;
86
- }
87
- this.$emit("input", this.number);
88
-
89
- if (this.triggerEvent)
90
- this.addEvent({
91
- name: "updateIncrementDecrement",
92
- data: { name: this.name, value: this.number },
93
- });
94
-
95
- // if (this.changed) this.changed(this.params);
96
- },
97
- deep: true,
98
- },
99
- },
100
- };
101
- </script>
102
-
103
- <style scoped>
104
- .input {
105
- width: 40px;
106
- border: none;
107
- text-align: center;
108
- }
109
-
110
- .wrapper {
111
- height: 37px;
112
- width: 100%;
113
- display: flex;
114
- align-items: center;
115
- justify-content: center;
116
- background: #fff;
117
- border-radius: 8px;
118
- border: 1px solid #eaedf3;
119
- box-shadow: 0px 10px 20px -6px rgb(0 0 0 / 3%);
120
- }
121
-
122
- .wrapper span {
123
- width: 100%;
124
- text-align: center;
125
- font-size: 15px;
126
- font-weight: 600;
127
- cursor: pointer;
128
- user-select: none;
129
- }
130
-
131
- .wrapper span.num {
132
- font-size: 17px;
133
- border-right: 1px solid #eaedf3;
134
- border-left: 1px solid #eaedf3;
135
- cursor: pointer;
136
- color: #3f529b;
137
- font-size: 14px;
138
- font-weight: 400;
139
- cursor: pointer;
140
- }
141
-
142
- .wrapper span.num:hover {
143
- text-decoration: underline;
144
- transition: 0.1s;
145
- }
146
-
147
- .disabled {
148
- color: grey;
149
- opacity: 0.5;
150
- }
151
- </style>
1
+ <template>
2
+ <div>
3
+ <label v-if="title">
4
+ <span class="title">{{ title }} </span>
5
+ </label>
6
+ <div class="wrapper">
7
+ <span :class="{ disabled: disabled }" class="minus" @click="decrement">-</span>
8
+ <span :class="{ disabled: disabled }" class="num" @click="showEdit = true" v-if="!showEdit">{{ number }}</span>
9
+ <input v-if="showEdit" class="input" type="number" @keyup.enter.prevent="enter" :disabled="disabled"
10
+ v-model="number" />
11
+ <span v-if="showEdit" :class="{ disabled: disabled }" @click="showEdit = false">
12
+ <i class="fa-solid fa-check"></i>
13
+ </span>
14
+ <span :class="{ disabled: disabled }" class="plus" @click="increment">+</span>
15
+ </div>
16
+ </div>
17
+ </template>
18
+
19
+ <script>
20
+ import { mapMutations } from "vuex";
21
+
22
+ export default {
23
+ name: "IncrementDecrement",
24
+ props: [
25
+ "name",
26
+ "title",
27
+ "initialValue",
28
+ "value",
29
+ "disabled",
30
+ "fieldTarget",
31
+ "triggerEvent",
32
+ "min",
33
+ "max",
34
+ "params",
35
+ "changed"
36
+ ],
37
+ data() {
38
+ return {
39
+ number: 1,
40
+ showEdit: false,
41
+ };
42
+ },
43
+ mounted() {
44
+ this.number = this.value;
45
+ },
46
+ methods: {
47
+ ...mapMutations("generic", ["addFilter", "addEvent"]),
48
+ increment() {
49
+ if (!this.disabled) {
50
+ this.number++;
51
+ this.executeFilter();
52
+ }
53
+ },
54
+ decrement() {
55
+ if (!this.disabled) {
56
+ this.number--;
57
+ if (this.number < 0) this.number = 0;
58
+ this.executeFilter();
59
+ }
60
+ },
61
+ enter() {
62
+ this.showEdit = false;
63
+ if (this.changed) this.changed(this.params);
64
+ },
65
+ executeFilter() {
66
+ if (this.fieldTarget) {
67
+ let obj = { fieldTarget: this.fieldTarget, value: this.number };
68
+ this.addFilter(obj);
69
+ }
70
+
71
+ if (this.changed) this.changed(this.params);
72
+ },
73
+ },
74
+ watch: {
75
+ number: {
76
+ handler(number) {
77
+ if (this.min)
78
+ if (this.number < this.min) {
79
+ this.number = this.min;
80
+ return;
81
+ }
82
+ if (this.max)
83
+ if (this.number > this.max) {
84
+ this.number = this.max;
85
+ return;
86
+ }
87
+ this.$emit("input", this.number);
88
+
89
+ if (this.triggerEvent)
90
+ this.addEvent({
91
+ name: "updateIncrementDecrement",
92
+ data: { name: this.name, value: this.number },
93
+ });
94
+
95
+ // if (this.changed) this.changed(this.params);
96
+ },
97
+ deep: true,
98
+ },
99
+ },
100
+ };
101
+ </script>
102
+
103
+ <style scoped>
104
+ .input {
105
+ width: 40px;
106
+ border: none;
107
+ text-align: center;
108
+ }
109
+
110
+ .wrapper {
111
+ height: 37px;
112
+ width: 100%;
113
+ display: flex;
114
+ align-items: center;
115
+ justify-content: center;
116
+ background: #fff;
117
+ border-radius: 8px;
118
+ border: 1px solid #eaedf3;
119
+ box-shadow: 0px 10px 20px -6px rgb(0 0 0 / 3%);
120
+ }
121
+
122
+ .wrapper span {
123
+ width: 100%;
124
+ text-align: center;
125
+ font-size: 15px;
126
+ font-weight: 600;
127
+ cursor: pointer;
128
+ user-select: none;
129
+ }
130
+
131
+ .wrapper span.num {
132
+ font-size: 17px;
133
+ border-right: 1px solid #eaedf3;
134
+ border-left: 1px solid #eaedf3;
135
+ cursor: pointer;
136
+ color: #3f529b;
137
+ font-size: 14px;
138
+ font-weight: 400;
139
+ cursor: pointer;
140
+ }
141
+
142
+ .wrapper span.num:hover {
143
+ text-decoration: underline;
144
+ transition: 0.1s;
145
+ }
146
+
147
+ .disabled {
148
+ color: grey;
149
+ opacity: 0.5;
150
+ }
151
+ </style>
@@ -1,171 +1,171 @@
1
- <template>
2
- <div class="form-group">
3
- <label>
4
- <i class="title class-icon-title" :class="classIconTitle"></i>
5
- <i class="fa-sharp fa-solid fa-location-dot icon-location"></i>
6
- <span class="title" :style="'color: ' + titleColor"> {{ title }} </span>
7
- <span class="required" v-if="required">*</span>
8
- <Tip :field="field" :formName="formName" />
9
- </label>
10
- <div class="inner-addon right-addon">
11
- <div class="required glyphicon" v-if="notifications.length > 0 && formDirty">
12
- <i class="fas fa-exclamation-triangle"></i>
13
- </div>
14
- <slot v-else></slot>
15
- <gmap-autocomplete @place_changed="setPlace" class="form-control teste" v-bind:value="value">
16
- </gmap-autocomplete>
17
- </div>
18
- <div v-if="formDirty">
19
- <div v-for="message in notifications" :key="message">
20
- <span class="invalid">{{ message }}</span>
21
- </div>
22
- </div>
23
- </div>
24
- </template>
25
-
26
- <script>
27
- import Tip from "../shared/Tip.vue";
28
- import { mapState, mapMutations } from "vuex";
29
-
30
- export default {
31
- components: { Tip },
32
- name: "InputText",
33
- props: [
34
- "title",
35
- "classIconTitle",
36
- "field",
37
- "placeholder",
38
- "disabled",
39
- "titleColor",
40
- "mask",
41
- "_style",
42
- "formName",
43
- "required",
44
- "maxLength",
45
- "value",
46
- "enter",
47
- "cleaned",
48
- "exited",
49
- "markFormDirty",
50
- ],
51
- data() {
52
- return {
53
- notifications: [],
54
- formDirty: false,
55
- withoutMask: {
56
- mask: "*".repeat(255),
57
- tokens: {
58
- "*": { pattern: /./ },
59
- },
60
- },
61
- };
62
- },
63
- created() {
64
- this.validate();
65
- },
66
- methods: {
67
- ...mapMutations("validation", [
68
- "addValidation",
69
- "removeValidation",
70
- "updateFormDirty",
71
- ]),
72
- validate() {
73
- this.notifications = [];
74
-
75
- if (this.required && this.value.length == 0) {
76
- var message = `${this.title} não pode ser vazio!`;
77
- this.notifications.push(message);
78
- }
79
-
80
- if (this.maxLength > 0) {
81
- if (this.value.length > this.maxLength) {
82
- var message = `Máximo de ${this.maxLength} caracteres!`;
83
- this.notifications.push(message);
84
- }
85
- }
86
- },
87
- pressedEnter() {
88
- if (this.enter) this.enter();
89
- },
90
- outField() {
91
- if (this.exited) this.exited();
92
- },
93
- cleanedField() {
94
- if (this.value.length == 0) {
95
- if (this.cleaned) this.cleaned();
96
- }
97
- },
98
- setPlace(place) {
99
- this.currentPlace = place;
100
- this.$emit("input", this.currentPlace.formatted_address);
101
- },
102
- },
103
- computed: {
104
- ...mapState("validation", ["resetForm", "validations"]),
105
- },
106
- watch: {
107
- value() {
108
- this.validate();
109
- this.formDirty = true;
110
- // inverti a validação devido não colocar o default como true no props
111
- var _value = this.markFormDirty == undefined ? true : this.markFormDirty;
112
- if (_value) this.updateFormDirty(true);
113
- },
114
- notifications() {
115
- let self = this;
116
- this.notifications.forEach(function (notification) {
117
- let obj = {
118
- key: self.field + "&" + self.formName,
119
- formName: self.formName,
120
- notification: notification,
121
- };
122
- self.addValidation(obj);
123
- });
124
-
125
- if (this.notifications.length == 0) {
126
- let obj = {
127
- key: self.field + "&" + self.formName,
128
- formName: self.formName,
129
- };
130
- self.removeValidation(obj);
131
- }
132
- },
133
- resetForm: {
134
- handler(form) {
135
- if (form.name == this.formName) this.formDirty = false;
136
- },
137
- deep: true,
138
- },
139
- },
140
- };
141
- </script>
142
-
143
- <style scoped>
144
- .title {
145
- font-size: 14px !important;
146
- }
147
-
148
- .icon-location {
149
- color: #0251a0;
150
- }
151
-
152
- .class-icon-title {
153
- margin-right: 5px;
154
- }
155
-
156
- .success {
157
- color: #94aa2a;
158
- font-size: 14px;
159
- }
160
-
161
- .invalid {
162
- color: #f0134d;
163
- font-size: 14px;
164
- }
165
-
166
- .margin-button {
167
- margin-top: -3px;
168
- }
169
-
170
-
171
- </style>
1
+ <template>
2
+ <div class="form-group">
3
+ <label>
4
+ <i class="title class-icon-title" :class="classIconTitle"></i>
5
+ <i class="fa-sharp fa-solid fa-location-dot icon-location"></i>
6
+ <span class="title" :style="'color: ' + titleColor"> {{ title }} </span>
7
+ <span class="required" v-if="required">*</span>
8
+ <Tip :field="field" :formName="formName" />
9
+ </label>
10
+ <div class="inner-addon right-addon">
11
+ <div class="required glyphicon" v-if="notifications.length > 0 && formDirty">
12
+ <i class="fas fa-exclamation-triangle"></i>
13
+ </div>
14
+ <slot v-else></slot>
15
+ <gmap-autocomplete @place_changed="setPlace" class="form-control teste" v-bind:value="value">
16
+ </gmap-autocomplete>
17
+ </div>
18
+ <div v-if="formDirty">
19
+ <div v-for="message in notifications" :key="message">
20
+ <span class="invalid">{{ message }}</span>
21
+ </div>
22
+ </div>
23
+ </div>
24
+ </template>
25
+
26
+ <script>
27
+ import Tip from "../shared/Tip.vue";
28
+ import { mapState, mapMutations } from "vuex";
29
+
30
+ export default {
31
+ components: { Tip },
32
+ name: "InputText",
33
+ props: [
34
+ "title",
35
+ "classIconTitle",
36
+ "field",
37
+ "placeholder",
38
+ "disabled",
39
+ "titleColor",
40
+ "mask",
41
+ "_style",
42
+ "formName",
43
+ "required",
44
+ "maxLength",
45
+ "value",
46
+ "enter",
47
+ "cleaned",
48
+ "exited",
49
+ "markFormDirty",
50
+ ],
51
+ data() {
52
+ return {
53
+ notifications: [],
54
+ formDirty: false,
55
+ withoutMask: {
56
+ mask: "*".repeat(255),
57
+ tokens: {
58
+ "*": { pattern: /./ },
59
+ },
60
+ },
61
+ };
62
+ },
63
+ created() {
64
+ this.validate();
65
+ },
66
+ methods: {
67
+ ...mapMutations("validation", [
68
+ "addValidation",
69
+ "removeValidation",
70
+ "updateFormDirty",
71
+ ]),
72
+ validate() {
73
+ this.notifications = [];
74
+
75
+ if (this.required && this.value.length == 0) {
76
+ var message = `${this.title} não pode ser vazio!`;
77
+ this.notifications.push(message);
78
+ }
79
+
80
+ if (this.maxLength > 0) {
81
+ if (this.value.length > this.maxLength) {
82
+ var message = `Máximo de ${this.maxLength} caracteres!`;
83
+ this.notifications.push(message);
84
+ }
85
+ }
86
+ },
87
+ pressedEnter() {
88
+ if (this.enter) this.enter();
89
+ },
90
+ outField() {
91
+ if (this.exited) this.exited();
92
+ },
93
+ cleanedField() {
94
+ if (this.value.length == 0) {
95
+ if (this.cleaned) this.cleaned();
96
+ }
97
+ },
98
+ setPlace(place) {
99
+ this.currentPlace = place;
100
+ this.$emit("input", this.currentPlace.formatted_address);
101
+ },
102
+ },
103
+ computed: {
104
+ ...mapState("validation", ["resetForm", "validations"]),
105
+ },
106
+ watch: {
107
+ value() {
108
+ this.validate();
109
+ this.formDirty = true;
110
+ // inverti a validação devido não colocar o default como true no props
111
+ var _value = this.markFormDirty == undefined ? true : this.markFormDirty;
112
+ if (_value) this.updateFormDirty(true);
113
+ },
114
+ notifications() {
115
+ let self = this;
116
+ this.notifications.forEach(function (notification) {
117
+ let obj = {
118
+ key: self.field + "&" + self.formName,
119
+ formName: self.formName,
120
+ notification: notification,
121
+ };
122
+ self.addValidation(obj);
123
+ });
124
+
125
+ if (this.notifications.length == 0) {
126
+ let obj = {
127
+ key: self.field + "&" + self.formName,
128
+ formName: self.formName,
129
+ };
130
+ self.removeValidation(obj);
131
+ }
132
+ },
133
+ resetForm: {
134
+ handler(form) {
135
+ if (form.name == this.formName) this.formDirty = false;
136
+ },
137
+ deep: true,
138
+ },
139
+ },
140
+ };
141
+ </script>
142
+
143
+ <style scoped>
144
+ .title {
145
+ font-size: 14px !important;
146
+ }
147
+
148
+ .icon-location {
149
+ color: #0251a0;
150
+ }
151
+
152
+ .class-icon-title {
153
+ margin-right: 5px;
154
+ }
155
+
156
+ .success {
157
+ color: #94aa2a;
158
+ font-size: 14px;
159
+ }
160
+
161
+ .invalid {
162
+ color: #f0134d;
163
+ font-size: 14px;
164
+ }
165
+
166
+ .margin-button {
167
+ margin-top: -3px;
168
+ }
169
+
170
+
171
+ </style>