Friendly Project Name Generator with Zeit

నేను వెబ్ సైట్లు సృష్టించడానికి సులభంగా చేసే ప్రాజెక్టులకు కొన్ని ఆలోచనలు పొందారు - ఆలోచనలు ఒకటి ఒక చేయడమే netlify-like drag and drop interface కోసం zeit ఆధారిత ప్రాజెక్టులు (నేను జీట్ వంటి కానీ అది విస్తరించడానికి CLI మేజిక్ ఒక చిన్న బిట్ అవసరం).

ఈ పోస్ట్ పజిల్ యొక్క ఒక చిన్న భాగాన్ని మాత్రమే కవర్ చేస్తుంది: ప్రాజెక్ట్ పేర్లను సృష్టించడం.

Glitch దీనికి మంచి ఉదాహరణ, మీరు ఒక ప్రాజెక్ట్‌ను సృష్టించినప్పుడు అది విచిత్రమైన యాదృచ్ఛికంగా ఉత్పత్తి చేయబడిన పేరును ఇస్తుంది. ఈ బృందం ఒక good dictionary of fairly safe words కూడా బాగా మిళితం చేసింది (మరియు మీకు కావాలంటే వారు హోస్ట్ చేయడానికి సాధారణ సర్వర్ కలిగి ఉంటారు).

కాబట్టి, ఈ ఆదివారం సైడ్ ప్రాజెక్ట్ జైట్ యొక్క serverless-functions మరియు గ్లిచ్ నుండి నిఘంటువు ఉపయోగించి యాదృచ్ఛిక ప్రాజెక్ట్ పేర్లను రూపొందించడానికి ఒక సాధారణ సూక్ష్మ సేవను సృష్టించడం.

And here it is ( code ), ఇది చాలా చిన్నది మరియు చాలా క్లిష్టంగా లేదు.

const words = require("friendly-words");

function generate(count = 1, separator = "-") {
  const { predicates, objects } = words;
  const pCount = predicates.length;
  const oCount = objects.length;
  const output = [];

  for (let i = 0; i < count; i++) {
    const pair = [predicates[Math.floor(Math.random() * pCount)], objects[Math.floor(Math.random() * oCount)]];
    output.push(pair.join(separator));
  }

  return output;
}

module.exports = { generate }

మీరు దీన్ని నేరుగా మీ ప్రాజెక్ట్‌లో చేర్చకూడదనుకుంటే, https: // friendly-project-name కు వెబ్ అభ్యర్థన చేయడం ద్వారా యాదృచ్ఛిక ప్రాజెక్ట్ పేర్లను ("XY" రూపంలో) రూపొందించడానికి మీరు HTTP ఎండ్ పాయింట్‌ను ఉపయోగించవచ్చు. kinlan.now.sh/api/names, ఇది కిందివాటిని తిరిగి ఇస్తుంది.

["momentous-professor"]

కౌంట్ = x యొక్క ప్రశ్న-స్ట్రింగ్ పరామితితో ఎన్ని పేర్లను ఉత్పత్తి చేయాలో కూడా మీరు నియంత్రించవచ్చు, ఉదా. Https://friendly-project-name.kinlan.now.sh/api/names?count=100

["melon-tangerine","broad-jury","rebel-hardcover","far-friend","notch-hornet","principled-wildcat","level-pilot","steadfast-bovid","holistic-plant","expensive-ulna","sixth-gear","political-wrench","marred-spatula","aware-weaver","awake-pair","nosy-hub","absorbing-petunia","rhetorical-birth","paint-sprint","stripe-reward","fine-guardian","coconut-jumbo","spangle-eye","sudden-euphonium","familiar-fossa","third-seaplane","workable-cough","hot-light","diligent-ceratonykus","literate-cobalt","tranquil-sandalwood","alabaster-pest","sage-detail","mousy-diascia","burly-food","fern-pie","confusion-capybara","harsh-asterisk","simple-triangle","brindle-collard","destiny-poppy","power-globeflower","ruby-crush","absorbed-trollius","meadow-blackberry","fierce-zipper","coal-mailbox","sponge-language","snow-lawyer","adjoining-bramble","deserted-flower","able-tortoise","equatorial-bugle","neat-evergreen","pointy-quart","occipital-tax","balsam-fork","dear-fairy","polished-produce","darkened-gondola","sugar-pantry","broad-slouch","safe-cormorant","foregoing-ostrich","quasar-mailman","glittery-marble","abalone-titanosaurus","descriptive-arch","nickel-ostrich","historical-candy","mire-mistake","painted-eater","pineapple-sassafras","pastoral-thief","holy-waterlily","mewing-humor","bubbly-cave","pepper-situation","nosy-colony","sprout-aries","cyan-bestseller","humorous-plywood","heavy-beauty","spiral-riverbed","gifted-income","lead-kiwi","pointed-catshark","ninth-ocean","purple-toucan","tundra-cut","coal-geography","icy-lunaria","agate-wildcat","respected-garlic","polar-almandine","periodic-narcissus","carbonated-waiter","lavish-breadfruit","confirmed-brand","repeated-period"]

సెపరేటర్ యొక్క ప్రశ్న-స్ట్రింగ్ పరామితితో మీరు సెపరేటర్‌ను నియంత్రించవచ్చు. అనగా, సెపరేటర్ = @, ఉదా. https://friendly-project-name.kinlan.now.sh/api/names?separator=@

["handsomely@asterisk"]

ఈ ప్రాజెక్ట్ యొక్క చాలా ఉపయోగకరమైన అంశం ఏమిటంటే, పదాల కలయిక అప్రియమైనదిగా ఉంటే, గ్లిచ్ రెపోను మళ్లీ జరగకుండా చూసుకోవడం సులభం.

ప్రాజెక్ట్ హోస్టింగ్ చాలా ఖరీదైనది కాదని uming హిస్తే నేను సేవను కొనసాగిస్తాను, కానీ మీరు ఎప్పుడైనా ఇలాంటి సూక్ష్మ సేవను సృష్టించాలనుకుంటే దాన్ని మీరే క్లోన్ చేసుకోండి.

ప్రత్యక్ష ఉదాహరణ

చర్యలో ఉన్న API యొక్క సూపర్ శీఘ్ర ఉదాహరణ క్రిందిది.

const render = (promise, elementId) => {
  promise.then(async(response) => {
    const el = document.getElementById(elementId);
    el.innerText = await response.text();
  })
};


onload = () => {
  render(fetch("https://friendly-project-name.kinlan.now.sh/api/names"), "basic");
  render(fetch("https://friendly-project-name.kinlan.now.sh/api/names?count=100"), "many");
  render(fetch("https://friendly-project-name.kinlan.now.sh/api/names?separator=@"), "separator");
}

ఒకే ప్రతిస్పందన



చాలా స్పందనలు



కస్టమ్ సెపరేటర్లు



{{<raw-html>}}

{{</ raw-html>}}

Paul Kinlan

Trying to make the web and developers better.

RSS Github Medium