gyyg-components 0.4.6 → 0.4.7

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.
@@ -359,7 +359,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony default export */
359
359
  /***/ (function(module, __webpack_exports__, __webpack_require__) {
360
360
 
361
361
  "use strict";
362
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core-js/modules/es.iterator.constructor.js */ \"./node_modules/core-js/modules/es.iterator.constructor.js\");\n/* harmony import */ var core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core-js/modules/es.iterator.filter.js */ \"./node_modules/core-js/modules/es.iterator.filter.js\");\n/* harmony import */ var core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! core-js/modules/es.iterator.for-each.js */ \"./node_modules/core-js/modules/es.iterator.for-each.js\");\n/* harmony import */ var core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! core-js/modules/es.iterator.map.js */ \"./node_modules/core-js/modules/es.iterator.map.js\");\n/* harmony import */ var core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3__);\n\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n name: \"MecSelect\",\n props: {\n value: {\n default: null,\n required: true\n },\n options: {\n required: true\n },\n multiple: {\n type: Boolean,\n default: false\n },\n props: {\n type: Object,\n default() {\n return {\n label: \"name\",\n value: \"id\"\n };\n }\n },\n placeholder: {\n type: String,\n default: \"请选择\"\n },\n clearable: {\n type: Boolean,\n default: true\n },\n disabled: {\n type: Boolean,\n default: false\n },\n size: {\n type: String,\n default: undefined\n },\n filterable: {\n type: Boolean,\n default: false\n },\n isSelectFirst: {\n type: Boolean,\n default: false\n },\n appendIcon: {\n type: String,\n default: \"\"\n }\n },\n data() {\n return {\n selected: null,\n optionList: [],\n hasAutoSelected: false\n };\n },\n computed: {\n optionMap() {\n const map = new Map();\n this.optionList.forEach(item => {\n map.set(item[this.props.value], item);\n });\n return map;\n }\n },\n watch: {\n value: {\n handler(val) {\n this.selected = val;\n },\n immediate: true\n },\n options: {\n handler: function (newOptions) {\n this.processOptions(newOptions);\n },\n deep: true,\n immediate: true\n }\n },\n methods: {\n async processOptions(options) {\n try {\n let result = options;\n if (options instanceof Promise) {\n result = await options;\n } else if (typeof options === \"function\") {\n result = await options();\n }\n this.optionList = Array.isArray(result) ? result : result.data || [];\n if (this.isSelectFirst && !this.hasAutoSelected && !this.value && this.optionList.length > 0) {\n this.hasAutoSelected = true;\n this.handleChange(this.optionList[0][this.props.value]);\n }\n } catch (error) {\n console.error(\"Failed to process options:\", error);\n this.optionList = [];\n }\n },\n getItemKey(item) {\n return item[this.props.value];\n },\n getOptionInfo(value) {\n if (this.multiple && Array.isArray(value)) {\n return value.map(val => this.optionMap.get(val)).filter(Boolean);\n }\n return this.optionMap.get(value) || {};\n },\n handleChange(val) {\n this.selected = val;\n const info = this.getOptionInfo(val);\n this.$emit(\"change\", val, info);\n this.$emit(\"input\", val);\n this.$emit(\"update:value\", val);\n },\n handleClear() {\n this.selected = this.multiple ? [] : null;\n this.$emit(\"clear\");\n this.$emit(\"input\", this.selected);\n this.$emit(\"update:value\", this.selected);\n },\n iconClick() {\n this.$emit(\"iconClick\");\n }\n }\n});\n\n//# sourceURL=webpack://gyyg-components/./src/components/MecSelect/MecSelect.vue?./node_modules/cache-loader/dist/cjs.js??ref--13-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--1-0!./node_modules/vue-loader/lib??vue-loader-options");
362
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core-js/modules/es.iterator.constructor.js */ \"./node_modules/core-js/modules/es.iterator.constructor.js\");\n/* harmony import */ var core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core-js/modules/es.iterator.filter.js */ \"./node_modules/core-js/modules/es.iterator.filter.js\");\n/* harmony import */ var core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! core-js/modules/es.iterator.for-each.js */ \"./node_modules/core-js/modules/es.iterator.for-each.js\");\n/* harmony import */ var core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! core-js/modules/es.iterator.map.js */ \"./node_modules/core-js/modules/es.iterator.map.js\");\n/* harmony import */ var core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3__);\n\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n name: \"MecSelect\",\n props: {\n value: {\n default: null,\n required: true\n },\n options: {\n required: true\n },\n multiple: {\n type: Boolean,\n default: false\n },\n props: {\n type: Object,\n default() {\n return {\n label: \"name\",\n value: \"id\"\n };\n }\n },\n placeholder: {\n type: String,\n default: \"请选择\"\n },\n clearable: {\n type: Boolean,\n default: true\n },\n disabled: {\n type: Boolean,\n default: false\n },\n size: {\n type: String,\n default: undefined\n },\n filterable: {\n type: Boolean,\n default: false\n },\n isSelectFirst: {\n type: Boolean,\n default: false\n },\n appendIcon: {\n type: String,\n default: \"\"\n }\n },\n data() {\n return {\n selected: null,\n optionList: [],\n hasAutoSelected: false\n };\n },\n computed: {\n optionMap() {\n const map = new Map();\n this.optionList.forEach(item => {\n map.set(item[this.props.value], item);\n });\n return map;\n }\n },\n watch: {\n value: {\n handler(val) {\n this.selected = val;\n },\n immediate: true\n },\n options: {\n handler: function (newOptions) {\n this.processOptions(newOptions);\n },\n deep: true,\n immediate: true\n }\n },\n methods: {\n async processOptions(options) {\n try {\n let result = options;\n if (options instanceof Promise) {\n result = await options;\n } else if (typeof options === \"function\") {\n result = await options();\n }\n this.optionList = Array.isArray(result) ? result : result.data || [];\n if (this.isSelectFirst && !this.hasAutoSelected && !this.value && this.optionList.length > 0) {\n this.hasAutoSelected = true;\n this.handleChange(this.optionList[0][this.props.value]);\n }\n } catch (error) {\n console.error(\"Failed to process options:\", error);\n this.optionList = [];\n }\n },\n getItemKey(item) {\n return item[this.props.value];\n },\n getOptionInfo(value) {\n if (this.multiple && Array.isArray(value)) {\n return value.map(val => this.optionMap.get(val)).filter(Boolean);\n }\n return this.optionMap.get(value) || {};\n },\n handleChange(val) {\n this.selected = val;\n const info = this.getOptionInfo(val);\n this.$emit(\"change\", val, info);\n this.$emit(\"input\", val);\n this.$emit(\"update:value\", val);\n },\n handleClear() {\n this.selected = this.multiple ? [] : null;\n this.$emit(\"clear\");\n this.$emit(\"input\", this.selected);\n this.$emit(\"update:value\", this.selected);\n },\n iconClick() {\n if (this.disabled) return;\n this.$emit(\"iconClick\");\n }\n }\n});\n\n//# sourceURL=webpack://gyyg-components/./src/components/MecSelect/MecSelect.vue?./node_modules/cache-loader/dist/cjs.js??ref--13-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--1-0!./node_modules/vue-loader/lib??vue-loader-options");
363
363
 
