@winchsa/ui 0.1.2 → 0.1.4

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 (167) hide show
  1. package/README.md +3 -113
  2. package/dist/components/{core/DialogCloseBtn.vue → DialogCloseBtn.vue} +1 -1
  3. package/dist/components/Drawer.vue +1 -1
  4. package/dist/components/Drawer.vue.d.ts +1 -1
  5. package/dist/components/{loading/LoadingDialog.vue → LoadingDialog.vue} +1 -1
  6. package/dist/components/Modal.vue +2 -2
  7. package/dist/components/{core/MoreBtn.vue → MoreBtn.vue} +1 -1
  8. package/dist/components/{core/MoreBtn.vue.d.ts → MoreBtn.vue.d.ts} +1 -1
  9. package/dist/components/{core/cards → cards}/AppCard.vue +1 -1
  10. package/dist/components/{core/cards → cards}/AppCard.vue.d.ts +1 -1
  11. package/dist/components/{core/cards → cards}/AppCardActions.vue +1 -1
  12. package/dist/components/{core/cards → cards}/AppCardActions.vue.d.ts +5 -5
  13. package/dist/components/cards/CheckboxesCard.vue +1 -1
  14. package/dist/components/cards/ImageCard.vue +1 -1
  15. package/dist/components/cards/ImageCard.vue.d.ts +1 -1
  16. package/dist/components/cards/InputCard.vue +1 -1
  17. package/dist/components/cards/InputCard.vue.d.ts +1 -1
  18. package/dist/components/cards/StaticCard.vue +1 -1
  19. package/dist/components/cards/StaticCard.vue.d.ts +1 -1
  20. package/dist/components/{core → forms}/AppBarSearch.vue +1 -1
  21. package/dist/components/{core → forms}/AppBarSearch.vue.d.ts +25 -25
  22. package/dist/components/forms/AppLink.vue +1 -1
  23. package/dist/components/forms/AppOtpInput.vue +1 -1
  24. package/dist/components/{core → forms}/AppSearchHeader.vue +2 -2
  25. package/dist/components/forms/AutocompleteInput.vue +1 -1
  26. package/dist/components/{core/app-form-elements → forms}/CustomCheckboxes.vue +1 -1
  27. package/dist/components/{core/app-form-elements → forms}/CustomCheckboxes.vue.d.ts +1 -1
  28. package/dist/components/{core/app-form-elements → forms}/CustomCheckboxesWithIcon.vue +1 -1
  29. package/dist/components/{core/app-form-elements → forms}/CustomCheckboxesWithIcon.vue.d.ts +1 -1
  30. package/dist/components/{core/app-form-elements → forms}/CustomCheckboxesWithImage.vue +1 -1
  31. package/dist/components/{core/app-form-elements → forms}/CustomCheckboxesWithImage.vue.d.ts +1 -1
  32. package/dist/components/{core/app-form-elements → forms}/CustomRadios.vue +1 -1
  33. package/dist/components/{core/app-form-elements → forms}/CustomRadios.vue.d.ts +1 -1
  34. package/dist/components/{core/app-form-elements → forms}/CustomRadiosWithIcon.vue.d.ts +1 -1
  35. package/dist/components/{core/app-form-elements → forms}/CustomRadiosWithImage.vue.d.ts +1 -1
  36. package/dist/components/forms/DatePickerRange.vue +1 -1
  37. package/dist/components/forms/ManualDate.vue +2 -2
  38. package/dist/components/forms/PasswordInput.vue +1 -1
  39. package/dist/components/forms/RangeInput.vue +1 -1
  40. package/dist/components/table/DataTable.vue +4 -4
  41. package/dist/components/table/EditableDataTable.vue +1 -1
  42. package/dist/components/table/EditableDataTable.vue.d.ts +1 -1
  43. package/dist/components/table/EditableDataTableRow.vue +2 -2
  44. package/dist/components/table/FilterGenerator.vue +3 -3
  45. package/dist/components/table/StaticTable.vue +1 -1
  46. package/dist/components/table/TablePagination.vue +1 -1
  47. package/dist/composables/useFormValidation.d.ts +0 -0
  48. package/dist/composables/useFormValidation.js +1 -0
  49. package/dist/composables/useFormValidation.mjs +0 -0
  50. package/dist/index.d.ts +38 -39
  51. package/dist/index.js +43 -36
  52. package/dist/index.mjs +71 -69
  53. package/dist/utils/hijri-date.d.ts +58 -0
  54. package/dist/utils/hijri-date.js +168 -0
  55. package/dist/utils/hijri-date.mjs +1951 -0
  56. package/dist/utils/ruleValidator.d.ts +6 -0
  57. package/dist/utils/ruleValidator.js +32 -2
  58. package/dist/utils/ruleValidator.mjs +29 -0
  59. package/package.json +8 -10
  60. package/dist/components/icons/EndMarker.vue +0 -25
  61. package/dist/components/icons/EndMarker.vue.d.ts +0 -17
  62. package/dist/components/icons/RedXIcon.vue +0 -36
  63. package/dist/components/icons/RedXIcon.vue.d.ts +0 -2
  64. package/dist/components/icons/StarFillIcon.vue +0 -28
  65. package/dist/components/icons/StarFillIcon.vue.d.ts +0 -2
  66. package/dist/components/icons/StartMarker.vue +0 -25
  67. package/dist/components/icons/StartMarker.vue.d.ts +0 -17
  68. package/dist/components/icons/WorkerIcon.vue +0 -39
  69. package/dist/components/icons/WorkerIcon.vue.d.ts +0 -2
  70. package/dist/fonts/NotoSans-Medium.ttf +0 -0
  71. package/dist/fonts/NotoSansArabic-Medium.ttf +0 -0
  72. package/dist/fonts/saudi_riyal_symbol/saudi_riyal_symbol.eot +0 -0
  73. package/dist/fonts/saudi_riyal_symbol/saudi_riyal_symbol.svg +0 -9
  74. package/dist/fonts/saudi_riyal_symbol/saudi_riyal_symbol.ttf +0 -0
  75. package/dist/fonts/saudi_riyal_symbol/saudi_riyal_symbol.woff +0 -0
  76. package/dist/fonts/saudi_riyal_symbol/saudi_riyal_symbol.woff2 +0 -0
  77. package/dist/images/successful-registration.svg +0 -15
  78. package/dist/styles/assets/scss/styles.css +0 -16099
  79. package/dist/styles/assets/scss/styles.scss +0 -246
  80. package/src/styles/@core/scss/base/_components.scss +0 -164
  81. package/src/styles/@core/scss/base/_dark.scss +0 -16
  82. package/src/styles/@core/scss/base/_default-layout-w-vertical-nav.scss +0 -106
  83. package/src/styles/@core/scss/base/_default-layout.scss +0 -16
  84. package/src/styles/@core/scss/base/_index.scss +0 -47
  85. package/src/styles/@core/scss/base/_layouts.scss +0 -63
  86. package/src/styles/@core/scss/base/_misc.scss +0 -20
  87. package/src/styles/@core/scss/base/_mixins.scss +0 -84
  88. package/src/styles/@core/scss/base/_route-transitions.scss +0 -70
  89. package/src/styles/@core/scss/base/_utilities.scss +0 -418
  90. package/src/styles/@core/scss/base/_utils.scss +0 -100
  91. package/src/styles/@core/scss/base/_variables.scss +0 -190
  92. package/src/styles/@core/scss/base/_vertical-nav.scss +0 -264
  93. package/src/styles/@core/scss/base/libs/_perfect-scrollbar.scss +0 -35
  94. package/src/styles/@core/scss/base/libs/vuetify/_index.scss +0 -1
  95. package/src/styles/@core/scss/base/libs/vuetify/_overrides.scss +0 -385
  96. package/src/styles/@core/scss/base/libs/vuetify/_variables.scss +0 -48
  97. package/src/styles/@core/scss/base/placeholders/_default-layout-vertical-nav.scss +0 -48
  98. package/src/styles/@core/scss/base/placeholders/_default-layout.scss +0 -3
  99. package/src/styles/@core/scss/base/placeholders/_index.scss +0 -5
  100. package/src/styles/@core/scss/base/placeholders/_misc.scss +0 -7
  101. package/src/styles/@core/scss/base/placeholders/_nav.scss +0 -26
  102. package/src/styles/@core/scss/base/placeholders/_vertical-nav.scss +0 -84
  103. package/src/styles/@core/scss/base/skins/_bordered.scss +0 -60
  104. package/src/styles/@core/scss/base/skins/_index.scss +0 -1
  105. package/src/styles/@core/scss/template/_components.scss +0 -1035
  106. package/src/styles/@core/scss/template/_default-layout-w-vertical-nav.scss +0 -20
  107. package/src/styles/@core/scss/template/_utilities.scss +0 -20
  108. package/src/styles/@core/scss/template/_variables.scss +0 -67
  109. package/src/styles/@core/scss/template/_vertical-nav.scss +0 -41
  110. package/src/styles/@core/scss/template/index.scss +0 -15
  111. package/src/styles/@core/scss/template/libs/apex-chart.scss +0 -99
  112. package/src/styles/@core/scss/template/libs/shepherd.scss +0 -88
  113. package/src/styles/@core/scss/template/libs/vuetify/_variables.scss +0 -461
  114. package/src/styles/@core/scss/template/libs/vuetify/index.scss +0 -1
  115. package/src/styles/@core/scss/template/pages/misc.scss +0 -20
  116. package/src/styles/@core/scss/template/placeholders/_default-layout-vertical-nav.scss +0 -9
  117. package/src/styles/@core/scss/template/placeholders/_index.scss +0 -3
  118. package/src/styles/@core/scss/template/placeholders/_nav.scss +0 -15
  119. package/src/styles/@core/scss/template/placeholders/_vertical-nav.scss +0 -18
  120. package/src/styles/@core/scss/template/skins/_bordered.scss +0 -36
  121. package/src/styles/@core/scss/template/skins/_index.scss +0 -1
  122. package/src/styles/@layouts/styles/_classes.scss +0 -3
  123. package/src/styles/@layouts/styles/_dashboard-layout.scss +0 -43
  124. package/src/styles/@layouts/styles/_global.scss +0 -10
  125. package/src/styles/@layouts/styles/_mixins.scss +0 -28
  126. package/src/styles/@layouts/styles/_placeholders.scss +0 -53
  127. package/src/styles/@layouts/styles/_rtl.scss +0 -7
  128. package/src/styles/@layouts/styles/_variables.scss +0 -22
  129. package/src/styles/@layouts/styles/index.scss +0 -2
  130. package/src/styles/assets/scss/styles.scss +0 -246
  131. package/src/styles/assets/scss/variables/_template.scss +0 -1
  132. package/src/styles/assets/scss/variables/_vuetify.scss +0 -1
  133. /package/dist/components/{core/CustomizerSection.vue → CustomizerSection.vue} +0 -0
  134. /package/dist/components/{core/CustomizerSection.vue.d.ts → CustomizerSection.vue.d.ts} +0 -0
  135. /package/dist/components/{core/DialogCloseBtn.vue.d.ts → DialogCloseBtn.vue.d.ts} +0 -0
  136. /package/dist/components/{loading/LoadingBar.vue → LoadingBar.vue} +0 -0
  137. /package/dist/components/{loading/LoadingBar.vue.d.ts → LoadingBar.vue.d.ts} +0 -0
  138. /package/dist/components/{loading/LoadingDialog.vue.d.ts → LoadingDialog.vue.d.ts} +0 -0
  139. /package/dist/components/{loading/LoadingItem.vue → LoadingItem.vue} +0 -0
  140. /package/dist/components/{loading/LoadingItem.vue.d.ts → LoadingItem.vue.d.ts} +0 -0
  141. /package/dist/components/{core/ScrollToTop.vue → ScrollToTop.vue} +0 -0
  142. /package/dist/components/{core/ScrollToTop.vue.d.ts → ScrollToTop.vue.d.ts} +0 -0
  143. /package/dist/components/{core/cards → cards}/CardStatisticsHorizontal.vue +0 -0
  144. /package/dist/components/{core/cards → cards}/CardStatisticsHorizontal.vue.d.ts +0 -0
  145. /package/dist/components/{core/app-form-elements → forms}/AppCombobox.vue +0 -0
  146. /package/dist/components/{core/app-form-elements → forms}/AppCombobox.vue.d.ts +0 -0
  147. /package/dist/components/{core → forms}/AppDrawerHeaderSection.vue +0 -0
  148. /package/dist/components/{core → forms}/AppDrawerHeaderSection.vue.d.ts +0 -0
  149. /package/dist/components/{core → forms}/AppSearchHeader.vue.d.ts +0 -0
  150. /package/dist/components/{core/app-form-elements → forms}/AppSelect.vue +0 -0
  151. /package/dist/components/{core/app-form-elements → forms}/AppSelect.vue.d.ts +0 -0
  152. /package/dist/components/{core → forms}/AppStepper.vue +0 -0
  153. /package/dist/components/{core → forms}/AppStepper.vue.d.ts +0 -0
  154. /package/dist/components/{core/app-form-elements → forms}/AppSwitch.vue +0 -0
  155. /package/dist/components/{core/app-form-elements → forms}/AppSwitch.vue.d.ts +0 -0
  156. /package/dist/components/{core/app-form-elements → forms}/AppTextField.vue +0 -0
  157. /package/dist/components/{core/app-form-elements → forms}/AppTextField.vue.d.ts +0 -0
  158. /package/dist/components/{core/app-form-elements → forms}/AppTextarea.vue +0 -0
  159. /package/dist/components/{core/app-form-elements → forms}/AppTextarea.vue.d.ts +0 -0
  160. /package/dist/components/{core/app-form-elements → forms}/CustomRadiosWithIcon.vue +0 -0
  161. /package/dist/components/{core/app-form-elements → forms}/CustomRadiosWithImage.vue +0 -0
  162. /package/dist/composables/{use-is-mobile.d.ts → useIsMobile.d.ts} +0 -0
  163. /package/dist/composables/{use-is-mobile.js → useIsMobile.js} +0 -0
  164. /package/dist/composables/{use-is-mobile.mjs → useIsMobile.mjs} +0 -0
  165. /package/dist/composables/{use-table-filters.d.ts → useTableFilters.d.ts} +0 -0
  166. /package/dist/composables/{use-table-filters.js → useTableFilters.js} +0 -0
  167. /package/dist/composables/{use-table-filters.mjs → useTableFilters.mjs} +0 -0
