import { a as __unplugin_components_0 } from './chunk-6003391e.js';
import { _ as __unplugin_components_3 } from './chunk-4e7a6a8d.js';
import { a as __unplugin_components_1 } from './chunk-8109fd17.js';
import { defineComponent, ref, computed, withCtx, unref, isRef, createTextVNode, createVNode, useSSRContext } from 'vue';
import { ssrRenderComponent } from 'vue/server-renderer';
import { u as useCopy } from './chunk-77c5cc16.js';
import { u as useValidation } from './chunk-35c3d701.js';
import { i as isNotThrowing } from './chunk-5697d061.js';
import { w as withDefaultOnError } from './chunk-f1b4cc24.js';
import '@vueuse/core';
import 'pinia';
import './chunk-11f44f81.js';
import 'naive-ui';
import 'lodash';
const _sfc_main = /* @__PURE__ */ defineComponent({
  __name: "url-encoder",
  __ssrInlineRender: true,
  setup(__props) {
    const encodeInput = ref("Hello world :)");
    const encodeOutput = computed(() => withDefaultOnError(() => encodeURIComponent(encodeInput.value), ""));
    const encodedValidation = useValidation({
      source: encodeInput,
      rules: [
        {
          validator: (value) => isNotThrowing(() => encodeURIComponent(value)),
          message: "Impossible to parse this string"
        }
      ]
    });
    const { copy: copyEncoded } = useCopy({ source: encodeOutput, text: "Encoded string copied to the clipboard" });
    const decodeInput = ref("Hello%20world%20%3A)");
    const decodeOutput = computed(() => withDefaultOnError(() => decodeURIComponent(decodeInput.value), ""));
    const decodeValidation = useValidation({
      source: encodeInput,
      rules: [
        {
          validator: (value) => isNotThrowing(() => decodeURIComponent(value)),
          message: "Impossible to parse this string"
        }
      ]
    });
    const { copy: copyDecoded } = useCopy({ source: decodeOutput, text: "Decoded string copied to the clipboard" });
    return (_ctx, _push, _parent, _attrs) => {
      const _component_c_card = __unplugin_components_1;
      const _component_c_input_text = __unplugin_components_3;
      const _component_c_button = __unplugin_components_0;
      _push(``);
      _push(ssrRenderComponent(_component_c_card, { title: "Encode" }, {
        default: withCtx((_, _push2, _parent2, _scopeId) => {
          if (_push2) {
            _push2(ssrRenderComponent(_component_c_input_text, {
              value: unref(encodeInput),
              "onUpdate:value": ($event) => isRef(encodeInput) ? encodeInput.value = $event : null,
              label: "Your string :",
              validation: unref(encodedValidation),
              multiline: "",
              autosize: "",
              placeholder: "The string to encode",
              rows: "2",
              "mb-3": ""
            }, null, _parent2, _scopeId));
            _push2(ssrRenderComponent(_component_c_input_text, {
              label: "Your string encoded :",
              value: unref(encodeOutput),
              multiline: "",
              autosize: "",
              readonly: "",
              placeholder: "Your string encoded",
              rows: "2",
              "mb-3": ""
            }, null, _parent2, _scopeId));
            _push2(`
`);
            _push2(ssrRenderComponent(_component_c_button, {
              onClick: ($event) => unref(copyEncoded)()
            }, {
              default: withCtx((_2, _push3, _parent3, _scopeId2) => {
                if (_push3) {
                  _push3(` Copy `);
                } else {
                  return [
                    createTextVNode(" Copy ")
                  ];
                }
              }),
              _: 1
            }, _parent2, _scopeId));
            _push2(`
`);
          } else {
            return [
              createVNode(_component_c_input_text, {
                value: unref(encodeInput),
                "onUpdate:value": ($event) => isRef(encodeInput) ? encodeInput.value = $event : null,
                label: "Your string :",
                validation: unref(encodedValidation),
                multiline: "",
                autosize: "",
                placeholder: "The string to encode",
                rows: "2",
                "mb-3": ""
              }, null, 8, ["value", "onUpdate:value", "validation"]),
              createVNode(_component_c_input_text, {
                label: "Your string encoded :",
                value: unref(encodeOutput),
                multiline: "",
                autosize: "",
                readonly: "",
                placeholder: "Your string encoded",
                rows: "2",
                "mb-3": ""
              }, null, 8, ["value"]),
              createVNode("div", {
                flex: "",
                "justify-center": ""
              }, [
                createVNode(_component_c_button, {
                  onClick: ($event) => unref(copyEncoded)()
                }, {
                  default: withCtx(() => [
                    createTextVNode(" Copy ")
                  ]),
                  _: 1
                }, 8, ["onClick"])
              ])
            ];
          }
        }),
        _: 1
      }, _parent));
      _push(ssrRenderComponent(_component_c_card, { title: "Decode" }, {
        default: withCtx((_, _push2, _parent2, _scopeId) => {
          if (_push2) {
            _push2(ssrRenderComponent(_component_c_input_text, {
              value: unref(decodeInput),
              "onUpdate:value": ($event) => isRef(decodeInput) ? decodeInput.value = $event : null,
              label: "Your encoded string :",
              validation: unref(decodeValidation),
              multiline: "",
              autosize: "",
              placeholder: "The string to decode",
              rows: "2",
              "mb-3": ""
            }, null, _parent2, _scopeId));
            _push2(ssrRenderComponent(_component_c_input_text, {
              label: "Your string decoded :",
              value: unref(decodeOutput),
              multiline: "",
              autosize: "",
              readonly: "",
              placeholder: "Your string decoded",
              rows: "2",
              "mb-3": ""
            }, null, _parent2, _scopeId));
            _push2(``);
            _push2(ssrRenderComponent(_component_c_button, {
              onClick: ($event) => unref(copyDecoded)()
            }, {
              default: withCtx((_2, _push3, _parent3, _scopeId2) => {
                if (_push3) {
                  _push3(` Copy `);
                } else {
                  return [
                    createTextVNode(" Copy ")
                  ];
                }
              }),
              _: 1
            }, _parent2, _scopeId));
            _push2(`
`);
          } else {
            return [
              createVNode(_component_c_input_text, {
                value: unref(decodeInput),
                "onUpdate:value": ($event) => isRef(decodeInput) ? decodeInput.value = $event : null,
                label: "Your encoded string :",
                validation: unref(decodeValidation),
                multiline: "",
                autosize: "",
                placeholder: "The string to decode",
                rows: "2",
                "mb-3": ""
              }, null, 8, ["value", "onUpdate:value", "validation"]),
              createVNode(_component_c_input_text, {
                label: "Your string decoded :",
                value: unref(decodeOutput),
                multiline: "",
                autosize: "",
                readonly: "",
                placeholder: "Your string decoded",
                rows: "2",
                "mb-3": ""
              }, null, 8, ["value"]),
              createVNode("div", {
                flex: "",
                "justify-center": ""
              }, [
                createVNode(_component_c_button, {
                  onClick: ($event) => unref(copyDecoded)()
                }, {
                  default: withCtx(() => [
                    createTextVNode(" Copy ")
                  ]),
                  _: 1
                }, 8, ["onClick"])
              ])
            ];
          }
        }),
        _: 1
      }, _parent));
      _push(``);
    };
  }
});
const _sfc_setup = _sfc_main.setup;
_sfc_main.setup = (props, ctx) => {
  const ssrContext = useSSRContext();
  (ssrContext.modules || (ssrContext.modules = /* @__PURE__ */ new Set())).add("src/tools/url-encoder/url-encoder.vue");
  return _sfc_setup ? _sfc_setup(props, ctx) : void 0;
};
export { _sfc_main as default };