@phill-component/icons 1.10.3 → 1.10.6

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 (69) hide show
  1. package/dist/mobile/uvue/icon-attachment/attachment.png +0 -0
  2. package/dist/mobile/uvue/{icon-edit/icon-edit.uvue → icon-attachment/icon-attachment.uvue} +2 -2
  3. package/dist/mobile/uvue/icon-brush/brush.png +0 -0
  4. package/dist/mobile/vue/{icon-filter.vue → icon-attachment.vue} +2 -2
  5. package/dist/web/vue/{Copy.vue → Attachment.vue} +1 -1
  6. package/dist/web/vue/index.js +2 -16
  7. package/package.json +23 -21
  8. package/scripts/build.js +1 -1
  9. package/dist/mobile/uvue/icon-calendar/calendar.png +0 -0
  10. package/dist/mobile/uvue/icon-calendar/icon-calendar.uvue +0 -75
  11. package/dist/mobile/uvue/icon-copy/copy.png +0 -0
  12. package/dist/mobile/uvue/icon-copy/icon-copy.uvue +0 -75
  13. package/dist/mobile/uvue/icon-edit/edit.png +0 -0
  14. package/dist/mobile/uvue/icon-file-fold/file_fold.png +0 -0
  15. package/dist/mobile/uvue/icon-file-fold/icon-file-fold.uvue +0 -75
  16. package/dist/mobile/uvue/icon-filter/filter.png +0 -0
  17. package/dist/mobile/uvue/icon-filter/icon-filter.uvue +0 -75
  18. package/dist/mobile/uvue/icon-find-replace/find-replace.png +0 -0
  19. package/dist/mobile/uvue/icon-find-replace/icon-find-replace.uvue +0 -75
  20. package/dist/mobile/uvue/icon-h6/h6.png +0 -0
  21. package/dist/mobile/uvue/icon-h6/icon-h6.uvue +0 -75
  22. package/dist/mobile/uvue/icon-highlight/highlight.png +0 -0
  23. package/dist/mobile/uvue/icon-highlight/icon-highlight.uvue +0 -75
  24. package/dist/mobile/uvue/icon-home/home.png +0 -0
  25. package/dist/mobile/uvue/icon-home/icon-home.uvue +0 -75
  26. package/dist/mobile/uvue/icon-oblique-line/icon-oblique-line.uvue +0 -75
  27. package/dist/mobile/uvue/icon-oblique-line/oblique-line.png +0 -0
  28. package/dist/mobile/uvue/icon-original-size/icon-original-size.uvue +0 -75
  29. package/dist/mobile/uvue/icon-original-size/original-size.png +0 -0
  30. package/dist/mobile/uvue/icon-setting/icon-setting.uvue +0 -75
  31. package/dist/mobile/uvue/icon-setting/setting.png +0 -0
  32. package/dist/mobile/uvue/icon-task/icon-task.uvue +0 -75
  33. package/dist/mobile/uvue/icon-task/task.png +0 -0
  34. package/dist/mobile/uvue/icon-to-landscape/icon-to-landscape.uvue +0 -75
  35. package/dist/mobile/uvue/icon-to-landscape/to_landscape.png +0 -0
  36. package/dist/mobile/uvue/icon-zoom-in/icon-zoom-in.uvue +0 -75
  37. package/dist/mobile/uvue/icon-zoom-in/zoom-in.png +0 -0
  38. package/dist/mobile/vue/icon-calendar.vue +0 -58
  39. package/dist/mobile/vue/icon-copy.vue +0 -58
  40. package/dist/mobile/vue/icon-edit.vue +0 -58
  41. package/dist/mobile/vue/icon-file-fold.vue +0 -58
  42. package/dist/mobile/vue/icon-find-replace.vue +0 -58
  43. package/dist/mobile/vue/icon-h6.vue +0 -58
  44. package/dist/mobile/vue/icon-highlight.vue +0 -58
  45. package/dist/mobile/vue/icon-home.vue +0 -58
  46. package/dist/mobile/vue/icon-oblique-line.vue +0 -58
  47. package/dist/mobile/vue/icon-original-size.vue +0 -58
  48. package/dist/mobile/vue/icon-setting.vue +0 -58
  49. package/dist/mobile/vue/icon-task.vue +0 -58
  50. package/dist/mobile/vue/icon-to-landscape.vue +0 -58
  51. package/dist/mobile/vue/icon-zoom-in.vue +0 -58
  52. package/dist/web/vue/Calendar.vue +0 -53
  53. package/dist/web/vue/Edit.vue +0 -53
  54. package/dist/web/vue/FileFold.vue +0 -53
  55. package/dist/web/vue/Filter.vue +0 -53
  56. package/dist/web/vue/FindReplace.vue +0 -53
  57. package/dist/web/vue/H6.vue +0 -53
  58. package/dist/web/vue/Highlight.vue +0 -53
  59. package/dist/web/vue/Home.vue +0 -53
  60. package/dist/web/vue/ObliqueLine.vue +0 -53
  61. package/dist/web/vue/OriginalSize.vue +0 -53
  62. package/dist/web/vue/Setting.vue +0 -53
  63. package/dist/web/vue/Task.vue +0 -53
  64. package/dist/web/vue/ToLandscape.vue +0 -53
  65. package/dist/web/vue/ZoomIn.vue +0 -53
  66. package/scripts/fetch.js +0 -47
  67. package/scripts/jenkins-server.js +0 -198
  68. package/scripts/publish.js +0 -155
  69. package/scripts/sync.js +0 -201