@@ -1,53 +0,0 @@
1
- // placeholders
2
- @use '../../assets/scss/variables/template' as variables;
3
-
4
- %boxed-content {
5
- @at-root #{&}-spacing {
6
- // TODO: Use grid gutter variable here
7
- padding-inline: 1.5rem;
8
- }
9
-
10
- inline-size: 100%;
11
- margin-inline: auto;
12
- max-inline-size: variables.$layout-boxed-content-width;
13
- }
14
-
15
- %layout-navbar-hidden {
16
- display: none;
17
- }
18
-
19
- // ℹ️ We created this placeholder even it is being used in just layout w/ vertical nav because in future we might apply style to both navbar & horizontal nav separately
20
- %layout-navbar-sticky {
21
- position: sticky;
22
- inset-block-start: 0;
23
-
24
- // will-change: transform;
25
- // inline-size: 100%;
26
- }
27
-
28
- %style-scroll-bar {
29
- /* width */
30
-
31
- &::-webkit-scrollbar {
32
- background: rgb(var(--v-theme-surface));
33
- block-size: 8px;
34
- border-end-end-radius: 14px;
35
- border-start-end-radius: 14px;
36
- inline-size: 4px;
37
- }
38
-
39
- /* Track */
40
- &::-webkit-scrollbar-track {
41
- background: transparent;
42
- }
43
-
44
- /* Handle */
45
- &::-webkit-scrollbar-thumb {
46
- border-radius: 0.5rem;
47
- background: rgb(var(--v-theme-silver));
48
- }
49
-
50
- &::-webkit-scrollbar-corner {
51
- display: none;
52
- }
53
- }
@@ -1,7 +0,0 @@
1
- @use 'mixins';
2
-
3
- .layout-vertical-nav .nav-group-arrow {
4
- @include mixins.rtl {
5
- transform: rotate(180deg);
6
- }
7
- }
@@ -1,22 +0,0 @@
1
- // Vertical nav
2
- $layout-vertical-nav-z-index: 12 !default;
3
- $layout-vertical-nav-width: 260px !default;
4
- $layout-vertical-nav-collapsed-width: 84px !default;
5
-
6
- // Navbar
7
- $layout-vertical-nav-navbar-height: 64px !default;
8
- $layout-vertical-nav-navbar-is-contained: true !default;
9
- $layout-vertical-nav-layout-navbar-z-index: 11 !default;
10
- $layout-horizontal-nav-layout-navbar-z-index: 11 !default;
11
-
12
- // Main content
13
- $layout-boxed-content-width: 1440px !default;
14
-
15
- // Footer
16
- $layout-vertical-nav-footer-height: 56px !default;
17
-
18
- // Layout overlay
19
- $layout-overlay-z-index: 11 !default;
20
-
21
- // RTL
22
- $enable-rtl-styles: true !default;
@@ -1,2 +0,0 @@
1
- @use '_global';
2
- @use '_classes';
@@ -1,246 +0,0 @@
1
- $font-family-custom: 'Saudi Riyal Symbol', 'Noto Sans English', 'Noto Sans Arabic', 'SA', --apple-system, 'Segoe UI', Roboto, Helvetica, sans-serif;
2
-
3
- @use 'vuetify/styles' as * with ($body-font-family: $font-family-custom);
4
-
5
- @font-face {
6
- font-family: 'Noto Sans English';
7
- src: url('../../../fonts/NotoSans-Medium.ttf') format('woff2');
8
- font-display: swap;
9
- font-weight: normal;
10
- letter-spacing: 0 !important;
11
- unicode-range: U+0020-007E, U+00A0-00FF, U+0100-017F, U+0180-024F, U+1E00-1EFF;
12
- }
13
-
14
- @font-face {
15
- font-family: 'Noto Sans Arabic';
16
- src: url('../../../fonts/NotoSansArabic-Medium.ttf') format('woff2');
17
- font-display: swap;
18
- font-weight: normal;
19
- unicode-range: U+0600-06FF;
20
- }
21
-
22
- @font-face {
23
- font-family: 'Saudi Riyal Symbol';
24
- src: url('../../../fonts/saudi_riyal_symbol/saudi_riyal_symbol.eot');
25
- src: url('../../../fonts/saudi_riyal_symbol/saudi_riyal_symbol.eot') format('embedded-opentype'),
26
- url('../../../fonts/saudi_riyal_symbol/saudi_riyal_symbol.woff') format('woff'),
27
- url('../../../fonts/saudi_riyal_symbol/saudi_riyal_symbol.ttf') format('truetype'),
28
- url('../../../fonts/saudi_riyal_symbol/saudi_riyal_symbol.svg') format('svg');
29
- font-weight: normal;
30
- font-style: normal;
31
- font-display: swap;
32
- }
33
-
34
- .v-application {
35
-
36
- &,
37
- * {
38
- [dir='ltr'] & {
39
- font-family: 'Saudi Riyal Symbol', 'Noto Sans English', 'Noto Sans Arabic', sans-serif;
40
- }
41
-
42
- [dir='rtl'] & {
43
- font-family: 'Saudi Riyal Symbol', 'Noto Sans Arabic', 'Noto Sans English', sans-serif;
44
- }
45
- }
46
-
47
- .v-slide-group__next,
48
- .v-tab-login .v-slide-group__prev {
49
- display: none;
50
- }
51
-
52
- .v-tabs--grow .v-btn {
53
- flex: 1 1 0 !important;
54
- padding: 10px 0;
55
- height: auto;
56
- }
57
-
58
- .app-text-field {
59
- input {
60
- font-size: 13px;
61
- color: rgba(var(--v-theme-on-background), var(--v-high-emphasis-opacity));
62
- margin: 0;
63
- }
64
-
65
- .v-field--active.v-field--focused {
66
- box-shadow: none !important;
67
- }
68
- }
69
-
70
- .v-overlay__content {
71
-
72
- .v-list-item:not(.v-list-item--active):hover,
73
- .v-list-item:not(.v-list-item--active):focus-visible {
74
- color: #000;
75
- background-color: rgba(255, 194, 15, 1);
76
- }
77
-
78
- .v-list-item--variant-text .v-list-item__overlay {
79
- background-color: rgba(255, 194, 15, 1);
80
- }
81
- }
82
-
83
- .v-input--disabled {
84
- .v-field {
85
- pointer-events: none;
86
- background: rgb(var(--v-disabled-background)) !important;
87
- border: none !important;
88
-
89
- &--disabled {
90
- opacity: 1 !important;
91
- }
92
- }
93
-
94
- .v-field__outline {
95
- color: rgb(var(--v-disabled-border)) !important;
96
- }
97
- }
98
- }
99
-
100
- .v-field--active.v-field--focused {
101
- box-shadow: none !important;
102
- }
103
-
104
- .v-breadcrumbs,
105
- .v-card-title {
106
- font-weight: 600 !important;
107
- }
108
-
109
- .v-label,
110
- .nav-item-title,
111
- .v-input__details,
112
- .v-list-item-title,
113
- .v-list-item__content,
114
- .v-list-item-title,
115
- .v-card-item__content,
116
- .v-card-title,
117
- .v-card-text {
118
- overflow: initial !important;
119
- }
120
-
121
- .v-window {
122
- padding: 12px 0;
123
- }
124
-
125
- .text-pre-line {
126
- white-space: pre-line !important;
127
- }
128
-
129
- .v-input__prepend,
130
- .v-input__append {
131
- padding-top: 0 !important;
132
- }
133
-
134
- .hover-underline,
135
- %hover-underline {
136
- position: relative;
137
- display: inline-block;
138
- cursor: pointer;
139
-
140
- &::after {
141
- content: '';
142
- position: absolute;
143
- bottom: -3px;
144
- inset-inline-start: 0;
145
- width: 0;
146
- height: 2px;
147
- background-color: rgba(var(--v-theme-primary));
148
- transition: width 0.3s ease;
149
- }
150
-
151
- &:hover {
152
- &::after {
153
- width: 100%;
154
- }
155
- }
156
- }
157
-
158
- .outline-none {
159
- outline: none !important;
160
- }
161
-
162
- .v-breadcrumbs-item--link {
163
- text-decoration: none !important;
164
- @extend %hover-underline;
165
-
166
- &:hover {
167
- text-decoration: none;
168
- }
169
- }
170
-
171
- .back-btn {
172
- position: absolute;
173
- top: 50%;
174
- inset-inline-start: 0;
175
- transform: translateY(-50%);
176
- background: rgb(var(--v-theme-gray-200)) !important;
177
-
178
- &:hover {
179
- background: rgb(var(--v-theme-secondary)) !important;
180
- color: rgb(var(--v-theme-on-secondary)) !important;
181
- }
182
-
183
- .v-btn__overlay {
184
- display: none !important;
185
- }
186
-
187
- &:active {
188
- transform: translateY(-50%) !important;
189
- }
190
- }
191
-
192
- .v-chip {
193
- min-width: 96px !important;
194
- text-align: center;
195
- justify-content: center;
196
- letter-spacing: 0 !important;
197
- }
198
-
199
- .v-autocomplete__selection {
200
- .v-chip {
201
- max-width: 100% !important;
202
- }
203
- }
204
-
205
- .v-input__control {
206
- .v-field {
207
- position: relative !important;
208
-
209
- .v-field__clearable {
210
- position: absolute !important;
211
- inset-inline-start: -20px !important;
212
- z-index: 999 !important;
213
- width: 20px !important;
214
- background-color: rgb(var(--v-theme-surface));
215
- top: 50% !important;
216
- transform: translateY(-50%);
217
- }
218
- }
219
- }
220
-
221
- .v-input--disabled {
222
- .v-field {
223
- .v-field__clearable {
224
- background-color: rgb(var(--v-disabled-background));
225
- }
226
- }
227
- }
228
-
229
- .v-input--disabled .v-input__control .v-field__field {
230
- border: none !important;
231
- }
232
-
233
- .v-input--disabled .v-field .v-field__overlay {
234
- border: 1px solid rgba(var(--v-border-color), var(--v-border-opacity)) !important;
235
- }
236
-
237
- .v-breadcrumbs-item {
238
- padding: 0px !important;
239
- }
240
-
241
- .multiselect__tags {
242
- padding-top: 10px !important;
243
- padding-inline-start: 8px !important;
244
- padding-bottom: 0 !important;
245
- padding-inline-end: 40px !important;
246
- }
@@ -1 +0,0 @@
1
- @forward '../../../@core/scss/template/variables';
@@ -1 +0,0 @@
1
- @forward '../../../@core/scss/template/libs/vuetify/variables';
File without changes