364
364
  /***/ }),
365
365
 
@@ -368,7 +368,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony default export */
368
368
  /***/ (function(module, __webpack_exports__, __webpack_require__) {
369
369
 
370
370
  "use strict";
371
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core-js/modules/es.iterator.constructor.js */ \"./node_modules/core-js/modules/es.iterator.constructor.js\");\n/* harmony import */ var core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core-js/modules/es.iterator.filter.js */ \"./node_modules/core-js/modules/es.iterator.filter.js\");\n/* harmony import */ var core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! core-js/modules/es.iterator.for-each.js */ \"./node_modules/core-js/modules/es.iterator.for-each.js\");\n/* harmony import */ var core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! core-js/modules/es.iterator.map.js */ \"./node_modules/core-js/modules/es.iterator.map.js\");\n/* harmony import */ var core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3__);\n\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n name: \"MecSelect\",\n props: {\n value: {\n default: null,\n required: true\n },\n options: {\n required: true\n },\n multiple: {\n type: Boolean,\n default: false\n },\n props: {\n type: Object,\n default() {\n return {\n label: \"name\",\n value: \"id\"\n };\n }\n },\n placeholder: {\n type: String,\n default: \"请选择\"\n },\n clearable: {\n type: Boolean,\n default: true\n },\n disabled: {\n type: Boolean,\n default: false\n },\n size: {\n type: String,\n default: undefined\n },\n filterable: {\n type: Boolean,\n default: false\n },\n isSelectFirst: {\n type: Boolean,\n default: false\n },\n appendIcon: {\n type: String,\n default: \"\"\n }\n },\n data() {\n return {\n selected: null,\n optionList: [],\n hasAutoSelected: false\n };\n },\n computed: {\n optionMap() {\n const map = new Map();\n this.optionList.forEach(item => {\n map.set(item[this.props.value], item);\n });\n return map;\n }\n },\n watch: {\n value: {\n handler(val) {\n this.selected = val;\n },\n immediate: true\n },\n options: {\n handler: function (newOptions) {\n this.processOptions(newOptions);\n },\n deep: true,\n immediate: true\n }\n },\n methods: {\n async processOptions(options) {\n try {\n let result = options;\n if (options instanceof Promise) {\n result = await options;\n } else if (typeof options === \"function\") {\n result = await options();\n }\n this.optionList = Array.isArray(result) ? result : result.data || [];\n if (this.isSelectFirst && !this.hasAutoSelected && !this.value && this.optionList.length > 0) {\n this.hasAutoSelected = true;\n this.handleChange(this.optionList[0][this.props.value]);\n }\n } catch (error) {\n console.error(\"Failed to process options:\", error);\n this.optionList = [];\n }\n },\n getItemKey(item) {\n return item[this.props.value];\n },\n getOptionInfo(value) {\n if (this.multiple && Array.isArray(value)) {\n return value.map(val => this.optionMap.get(val)).filter(Boolean);\n }\n return this.optionMap.get(value) || {};\n },\n handleChange(val) {\n this.selected = val;\n const info = this.getOptionInfo(val);\n this.$emit(\"change\", val, info);\n this.$emit(\"input\", val);\n this.$emit(\"update:value\", val);\n },\n handleClear() {\n this.selected = this.multiple ? [] : null;\n this.$emit(\"clear\");\n this.$emit(\"input\", this.selected);\n this.$emit(\"update:value\", this.selected);\n },\n iconClick() {\n this.$emit(\"iconClick\");\n }\n }\n});\n\n//# sourceURL=webpack://gyyg-components/./src/components/MecSelect/MecSelect.vue?./node_modules/cache-loader/dist/cjs.js??ref--13-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--1-0!./node_modules/vue-loader/lib??vue-loader-options");
371
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core-js/modules/es.iterator.constructor.js */ \"./node_modules/core-js/modules/es.iterator.constructor.js\");\n/* harmony import */ var core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core-js/modules/es.iterator.filter.js */ \"./node_modules/core-js/modules/es.iterator.filter.js\");\n/* harmony import */ var core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! core-js/modules/es.iterator.for-each.js */ \"./node_modules/core-js/modules/es.iterator.for-each.js\");\n/* harmony import */ var core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! core-js/modules/es.iterator.map.js */ \"./node_modules/core-js/modules/es.iterator.map.js\");\n/* harmony import */ var core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3__);\n\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n name: \"MecSelect\",\n props: {\n value: {\n default: null,\n required: true\n },\n options: {\n required: true\n },\n multiple: {\n type: Boolean,\n default: false\n },\n props: {\n type: Object,\n default() {\n return {\n label: \"name\",\n value: \"id\"\n };\n }\n },\n placeholder: {\n type: String,\n default: \"请选择\"\n },\n clearable: {\n type: Boolean,\n default: true\n },\n disabled: {\n type: Boolean,\n default: false\n },\n size: {\n type: String,\n default: undefined\n },\n filterable: {\n type: Boolean,\n default: false\n },\n isSelectFirst: {\n type: Boolean,\n default: false\n },\n appendIcon: {\n type: String,\n default: \"\"\n }\n },\n data() {\n return {\n selected: null,\n optionList: [],\n hasAutoSelected: false\n };\n },\n computed: {\n optionMap() {\n const map = new Map();\n this.optionList.forEach(item => {\n map.set(item[this.props.value], item);\n });\n return map;\n }\n },\n watch: {\n value: {\n handler(val) {\n this.selected = val;\n },\n immediate: true\n },\n options: {\n handler: function (newOptions) {\n this.processOptions(newOptions);\n },\n deep: true,\n immediate: true\n }\n },\n methods: {\n async processOptions(options) {\n try {\n let result = options;\n if (options instanceof Promise) {\n result = await options;\n } else if (typeof options === \"function\") {\n result = await options();\n }\n this.optionList = Array.isArray(result) ? result : result.data || [];\n if (this.isSelectFirst && !this.hasAutoSelected && !this.value && this.optionList.length > 0) {\n this.hasAutoSelected = true;\n this.handleChange(this.optionList[0][this.props.value]);\n }\n } catch (error) {\n console.error(\"Failed to process options:\", error);\n this.optionList = [];\n }\n },\n getItemKey(item) {\n return item[this.props.value];\n },\n getOptionInfo(value) {\n if (this.multiple && Array.isArray(value)) {\n return value.map(val => this.optionMap.get(val)).filter(Boolean);\n }\n return this.optionMap.get(value) || {};\n },\n handleChange(val) {\n this.selected = val;\n const info = this.getOptionInfo(val);\n this.$emit(\"change\", val, info);\n this.$emit(\"input\", val);\n this.$emit(\"update:value\", val);\n },\n handleClear() {\n this.selected = this.multiple ? [] : null;\n this.$emit(\"clear\");\n this.$emit(\"input\", this.selected);\n this.$emit(\"update:value\", this.selected);\n },\n iconClick() {\n if (this.disabled) return;\n this.$emit(\"iconClick\");\n }\n }\n});\n\n//# sourceURL=webpack://gyyg-components/./src/components/MecSelect/MecSelect.vue?./node_modules/cache-loader/dist/cjs.js??ref--13-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--1-0!./node_modules/vue-loader/lib??vue-loader-options");
372
372
 
