344 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			344 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
import { defineComponent, createVNode as _createVNode } from "vue";
 | 
						|
import { useId } from "../composables/use-id.mjs";
 | 
						|
import { getSizeStyle, makeStringProp, createNamespace } from "../utils/index.mjs";
 | 
						|
const [name, bem] = createNamespace("empty");
 | 
						|
const emptyProps = {
 | 
						|
  image: makeStringProp("default"),
 | 
						|
  imageSize: [Number, String, Array],
 | 
						|
  description: String
 | 
						|
};
 | 
						|
var stdin_default = defineComponent({
 | 
						|
  name,
 | 
						|
  props: emptyProps,
 | 
						|
  setup(props, {
 | 
						|
    slots
 | 
						|
  }) {
 | 
						|
    const renderDescription = () => {
 | 
						|
      const description = slots.description ? slots.description() : props.description;
 | 
						|
      if (description) {
 | 
						|
        return _createVNode("p", {
 | 
						|
          "class": bem("description")
 | 
						|
        }, [description]);
 | 
						|
      }
 | 
						|
    };
 | 
						|
    const renderBottom = () => {
 | 
						|
      if (slots.default) {
 | 
						|
        return _createVNode("div", {
 | 
						|
          "class": bem("bottom")
 | 
						|
        }, [slots.default()]);
 | 
						|
      }
 | 
						|
    };
 | 
						|
    const baseId = useId();
 | 
						|
    const getId = (num) => `${baseId}-${num}`;
 | 
						|
    const getUrlById = (num) => `url(#${getId(num)})`;
 | 
						|
    const renderStop = (color, offset, opacity) => _createVNode("stop", {
 | 
						|
      "stop-color": color,
 | 
						|
      "offset": `${offset}%`,
 | 
						|
      "stop-opacity": opacity
 | 
						|
    }, null);
 | 
						|
    const renderStops = (fromColor, toColor) => [renderStop(fromColor, 0), renderStop(toColor, 100)];
 | 
						|
    const renderShadow = (id) => [_createVNode("defs", null, [_createVNode("radialGradient", {
 | 
						|
      "id": getId(id),
 | 
						|
      "cx": "50%",
 | 
						|
      "cy": "54%",
 | 
						|
      "fx": "50%",
 | 
						|
      "fy": "54%",
 | 
						|
      "r": "297%",
 | 
						|
      "gradientTransform": "matrix(-.16 0 0 -.33 .58 .72)",
 | 
						|
      "data-allow-mismatch": "attribute"
 | 
						|
    }, [renderStop("#EBEDF0", 0), renderStop("#F2F3F5", 100, 0.3)])]), _createVNode("ellipse", {
 | 
						|
      "fill": getUrlById(id),
 | 
						|
      "opacity": ".8",
 | 
						|
      "cx": "80",
 | 
						|
      "cy": "140",
 | 
						|
      "rx": "46",
 | 
						|
      "ry": "8",
 | 
						|
      "data-allow-mismatch": "attribute"
 | 
						|
    }, null)];
 | 
						|
    const renderBuilding = () => [_createVNode("defs", null, [_createVNode("linearGradient", {
 | 
						|
      "id": getId("a"),
 | 
						|
      "x1": "64%",
 | 
						|
      "y1": "100%",
 | 
						|
      "x2": "64%",
 | 
						|
      "data-allow-mismatch": "attribute"
 | 
						|
    }, [renderStop("#FFF", 0, 0.5), renderStop("#F2F3F5", 100)])]), _createVNode("g", {
 | 
						|
      "opacity": ".8",
 | 
						|
      "data-allow-mismatch": "children"
 | 
						|
    }, [_createVNode("path", {
 | 
						|
      "d": "M36 131V53H16v20H2v58h34z",
 | 
						|
      "fill": getUrlById("a")
 | 
						|
    }, null), _createVNode("path", {
 | 
						|
      "d": "M123 15h22v14h9v77h-31V15z",
 | 
						|
      "fill": getUrlById("a")
 | 
						|
    }, null)])];
 | 
						|
    const renderCloud = () => [_createVNode("defs", null, [_createVNode("linearGradient", {
 | 
						|
      "id": getId("b"),
 | 
						|
      "x1": "64%",
 | 
						|
      "y1": "97%",
 | 
						|
      "x2": "64%",
 | 
						|
      "y2": "0%",
 | 
						|
      "data-allow-mismatch": "attribute"
 | 
						|
    }, [renderStop("#F2F3F5", 0, 0.3), renderStop("#F2F3F5", 100)])]), _createVNode("g", {
 | 
						|
      "opacity": ".8",
 | 
						|
      "data-allow-mismatch": "children"
 | 
						|
    }, [_createVNode("path", {
 | 
						|
      "d": "M87 6c3 0 7 3 8 6a8 8 0 1 1-1 16H80a7 7 0 0 1-8-6c0-4 3-7 6-7 0-5 4-9 9-9Z",
 | 
						|
      "fill": getUrlById("b")
 | 
						|
    }, null), _createVNode("path", {
 | 
						|
      "d": "M19 23c2 0 3 1 4 3 2 0 4 2 4 4a4 4 0 0 1-4 3v1h-7v-1l-1 1c-2 0-3-2-3-4 0-1 1-3 3-3 0-2 2-4 4-4Z",
 | 
						|
      "fill": getUrlById("b")
 | 
						|
    }, null)])];
 | 
						|
    const renderNetwork = () => _createVNode("svg", {
 | 
						|
      "viewBox": "0 0 160 160"
 | 
						|
    }, [_createVNode("defs", {
 | 
						|
      "data-allow-mismatch": "children"
 | 
						|
    }, [_createVNode("linearGradient", {
 | 
						|
      "id": getId(1),
 | 
						|
      "x1": "64%",
 | 
						|
      "y1": "100%",
 | 
						|
      "x2": "64%"
 | 
						|
    }, [renderStop("#FFF", 0, 0.5), renderStop("#F2F3F5", 100)]), _createVNode("linearGradient", {
 | 
						|
      "id": getId(2),
 | 
						|
      "x1": "50%",
 | 
						|
      "x2": "50%",
 | 
						|
      "y2": "84%"
 | 
						|
    }, [renderStop("#EBEDF0", 0), renderStop("#DCDEE0", 100, 0)]), _createVNode("linearGradient", {
 | 
						|
      "id": getId(3),
 | 
						|
      "x1": "100%",
 | 
						|
      "x2": "100%",
 | 
						|
      "y2": "100%"
 | 
						|
    }, [renderStops("#EAEDF0", "#DCDEE0")]), _createVNode("radialGradient", {
 | 
						|
      "id": getId(4),
 | 
						|
      "cx": "50%",
 | 
						|
      "cy": "0%",
 | 
						|
      "fx": "50%",
 | 
						|
      "fy": "0%",
 | 
						|
      "r": "100%",
 | 
						|
      "gradientTransform": "matrix(0 1 -.54 0 .5 -.5)"
 | 
						|
    }, [renderStop("#EBEDF0", 0), renderStop("#FFF", 100, 0)])]), _createVNode("g", {
 | 
						|
      "fill": "none"
 | 
						|
    }, [renderBuilding(), _createVNode("path", {
 | 
						|
      "fill": getUrlById(4),
 | 
						|
      "d": "M0 139h160v21H0z",
 | 
						|
      "data-allow-mismatch": "attribute"
 | 
						|
    }, null), _createVNode("path", {
 | 
						|
      "d": "M80 54a7 7 0 0 1 3 13v27l-2 2h-2a2 2 0 0 1-2-2V67a7 7 0 0 1 3-13z",
 | 
						|
      "fill": getUrlById(2),
 | 
						|
      "data-allow-mismatch": "attribute"
 | 
						|
    }, null), _createVNode("g", {
 | 
						|
      "opacity": ".6",
 | 
						|
      "stroke-linecap": "round",
 | 
						|
      "stroke-width": "7",
 | 
						|
      "data-allow-mismatch": "children"
 | 
						|
    }, [_createVNode("path", {
 | 
						|
      "d": "M64 47a19 19 0 0 0-5 13c0 5 2 10 5 13",
 | 
						|
      "stroke": getUrlById(3)
 | 
						|
    }, null), _createVNode("path", {
 | 
						|
      "d": "M53 36a34 34 0 0 0 0 48",
 | 
						|
      "stroke": getUrlById(3)
 | 
						|
    }, null), _createVNode("path", {
 | 
						|
      "d": "M95 73a19 19 0 0 0 6-13c0-5-2-9-6-13",
 | 
						|
      "stroke": getUrlById(3)
 | 
						|
    }, null), _createVNode("path", {
 | 
						|
      "d": "M106 84a34 34 0 0 0 0-48",
 | 
						|
      "stroke": getUrlById(3)
 | 
						|
    }, null)]), _createVNode("g", {
 | 
						|
      "transform": "translate(31 105)"
 | 
						|
    }, [_createVNode("rect", {
 | 
						|
      "fill": "#EBEDF0",
 | 
						|
      "width": "98",
 | 
						|
      "height": "34",
 | 
						|
      "rx": "2"
 | 
						|
    }, null), _createVNode("rect", {
 | 
						|
      "fill": "#FFF",
 | 
						|
      "x": "9",
 | 
						|
      "y": "8",
 | 
						|
      "width": "80",
 | 
						|
      "height": "18",
 | 
						|
      "rx": "1.1"
 | 
						|
    }, null), _createVNode("rect", {
 | 
						|
      "fill": "#EBEDF0",
 | 
						|
      "x": "15",
 | 
						|
      "y": "12",
 | 
						|
      "width": "18",
 | 
						|
      "height": "6",
 | 
						|
      "rx": "1.1"
 | 
						|
    }, null)])])]);
 | 
						|
    const renderMaterial = () => _createVNode("svg", {
 | 
						|
      "viewBox": "0 0 160 160"
 | 
						|
    }, [_createVNode("defs", {
 | 
						|
      "data-allow-mismatch": "children"
 | 
						|
    }, [_createVNode("linearGradient", {
 | 
						|
      "x1": "50%",
 | 
						|
      "x2": "50%",
 | 
						|
      "y2": "100%",
 | 
						|
      "id": getId(5)
 | 
						|
    }, [renderStops("#F2F3F5", "#DCDEE0")]), _createVNode("linearGradient", {
 | 
						|
      "x1": "95%",
 | 
						|
      "y1": "48%",
 | 
						|
      "x2": "5.5%",
 | 
						|
      "y2": "51%",
 | 
						|
      "id": getId(6)
 | 
						|
    }, [renderStops("#EAEDF1", "#DCDEE0")]), _createVNode("linearGradient", {
 | 
						|
      "y1": "45%",
 | 
						|
      "x2": "100%",
 | 
						|
      "y2": "54%",
 | 
						|
      "id": getId(7)
 | 
						|
    }, [renderStops("#EAEDF1", "#DCDEE0")])]), renderBuilding(), renderCloud(), _createVNode("g", {
 | 
						|
      "transform": "translate(36 50)",
 | 
						|
      "fill": "none"
 | 
						|
    }, [_createVNode("g", {
 | 
						|
      "transform": "translate(8)"
 | 
						|
    }, [_createVNode("rect", {
 | 
						|
      "fill": "#EBEDF0",
 | 
						|
      "opacity": ".6",
 | 
						|
      "x": "38",
 | 
						|
      "y": "13",
 | 
						|
      "width": "36",
 | 
						|
      "height": "53",
 | 
						|
      "rx": "2"
 | 
						|
    }, null), _createVNode("rect", {
 | 
						|
      "fill": getUrlById(5),
 | 
						|
      "width": "64",
 | 
						|
      "height": "66",
 | 
						|
      "rx": "2",
 | 
						|
      "data-allow-mismatch": "attribute"
 | 
						|
    }, null), _createVNode("rect", {
 | 
						|
      "fill": "#FFF",
 | 
						|
      "x": "6",
 | 
						|
      "y": "6",
 | 
						|
      "width": "52",
 | 
						|
      "height": "55",
 | 
						|
      "rx": "1"
 | 
						|
    }, null), _createVNode("g", {
 | 
						|
      "transform": "translate(15 17)",
 | 
						|
      "fill": getUrlById(6),
 | 
						|
      "data-allow-mismatch": "attribute"
 | 
						|
    }, [_createVNode("rect", {
 | 
						|
      "width": "34",
 | 
						|
      "height": "6",
 | 
						|
      "rx": "1"
 | 
						|
    }, null), _createVNode("path", {
 | 
						|
      "d": "M0 14h34v6H0z"
 | 
						|
    }, null), _createVNode("rect", {
 | 
						|
      "y": "28",
 | 
						|
      "width": "34",
 | 
						|
      "height": "6",
 | 
						|
      "rx": "1"
 | 
						|
    }, null)])]), _createVNode("rect", {
 | 
						|
      "fill": getUrlById(7),
 | 
						|
      "y": "61",
 | 
						|
      "width": "88",
 | 
						|
      "height": "28",
 | 
						|
      "rx": "1",
 | 
						|
      "data-allow-mismatch": "attribute"
 | 
						|
    }, null), _createVNode("rect", {
 | 
						|
      "fill": "#F7F8FA",
 | 
						|
      "x": "29",
 | 
						|
      "y": "72",
 | 
						|
      "width": "30",
 | 
						|
      "height": "6",
 | 
						|
      "rx": "1"
 | 
						|
    }, null)])]);
 | 
						|
    const renderError = () => _createVNode("svg", {
 | 
						|
      "viewBox": "0 0 160 160"
 | 
						|
    }, [_createVNode("defs", null, [_createVNode("linearGradient", {
 | 
						|
      "x1": "50%",
 | 
						|
      "x2": "50%",
 | 
						|
      "y2": "100%",
 | 
						|
      "id": getId(8),
 | 
						|
      "data-allow-mismatch": "attribute"
 | 
						|
    }, [renderStops("#EAEDF1", "#DCDEE0")])]), renderBuilding(), renderCloud(), renderShadow("c"), _createVNode("path", {
 | 
						|
      "d": "m59 60 21 21 21-21h3l9 9v3L92 93l21 21v3l-9 9h-3l-21-21-21 21h-3l-9-9v-3l21-21-21-21v-3l9-9h3Z",
 | 
						|
      "fill": getUrlById(8),
 | 
						|
      "data-allow-mismatch": "attribute"
 | 
						|
    }, null)]);
 | 
						|
    const renderSearch = () => _createVNode("svg", {
 | 
						|
      "viewBox": "0 0 160 160"
 | 
						|
    }, [_createVNode("defs", {
 | 
						|
      "data-allow-mismatch": "children"
 | 
						|
    }, [_createVNode("linearGradient", {
 | 
						|
      "x1": "50%",
 | 
						|
      "y1": "100%",
 | 
						|
      "x2": "50%",
 | 
						|
      "id": getId(9)
 | 
						|
    }, [renderStops("#EEE", "#D8D8D8")]), _createVNode("linearGradient", {
 | 
						|
      "x1": "100%",
 | 
						|
      "y1": "50%",
 | 
						|
      "y2": "50%",
 | 
						|
      "id": getId(10)
 | 
						|
    }, [renderStops("#F2F3F5", "#DCDEE0")]), _createVNode("linearGradient", {
 | 
						|
      "x1": "50%",
 | 
						|
      "x2": "50%",
 | 
						|
      "y2": "100%",
 | 
						|
      "id": getId(11)
 | 
						|
    }, [renderStops("#F2F3F5", "#DCDEE0")]), _createVNode("linearGradient", {
 | 
						|
      "x1": "50%",
 | 
						|
      "x2": "50%",
 | 
						|
      "y2": "100%",
 | 
						|
      "id": getId(12)
 | 
						|
    }, [renderStops("#FFF", "#F7F8FA")])]), renderBuilding(), renderCloud(), renderShadow("d"), _createVNode("g", {
 | 
						|
      "transform": "rotate(-45 113 -4)",
 | 
						|
      "fill": "none",
 | 
						|
      "data-allow-mismatch": "children"
 | 
						|
    }, [_createVNode("rect", {
 | 
						|
      "fill": getUrlById(9),
 | 
						|
      "x": "24",
 | 
						|
      "y": "52.8",
 | 
						|
      "width": "5.8",
 | 
						|
      "height": "19",
 | 
						|
      "rx": "1"
 | 
						|
    }, null), _createVNode("rect", {
 | 
						|
      "fill": getUrlById(10),
 | 
						|
      "x": "22.1",
 | 
						|
      "y": "67.3",
 | 
						|
      "width": "9.9",
 | 
						|
      "height": "28",
 | 
						|
      "rx": "1"
 | 
						|
    }, null), _createVNode("circle", {
 | 
						|
      "stroke": getUrlById(11),
 | 
						|
      "stroke-width": "8",
 | 
						|
      "cx": "27",
 | 
						|
      "cy": "27",
 | 
						|
      "r": "27"
 | 
						|
    }, null), _createVNode("circle", {
 | 
						|
      "fill": getUrlById(12),
 | 
						|
      "cx": "27",
 | 
						|
      "cy": "27",
 | 
						|
      "r": "16"
 | 
						|
    }, null), _createVNode("path", {
 | 
						|
      "d": "M37 7c-8 0-15 5-16 12",
 | 
						|
      "stroke": getUrlById(11),
 | 
						|
      "stroke-width": "3",
 | 
						|
      "opacity": ".5",
 | 
						|
      "stroke-linecap": "round",
 | 
						|
      "transform": "rotate(45 29 13)"
 | 
						|
    }, null)])]);
 | 
						|
    const renderImage = () => {
 | 
						|
      var _a;
 | 
						|
      if (slots.image) {
 | 
						|
        return slots.image();
 | 
						|
      }
 | 
						|
      const PRESET_IMAGES = {
 | 
						|
        error: renderError,
 | 
						|
        search: renderSearch,
 | 
						|
        network: renderNetwork,
 | 
						|
        default: renderMaterial
 | 
						|
      };
 | 
						|
      return ((_a = PRESET_IMAGES[props.image]) == null ? void 0 : _a.call(PRESET_IMAGES)) || _createVNode("img", {
 | 
						|
        "src": props.image
 | 
						|
      }, null);
 | 
						|
    };
 | 
						|
    return () => _createVNode("div", {
 | 
						|
      "class": bem()
 | 
						|
    }, [_createVNode("div", {
 | 
						|
      "class": bem("image"),
 | 
						|
      "style": getSizeStyle(props.imageSize)
 | 
						|
    }, [renderImage()]), renderDescription(), renderBottom()]);
 | 
						|
  }
 | 
						|
});
 | 
						|
export {
 | 
						|
  stdin_default as default,
 | 
						|
  emptyProps
 | 
						|
};
 |