classcard-ui 0.2.774 → 0.2.775

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 (175) hide show
  1. package/README.md +24 -24
  2. package/dist/classcard-ui.common.js +79 -63
  3. package/dist/classcard-ui.common.js.map +1 -1
  4. package/dist/classcard-ui.umd.js +79 -63
  5. package/dist/classcard-ui.umd.js.map +1 -1
  6. package/dist/classcard-ui.umd.min.js +1 -1
  7. package/dist/classcard-ui.umd.min.js.map +1 -1
  8. package/package.json +81 -81
  9. package/src/App.vue +16 -16
  10. package/src/components/CAlerts/CAlerts.vue +70 -70
  11. package/src/components/CAlerts/index.js +2 -2
  12. package/src/components/CAnchorTabs/CAnchorTabs.vue +96 -96
  13. package/src/components/CAnchorTabs/index.js +2 -2
  14. package/src/components/CAnchorTag/CAnchorTag.vue +62 -62
  15. package/src/components/CAnchorTag/index.js +2 -2
  16. package/src/components/CAvatar/CAvatar.vue +112 -112
  17. package/src/components/CAvatar/index.js +2 -2
  18. package/src/components/CAvatarGroup/CAvatarGroup.vue +145 -145
  19. package/src/components/CAvatarGroup/index.js +2 -2
  20. package/src/components/CBasicTable/CBasicTable.vue +184 -184
  21. package/src/components/CBasicTable/index.js +2 -2
  22. package/src/components/CBreadcrumbs/CBreadcrumbs.vue +38 -38
  23. package/src/components/CBreadcrumbs/index.js +2 -2
  24. package/src/components/CButton/CButton.vue +147 -147
  25. package/src/components/CButton/index.js +2 -2
  26. package/src/components/CButtonGroup/CButtonGroup.vue +118 -118
  27. package/src/components/CButtonGroup/index.js +2 -2
  28. package/src/components/CButtonIcon/CButtonIcon.vue +112 -112
  29. package/src/components/CButtonIcon/index.js +2 -2
  30. package/src/components/CButtonLink/CButtonLink.vue +39 -39
  31. package/src/components/CButtonLink/index.js +2 -2
  32. package/src/components/CButtonSelect/CButtonSelect.vue +103 -103
  33. package/src/components/CButtonSelect/index.js +2 -2
  34. package/src/components/CButtonWithDropdown/CButtonWithDropdown.vue +168 -168
  35. package/src/components/CButtonWithDropdown/index.js +2 -2
  36. package/src/components/CCalendar/CCalendar.vue +410 -410
  37. package/src/components/CCalendar/index.js +3 -3
  38. package/src/components/CCard/CCard.vue +49 -49
  39. package/src/components/CCard/index.js +2 -2
  40. package/src/components/CCheckbox/CCheckbox.vue +70 -70
  41. package/src/components/CCheckbox/index.js +2 -2
  42. package/src/components/CCollapsibleSection/CCollapsibleSection.vue +101 -101
  43. package/src/components/CCollapsibleSection/index.js +2 -2
  44. package/src/components/CColorDots/CColorDots.vue +35 -35
  45. package/src/components/CColorDots/index.js +3 -3
  46. package/src/components/CConfirmActionModal/CConfirmActionModal.vue +131 -131
  47. package/src/components/CConfirmActionModal/index.js +3 -3
  48. package/src/components/CDatepicker/CDatepicker.vue +139 -139
  49. package/src/components/CDatepicker/index.js +2 -2
  50. package/src/components/CDualSelect/CDualSelect.vue +193 -193
  51. package/src/components/CDualSelect/index.js +2 -2
  52. package/src/components/CEditor/CEditor.vue +96 -96
  53. package/src/components/CEditor/index.js +2 -2
  54. package/src/components/CFormSectionHeading/CFormSectionHeading.vue +53 -53
  55. package/src/components/CFormSectionHeading/index.js +2 -2
  56. package/src/components/CGroupedSelect/CGroupedSelect.vue +218 -218
  57. package/src/components/CGroupedSelect/index.js +3 -3
  58. package/src/components/CIcon/CIcon.vue +77 -77
  59. package/src/components/CIcon/index.js +2 -2
  60. package/src/components/CIconDropdown/CIconDropdown.vue +118 -118
  61. package/src/components/CIconDropdown/index.js +2 -2
  62. package/src/components/CInput/CInput.vue +123 -123
  63. package/src/components/CInput/index.js +2 -2
  64. package/src/components/CInputAddon/CInputAddon.vue +202 -202
  65. package/src/components/CInputAddon/index.js +2 -2
  66. package/src/components/CInputEmail/CInputEmail.vue +93 -93
  67. package/src/components/CInputEmail/index.js +2 -2
  68. package/src/components/CModalHeading/CModalHeading.vue +22 -22
  69. package/src/components/CModalHeading/index.js +2 -2
  70. package/src/components/CModuleHelpLinks/CModuleHelpLinks.vue +39 -39
  71. package/src/components/CModuleHelpLinks/index.js +3 -3
  72. package/src/components/CMultiselect/CMultiselect.vue +361 -361
  73. package/src/components/CMultiselect/index.js +2 -2
  74. package/src/components/CMultiselectr/CMultiselectr.vue +44 -44
  75. package/src/components/CMultiselectr/index.js +2 -2
  76. package/src/components/CPageHeading/CPageHeading.vue +56 -56
  77. package/src/components/CPageHeading/index.js +2 -2
  78. package/src/components/CPagination/CPagination.vue +204 -204
  79. package/src/components/CPagination/index.js +2 -2
  80. package/src/components/CPhoneNumber/CPhoneNumber.vue +89 -89
  81. package/src/components/CPhoneNumber/index.js +2 -2
  82. package/src/components/CRadio/CRadio.vue +106 -106
  83. package/src/components/CRadio/index.js +2 -2
  84. package/src/components/CRangeSlider/CRangeSlider.vue +55 -55
  85. package/src/components/CRangeSlider/index.js +2 -2
  86. package/src/components/CReorderableStackedList/CReorderableStackedList.vue +94 -94
  87. package/src/components/CReorderableStackedList/index.js +2 -2
  88. package/src/components/CSelect/CSelect.vue +353 -353
  89. package/src/components/CSelect/index.js +2 -2
  90. package/src/components/CSmallTimeline/CSmallTimeline.vue +40 -40
  91. package/src/components/CSmallTimeline/index.js +2 -2
  92. package/src/components/CStackedList/CStackedList.vue +132 -132
  93. package/src/components/CStackedList/index.js +2 -2
  94. package/src/components/CStats/CStats.vue +116 -116
  95. package/src/components/CStats/index.js +2 -2
  96. package/src/components/CSwitch/CSwitch.vue +168 -168
  97. package/src/components/CSwitch/index.js +2 -2
  98. package/src/components/CTable/CTable.vue +542 -538
  99. package/src/components/CTable/index.js +2 -2
  100. package/src/components/CTabs/CTabs.vue +111 -111
  101. package/src/components/CTabs/index.js +2 -2
  102. package/src/components/CTag/CTag.vue +36 -36
  103. package/src/components/CTag/index.js +2 -2
  104. package/src/components/CTextarea/CTextarea.vue +95 -95
  105. package/src/components/CTextarea/index.js +2 -2
  106. package/src/components/CTimeline/CTimeline.vue +237 -237
  107. package/src/components/CTimeline/index.js +2 -2
  108. package/src/components/CUpload/CUpload.vue +231 -231
  109. package/src/components/CUpload/index.js +2 -2
  110. package/src/components/index.js +48 -48
  111. package/src/icons.js +304 -304
  112. package/src/main.js +22 -22
  113. package/src/stories/CAlerts.stories.js +37 -37
  114. package/src/stories/CAnchorTabs.stories.js +29 -29
  115. package/src/stories/CAnchorTag.stories.js +36 -36
  116. package/src/stories/CAvatar.stories.js +38 -38
  117. package/src/stories/CAvatarGroup.stories.js +100 -100
  118. package/src/stories/CBasicTable.stories.js +316 -316
  119. package/src/stories/CBreadcrumbs.stories.js +24 -24
  120. package/src/stories/CButton.stories.js +46 -46
  121. package/src/stories/CButtonGroup.stories.js +33 -33
  122. package/src/stories/CButtonIcon.stories.js +27 -27
  123. package/src/stories/CButtonLink.stories.js +24 -24
  124. package/src/stories/CButtonSelect.stories.js +32 -32
  125. package/src/stories/CButtonWithDropdown.stories.js +41 -41
  126. package/src/stories/CCalendar.stories.js +16 -16
  127. package/src/stories/CCard.stories.js +30 -30
  128. package/src/stories/CCheckbox.stories.js +29 -29
  129. package/src/stories/CCollapsibleSection.stories.js +28 -28
  130. package/src/stories/CColorDots.stories.js +28 -28
  131. package/src/stories/CConfirmActionModal.stories.js +59 -59
  132. package/src/stories/CDatepicker.stories.js +30 -30
  133. package/src/stories/CDualSelect.stories.js +29 -29
  134. package/src/stories/CEditor.stories.js +30 -30
  135. package/src/stories/CFormSectionHeading.stories.js +34 -34
  136. package/src/stories/CGroupedSelect.stories.js +69 -69
  137. package/src/stories/CIcon.stories.js +26 -26
  138. package/src/stories/CIconDropdown.stories.js +45 -45
  139. package/src/stories/CInput.stories.js +36 -36
  140. package/src/stories/CInputAddon.stories.js +37 -37
  141. package/src/stories/CInputEmail.stories.js +27 -27
  142. package/src/stories/CModalHeading.stories.js +25 -25
  143. package/src/stories/CModuleHelpLinks.stories.js +25 -25
  144. package/src/stories/CMultiselect.stories.js +103 -103
  145. package/src/stories/CMultiselectr.stories.js +23 -23
  146. package/src/stories/CPageHeading.stories.js +32 -32
  147. package/src/stories/CPagination.stories.js +30 -30
  148. package/src/stories/CPhoneNumber.stories.js +29 -29
  149. package/src/stories/CRadio.stories.js +36 -36
  150. package/src/stories/CRangeSlider.stories.js +23 -23
  151. package/src/stories/CReorderableStackedList.stories.js +23 -23
  152. package/src/stories/CSelect.stories.js +62 -62
  153. package/src/stories/CSmallTimeline.stories.js +26 -26
  154. package/src/stories/CStackedList.stories.js +37 -37
  155. package/src/stories/CStats.stories.js +33 -33
  156. package/src/stories/CSwitch.stories.js +28 -28
  157. package/src/stories/CTable.stories.js +77 -77
  158. package/src/stories/CTabs.stories.js +33 -33
  159. package/src/stories/CTag.stories.js +23 -23
  160. package/src/stories/CTextarea.stories.js +32 -32
  161. package/src/stories/CTimeline.stories.js +26 -26
  162. package/src/stories/CUpload.stories.js +36 -36
  163. package/src/stories/Introduction.stories.mdx +207 -207
  164. package/src/stories/Page.vue +88 -88
  165. package/src/stories/assets/code-brackets.svg +0 -0
  166. package/src/stories/assets/colors.svg +0 -0
  167. package/src/stories/assets/comments.svg +0 -0
  168. package/src/stories/assets/direction.svg +0 -0
  169. package/src/stories/assets/flow.svg +0 -0
  170. package/src/stories/assets/plugin.svg +0 -0
  171. package/src/stories/assets/repo.svg +0 -0
  172. package/src/stories/assets/stackalt.svg +0 -0
  173. package/src/stories/header.css +26 -26
  174. package/src/stories/page.css +69 -69
  175. package/src/stories/utils.css +17 -17