373
373
  /***/ }),
374
374
 
@@ -368,7 +368,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony default export */
368
368
  /***/ (function(module, __webpack_exports__, __webpack_require__) {
369
369
 
370
370
  "use strict";
371
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core-js/modules/es.iterator.constructor.js */ \"./node_modules/core-js/modules/es.iterator.constructor.js\");\n/* harmony import */ var core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core-js/modules/es.iterator.filter.js */ \"./node_modules/core-js/modules/es.iterator.filter.js\");\n/* harmony import */ var core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! core-js/modules/es.iterator.for-each.js */ \"./node_modules/core-js/modules/es.iterator.for-each.js\");\n/* harmony import */ var core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! core-js/modules/es.iterator.map.js */ \"./node_modules/core-js/modules/es.iterator.map.js\");\n/* harmony import */ var core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3__);\n\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n name: \"MecSelect\",\n props: {\n value: {\n default: null,\n required: true\n },\n options: {\n required: true\n },\n multiple: {\n type: Boolean,\n default: false\n },\n props: {\n type: Object,\n default() {\n return {\n label: \"name\",\n value: \"id\"\n };\n }\n },\n placeholder: {\n type: String,\n default: \"请选择\"\n },\n clearable: {\n type: Boolean,\n default: true\n },\n disabled: {\n type: Boolean,\n default: false\n },\n size: {\n type: String,\n default: undefined\n },\n filterable: {\n type: Boolean,\n default: false\n },\n isSelectFirst: {\n type: Boolean,\n default: false\n },\n appendIcon: {\n type: String,\n default: \"\"\n }\n },\n data() {\n return {\n selected: null,\n optionList: [],\n hasAutoSelected: false\n };\n },\n computed: {\n optionMap() {\n const map = new Map();\n this.optionList.forEach(item => {\n map.set(item[this.props.value], item);\n });\n return map;\n }\n },\n watch: {\n value: {\n handler(val) {\n this.selected = val;\n },\n immediate: true\n },\n options: {\n handler: function (newOptions) {\n this.processOptions(newOptions);\n },\n deep: true,\n immediate: true\n }\n },\n methods: {\n async processOptions(options) {\n try {\n let result = options;\n if (options instanceof Promise) {\n result = await options;\n } else if (typeof options === \"function\") {\n result = await options();\n }\n this.optionList = Array.isArray(result) ? result : result.data || [];\n if (this.isSelectFirst && !this.hasAutoSelected && !this.value && this.optionList.length > 0) {\n this.hasAutoSelected = true;\n this.handleChange(this.optionList[0][this.props.value]);\n }\n } catch (error) {\n console.error(\"Failed to process options:\", error);\n this.optionList = [];\n }\n },\n getItemKey(item) {\n return item[this.props.value];\n },\n getOptionInfo(value) {\n if (this.multiple && Array.isArray(value)) {\n return value.map(val => this.optionMap.get(val)).filter(Boolean);\n }\n return this.optionMap.get(value) || {};\n },\n handleChange(val) {\n this.selected = val;\n const info = this.getOptionInfo(val);\n this.$emit(\"change\", val, info);\n this.$emit(\"input\", val);\n this.$emit(\"update:value\", val);\n },\n handleClear() {\n this.selected = this.multiple ? [] : null;\n this.$emit(\"clear\");\n this.$emit(\"input\", this.selected);\n this.$emit(\"update:value\", this.selected);\n },\n iconClick() {\n this.$emit(\"iconClick\");\n }\n }\n});\n\n//# sourceURL=webpack://gyyg-components/./src/components/MecSelect/MecSelect.vue?./node_modules/cache-loader/dist/cjs.js??ref--13-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--1-0!./node_modules/vue-loader/lib??vue-loader-options");
371
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core-js/modules/es.iterator.constructor.js */ \"./node_modules/core-js/modules/es.iterator.constructor.js\");\n/* harmony import */ var core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_constructor_js__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core-js/modules/es.iterator.filter.js */ \"./node_modules/core-js/modules/es.iterator.filter.js\");\n/* harmony import */ var core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_filter_js__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! core-js/modules/es.iterator.for-each.js */ \"./node_modules/core-js/modules/es.iterator.for-each.js\");\n/* harmony import */ var core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_for_each_js__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! core-js/modules/es.iterator.map.js */ \"./node_modules/core-js/modules/es.iterator.map.js\");\n/* harmony import */ var core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(core_js_modules_es_iterator_map_js__WEBPACK_IMPORTED_MODULE_3__);\n\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n name: \"MecSelect\",\n props: {\n value: {\n default: null,\n required: true\n },\n options: {\n required: true\n },\n multiple: {\n type: Boolean,\n default: false\n },\n props: {\n type: Object,\n default() {\n return {\n label: \"name\",\n value: \"id\"\n };\n }\n },\n placeholder: {\n type: String,\n default: \"请选择\"\n },\n clearable: {\n type: Boolean,\n default: true\n },\n disabled: {\n type: Boolean,\n default: false\n },\n size: {\n type: String,\n default: undefined\n },\n filterable: {\n type: Boolean,\n default: false\n },\n isSelectFirst: {\n type: Boolean,\n default: false\n },\n appendIcon: {\n type: String,\n default: \"\"\n }\n },\n data() {\n return {\n selected: null,\n optionList: [],\n hasAutoSelected: false\n };\n },\n computed: {\n optionMap() {\n const map = new Map();\n this.optionList.forEach(item => {\n map.set(item[this.props.value], item);\n });\n return map;\n }\n },\n watch: {\n value: {\n handler(val) {\n this.selected = val;\n },\n immediate: true\n },\n options: {\n handler: function (newOptions) {\n this.processOptions(newOptions);\n },\n deep: true,\n immediate: true\n }\n },\n methods: {\n async processOptions(options) {\n try {\n let result = options;\n if (options instanceof Promise) {\n result = await options;\n } else if (typeof options === \"function\") {\n result = await options();\n }\n this.optionList = Array.isArray(result) ? result : result.data || [];\n if (this.isSelectFirst && !this.hasAutoSelected && !this.value && this.optionList.length > 0) {\n this.hasAutoSelected = true;\n this.handleChange(this.optionList[0][this.props.value]);\n }\n } catch (error) {\n console.error(\"Failed to process options:\", error);\n this.optionList = [];\n }\n },\n getItemKey(item) {\n return item[this.props.value];\n },\n getOptionInfo(value) {\n if (this.multiple && Array.isArray(value)) {\n return value.map(val => this.optionMap.get(val)).filter(Boolean);\n }\n return this.optionMap.get(value) || {};\n },\n handleChange(val) {\n this.selected = val;\n const info = this.getOptionInfo(val);\n this.$emit(\"change\", val, info);\n this.$emit(\"input\", val);\n this.$emit(\"update:value\", val);\n },\n handleClear() {\n this.selected = this.multiple ? [] : null;\n this.$emit(\"clear\");\n this.$emit(\"input\", this.selected);\n this.$emit(\"update:value\", this.selected);\n },\n iconClick() {\n if (this.disabled) return;\n this.$emit(\"iconClick\");\n }\n }\n});\n\n//# sourceURL=webpack://gyyg-components/./src/components/MecSelect/MecSelect.vue?./node_modules/cache-loader/dist/cjs.js??ref--13-0!./node_modules/babel-loader/lib!./node_modules/cache-loader/dist/cjs.js??ref--1-0!./node_modules/vue-loader/lib??vue-loader-options");
372
372
 
373
373
  /***/ }),
374
374
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "gyyg-components",
3
- "version": "0.4.6",
3
+ "version": "0.4.7",
4
4
  "private": false,
5
5
  "main": "lib/gyyg-components.umd.js",
6
6
  "scripts": {
@@ -167,6 +167,7 @@ export default {
167
167
  this.$emit("update:value", this.selected);
168
168
  },
169
169
  iconClick() {
170
+ if(this.disabled) return;
170
171
  this.$emit("iconClick");
171
172
  },
172
173
  },