mediacube-ui 0.1.346 → 0.1.347

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 (108) hide show
  1. package/CHANGELOG.md +2 -0
  2. package/dist/0.mediacube-ui.umd.js +50 -0
  3. package/dist/assets/img/icons.3b7d59b2f49c67a2a3a4566b8ab233fd.svg +1 -0
  4. package/dist/assets/img/no_table_data.236cd56f46cfb71fc363b008d4ca70d5.png +0 -0
  5. package/dist/assets/img/no_user.e0030d6e54e2400e1181fd22b83cf8ae.png +0 -0
  6. package/dist/mediacube-ui.umd.js +1 -0
  7. package/package.json +14 -16
  8. package/src/assets/tokens/tokens.json +5 -0
  9. package/dist/mediacube-ui.common.js +0 -378
  10. package/src/elements/McAvatar/McAvatar.vue +0 -274
  11. package/src/elements/McBadge/McBadge.vue +0 -148
  12. package/src/elements/McButton/McButton.vue +0 -841
  13. package/src/elements/McChip/McChip.vue +0 -300
  14. package/src/elements/McCropper/McCropper.vue +0 -133
  15. package/src/elements/McDate/McDate.vue +0 -105
  16. package/src/elements/McDatePicker/McDatePicker.vue +0 -902
  17. package/src/elements/McField/McFieldCheckbox/McFieldCheckbox.vue +0 -332
  18. package/src/elements/McField/McFieldRadio/McFieldRadioButton/McFieldRadioButton.vue +0 -201
  19. package/src/elements/McField/McFieldRadio/McFieldRadioGroup/McFieldRadioGroup.vue +0 -194
  20. package/src/elements/McField/McFieldSelect/McFieldSelect.vue +0 -1087
  21. package/src/elements/McField/McFieldText/McFieldText.vue +0 -969
  22. package/src/elements/McField/McFieldToggle/McFieldToggle.vue +0 -268
  23. package/src/elements/McInfinityLoadingIndicator/McInfinityLoadingIndicator.vue +0 -97
  24. package/src/elements/McNotification/McNotification.vue +0 -209
  25. package/src/elements/McProgress/McProgress.vue +0 -218
  26. package/src/elements/McRangeSlider/McRangeSlider.vue +0 -195
  27. package/src/elements/McSeparator/McSeparator.vue +0 -143
  28. package/src/elements/McSlideUpDown/McSlideUpDown.vue +0 -157
  29. package/src/elements/McSvgIcon/McSvgIcon.vue +0 -127
  30. package/src/elements/McTabs/McTab/McTab.vue +0 -187
  31. package/src/elements/McTabs/McTabs/McTabs.vue +0 -531
  32. package/src/elements/McTitle/McTitle.vue +0 -365
  33. package/src/elements/McTooltip/McTooltip.vue +0 -334
  34. package/src/helpers/consts.js +0 -3
  35. package/src/helpers/delayedAction.js +0 -26
  36. package/src/helpers/storybookFunctions.js +0 -20
  37. package/src/helpers/storybookVariables.js +0 -24
  38. package/src/mixins/equalFieldHeight.js +0 -59
  39. package/src/mixins/fieldErrors.js +0 -28
  40. package/src/patterns/McAccordion/McAccordion.vue +0 -53
  41. package/src/patterns/McCells/McCell/McCell.vue +0 -101
  42. package/src/patterns/McChat/McChat.vue +0 -305
  43. package/src/patterns/McChat/McChatComment/McChatComment.vue +0 -265
  44. package/src/patterns/McChat/McChatForm/McChatForm.vue +0 -147
  45. package/src/patterns/McCollapse/McCollapse.vue +0 -280
  46. package/src/patterns/McDrawer/McDrawer.vue +0 -146
  47. package/src/patterns/McDropdown/McDropdown.vue +0 -247
  48. package/src/patterns/McDropdown/McDropdownPanel/McDropdownPanel.vue +0 -40
  49. package/src/patterns/McFakeScroll/McFakeScroll.vue +0 -277
  50. package/src/patterns/McFilter/McFilter.vue +0 -847
  51. package/src/patterns/McFilter/McFilterChip/McFilterChip.vue +0 -83
  52. package/src/patterns/McFilter/McFilterTags/McFilterTags.vue +0 -374
  53. package/src/patterns/McFilter/McFilterTypeDate/McFilterTypeDate.vue +0 -70
  54. package/src/patterns/McFilter/McFilterTypeRange/McFilterTypeRange.vue +0 -132
  55. package/src/patterns/McFilter/McFilterTypeRelation/McFilterTypeRelation.vue +0 -221
  56. package/src/patterns/McFilter/McFilterTypeSimple/McFilterTypeSimple.vue +0 -161
  57. package/src/patterns/McFilter/McFilterTypeText/McFilterTypeText.vue +0 -62
  58. package/src/patterns/McGrid/McGridCol/McGridCol.vue +0 -165
  59. package/src/patterns/McGrid/McGridRow/McGridRow.vue +0 -158
  60. package/src/patterns/McModal/McModal.vue +0 -680
  61. package/src/patterns/McOverlay/McOverlay.vue +0 -78
  62. package/src/patterns/McPreview/McPreview.vue +0 -118
  63. package/src/patterns/McSideBar/McSideBar/McSideBar.vue +0 -387
  64. package/src/patterns/McSideBar/McSideBarBottom/McSideBarBottom.vue +0 -125
  65. package/src/patterns/McSideBar/McSideBarButton/McSideBarButton.vue +0 -252
  66. package/src/patterns/McSideBar/McSideBarCenter/McSideBarCenter.vue +0 -367
  67. package/src/patterns/McSideBar/McSideBarTop/McSideBarTop.vue +0 -238
  68. package/src/patterns/McStack/McStack.vue +0 -158
  69. package/src/patterns/McTable/McTable/McTable.vue +0 -854
  70. package/src/patterns/McTable/McTableCol/McTableCol.vue +0 -296
  71. package/src/patterns/McTableCard/McTableCard.vue +0 -135
  72. package/src/patterns/McTableCard/McTableCardHeader/McTableCardHeader.vue +0 -74
  73. package/src/patterns/McTopBar/McTopBar.vue +0 -153
  74. package/src/patterns/McWrapScroll/McWrapScroll.vue +0 -291
  75. package/src/styles/_functions.scss +0 -187
  76. package/src/styles/_mixins.scss +0 -612
  77. package/src/styles/_spacing.scss +0 -33
  78. package/src/styles/_variables.scss +0 -23
  79. package/src/styles/global.scss +0 -308
  80. package/src/styles/main.scss +0 -4
  81. package/src/styles/table.scss +0 -10
  82. package/src/styles/toast.scss +0 -55
  83. package/src/templates/layouts/McContentFixed/McContentFixed.vue +0 -60
  84. package/src/templates/layouts/McMain/McMain.vue +0 -115
  85. package/src/templates/layouts/McRoot/McRoot.vue +0 -45
  86. package/src/tokens/animations.scss +0 -9
  87. package/src/tokens/border-radius.scss +0 -26
  88. package/src/tokens/box-shadows.scss +0 -28
  89. package/src/tokens/colors.scss +0 -82
  90. package/src/tokens/durations.scss +0 -7
  91. package/src/tokens/easings.scss +0 -6
  92. package/src/tokens/font-families.scss +0 -8
  93. package/src/tokens/font-sizes.scss +0 -23
  94. package/src/tokens/font-weights.scss +0 -9
  95. package/src/tokens/gradients.scss +0 -19
  96. package/src/tokens/letter-spacings.scss +0 -6
  97. package/src/tokens/line-heights.scss +0 -22
  98. package/src/tokens/media-queries.scss +0 -32
  99. package/src/tokens/opacities.scss +0 -8
  100. package/src/tokens/sizes.scss +0 -47
  101. package/src/tokens/spacings.scss +0 -38
  102. package/src/tokens/z-indexes.scss +0 -14
  103. package/src/utils/dayjs.js +0 -19
  104. package/src/utils/filters.js +0 -11
  105. package/src/utils/getTokens.js +0 -41
  106. package/src/utils/load-icons.js +0 -3
  107. package/src/utils/treeSearch.js +0 -30
  108. package/src/utils/webFontLoader.js +0 -12