@@ -1,112 +1,112 @@
1
- <template>
2
- <div>
3
- <slot></slot>
4
- <button
5
- v-if="type == 'tertiary'"
6
- class="flex cursor-pointer flex-row rounded-md px-2 py-2 text-sm text-indigo-600 hover:bg-indigo-100 hover:text-indigo-800 focus:outline-none focus:ring-2 focus:ring-indigo-200 focus:ring-offset-2"
7
- @click.prevent="$emit('action')"
8
- >
9
- <c-icon
10
- cursorType="cursor-pointer"
11
- v-if="icon"
12
- :type="icon.type"
13
- :class="icon.class"
14
- :name="icon.name"
15
- ></c-icon>
16
- <slot></slot>
17
- </button>
18
- <button
19
- v-else-if="type == 'rounded-hover'"
20
- @click.prevent="$emit('action')"
21
- class="flex h-8 w-8 cursor-pointer items-center justify-center rounded-full bg-white text-gray-500 hover:bg-gray-100 hover:text-gray-500 focus:outline-none focus:ring-2 focus:ring-indigo-500"
22
- >
23
- <c-icon
24
- v-if="icon"
25
- cursorType="cursor-pointer"
26
- :type="icon.type"
27
- :class="icon.class"
28
- :name="icon.name"
29
- ></c-icon>
30
- </button>
31
- <button
32
- v-else
33
- :type="type"
34
- :class="classes"
35
- class="inline-flex items-center rounded-md px-2 py-2 text-sm font-medium shadow-sm focus:outline-none focus:ring-2 focus:ring-offset-2"
36
- @click.prevent="$emit('action')"
37
- >
38
- <c-icon
39
- v-if="isLoading"
40
- cursorType="cursor-pointer"
41
- class="mr-2 h-5 w-5"
42
- :class="loaderClasses"
43
- name="loader"
44
- ></c-icon>
45
- <c-icon
46
- v-if="icon"
47
- :type="icon.type"
48
- :class="icon.class"
49
- :name="icon.name"
50
- :viewBox="icon.viewBox"
51
- cursorType="cursor-pointer"
52
- ></c-icon>
53
- <slot></slot>
54
- </button>
55
- </div>
56
- </template>
57
-
58
- <script>
59
- import CIcon from "../CIcon/CIcon.vue";
60
- export default {
61
- name: "CButtonIcon",
62
- components: { CIcon },
63
- props: {
64
- icon: {
65
- type: Object,
66
- },
67
- type: {
68
- type: String,
69
- default: "primary",
70
- required: true,
71
- },
72
- isLoading: {
73
- type: Boolean,
74
- default: false,
75
- },
76
- action: {
77
- type: Function,
78
- },
79
- loaderClasses: {
80
- type: String,
81
- },
82
- },
83
-
84
- computed: {
85
- classes() {
86
- return {
87
- "border border-gray-200 bg-white text-gray-700 hover:bg-gray-50 focus:ring-indigo-600":
88
- this.type == "white",
89
- "text-indigo-700 bg-indigo-100 hover:bg-indigo-200 focus:ring-indigo-500":
90
- this.type == "secondary",
91
- "border text-white hover:bg-indigo-800 bg-indigo-700 focus:ring-indigo-600":
92
- this.type == "primary",
93
- "border text-white hover:bg-red-800 bg-red-700 focus:ring-red-600":
94
- this.type == "danger",
95
- "border text-white hover:bg-green-800 bg-green-700 focus:ring-green-600":
96
- this.type == "success",
97
- "text-gray-900 hover:bg-gray-200 bg-gray-100":
98
- this.type == "secondary-gray",
99
- "cursor-default pointer-events-none": this.isLoading,
100
- };
101
- },
102
- },
103
-
104
- methods: {
105
- onClick() {
106
- this.$emit("onClick");
107
- },
108
- },
109
- };
110
- </script>
111
-
112
- <style></style>
1
+ <template>
2
+ <div>
3
+ <slot></slot>
4
+ <button
5
+ v-if="type == 'tertiary'"
6
+ class="flex cursor-pointer flex-row rounded-md px-2 py-2 text-sm text-indigo-600 hover:bg-indigo-100 hover:text-indigo-800 focus:outline-none focus:ring-2 focus:ring-indigo-200 focus:ring-offset-2"
7
+ @click.prevent="$emit('action')"
8
+ >
9
+ <c-icon
10
+ cursorType="cursor-pointer"
11
+ v-if="icon"
12
+ :type="icon.type"
13
+ :class="icon.class"
14
+ :name="icon.name"
15
+ ></c-icon>
16
+ <slot></slot>
17
+ </button>
18
+ <button
19
+ v-else-if="type == 'rounded-hover'"
20
+ @click.prevent="$emit('action')"
21
+ class="flex h-8 w-8 cursor-pointer items-center justify-center rounded-full bg-white text-gray-500 hover:bg-gray-100 hover:text-gray-500 focus:outline-none focus:ring-2 focus:ring-indigo-500"
22
+ >
23
+ <c-icon
24
+ v-if="icon"
25
+ cursorType="cursor-pointer"
26
+ :type="icon.type"
27
+ :class="icon.class"
28
+ :name="icon.name"
29
+ ></c-icon>
30
+ </button>
31
+ <button
32
+ v-else
33
+ :type="type"
34
+ :class="classes"
35
+ class="inline-flex items-center rounded-md px-2 py-2 text-sm font-medium shadow-sm focus:outline-none focus:ring-2 focus:ring-offset-2"
36
+ @click.prevent="$emit('action')"
37
+ >
38
+ <c-icon
39
+ v-if="isLoading"
40
+ cursorType="cursor-pointer"
41
+ class="mr-2 h-5 w-5"
42
+ :class="loaderClasses"
43
+ name="loader"
44
+ ></c-icon>
45
+ <c-icon
46
+ v-if="icon"
47
+ :type="icon.type"
48
+ :class="icon.class"
49
+ :name="icon.name"
50
+ :viewBox="icon.viewBox"
51
+ cursorType="cursor-pointer"
52
+ ></c-icon>
53
+ <slot></slot>
54
+ </button>
55
+ </div>
56
+ </template>
57
+
58
+ <script>
59
+ import CIcon from "../CIcon/CIcon.vue";
60
+ export default {
61
+ name: "CButtonIcon",
62
+ components: { CIcon },
63
+ props: {
64
+ icon: {
65
+ type: Object,
66
+ },
67
+ type: {
68
+ type: String,
69
+ default: "primary",
70
+ required: true,
71
+ },
72
+ isLoading: {
73
+ type: Boolean,
74
+ default: false,
75
+ },
76
+ action: {
77
+ type: Function,
78
+ },
79
+ loaderClasses: {
80
+ type: String,
81
+ },
82
+ },
83
+
84
+ computed: {
85
+ classes() {
86
+ return {
87
+ "border border-gray-200 bg-white text-gray-700 hover:bg-gray-50 focus:ring-indigo-600":
88
+ this.type == "white",
89
+ "text-indigo-700 bg-indigo-100 hover:bg-indigo-200 focus:ring-indigo-500":
90
+ this.type == "secondary",
91
+ "border text-white hover:bg-indigo-800 bg-indigo-700 focus:ring-indigo-600":
92
+ this.type == "primary",
93
+ "border text-white hover:bg-red-800 bg-red-700 focus:ring-red-600":
94
+ this.type == "danger",
95
+ "border text-white hover:bg-green-800 bg-green-700 focus:ring-green-600":
96
+ this.type == "success",
97
+ "text-gray-900 hover:bg-gray-200 bg-gray-100":
98
+ this.type == "secondary-gray",
99
+ "cursor-default pointer-events-none": this.isLoading,
100
+ };
101
+ },
102
+ },
103
+
104
+ methods: {
105
+ onClick() {
106
+ this.$emit("onClick");
107
+ },
108
+ },
109
+ };
110
+ </script>
111
+
112
+ <style></style>
@@ -1,3 +1,3 @@
1
- import CButtonIcon from './CButtonIcon.vue'
2
-
1
+ import CButtonIcon from './CButtonIcon.vue'
2
+
3
3
  export default CButtonIcon
