domelemjs 1.1.3 → 1.1.4

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.
package/index.js CHANGED
@@ -26,6 +26,8 @@ const createDOMElem = ({
26
26
  * add all the attributes they want
27
27
  */
28
28
 
29
+ const noSpecChAttrs = ["class", "id"];
30
+
29
31
  attrs &&
30
32
  makeThatArray(attrs).forEach((atts) =>
31
33
  Object.keys(atts).forEach((attr) => {
@@ -35,15 +37,14 @@ const createDOMElem = ({
35
37
  makeThatArray(atts[attr]).map((data) =>
36
38
  Object.keys(data).forEach((d) => (elem.dataset[d] = data[d]))
37
39
  );
38
- } else if (attr === "class" || attr === "id") {
40
+ } else {
39
41
  elem.setAttribute(
40
42
  attr,
41
- makeThatArray(atts[attr])
42
- .map((a) => noSpecChars(a))
43
- .join(" ")
43
+ (noSpecChAttrs.includes(attr)
44
+ ? makeThatArray(atts[attr]).map((a) => noSpecChars(a))
45
+ : makeThatArray(atts[attr])
46
+ ).join(" ")
44
47
  );
45
- } else {
46
- elem.setAttribute(attr, makeThatArray(atts[attr]).join(" "));
47
48
  }
48
49
  })
49
50
  );
@@ -157,24 +158,24 @@ const noSpecChars = (text, lowercase = false) => {
157
158
  Ű: "U",
158
159
  Í: "I",
159
160
  " ": "-",
160
- "/": "-",
161
- ":": "-",
162
- ";": "-",
163
- "=": "-",
161
+ "/": "",
162
+ ":": "",
163
+ ";": "",
164
+ "=": "",
165
+ "*": "",
166
+ "?": "",
164
167
  };
165
- for (let char in specialChars) {
166
- text = replaceAll(text, char, specialChars[char]);
167
- }
168
+
169
+ Object.keys(specialChars).forEach(
170
+ (char) => (text = replaceAll(text, char, specialChars[char]))
171
+ );
172
+
168
173
  return lowercase ? text.toLowerCase() : text;
169
174
  };
170
175
 
171
- /* check is it is array do nothing, if not maki it array */
176
+ /* check is it is array do nothing, if not make it array */
172
177
  const makeThatArray = (arr) => {
173
- if (Array.isArray(arr)) {
174
- return arr;
175
- } else {
176
- return [arr];
177
- }
178
+ return Array.isArray(arr) ? arr : [arr];
178
179
  };
179
180
 
180
181
  /* removing the "-" symbol form the string adn makind the afterward word to uppercase, that is named as camelCase */
package/index.min.js CHANGED
@@ -1,2 +1,2 @@
1
- const createDOMElem=({tag:tag,content:content,text:text,attrs:attrs,style:style,children:children,parent:parent,handleEvent:handleEvent})=>{let elem=document.createElement(tag);return content&&(elem.innerHTML=content),text&&(elem.textContent=text),attrs&&makeThatArray(attrs).forEach(atts=>Object.keys(atts).forEach(attr=>{"checked"===attr?elem.checked=atts[attr]:"dataset"===attr?makeThatArray(atts[attr]).map(data=>Object.keys(data).forEach(d=>elem.dataset[d]=data[d])):"class"===attr||"id"===attr?elem.setAttribute(attr,makeThatArray(atts[attr]).map(a=>noSpecChars(a)).join(" ")):elem.setAttribute(attr,makeThatArray(atts[attr]).join(" "))})),style&&makeThatArray(style).map(styleElem=>"object"==typeof styleElem?Object.keys(styleElem).map(styleTxt=>`${styleTxt}: ${styleElem[styleTxt]}`).join("; "):makeThatArray(styleElem).join("; ")).join("; ").split(";").forEach(styleTxts=>{let[styleTxt,val]=styleTxts.split(":").map(c=>c.trim());elem.style[makeCamelCase(styleTxt)]=val}),children&&makeThatArray(children).map(child=>{elem.appendChild("object"==typeof child?createDOMElem(child):child)}),handleEvent&&makeThatArray(handleEvent).forEach(newEvent=>{elem.addEventListener(newEvent.event,newEvent.cb)}),parent?"string"==typeof parent&&(parent=[".","#"].map(prep=>document.querySelector(prep+parent)).filter(pe=>null!==pe)[0]):parent=document.querySelector("body"),parent.appendChild(elem),elem},DOMElem={Create:createDOMElem},noSpecChars=(text,lowercase=!1)=>{function replaceAll(string,search,replace){return string.split(search).join(replace)}let specialChars={"é":"e","á":"a","ó":"o","ö":"o","ő":"o","ú":"u","ü":"u","ű":"u","í":"i","É":"E","Á":"A","Ó":"O","Ö":"O","Ő":"O","Ú":"U","Ü":"U","Ű":"U","Í":"I"," ":"-","/":"-",":":"-",";":"-","=":"-"};for(let char in specialChars)text=replaceAll(text,char,specialChars[char]);return lowercase?text.toLowerCase():text},makeThatArray=arr=>Array.isArray(arr)?arr:[arr];function makeCamelCase(s){return s.split("-").map((ss,i)=>i>0?ss.charAt(0).toUpperCase()+ss.slice(1):ss).join("")}
1
+ const createDOMElem=({tag:tag,content:content,text:text,attrs:attrs,style:style,children:children,parent:parent,handleEvent:handleEvent})=>{let elem=document.createElement(tag);content&&(elem.innerHTML=content),text&&(elem.textContent=text);const noSpecChAttrs=["class","id"];return attrs&&makeThatArray(attrs).forEach(atts=>Object.keys(atts).forEach(attr=>{"checked"===attr?elem.checked=atts[attr]:"dataset"===attr?makeThatArray(atts[attr]).map(data=>Object.keys(data).forEach(d=>elem.dataset[d]=data[d])):elem.setAttribute(attr,(noSpecChAttrs.includes(attr)?makeThatArray(atts[attr]).map(a=>noSpecChars(a)):makeThatArray(atts[attr])).join(" "))})),style&&makeThatArray(style).map(styleElem=>"object"==typeof styleElem?Object.keys(styleElem).map(styleTxt=>`${styleTxt}: ${styleElem[styleTxt]}`).join("; "):makeThatArray(styleElem).join("; ")).join("; ").split(";").forEach(styleTxts=>{let[styleTxt,val]=styleTxts.split(":").map(c=>c.trim());elem.style[makeCamelCase(styleTxt)]=val}),children&&makeThatArray(children).map(child=>{elem.appendChild("object"==typeof child?createDOMElem(child):child)}),handleEvent&&makeThatArray(handleEvent).forEach(newEvent=>{elem.addEventListener(newEvent.event,newEvent.cb)}),parent?"string"==typeof parent&&(parent=[".","#"].map(prep=>document.querySelector(prep+parent)).filter(pe=>null!==pe)[0]):parent=document.querySelector("body"),parent.appendChild(elem),elem},DOMElem={Create:createDOMElem},noSpecChars=(text,lowercase=!1)=>{function replaceAll(string,search,replace){return string.split(search).join(replace)}let specialChars={"é":"e","á":"a","ó":"o","ö":"o","ő":"o","ú":"u","ü":"u","ű":"u","í":"i","É":"E","Á":"A","Ó":"O","Ö":"O","Ő":"O","Ú":"U","Ü":"U","Ű":"U","Í":"I"," ":"-","/":"",":":"",";":"","=":"","*":"","?":""};return Object.keys(specialChars).forEach(char=>text=replaceAll(text,char,specialChars[char])),lowercase?text.toLowerCase():text},makeThatArray=arr=>Array.isArray(arr)?arr:[arr];function makeCamelCase(s){return s.split("-").map((ss,i)=>i>0?ss.charAt(0).toUpperCase()+ss.slice(1):ss).join("")}
2
2
  //# sourceMappingURL=index.min.js.map
package/index.min.js.map CHANGED
@@ -18,6 +18,7 @@
18
18
  "createElement",
19
19
  "innerHTML",
20
20
  "textContent",
21
+ "noSpecChAttrs",
21
22
  "makeThatArray",
22
23
  "forEach",
23
24
  "atts",
@@ -30,6 +31,7 @@
30
31
  "d",
31
32
  "dataset",
32
33
  "setAttribute",
34
+ "includes",
33
35
  "a",
34
36
  "noSpecChars",
35
37
  "join",
@@ -82,6 +84,8 @@
82
84
  ":",
83
85
  ";",
84
86
  "=",
87
+ "*",
88
+ "?",
85
89
  "char",
86
90
  "toLowerCase",
87
91
  "arr",
@@ -94,6 +98,6 @@
94
98
  "toUpperCase",
95
99
  "slice"
96
100
  ],
97
- "mappings": "AAAA,MAAMA,cAAgB,EACpBC,IAAAA,IACAC,QAAAA,QACAC,KAAAA,KACAC,MAAAA,MACAC,MAAAA,MACAC,SAAAA,SACAC,OAAAA,OACAC,YAAAA,gBAKA,IAAIC,KAAOC,SAASC,cAAcV,KA4GlC,OAvGAC,UAAYO,KAAKG,UAAYV,SAI7BC,OAASM,KAAKI,YAAcV,MAM5BC,OACEU,cAAcV,OAAOW,QAASC,MAC5BC,OAAOC,KAAKF,MAAMD,QAASI,OACZ,YAATA,KACFV,KAAKW,QAAUJ,KAAKG,MACF,YAATA,KACTL,cAAcE,KAAKG,OAAOE,IAAKC,MAC7BL,OAAOC,KAAKI,MAAMP,QAASQ,GAAOd,KAAKe,QAAQD,GAAKD,KAAKC,KAEzC,UAATJ,MAA6B,OAATA,KAC7BV,KAAKgB,aACHN,KACAL,cAAcE,KAAKG,OAChBE,IAAKK,GAAMC,YAAYD,IACvBE,KAAK,MAGVnB,KAAKgB,aAAaN,KAAML,cAAcE,KAAKG,OAAOS,KAAK,SAc/DvB,OACES,cAAcT,OACXgB,IAAKQ,WACqB,iBAAdA,UACFZ,OAAOC,KAAKW,WAChBR,IAAKS,UAAa,GAAGA,aAAaD,UAAUC,aAC5CF,KAAK,MAEDd,cAAce,WAAWD,KAAK,OAGxCA,KAAK,MACLG,MAAM,KACNhB,QAASiB,YACR,IAAKF,SAAUG,KAAOD,UAAUD,MAAM,KAAKV,IAAKa,GAAMA,EAAEC,QACxD1B,KAAKJ,MAAM+B,cAAcN,WAAaG,MAG5C3B,UACEQ,cAAcR,UAAUe,IAAKgB,QAC3B5B,KAAK6B,YACc,iBAAVD,MAAqBrC,cAAcqC,OAASA,SAUzD7B,aACEM,cAAcN,aAAaO,QAASwB,WAClC9B,KAAK+B,iBAAiBD,SAASE,MAAOF,SAASG,MAY/CnC,OACoB,iBAAXA,SACTA,OAAS,CAAC,IAAK,KACZc,IAAKsB,MACGjC,SAASkC,cAAcD,KAAOpC,SAEtCsC,OAAQC,IACO,OAAPA,IACN,IAEFvC,OAASG,SAASkC,cAAc,QAEvCrC,OAAO+B,YAAY7B,MAKZA,MAIHsC,QAAU,CACdC,OAAQhD,eAQJ2B,YAAc,CAACxB,KAAM8C,WAAY,KACrC,SAASC,WAAWC,OAAQC,OAAQC,SAClC,OAAOF,OAAOpB,MAAMqB,QAAQxB,KAAKyB,SAGnC,IAAIC,aAAe,CACjBC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAK,IACLC,IAAK,IACLC,IAAK,IACLC,IAAK,IACLC,IAAK,KAEP,IAAK,IAAIC,QAAQxB,aACfnD,KAAO+C,WAAW/C,KAAM2E,KAAMxB,aAAawB,OAE7C,OAAO7B,UAAY9C,KAAK4E,cAAgB5E,MAIpCW,cAAiBkE,KACjBC,MAAMC,QAAQF,KACTA,IAEA,CAACA,KAKZ,SAAS5C,cAAc+C,GACrB,OAAOA,EACJpD,MAAM,KACNV,IAAI,CAAC+D,GAAIC,IACDA,EAAI,EAAID,GAAGE,OAAO,GAAGC,cAAgBH,GAAGI,MAAM,GAAKJ,IAE3DxD,KAAK",
101
+ "mappings": "AAAA,MAAMA,cAAgB,EACpBC,IAAAA,IACAC,QAAAA,QACAC,KAAAA,KACAC,MAAAA,MACAC,MAAAA,MACAC,SAAAA,SACAC,OAAAA,OACAC,YAAAA,gBAKA,IAAIC,KAAOC,SAASC,cAAcV,KAKlCC,UAAYO,KAAKG,UAAYV,SAI7BC,OAASM,KAAKI,YAAcV,MAM5B,MAAMW,cAAgB,CAAC,QAAS,MA8FhC,OA5FAV,OACEW,cAAcX,OAAOY,QAASC,MAC5BC,OAAOC,KAAKF,MAAMD,QAASI,OACZ,YAATA,KACFX,KAAKY,QAAUJ,KAAKG,MACF,YAATA,KACTL,cAAcE,KAAKG,OAAOE,IAAKC,MAC7BL,OAAOC,KAAKI,MAAMP,QAASQ,GAAOf,KAAKgB,QAAQD,GAAKD,KAAKC,KAG3Df,KAAKiB,aACHN,MACCN,cAAca,SAASP,MACpBL,cAAcE,KAAKG,OAAOE,IAAKM,GAAMC,YAAYD,IACjDb,cAAcE,KAAKG,QACrBU,KAAK,SAejBzB,OACEU,cAAcV,OACXiB,IAAKS,WACqB,iBAAdA,UACFb,OAAOC,KAAKY,WAChBT,IAAKU,UAAa,GAAGA,aAAaD,UAAUC,aAC5CF,KAAK,MAEDf,cAAcgB,WAAWD,KAAK,OAGxCA,KAAK,MACLG,MAAM,KACNjB,QAASkB,YACR,IAAKF,SAAUG,KAAOD,UAAUD,MAAM,KAAKX,IAAKc,GAAMA,EAAEC,QACxD5B,KAAKJ,MAAMiC,cAAcN,WAAaG,MAG5C7B,UACES,cAAcT,UAAUgB,IAAKiB,QAC3B9B,KAAK+B,YACc,iBAAVD,MAAqBvC,cAAcuC,OAASA,SAUzD/B,aACEO,cAAcP,aAAaQ,QAASyB,WAClChC,KAAKiC,iBAAiBD,SAASE,MAAOF,SAASG,MAY/CrC,OACoB,iBAAXA,SACTA,OAAS,CAAC,IAAK,KACZe,IAAKuB,MACGnC,SAASoC,cAAcD,KAAOtC,SAEtCwC,OAAQC,IACO,OAAPA,IACN,IAEFzC,OAASG,SAASoC,cAAc,QAEvCvC,OAAOiC,YAAY/B,MAKZA,MAIHwC,QAAU,CACdC,OAAQlD,eAQJ6B,YAAc,CAAC1B,KAAMgD,WAAY,KACrC,SAASC,WAAWC,OAAQC,OAAQC,SAClC,OAAOF,OAAOpB,MAAMqB,QAAQxB,KAAKyB,SAGnC,IAAIC,aAAe,CACjBC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAG,IACHC,IAAK,IACLC,IAAK,GACLC,IAAK,GACLC,IAAK,GACLC,IAAK,GACLC,IAAK,GACLC,IAAK,IAOP,OAJA/D,OAAOC,KAAKqC,cAAcxC,QACvBkE,MAAU/E,KAAOiD,WAAWjD,KAAM+E,KAAM1B,aAAa0B,QAGjD/B,UAAYhD,KAAKgF,cAAgBhF,MAIpCY,cAAiBqE,KACdC,MAAMC,QAAQF,KAAOA,IAAM,CAACA,KAIrC,SAAS9C,cAAciD,GACrB,OAAOA,EACJtD,MAAM,KACNX,IAAI,CAACkE,GAAIC,IACDA,EAAI,EAAID,GAAGE,OAAO,GAAGC,cAAgBH,GAAGI,MAAM,GAAKJ,IAE3D1D,KAAK",
98
102
  "file": "index.js"
99
103
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "domelemjs",
3
- "version": "1.1.3",
3
+ "version": "1.1.4",
4
4
  "description": "With the help of this package the rendering of HTML elements form JavaScript become a easy job.",
5
5
  "main": "index.js",
6
6
  "scripts": {
@@ -20,7 +20,11 @@
20
20
  text: "Hello World!",
21
21
  parent: app,
22
22
  style: "color: red; background-color: green",
23
- attrs: { id: "title1", dataset: { text: "redText" } },
23
+ attrs: {
24
+ id: "title1",
25
+ class: "áéőúóüűöí/*-",
26
+ dataset: { text: "redText" },
27
+ },
24
28
  });
25
29
  createDOMElem({
26
30
  tag: "h2",