@@ -1,332 +0,0 @@
1
- <template>
2
- <div :dir="dir" :class="classes" :style="styles">
3
- <div v-if="title || $slots.header" class="mc-field-text__header">
4
- <!-- @slot Слот заголовка -->
5
- <slot name="header">
6
- <mc-title :ellipsis="false" weight="medium">{{ title }}</mc-title>
7
- </slot>
8
- </div>
9
- <div class="mc-field-checkbox__input-wrap">
10
- <label class="mc-field-checkbox__name">
11
- <mc-svg-icon
12
- class="mc-field-checkbox__icon"
13
- :name="isChecked ? 'checkbox--checked' : 'checkbox'"
14
- :color="isChecked ? 'purple' : 'gray'"
15
- :size="checkboxSize"
16
- />
17
- <input v-bind="inputProps" @change="handleChange" />
18
- <span v-if="mainText || $slots.default" class="mc-field-checkbox__name-text">
19
- <!-- @slot Слот для пользовательской подписи чекбокса -->
20
- <slot>
21
- <mc-title tag-name="div" :ellipsis="false">
22
- {{ mainText }}
23
- </mc-title>
24
- </slot>
25
- </span>
26
- </label>
27
- <div class="mc-field-checkbox__footer">
28
- <mc-title
29
- v-if="errorText"
30
- tag-name="div"
31
- color="red"
32
- variation="overline"
33
- max-width="100%"
34
- :ellipsis="false"
35
- >
36
- {{ errorText }}
37
- </mc-title>
38
- <br v-if="errorText" />
39
- <!-- @slot Слот доп. текста под чекбоксом -->
40
- <slot name="footer">
41
- <mc-title
42
- v-if="helpText"
43
- tag-name="div"
44
- variation="overline"
45
- color="gray"
46
- max-width="100%"
47
- :ellipsis="false"
48
- >
49
- {{ helpText }}
50
- </mc-title>
51
- </slot>
52
- </div>
53
- </div>
54
- </div>
55
- </template>
56
-
57
- <script>
58
- import McTitle from '../../McTitle/McTitle'
59
- import McSvgIcon from '../../McSvgIcon/McSvgIcon'
60
- import fieldErrors from '../../../mixins/fieldErrors'
61
- import { LANGUAGES } from '../../../helpers/consts'
62
- export default {
63
- name: 'McFieldCheckbox',
64
- components: { McTitle, McSvgIcon },
65
- mixins: [fieldErrors],
66
- props: {
67
- /**
68
- * Значение
69
- *
70
- */
71
- value: {
72
- default: null,
73
- },
74
-
75
- /**
76
- * Name
77
- *
78
- */
79
- name: {
80
- type: String,
81
- default: null,
82
- },
83
-
84
- /**
85
- * Выбранное значение
86
- *
87
- */
88
- checkedValue: {
89
- default: true,
90
- },
91
-
92
- /**
93
- * Невыбранное значение
94
- *
95
- */
96
- uncheckedValue: {
97
- default: false,
98
- },
99
-
100
- /**
101
- * Ошибки
102
- *
103
- */
104
- errors: {
105
- type: Array,
106
- default: null,
107
- },
108
-
109
- /**
110
- * Вспомогательный текст под инпутом:
111
- *
112
- */
113
- helpText: {
114
- type: String,
115
- default: null,
116
- },
117
-
118
- /**
119
- * Подпись чекбокса:
120
- *
121
- */
122
- mainText: {
123
- type: String,
124
- default: null,
125
- },
126
-
127
- /**
128
- * Заголовок поля:
129
- *
130
- */
131
- title: {
132
- type: String,
133
- default: null,
134
- },
135
-
136
- /**
137
- * Отключенное состояние
138
- *
139
- */
140
- disabled: {
141
- type: Boolean,
142
- default: false,
143
- },
144
- multiple: {
145
- type: Boolean,
146
- default: false,
147
- },
148
- checkboxSize: {
149
- type: String,
150
- default: '250',
151
- },
152
-
153
- /**
154
- * Атрибут tabindex для главного элемента
155
- *
156
- */
157
- tabindex: {
158
- type: [String, Number],
159
- },
160
- locale: {
161
- type: String,
162
- default: null,
163
- },
164
- },
165
- computed: {
166
- rtl() {
167
- return LANGUAGES.rtl.includes(this.locale)
168
- },
169
- dir() {
170
- return this.rtl ? 'rtl' : null
171
- },
172
- classes() {
173
- return {
174
- 'mc-field-checkbox': true,
175
- 'mc-field-checkbox--error': this.errors,
176
- 'mc-field-checkbox--disabled': this.disabled,
177
- 'mc-field-checkbox--empty': !this.mainText && !this.$slots.default,
178
- 'mc-field-checkbox--rtl': this.rtl,
179
- }
180
- },
181
- styles() {
182
- return {
183
- '--mc-field-checkbox-size': this.checkboxSize && `var(--size-${this.checkboxSize})`,
184
- }
185
- },
186
- inputProps() {
187
- return {
188
- disabled: this.disabled,
189
- name: this.name,
190
- checked: this.isChecked,
191
- tabindex: this.tabindex,
192
- type: 'checkbox',
193
- class: 'mc-field-checkbox__input',
194
- }
195
- },
196
- isChecked() {
197
- return this.multiple && this.value
198
- ? this.value.includes(this.checkedValue)
199
- : this.value === this.checkedValue
200
- },
201
- },
202
- methods: {
203
- handleChange(e) {
204
- this.toggleErrorVisible()
205
- /**
206
- * Событие инпута
207
- * @property {boolean}
208
- */
209
- this.$emit(
210
- 'input',
211
- this.multiple && this.value
212
- ? this.value.includes(this.checkedValue)
213
- ? this.value.filter(v => v !== this.checkedValue)
214
- : [...this.value, this.checkedValue]
215
- : e.target.checked
216
- ? this.checkedValue
217
- : this.uncheckedValue,
218
- )
219
- },
220
- },
221
- }
222
- </script>
223
-
224
- <style lang="scss">
225
- @import '../../../styles/mixins';
226
- .mc-field-checkbox {
227
- $block-name: &;
228
- position: relative;
229
- display: block;
230
- min-width: var(--mc-field-checkbox-size);
231
- min-height: var(--mc-field-checkbox-size);
232
- #{$block-name}__icon {
233
- width: var(--mc-field-checkbox-size);
234
- height: var(--mc-field-checkbox-size);
235
- }
236
-
237
- &__header {
238
- @include reset-text-indents();
239
- display: block;
240
- margin-bottom: $space-100;
241
-
242
- &:empty {
243
- display: none;
244
- }
245
- }
246
-
247
- &__name {
248
- @include reset();
249
- position: relative;
250
- line-height: $line-height-200;
251
- font-size: $font-size-200;
252
- display: flex;
253
- align-items: center;
254
- cursor: pointer;
255
- user-select: none;
256
- }
257
-
258
- &__icon {
259
- z-index: 1;
260
- &:hover {
261
- color: $color-purple;
262
- }
263
- }
264
-
265
- &__name-text {
266
- display: inline-block;
267
- margin-inline-start: $space-100;
268
- &:before {
269
- @include pseudo(none);
270
- @include size(var(--mc-field-checkbox-size));
271
- @include position(absolute, 0 null null 0);
272
- background-size: 100%;
273
- }
274
-
275
- .mc-button {
276
- display: inline;
277
- white-space: normal;
278
- vertical-align: top;
279
- margin-inline-start: 1px;
280
-
281
- &__text {
282
- white-space: normal;
283
- display: inline;
284
- }
285
- }
286
- }
287
-
288
- &__input {
289
- display: none;
290
- }
291
-
292
- &__footer {
293
- padding-inline-start: $space-250;
294
- margin-top: $space-50;
295
- &:empty {
296
- display: none;
297
- }
298
- }
299
-
300
- &--disabled {
301
- #{$block-name} {
302
- &__icon {
303
- color: $color-outline-gray;
304
- &:hover {
305
- color: $color-outline-gray;
306
- }
307
- }
308
- &__name-text {
309
- &:before {
310
- display: block;
311
- border-radius: 2px;
312
- background-color: $color-hover-gray;
313
- }
314
- }
315
- }
316
- }
317
-
318
- &--empty {
319
- #{$block-name} {
320
- &__footer,
321
- &__name {
322
- padding: 0;
323
- margin: 0;
324
- }
325
- }
326
- }
327
-
328
- &--rtl {
329
- direction: rtl;
330
- }
331
- }
332
- </style>
@@ -1,201 +0,0 @@
1
- <template>
2
- <label class="mc-field-radio-button" :class="classes">
3
- <input v-bind="inputProps" @change="handleChange" />
4
- <span class="mc-field-radio-button__icon_wrapper">
5
- <mc-svg-icon
6
- :name="checkedDefault ? activeIcon : 'circle'"
7
- :color="iconColor"
8
- :size="iconSize"
9
- class="mc-field-radio-button__icon"
10
- />
11
- </span>
12
- <span v-if="label || $slots.default" class="mc-field-radio-button__text">
13
- <!-- @slot Слот для пользовательской подписи радио -->
14
- <slot>
15
- <mc-title tag-name="div" :ellipsis="false">
16
- {{ label }}
17
- </mc-title>
18
- </slot>
19
- </span>
20
- </label>
21
- </template>
22
-
23
- <script>
24
- import McTitle from '../../../McTitle/McTitle'
25
- import McSvgIcon from '../../../McSvgIcon/McSvgIcon.vue'
26
- export default {
27
- name: 'McFieldRadioButton',
28
- components: {
29
- McTitle,
30
- McSvgIcon,
31
- },
32
- props: {
33
- /**
34
- * Значение
35
- */
36
- value: {
37
- default: null,
38
- },
39
-
40
- /**
41
- * Name
42
- */
43
- name: {
44
- type: String,
45
- required: true,
46
- },
47
-
48
- /**
49
- * Предварительно активированный
50
- */
51
- checkedDefault: {
52
- type: Boolean,
53
- default: false,
54
- },
55
-
56
- /**
57
- * Подпись радио:
58
- *
59
- */
60
- label: {
61
- type: String,
62
- default: null,
63
- },
64
-
65
- /**
66
- * Отключенное состояние
67
- *
68
- */
69
- disabled: {
70
- type: Boolean,
71
- default: false,
72
- },
73
-
74
- /**
75
- * Атрибут tabindex для главного элемента
76
- *
77
- */
78
- tabindex: {
79
- type: [String, Number],
80
- },
81
- /**
82
- * Вариант активного состояния - circle || checkmark
83
- * circle - внутри круг
84
- * checkmark - внутри галочка
85
- * */
86
- activeVariation: {
87
- type: String,
88
- default: 'circle',
89
- },
90
- /**
91
- * цвет
92
- */
93
- color: {
94
- type: String,
95
- default: 'purple',
96
- },
97
- iconSize: {
98
- type: String,
99
- default: '250',
100
- },
101
- },
102
- computed: {
103
- classes() {
104
- return {
105
- 'mc-field-radio-button--disabled': this.disabled,
106
- 'mc-field-radio-button--empty': !this.label && !this.$slots.default,
107
- }
108
- },
109
- activeIcon() {
110
- switch (this.activeVariation) {
111
- case 'checkmark': {
112
- return 'check_circle_solid'
113
- }
114
- default: {
115
- return 'radio--checked'
116
- }
117
- }
118
- },
119
- iconColor() {
120
- switch (true) {
121
- case this.disabled:
122
- return 'outline-gray'
123
- case this.checkedDefault:
124
- return this.color
125
- default:
126
- return 'gray'
127
- }
128
- },
129
- inputProps() {
130
- return {
131
- disabled: this.disabled,
132
- value: this.value,
133
- name: this.name,
134
- checked: this.checkedDefault,
135
- tabindex: this.tabindex,
136
- class: 'mc-field-radio-button__input',
137
- type: 'radio',
138
- }
139
- },
140
- },
141
- methods: {
142
- handleChange(event) {
143
- /**
144
- * Событие инпута
145
- * @property {boolean}
146
- */
147
- this.$emit('input', event)
148
- },
149
- },
150
- }
151
- </script>
152
-
153
- <style lang="scss">
154
- @import '../../../../styles/mixins';
155
- .mc-field-radio-button {
156
- $block-name: &;
157
- display: inline-block;
158
- min-width: $size-250;
159
- min-height: $size-250;
160
- @include reset();
161
- position: relative;
162
- padding-inline-start: $space-300;
163
- line-height: $line-height-200;
164
- font-size: $font-size-200;
165
- cursor: pointer;
166
-
167
- &__icon {
168
- &_wrapper {
169
- z-index: 1;
170
- @include position(absolute, 0 null null 0);
171
- }
172
- }
173
-
174
- &__text {
175
- display: inline-block;
176
- margin: 2px 0;
177
- }
178
-
179
- &__input {
180
- display: none;
181
- }
182
-
183
- &--disabled {
184
- cursor: auto;
185
-
186
- #{$block-name}__input {
187
- & ~ #{$block-name}__icon_wrapper {
188
- .mc-svg-icon {
189
- border-radius: $radius-circle;
190
- background-color: $color-hover-gray;
191
- }
192
- }
193
- }
194
- }
195
-
196
- &--empty {
197
- padding: 0;
198
- margin: 0;
199
- }
200
- }
201
- </style>