@@ -1,39 +1,39 @@
1
- <template>
2
- <span class="relative z-0 inline-flex w-full rounded-md shadow-sm">
3
- <button
4
- v-if="image"
5
- type="button"
6
- class="focus:outline-none relative -ml-px inline-flex items-center rounded-l-md border border-gray-300 bg-white text-sm font-medium text-gray-700 hover:bg-gray-50 focus:z-10 focus:border-indigo-500 focus:ring-1 focus:ring-indigo-500"
7
- >
8
- <img class="h-10 w-10" :src="image" />
9
- </button>
10
- <button
11
- type="button"
12
- class="focus:outline-none relative inline-flex w-full items-center justify-between rounded-r-md border border-gray-300 bg-white py-2 pl-4 pr-1 text-sm font-medium text-gray-700 hover:bg-gray-50 focus:z-10 focus:border-indigo-500 focus:ring-1 focus:ring-indigo-500"
13
- :class="image ? 'rounded-r-md' : 'rounded-md'"
14
- @click="$emit('action')"
15
- >
16
- {{ label }}
17
- <c-icon type="solid" name="chevron-right" class="h-5 w-5"></c-icon>
18
- </button>
19
- </span>
20
- </template>
21
- <script>
22
- import CIcon from "../CIcon/CIcon.vue";
23
- export default {
24
- name: "CButtonLink",
25
- components: { CIcon },
26
- props: {
27
- label: {
28
- type: String,
29
- },
30
- image: {
31
- type: String,
32
- default: null,
33
- },
34
- action: {
35
- type: Function,
36
- },
37
- },
38
- };
39
- </script>
1
+ <template>
2
+ <span class="relative z-0 inline-flex w-full rounded-md shadow-sm">
3
+ <button
4
+ v-if="image"
5
+ type="button"
6
+ class="focus:outline-none relative -ml-px inline-flex items-center rounded-l-md border border-gray-300 bg-white text-sm font-medium text-gray-700 hover:bg-gray-50 focus:z-10 focus:border-indigo-500 focus:ring-1 focus:ring-indigo-500"
7
+ >
8
+ <img class="h-10 w-10" :src="image" />
9
+ </button>
10
+ <button
11
+ type="button"
12
+ class="focus:outline-none relative inline-flex w-full items-center justify-between rounded-r-md border border-gray-300 bg-white py-2 pl-4 pr-1 text-sm font-medium text-gray-700 hover:bg-gray-50 focus:z-10 focus:border-indigo-500 focus:ring-1 focus:ring-indigo-500"
13
+ :class="image ? 'rounded-r-md' : 'rounded-md'"
14
+ @click="$emit('action')"
15
+ >
16
+ {{ label }}
17
+ <c-icon type="solid" name="chevron-right" class="h-5 w-5"></c-icon>
18
+ </button>
19
+ </span>
20
+ </template>
21
+ <script>
22
+ import CIcon from "../CIcon/CIcon.vue";
23
+ export default {
24
+ name: "CButtonLink",
25
+ components: { CIcon },
26
+ props: {
27
+ label: {
28
+ type: String,
29
+ },
30
+ image: {
31
+ type: String,
32
+ default: null,
33
+ },
34
+ action: {
35
+ type: Function,
36
+ },
37
+ },
38
+ };
39
+ </script>
@@ -1,3 +1,3 @@
1
- import CButtonLink from './CButtonLink.vue'
2
-
1
+ import CButtonLink from './CButtonLink.vue'
2
+
3
3
  export default CButtonLink
