diff --git a/components/other-select/index.vue b/components/other-select/index.vue
new file mode 100644
index 0000000..23e9b27
--- /dev/null
+++ b/components/other-select/index.vue
@@ -0,0 +1,110 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/hybrid/html/map.html b/hybrid/html/map.html
new file mode 100644
index 0000000..4fb7698
--- /dev/null
+++ b/hybrid/html/map.html
@@ -0,0 +1,59 @@
+
+
+
+
+
+ Document
+
+
+
+
+
+
+
+
+
diff --git a/hybrid/js/uni.webview.1.5.4.js b/hybrid/js/uni.webview.1.5.4.js
new file mode 100644
index 0000000..271a163
--- /dev/null
+++ b/hybrid/js/uni.webview.1.5.4.js
@@ -0,0 +1 @@
+!function(e,n){"object"==typeof exports&&"undefined"!=typeof module?module.exports=n():"function"==typeof define&&define.amd?define(n):(e=e||self).uni=n()}(this,(function(){"use strict";try{var e={};Object.defineProperty(e,"passive",{get:function(){!0}}),window.addEventListener("test-passive",null,e)}catch(e){}var n=Object.prototype.hasOwnProperty;function i(e,i){return n.call(e,i)}var t=[];function r(){return window.__dcloud_weex_postMessage||window.__dcloud_weex_}var o=function(e,n){var i={options:{timestamp:+new Date},name:e,arg:n};if(r()){if("postMessage"===e){var o={data:[n]};return window.__dcloud_weex_postMessage?window.__dcloud_weex_postMessage(o):window.__dcloud_weex_.postMessage(JSON.stringify(o))}var a={type:"WEB_INVOKE_APPSERVICE",args:{data:i,webviewIds:t}};window.__dcloud_weex_postMessage?window.__dcloud_weex_postMessageToService(a):window.__dcloud_weex_.postMessageToService(JSON.stringify(a))}if(!window.plus)return window.parent.postMessage({type:"WEB_INVOKE_APPSERVICE",data:i,pageId:""},"*");if(0===t.length){var d=plus.webview.currentWebview();if(!d)throw new Error("plus.webview.currentWebview() is undefined");var s=d.parent(),w="";w=s?s.id:d.id,t.push(w)}if(plus.webview.getWebviewById("__uniapp__service"))plus.webview.postMessageToUniNView({type:"WEB_INVOKE_APPSERVICE",args:{data:i,webviewIds:t}},"__uniapp__service");else{var u=JSON.stringify(i);plus.webview.getLaunchWebview().evalJS('UniPlusBridge.subscribeHandler("'.concat("WEB_INVOKE_APPSERVICE",'",').concat(u,",").concat(JSON.stringify(t),");"))}},a={navigateTo:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=e.url;o("navigateTo",{url:encodeURI(n)})},navigateBack:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=e.delta;o("navigateBack",{delta:parseInt(n)||1})},switchTab:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=e.url;o("switchTab",{url:encodeURI(n)})},reLaunch:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=e.url;o("reLaunch",{url:encodeURI(n)})},redirectTo:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=e.url;o("redirectTo",{url:encodeURI(n)})},getEnv:function(e){r()?e({nvue:!0}):window.plus?e({plus:!0}):e({h5:!0})},postMessage:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};o("postMessage",e.data||{})}},d=/uni-app/i.test(navigator.userAgent),s=/Html5Plus/i.test(navigator.userAgent),w=/complete|loaded|interactive/;var u=window.my&&navigator.userAgent.indexOf(["t","n","e","i","l","C","y","a","p","i","l","A"].reverse().join(""))>-1;var g=window.swan&&window.swan.webView&&/swan/i.test(navigator.userAgent);var v=window.qq&&window.qq.miniProgram&&/QQ/i.test(navigator.userAgent)&&/miniProgram/i.test(navigator.userAgent);var c=window.tt&&window.tt.miniProgram&&/toutiaomicroapp/i.test(navigator.userAgent);var m=window.wx&&window.wx.miniProgram&&/micromessenger/i.test(navigator.userAgent)&&/miniProgram/i.test(navigator.userAgent);var p=window.qa&&/quickapp/i.test(navigator.userAgent);var f=window.ks&&window.ks.miniProgram&&/micromessenger/i.test(navigator.userAgent)&&/miniProgram/i.test(navigator.userAgent);var l=window.tt&&window.tt.miniProgram&&/Lark|Feishu/i.test(navigator.userAgent);var _=window.jd&&window.jd.miniProgram&&/micromessenger/i.test(navigator.userAgent)&&/miniProgram/i.test(navigator.userAgent);var E=window.xhs&&window.xhs.miniProgram&&/xhsminiapp/i.test(navigator.userAgent);for(var h,P=function(){window.UniAppJSBridge=!0,document.dispatchEvent(new CustomEvent("UniAppJSBridgeReady",{bubbles:!0,cancelable:!0}))},b=[function(e){if(d||s)return window.__dcloud_weex_postMessage||window.__dcloud_weex_?document.addEventListener("DOMContentLoaded",e):window.plus&&w.test(document.readyState)?setTimeout(e,0):document.addEventListener("plusready",e),a},function(e){if(m)return window.WeixinJSBridge&&window.WeixinJSBridge.invoke?setTimeout(e,0):document.addEventListener("WeixinJSBridgeReady",e),window.wx.miniProgram},function(e){if(v)return window.QQJSBridge&&window.QQJSBridge.invoke?setTimeout(e,0):document.addEventListener("QQJSBridgeReady",e),window.qq.miniProgram},function(e){if(u){document.addEventListener("DOMContentLoaded",e);var n=window.my;return{navigateTo:n.navigateTo,navigateBack:n.navigateBack,switchTab:n.switchTab,reLaunch:n.reLaunch,redirectTo:n.redirectTo,postMessage:n.postMessage,getEnv:n.getEnv}}},function(e){if(g)return document.addEventListener("DOMContentLoaded",e),window.swan.webView},function(e){if(c)return document.addEventListener("DOMContentLoaded",e),window.tt.miniProgram},function(e){if(p){window.QaJSBridge&&window.QaJSBridge.invoke?setTimeout(e,0):document.addEventListener("QaJSBridgeReady",e);var n=window.qa;return{navigateTo:n.navigateTo,navigateBack:n.navigateBack,switchTab:n.switchTab,reLaunch:n.reLaunch,redirectTo:n.redirectTo,postMessage:n.postMessage,getEnv:n.getEnv}}},function(e){if(f)return window.WeixinJSBridge&&window.WeixinJSBridge.invoke?setTimeout(e,0):document.addEventListener("WeixinJSBridgeReady",e),window.ks.miniProgram},function(e){if(l)return document.addEventListener("DOMContentLoaded",e),window.tt.miniProgram},function(e){if(_)return window.JDJSBridgeReady&&window.JDJSBridgeReady.invoke?setTimeout(e,0):document.addEventListener("JDJSBridgeReady",e),window.jd.miniProgram},function(e){if(E)return window.xhs.miniProgram},function(e){return document.addEventListener("DOMContentLoaded",e),a}],y=0;y
+
+
+
+
+
+
\ No newline at end of file
diff --git a/utils/gcoord.js b/utils/gcoord.js
new file mode 100644
index 0000000..a9391cd
--- /dev/null
+++ b/utils/gcoord.js
@@ -0,0 +1,216 @@
+/* @preserve
+ * gcoord 0.2.2, geographic coordinate library
+ * Copyright (c) 2019 Jiulong Hu
+ */
+!function (e, t) {
+ "object" == typeof exports && "undefined" != typeof module ? t(exports) : "function" == typeof define && define.amd ? define(["exports"], t) : t(e.gcoord = {})
+}(this, function (e) {
+ "use strict";
+ var t = "WGS84", r = t, n = t, o = "GCJ02", a = o, i = "BD09", u = i, f = i, c = i, s = "BD09MC", l = s,
+ M = "EPSG3857", g = M, h = M, v = M, d = M;
+
+ function m(e) {
+ throw new Error(e)
+ }
+
+ function G(e) {
+ return !isNaN(e) && null !== e && !S(e)
+ }
+
+ function S(e) {
+ return !!e && "[object Array]" === Object.prototype.toString.call(e)
+ }
+
+ function P() {
+ for (var o = [], e = 0; e < arguments.length; e++) o[e] = arguments[e];
+ var a = o.length - 1;
+ return function () {
+ for (var e = [], t = 0; t < arguments.length; t++) e[t] = arguments[t];
+ for (var r = a, n = o[a].apply(null, e); r--;) n = o[r].call(null, n);
+ return n
+ }
+ }
+
+ var b = Math.sin, y = Math.cos, p = Math.sqrt, B = Math.abs, D = Math.PI, C = 6378245, E = .006693421622965823;
+
+ function W(e) {
+ var t = e[0], r = e[1];
+ if (!J(t, r)) return [t, r];
+ for (var n = [t, r], o = n[0], a = n[1], i = x([o, a]), u = i[0] - t, f = i[1] - r; 1e-6 < B(u) || 1e-6 < B(f);) u = (i = x([o -= u, a -= f]))[0] - t, f = i[1] - r;
+ return [o, a]
+ }
+
+ function x(e) {
+ var t = e[0], r = e[1];
+ if (!J(t, r)) return [t, r];
+ var n = function (e, t) {
+ var r = function (e, t) {
+ var r = 300 + e + 2 * t + .1 * e * e + .1 * e * t + .1 * p(B(e));
+ return r += 2 * (20 * b(6 * e * D) + 20 * b(2 * e * D)) / 3, r += 2 * (20 * b(e * D) + 40 * b(e / 3 * D)) / 3, r += 2 * (150 * b(e / 12 * D) + 300 * b(e / 30 * D)) / 3
+ }(e - 105, t - 35), n = function (e, t) {
+ var r = 2 * e - 100 + 3 * t + .2 * t * t + .1 * e * t + .2 * p(B(e));
+ return r += 2 * (20 * b(6 * e * D) + 20 * b(2 * e * D)) / 3, r += 2 * (20 * b(t * D) + 40 * b(t / 3 * D)) / 3, r += 2 * (160 * b(t / 12 * D) + 320 * b(t * D / 30)) / 3
+ }(e - 105, t - 35), o = t / 180 * D, a = b(o), i = p(a = 1 - E * a * a);
+ return [r = 180 * r / (C / i * y(o) * D), n = 180 * n / (C * (1 - E) / (a * i) * D)]
+ }(t, r);
+ return [t + n[0], r + n[1]]
+ }
+
+ function J(e, t) {
+ return 72.004 <= e && e <= 137.8347 && .8293 <= t && t <= 55.8271
+ }
+
+ var k = Math.sin, L = Math.cos, j = Math.atan2, I = Math.sqrt, q = 3e3 * Math.PI / 180;
+
+ function w(e) {
+ var t = e[0] - .0065, r = e[1] - .006, n = I(t * t + r * r) - 2e-5 * k(r * q), o = j(r, t) - 3e-6 * L(t * q);
+ return [n * L(o), n * k(o)]
+ }
+
+ function N(e) {
+ var t = e[0], r = e[1], n = I(t * t + r * r) + 2e-5 * k(r * q), o = j(r, t) + 3e-6 * L(t * q);
+ return [n * L(o) + .0065, n * k(o) + .006]
+ }
+
+ var O = 180 / Math.PI, A = Math.PI / 180, F = 6378137, _ = 20037508.342789244;
+
+ function z(e) {
+ return [e[0] * O / F, (.5 * Math.PI - 2 * Math.atan(Math.exp(-e[1] / F))) * O]
+ }
+
+ function T(e) {
+ var t = Math.abs(e[0]) <= 180 ? e[0] : e[0] - 360 * (e[0] < 0 ? -1 : 1),
+ r = [F * t * A, F * Math.log(Math.tan(.25 * Math.PI + .5 * e[1] * A))];
+ return r[0] > _ && (r[0] = _), r[0] < -_ && (r[0] = -_), r[1] > _ && (r[1] = _), r[1] < -_ && (r[1] = -_), r
+ }
+
+ var U = Math.abs, H = Math.pow, K = [12890594.86, 8362377.87, 5591021, 3481989.83, 1678043.12, 0],
+ Q = [75, 60, 45, 30, 15, 0],
+ R = [[1.410526172116255e-8, 898305509648872e-20, -1.9939833816331, 200.9824383106796, -187.2403703815547, 91.6087516669843, -23.38765649603339, 2.57121317296198, -.03801003308653, 17337981.2], [-7.435856389565537e-9, 8983055097726239e-21, -.78625201886289, 96.32687599759846, -1.85204757529826, -59.36935905485877, 47.40033549296737, -16.50741931063887, 2.28786674699375, 10260144.86], [-3.030883460898826e-8, 898305509983578e-20, .30071316287616, 59.74293618442277, 7.357984074871, -25.38371002664745, 13.45380521110908, -3.29883767235584, .32710905363475, 6856817.37], [-1.981981304930552e-8, 8983055099779535e-21, .03278182852591, 40.31678527705744, .65659298677277, -4.44255534477492, .85341911805263, .12923347998204, -.04625736007561, 4482777.06], [3.09191371068437e-9, 8983055096812155e-21, 6995724062e-14, 23.10934304144901, -.00023663490511, -.6321817810242, -.00663494467273, .03430082397953, -.00466043876332, 2555164.4], [2.890871144776878e-9, 8983055095805407e-21, -3.068298e-8, 7.47137025468032, -353937994e-14, -.02145144861037, -1234426596e-14, .00010322952773, -323890364e-14, 826088.5]],
+ V = [[-.0015702102444, 111320.7020616939, 0x60e374c3105a3, -0x24bb4115e2e164, 0x5cc55543bb0ae8, -0x7ce070193f3784, 0x5e7ca61ddf8150, -0x261a578d8b24d0, 0x665d60f3742ca, 82.5], [.0008277824516172526, 111320.7020463578, 647795574.6671607, -4082003173.641316, 10774905663.51142, -15171875531.51559, 12053065338.62167, -5124939663.577472, 913311935.9512032, 67.5], [.00337398766765, 111320.7020202162, 4481351.045890365, -23393751.19931662, 79682215.47186455, -115964993.2797253, 97236711.15602145, -43661946.33752821, 8477230.501135234, 52.5], [.00220636496208, 111320.7020209128, 51751.86112841131, 3796837.749470245, 992013.7397791013, -1221952.21711287, 1340652.697009075, -620943.6990984312, 144416.9293806241, 37.5], [-.0003441963504368392, 111320.7020576856, 278.2353980772752, 2485758.690035394, 6070.750963243378, 54821.18345352118, 9540.606633304236, -2710.55326746645, 1405.483844121726, 22.5], [-.0003218135878613132, 111320.7020701615, .00369383431289, 823725.6402795718, .46104986909093, 2351.343141331292, 1.58060784298199, 8.77738589078284, .37238884252424, 7.45]];
+
+ function X(e, t, r) {
+ var n = U(t) / r[9], o = r[0] + r[1] * U(e),
+ a = r[2] + r[3] * n + r[4] * H(n, 2) + r[5] * H(n, 3) + r[6] * H(n, 4) + r[7] * H(n, 5) + r[8] * H(n, 6);
+ return [o *= e < 0 ? -1 : 1, a *= t < 0 ? -1 : 1]
+ }
+
+ function Y(e) {
+ for (var t = e[0], r = e[1], n = [], o = 0; o < Q.length; o++) if (U(r) > Q[o]) {
+ n = V[o];
+ break
+ }
+ return X(t, r, n)
+ }
+
+ function Z(e) {
+ for (var t = e[0], r = e[1], n = [], o = 0; o < K.length; o++) if (K[o] <= r) {
+ n = R[o];
+ break
+ }
+ return X(t, r, n)
+ }
+
+ var $ = {to: {GCJ02: x, BD09: P(N, x), BD09MC: P(Y, N, x), EPSG3857: T}},
+ ee = {to: {WGS84: W, BD09: N, BD09MC: P(Y, N), EPSG3857: P(T, W)}},
+ te = {to: {WGS84: P(W, w), GCJ02: w, EPSG3857: P(T, W, w), BD09MC: Y}},
+ re = {to: {WGS84: z, GCJ02: P(x, z), BD09: P(N, x, z), BD09MC: P(Y, N, x, z)}},
+ ne = {to: {WGS84: P(W, w, Z), GCJ02: P(w, Z), EPSG3857: P(T, W, w, Z), BD09: Z}},
+ oe = Object.freeze({WGS84: $, GCJ02: ee, BD09: te, EPSG3857: re, BD09MC: ne});
+
+ function ae(e, t, r) {
+ e || m("coordinate is required"), t || m("original coordinate system is required"), r || m("target coordinate system is required");
+ var n = oe[t];
+ if (n || m("original coordinate system is invalid"), t === r) return e;
+ var o = n.to[r];
+ o || m("target coordinate system is invalid");
+ var a = typeof e;
+ if ("string" != a && "object" != a && m("coordinate must be an geojson or an array of position"), "string" == a) try {
+ e = JSON.parse(e)
+ } catch (e) {
+ m("input is not a legal JSON string")
+ }
+ var i = !1;
+ S(e) && (e.length < 2 && m("position must be at 2 numbers long"), G(e[0]) && G(e[1]) || m("position must contain numbers"), e = e.map(Number), i = !0);
+ var u = o;
+ return i ? u(e) : (function e(t, r, n) {
+ if (void 0 === n && (n = !1), null !== t) for (var o, a, i, u, f, c, s, l, M = 0, g = 0, h = t.type, v = "FeatureCollection" === h, d = "Feature" === h, G = v ? t.features.length : 1, S = 0; S < G; S++) {
+ f = (l = !!(s = v ? t.features[S].geometry : d ? t.geometry : t) && "GeometryCollection" === s.type) ? s.geometries.length : 1;
+ for (var P = 0; P < f; P++) {
+ var b = 0, y = 0;
+ if (null !== (u = l ? s.geometries[P] : s)) {
+ var p = u.type;
+ switch (M = !n || "Polygon" !== p && "MultiPolygon" !== p ? 0 : 1, p) {
+ case null:
+ break;
+ case"Point":
+ if (!1 === r(c = u.coordinates, g, S, b, y)) return !1;
+ g++, b++;
+ break;
+ case"LineString":
+ case"MultiPoint":
+ for (c = u.coordinates, o = 0; o < c.length; o++) {
+ if (!1 === r(c[o], g, S, b, y)) return !1;
+ g++, "MultiPoint" === p && b++
+ }
+ "LineString" === p && b++;
+ break;
+ case"Polygon":
+ case"MultiLineString":
+ for (c = u.coordinates, o = 0; o < c.length; o++) {
+ for (a = 0; a < c[o].length - M; a++) {
+ if (!1 === r(c[o][a], g, S, b, y)) return !1;
+ g++
+ }
+ "MultiLineString" === p && b++, "Polygon" === p && y++
+ }
+ "Polygon" === p && b++;
+ break;
+ case"MultiPolygon":
+ for (c = u.coordinates, o = 0; o < c.length; o++) {
+ for (a = y = 0; a < c[o].length; a++) {
+ for (i = 0; i < c[o][a].length - M; i++) {
+ if (!1 === r(c[o][a][i], g, S, b, y)) return !1;
+ g++
+ }
+ y++
+ }
+ b++
+ }
+ break;
+ case"GeometryCollection":
+ for (o = 0; o < u.geometries.length; o++) if (!1 === e(u.geometries[o], r, n)) return !1;
+ break;
+ default:
+ m("Unknown Geometry Type")
+ }
+ }
+ }
+ }
+ }(e, function (e) {
+ var t;
+ t = u(e), e[0] = t[0], e[1] = t[1]
+ }), e)
+ }
+
+ var ie = {
+ WGS84: t,
+ WGS1984: r,
+ EPSG4326: n,
+ GCJ02: o,
+ AMap: a,
+ BD09: i,
+ BD09LL: u,
+ Baidu: f,
+ BMap: c,
+ BD09MC: s,
+ BD09Meter: l,
+ EPSG3857: M,
+ EPSG900913: g,
+ EPSG102100: h,
+ WebMercator: v,
+ WM: d,
+ transform: ae
+ };
+ e.WGS84 = t, e.WGS1984 = r, e.EPSG4326 = n, e.GCJ02 = o, e.AMap = a, e.BD09 = i, e.BD09LL = u, e.Baidu = f, e.BMap = c, e.BD09MC = s, e.BD09Meter = l, e.EPSG3857 = M, e.EPSG900913 = g, e.EPSG102100 = h, e.WebMercator = v, e.WM = d, e.transform = ae, e.default = ie, Object.defineProperty(e, "__esModule", {value: !0})
+});
\ No newline at end of file