@@ -1,58 +0,0 @@
1
- <template>
2
- <view class="icon" @tap="onTap" :hover-class="hoverClass" :style="[wrapStyle, iconStyle]">
3
- <!-- #ifdef H5 -->
4
- <svg v-bind="$attrs" :style="iconStyle" :width="iconW" :height="iconH" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24"><path fill="currentColor" fill-rule="evenodd" d="M12 8a4 4 0 1 1 0 8.001 4 4 0 0 1 0-8m0 2a2 2 0 1 0 0 4 2 2 0 0 0 0-4" clip-rule="evenodd"/><path fill="currentColor" fill-rule="evenodd" d="M10.539 2.634a2 2 0 0 1 2.922 0l1.675 1.793 2.453-.083a2 2 0 0 1 2.066 2.067l-.082 2.453 1.792 1.675a2 2 0 0 1 0 2.922l-1.792 1.675.082 2.452a2 2 0 0 1-2.067 2.067l-2.452-.082-1.675 1.792a2 2 0 0 1-2.922 0l-1.675-1.792-2.453.082a2 2 0 0 1-2.067-2.066l.083-2.453-1.793-1.675a2 2 0 0 1 0-2.922l1.793-1.675-.083-2.453a2 2 0 0 1 2.067-2.067l2.453.083zm-.214 3.158a2 2 0 0 1-1.53.634l-2.452-.083.083 2.452a2 2 0 0 1-.634 1.53L4 12l1.792 1.675a2 2 0 0 1 .634 1.53l-.083 2.453 2.452-.084a2 2 0 0 1 1.53.633L12 20l1.675-1.793a2 2 0 0 1 1.53-.633l2.453.084-.084-2.454a2 2 0 0 1 .633-1.529L20 12l-1.793-1.675a2 2 0 0 1-.633-1.53l.084-2.452-2.454.083a2 2 0 0 1-1.529-.634L12 4z" clip-rule="evenodd"/></svg>
5
- <!-- #endif -->
6
- <!-- #ifndef H5 -->
7
- <image :src="imgSrc" :style="iconBoxStyle" />
8
- <!-- #endif -->
9
- <text v-if="label !== ''" class="icon__label" :style="labelStyle">{{ label }}</text>
10
- </view>
11
- </template>
12
- <script setup>
13
- import { computed } from 'vue'
14
- import imgSrc from '@/uni_modules/@phill-component/icons/mobile/uvue/icon-setting/setting.png'
15
- const props = defineProps({
16
- size: { type: [String, Number], default: '1em' },
17
- color: { type: String, default: 'var(--tsm-color-primary)' },
18
- label: { type: [String, Number], default: '' },
19
- labelPos: { type: String, default: 'right' },
20
- labelSize: { type: [String, Number], default: '15px' },
21
- labelColor: { type: String, default: '' },
22
- space: { type: [String, Number], default: '3px' },
23
- width: { type: [String, Number], default: '' },
24
- height: { type: [String, Number], default: '' },
25
- hoverClass: { type: String, default: '' },
26
- index: { type: [String, Number], default: '' },
27
- stop: { type: Boolean, default: false }
28
- })
29
- const emit = defineEmits(['click'])
30
- const toPx = (v) => typeof v === 'number' ? (v + 'px') : (String(v||''));
31
- const iconW = computed(() => props.width ? toPx(props.width) : toPx(props.size))
32
- const iconH = computed(() => props.height ? toPx(props.height) : toPx(props.size))
33
- const iconBoxStyle = computed(() => ({ width: iconW.value, height: iconH.value }))
34
- const iconStyle = computed(() => {
35
- return { color: props.color || 'inherit' }
36
- })
37
- const wrapStyle = computed(() => {
38
- const dirMap = { right: 'row', left: 'row-reverse', top: 'column-reverse', bottom: 'column' }
39
- return { display: 'flex', alignItems: 'center', flexDirection: dirMap[props.labelPos] || 'row' }
40
- })
41
- const labelStyle = computed(() => {
42
- return {
43
- color: props.labelColor || '',
44
- fontSize: toPx(props.labelSize),
45
- marginLeft: props.labelPos === 'right' ? toPx(props.space) : 0,
46
- marginTop: props.labelPos === 'bottom' ? toPx(props.space) : 0,
47
- marginRight: props.labelPos === 'left' ? toPx(props.space) : 0,
48
- marginBottom: props.labelPos === 'top' ? toPx(props.space) : 0
49
- }
50
- })
51
- function onTap(e) {
52
- emit('click', props.index)
53
- if (props.stop && e && e.stopPropagation) e.stopPropagation()
54
- }
55
- </script>
56
- <style scoped>
57
- .icon__label { line-height: 1; }
58
- </style>
@@ -1,58 +0,0 @@
1
- <template>
2
- <view class="icon" @tap="onTap" :hover-class="hoverClass" :style="[wrapStyle, iconStyle]">
3
- <!-- #ifdef H5 -->
4
- <svg v-bind="$attrs" :style="iconStyle" :width="iconW" :height="iconH" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24"><path fill="currentColor" d="M18.059 12.905a2 2 0 0 1 1.6 3.199h.001c-.01.014-.544.747-.595 1.514l-.003 1.258 1.712.383a1.645 1.645 0 0 1 1.287 1.605v.65a.275.275 0 0 1-.274.275h-7.45a.275.275 0 0 1-.274-.274v-.653c0-.77.534-1.437 1.285-1.605l1.714-.386.003-1.14h-.004a2.6 2.6 0 0 0-.5-1.501 2.001 2.001 0 0 1 1.498-3.324"/><path fill="currentColor" d="M6.96 3.387c0-.598.431-1.082.962-1.082h5.77c.53 0 .96.484.96 1.082 0 .597-.43 1.082-.96 1.082h-5.77c-.53 0-.961-.485-.961-1.082"/><path fill="currentColor" d="M6.157 3.062q-.019.132-.02.27c0 1.046.824 1.895 1.842 1.895h5.524c1.017 0 1.842-.849 1.842-1.895a2 2 0 0 0-.02-.27h1.222c1.205 0 2.182.976 2.183 2.181v6.197a3.363 3.363 0 0 0-3.235 5.47c.11.163.272.473.272.849v.24l-.87.195a2.99 2.99 0 0 0-2.332 2.724H4.932a2.18 2.18 0 0 1-2.182-2.182V5.243c0-1.205.977-2.181 2.182-2.181z"/><path fill="currentColor" d="M6.95 3.332c0-.598.424-1.082.947-1.082h5.688c.523 0 .948.484.948 1.082s-.425 1.082-.948 1.082H7.897c-.523 0-.948-.484-.948-1.082"/><path fill="currentColor" fill-rule="evenodd" d="M14.604 8.9a.77.77 0 0 1 .169 1.11l-3.103 3.975c-1.133 1.468-2.234 1.071-3.128.217l-1.487-1.42a.77.77 0 0 1 0-1.12.857.857 0 0 1 1.173 0l1.487 1.42c.178.17.474.15.625-.044l3.103-3.976a.855.855 0 0 1 1.16-.162" clip-rule="evenodd"/></svg>
5
- <!-- #endif -->
6
- <!-- #ifndef H5 -->
7
- <image :src="imgSrc" :style="iconBoxStyle" />
8
- <!-- #endif -->
9
- <text v-if="label !== ''" class="icon__label" :style="labelStyle">{{ label }}</text>
10
- </view>
11
- </template>
12
- <script setup>
13
- import { computed } from 'vue'
14
- import imgSrc from '@/uni_modules/@phill-component/icons/mobile/uvue/icon-task/task.png'
15
- const props = defineProps({
16
- size: { type: [String, Number], default: '1em' },
17
- color: { type: String, default: 'var(--tsm-color-primary)' },
18
- label: { type: [String, Number], default: '' },
19
- labelPos: { type: String, default: 'right' },
20
- labelSize: { type: [String, Number], default: '15px' },
21
- labelColor: { type: String, default: '' },
22
- space: { type: [String, Number], default: '3px' },
23
- width: { type: [String, Number], default: '' },
24
- height: { type: [String, Number], default: '' },
25
- hoverClass: { type: String, default: '' },
26
- index: { type: [String, Number], default: '' },
27
- stop: { type: Boolean, default: false }
28
- })
29
- const emit = defineEmits(['click'])
30
- const toPx = (v) => typeof v === 'number' ? (v + 'px') : (String(v||''));
31
- const iconW = computed(() => props.width ? toPx(props.width) : toPx(props.size))
32
- const iconH = computed(() => props.height ? toPx(props.height) : toPx(props.size))
33
- const iconBoxStyle = computed(() => ({ width: iconW.value, height: iconH.value }))
34
- const iconStyle = computed(() => {
35
- return { color: props.color || 'inherit' }
36
- })
37
- const wrapStyle = computed(() => {
38
- const dirMap = { right: 'row', left: 'row-reverse', top: 'column-reverse', bottom: 'column' }
39
- return { display: 'flex', alignItems: 'center', flexDirection: dirMap[props.labelPos] || 'row' }
40
- })
41
- const labelStyle = computed(() => {
42
- return {
43
- color: props.labelColor || '',
44
- fontSize: toPx(props.labelSize),
45
- marginLeft: props.labelPos === 'right' ? toPx(props.space) : 0,
46
- marginTop: props.labelPos === 'bottom' ? toPx(props.space) : 0,
47
- marginRight: props.labelPos === 'left' ? toPx(props.space) : 0,
48
- marginBottom: props.labelPos === 'top' ? toPx(props.space) : 0
49
- }
50
- })
51
- function onTap(e) {
52
- emit('click', props.index)
53
- if (props.stop && e && e.stopPropagation) e.stopPropagation()
54
- }
55
- </script>
56
- <style scoped>
57
- .icon__label { line-height: 1; }
58
- </style>
@@ -1,58 +0,0 @@
1
- <template>
2
- <view class="icon" @tap="onTap" :hover-class="hoverClass" :style="[wrapStyle, iconStyle]">
3
- <!-- #ifdef H5 -->
4
- <svg v-bind="$attrs" :style="iconStyle" :width="iconW" :height="iconH" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24"><path fill="currentColor" d="M20 11a2 2 0 0 1 2 2v7a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2v-7a2 2 0 0 1 2-2zM4 20h16v-7H4zm6-18a2 2 0 0 1 2 2v5a1 1 0 1 1-2 0V4H4v5a1 1 0 0 1-2 0V4a2 2 0 0 1 2-2zm8 0a1 1 0 0 1 1 .998l.006 3.23.954-.953a1 1 0 0 1 1.414 1.415l-2.657 2.657a1 1 0 0 1-1.414 0L14.646 6.69a1.001 1.001 0 0 1 1.415-1.415l.945.946L17.002 4H14.5a1 1 0 1 1 0-2z"/></svg>
5
- <!-- #endif -->
6
- <!-- #ifndef H5 -->
7
- <image :src="imgSrc" :style="iconBoxStyle" />
8
- <!-- #endif -->
9
- <text v-if="label !== ''" class="icon__label" :style="labelStyle">{{ label }}</text>
10
- </view>
11
- </template>
12
- <script setup>
13
- import { computed } from 'vue'
14
- import imgSrc from '@/uni_modules/@phill-component/icons/mobile/uvue/icon-to-landscape/to_landscape.png'
15
- const props = defineProps({
16
- size: { type: [String, Number], default: '1em' },
17
- color: { type: String, default: 'var(--tsm-color-primary)' },
18
- label: { type: [String, Number], default: '' },
19
- labelPos: { type: String, default: 'right' },
20
- labelSize: { type: [String, Number], default: '15px' },
21
- labelColor: { type: String, default: '' },
22
- space: { type: [String, Number], default: '3px' },
23
- width: { type: [String, Number], default: '' },
24
- height: { type: [String, Number], default: '' },
25
- hoverClass: { type: String, default: '' },
26
- index: { type: [String, Number], default: '' },
27
- stop: { type: Boolean, default: false }
28
- })
29
- const emit = defineEmits(['click'])
30
- const toPx = (v) => typeof v === 'number' ? (v + 'px') : (String(v||''));
31
- const iconW = computed(() => props.width ? toPx(props.width) : toPx(props.size))
32
- const iconH = computed(() => props.height ? toPx(props.height) : toPx(props.size))
33
- const iconBoxStyle = computed(() => ({ width: iconW.value, height: iconH.value }))
34
- const iconStyle = computed(() => {
35
- return { color: props.color || 'inherit' }
36
- })
37
- const wrapStyle = computed(() => {
38
- const dirMap = { right: 'row', left: 'row-reverse', top: 'column-reverse', bottom: 'column' }
39
- return { display: 'flex', alignItems: 'center', flexDirection: dirMap[props.labelPos] || 'row' }
40
- })
41
- const labelStyle = computed(() => {
42
- return {
43
- color: props.labelColor || '',
44
- fontSize: toPx(props.labelSize),
45
- marginLeft: props.labelPos === 'right' ? toPx(props.space) : 0,
46
- marginTop: props.labelPos === 'bottom' ? toPx(props.space) : 0,
47
- marginRight: props.labelPos === 'left' ? toPx(props.space) : 0,
48
- marginBottom: props.labelPos === 'top' ? toPx(props.space) : 0
49
- }
50
- })
51
- function onTap(e) {
52
- emit('click', props.index)
53
- if (props.stop && e && e.stopPropagation) e.stopPropagation()
54
- }
55
- </script>
56
- <style scoped>
57
- .icon__label { line-height: 1; }
58
- </style>
@@ -1,58 +0,0 @@
1
- <template>
2
- <view class="icon" @tap="onTap" :hover-class="hoverClass" :style="[wrapStyle, iconStyle]">
3
- <!-- #ifdef H5 -->
4
- <svg v-bind="$attrs" :style="iconStyle" :width="iconW" :height="iconH" fill="none" viewBox="0 0 48 48"><path stroke="currentColor" stroke-width="2" d="M32.607 32.607A14.95 14.95 0 0 0 37 22c0-8.284-6.716-15-15-15S7 13.716 7 22s6.716 15 15 15c4.142 0 7.892-1.679 10.607-4.393zm0 0L41.5 41.5M29 22H15m7 7V15"/></svg>
5
- <!-- #endif -->
6
- <!-- #ifndef H5 -->
7
- <image :src="imgSrc" :style="iconBoxStyle" />
8
- <!-- #endif -->
9
- <text v-if="label !== ''" class="icon__label" :style="labelStyle">{{ label }}</text>
10
- </view>
11
- </template>
12
- <script setup>
13
- import { computed } from 'vue'
14
- import imgSrc from '@/uni_modules/@phill-component/icons/mobile/uvue/icon-zoom-in/zoom-in.png'
15
- const props = defineProps({
16
- size: { type: [String, Number], default: '1em' },
17
- color: { type: String, default: 'var(--tsm-color-primary)' },
18
- label: { type: [String, Number], default: '' },
19
- labelPos: { type: String, default: 'right' },
20
- labelSize: { type: [String, Number], default: '15px' },
21
- labelColor: { type: String, default: '' },
22
- space: { type: [String, Number], default: '3px' },
23
- width: { type: [String, Number], default: '' },
24
- height: { type: [String, Number], default: '' },
25
- hoverClass: { type: String, default: '' },
26
- index: { type: [String, Number], default: '' },
27
- stop: { type: Boolean, default: false }
28
- })
29
- const emit = defineEmits(['click'])
30
- const toPx = (v) => typeof v === 'number' ? (v + 'px') : (String(v||''));
31
- const iconW = computed(() => props.width ? toPx(props.width) : toPx(props.size))
32
- const iconH = computed(() => props.height ? toPx(props.height) : toPx(props.size))
33
- const iconBoxStyle = computed(() => ({ width: iconW.value, height: iconH.value }))
34
- const iconStyle = computed(() => {
35
- return { color: props.color || 'inherit' }
36
- })
37
- const wrapStyle = computed(() => {
38
- const dirMap = { right: 'row', left: 'row-reverse', top: 'column-reverse', bottom: 'column' }
39
- return { display: 'flex', alignItems: 'center', flexDirection: dirMap[props.labelPos] || 'row' }
40
- })
41
- const labelStyle = computed(() => {
42
- return {
43
- color: props.labelColor || '',
44
- fontSize: toPx(props.labelSize),
45
- marginLeft: props.labelPos === 'right' ? toPx(props.space) : 0,
46
- marginTop: props.labelPos === 'bottom' ? toPx(props.space) : 0,
47
- marginRight: props.labelPos === 'left' ? toPx(props.space) : 0,
48
- marginBottom: props.labelPos === 'top' ? toPx(props.space) : 0
49
- }
50
- })
51
- function onTap(e) {
52
- emit('click', props.index)
53
- if (props.stop && e && e.stopPropagation) e.stopPropagation()
54
- }
55
- </script>
56
- <style scoped>
57
- .icon__label { line-height: 1; }
58
- </style>
@@ -1,53 +0,0 @@
1
- <template>
2
- <view class="icon" @tap="onTap" :hover-class="hoverClass" :style="[wrapStyle, iconStyle]">
3
- <svg v-bind="$attrs" :style="iconStyle" :width="iconW" :height="iconH" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24"><path fill="currentColor" d="M6.5 6.25a1.625 1.625 0 0 0 3.25 0V4.125h4.625v2a1.625 1.625 0 1 0 3.25 0v-2H19.5a2 2 0 0 1 2 2v7.166a3.07 3.07 0 0 0-2.088-.818 3.097 3.097 0 0 0-3.092 3.102c0 .76.273 1.455.725 1.994-2.167.837-3.08 2.83-3.068 4.056H4.5a2 2 0 0 1-2-2v-13.5a2 2 0 0 1 2-2h2z"/><path fill="currentColor" d="M7.557 14.718c.394 0 .714.32.714.715v1.228c0 .395-.32.714-.714.714H6.34a.714.714 0 0 1-.715-.714v-1.228c0-.395.32-.715.715-.715zm5.054 0c.395 0 .715.32.715.715v1.228c0 .395-.32.714-.715.714h-1.216a.714.714 0 0 1-.715-.714v-1.228c0-.395.32-.715.715-.715zm-5.054-4.593c.394 0 .714.32.714.715v1.228c0 .395-.32.714-.714.714H6.34a.714.714 0 0 1-.715-.714V10.84c0-.395.32-.715.715-.715zm5.054 0c.395 0 .715.32.715.715v1.228c0 .395-.32.714-.715.714h-1.216a.714.714 0 0 1-.715-.714V10.84c0-.395.32-.715.715-.715zm5.047 0c.395 0 .715.32.715.715v1.228c0 .395-.32.714-.715.714h-1.217a.714.714 0 0 1-.714-.714V10.84c0-.395.32-.715.714-.715z"/><rect width="2" height="4.752" x="7.125" y="2.5" fill="currentColor" rx="1"/><rect width="2" height="4.752" x="15" y="2.375" fill="currentColor" rx="1"/><path fill="currentColor" d="M19.652 18.436c3.333 0 4 2.006 4 2.675 0 .668-.665.67-.667.67H16.32s-.666-.001-.667-.67c0-.669.667-2.675 4-2.675m0-4.683c.53 0 1.04.211 1.414.588a2.01 2.01 0 0 1 0 2.838 1.997 1.997 0 0 1-2.828 0 2.01 2.01 0 0 1 0-2.838 2 2 0 0 1 1.414-.588"/></svg>
4
- <text v-if="label !== ''" class="icon__label" :style="labelStyle">{{ label }}</text>
5
- </view>
6
- </template>
7
- <script setup>
8
- import { computed } from 'vue'
9
- const props = defineProps({
10
- size: { type: [String, Number], default: '1em' },
11
- color: { type: String, default: 'inherit' },
12
- label: { type: [String, Number], default: '' },
13
- labelPos: { type: String, default: 'right' },
14
- labelSize: { type: [String, Number], default: '15px' },
15
- labelColor: { type: String, default: '' },
16
- space: { type: [String, Number], default: '3px' },
17
- width: { type: [String, Number], default: '' },
18
- height: { type: [String, Number], default: '' },
19
- hoverClass: { type: String, default: '' },
20
- index: { type: [String, Number], default: '' },
21
- stop: { type: Boolean, default: false }
22
- })
23
- const emit = defineEmits(['click'])
24
- const toPx = (v) => typeof v === 'number' ? (v + 'px') : (String(v||''));
25
- const iconW = computed(() => props.width ? toPx(props.width) : toPx(props.size))
26
- const iconH = computed(() => props.height ? toPx(props.height) : toPx(props.size))
27
- const iconBoxStyle = computed(() => ({ width: iconW.value, height: iconH.value }))
28
- const iconStyle = computed(() => {
29
- return { color: props.color || 'inherit' }
30
- })
31
- const wrapStyle = computed(() => {
32
- const dirMap = { right: 'row', left: 'row-reverse', top: 'column-reverse', bottom: 'column' }
33
- return { display: 'flex', alignItems: 'center', flexDirection: dirMap[props.labelPos] || 'row' }
34
- })
35
- const labelStyle = computed(() => {
36
- return {
37
- color: props.labelColor || '',
38
- fontSize: toPx(props.labelSize),
39
- marginLeft: props.labelPos === 'right' ? toPx(props.space) : 0,
40
- marginTop: props.labelPos === 'bottom' ? toPx(props.space) : 0,
41
- marginRight: props.labelPos === 'left' ? toPx(props.space) : 0,
42
- marginBottom: props.labelPos === 'top' ? toPx(props.space) : 0
43
- }
44
- })
45
- const imgSrc = '__IMG_SRC__'
46
- function onTap(e) {
47
- emit('click', props.index)
48
- if (props.stop && e && e.stopPropagation) e.stopPropagation()
49
- }
50
- </script>
51
- <style scoped>
52
- .icon__label { line-height: 1; }
53
- </style>
@@ -1,53 +0,0 @@
1
- <template>
2
- <view class="icon" @tap="onTap" :hover-class="hoverClass" :style="[wrapStyle, iconStyle]">
3
- <svg v-bind="$attrs" :style="iconStyle" :width="iconW" :height="iconH" fill="none" viewBox="0 0 48 48"><path stroke="currentColor" stroke-width="2" d="m30.479 19.038 5.734-5.734a1 1 0 0 0 0-1.414l-5.586-5.586a1 1 0 0 0-1.414 0l-5.734 5.734m7 7L15.763 33.754a1 1 0 0 1-.591.286l-6.047.708a1 1 0 0 1-1.113-1.069l.477-6.31a1 1 0 0 1 .29-.631l14.7-14.7m7 7-7-7M5.999 42h36"/></svg>
4
- <text v-if="label !== ''" class="icon__label" :style="labelStyle">{{ label }}</text>
5
- </view>
6
- </template>
7
- <script setup>
8
- import { computed } from 'vue'
9
- const props = defineProps({
10
- size: { type: [String, Number], default: '1em' },
11
- color: { type: String, default: 'inherit' },
12
- label: { type: [String, Number], default: '' },
13
- labelPos: { type: String, default: 'right' },
14
- labelSize: { type: [String, Number], default: '15px' },
15
- labelColor: { type: String, default: '' },
16
- space: { type: [String, Number], default: '3px' },
17
- width: { type: [String, Number], default: '' },
18
- height: { type: [String, Number], default: '' },
19
- hoverClass: { type: String, default: '' },
20
- index: { type: [String, Number], default: '' },
21
- stop: { type: Boolean, default: false }
22
- })
23
- const emit = defineEmits(['click'])
24
- const toPx = (v) => typeof v === 'number' ? (v + 'px') : (String(v||''));
25
- const iconW = computed(() => props.width ? toPx(props.width) : toPx(props.size))
26
- const iconH = computed(() => props.height ? toPx(props.height) : toPx(props.size))
27
- const iconBoxStyle = computed(() => ({ width: iconW.value, height: iconH.value }))
28
- const iconStyle = computed(() => {
29
- return { color: props.color || 'inherit' }
30
- })
31
- const wrapStyle = computed(() => {
32
- const dirMap = { right: 'row', left: 'row-reverse', top: 'column-reverse', bottom: 'column' }
33
- return { display: 'flex', alignItems: 'center', flexDirection: dirMap[props.labelPos] || 'row' }
34
- })
35
- const labelStyle = computed(() => {
36
- return {
37
- color: props.labelColor || '',
38
- fontSize: toPx(props.labelSize),
39
- marginLeft: props.labelPos === 'right' ? toPx(props.space) : 0,
40
- marginTop: props.labelPos === 'bottom' ? toPx(props.space) : 0,
41
- marginRight: props.labelPos === 'left' ? toPx(props.space) : 0,
42
- marginBottom: props.labelPos === 'top' ? toPx(props.space) : 0
43
- }
44
- })
45
- const imgSrc = '__IMG_SRC__'
46
- function onTap(e) {
47
- emit('click', props.index)
48
- if (props.stop && e && e.stopPropagation) e.stopPropagation()
49
- }
50
- </script>
51
- <style scoped>
52
- .icon__label { line-height: 1; }
53
- </style>
@@ -1,53 +0,0 @@
1
- <template>
2
- <view class="icon" @tap="onTap" :hover-class="hoverClass" :style="[wrapStyle, iconStyle]">
3
- <svg v-bind="$attrs" :style="iconStyle" :width="iconW" :height="iconH" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24"><g filter="url(#a)"><path fill="currentColor" d="M4.5 3.6a3 3 0 0 1 3-3h7.366a3 3 0 0 1 2.266 1.034l3.433 3.958a3 3 0 0 1 .734 1.966V20.4a3 3 0 0 1-3 3H7.5a3 3 0 0 1-3-3z"/><path fill="currentColor" fill-opacity=".4" d="M4.5 3.6a3 3 0 0 1 3-3h7.366a3 3 0 0 1 2.266 1.034l3.433 3.958a3 3 0 0 1 .734 1.966V20.4a3 3 0 0 1-3 3H7.5a3 3 0 0 1-3-3z"/><path fill="currentColor" fill-opacity=".96" d="M4.5 3.6a3 3 0 0 1 3-3h7.366a3 3 0 0 1 2.266 1.034l3.433 3.958a3 3 0 0 1 .734 1.966V20.4a3 3 0 0 1-3 3H7.5a3 3 0 0 1-3-3z"/></g><path fill="currentColor" fill-opacity=".129" fill-rule="evenodd" d="M18.3 22.56H7.5a2.16 2.16 0 0 1-2.16-2.16V3.6A2.16 2.16 0 0 1 7.5 1.44h7.366q.317 0 .614.09v1.776a2.82 2.82 0 0 0 1.83 2.64l3.103 1.164q.046.22.046.448V20.4a2.16 2.16 0 0 1-2.16 2.16m1.49-16.58-3.293-3.796a2 2 0 0 0-.177-.181v1.303a1.98 1.98 0 0 0 1.285 1.854zM4.5 3.6a3 3 0 0 1 3-3h7.366a3 3 0 0 1 2.266 1.034l3.433 3.958a3 3 0 0 1 .734 1.966V20.4a3 3 0 0 1-3 3H7.5a3 3 0 0 1-3-3z" clip-rule="evenodd"/><g filter="url(#e)"><path fill="currentColor" d="M2.7 9a3 3 0 0 1 3-3h8.4a3 3 0 0 1 3 3v8.4a3 3 0 0 1-3 3H5.7a3 3 0 0 1-3-3z"/></g><path fill="currentColor" fill-opacity=".129" fill-rule="evenodd" d="M14.1 6.72H5.7A2.28 2.28 0 0 0 3.42 9v8.4a2.28 2.28 0 0 0 2.28 2.28h8.4a2.28 2.28 0 0 0 2.28-2.28V9a2.28 2.28 0 0 0-2.28-2.28M5.7 6a3 3 0 0 0-3 3v8.4a3 3 0 0 0 3 3h8.4a3 3 0 0 0 3-3V9a3 3 0 0 0-3-3z" clip-rule="evenodd"/><path fill="currentColor" d="M8.356 8.326h1.287c.142 0 .257-.103.257-.229V6.95c0-.127-.115-.229-.257-.229H8.356c-.142 0-.256.102-.256.229v1.148c0 .126.114.229.256.229m3.087 0h-1.287c-.142 0-.256.102-.256.229v1.148c0 .127.114.229.256.229h1.287c.142 0 .257-.103.257-.229V8.555c0-.127-.115-.23-.257-.23m-3.087 3.212h1.287c.142 0 .257-.103.257-.229v-1.148c0-.127-.115-.23-.257-.23H8.356c-.142 0-.256.103-.256.23v1.148c0 .126.114.229.256.229m3.087 0h-1.287c-.142 0-.256.102-.256.228v1.149c0 .126.114.229.256.229h1.287c.142 0 .257-.103.257-.229v-1.149c0-.126-.115-.228-.257-.228m-.373 2.492H8.656c-.307 0-.556.223-.556.497v2.497c0 .274.249.496.556.496h2.414c.308 0 .557-.222.557-.496v-2.497c0-.274-.25-.497-.557-.497m-.088 2.644c0 .22-.2.398-.447.398H9.192c-.247 0-.447-.178-.447-.398v-.44c0-.22.2-.399.447-.399h1.342c.247 0 .448.179.448.4z"/><defs><linearGradient id="b" x1="12.677" x2="12.677" y1=".6" y2="23.4" gradientUnits="userSpaceOnUse"><stop stop-color="currentColor"/><stop offset="1" stop-color="currentColor" stop-opacity=".9"/><stop offset="1" stop-color="currentColor" stop-opacity=".9"/></linearGradient><linearGradient id="c" x1="12.677" x2="12.677" y1=".6" y2="23.4" gradientUnits="userSpaceOnUse"><stop stop-color="currentColor" stop-opacity=".4"/><stop offset="1" stop-color="currentColor"/></linearGradient><linearGradient id="d" x1="12.677" x2="12.677" y1=".6" y2="23.4" gradientUnits="userSpaceOnUse"><stop stop-color="currentColor"/><stop offset="1" stop-color="currentColor" stop-opacity=".9"/></linearGradient><filter id="a" width="16.8" height="23.28" x="4.5" y=".12" color-interpolation-filters="sRGB" filterUnits="userSpaceOnUse"><feFlood flood-opacity="0" result="BackgroundImageFix"/><feBlend in="SourceGraphic" in2="BackgroundImageFix" result="shape"/><feColorMatrix in="SourceAlpha" result="hardAlpha" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0"/><feOffset dy="-.48"/><feGaussianBlur stdDeviation=".24"/><feComposite in2="hardAlpha" k2="-1" k3="1" operator="arithmetic"/><feColorMatrix values="0 0 0 0 0.00784314 0 0 0 0 0.0235294 0 0 0 0 0.168627 0 0 0 0.04 0"/><feBlend in2="shape" result="effect1_innerShadow_16434_6563"/><feColorMatrix in="SourceAlpha" result="hardAlpha" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0"/><feOffset dy="-.72"/><feGaussianBlur stdDeviation=".06"/><feComposite in2="hardAlpha" k2="-1" k3="1" operator="arithmetic"/><feColorMatrix values="0 0 0 0 0.00784314 0 0 0 0 0.0235294 0 0 0 0 0.168627 0 0 0 0.02 0"/><feBlend in2="effect1_innerShadow_16434_6563" result="effect2_innerShadow_16434_6563"/></filter><filter id="e" width="18" height="18" x="2.1" y="4.8" color-interpolation-filters="sRGB" filterUnits="userSpaceOnUse"><feFlood flood-opacity="0" result="BackgroundImageFix"/><feColorMatrix in="SourceAlpha" result="hardAlpha" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0"/><feOffset dx="1.2" dy=".6"/><feGaussianBlur stdDeviation=".9"/><feComposite in2="hardAlpha" operator="out"/><feColorMatrix values="0 0 0 0 0.698039 0 0 0 0 0.388235 0 0 0 0 0.988235 0 0 0 0.1 0"/><feBlend in2="BackgroundImageFix" result="effect1_dropShadow_16434_6563"/><feBlend in="SourceGraphic" in2="effect1_dropShadow_16434_6563" result="shape"/><feColorMatrix in="SourceAlpha" result="hardAlpha" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0"/><feOffset dx="-.6" dy="-.6"/><feGaussianBlur stdDeviation="1.2"/><feComposite in2="hardAlpha" k2="-1" k3="1" operator="arithmetic"/><feColorMatrix values="0 0 0 0 0.336198 0 0 0 0 0.336198 0 0 0 0 0.336198 0 0 0 0.25 0"/><feBlend in2="shape" result="effect2_innerShadow_16434_6563"/><feColorMatrix in="SourceAlpha" result="hardAlpha" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0"/><feOffset dx=".6" dy="1.2"/><feGaussianBlur stdDeviation="1.8"/><feComposite in2="hardAlpha" k2="-1" k3="1" operator="arithmetic"/><feColorMatrix values="0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.3 0"/><feBlend in2="effect2_innerShadow_16434_6563" result="effect3_innerShadow_16434_6563"/></filter></defs></svg>
4
- <text v-if="label !== ''" class="icon__label" :style="labelStyle">{{ label }}</text>
5
- </view>
6
- </template>
7
- <script setup>
8
- import { computed } from 'vue'
9
- const props = defineProps({
10
- size: { type: [String, Number], default: '1em' },
11
- color: { type: String, default: 'inherit' },
12
- label: { type: [String, Number], default: '' },
13
- labelPos: { type: String, default: 'right' },
14
- labelSize: { type: [String, Number], default: '15px' },
15
- labelColor: { type: String, default: '' },
16
- space: { type: [String, Number], default: '3px' },
17
- width: { type: [String, Number], default: '' },
18
- height: { type: [String, Number], default: '' },
19
- hoverClass: { type: String, default: '' },
20
- index: { type: [String, Number], default: '' },
21
- stop: { type: Boolean, default: false }
22
- })
23
- const emit = defineEmits(['click'])
24
- const toPx = (v) => typeof v === 'number' ? (v + 'px') : (String(v||''));
25
- const iconW = computed(() => props.width ? toPx(props.width) : toPx(props.size))
26
- const iconH = computed(() => props.height ? toPx(props.height) : toPx(props.size))
27
- const iconBoxStyle = computed(() => ({ width: iconW.value, height: iconH.value }))
28
- const iconStyle = computed(() => {
29
- return { color: props.color || 'inherit' }
30
- })
31
- const wrapStyle = computed(() => {
32
- const dirMap = { right: 'row', left: 'row-reverse', top: 'column-reverse', bottom: 'column' }
33
- return { display: 'flex', alignItems: 'center', flexDirection: dirMap[props.labelPos] || 'row' }
34
- })
35
- const labelStyle = computed(() => {
36
- return {
37
- color: props.labelColor || '',
38
- fontSize: toPx(props.labelSize),
39
- marginLeft: props.labelPos === 'right' ? toPx(props.space) : 0,
40
- marginTop: props.labelPos === 'bottom' ? toPx(props.space) : 0,
41
- marginRight: props.labelPos === 'left' ? toPx(props.space) : 0,
42
- marginBottom: props.labelPos === 'top' ? toPx(props.space) : 0
43
- }
44
- })
45
- const imgSrc = '__IMG_SRC__'
46
- function onTap(e) {
47
- emit('click', props.index)
48
- if (props.stop && e && e.stopPropagation) e.stopPropagation()
49
- }
50
- </script>
51
- <style scoped>
52
- .icon__label { line-height: 1; }
53
- </style>
@@ -1,53 +0,0 @@
1
- <template>
2
- <view class="icon" @tap="onTap" :hover-class="hoverClass" :style="[wrapStyle, iconStyle]">
3
- <svg v-bind="$attrs" :style="iconStyle" :width="iconW" :height="iconH" fill="none" viewBox="0 0 48 48"><path stroke="currentColor" stroke-width="2" d="M30 42V22.549a1 1 0 0 1 .463-.844l10.074-6.41A1 1 0 0 0 41 14.45V8a1 1 0 0 0-1-1H8a1 1 0 0 0-1 1v6.451a1 1 0 0 0 .463.844l10.074 6.41a1 1 0 0 1 .463.844V37"/></svg>
4
- <text v-if="label !== ''" class="icon__label" :style="labelStyle">{{ label }}</text>
5
- </view>
6
- </template>
7
- <script setup>
8
- import { computed } from 'vue'
9
- const props = defineProps({
10
- size: { type: [String, Number], default: '1em' },
11
- color: { type: String, default: 'inherit' },
12
- label: { type: [String, Number], default: '' },
13
- labelPos: { type: String, default: 'right' },
14
- labelSize: { type: [String, Number], default: '15px' },
15
- labelColor: { type: String, default: '' },
16
- space: { type: [String, Number], default: '3px' },
17
- width: { type: [String, Number], default: '' },
18
- height: { type: [String, Number], default: '' },
19
- hoverClass: { type: String, default: '' },
20
- index: { type: [String, Number], default: '' },
21
- stop: { type: Boolean, default: false }
22
- })
23
- const emit = defineEmits(['click'])
24
- const toPx = (v) => typeof v === 'number' ? (v + 'px') : (String(v||''));
25
- const iconW = computed(() => props.width ? toPx(props.width) : toPx(props.size))
26
- const iconH = computed(() => props.height ? toPx(props.height) : toPx(props.size))
27
- const iconBoxStyle = computed(() => ({ width: iconW.value, height: iconH.value }))
28
- const iconStyle = computed(() => {
29
- return { color: props.color || 'inherit' }
30
- })
31
- const wrapStyle = computed(() => {
32
- const dirMap = { right: 'row', left: 'row-reverse', top: 'column-reverse', bottom: 'column' }
33
- return { display: 'flex', alignItems: 'center', flexDirection: dirMap[props.labelPos] || 'row' }
34
- })
35
- const labelStyle = computed(() => {
36
- return {
37
- color: props.labelColor || '',
38
- fontSize: toPx(props.labelSize),
39
- marginLeft: props.labelPos === 'right' ? toPx(props.space) : 0,
40
- marginTop: props.labelPos === 'bottom' ? toPx(props.space) : 0,
41
- marginRight: props.labelPos === 'left' ? toPx(props.space) : 0,
42
- marginBottom: props.labelPos === 'top' ? toPx(props.space) : 0
43
- }
44
- })
45
- const imgSrc = '__IMG_SRC__'
46
- function onTap(e) {
47
- emit('click', props.index)
48
- if (props.stop && e && e.stopPropagation) e.stopPropagation()
49
- }
50
- </script>
51
- <style scoped>
52
- .icon__label { line-height: 1; }
53
- </style>
@@ -1,53 +0,0 @@
1
- <template>
2
- <view class="icon" @tap="onTap" :hover-class="hoverClass" :style="[wrapStyle, iconStyle]">
3
- <svg v-bind="$attrs" :style="iconStyle" :width="iconW" :height="iconH" fill="none" viewBox="0 0 48 48"><path stroke="currentColor" stroke-width="2" d="M42.354 40.854 36.01 34.51m0 0a9 9 0 0 1-15.364-6.364c0-5 4-9 9-9s9 4 9 9a8.97 8.97 0 0 1-2.636 6.364zm5.636-26.365h-36m10 16h-10m10 16h-10"/></svg>
4
- <text v-if="label !== ''" class="icon__label" :style="labelStyle">{{ label }}</text>
5
- </view>
6
- </template>
7
- <script setup>
8
- import { computed } from 'vue'
9
- const props = defineProps({
10
- size: { type: [String, Number], default: '1em' },
11
- color: { type: String, default: 'inherit' },
12
- label: { type: [String, Number], default: '' },
13
- labelPos: { type: String, default: 'right' },
14
- labelSize: { type: [String, Number], default: '15px' },
15
- labelColor: { type: String, default: '' },
16
- space: { type: [String, Number], default: '3px' },
17
- width: { type: [String, Number], default: '' },
18
- height: { type: [String, Number], default: '' },
19
- hoverClass: { type: String, default: '' },
20
- index: { type: [String, Number], default: '' },
21
- stop: { type: Boolean, default: false }
22
- })
23
- const emit = defineEmits(['click'])
24
- const toPx = (v) => typeof v === 'number' ? (v + 'px') : (String(v||''));
25
- const iconW = computed(() => props.width ? toPx(props.width) : toPx(props.size))
26
- const iconH = computed(() => props.height ? toPx(props.height) : toPx(props.size))
27
- const iconBoxStyle = computed(() => ({ width: iconW.value, height: iconH.value }))
28
- const iconStyle = computed(() => {
29
- return { color: props.color || 'inherit' }
30
- })
31
- const wrapStyle = computed(() => {
32
- const dirMap = { right: 'row', left: 'row-reverse', top: 'column-reverse', bottom: 'column' }
33
- return { display: 'flex', alignItems: 'center', flexDirection: dirMap[props.labelPos] || 'row' }
34
- })
35
- const labelStyle = computed(() => {
36
- return {
37
- color: props.labelColor || '',
38
- fontSize: toPx(props.labelSize),
39
- marginLeft: props.labelPos === 'right' ? toPx(props.space) : 0,
40
- marginTop: props.labelPos === 'bottom' ? toPx(props.space) : 0,
41
- marginRight: props.labelPos === 'left' ? toPx(props.space) : 0,
42
- marginBottom: props.labelPos === 'top' ? toPx(props.space) : 0
43
- }
44
- })
45
- const imgSrc = '__IMG_SRC__'
46
- function onTap(e) {
47
- emit('click', props.index)
48
- if (props.stop && e && e.stopPropagation) e.stopPropagation()
49
- }
50
- </script>
51
- <style scoped>
52
- .icon__label { line-height: 1; }
53
- </style>
@@ -1,53 +0,0 @@
1
- <template>
2
- <view class="icon" @tap="onTap" :hover-class="hoverClass" :style="[wrapStyle, iconStyle]">
3
- <svg v-bind="$attrs" :style="iconStyle" :width="iconW" :height="iconH" fill="none" viewBox="0 0 48 48"><path stroke="currentColor" stroke-width="2" d="M6 6v18m0 0v18m0-18h20m0 0V6m0 18v18m6-7.5c0 3.038 2.239 5.5 5 5.5s5-2.462 5-5.5-2.239-5.5-5-5.5-5 2.462-5 5.5zm0 0v-5.73c0-4.444 3.867-7.677 8-7.263.437.044.736.08.952.115"/></svg>
4
- <text v-if="label !== ''" class="icon__label" :style="labelStyle">{{ label }}</text>
5
- </view>
6
- </template>
7
- <script setup>
8
- import { computed } from 'vue'
9
- const props = defineProps({
10
- size: { type: [String, Number], default: '1em' },
11
- color: { type: String, default: 'inherit' },
12
- label: { type: [String, Number], default: '' },
13
- labelPos: { type: String, default: 'right' },
14
- labelSize: { type: [String, Number], default: '15px' },
15
- labelColor: { type: String, default: '' },
16
- space: { type: [String, Number], default: '3px' },
17
- width: { type: [String, Number], default: '' },
18
- height: { type: [String, Number], default: '' },
19
- hoverClass: { type: String, default: '' },
20
- index: { type: [String, Number], default: '' },
21
- stop: { type: Boolean, default: false }
22
- })
23
- const emit = defineEmits(['click'])
24
- const toPx = (v) => typeof v === 'number' ? (v + 'px') : (String(v||''));
25
- const iconW = computed(() => props.width ? toPx(props.width) : toPx(props.size))
26
- const iconH = computed(() => props.height ? toPx(props.height) : toPx(props.size))
27
- const iconBoxStyle = computed(() => ({ width: iconW.value, height: iconH.value }))
28
- const iconStyle = computed(() => {
29
- return { color: props.color || 'inherit' }
30
- })
31
- const wrapStyle = computed(() => {
32
- const dirMap = { right: 'row', left: 'row-reverse', top: 'column-reverse', bottom: 'column' }
33
- return { display: 'flex', alignItems: 'center', flexDirection: dirMap[props.labelPos] || 'row' }
34
- })
35
- const labelStyle = computed(() => {
36
- return {
37
- color: props.labelColor || '',
38
- fontSize: toPx(props.labelSize),
39
- marginLeft: props.labelPos === 'right' ? toPx(props.space) : 0,
40
- marginTop: props.labelPos === 'bottom' ? toPx(props.space) : 0,
41
- marginRight: props.labelPos === 'left' ? toPx(props.space) : 0,
42
- marginBottom: props.labelPos === 'top' ? toPx(props.space) : 0
43
- }
44
- })
45
- const imgSrc = '__IMG_SRC__'
46
- function onTap(e) {
47
- emit('click', props.index)
48
- if (props.stop && e && e.stopPropagation) e.stopPropagation()
49
- }
50
- </script>
51
- <style scoped>
52
- .icon__label { line-height: 1; }
53
- </style>
@@ -1,53 +0,0 @@
1
- <template>
2
- <view class="icon" @tap="onTap" :hover-class="hoverClass" :style="[wrapStyle, iconStyle]">
3
- <svg v-bind="$attrs" :style="iconStyle" :width="iconW" :height="iconH" fill="none" viewBox="0 0 48 48"><path stroke="currentColor" stroke-width="2" d="M39 43V28a1 1 0 0 0-1-1h-4v-8a1 1 0 0 0-1-1H15a1 1 0 0 0-1 1v8h-4a1 1 0 0 0-1 1v15M19 9.28V17a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V7.28a1 1 0 0 0-1.242-.97l-8 2a1 1 0 0 0-.758.97z"/></svg>
4
- <text v-if="label !== ''" class="icon__label" :style="labelStyle">{{ label }}</text>
5
- </view>
6
- </template>
7
- <script setup>
8
- import { computed } from 'vue'
9
- const props = defineProps({
10
- size: { type: [String, Number], default: '1em' },
11
- color: { type: String, default: 'inherit' },
12
- label: { type: [String, Number], default: '' },
13
- labelPos: { type: String, default: 'right' },
14
- labelSize: { type: [String, Number], default: '15px' },
15
- labelColor: { type: String, default: '' },
16
- space: { type: [String, Number], default: '3px' },
17
- width: { type: [String, Number], default: '' },
18
- height: { type: [String, Number], default: '' },
19
- hoverClass: { type: String, default: '' },
20
- index: { type: [String, Number], default: '' },
21
- stop: { type: Boolean, default: false }
22
- })
23
- const emit = defineEmits(['click'])
24
- const toPx = (v) => typeof v === 'number' ? (v + 'px') : (String(v||''));
25
- const iconW = computed(() => props.width ? toPx(props.width) : toPx(props.size))
26
- const iconH = computed(() => props.height ? toPx(props.height) : toPx(props.size))
27
- const iconBoxStyle = computed(() => ({ width: iconW.value, height: iconH.value }))
28
- const iconStyle = computed(() => {
29
- return { color: props.color || 'inherit' }
30
- })
31
- const wrapStyle = computed(() => {
32
- const dirMap = { right: 'row', left: 'row-reverse', top: 'column-reverse', bottom: 'column' }
33
- return { display: 'flex', alignItems: 'center', flexDirection: dirMap[props.labelPos] || 'row' }
34
- })
35
- const labelStyle = computed(() => {
36
- return {
37
- color: props.labelColor || '',
38
- fontSize: toPx(props.labelSize),
39
- marginLeft: props.labelPos === 'right' ? toPx(props.space) : 0,
40
- marginTop: props.labelPos === 'bottom' ? toPx(props.space) : 0,
41
- marginRight: props.labelPos === 'left' ? toPx(props.space) : 0,
42
- marginBottom: props.labelPos === 'top' ? toPx(props.space) : 0
43
- }
44
- })
45
- const imgSrc = '__IMG_SRC__'
46
- function onTap(e) {
47
- emit('click', props.index)
48
- if (props.stop && e && e.stopPropagation) e.stopPropagation()
49
- }
50
- </script>
51
- <style scoped>
52
- .icon__label { line-height: 1; }
53
- </style>