@@ -1,103 +1,103 @@
1
- <template>
2
- <div>
3
- <slot></slot>
4
- <div class="relative inline-block text-left">
5
- <button
6
- :type="type"
7
- @click="toggleDropdown = !toggleDropdown"
8
- @blur="close()"
9
- :class="classes"
10
- class="inline-flex justify-center w-full rounded-md border border-transparent shadow-sm px-4 py-2 text-sm font-medium focus:outline-none"
11
- aria-haspopup="listbox"
12
- aria-expanded="true"
13
- aria-labelledby="listbox-label"
14
- >
15
- <c-icon v-if="isLoading" class="mr-2 h-5 w-5" name="loader"></c-icon>
16
- {{ label }}
17
- <c-icon name="chevron-down" type="solid" class="ml-2 h-5 w-5"></c-icon>
18
- </button>
19
-
20
- <div
21
- v-if="toggleDropdown"
22
- :class="dropdownPositionClass"
23
- class="z-10 absolute mt-2 -mr-1 w-56 rounded-md shadow-lg bg-white ring-1 ring-gray-900 ring-opacity-5"
24
- >
25
- <ul class="py-1" tabindex="-1" role="listbox" aria-labelledby="listbox-label">
26
- <li
27
- v-for="(item) in items"
28
- :key="item.text"
29
- class="flex px-4 py-2 text-sm text-gray-700 hover:bg-gray-100 hover:text-gray-900 cursor-pointer"
30
- @mousedown="emitOptionAction(item.action)"
31
- >
32
- <c-icon
33
- v-if="item.icon"
34
- :type="item.iconType"
35
- class="mr-2 h-5 w-5 text-gray-500"
36
- :name="item.icon"
37
- ></c-icon>
38
- <slot name="customIcon" v-if="item.customIcon"></slot>
39
- {{ item.text }}
40
- </li>
41
- </ul>
42
- </div>
43
- </div>
44
- </div>
45
- </template>
46
-
47
- <script>
48
- import CIcon from "../CIcon/CIcon.vue";
49
- export default {
50
- name: "CButtonSelect",
51
- components: { CIcon },
52
- props: {
53
- label: {
54
- type: String,
55
- required: true,
56
- },
57
- type: {
58
- type: String,
59
- default: "primary",
60
- },
61
- items: {
62
- type: Array,
63
- required: true,
64
- },
65
- isLoading: {
66
- type: Boolean,
67
- default: false,
68
- },
69
- dropdownPositionClass: {
70
- type: String,
71
- },
72
- },
73
- data() {
74
- return {
75
- toggleDropdown: false,
76
- };
77
- },
78
-
79
- computed: {
80
- classes() {
81
- return {
82
- "text-gray-700 border-gray-300 hover:bg-gray-50 focus:ring-indigo-600":
83
- this.type == "secondary",
84
- "text-white hover:bg-indigo-800 bg-indigo-700 focus:ring-indigo-600":
85
- this.type == "primary",
86
- "text-white hover:bg-red-800 bg-red-700 focus:ring-red-600": this.type == "danger",
87
- "text-white hover:bg-green-800 bg-green-700 focus:ring-green-600": this.type == "success",
88
- "cursor-default pointer-events-none": this.isLoading,
89
- };
90
- },
91
- },
92
- methods: {
93
- emitOptionAction(action) {
94
- this.$emit("buttonActions", action);
95
- },
96
- close() {
97
- this.toggleDropdown = false;
98
- },
99
- },
100
- };
101
- </script>
102
-
103
- <style></style>
1
+ <template>
2
+ <div>
3
+ <slot></slot>
4
+ <div class="relative inline-block text-left">
5
+ <button
6
+ :type="type"
7
+ @click="toggleDropdown = !toggleDropdown"
8
+ @blur="close()"
9
+ :class="classes"
10
+ class="inline-flex justify-center w-full rounded-md border border-transparent shadow-sm px-4 py-2 text-sm font-medium focus:outline-none"
11
+ aria-haspopup="listbox"
12
+ aria-expanded="true"
13
+ aria-labelledby="listbox-label"
14
+ >
15
+ <c-icon v-if="isLoading" class="mr-2 h-5 w-5" name="loader"></c-icon>
16
+ {{ label }}
17
+ <c-icon name="chevron-down" type="solid" class="ml-2 h-5 w-5"></c-icon>
18
+ </button>
19
+
20
+ <div
21
+ v-if="toggleDropdown"
22
+ :class="dropdownPositionClass"
23
+ class="z-10 absolute mt-2 -mr-1 w-56 rounded-md shadow-lg bg-white ring-1 ring-gray-900 ring-opacity-5"
24
+ >
25
+ <ul class="py-1" tabindex="-1" role="listbox" aria-labelledby="listbox-label">
26
+ <li
27
+ v-for="(item) in items"
28
+ :key="item.text"
29
+ class="flex px-4 py-2 text-sm text-gray-700 hover:bg-gray-100 hover:text-gray-900 cursor-pointer"
30
+ @mousedown="emitOptionAction(item.action)"
31
+ >
32
+ <c-icon
33
+ v-if="item.icon"
34
+ :type="item.iconType"
35
+ class="mr-2 h-5 w-5 text-gray-500"
36
+ :name="item.icon"
37
+ ></c-icon>
38
+ <slot name="customIcon" v-if="item.customIcon"></slot>
39
+ {{ item.text }}
40
+ </li>
41
+ </ul>
42
+ </div>
43
+ </div>
44
+ </div>
45
+ </template>
46
+
47
+ <script>
48
+ import CIcon from "../CIcon/CIcon.vue";
49
+ export default {
50
+ name: "CButtonSelect",
51
+ components: { CIcon },
52
+ props: {
53
+ label: {
54
+ type: String,
55
+ required: true,
56
+ },
57
+ type: {
58
+ type: String,
59
+ default: "primary",
60
+ },
61
+ items: {
62
+ type: Array,
63
+ required: true,
64
+ },
65
+ isLoading: {
66
+ type: Boolean,
67
+ default: false,
68
+ },
69
+ dropdownPositionClass: {
70
+ type: String,
71
+ },
72
+ },
73
+ data() {
74
+ return {
75
+ toggleDropdown: false,
76
+ };
77
+ },
78
+
79
+ computed: {
80
+ classes() {
81
+ return {
82
+ "text-gray-700 border-gray-300 hover:bg-gray-50 focus:ring-indigo-600":
83
+ this.type == "secondary",
84
+ "text-white hover:bg-indigo-800 bg-indigo-700 focus:ring-indigo-600":
85
+ this.type == "primary",
86
+ "text-white hover:bg-red-800 bg-red-700 focus:ring-red-600": this.type == "danger",
87
+ "text-white hover:bg-green-800 bg-green-700 focus:ring-green-600": this.type == "success",
88
+ "cursor-default pointer-events-none": this.isLoading,
89
+ };
90
+ },
91
+ },
92
+ methods: {
93
+ emitOptionAction(action) {
94
+ this.$emit("buttonActions", action);
95
+ },
96
+ close() {
97
+ this.toggleDropdown = false;
98
+ },
99
+ },
100
+ };
101
+ </script>
102
+
103
+ <style></style>
@@ -1,3 +1,3 @@
1
- import CButtonSelect from './CButtonSelect.vue'
2
-
1
+ import CButtonSelect from './CButtonSelect.vue'
2
+
3
3
  export default CButtonSelect