{"version":3,"sources":["../../src/pages/email-template/email-template.ts","../../node_modules/ngx-chips/fesm5/ngx-chips.js","../../node_modules/ng2-material-dropdown/fesm5/ng2-material-dropdown.js","../../src/pages/email-template/email-template.module.ts"],"names":[],"mappings":"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A;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,+DAAQ,GAAG;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,mBAAmB,iEAAU;AAC7B,QAAQ,iEAAU;AAClB;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,4CAA4C,+DAAQ,GAAG;AACvD,4CAA4C,+DAAQ,GAAG;AACvD;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC,sBAAsB;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC,sBAAsB;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D,2BAA2B,EAAE;AACzF;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,kBAAkB;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,4BAA4B,2DAAY;AACxC;AACA;AACA;AACA,0BAA0B,2DAAY;AACtC;AACA;AACA;AACA,2BAA2B,2DAAY;AACvC;AACA;AACA;AACA,2BAA2B,2DAAY;AACvC;AACA;AACA;AACA,6BAA6B,2DAAY;AACzC;AACA;AACA;AACA,mCAAmC,2DAAY;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB,mEAAW,EAAE,qCAAqC;AAC1E;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,wBAAwB;AACxB;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,wBAAwB,iEAAS;AACjC;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,kCAAkC,EAAE;AACxE,iCAAiC,sBAAsB,EAAE;AACzD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,iEAAU;AACd,QAAQ,6DAAM;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AW,yBAAyB,6CAA6C,uBAAuB,wBAAwB,2BAA2B,+CAA+C,iCAAiC,WAAW;AACxa,SAAS;AACT;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,2DAAY;AACxC;AACA;AACA;AACA,4BAA4B,2DAAY;AACxC;AACA;AACA;AACA,0BAA0B,2DAAY;AACtC;AACA;AACA;AACA,6BAA6B,2DAAY;AACzC;AACA;AACA;AACA,+BAA+B,2DAAY;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B;AAC3B;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,kCAAkC;AACnE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,kCAAkC,EAAE;AACpE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc,+DAAQ,GAAG,sBAAsB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA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ACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAwB;AACxB;AACA,8CAA8C,QAAQ,gEAAS;AAC/D;AACA,mBAAmB,kEAAW;AAC9B;AACA;AACA;AACA,2GAA2G,EAAE;AAC7G;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS,EAAE;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,6DAAK;AAC3B,qDAAqD,qCAAqC,EAAE;AAC5F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0DAA0D;AAC1D;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,oEAAY,iBAAiB,8DAAM;AACrD;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,+DAAQ,GAAG,sBAAsB;AAChD;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sDAAsD;AACtD;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,iEAAU;AACd,QAAQ,gEAAS,CAAC,0EAAW,GAAG,gBAAgB;AAChD,QAAQ,iEAAU,gBAAgB,0EAAW;AAC7C;AACA,IAAI,iEAAU;AACd,QAAQ,sEAAe,CAAC,0DAAW;AACnC,QAAQ,iEAAU,gBAAgB,wDAAS;AAC3C;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,mEAAY;AACpB,QAAQ,iEAAU;AAClB,QAAQ,iEAAU;AAClB,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,mEAAY;AACpB,QAAQ,iEAAU;AAClB,QAAQ,iEAAU;AAClB,QAAQ,iEAAU;AAClB;AACA,uBAAuB,iEAAU;AACjC,QAAQ,gEAAS;AACjB;AACA,8UAA8U,mBAAmB,ybAAyb,uCAAuC;AACj0B,SAAS;AACT,QAAQ,iEAAU,uBAAuB,uDAAQ;AACjD;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA,aAAa,yEAAiB;AAC9B,iBAAiB,iEAAU,cAAc,0BAA0B,EAAE;AACrE;AACA;AACA;AACA,IAAI,gEAAS;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,2DAAY;AACtC;AACA;AACA;AACA;AACA,6BAA6B,2DAAY;AACzC;AACA;AACA;AACA;AACA,6BAA6B,2DAAY;AACzC;AACA;AACA;AACA;AACA,4BAA4B,2DAAY;AACxC;AACA;AACA;AACA;AACA,2BAA2B,2DAAY;AACvC;AACA;AACA;AACA;AACA,iCAAiC,2DAAY;AAC7C;AACA;AACA;AACA;AACA,4BAA4B,2DAAY;AACxC;AACA;AACA;AACA;AACA,sCAAsC,2DAAY;AAClD;AACA;AACA;AACA;AACA,gCAAgC,2DAAY;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,2DAAY;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB;AACvB;AACA;AACA,mCAAmC,4BAA4B;AAC/D;AACA;AACA,0BAA0B,+DAAQ;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,+DAAQ,GAAG,wCAAwC,UAAU;AAChF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,0BAA0B;AACxE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD,QAAQ,gEAAS;AAClE;AACA;AACA,mBAAmB,kEAAW;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB,0CAA0C,gCAAgC,gCAAgC,EAAE,MAAM;AAClH;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,aAAa;AACb,SAAS,EAAE;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,8DAAM,oBAAoB,6BAA6B,EAAE;AACrF;AACA,SAAS;AACT,yDAAyD,2DAAG;AAC5D;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,6DAAK;AAC/B;AACA,SAAS;AACT;AACA;AACA;AACA,gCAAgC;AAChC,mBAAmB;AACnB,sBAAsB;AACtB,4BAA4B;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,6DAAK;AAC/B;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,aAAa;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+DAA+D,qCAAqC,EAAE;AACtG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,gEAAS;AACxB;AACA,mBAAmB,kEAAW;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,kBAAkB;AACrD;AACA;AACA,iCAAiC,uBAAuB;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,oBAAoB;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB;AACpB;AACA;AACA,oCAAoC,+BAA+B;AACnE;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,iBAAiB;AACrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B;AAC9B,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB;AACpB;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,2BAA2B,EAAE;AAC3E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB;AACnB,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC;AAChC,oBAAoB;AACpB,sBAAsB;AACtB,4BAA4B;AAC5B;AACA;AACA;AACA,0CAA0C,0BAA0B;AACpE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,8DAAM,0BAA0B,mCAAmC,EAAE,GAAG,6DAAK;AACvG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC,EAAE;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,oEAAY;AAC9B;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,oEAAY,OAAO,8DAAM;AAC3C;AACA,qCAAqC,gCAAgC;AACrE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,wCAAwC,EAAE;AAC1F;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,+DAAQ,GAAG;AAC/B;AACA;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,4DAAK;AACb,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,6DAAM;AACd,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,6DAAM;AACd,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,6DAAM;AACd,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,6DAAM;AACd,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,6DAAM;AACd,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,6DAAM;AACd,QAAQ,iEAAU;AAClB;AACA,IAAI,iEAAU;AACd,QAAQ,6DAAM;AACd,QAAQ,iEAAU;AAClB;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CA,gBAAgB;AAChB;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA,SAAS,OAAO,wDAAS;AACzB;AACA,mDAAmD,sDAAsD,gBAAgB,sBAAsB,eAAe,sBAAsB,WAAW,UAAU,eAAe,gBAAgB,YAAY,gCAAgC,gBAAgB,gBAAgB,WAAW,aAAa,mBAAmB,gBAAgB,2BAA2B,WAAW,uDAAuD,WAAW,gCAAgC,4BAA4B,aAAa,4BAA4B,WAAW,YAAY,aAAa,YAAY,+DAA+D,YAAY,eAAe,WAAW,mBAAmB,mBAAmB,kBAAkB,YAAY,aAAa,sEAAsE,0BAA0B;AACl4B;AACA,iBAAiB,IAAI;AACrB;AACA;AACA,oDAAoD;AACpD,SAAS,OAAO,yDAAU,GAAG;AAC7B,MAAM;AACN;AACA,2BAA2B,OAAO,qDAAM,EAAE;AAC1C,uBAAuB,OAAO,oDAAK,EAAE;AACrC;AACA;AACA,CAAC;;AAED;AACA;AACA,cAAc,WAAW;AACzB;AACA,eAAe,EAAE;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB;AACA;AACA,eAAe,EAAE,sBAAsB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,cAAc,WAAW;AACzB;AACA;AACA;AACA,kCAAkC,2DAAY;AAC9C,iCAAiC,2DAAY;AAC7C,mCAAmC,2DAAY;AAC/C;AACA;AACA;AACA;AACA;AACA,oBAAoB;AACpB;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,eAAe,EAAE;AACjB,eAAe,GAAG;AAClB,gBAAgB;AAChB;AACA;AACA;AACA,eAAe,EAAE;AACjB,eAAe,GAAG;AAClB,gBAAgB;AAChB;AACA;AACA,uCAAuC,sBAAsB;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA,cAAc,WAAW;AACzB;AACA;AACA;AACA;AACA,kCAAkC,EAAE;AACpC;AACA,wBAAwB;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,OAAO,yDAAU,EAAE;AAC5B;AACA;AACA,CAAC;;AAED;AACA;AACA,cAAc,WAAW;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB;AACpB;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,eAAe,GAAG;AAClB,gBAAgB;AAChB;AACA;AACA;AACA;AACA,eAAe,GAAG;AAClB,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA,SAAS,OAAO,wDAAS;AACzB;AACA,6CAA6C,sDAAsD,gBAAgB,sBAAsB,eAAe,eAAe,oBAAoB,gBAAgB,qBAAqB,YAAY,iBAAiB,qBAAqB,uBAAuB,mBAAmB,gBAAgB,2BAA2B,yBAAyB,gCAAgC,UAAU,qBAAqB,UAAU,sBAAsB,gCAAgC,iDAAiD,sBAAsB,eAAe,YAAY,YAAY,sBAAsB;AACnoB;AACA,iBAAiB,IAAI;AACrB;AACA;AACA,8CAA8C;AAC9C,SAAS,8BAA8B;AACvC,SAAS,OAAO,yDAAU,GAAG;AAC7B,SAAS,OAAO,uDAAQ,GAAG;AAC3B,MAAM;AACN;AACA,0BAA0B,OAAO,oDAAK,EAAE;AACxC,mBAAmB,OAAO,oDAAK,EAAE;AACjC;AACA;AACA,CAAC;;AAED;AACA;AACA,cAAc,WAAW;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,GAAG;AAClB,eAAe,GAAG;AAClB,gBAAgB;AAChB;AACA;AACA;AACA;AACA,eAAe,GAAG;AAClB,eAAe,GAAG;AAClB,gBAAgB;AAChB;AACA;AACA,iCAAiC,gBAAgB;AACjD,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,EAAE,WAAW;AAC5B,eAAe,EAAE,UAAU;AAC3B,gBAAgB;AAChB;AACA;AACA;AACA;AACA,eAAe,EAAE,WAAW;AAC5B,eAAe,EAAE,UAAU;AAC3B,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB,uBAAuB,EAAE;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,EAAE;AACjB,gBAAgB;AAChB;AACA;AACA;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","file":"8.c4debb463df3e6f75b71.chunk.js","sourcesContent":["import { Component, ViewChild} from '@angular/core';\r\nimport { IonicPage, NavController, NavParams, ViewController,} from 'ionic-angular';\r\n\r\n/**\r\n * Generated class for the EmailTemplatePage page.\r\n *\r\n * See https://ionicframework.com/docs/components/#navigation for more info on\r\n * Ionic pages and navigation.\r\n */\r\n\r\n@IonicPage()\r\n@Component({\r\n selector: 'page-email-template',\r\n templateUrl: 'email-template.html',\r\n})\r\nexport class EmailTemplatePage {\r\n\r\n // @ViewChild('ioninput') ioninputRef: ElementRef;\r\n @ViewChild('myInput') myInput;\r\n assessmentNameTag = ['#clientfirstname ','#clientlastname ','#practitionertitle ', '#practitionerfirstname ', '#practitionerlastname ', '#profession ', '#recipientname'];\r\n\r\n sendEmail: { title: string, subject: string, body: string, default: boolean } = {\r\n title: '',\r\n subject: '',\r\n body: '',\r\n default: false\r\n };\r\n\r\n constructor(public navCtrl: NavController, public navParams: NavParams, public viewCtrl: ViewController) {\r\n //this.sendEmail.title = 'Email Template'\r\n //this.sendEmail.subject = 'Hello' + ` ` + \"assessment request\";\r\n //this.sendEmail.body = \"Dear \" + `,\r\n\r\n//This is an automated email setup by ` + `who would like you to fill in a questionnaire to check in with you. Please click the link below and follow the prompts to fill in the assessment. The results will be available to ` + ` once you have submitted the assessment.\r\n//Thank you.` + `\\n` + `\\n` +\r\nif (this.navParams.data.template) {\r\n this.sendEmail.body = this.navParams.data.template.body;\r\n this.sendEmail.title = this.navParams.data.template.title;\r\n this.sendEmail.subject = this.navParams.data.template.subject;\r\n this.sendEmail.default = this.navParams.data.template.default;\r\n}\r\n\r\n\r\nthis.getLifeLineText();\r\n \r\n }\r\n\r\n getLifeLineText() {\r\n \r\n return `If you are in need urgent assistance please contact Lifeline on 13 11 14.`\r\n \r\n}\r\n\r\n ionViewDidLoad() {\r\n \r\n }\r\n\r\n saveTemplate(){\r\n this.viewCtrl.dismiss({template: this.sendEmail, dismiss:'done'});\r\n }\r\n\r\n onSelected(textToInsert) {\r\n this.myInput.setFocus();\r\n document.execCommand('insertText', false /*no UI*/, textToInsert);\r\n }\r\n\r\n cancel() {\r\n this.viewCtrl.dismiss({template: this.sendEmail, dismiss:'cancel'});\r\n }\r\n\r\n deleteTemplate(){\r\n this.viewCtrl.dismiss({template: this.sendEmail, dismiss:'delete'})\r\n }\r\n\r\n}\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/pages/email-template/email-template.ts","import { __decorate, __assign, __metadata, __awaiter, __generator, __extends, __spread } from 'tslib';\nimport { Pipe, Injectable, Input, Output, EventEmitter, ViewChild, Component, TemplateRef, HostBinding, HostListener, ElementRef, Renderer2, ChangeDetectorRef, ContentChildren, QueryList, Injector, forwardRef, ContentChild, ViewChildren, NgModule } from '@angular/core';\nimport { FormGroup, FormControl, NG_VALUE_ACCESSOR, ReactiveFormsModule, FormsModule, COMPOSITION_BUFFER_MODE } from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { Ng2Dropdown, Ng2DropdownModule } from 'ng2-material-dropdown';\nimport { debounceTime, filter, first, map } from 'rxjs/operators';\nimport { trigger, state, style, transition, animate, keyframes } from '@angular/animations';\n\nvar escape = function (s) { return s.replace(/[-\\/\\\\^$*+?.()|[\\]{}]/g, '\\\\$&'); };\nvar HighlightPipe = /** @class */ (function () {\n function HighlightPipe() {\n }\n /**\n * @name transform\n * @param value {string}\n * @param arg {string}\n */\n HighlightPipe.prototype.transform = function (value, arg) {\n if (!arg.trim()) {\n return value;\n }\n try {\n var regex = new RegExp(\"(\" + escape(arg) + \")\", 'i');\n return value.replace(regex, '$1');\n }\n catch (e) {\n return value;\n }\n };\n HighlightPipe = __decorate([\n Pipe({\n name: 'highlight'\n })\n ], HighlightPipe);\n return HighlightPipe;\n}());\n\n/*\n** constants and default values for \n */\nvar PLACEHOLDER = '+ Tag';\nvar SECONDARY_PLACEHOLDER = 'Enter a new tag';\nvar KEYDOWN = 'keydown';\nvar KEYUP = 'keyup';\nvar MAX_ITEMS_WARNING = 'The number of items specified was greater than the property max-items.';\nvar ACTIONS_KEYS = {\n DELETE: 'DELETE',\n SWITCH_PREV: 'SWITCH_PREV',\n SWITCH_NEXT: 'SWITCH_NEXT',\n TAB: 'TAB'\n};\nvar KEY_PRESS_ACTIONS = {\n 8: ACTIONS_KEYS.DELETE,\n 37: ACTIONS_KEYS.SWITCH_PREV,\n 39: ACTIONS_KEYS.SWITCH_NEXT,\n 9: ACTIONS_KEYS.TAB\n};\nvar DRAG_AND_DROP_KEY = 'Text';\nvar NEXT = 'NEXT';\nvar PREV = 'PREV';\n\nvar DragProvider = /** @class */ (function () {\n function DragProvider() {\n this.state = {\n dragging: false,\n dropping: false,\n index: undefined\n };\n }\n /**\n * @name setDraggedItem\n * @param event\n * @param tag\n */\n DragProvider.prototype.setDraggedItem = function (event, tag) {\n if (event && event.dataTransfer) {\n event.dataTransfer.setData(DRAG_AND_DROP_KEY, JSON.stringify(tag));\n }\n };\n /**\n * @name getDraggedItem\n * @param event\n */\n DragProvider.prototype.getDraggedItem = function (event) {\n if (event && event.dataTransfer) {\n var data = event.dataTransfer.getData(DRAG_AND_DROP_KEY);\n try {\n return JSON.parse(data);\n }\n catch (_a) {\n return;\n }\n }\n };\n /**\n * @name setSender\n * @param sender\n */\n DragProvider.prototype.setSender = function (sender) {\n this.sender = sender;\n };\n /**\n * @name setReceiver\n * @param receiver\n */\n DragProvider.prototype.setReceiver = function (receiver) {\n this.receiver = receiver;\n };\n /**\n * @name onTagDropped\n * @param tag\n * @param indexDragged\n * @param indexDropped\n */\n DragProvider.prototype.onTagDropped = function (tag, indexDragged, indexDropped) {\n this.onDragEnd();\n this.sender.onRemoveRequested(tag, indexDragged);\n this.receiver.onAddingRequested(false, tag, indexDropped);\n };\n /**\n * @name setState\n * @param state\n */\n DragProvider.prototype.setState = function (state) {\n this.state = __assign({}, this.state, state);\n };\n /**\n * @name getState\n * @param key\n */\n DragProvider.prototype.getState = function (key) {\n return key ? this.state[key] : this.state;\n };\n /**\n * @name onDragEnd\n */\n DragProvider.prototype.onDragEnd = function () {\n this.setState({\n dragging: false,\n dropping: false,\n index: undefined\n });\n };\n DragProvider = __decorate([\n Injectable()\n ], DragProvider);\n return DragProvider;\n}());\n\nvar defaults = {\n tagInput: {\n separatorKeys: [],\n separatorKeyCodes: [],\n maxItems: Infinity,\n placeholder: PLACEHOLDER,\n secondaryPlaceholder: SECONDARY_PLACEHOLDER,\n validators: [],\n asyncValidators: [],\n onlyFromAutocomplete: false,\n errorMessages: {},\n theme: '',\n onTextChangeDebounce: 250,\n inputId: null,\n inputClass: '',\n clearOnBlur: false,\n hideForm: false,\n addOnBlur: false,\n addOnPaste: false,\n pasteSplitPattern: ',',\n blinkIfDupe: true,\n removable: true,\n editable: false,\n allowDupes: false,\n modelAsStrings: false,\n trimTags: true,\n ripple: true,\n tabIndex: '',\n disable: false,\n dragZone: '',\n onRemoving: undefined,\n onAdding: undefined,\n displayBy: 'display',\n identifyBy: 'value',\n animationDuration: {\n enter: '250ms',\n leave: '150ms'\n }\n },\n dropdown: {\n displayBy: 'display',\n identifyBy: 'value',\n appendToBody: true,\n offset: '50 0',\n focusFirstElement: false,\n showDropdownIfEmpty: false,\n minimumTextLength: 1,\n limitItemsTo: Infinity,\n keepOpen: true,\n dynamicUpdate: true,\n zIndex: 1000,\n matchingFn: matchingFn\n }\n};\n/**\n * @name matchingFn\n * @param this\n * @param value\n * @param target\n */\nfunction matchingFn(value, target) {\n var targetValue = target[this.displayBy].toString();\n return targetValue && targetValue\n .toLowerCase()\n .indexOf(value.toLowerCase()) >= 0;\n}\n\nvar OptionsProvider = /** @class */ (function () {\n function OptionsProvider() {\n }\n OptionsProvider.prototype.setOptions = function (options) {\n OptionsProvider.defaults.tagInput = __assign({}, defaults.tagInput, options.tagInput);\n OptionsProvider.defaults.dropdown = __assign({}, defaults.dropdown, options.dropdown);\n };\n OptionsProvider.defaults = defaults;\n return OptionsProvider;\n}());\n\nfunction isObject(obj) {\n return obj === Object(obj);\n}\nvar TagInputAccessor = /** @class */ (function () {\n function TagInputAccessor() {\n this._items = [];\n /**\n * @name displayBy\n */\n this.displayBy = OptionsProvider.defaults.tagInput.displayBy;\n /**\n * @name identifyBy\n */\n this.identifyBy = OptionsProvider.defaults.tagInput.identifyBy;\n }\n Object.defineProperty(TagInputAccessor.prototype, \"items\", {\n get: function () {\n return this._items;\n },\n set: function (items) {\n this._items = items;\n this._onChangeCallback(this._items);\n },\n enumerable: true,\n configurable: true\n });\n TagInputAccessor.prototype.onTouched = function () {\n this._onTouchedCallback();\n };\n TagInputAccessor.prototype.writeValue = function (items) {\n this._items = items || [];\n };\n TagInputAccessor.prototype.registerOnChange = function (fn) {\n this._onChangeCallback = fn;\n };\n TagInputAccessor.prototype.registerOnTouched = function (fn) {\n this._onTouchedCallback = fn;\n };\n /**\n * @name getItemValue\n * @param item\n * @param fromDropdown\n */\n TagInputAccessor.prototype.getItemValue = function (item, fromDropdown) {\n if (fromDropdown === void 0) { fromDropdown = false; }\n var property = fromDropdown && this.dropdown ? this.dropdown.identifyBy : this.identifyBy;\n return isObject(item) ? item[property] : item;\n };\n /**\n * @name getItemDisplay\n * @param item\n * @param fromDropdown\n */\n TagInputAccessor.prototype.getItemDisplay = function (item, fromDropdown) {\n if (fromDropdown === void 0) { fromDropdown = false; }\n var property = fromDropdown && this.dropdown ? this.dropdown.displayBy : this.displayBy;\n return isObject(item) ? item[property] : item;\n };\n /**\n * @name getItemsWithout\n * @param index\n */\n TagInputAccessor.prototype.getItemsWithout = function (index) {\n return this.items.filter(function (item, position) { return position !== index; });\n };\n __decorate([\n Input(),\n __metadata(\"design:type\", String)\n ], TagInputAccessor.prototype, \"displayBy\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", String)\n ], TagInputAccessor.prototype, \"identifyBy\", void 0);\n return TagInputAccessor;\n}());\n\n/**\n * @name listen\n * @param listenerType\n * @param action\n * @param condition\n */\nfunction listen(listenerType, action, condition) {\n if (condition === void 0) { condition = true; }\n // if the event provided does not exist, throw an error\n if (!this.listeners.hasOwnProperty(listenerType)) {\n throw new Error('The event entered may be wrong');\n }\n // if a condition is present and is false, exit early\n if (!condition) {\n return;\n }\n // fire listener\n this.listeners[listenerType].push(action);\n}\n\nvar TagInputForm = /** @class */ (function () {\n function TagInputForm() {\n /**\n * @name onSubmit\n */\n this.onSubmit = new EventEmitter();\n /**\n * @name onBlur\n */\n this.onBlur = new EventEmitter();\n /**\n * @name onFocus\n */\n this.onFocus = new EventEmitter();\n /**\n * @name onKeyup\n */\n this.onKeyup = new EventEmitter();\n /**\n * @name onKeydown\n */\n this.onKeydown = new EventEmitter();\n /**\n * @name inputTextChange\n */\n this.inputTextChange = new EventEmitter();\n /**\n * @name validators\n */\n this.validators = [];\n /**\n * @name asyncValidators\n * @desc array of AsyncValidator that are used to validate the tag before it gets appended to the list\n */\n this.asyncValidators = [];\n /**\n * @name tabindex\n * @desc pass through the specified tabindex to the input\n */\n this.tabindex = '';\n /**\n * @name disabled\n */\n this.disabled = false;\n this.item = new FormControl({ value: '', disabled: this.disabled });\n }\n Object.defineProperty(TagInputForm.prototype, \"inputText\", {\n /**\n * @name inputText\n */\n get: function () {\n return this.item.value;\n },\n /**\n * @name inputText\n * @param text {string}\n */\n set: function (text) {\n this.item.setValue(text);\n this.inputTextChange.emit(text);\n },\n enumerable: true,\n configurable: true\n });\n TagInputForm.prototype.ngOnInit = function () {\n this.item.setValidators(this.validators);\n this.item.setAsyncValidators(this.asyncValidators);\n // creating form\n this.form = new FormGroup({\n item: this.item\n });\n };\n TagInputForm.prototype.ngOnChanges = function (changes) {\n if (changes.disabled && !changes.disabled.firstChange) {\n if (changes.disabled.currentValue) {\n this.form.controls['item'].disable();\n }\n else {\n this.form.controls['item'].enable();\n }\n }\n };\n Object.defineProperty(TagInputForm.prototype, \"value\", {\n /**\n * @name value\n */\n get: function () {\n return this.form.get('item');\n },\n enumerable: true,\n configurable: true\n });\n /**\n * @name isInputFocused\n */\n TagInputForm.prototype.isInputFocused = function () {\n var doc = typeof document !== 'undefined' ? document : undefined;\n return doc ? doc.activeElement === this.input.nativeElement : false;\n };\n /**\n * @name getErrorMessages\n * @param messages\n */\n TagInputForm.prototype.getErrorMessages = function (messages) {\n var _this = this;\n return Object.keys(messages)\n .filter(function (err) { return _this.value.hasError(err); })\n .map(function (err) { return messages[err]; });\n };\n /**\n * @name hasErrors\n */\n TagInputForm.prototype.hasErrors = function () {\n var _a = this.form, dirty = _a.dirty, value = _a.value, valid = _a.valid;\n return dirty && value.item && !valid;\n };\n /**\n * @name focus\n */\n TagInputForm.prototype.focus = function () {\n this.input.nativeElement.focus();\n };\n /**\n * @name blur\n */\n TagInputForm.prototype.blur = function () {\n this.input.nativeElement.blur();\n };\n /**\n * @name getElementPosition\n */\n TagInputForm.prototype.getElementPosition = function () {\n return this.input.nativeElement.getBoundingClientRect();\n };\n /**\n * - removes input from the component\n * @name destroy\n */\n TagInputForm.prototype.destroy = function () {\n var input = this.input.nativeElement;\n input.parentElement.removeChild(input);\n };\n /**\n * @name onKeyDown\n * @param $event\n */\n TagInputForm.prototype.onKeyDown = function ($event) {\n this.inputText = this.value.value;\n if ($event.key === 'Enter') {\n this.submit($event);\n this.inputText = '';\n }\n return this.onKeydown.emit($event);\n };\n /**\n * @name onKeyUp\n * @param $event\n */\n TagInputForm.prototype.onKeyUp = function ($event) {\n this.inputText = this.value.value;\n return this.onKeyup.emit($event);\n };\n /**\n * @name submit\n */\n TagInputForm.prototype.submit = function ($event) {\n $event.preventDefault();\n if (this.form.valid) {\n this.onSubmit.emit($event);\n }\n };\n __decorate([\n Output(),\n __metadata(\"design:type\", EventEmitter)\n ], TagInputForm.prototype, \"onSubmit\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", EventEmitter)\n ], TagInputForm.prototype, \"onBlur\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", EventEmitter)\n ], TagInputForm.prototype, \"onFocus\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", EventEmitter)\n ], TagInputForm.prototype, \"onKeyup\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", EventEmitter)\n ], TagInputForm.prototype, \"onKeydown\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", EventEmitter)\n ], TagInputForm.prototype, \"inputTextChange\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", String)\n ], TagInputForm.prototype, \"placeholder\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Array)\n ], TagInputForm.prototype, \"validators\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Array)\n ], TagInputForm.prototype, \"asyncValidators\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", String)\n ], TagInputForm.prototype, \"inputId\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", String)\n ], TagInputForm.prototype, \"inputClass\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputForm.prototype, \"tabindex\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputForm.prototype, \"disabled\", void 0);\n __decorate([\n ViewChild('input', { static: false }),\n __metadata(\"design:type\", Object)\n ], TagInputForm.prototype, \"input\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", String),\n __metadata(\"design:paramtypes\", [String])\n ], TagInputForm.prototype, \"inputText\", null);\n TagInputForm = __decorate([\n Component({\n selector: 'tag-input-form',\n template: \"\\n\\n \\n\\n\",\n styles: [\".dark tag:focus{box-shadow:0 0 0 1px #323232}.ng2-tag-input.bootstrap3-info{background-color:#fff;display:inline-block;color:#555;vertical-align:middle;max-width:100%;height:42px;line-height:44px}.ng2-tag-input.bootstrap3-info input{border:none;box-shadow:none;outline:0;background-color:transparent;padding:0 6px;margin:0;width:auto;max-width:inherit}.ng2-tag-input.bootstrap3-info .form-control input::-moz-placeholder{color:#777;opacity:1}.ng2-tag-input.bootstrap3-info .form-control input:-ms-input-placeholder{color:#777}.ng2-tag-input.bootstrap3-info .form-control input::-webkit-input-placeholder{color:#777}.ng2-tag-input.bootstrap3-info input:focus{border:none;box-shadow:none}.bootstrap3-info.ng2-tag-input.ng2-tag-input--focused{box-shadow:inset 0 1px 1px rgba(0,0,0,.4);border:1px solid #ccc}.ng2-tag-input{display:block;flex-direction:row;flex-wrap:wrap;position:relative;transition:.25s;padding:.25rem 0;min-height:32px;cursor:text;border-bottom:2px solid #efefef}.ng2-tag-input:focus{outline:0}.ng2-tag-input.ng2-tag-input--dropping{opacity:.7}.ng2-tag-input.ng2-tag-input--focused{border-bottom:2px solid #2196f3}.ng2-tag-input.ng2-tag-input--invalid{border-bottom:2px solid #f44336}.ng2-tag-input.ng2-tag-input--loading{border:none}.ng2-tag-input.ng2-tag-input--disabled{opacity:.5;cursor:not-allowed}.ng2-tag-input form{margin:.1em 0}.ng2-tag-input .ng2-tags-container{flex-wrap:wrap;display:flex}.minimal.ng2-tag-input{display:block;flex-direction:row;flex-wrap:wrap;position:relative;cursor:text;border-bottom:1px solid transparent}.minimal.ng2-tag-input:focus{outline:0}.minimal.ng2-tag-input.ng2-tag-input--dropping{opacity:.7}.minimal.ng2-tag-input.ng2-tag-input--loading{border:none}.minimal.ng2-tag-input.ng2-tag-input--disabled{opacity:.5;cursor:not-allowed}.minimal.ng2-tag-input .ng2-tags-container{flex-wrap:wrap;display:flex}.dark.ng2-tag-input{display:block;flex-direction:row;flex-wrap:wrap;position:relative;cursor:text;border-bottom:2px solid #444}.dark.ng2-tag-input:focus{outline:0}.dark.ng2-tag-input.ng2-tag-input--dropping{opacity:.7}.dark.ng2-tag-input.ng2-tag-input--loading{border:none}.dark.ng2-tag-input.ng2-tag-input--disabled{opacity:.5;cursor:not-allowed}.dark.ng2-tag-input .ng2-tags-container{flex-wrap:wrap;display:flex}.bootstrap.ng2-tag-input{display:block;flex-direction:row;flex-wrap:wrap;position:relative;cursor:text;border-bottom:2px solid #efefef}.bootstrap.ng2-tag-input:focus{outline:0}.bootstrap.ng2-tag-input.ng2-tag-input--dropping{opacity:.7}.bootstrap.ng2-tag-input.ng2-tag-input--focused{border-bottom:2px solid #0275d8}.bootstrap.ng2-tag-input.ng2-tag-input--invalid{border-bottom:2px solid #d9534f}.bootstrap.ng2-tag-input.ng2-tag-input--loading{border:none}.bootstrap.ng2-tag-input.ng2-tag-input--disabled{opacity:.5;cursor:not-allowed}.bootstrap.ng2-tag-input .ng2-tags-container{flex-wrap:wrap;display:flex}.bootstrap3-info.ng2-tag-input{display:block;flex-direction:row;flex-wrap:wrap;position:relative;padding:4px;cursor:text;box-shadow:inset 0 1px 1px rgba(0,0,0,.075);border-radius:4px}.bootstrap3-info.ng2-tag-input:focus{outline:0}.bootstrap3-info.ng2-tag-input.ng2-tag-input--dropping{opacity:.7}.bootstrap3-info.ng2-tag-input.ng2-tag-input--invalid{box-shadow:inset 0 1px 1px #d9534f;border-bottom:1px solid #d9534f}.bootstrap3-info.ng2-tag-input.ng2-tag-input--loading{border:none}.bootstrap3-info.ng2-tag-input.ng2-tag-input--disabled{opacity:.5;cursor:not-allowed}.bootstrap3-info.ng2-tag-input form{margin:.1em 0}.bootstrap3-info.ng2-tag-input .ng2-tags-container{flex-wrap:wrap;display:flex}.error-message{font-size:.8em;color:#f44336;margin:.5em 0 0}.bootstrap .error-message{color:#d9534f}.ng2-tag-input__text-input{display:inline;vertical-align:middle;border:none;padding:0 .5rem;height:38px;font-size:1em;font-family:Roboto,\\\"Helvetica Neue\\\",sans-serif}.ng2-tag-input__text-input:focus{outline:0}.ng2-tag-input__text-input[disabled=true]{opacity:.5;background:#fff}\"]\n })\n ], TagInputForm);\n return TagInputForm;\n}());\n\nvar TagRipple = /** @class */ (function () {\n function TagRipple() {\n this.state = 'none';\n }\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagRipple.prototype, \"state\", void 0);\n TagRipple = __decorate([\n Component({\n selector: 'tag-ripple',\n template: \"\\n \\n \",\n animations: [\n trigger('ink', [\n state('none', style({ width: 0, opacity: 0 })),\n transition('none => clicked', [\n animate(300, keyframes([\n style({ opacity: 1, offset: 0, width: '30%', borderRadius: '100%' }),\n style({ opacity: 1, offset: 0.5, width: '50%' }),\n style({ opacity: 0.5, offset: 1, width: '100%', borderRadius: '16px' })\n ]))\n ])\n ])\n ],\n styles: [\"\\n :host {\\n width: 100%;\\n height: 100%;\\n left: 0;\\n overflow: hidden;\\n position: absolute;\\n }\\n\\n .tag-ripple {\\n background: rgba(0, 0, 0, 0.1);\\n top: 50%;\\n left: 50%;\\n height: 100%;\\n transform: translate(-50%, -50%);\\n position: absolute;\\n }\\n \"]\n })\n ], TagRipple);\n return TagRipple;\n}());\n\n// mocking navigator\nvar navigator = typeof window !== 'undefined' ? window.navigator : {\n userAgent: 'Chrome',\n vendor: 'Google Inc'\n};\nvar isChrome = /Chrome/.test(navigator.userAgent) && /Google Inc/.test(navigator.vendor);\nvar TagComponent = /** @class */ (function () {\n function TagComponent(element, renderer, cdRef) {\n this.element = element;\n this.renderer = renderer;\n this.cdRef = cdRef;\n /**\n * @name disabled\n */\n this.disabled = false;\n /**\n * @name onSelect\n */\n this.onSelect = new EventEmitter();\n /**\n * @name onRemove\n */\n this.onRemove = new EventEmitter();\n /**\n * @name onBlur\n */\n this.onBlur = new EventEmitter();\n /**\n * @name onKeyDown\n */\n this.onKeyDown = new EventEmitter();\n /**\n * @name onTagEdited\n */\n this.onTagEdited = new EventEmitter();\n /**\n * @name editing\n */\n this.editing = false;\n /**\n * @name rippleState\n */\n this.rippleState = 'none';\n }\n Object.defineProperty(TagComponent.prototype, \"readonly\", {\n /**\n * @name readonly {boolean}\n */\n get: function () {\n return typeof this.model !== 'string' && this.model.readonly === true;\n },\n enumerable: true,\n configurable: true\n });\n /**\n * @name select\n */\n TagComponent.prototype.select = function ($event) {\n if (this.readonly || this.disabled) {\n return;\n }\n if ($event) {\n $event.stopPropagation();\n }\n this.focus();\n this.onSelect.emit(this.model);\n };\n /**\n * @name remove\n */\n TagComponent.prototype.remove = function ($event) {\n $event.stopPropagation();\n this.onRemove.emit(this);\n };\n /**\n * @name focus\n */\n TagComponent.prototype.focus = function () {\n this.element.nativeElement.focus();\n };\n TagComponent.prototype.move = function () {\n this.moving = true;\n };\n /**\n * @name keydown\n * @param event\n */\n TagComponent.prototype.keydown = function (event) {\n if (this.editing) {\n if (event.keyCode === 13) {\n return this.disableEditMode(event);\n }\n }\n else {\n this.onKeyDown.emit({ event: event, model: this.model });\n }\n };\n /**\n * @name blink\n */\n TagComponent.prototype.blink = function () {\n var classList = this.element.nativeElement.classList;\n classList.add('blink');\n setTimeout(function () { return classList.remove('blink'); }, 50);\n };\n /**\n * @name toggleEditMode\n */\n TagComponent.prototype.toggleEditMode = function () {\n if (this.editable) {\n return this.editing ? undefined : this.activateEditMode();\n }\n };\n /**\n * @name onBlurred\n * @param event\n */\n TagComponent.prototype.onBlurred = function (event) {\n var _a;\n // Checks if it is editable first before handeling the onBlurred event in order to prevent\n // a bug in IE where tags are still editable with onlyFromAutocomplete set to true\n if (!this.editable) {\n return;\n }\n this.disableEditMode();\n var value = event.target.innerText;\n var result = typeof this.model === 'string'\n ? value\n : __assign({}, this.model, (_a = {}, _a[this.displayBy] = value, _a));\n this.onBlur.emit(result);\n };\n /**\n * @name getDisplayValue\n * @param item\n */\n TagComponent.prototype.getDisplayValue = function (item) {\n return typeof item === 'string' ? item : item[this.displayBy];\n };\n Object.defineProperty(TagComponent.prototype, \"isRippleVisible\", {\n /**\n * @desc returns whether the ripple is visible or not\n * only works in Chrome\n * @name isRippleVisible\n */\n get: function () {\n return !this.readonly && !this.editing && isChrome && this.hasRipple;\n },\n enumerable: true,\n configurable: true\n });\n /**\n * @name disableEditMode\n * @param $event\n */\n TagComponent.prototype.disableEditMode = function ($event) {\n var classList = this.element.nativeElement.classList;\n var input = this.getContentEditableText();\n this.editing = false;\n classList.remove('tag--editing');\n if (!input) {\n this.setContentEditableText(this.model);\n return;\n }\n this.storeNewValue(input);\n this.cdRef.detectChanges();\n if ($event) {\n $event.preventDefault();\n }\n };\n /**\n * @name isDeleteIconVisible\n */\n TagComponent.prototype.isDeleteIconVisible = function () {\n return (!this.readonly && !this.disabled && this.removable && !this.editing);\n };\n /**\n * @name getContentEditableText\n */\n TagComponent.prototype.getContentEditableText = function () {\n var input = this.getContentEditable();\n return input ? input.innerText.trim() : '';\n };\n /**\n * @name setContentEditableText\n * @param model\n */\n TagComponent.prototype.setContentEditableText = function (model) {\n var input = this.getContentEditable();\n var value = this.getDisplayValue(model);\n input.innerText = value;\n };\n /**\n * @name\n */\n TagComponent.prototype.activateEditMode = function () {\n var classList = this.element.nativeElement.classList;\n classList.add('tag--editing');\n this.editing = true;\n };\n /**\n * @name storeNewValue\n * @param input\n */\n TagComponent.prototype.storeNewValue = function (input) {\n var _this = this;\n var _a;\n var exists = function (tag) {\n return typeof tag === 'string'\n ? tag === input\n : tag[_this.displayBy] === input;\n };\n var hasId = function () {\n return _this.model[_this.identifyBy] !== _this.model[_this.displayBy];\n };\n // if the value changed, replace the value in the model\n if (exists(this.model)) {\n return;\n }\n var model = typeof this.model === 'string'\n ? input\n : (_a = {\n index: this.index\n },\n _a[this.identifyBy] = hasId()\n ? this.model[this.identifyBy]\n : input,\n _a[this.displayBy] = input,\n _a);\n if (this.canAddTag(model)) {\n this.onTagEdited.emit({ tag: model, index: this.index });\n }\n else {\n this.setContentEditableText(this.model);\n }\n };\n /**\n * @name getContentEditable\n */\n TagComponent.prototype.getContentEditable = function () {\n return this.element.nativeElement.querySelector('[contenteditable]');\n };\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagComponent.prototype, \"model\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Boolean)\n ], TagComponent.prototype, \"removable\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Boolean)\n ], TagComponent.prototype, \"editable\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", TemplateRef)\n ], TagComponent.prototype, \"template\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", String)\n ], TagComponent.prototype, \"displayBy\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", String)\n ], TagComponent.prototype, \"identifyBy\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Number)\n ], TagComponent.prototype, \"index\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Boolean)\n ], TagComponent.prototype, \"hasRipple\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagComponent.prototype, \"disabled\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Function)\n ], TagComponent.prototype, \"canAddTag\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", EventEmitter)\n ], TagComponent.prototype, \"onSelect\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", EventEmitter)\n ], TagComponent.prototype, \"onRemove\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", EventEmitter)\n ], TagComponent.prototype, \"onBlur\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", EventEmitter)\n ], TagComponent.prototype, \"onKeyDown\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", EventEmitter)\n ], TagComponent.prototype, \"onTagEdited\", void 0);\n __decorate([\n HostBinding('class.moving'),\n __metadata(\"design:type\", Boolean)\n ], TagComponent.prototype, \"moving\", void 0);\n __decorate([\n ViewChild(TagRipple, { static: false }),\n __metadata(\"design:type\", TagRipple)\n ], TagComponent.prototype, \"ripple\", void 0);\n __decorate([\n HostListener('keydown', ['$event']),\n __metadata(\"design:type\", Function),\n __metadata(\"design:paramtypes\", [Object]),\n __metadata(\"design:returntype\", void 0)\n ], TagComponent.prototype, \"keydown\", null);\n TagComponent = __decorate([\n Component({\n selector: 'tag',\n template: \"\\n\\n \\n \\n \\n \\n \\n\\n \\n \\n \\n {{ getDisplayValue(model) }}\\n \\n\\n \\n \\n \\n \\n\\n\\n\\n\\n\",\n styles: [\":host,:host>div,:host>div:focus{outline:0;overflow:hidden;transition:opacity 1s;z-index:1}:host{max-width:400px}:host.blink{-webkit-animation:.3s ease-in-out forwards blink;animation:.3s ease-in-out forwards blink}@-webkit-keyframes blink{0%{opacity:.3}}@keyframes blink{0%{opacity:.3}}:host .disabled{cursor:not-allowed}:host [contenteditable=true]{outline:0}.tag-wrapper{flex-direction:row;display:flex}.tag__text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}\"]\n }),\n __metadata(\"design:paramtypes\", [ElementRef,\n Renderer2,\n ChangeDetectorRef])\n ], TagComponent);\n return TagComponent;\n}());\n\n/**\n * @name animations\n */\nvar animations = [\n trigger('animation', [\n state('in', style({\n opacity: 1\n })),\n state('out', style({\n opacity: 0\n })),\n transition(':enter', [\n animate('{{ enter }}', keyframes([\n style({ opacity: 0, offset: 0, transform: 'translate(0px, 20px)' }),\n style({ opacity: 0.3, offset: 0.3, transform: 'translate(0px, -10px)' }),\n style({ opacity: 0.5, offset: 0.5, transform: 'translate(0px, 0px)' }),\n style({ opacity: 0.75, offset: 0.75, transform: 'translate(0px, 5px)' }),\n style({ opacity: 1, offset: 1, transform: 'translate(0px, 0px)' })\n ]))\n ]),\n transition(':leave', [\n animate('{{ leave }}', keyframes([\n style({ opacity: 1, transform: 'translateX(0)', offset: 0 }),\n style({ opacity: 1, transform: 'translateX(-15px)', offset: 0.7 }),\n style({ opacity: 0, transform: 'translateX(100%)', offset: 1.0 })\n ]))\n ])\n ])\n];\n\nvar TagInputDropdown = /** @class */ (function () {\n function TagInputDropdown(injector) {\n var _this = this;\n this.injector = injector;\n /**\n * @name offset\n */\n this.offset = defaults.dropdown.offset;\n /**\n * @name focusFirstElement\n */\n this.focusFirstElement = defaults.dropdown.focusFirstElement;\n /**\n * - show autocomplete dropdown if the value of input is empty\n * @name showDropdownIfEmpty\n */\n this.showDropdownIfEmpty = defaults.dropdown.showDropdownIfEmpty;\n /**\n * - desc minimum text length in order to display the autocomplete dropdown\n * @name minimumTextLength\n */\n this.minimumTextLength = defaults.dropdown.minimumTextLength;\n /**\n * - number of items to display in the autocomplete dropdown\n * @name limitItemsTo\n */\n this.limitItemsTo = defaults.dropdown.limitItemsTo;\n /**\n * @name displayBy\n */\n this.displayBy = defaults.dropdown.displayBy;\n /**\n * @name identifyBy\n */\n this.identifyBy = defaults.dropdown.identifyBy;\n /**\n * @description a function a developer can use to implement custom matching for the autocomplete\n * @name matchingFn\n */\n this.matchingFn = defaults.dropdown.matchingFn;\n /**\n * @name appendToBody\n */\n this.appendToBody = defaults.dropdown.appendToBody;\n /**\n * @name keepOpen\n * @description option to leave dropdown open when adding a new item\n */\n this.keepOpen = defaults.dropdown.keepOpen;\n /**\n * @name dynamicUpdate\n */\n this.dynamicUpdate = defaults.dropdown.dynamicUpdate;\n /**\n * @name zIndex\n */\n this.zIndex = defaults.dropdown.zIndex;\n /**\n * list of items that match the current value of the input (for autocomplete)\n * @name items\n */\n this.items = [];\n /**\n * @name tagInput\n */\n this.tagInput = this.injector.get(TagInputComponent);\n /**\n * @name _autocompleteItems\n */\n this._autocompleteItems = [];\n /**\n *\n * @name show\n */\n this.show = function () {\n var maxItemsReached = _this.tagInput.items.length === _this.tagInput.maxItems;\n var value = _this.getFormValue();\n var hasMinimumText = value.trim().length >= _this.minimumTextLength;\n var position = _this.calculatePosition();\n var items = _this.getMatchingItems(value);\n var hasItems = items.length > 0;\n var isHidden = _this.isVisible === false;\n var showDropdownIfEmpty = _this.showDropdownIfEmpty && hasItems && !value;\n var isDisabled = _this.tagInput.disable;\n var shouldShow = isHidden && ((hasItems && hasMinimumText) || showDropdownIfEmpty);\n var shouldHide = _this.isVisible && !hasItems;\n if (_this.autocompleteObservable && hasMinimumText) {\n return _this.getItemsFromObservable(value);\n }\n if ((!_this.showDropdownIfEmpty && !value) || maxItemsReached || isDisabled) {\n return _this.dropdown.hide();\n }\n _this.setItems(items);\n if (shouldShow) {\n _this.dropdown.show(position);\n }\n else if (shouldHide) {\n _this.hide();\n }\n };\n /**\n * @name requestAdding\n * @param item {Ng2MenuItem}\n */\n this.requestAdding = function (item) { return __awaiter(_this, void 0, void 0, function () {\n var tag;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n tag = this.createTagModel(item);\n return [4 /*yield*/, this.tagInput.onAddingRequested(true, tag).catch(function () { })];\n case 1:\n _a.sent();\n return [2 /*return*/];\n }\n });\n }); };\n /**\n * @name resetItems\n */\n this.resetItems = function () {\n _this.items = [];\n };\n /**\n * @name getItemsFromObservable\n * @param text\n */\n this.getItemsFromObservable = function (text) {\n _this.setLoadingState(true);\n var subscribeFn = function (data) {\n // hide loading animation\n _this.setLoadingState(false)\n // add items\n .populateItems(data);\n _this.setItems(_this.getMatchingItems(text));\n if (_this.items.length) {\n _this.dropdown.show(_this.calculatePosition());\n }\n else {\n _this.dropdown.hide();\n }\n };\n _this.autocompleteObservable(text)\n .pipe(first())\n .subscribe(subscribeFn, function () { return _this.setLoadingState(false); });\n };\n }\n Object.defineProperty(TagInputDropdown.prototype, \"autocompleteItems\", {\n /**\n * @name autocompleteItems\n * @desc array of items that will populate the autocomplete\n */\n get: function () {\n var _this = this;\n var items = this._autocompleteItems;\n if (!items) {\n return [];\n }\n return items.map(function (item) {\n var _a;\n return typeof item === 'string' ? (_a = {},\n _a[_this.displayBy] = item,\n _a[_this.identifyBy] = item,\n _a) : item;\n });\n },\n /**\n * @name autocompleteItems\n * @param items\n */\n set: function (items) {\n this._autocompleteItems = items;\n },\n enumerable: true,\n configurable: true\n });\n /**\n * @name ngAfterviewInit\n */\n TagInputDropdown.prototype.ngAfterViewInit = function () {\n var _this = this;\n this.onItemClicked().subscribe(function (item) {\n _this.requestAdding(item);\n });\n // reset itemsMatching array when the dropdown is hidden\n this.onHide().subscribe(this.resetItems);\n var DEBOUNCE_TIME = 200;\n var KEEP_OPEN = this.keepOpen;\n this.tagInput\n .onTextChange\n .asObservable()\n .pipe(debounceTime(DEBOUNCE_TIME), filter(function (value) {\n if (KEEP_OPEN === false) {\n return value.length > 0;\n }\n return true;\n }))\n .subscribe(this.show);\n };\n /**\n * @name updatePosition\n */\n TagInputDropdown.prototype.updatePosition = function () {\n var position = this.tagInput.inputForm.getElementPosition();\n this.dropdown.menu.updatePosition(position, this.dynamicUpdate);\n };\n Object.defineProperty(TagInputDropdown.prototype, \"isVisible\", {\n /**\n * @name isVisible\n */\n get: function () {\n return this.dropdown.menu.state.menuState.isVisible;\n },\n enumerable: true,\n configurable: true\n });\n /**\n * @name onHide\n */\n TagInputDropdown.prototype.onHide = function () {\n return this.dropdown.onHide;\n };\n /**\n * @name onItemClicked\n */\n TagInputDropdown.prototype.onItemClicked = function () {\n return this.dropdown.onItemClicked;\n };\n Object.defineProperty(TagInputDropdown.prototype, \"selectedItem\", {\n /**\n * @name selectedItem\n */\n get: function () {\n return this.dropdown.menu.state.dropdownState.selectedItem;\n },\n enumerable: true,\n configurable: true\n });\n Object.defineProperty(TagInputDropdown.prototype, \"state\", {\n /**\n * @name state\n */\n get: function () {\n return this.dropdown.menu.state;\n },\n enumerable: true,\n configurable: true\n });\n /**\n * @name hide\n */\n TagInputDropdown.prototype.hide = function () {\n this.resetItems();\n this.dropdown.hide();\n };\n /**\n * @name scrollListener\n */\n TagInputDropdown.prototype.scrollListener = function () {\n if (!this.isVisible || !this.dynamicUpdate) {\n return;\n }\n this.updatePosition();\n };\n /**\n * @name onWindowBlur\n */\n TagInputDropdown.prototype.onWindowBlur = function () {\n this.dropdown.hide();\n };\n /**\n * @name getFormValue\n */\n TagInputDropdown.prototype.getFormValue = function () {\n var formValue = this.tagInput.formValue;\n return formValue ? formValue.toString().trim() : '';\n };\n /**\n * @name calculatePosition\n */\n TagInputDropdown.prototype.calculatePosition = function () {\n return this.tagInput.inputForm.getElementPosition();\n };\n /**\n * @name createTagModel\n * @param item\n */\n TagInputDropdown.prototype.createTagModel = function (item) {\n var _a;\n var display = typeof item.value === 'string' ? item.value : item.value[this.displayBy];\n var value = typeof item.value === 'string' ? item.value : item.value[this.identifyBy];\n return __assign({}, item.value, (_a = {}, _a[this.tagInput.displayBy] = display, _a[this.tagInput.identifyBy] = value, _a));\n };\n /**\n *\n * @param value {string}\n */\n TagInputDropdown.prototype.getMatchingItems = function (value) {\n var _this = this;\n if (!value && !this.showDropdownIfEmpty) {\n return [];\n }\n var dupesAllowed = this.tagInput.allowDupes;\n return this.autocompleteItems.filter(function (item) {\n var hasValue = dupesAllowed ? false : _this.tagInput.tags.some(function (tag) {\n var identifyBy = _this.tagInput.identifyBy;\n var model = typeof tag.model === 'string' ? tag.model : tag.model[identifyBy];\n return model === item[_this.identifyBy];\n });\n return _this.matchingFn(value, item) && (hasValue === false);\n });\n };\n /**\n * @name setItems\n */\n TagInputDropdown.prototype.setItems = function (items) {\n this.items = items.slice(0, this.limitItemsTo || items.length);\n };\n /**\n * @name populateItems\n * @param data\n */\n TagInputDropdown.prototype.populateItems = function (data) {\n var _this = this;\n this.autocompleteItems = data.map(function (item) {\n var _a;\n return typeof item === 'string' ? (_a = {},\n _a[_this.displayBy] = item,\n _a[_this.identifyBy] = item,\n _a) : item;\n });\n return this;\n };\n /**\n * @name setLoadingState\n * @param state\n */\n TagInputDropdown.prototype.setLoadingState = function (state) {\n this.tagInput.isLoading = state;\n return this;\n };\n __decorate([\n ViewChild(Ng2Dropdown, { static: false }),\n __metadata(\"design:type\", Ng2Dropdown)\n ], TagInputDropdown.prototype, \"dropdown\", void 0);\n __decorate([\n ContentChildren(TemplateRef),\n __metadata(\"design:type\", QueryList)\n ], TagInputDropdown.prototype, \"templates\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", String)\n ], TagInputDropdown.prototype, \"offset\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputDropdown.prototype, \"focusFirstElement\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputDropdown.prototype, \"showDropdownIfEmpty\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Function)\n ], TagInputDropdown.prototype, \"autocompleteObservable\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputDropdown.prototype, \"minimumTextLength\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Number)\n ], TagInputDropdown.prototype, \"limitItemsTo\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputDropdown.prototype, \"displayBy\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputDropdown.prototype, \"identifyBy\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Function)\n ], TagInputDropdown.prototype, \"matchingFn\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputDropdown.prototype, \"appendToBody\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputDropdown.prototype, \"keepOpen\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputDropdown.prototype, \"dynamicUpdate\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputDropdown.prototype, \"zIndex\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Array),\n __metadata(\"design:paramtypes\", [Array])\n ], TagInputDropdown.prototype, \"autocompleteItems\", null);\n __decorate([\n HostListener('window:scroll'),\n __metadata(\"design:type\", Function),\n __metadata(\"design:paramtypes\", []),\n __metadata(\"design:returntype\", void 0)\n ], TagInputDropdown.prototype, \"scrollListener\", null);\n __decorate([\n HostListener('window:blur'),\n __metadata(\"design:type\", Function),\n __metadata(\"design:paramtypes\", []),\n __metadata(\"design:returntype\", void 0)\n ], TagInputDropdown.prototype, \"onWindowBlur\", null);\n TagInputDropdown = __decorate([\n Component({\n selector: 'tag-input-dropdown',\n template: \"\\n \\n \\n\\n \\n \\n\\n \\n \\n \\n \\n\\n\"\n }),\n __metadata(\"design:paramtypes\", [Injector])\n ], TagInputDropdown);\n return TagInputDropdown;\n}());\n\n// angular universal hacks\n/* tslint:disable-next-line */\nvar DragEvent = window.DragEvent;\nvar CUSTOM_ACCESSOR = {\n provide: NG_VALUE_ACCESSOR,\n useExisting: forwardRef(function () { return TagInputComponent; }),\n multi: true\n};\nvar TagInputComponent = /** @class */ (function (_super) {\n __extends(TagInputComponent, _super);\n function TagInputComponent(renderer, dragProvider) {\n var _a;\n var _this = _super.call(this) || this;\n _this.renderer = renderer;\n _this.dragProvider = dragProvider;\n /**\n * @name separatorKeys\n * @desc keyboard keys with which a user can separate items\n */\n _this.separatorKeys = defaults.tagInput.separatorKeys;\n /**\n * @name separatorKeyCodes\n * @desc keyboard key codes with which a user can separate items\n */\n _this.separatorKeyCodes = defaults.tagInput.separatorKeyCodes;\n /**\n * @name placeholder\n * @desc the placeholder of the input text\n */\n _this.placeholder = defaults.tagInput.placeholder;\n /**\n * @name secondaryPlaceholder\n * @desc placeholder to appear when the input is empty\n */\n _this.secondaryPlaceholder = defaults.tagInput.secondaryPlaceholder;\n /**\n * @name maxItems\n * @desc maximum number of items that can be added\n */\n _this.maxItems = defaults.tagInput.maxItems;\n /**\n * @name validators\n * @desc array of Validators that are used to validate the tag before it gets appended to the list\n */\n _this.validators = defaults.tagInput.validators;\n /**\n * @name asyncValidators\n * @desc array of AsyncValidator that are used to validate the tag before it gets appended to the list\n */\n _this.asyncValidators = defaults.tagInput.asyncValidators;\n /**\n * - if set to true, it will only possible to add items from the autocomplete\n * @name onlyFromAutocomplete\n */\n _this.onlyFromAutocomplete = defaults.tagInput.onlyFromAutocomplete;\n /**\n * @name errorMessages\n */\n _this.errorMessages = defaults.tagInput.errorMessages;\n /**\n * @name theme\n */\n _this.theme = defaults.tagInput.theme;\n /**\n * @name onTextChangeDebounce\n */\n _this.onTextChangeDebounce = defaults.tagInput.onTextChangeDebounce;\n /**\n * - custom id assigned to the input\n * @name id\n */\n _this.inputId = defaults.tagInput.inputId;\n /**\n * - custom class assigned to the input\n */\n _this.inputClass = defaults.tagInput.inputClass;\n /**\n * - option to clear text input when the form is blurred\n * @name clearOnBlur\n */\n _this.clearOnBlur = defaults.tagInput.clearOnBlur;\n /**\n * - hideForm\n * @name clearOnBlur\n */\n _this.hideForm = defaults.tagInput.hideForm;\n /**\n * @name addOnBlur\n */\n _this.addOnBlur = defaults.tagInput.addOnBlur;\n /**\n * @name addOnPaste\n */\n _this.addOnPaste = defaults.tagInput.addOnPaste;\n /**\n * - pattern used with the native method split() to separate patterns in the string pasted\n * @name pasteSplitPattern\n */\n _this.pasteSplitPattern = defaults.tagInput.pasteSplitPattern;\n /**\n * @name blinkIfDupe\n */\n _this.blinkIfDupe = defaults.tagInput.blinkIfDupe;\n /**\n * @name removable\n */\n _this.removable = defaults.tagInput.removable;\n /**\n * @name editable\n */\n _this.editable = defaults.tagInput.editable;\n /**\n * @name allowDupes\n */\n _this.allowDupes = defaults.tagInput.allowDupes;\n /**\n * @description if set to true, the newly added tags will be added as strings, and not objects\n * @name modelAsStrings\n */\n _this.modelAsStrings = defaults.tagInput.modelAsStrings;\n /**\n * @name trimTags\n */\n _this.trimTags = defaults.tagInput.trimTags;\n /**\n * @name ripple\n */\n _this.ripple = defaults.tagInput.ripple;\n /**\n * @name tabindex\n * @desc pass through the specified tabindex to the input\n */\n _this.tabindex = defaults.tagInput.tabIndex;\n /**\n * @name disable\n */\n _this.disable = defaults.tagInput.disable;\n /**\n * @name dragZone\n */\n _this.dragZone = defaults.tagInput.dragZone;\n /**\n * @name onRemoving\n */\n _this.onRemoving = defaults.tagInput.onRemoving;\n /**\n * @name onAdding\n */\n _this.onAdding = defaults.tagInput.onAdding;\n /**\n * @name animationDuration\n */\n _this.animationDuration = defaults.tagInput.animationDuration;\n /**\n * @name onAdd\n * @desc event emitted when adding a new item\n */\n _this.onAdd = new EventEmitter();\n /**\n * @name onRemove\n * @desc event emitted when removing an existing item\n */\n _this.onRemove = new EventEmitter();\n /**\n * @name onSelect\n * @desc event emitted when selecting an item\n */\n _this.onSelect = new EventEmitter();\n /**\n * @name onFocus\n * @desc event emitted when the input is focused\n */\n _this.onFocus = new EventEmitter();\n /**\n * @name onFocus\n * @desc event emitted when the input is blurred\n */\n _this.onBlur = new EventEmitter();\n /**\n * @name onTextChange\n * @desc event emitted when the input value changes\n */\n _this.onTextChange = new EventEmitter();\n /**\n * - output triggered when text is pasted in the form\n * @name onPaste\n */\n _this.onPaste = new EventEmitter();\n /**\n * - output triggered when tag entered is not valid\n * @name onValidationError\n */\n _this.onValidationError = new EventEmitter();\n /**\n * - output triggered when tag is edited\n * @name onTagEdited\n */\n _this.onTagEdited = new EventEmitter();\n /**\n * @name isLoading\n */\n _this.isLoading = false;\n /**\n * @name listeners\n * @desc array of events that get fired using @fireEvents\n */\n _this.listeners = (_a = {},\n _a[KEYDOWN] = [],\n _a[KEYUP] = [],\n _a);\n /**\n * @description emitter for the 2-way data binding inputText value\n * @name inputTextChange\n */\n _this.inputTextChange = new EventEmitter();\n /**\n * @description private variable to bind get/set\n * @name inputTextValue\n */\n _this.inputTextValue = '';\n _this.errors = [];\n /**\n * @name appendTag\n * @param tag {TagModel}\n */\n _this.appendTag = function (tag, index) {\n if (index === void 0) { index = _this.items.length; }\n var items = _this.items;\n var model = _this.modelAsStrings ? tag[_this.identifyBy] : tag;\n _this.items = __spread(items.slice(0, index), [\n model\n ], items.slice(index, items.length));\n };\n /**\n * @name createTag\n * @param model\n */\n _this.createTag = function (model) {\n var _a;\n var trim = function (val, key) {\n return typeof val === 'string' ? val.trim() : val[key];\n };\n return __assign({}, typeof model !== 'string' ? model : {}, (_a = {}, _a[_this.displayBy] = _this.trimTags ? trim(model, _this.displayBy) : model, _a[_this.identifyBy] = _this.trimTags ? trim(model, _this.identifyBy) : model, _a));\n };\n /**\n *\n * @param tag\n * @param isFromAutocomplete\n */\n _this.isTagValid = function (tag, fromAutocomplete) {\n if (fromAutocomplete === void 0) { fromAutocomplete = false; }\n var selectedItem = _this.dropdown ? _this.dropdown.selectedItem : undefined;\n var value = _this.getItemDisplay(tag).trim();\n if (selectedItem && !fromAutocomplete || !value) {\n return false;\n }\n var dupe = _this.findDupe(tag, fromAutocomplete);\n // if so, give a visual cue and return false\n if (!_this.allowDupes && dupe && _this.blinkIfDupe) {\n var model = _this.tags.find(function (item) {\n return _this.getItemValue(item.model) === _this.getItemValue(dupe);\n });\n if (model) {\n model.blink();\n }\n }\n var isFromAutocomplete = fromAutocomplete && _this.onlyFromAutocomplete;\n var assertions = [\n // 1. there must be no dupe OR dupes are allowed\n !dupe || _this.allowDupes,\n // 2. check max items has not been reached\n !_this.maxItemsReached,\n // 3. check item comes from autocomplete or onlyFromAutocomplete is false\n ((isFromAutocomplete) || !_this.onlyFromAutocomplete)\n ];\n return assertions.filter(Boolean).length === assertions.length;\n };\n /**\n * @name onPasteCallback\n * @param data\n */\n _this.onPasteCallback = function (data) { return __awaiter(_this, void 0, void 0, function () {\n var getText, text, requests, resetInput;\n var _this = this;\n return __generator(this, function (_a) {\n getText = function () {\n var isIE = Boolean(window.clipboardData);\n var clipboardData = isIE ? (window.clipboardData) : data.clipboardData;\n var type = isIE ? 'Text' : 'text/plain';\n return clipboardData === null ? '' : clipboardData.getData(type) || '';\n };\n text = getText();\n requests = text\n .split(this.pasteSplitPattern)\n .map(function (item) {\n var tag = _this.createTag(item);\n _this.setInputValue(tag[_this.displayBy]);\n return _this.onAddingRequested(false, tag);\n });\n resetInput = function () { return setTimeout(function () { return _this.setInputValue(''); }, 50); };\n Promise.all(requests).then(function () {\n _this.onPaste.emit(text);\n resetInput();\n })\n .catch(resetInput);\n return [2 /*return*/];\n });\n }); };\n return _this;\n }\n Object.defineProperty(TagInputComponent.prototype, \"inputText\", {\n /**\n * @name inputText\n */\n get: function () {\n return this.inputTextValue;\n },\n /**\n * @name inputText\n * @param text\n */\n set: function (text) {\n this.inputTextValue = text;\n this.inputTextChange.emit(text);\n },\n enumerable: true,\n configurable: true\n });\n Object.defineProperty(TagInputComponent.prototype, \"tabindexAttr\", {\n /**\n * @desc removes the tab index if it is set - it will be passed through to the input\n * @name tabindexAttr\n */\n get: function () {\n return this.tabindex !== '' ? '-1' : '';\n },\n enumerable: true,\n configurable: true\n });\n /**\n * @name ngAfterViewInit\n */\n TagInputComponent.prototype.ngAfterViewInit = function () {\n // set up listeners\n var _this = this;\n this.setUpKeypressListeners();\n this.setupSeparatorKeysListener();\n this.setUpInputKeydownListeners();\n if (this.onTextChange.observers.length) {\n this.setUpTextChangeSubscriber();\n }\n // if clear on blur is set to true, subscribe to the event and clear the text's form\n if (this.clearOnBlur || this.addOnBlur) {\n this.setUpOnBlurSubscriber();\n }\n // if addOnPaste is set to true, register the handler and add items\n if (this.addOnPaste) {\n this.setUpOnPasteListener();\n }\n var statusChanges$ = this.inputForm.form.statusChanges;\n statusChanges$.pipe(filter(function (status) { return status !== 'PENDING'; })).subscribe(function () {\n _this.errors = _this.inputForm.getErrorMessages(_this.errorMessages);\n });\n this.isProgressBarVisible$ = statusChanges$.pipe(map(function (status) {\n return status === 'PENDING' || _this.isLoading;\n }));\n // if hideForm is set to true, remove the input\n if (this.hideForm) {\n this.inputForm.destroy();\n }\n };\n /**\n * @name ngOnInit\n */\n TagInputComponent.prototype.ngOnInit = function () {\n // if the number of items specified in the model is > of the value of maxItems\n // degrade gracefully and let the max number of items to be the number of items in the model\n // though, warn the user.\n var hasReachedMaxItems = this.maxItems !== undefined &&\n this.items &&\n this.items.length > this.maxItems;\n if (hasReachedMaxItems) {\n this.maxItems = this.items.length;\n console.warn(MAX_ITEMS_WARNING);\n }\n // Setting editable to false to fix problem with tags in IE still being editable when\n // onlyFromAutocomplete is true\n this.editable = this.onlyFromAutocomplete ? false : this.editable;\n this.setAnimationMetadata();\n };\n /**\n * @name onRemoveRequested\n * @param tag\n * @param index\n */\n TagInputComponent.prototype.onRemoveRequested = function (tag, index) {\n var _this = this;\n return new Promise(function (resolve) {\n var subscribeFn = function (model) {\n _this.removeItem(model, index);\n resolve(tag);\n };\n _this.onRemoving ?\n _this.onRemoving(tag)\n .pipe(first())\n .subscribe(subscribeFn) : subscribeFn(tag);\n });\n };\n /**\n * @name onAddingRequested\n * @param fromAutocomplete {boolean}\n * @param tag {TagModel}\n * @param index? {number}\n * @param giveupFocus? {boolean}\n */\n TagInputComponent.prototype.onAddingRequested = function (fromAutocomplete, tag, index, giveupFocus) {\n var _this = this;\n return new Promise(function (resolve, reject) {\n var subscribeFn = function (model) {\n return _this\n .addItem(fromAutocomplete, model, index, giveupFocus)\n .then(resolve)\n .catch(reject);\n };\n return _this.onAdding ?\n _this.onAdding(tag)\n .pipe(first())\n .subscribe(subscribeFn, reject) : subscribeFn(tag);\n });\n };\n /**\n * @name selectItem\n * @desc selects item passed as parameter as the selected tag\n * @param item\n * @param emit\n */\n TagInputComponent.prototype.selectItem = function (item, emit) {\n if (emit === void 0) { emit = true; }\n var isReadonly = item && typeof item !== 'string' && item.readonly;\n if (isReadonly || this.selectedTag === item) {\n return;\n }\n this.selectedTag = item;\n if (emit) {\n this.onSelect.emit(item);\n }\n };\n /**\n * @name fireEvents\n * @desc goes through the list of the events for a given eventName, and fires each of them\n * @param eventName\n * @param $event\n */\n TagInputComponent.prototype.fireEvents = function (eventName, $event) {\n var _this = this;\n this.listeners[eventName].forEach(function (listener) { return listener.call(_this, $event); });\n };\n /**\n * @name handleKeydown\n * @desc handles action when the user hits a keyboard key\n * @param data\n */\n TagInputComponent.prototype.handleKeydown = function (data) {\n var event = data.event;\n var key = event.keyCode || event.which;\n var shiftKey = event.shiftKey || false;\n switch (KEY_PRESS_ACTIONS[key]) {\n case ACTIONS_KEYS.DELETE:\n if (this.selectedTag && this.removable) {\n var index = this.items.indexOf(this.selectedTag);\n this.onRemoveRequested(this.selectedTag, index);\n }\n break;\n case ACTIONS_KEYS.SWITCH_PREV:\n this.moveToTag(data.model, PREV);\n break;\n case ACTIONS_KEYS.SWITCH_NEXT:\n this.moveToTag(data.model, NEXT);\n break;\n case ACTIONS_KEYS.TAB:\n if (shiftKey) {\n if (this.isFirstTag(data.model)) {\n return;\n }\n this.moveToTag(data.model, PREV);\n }\n else {\n if (this.isLastTag(data.model) && (this.disable || this.maxItemsReached)) {\n return;\n }\n this.moveToTag(data.model, NEXT);\n }\n break;\n default:\n return;\n }\n // prevent default behaviour\n event.preventDefault();\n };\n TagInputComponent.prototype.onFormSubmit = function () {\n return __awaiter(this, void 0, void 0, function () {\n var _a;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n _b.trys.push([0, 2, , 3]);\n return [4 /*yield*/, this.onAddingRequested(false, this.formValue)];\n case 1:\n _b.sent();\n return [3 /*break*/, 3];\n case 2:\n _a = _b.sent();\n return [2 /*return*/];\n case 3: return [2 /*return*/];\n }\n });\n });\n };\n /**\n * @name setInputValue\n * @param value\n */\n TagInputComponent.prototype.setInputValue = function (value, emitEvent) {\n if (emitEvent === void 0) { emitEvent = true; }\n var control = this.getControl();\n // update form value with the transformed item\n control.setValue(value, { emitEvent: emitEvent });\n };\n /**\n * @name getControl\n */\n TagInputComponent.prototype.getControl = function () {\n return this.inputForm.value;\n };\n /**\n * @name focus\n * @param applyFocus\n * @param displayAutocomplete\n */\n TagInputComponent.prototype.focus = function (applyFocus, displayAutocomplete) {\n if (applyFocus === void 0) { applyFocus = false; }\n if (this.dragProvider.getState('dragging')) {\n return;\n }\n this.selectItem(undefined, false);\n if (applyFocus) {\n this.inputForm.focus();\n this.onFocus.emit(this.formValue);\n }\n };\n /**\n * @name blur\n */\n TagInputComponent.prototype.blur = function () {\n this.onTouched();\n this.onBlur.emit(this.formValue);\n };\n /**\n * @name hasErrors\n */\n TagInputComponent.prototype.hasErrors = function () {\n return !!this.inputForm && this.inputForm.hasErrors();\n };\n /**\n * @name isInputFocused\n */\n TagInputComponent.prototype.isInputFocused = function () {\n return !!this.inputForm && this.inputForm.isInputFocused();\n };\n /**\n * - this is the one way I found to tell if the template has been passed and it is not\n * the template for the menu item\n * @name hasCustomTemplate\n */\n TagInputComponent.prototype.hasCustomTemplate = function () {\n var template = this.templates ? this.templates.first : undefined;\n var menuTemplate = this.dropdown && this.dropdown.templates ?\n this.dropdown.templates.first : undefined;\n return Boolean(template && template !== menuTemplate);\n };\n Object.defineProperty(TagInputComponent.prototype, \"maxItemsReached\", {\n /**\n * @name maxItemsReached\n */\n get: function () {\n return this.maxItems !== undefined &&\n this.items.length >= this.maxItems;\n },\n enumerable: true,\n configurable: true\n });\n Object.defineProperty(TagInputComponent.prototype, \"formValue\", {\n /**\n * @name formValue\n */\n get: function () {\n var form = this.inputForm.value;\n return form ? form.value : '';\n },\n enumerable: true,\n configurable: true\n });\n /**3\n * @name onDragStarted\n * @param event\n * @param index\n */\n TagInputComponent.prototype.onDragStarted = function (event, tag, index) {\n event.stopPropagation();\n var item = { zone: this.dragZone, tag: tag, index: index };\n this.dragProvider.setSender(this);\n this.dragProvider.setDraggedItem(event, item);\n this.dragProvider.setState({ dragging: true, index: index });\n };\n /**\n * @name onDragOver\n * @param event\n */\n TagInputComponent.prototype.onDragOver = function (event, index) {\n this.dragProvider.setState({ dropping: true });\n this.dragProvider.setReceiver(this);\n event.preventDefault();\n };\n /**\n * @name onTagDropped\n * @param event\n * @param index\n */\n TagInputComponent.prototype.onTagDropped = function (event, index) {\n var item = this.dragProvider.getDraggedItem(event);\n if (!item || item.zone !== this.dragZone) {\n return;\n }\n this.dragProvider.onTagDropped(item.tag, item.index, index);\n event.preventDefault();\n event.stopPropagation();\n };\n /**\n * @name isDropping\n */\n TagInputComponent.prototype.isDropping = function () {\n var isReceiver = this.dragProvider.receiver === this;\n var isDropping = this.dragProvider.getState('dropping');\n return Boolean(isReceiver && isDropping);\n };\n /**\n * @name onTagBlurred\n * @param changedElement {TagModel}\n * @param index {number}\n */\n TagInputComponent.prototype.onTagBlurred = function (changedElement, index) {\n this.items[index] = changedElement;\n this.blur();\n };\n /**\n * @name trackBy\n * @param items\n */\n TagInputComponent.prototype.trackBy = function (index, item) {\n return item[this.identifyBy];\n };\n /**\n * @name updateEditedTag\n * @param tag\n */\n TagInputComponent.prototype.updateEditedTag = function (_a) {\n var tag = _a.tag, index = _a.index;\n this.onTagEdited.emit(tag);\n };\n /**\n * @name moveToTag\n * @param item\n * @param direction\n */\n TagInputComponent.prototype.moveToTag = function (item, direction) {\n var isLast = this.isLastTag(item);\n var isFirst = this.isFirstTag(item);\n var stopSwitch = (direction === NEXT && isLast) ||\n (direction === PREV && isFirst);\n if (stopSwitch) {\n this.focus(true);\n return;\n }\n var offset = direction === NEXT ? 1 : -1;\n var index = this.getTagIndex(item) + offset;\n var tag = this.getTagAtIndex(index);\n return tag.select.call(tag);\n };\n /**\n * @name isFirstTag\n * @param item {TagModel}\n */\n TagInputComponent.prototype.isFirstTag = function (item) {\n return this.tags.first.model === item;\n };\n /**\n * @name isLastTag\n * @param item {TagModel}\n */\n TagInputComponent.prototype.isLastTag = function (item) {\n return this.tags.last.model === item;\n };\n /**\n * @name getTagIndex\n * @param item\n */\n TagInputComponent.prototype.getTagIndex = function (item) {\n var tags = this.tags.toArray();\n return tags.findIndex(function (tag) { return tag.model === item; });\n };\n /**\n * @name getTagAtIndex\n * @param index\n */\n TagInputComponent.prototype.getTagAtIndex = function (index) {\n var tags = this.tags.toArray();\n return tags[index];\n };\n /**\n * @name removeItem\n * @desc removes an item from the array of the model\n * @param tag {TagModel}\n * @param index {number}\n */\n TagInputComponent.prototype.removeItem = function (tag, index) {\n this.items = this.getItemsWithout(index);\n // if the removed tag was selected, set it as undefined\n if (this.selectedTag === tag) {\n this.selectItem(undefined, false);\n }\n // focus input\n this.focus(true, false);\n // emit remove event\n this.onRemove.emit(tag);\n };\n /**\n * @name addItem\n * @desc adds the current text model to the items array\n * @param fromAutocomplete {boolean}\n * @param item {TagModel}\n * @param index? {number}\n * @param giveupFocus? {boolean}\n */\n TagInputComponent.prototype.addItem = function (fromAutocomplete, item, index, giveupFocus) {\n var _this = this;\n if (fromAutocomplete === void 0) { fromAutocomplete = false; }\n var display = this.getItemDisplay(item);\n var tag = this.createTag(item);\n if (fromAutocomplete) {\n this.setInputValue(this.getItemValue(item, true));\n }\n return new Promise(function (resolve, reject) {\n /**\n * @name reset\n */\n var reset = function () {\n // reset control and focus input\n _this.setInputValue('');\n if (giveupFocus) {\n _this.focus(false, false);\n }\n else {\n // focus input\n _this.focus(true, false);\n }\n resolve(display);\n };\n var appendItem = function () {\n _this.appendTag(tag, index);\n // emit event\n _this.onAdd.emit(tag);\n if (!_this.dropdown) {\n return;\n }\n _this.dropdown.hide();\n if (_this.dropdown.showDropdownIfEmpty) {\n _this.dropdown.show();\n }\n };\n var status = _this.inputForm.form.status;\n var isTagValid = _this.isTagValid(tag, fromAutocomplete);\n var onValidationError = function () {\n _this.onValidationError.emit(tag);\n return reject();\n };\n if (status === 'VALID' && isTagValid) {\n appendItem();\n return reset();\n }\n if (status === 'INVALID' || !isTagValid) {\n reset();\n return onValidationError();\n }\n if (status === 'PENDING') {\n var statusUpdate$ = _this.inputForm.form.statusChanges;\n return statusUpdate$\n .pipe(filter(function (statusUpdate) { return statusUpdate !== 'PENDING'; }), first())\n .subscribe(function (statusUpdate) {\n if (statusUpdate === 'VALID' && isTagValid) {\n appendItem();\n resolve();\n }\n else {\n onValidationError();\n }\n });\n }\n });\n };\n /**\n * @name setupSeparatorKeysListener\n */\n TagInputComponent.prototype.setupSeparatorKeysListener = function () {\n var _this = this;\n var useSeparatorKeys = this.separatorKeyCodes.length > 0 || this.separatorKeys.length > 0;\n var listener = function ($event) {\n var hasKeyCode = _this.separatorKeyCodes.indexOf($event.keyCode) >= 0;\n var hasKey = _this.separatorKeys.indexOf($event.key) >= 0;\n // the keyCode of keydown event is 229 when IME is processing the key event.\n var isIMEProcessing = $event.keyCode === 229;\n if (hasKeyCode || (hasKey && !isIMEProcessing)) {\n $event.preventDefault();\n _this.onAddingRequested(false, _this.formValue)\n .catch(function () { });\n }\n };\n listen.call(this, KEYDOWN, listener, useSeparatorKeys);\n };\n /**\n * @name setUpKeypressListeners\n */\n TagInputComponent.prototype.setUpKeypressListeners = function () {\n var _this = this;\n var listener = function ($event) {\n var isCorrectKey = $event.keyCode === 37 || $event.keyCode === 8;\n if (isCorrectKey &&\n !_this.formValue &&\n _this.items.length) {\n _this.tags.last.select.call(_this.tags.last);\n }\n };\n // setting up the keypress listeners\n listen.call(this, KEYDOWN, listener);\n };\n /**\n * @name setUpKeydownListeners\n */\n TagInputComponent.prototype.setUpInputKeydownListeners = function () {\n var _this = this;\n this.inputForm.onKeydown.subscribe(function (event) {\n _this.fireEvents('keydown', event);\n if (event.key === 'Backspace' && _this.formValue.trim() === '') {\n event.preventDefault();\n }\n });\n };\n /**\n * @name setUpOnPasteListener\n */\n TagInputComponent.prototype.setUpOnPasteListener = function () {\n var _this = this;\n var input = this.inputForm.input.nativeElement;\n // attach listener to input\n this.renderer.listen(input, 'paste', function (event) {\n _this.onPasteCallback(event);\n event.preventDefault();\n return true;\n });\n };\n /**\n * @name setUpTextChangeSubscriber\n */\n TagInputComponent.prototype.setUpTextChangeSubscriber = function () {\n var _this = this;\n this.inputForm.form\n .valueChanges\n .pipe(debounceTime(this.onTextChangeDebounce))\n .subscribe(function (value) {\n _this.onTextChange.emit(value.item);\n });\n };\n /**\n * @name setUpOnBlurSubscriber\n */\n TagInputComponent.prototype.setUpOnBlurSubscriber = function () {\n var _this = this;\n var filterFn = function () {\n var isVisible = _this.dropdown && _this.dropdown.isVisible;\n return !isVisible && !!_this.formValue;\n };\n this.inputForm\n .onBlur\n .pipe(debounceTime(100), filter(filterFn))\n .subscribe(function () {\n var reset = function () { return _this.setInputValue(''); };\n if (_this.addOnBlur) {\n return _this\n .onAddingRequested(false, _this.formValue, undefined, true)\n .then(reset)\n .catch(reset);\n }\n reset();\n });\n };\n /**\n * @name findDupe\n * @param tag\n * @param isFromAutocomplete\n */\n TagInputComponent.prototype.findDupe = function (tag, isFromAutocomplete) {\n var _this = this;\n var identifyBy = isFromAutocomplete ? this.dropdown.identifyBy : this.identifyBy;\n var id = tag[identifyBy];\n return this.items.find(function (item) { return _this.getItemValue(item) === id; });\n };\n /**\n * @name setAnimationMetadata\n */\n TagInputComponent.prototype.setAnimationMetadata = function () {\n this.animationMetadata = {\n value: 'in',\n params: __assign({}, this.animationDuration)\n };\n };\n __decorate([\n Input(),\n __metadata(\"design:type\", Array)\n ], TagInputComponent.prototype, \"separatorKeys\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Array)\n ], TagInputComponent.prototype, \"separatorKeyCodes\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", String)\n ], TagInputComponent.prototype, \"placeholder\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", String)\n ], TagInputComponent.prototype, \"secondaryPlaceholder\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Number)\n ], TagInputComponent.prototype, \"maxItems\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Array)\n ], TagInputComponent.prototype, \"validators\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Array)\n ], TagInputComponent.prototype, \"asyncValidators\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"onlyFromAutocomplete\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"errorMessages\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", String)\n ], TagInputComponent.prototype, \"theme\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"onTextChangeDebounce\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"inputId\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", String)\n ], TagInputComponent.prototype, \"inputClass\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Boolean)\n ], TagInputComponent.prototype, \"clearOnBlur\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Boolean)\n ], TagInputComponent.prototype, \"hideForm\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Boolean)\n ], TagInputComponent.prototype, \"addOnBlur\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Boolean)\n ], TagInputComponent.prototype, \"addOnPaste\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"pasteSplitPattern\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"blinkIfDupe\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"removable\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Boolean)\n ], TagInputComponent.prototype, \"editable\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"allowDupes\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"modelAsStrings\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"trimTags\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", String),\n __metadata(\"design:paramtypes\", [String])\n ], TagInputComponent.prototype, \"inputText\", null);\n __decorate([\n Input(),\n __metadata(\"design:type\", Boolean)\n ], TagInputComponent.prototype, \"ripple\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", String)\n ], TagInputComponent.prototype, \"tabindex\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Boolean)\n ], TagInputComponent.prototype, \"disable\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", String)\n ], TagInputComponent.prototype, \"dragZone\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"onRemoving\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"onAdding\", void 0);\n __decorate([\n Input(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"animationDuration\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"onAdd\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"onRemove\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"onSelect\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"onFocus\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"onBlur\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"onTextChange\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"onPaste\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"onValidationError\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", Object)\n ], TagInputComponent.prototype, \"onTagEdited\", void 0);\n __decorate([\n ContentChild(TagInputDropdown, { static: false }),\n __metadata(\"design:type\", TagInputDropdown)\n ], TagInputComponent.prototype, \"dropdown\", void 0);\n __decorate([\n ContentChildren(TemplateRef, { descendants: false }),\n __metadata(\"design:type\", QueryList)\n ], TagInputComponent.prototype, \"templates\", void 0);\n __decorate([\n ViewChild(TagInputForm, { static: false }),\n __metadata(\"design:type\", TagInputForm)\n ], TagInputComponent.prototype, \"inputForm\", void 0);\n __decorate([\n ViewChildren(TagComponent),\n __metadata(\"design:type\", QueryList)\n ], TagInputComponent.prototype, \"tags\", void 0);\n __decorate([\n Output(),\n __metadata(\"design:type\", EventEmitter)\n ], TagInputComponent.prototype, \"inputTextChange\", void 0);\n __decorate([\n HostBinding('attr.tabindex'),\n __metadata(\"design:type\", String),\n __metadata(\"design:paramtypes\", [])\n ], TagInputComponent.prototype, \"tabindexAttr\", null);\n TagInputComponent = __decorate([\n Component({\n selector: 'tag-input',\n providers: [CUSTOM_ACCESSOR],\n template: \"\\n\\n \\n \\n \\n \\n\\n \\n \\n \\n\\n \\n\\n\\n\\n\\n \\n {{ error }}\\n \\n\\n\",\n animations: animations,\n styles: [\".dark tag:focus{box-shadow:0 0 0 1px #323232}.ng2-tag-input.bootstrap3-info{background-color:#fff;display:inline-block;color:#555;vertical-align:middle;max-width:100%;height:42px;line-height:44px}.ng2-tag-input.bootstrap3-info input{border:none;box-shadow:none;outline:0;background-color:transparent;padding:0 6px;margin:0;width:auto;max-width:inherit}.ng2-tag-input.bootstrap3-info .form-control input::-moz-placeholder{color:#777;opacity:1}.ng2-tag-input.bootstrap3-info .form-control input:-ms-input-placeholder{color:#777}.ng2-tag-input.bootstrap3-info .form-control input::-webkit-input-placeholder{color:#777}.ng2-tag-input.bootstrap3-info input:focus{border:none;box-shadow:none}.bootstrap3-info.ng2-tag-input.ng2-tag-input--focused{box-shadow:inset 0 1px 1px rgba(0,0,0,.4);border:1px solid #ccc}.ng2-tag-input{display:block;flex-direction:row;flex-wrap:wrap;position:relative;transition:.25s;padding:.25rem 0;min-height:32px;cursor:text;border-bottom:2px solid #efefef}.ng2-tag-input:focus{outline:0}.ng2-tag-input.ng2-tag-input--dropping{opacity:.7}.ng2-tag-input.ng2-tag-input--focused{border-bottom:2px solid #2196f3}.ng2-tag-input.ng2-tag-input--invalid{border-bottom:2px solid #f44336}.ng2-tag-input.ng2-tag-input--loading{border:none}.ng2-tag-input.ng2-tag-input--disabled{opacity:.5;cursor:not-allowed}.ng2-tag-input form{margin:.1em 0}.ng2-tag-input .ng2-tags-container{flex-wrap:wrap;display:flex}.minimal.ng2-tag-input{display:block;flex-direction:row;flex-wrap:wrap;position:relative;cursor:text;border-bottom:1px solid transparent}.minimal.ng2-tag-input:focus{outline:0}.minimal.ng2-tag-input.ng2-tag-input--dropping{opacity:.7}.minimal.ng2-tag-input.ng2-tag-input--loading{border:none}.minimal.ng2-tag-input.ng2-tag-input--disabled{opacity:.5;cursor:not-allowed}.minimal.ng2-tag-input .ng2-tags-container{flex-wrap:wrap;display:flex}.dark.ng2-tag-input{display:block;flex-direction:row;flex-wrap:wrap;position:relative;cursor:text;border-bottom:2px solid #444}.dark.ng2-tag-input:focus{outline:0}.dark.ng2-tag-input.ng2-tag-input--dropping{opacity:.7}.dark.ng2-tag-input.ng2-tag-input--loading{border:none}.dark.ng2-tag-input.ng2-tag-input--disabled{opacity:.5;cursor:not-allowed}.dark.ng2-tag-input .ng2-tags-container{flex-wrap:wrap;display:flex}.bootstrap.ng2-tag-input{display:block;flex-direction:row;flex-wrap:wrap;position:relative;cursor:text;border-bottom:2px solid #efefef}.bootstrap.ng2-tag-input:focus{outline:0}.bootstrap.ng2-tag-input.ng2-tag-input--dropping{opacity:.7}.bootstrap.ng2-tag-input.ng2-tag-input--focused{border-bottom:2px solid #0275d8}.bootstrap.ng2-tag-input.ng2-tag-input--invalid{border-bottom:2px solid #d9534f}.bootstrap.ng2-tag-input.ng2-tag-input--loading{border:none}.bootstrap.ng2-tag-input.ng2-tag-input--disabled{opacity:.5;cursor:not-allowed}.bootstrap.ng2-tag-input .ng2-tags-container{flex-wrap:wrap;display:flex}.bootstrap3-info.ng2-tag-input{display:block;flex-direction:row;flex-wrap:wrap;position:relative;padding:4px;cursor:text;box-shadow:inset 0 1px 1px rgba(0,0,0,.075);border-radius:4px}.bootstrap3-info.ng2-tag-input:focus{outline:0}.bootstrap3-info.ng2-tag-input.ng2-tag-input--dropping{opacity:.7}.bootstrap3-info.ng2-tag-input.ng2-tag-input--invalid{box-shadow:inset 0 1px 1px #d9534f;border-bottom:1px solid #d9534f}.bootstrap3-info.ng2-tag-input.ng2-tag-input--loading{border:none}.bootstrap3-info.ng2-tag-input.ng2-tag-input--disabled{opacity:.5;cursor:not-allowed}.bootstrap3-info.ng2-tag-input form{margin:.1em 0}.bootstrap3-info.ng2-tag-input .ng2-tags-container{flex-wrap:wrap;display:flex}.error-message{font-size:.8em;color:#f44336;margin:.5em 0 0}.bootstrap .error-message{color:#d9534f}.progress-bar,.progress-bar:before{height:2px;width:100%;margin:0}.progress-bar{background-color:#2196f3;display:flex;position:absolute;bottom:0}.progress-bar:before{background-color:#82c4f8;content:\\\"\\\";-webkit-animation:2s cubic-bezier(.4,0,.2,1) infinite running-progress;animation:2s cubic-bezier(.4,0,.2,1) infinite running-progress}@-webkit-keyframes running-progress{0%{margin-left:0;margin-right:100%}50%{margin-left:25%;margin-right:0}100%{margin-left:100%;margin-right:0}}@keyframes running-progress{0%{margin-left:0;margin-right:100%}50%{margin-left:25%;margin-right:0}100%{margin-left:100%;margin-right:0}}tag{display:flex;flex-direction:row;flex-wrap:wrap;font-family:Roboto,\\\"Helvetica Neue\\\",sans-serif;font-weight:400;font-size:1em;letter-spacing:.05rem;color:#444;border-radius:16px;transition:.3s;margin:.1rem .3rem .1rem 0;padding:.08rem .45rem;height:32px;line-height:34px;background:#efefef;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;outline:0;cursor:pointer;position:relative}tag:not(.readonly):not(.tag--editing):focus{background:#2196f3;color:#fff;box-shadow:0 2px 3px 1px #d4d1d1}tag:not(.readonly):not(.tag--editing):active{background:#0d8aee;color:#fff;box-shadow:0 2px 3px 1px #d4d1d1}tag:not(:focus):not(.tag--editing):not(:active):not(.readonly):hover{background:#e2e2e2;color:initial;box-shadow:0 2px 3px 1px #d4d1d1}tag.readonly{cursor:default}tag.readonly:focus,tag:focus{outline:0}tag.tag--editing{background-color:#fff;border:1px solid #ccc;cursor:text}.minimal tag{display:flex;flex-direction:row;flex-wrap:wrap;border-radius:0;background:#f9f9f9;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;outline:0;cursor:pointer;position:relative}.minimal tag:not(.readonly):not(.tag--editing):active,.minimal tag:not(.readonly):not(.tag--editing):focus{background:#d0d0d0;color:initial}.minimal tag:not(:focus):not(.tag--editing):not(:active):not(.readonly):hover{background:#ececec}.minimal tag.readonly{cursor:default}.minimal tag.readonly:focus,.minimal tag:focus{outline:0}.minimal tag.tag--editing{cursor:text}.dark tag{display:flex;flex-direction:row;flex-wrap:wrap;color:#f9f9f9;border-radius:3px;background:#444;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;outline:0;cursor:pointer;position:relative}.dark tag:not(.readonly):not(.tag--editing):focus{background:#efefef;color:#444}.dark tag:not(:focus):not(.tag--editing):not(:active):not(.readonly):hover{background:#2b2b2b;color:#f9f9f9}.dark tag.readonly{cursor:default}.dark tag.readonly:focus,.dark tag:focus{outline:0}.dark tag.tag--editing{cursor:text}.bootstrap tag{display:flex;flex-direction:row;flex-wrap:wrap;color:#f9f9f9;border-radius:.25rem;background:#0275d8;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;outline:0;cursor:pointer;position:relative}.bootstrap tag:not(.readonly):not(.tag--editing):active,.bootstrap tag:not(.readonly):not(.tag--editing):focus{background:#025aa5}.bootstrap tag:not(:focus):not(.tag--editing):not(:active):not(.readonly):hover{background:#0267bf;color:#f9f9f9}.bootstrap tag.readonly{cursor:default}.bootstrap tag.readonly:focus,.bootstrap tag:focus{outline:0}.bootstrap tag.tag--editing{cursor:text}.bootstrap3-info tag{display:flex;flex-direction:row;flex-wrap:wrap;font-family:inherit;font-weight:400;font-size:95%;color:#fff;border-radius:.25em;background:#5bc0de;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;outline:0;cursor:pointer;position:relative;padding:.25em .6em;text-align:center;white-space:nowrap}.bootstrap3-info tag:not(.readonly):not(.tag--editing):active,.bootstrap3-info tag:not(.readonly):not(.tag--editing):focus{background:#28a1c5}.bootstrap3-info tag:not(:focus):not(.tag--editing):not(:active):not(.readonly):hover{background:#46b8da;color:#fff}.bootstrap3-info tag.readonly{cursor:default}.bootstrap3-info tag.readonly:focus,.bootstrap3-info tag:focus{outline:0}.bootstrap3-info tag.tag--editing{cursor:text}:host{display:block}\"]\n }),\n __metadata(\"design:paramtypes\", [Renderer2,\n DragProvider])\n ], TagInputComponent);\n return TagInputComponent;\n}(TagInputAccessor));\n\nvar DeleteIconComponent = /** @class */ (function () {\n function DeleteIconComponent() {\n }\n DeleteIconComponent = __decorate([\n Component({\n selector: 'delete-icon',\n template: \"\\n \\n \\n \\n\",\n styles: [\".dark tag:focus{box-shadow:0 0 0 1px #323232}.ng2-tag-input.bootstrap3-info{background-color:#fff;display:inline-block;color:#555;vertical-align:middle;max-width:100%;height:42px;line-height:44px}.ng2-tag-input.bootstrap3-info input{border:none;box-shadow:none;outline:0;background-color:transparent;padding:0 6px;margin:0;width:auto;max-width:inherit}.ng2-tag-input.bootstrap3-info .form-control input::-moz-placeholder{color:#777;opacity:1}.ng2-tag-input.bootstrap3-info .form-control input:-ms-input-placeholder{color:#777}.ng2-tag-input.bootstrap3-info .form-control input::-webkit-input-placeholder{color:#777}.ng2-tag-input.bootstrap3-info input:focus{border:none;box-shadow:none}.bootstrap3-info.ng2-tag-input.ng2-tag-input--focused{box-shadow:inset 0 1px 1px rgba(0,0,0,.4);border:1px solid #ccc}.ng2-tag-input{display:block;flex-direction:row;flex-wrap:wrap;position:relative;transition:.25s;padding:.25rem 0;min-height:32px;cursor:text;border-bottom:2px solid #efefef}.ng2-tag-input:focus{outline:0}.ng2-tag-input.ng2-tag-input--dropping{opacity:.7}.ng2-tag-input.ng2-tag-input--focused{border-bottom:2px solid #2196f3}.ng2-tag-input.ng2-tag-input--invalid{border-bottom:2px solid #f44336}.ng2-tag-input.ng2-tag-input--loading{border:none}.ng2-tag-input.ng2-tag-input--disabled{opacity:.5;cursor:not-allowed}.ng2-tag-input form{margin:.1em 0}.ng2-tag-input .ng2-tags-container{flex-wrap:wrap;display:flex}.minimal.ng2-tag-input{display:block;flex-direction:row;flex-wrap:wrap;position:relative;cursor:text;border-bottom:1px solid transparent}.minimal.ng2-tag-input:focus{outline:0}.minimal.ng2-tag-input.ng2-tag-input--dropping{opacity:.7}.minimal.ng2-tag-input.ng2-tag-input--loading{border:none}.minimal.ng2-tag-input.ng2-tag-input--disabled{opacity:.5;cursor:not-allowed}.minimal.ng2-tag-input .ng2-tags-container{flex-wrap:wrap;display:flex}.dark.ng2-tag-input{display:block;flex-direction:row;flex-wrap:wrap;position:relative;cursor:text;border-bottom:2px solid #444}.dark.ng2-tag-input:focus{outline:0}.dark.ng2-tag-input.ng2-tag-input--dropping{opacity:.7}.dark.ng2-tag-input.ng2-tag-input--loading{border:none}.dark.ng2-tag-input.ng2-tag-input--disabled{opacity:.5;cursor:not-allowed}.dark.ng2-tag-input .ng2-tags-container{flex-wrap:wrap;display:flex}.bootstrap.ng2-tag-input{display:block;flex-direction:row;flex-wrap:wrap;position:relative;cursor:text;border-bottom:2px solid #efefef}.bootstrap.ng2-tag-input:focus{outline:0}.bootstrap.ng2-tag-input.ng2-tag-input--dropping{opacity:.7}.bootstrap.ng2-tag-input.ng2-tag-input--focused{border-bottom:2px solid #0275d8}.bootstrap.ng2-tag-input.ng2-tag-input--invalid{border-bottom:2px solid #d9534f}.bootstrap.ng2-tag-input.ng2-tag-input--loading{border:none}.bootstrap.ng2-tag-input.ng2-tag-input--disabled{opacity:.5;cursor:not-allowed}.bootstrap.ng2-tag-input .ng2-tags-container{flex-wrap:wrap;display:flex}.bootstrap3-info.ng2-tag-input{display:block;flex-direction:row;flex-wrap:wrap;position:relative;padding:4px;cursor:text;box-shadow:inset 0 1px 1px rgba(0,0,0,.075);border-radius:4px}.bootstrap3-info.ng2-tag-input:focus{outline:0}.bootstrap3-info.ng2-tag-input.ng2-tag-input--dropping{opacity:.7}.bootstrap3-info.ng2-tag-input.ng2-tag-input--invalid{box-shadow:inset 0 1px 1px #d9534f;border-bottom:1px solid #d9534f}.bootstrap3-info.ng2-tag-input.ng2-tag-input--loading{border:none}.bootstrap3-info.ng2-tag-input.ng2-tag-input--disabled{opacity:.5;cursor:not-allowed}.bootstrap3-info.ng2-tag-input form{margin:.1em 0}.bootstrap3-info.ng2-tag-input .ng2-tags-container{flex-wrap:wrap;display:flex}.error-message{font-size:.8em;color:#f44336;margin:.5em 0 0}.bootstrap .error-message{color:#d9534f}:host(delete-icon){width:20px;height:16px;transition:.15s;display:inline-block;text-align:right}:host(delete-icon) path{fill:#444}:host(delete-icon) svg{vertical-align:bottom;height:34px}:host(delete-icon):hover{-webkit-transform:scale(1.5) translateY(-3px);transform:scale(1.5) translateY(-3px)}:host-context(.dark){text-align:right}:host-context(.dark) path{fill:#fff}:host-context(.dark) svg{vertical-align:bottom;height:34px}:host-context(.minimal){text-align:right}:host-context(.minimal) path{fill:#444}:host-context(.minimal) svg{vertical-align:bottom;height:34px}:host-context(.bootstrap){text-align:right}:host-context(.bootstrap) path{fill:#fff}:host-context(.bootstrap) svg{vertical-align:bottom;height:34px}:host-context(tag:active) path,:host-context(tag:focus) path{fill:#fff}:host-context(.darktag:active) path,:host-context(.darktag:focus) path{fill:#000}:host-context(.minimaltag:active) path,:host-context(.minimaltag:focus) path{fill:#000}:host-context(.bootstraptag:active) path,:host-context(.bootstraptag:focus) path{fill:#fff}:host-context(.bootstrap3-info){height:inherit}:host-context(.bootstrap3-info) path{fill:#fff}\"]\n })\n ], DeleteIconComponent);\n return DeleteIconComponent;\n}());\n\nvar optionsProvider = new OptionsProvider();\nvar TagInputModule = /** @class */ (function () {\n function TagInputModule() {\n }\n /**\n * @name withDefaults\n * @param options {Options}\n */\n TagInputModule.withDefaults = function (options) {\n optionsProvider.setOptions(options);\n };\n TagInputModule = __decorate([\n NgModule({\n imports: [\n CommonModule,\n ReactiveFormsModule,\n FormsModule,\n Ng2DropdownModule\n ],\n declarations: [\n TagInputComponent,\n DeleteIconComponent,\n TagInputForm,\n TagComponent,\n HighlightPipe,\n TagInputDropdown,\n TagRipple\n ],\n exports: [\n TagInputComponent,\n DeleteIconComponent,\n TagInputForm,\n TagComponent,\n HighlightPipe,\n TagInputDropdown,\n TagRipple\n ],\n providers: [\n DragProvider,\n { provide: COMPOSITION_BUFFER_MODE, useValue: false },\n ]\n })\n ], TagInputModule);\n return TagInputModule;\n}());\n\n/**\n * Generated bundle index. Do not edit.\n */\n\nexport { DeleteIconComponent, TagComponent, TagInputComponent, TagInputDropdown, TagInputForm, TagInputModule, TagRipple, TagInputAccessor as ɵa, animations as ɵb, DragProvider as ɵc, HighlightPipe as ɵd };\n//# sourceMappingURL=ngx-chips.js.map\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/ngx-chips/fesm5/ngx-chips.js\n// module id = 1015\n// module chunks = 8","import { Component, Output, Input, EventEmitter, ElementRef, Injectable, Renderer, ContentChildren, HostListener, ContentChild, NgModule } from '@angular/core';\nimport { trigger, style, transition, animate, keyframes, state } from '@angular/animations';\nimport { CommonModule } from '@angular/common';\n\n/**\n * @fileoverview added by tsickle\n * @suppress {checkTypes} checked by tsc\n */\nvar Ng2DropdownButton = /** @class */ (function () {\n function Ng2DropdownButton(element) {\n this.element = element;\n this.onMenuToggled = new EventEmitter();\n this.showCaret = true;\n }\n /**\n * \\@name toggleMenu\n * @desc emits event to toggle menu\n * @return {?}\n */\n Ng2DropdownButton.prototype.toggleMenu = /**\n * \\@name toggleMenu\n * @desc emits event to toggle menu\n * @return {?}\n */\n function () {\n this.onMenuToggled.emit(true);\n };\n /**\n * \\@name getPosition\n * @desc returns position of the button\n * @return {?}\n */\n Ng2DropdownButton.prototype.getPosition = /**\n * \\@name getPosition\n * @desc returns position of the button\n * @return {?}\n */\n function () {\n return this.element.nativeElement.getBoundingClientRect();\n };\n Ng2DropdownButton.decorators = [\n { type: Component, args: [{\n selector: 'ng2-dropdown-button',\n styles: [\".ng2-dropdown-button{font-family:Roboto,\\\"Helvetica Neue\\\",Helvetica,Arial;background:#fff;padding:.45rem .25rem;font-size:14px;letter-spacing:.08rem;color:#444;outline:0;cursor:pointer;font-weight:400;border:none;border-bottom:1px solid #efefef;text-align:left;min-width:100px;width:100%;display:flex;flex-direction:row;max-width:150px}.ng2-dropdown-button:hover{color:#222}.ng2-dropdown-button:active,.ng2-dropdown-button:focus{color:#222;border-bottom:2px solid #2196f3}.ng2-dropdown-button__label{flex:1 1 95%}.ng2-dropdown-button__caret{width:12px;height:12px;display:flex;flex:1 1 6%}:host-context(.ng2-dropdown-button--icon) .ng2-dropdown-button{border:none;min-width:40px;width:40px;border-radius:100%;transition:all .2s;text-align:center;height:40px;padding:.5em}:host-context(.ng2-dropdown-button--icon) .ng2-dropdown-button:active{background:rgba(0,0,0,.2)}\"],\n template: \"\\n \\n \\n \\n\\n \\n \\n \\n\\n\"\n },] },\n ];\n /** @nocollapse */\n Ng2DropdownButton.ctorParameters = function () { return [\n { type: ElementRef, },\n ]; };\n Ng2DropdownButton.propDecorators = {\n \"onMenuToggled\": [{ type: Output },],\n \"showCaret\": [{ type: Input },],\n };\n return Ng2DropdownButton;\n}());\n\n/**\n * @fileoverview added by tsickle\n * @suppress {checkTypes} checked by tsc\n */\nvar /** @type {?} */ KEYS = {\n BACKSPACE: 9,\n PREV: 38,\n NEXT: 40,\n ENTER: 13,\n ESCAPE: 27\n};\n/**\n * \\@name onSwitchNext\n * @param index\n * @param items\n * @param state\n */\nvar /** @type {?} */ onSwitchNext = function (index, items, state$$1) {\n if (index < items.length - 1) {\n state$$1.select(items[index + 1], true);\n }\n};\n/**\n * \\@name onSwitchPrev\n * @param index\n * @param items\n * @param state\n */\nvar /** @type {?} */ onSwitchPrev = function (index, items, state$$1) {\n if (index > 0) {\n state$$1.select(items[index - 1], true);\n }\n};\n/**\n * \\@name onBackspace\n * @param index\n * @param items\n * @param state\n */\nvar /** @type {?} */ onBackspace = function (index, items, state$$1) {\n if (index < items.length - 1) {\n state$$1.select(items[index + 1], true);\n }\n else {\n state$$1.select(items[0], true);\n }\n};\n/**\n * @this {?}\n * @return {?}\n */\nfunction onEscape() {\n this.hide();\n}\n/**\n * \\@name onItemClicked\n * @param index\n * @param items\n * @param state\n */\nvar /** @type {?} */ onItemClicked = function (index, items, state$$1) {\n return state$$1.selectedItem ? state$$1.selectedItem.click() : undefined;\n};\nvar /** @type {?} */ ACTIONS = (_a = {},\n _a[KEYS.BACKSPACE] = onBackspace,\n _a[KEYS.PREV] = onSwitchPrev,\n _a[KEYS.NEXT] = onSwitchNext,\n _a[KEYS.ENTER] = onItemClicked,\n _a[KEYS.ESCAPE] = onEscape,\n _a);\n/**\n * @param {?} event\n * @return {?}\n */\nfunction arrowKeysHandler(event) {\n if ([38, 40].indexOf(event.keyCode) > -1) {\n event.preventDefault();\n }\n}\nvar _a;\n\n/**\n * @fileoverview added by tsickle\n * @suppress {checkTypes} checked by tsc\n */\nvar Ng2DropdownState = /** @class */ (function () {\n function Ng2DropdownState() {\n this.onItemSelected = new EventEmitter();\n this.onItemClicked = new EventEmitter();\n this.onItemDestroyed = new EventEmitter();\n }\n Object.defineProperty(Ng2DropdownState.prototype, \"selectedItem\", {\n get: /**\n * \\@name selectedItem\n * @desc getter for _selectedItem\n * @return {?}\n */\n function () {\n return this._selectedItem;\n },\n enumerable: true,\n configurable: true\n });\n /**\n * \\@name selects a menu item and emits event\n * @param {?} item\n * @param {?=} dispatchEvent\n * @return {?}\n */\n Ng2DropdownState.prototype.select = /**\n * \\@name selects a menu item and emits event\n * @param {?} item\n * @param {?=} dispatchEvent\n * @return {?}\n */\n function (item, dispatchEvent) {\n if (dispatchEvent === void 0) { dispatchEvent = true; }\n this._selectedItem = item;\n if (!dispatchEvent || !item) {\n return;\n }\n item.focus();\n this.onItemSelected.emit(item);\n };\n /**\n * \\@name unselect\n * @desc sets _selectedItem as undefined\n * @return {?}\n */\n Ng2DropdownState.prototype.unselect = /**\n * \\@name unselect\n * @desc sets _selectedItem as undefined\n * @return {?}\n */\n function () {\n this._selectedItem = undefined;\n };\n return Ng2DropdownState;\n}());\n\n/**\n * @fileoverview added by tsickle\n * @suppress {checkTypes} checked by tsc\n */\nvar DropdownStateService = /** @class */ (function () {\n function DropdownStateService() {\n this.menuState = {\n isVisible: /** @type {?} */ (false),\n toString: /**\n * @return {?}\n */\n function () {\n return this.isVisible === true ? 'visible' : 'hidden';\n }\n };\n this.dropdownState = new Ng2DropdownState();\n }\n DropdownStateService.decorators = [\n { type: Injectable },\n ];\n return DropdownStateService;\n}());\n\n/**\n * @fileoverview added by tsickle\n * @suppress {checkTypes} checked by tsc\n */\nvar Ng2MenuItem = /** @class */ (function () {\n function Ng2MenuItem(state$$1, element, renderer) {\n this.state = state$$1;\n this.element = element;\n this.renderer = renderer;\n /**\n * \\@preventClose\n * @desc if true, clicking on the item won't close the dropdown\n */\n this.preventClose = false;\n }\n /**\n * @return {?}\n */\n Ng2MenuItem.prototype.ngOnDestroy = /**\n * @return {?}\n */\n function () {\n this.state.dropdownState.onItemDestroyed.emit(this);\n };\n Object.defineProperty(Ng2MenuItem.prototype, \"isSelected\", {\n get: /**\n * \\@name isSelected\n * @desc returns current selected item\n * @return {?}\n */\n function () {\n return this === this.state.dropdownState.selectedItem;\n },\n enumerable: true,\n configurable: true\n });\n /**\n * \\@name click\n * @desc emits select event\n * @param {?=} $event\n * @return {?}\n */\n Ng2MenuItem.prototype.select = /**\n * \\@name click\n * @desc emits select event\n * @param {?=} $event\n * @return {?}\n */\n function ($event) {\n this.state.dropdownState.select(this, true);\n if ($event) {\n $event.stopPropagation();\n $event.preventDefault();\n }\n };\n /**\n * \\@name click\n * @desc emits click event\n * @return {?}\n */\n Ng2MenuItem.prototype.click = /**\n * \\@name click\n * @desc emits click event\n * @return {?}\n */\n function () {\n this.state.dropdownState.onItemClicked.emit(this);\n };\n /**\n * \\@name focus\n * @return {?}\n */\n Ng2MenuItem.prototype.focus = /**\n * \\@name focus\n * @return {?}\n */\n function () {\n this.renderer.invokeElementMethod(this.element.nativeElement.children[0], 'focus');\n };\n Ng2MenuItem.decorators = [\n { type: Component, args: [{\n selector: 'ng2-menu-item',\n styles: [\".ng2-menu-item{font-family:Roboto,\\\"Helvetica Neue\\\",Helvetica,Arial;background:#fff;color:rgba(0,0,0,.87);cursor:pointer;font-size:.9em;text-transform:none;font-weight:400;letter-spacing:.03em;height:48px;line-height:48px;padding:.3em 1.25rem;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;transition:background .25s}.ng2-menu-item--selected{background:rgba(158,158,158,.2);outline:0}.ng2-menu-item:focus{outline:0}.ng2-menu-item:active{background:rgba(158,158,158,.4)}:host(ng2-menu-item) /deep/ [ng2-menu-item-icon]{vertical-align:middle;font-size:28px;width:1.5em;height:30px;color:rgba(0,0,0,.44)}\"],\n template: \"\\n \\n\\n\"\n },] },\n ];\n /** @nocollapse */\n Ng2MenuItem.ctorParameters = function () { return [\n { type: DropdownStateService, },\n { type: ElementRef, },\n { type: Renderer, },\n ]; };\n Ng2MenuItem.propDecorators = {\n \"preventClose\": [{ type: Input },],\n \"value\": [{ type: Input },],\n };\n return Ng2MenuItem;\n}());\n\n/**\n * @fileoverview added by tsickle\n * @suppress {checkTypes} checked by tsc\n */\nvar Ng2DropdownMenu = /** @class */ (function () {\n function Ng2DropdownMenu(state$$1, element, renderer) {\n this.state = state$$1;\n this.element = element;\n this.renderer = renderer;\n /**\n * \\@name width\n */\n this.width = 4;\n /**\n * \\@description if set to true, the first element of the dropdown will be automatically focused\n * \\@name focusFirstElement\n */\n this.focusFirstElement = true;\n /**\n * \\@name appendToBody\n */\n this.appendToBody = true;\n /**\n * \\@name zIndex\n */\n this.zIndex = 1000;\n this.listeners = {\n arrowHandler: undefined,\n handleKeypress: undefined\n };\n }\n /**\n * \\@name show\n * \\@shows menu and selects first item\n * @param {?=} position\n * @param {?=} dynamic\n * @return {?}\n */\n Ng2DropdownMenu.prototype.show = /**\n * \\@name show\n * \\@shows menu and selects first item\n * @param {?=} position\n * @param {?=} dynamic\n * @return {?}\n */\n function (position, dynamic) {\n if (dynamic === void 0) { dynamic = true; }\n var /** @type {?} */ dc = typeof document !== 'undefined' ? document : undefined;\n var /** @type {?} */ wd = typeof window !== 'undefined' ? window : undefined;\n if (!this.state.menuState.isVisible) {\n // setting handlers\n this.listeners.handleKeypress = this.renderer.listen(dc.body, 'keydown', this.handleKeypress.bind(this));\n this.listeners.arrowHandler = this.renderer.listen(wd, 'keydown', arrowKeysHandler);\n }\n // update state\n this.state.menuState.isVisible = true;\n if (position) {\n this.updatePosition(position, dynamic);\n }\n };\n /**\n * \\@name hide\n * @desc hides menu\n * @return {?}\n */\n Ng2DropdownMenu.prototype.hide = /**\n * \\@name hide\n * @desc hides menu\n * @return {?}\n */\n function () {\n this.state.menuState.isVisible = false;\n // reset selected item state\n this.state.dropdownState.unselect();\n // call function to unlisten\n this.listeners.arrowHandler ? this.listeners.arrowHandler() : undefined;\n this.listeners.handleKeypress ? this.listeners.handleKeypress() : undefined;\n };\n /**\n * \\@name updatePosition\n * @desc updates the menu position every time it is toggled\n * @param {?} position {ClientRect}\n * @param {?} dynamic {boolean}\n * @return {?}\n */\n Ng2DropdownMenu.prototype.updatePosition = /**\n * \\@name updatePosition\n * @desc updates the menu position every time it is toggled\n * @param {?} position {ClientRect}\n * @param {?} dynamic {boolean}\n * @return {?}\n */\n function (position, dynamic) {\n this.position = position;\n this.updateOnChange(dynamic);\n };\n /**\n * \\@name handleKeypress\n * @desc executes functions on keyPress based on the key pressed\n * @param {?} $event\n * @return {?}\n */\n Ng2DropdownMenu.prototype.handleKeypress = /**\n * \\@name handleKeypress\n * @desc executes functions on keyPress based on the key pressed\n * @param {?} $event\n * @return {?}\n */\n function ($event) {\n var /** @type {?} */ key = $event.keyCode;\n var /** @type {?} */ items = this.items.toArray();\n var /** @type {?} */ index = items.indexOf(this.state.dropdownState.selectedItem);\n if (!ACTIONS.hasOwnProperty(key)) {\n return;\n }\n ACTIONS[key].call(this, index, items, this.state.dropdownState);\n };\n /**\n * \\@name getMenuElement\n * @return {?}\n */\n Ng2DropdownMenu.prototype.getMenuElement = /**\n * \\@name getMenuElement\n * @return {?}\n */\n function () {\n return this.element.nativeElement.children[0];\n };\n /**\n * \\@name calcPositionOffset\n * @param {?} position\n * @return {?}\n */\n Ng2DropdownMenu.prototype.calcPositionOffset = /**\n * \\@name calcPositionOffset\n * @param {?} position\n * @return {?}\n */\n function (position) {\n var /** @type {?} */ wd = typeof window !== 'undefined' ? window : undefined;\n var /** @type {?} */ dc = typeof document !== 'undefined' ? document : undefined;\n if (!wd || !dc || !position) {\n return;\n }\n var /** @type {?} */ element = this.getMenuElement();\n var /** @type {?} */ supportPageOffset = wd.pageXOffset !== undefined;\n var /** @type {?} */ isCSS1Compat = ((dc.compatMode || '') === 'CSS1Compat');\n var /** @type {?} */ x = supportPageOffset ? wd.pageXOffset : isCSS1Compat ?\n dc.documentElement.scrollLeft : dc.body.scrollLeft;\n var /** @type {?} */ y = supportPageOffset ? wd.pageYOffset : isCSS1Compat ?\n dc.documentElement.scrollTop : dc.body.scrollTop;\n var _a = this.applyOffset(position.top + (this.appendToBody ? y - 15 : 0) + \"px\", position.left + x - 5 + \"px\"), top = _a.top, left = _a.left;\n var /** @type {?} */ clientWidth = element.clientWidth;\n var /** @type {?} */ clientHeight = element.clientHeight;\n var /** @type {?} */ marginFromBottom = parseInt(top) + clientHeight + (this.appendToBody ? 0 : y - 15);\n var /** @type {?} */ marginFromRight = parseInt(left) + clientWidth;\n var /** @type {?} */ windowScrollHeight = wd.innerHeight + wd.scrollY;\n var /** @type {?} */ windowScrollWidth = wd.innerWidth + wd.scrollX;\n if (marginFromBottom >= windowScrollHeight) {\n top = parseInt(top.replace('px', '')) - clientHeight + \"px\";\n }\n if (marginFromRight >= windowScrollWidth) {\n var /** @type {?} */ marginRight = marginFromRight - windowScrollWidth + 30;\n left = parseInt(left.replace('px', '')) - marginRight + \"px\";\n }\n return { top: top, left: left };\n };\n /**\n * @param {?} top\n * @param {?} left\n * @return {?}\n */\n Ng2DropdownMenu.prototype.applyOffset = /**\n * @param {?} top\n * @param {?} left\n * @return {?}\n */\n function (top, left) {\n if (!this.offset) {\n return { top: top, left: left };\n }\n var /** @type {?} */ offset = this.offset.split(' ');\n if (!offset[1]) {\n offset[1] = '0';\n }\n top = parseInt(top.replace('px', '')) + parseInt(offset[0]) + \"px\";\n left = parseInt(left.replace('px', '')) + parseInt(offset[1]) + \"px\";\n return { top: top, left: left };\n };\n /**\n * @return {?}\n */\n Ng2DropdownMenu.prototype.ngOnInit = /**\n * @return {?}\n */\n function () {\n var /** @type {?} */ dc = typeof document !== 'undefined' ? document : undefined;\n if (this.appendToBody) {\n // append menu element to the body\n dc.body.appendChild(this.element.nativeElement);\n }\n };\n /**\n * @param {?=} dynamic\n * @return {?}\n */\n Ng2DropdownMenu.prototype.updateOnChange = /**\n * @param {?=} dynamic\n * @return {?}\n */\n function (dynamic) {\n if (dynamic === void 0) { dynamic = true; }\n var /** @type {?} */ element = this.getMenuElement();\n var /** @type {?} */ position = this.calcPositionOffset(this.position);\n if (position) {\n this.renderer.setElementStyle(element, 'top', position.top.toString());\n this.renderer.setElementStyle(element, 'left', position.left.toString());\n }\n // select first item unless user disabled this option\n if (this.focusFirstElement &&\n this.items.first &&\n !this.state.dropdownState.selectedItem) {\n this.state.dropdownState.select(this.items.first, false);\n }\n };\n /**\n * @return {?}\n */\n Ng2DropdownMenu.prototype.ngOnDestroy = /**\n * @return {?}\n */\n function () {\n var /** @type {?} */ elem = this.element.nativeElement;\n elem.parentNode.removeChild(elem);\n if (this.listeners.handleKeypress) {\n this.listeners.handleKeypress();\n }\n };\n Ng2DropdownMenu.decorators = [\n { type: Component, args: [{\n selector: 'ng2-dropdown-menu',\n styles: [\":host{display:block}.ng2-dropdown-menu{overflow-y:auto;box-shadow:0 1px 2px 0 rgba(0,0,0,.3);position:absolute;padding:.5em 0;background:#fff;border-radius:1px;max-height:400px;width:260px;min-height:0;display:block}.ng2-dropdown-menu.ng2-dropdown-menu--inside-element{position:fixed}.ng2-dropdown-menu.ng2-dropdown-menu--width--2{width:200px}.ng2-dropdown-menu.ng2-dropdown-menu--width--4{width:260px}.ng2-dropdown-menu.ng2-dropdown-menu--width--6{width:320px}.ng2-dropdown-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1;overflow:hidden}:host /deep/ .ng2-menu-divider{height:1px;min-height:1px;max-height:1px;width:100%;display:block;background:#f9f9f9}\"],\n template: \"\\n\\n \\n \\n \\n\\n\\n\\n\\n\",\n animations: [\n trigger('fade', [\n state('visible', style({ display: 'block', opacity: 1, height: '*', width: '*' })),\n state('hidden', style({ display: 'none', opacity: 0, overflow: 'hidden', height: 0, width: 0 })),\n transition('hidden => visible', [\n animate('250ms ease-in', style({ opacity: 1, height: '*', width: '*' }))\n ]),\n transition('visible => hidden', [\n animate('350ms ease-out', style({ opacity: 0, width: 0, height: 0 }))\n ])\n ]),\n trigger('opacity', [\n transition('hidden => visible', [\n animate('450ms ease-in', keyframes([\n style({ opacity: 0, offset: 0 }),\n style({ opacity: 1, offset: 1 }),\n ]))\n ]),\n transition('visible => hidden', [\n animate('250ms ease-out', keyframes([\n style({ opacity: 1, offset: 0 }),\n style({ opacity: 0.5, offset: 0.3 }),\n style({ opacity: 0, offset: 1 }),\n ]))\n ])\n ])\n ]\n },] },\n ];\n /** @nocollapse */\n Ng2DropdownMenu.ctorParameters = function () { return [\n { type: DropdownStateService, },\n { type: ElementRef, },\n { type: Renderer, },\n ]; };\n Ng2DropdownMenu.propDecorators = {\n \"width\": [{ type: Input },],\n \"focusFirstElement\": [{ type: Input },],\n \"offset\": [{ type: Input },],\n \"appendToBody\": [{ type: Input },],\n \"zIndex\": [{ type: Input },],\n \"items\": [{ type: ContentChildren, args: [Ng2MenuItem,] },],\n };\n return Ng2DropdownMenu;\n}());\n\n/**\n * @fileoverview added by tsickle\n * @suppress {checkTypes} checked by tsc\n */\nvar Ng2Dropdown = /** @class */ (function () {\n function Ng2Dropdown(state$$1) {\n this.state = state$$1;\n this.dynamicUpdate = true;\n // outputs\n this.onItemClicked = new EventEmitter();\n this.onItemSelected = new EventEmitter();\n this.onShow = new EventEmitter();\n this.onHide = new EventEmitter();\n }\n /**\n * @return {?}\n */\n Ng2Dropdown.prototype.ngOnInit = /**\n * @return {?}\n */\n function () {\n var _this = this;\n this.state.dropdownState.onItemClicked.subscribe(function (item) {\n _this.onItemClicked.emit(item);\n if (item.preventClose) {\n return;\n }\n _this.hide.call(_this);\n });\n if (this.button) {\n this.button.onMenuToggled.subscribe(function () {\n _this.toggleMenu();\n });\n }\n this.state.dropdownState.onItemSelected.subscribe(function (item) {\n _this.onItemSelected.emit(item);\n });\n this.state.dropdownState.onItemDestroyed.subscribe(function (item) {\n var /** @type {?} */ newSelectedItem;\n var /** @type {?} */ items = _this.menu.items.toArray();\n if (item !== _this.state.dropdownState.selectedItem) {\n return;\n }\n if (_this.menu.focusFirstElement) {\n newSelectedItem = item === items[0] && items.length > 1 ? items[1] : items[0];\n }\n _this.state.dropdownState.select(newSelectedItem);\n });\n };\n /**\n * \\@name toggleMenu\n * @desc toggles menu visibility\n * @param {?=} position\n * @return {?}\n */\n Ng2Dropdown.prototype.toggleMenu = /**\n * \\@name toggleMenu\n * @desc toggles menu visibility\n * @param {?=} position\n * @return {?}\n */\n function (position) {\n if (position === void 0) { position = this.button.getPosition(); }\n this.state.menuState.isVisible ? this.hide() : this.show(position);\n };\n /**\n * - hides dropdown\n * \\@name hide\n * @return {?}\n */\n Ng2Dropdown.prototype.hide = /**\n * - hides dropdown\n * \\@name hide\n * @return {?}\n */\n function () {\n this.menu.hide();\n this.onHide.emit(this);\n };\n /**\n * - shows dropdown\n * \\@name show\n * @param {?=} position\n * @return {?}\n */\n Ng2Dropdown.prototype.show = /**\n * - shows dropdown\n * \\@name show\n * @param {?=} position\n * @return {?}\n */\n function (position) {\n if (position === void 0) { position = this.button.getPosition(); }\n this.menu.show(position, this.dynamicUpdate);\n this.onShow.emit(this);\n };\n /**\n * \\@name scrollListener\n * @return {?}\n */\n Ng2Dropdown.prototype.scrollListener = /**\n * \\@name scrollListener\n * @return {?}\n */\n function () {\n if (this.button && this.dynamicUpdate) {\n this.menu.updatePosition(this.button.getPosition(), true);\n }\n };\n Ng2Dropdown.decorators = [\n { type: Component, args: [{\n selector: 'ng2-dropdown',\n template: \"\\n \\n \\n\\n\",\n providers: [DropdownStateService]\n },] },\n ];\n /** @nocollapse */\n Ng2Dropdown.ctorParameters = function () { return [\n { type: DropdownStateService, },\n ]; };\n Ng2Dropdown.propDecorators = {\n \"button\": [{ type: ContentChild, args: [Ng2DropdownButton,] },],\n \"menu\": [{ type: ContentChild, args: [Ng2DropdownMenu,] },],\n \"dynamicUpdate\": [{ type: Input },],\n \"onItemClicked\": [{ type: Output },],\n \"onItemSelected\": [{ type: Output },],\n \"onShow\": [{ type: Output },],\n \"onHide\": [{ type: Output },],\n \"scrollListener\": [{ type: HostListener, args: ['window:scroll',] },],\n };\n return Ng2Dropdown;\n}());\n\n/**\n * @fileoverview added by tsickle\n * @suppress {checkTypes} checked by tsc\n */\nvar Ng2DropdownModule = /** @class */ (function () {\n function Ng2DropdownModule() {\n }\n Ng2DropdownModule.decorators = [\n { type: NgModule, args: [{\n exports: [\n Ng2MenuItem,\n Ng2DropdownButton,\n Ng2DropdownMenu,\n Ng2Dropdown\n ],\n declarations: [\n Ng2Dropdown,\n Ng2MenuItem,\n Ng2DropdownButton,\n Ng2DropdownMenu,\n ],\n imports: [\n CommonModule\n ]\n },] },\n ];\n return Ng2DropdownModule;\n}());\n\n/**\n * @fileoverview added by tsickle\n * @suppress {checkTypes} checked by tsc\n */\n\n/**\n * @fileoverview added by tsickle\n * @suppress {checkTypes} checked by tsc\n */\n\nexport { Ng2Dropdown, Ng2DropdownMenu, Ng2MenuItem, Ng2DropdownButton, Ng2DropdownModule, DropdownStateService };\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ng2-material-dropdown.js.map","sources":["ng://ng2-material-dropdown/src/modules/components/button/ng2-dropdown-button.ts","ng://ng2-material-dropdown/src/modules/components/menu/actions.ts","ng://ng2-material-dropdown/src/modules/services/ng2-dropdown-state.ts","ng://ng2-material-dropdown/src/modules/services/dropdown-state.service.ts","ng://ng2-material-dropdown/src/modules/components/menu-item/ng2-menu-item.ts","ng://ng2-material-dropdown/src/modules/components/menu/ng2-dropdown-menu.ts","ng://ng2-material-dropdown/src/modules/components/dropdown/ng2-dropdown.ts","ng://ng2-material-dropdown/src/modules/ng2-dropdown.module.ts"],"sourcesContent":["import {\n    Component,\n    Output,\n    Input,\n    EventEmitter,\n    ElementRef\n} from '@angular/core';\n\n@Component({\n    selector: 'ng2-dropdown-button',\n    styles: [`.ng2-dropdown-button{font-family:Roboto,\"Helvetica Neue\",Helvetica,Arial;background:#fff;padding:.45rem .25rem;font-size:14px;letter-spacing:.08rem;color:#444;outline:0;cursor:pointer;font-weight:400;border:none;border-bottom:1px solid #efefef;text-align:left;min-width:100px;width:100%;display:flex;flex-direction:row;max-width:150px}.ng2-dropdown-button:hover{color:#222}.ng2-dropdown-button:active,.ng2-dropdown-button:focus{color:#222;border-bottom:2px solid #2196f3}.ng2-dropdown-button__label{flex:1 1 95%}.ng2-dropdown-button__caret{width:12px;height:12px;display:flex;flex:1 1 6%}:host-context(.ng2-dropdown-button--icon) .ng2-dropdown-button{border:none;min-width:40px;width:40px;border-radius:100%;transition:all .2s;text-align:center;height:40px;padding:.5em}:host-context(.ng2-dropdown-button--icon) .ng2-dropdown-button:active{background:rgba(0,0,0,.2)}`],\n    template: `<button class='ng2-dropdown-button' type=\"button\" (click)=\"toggleMenu()\" tabindex=\"0s\">\n    <span class=\"ng2-dropdown-button__label\">\n        <ng-content></ng-content>\n    </span>\n\n    <span class=\"ng2-dropdown-button__caret\" *ngIf=\"showCaret\">\n        <svg enable-background=\"new 0 0 32 32\" height=\"16px\" id=\"Ð¡Ð»Ð¾Ð¹_1\" version=\"1.1\" viewBox=\"0 0 32 32\" width=\"16px\" xml:space=\"preserve\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\"><path d=\"M24.285,11.284L16,19.571l-8.285-8.288c-0.395-0.395-1.034-0.395-1.429,0  c-0.394,0.395-0.394,1.035,0,1.43l8.999,9.002l0,0l0,0c0.394,0.395,1.034,0.395,1.428,0l8.999-9.002  c0.394-0.395,0.394-1.036,0-1.431C25.319,10.889,24.679,10.889,24.285,11.284z\" fill=\"#121313\" id=\"Expand_More\"/><g/><g/><g/><g/><g/><g/></svg>\n    </span>\n</button>\n`\n})\nexport class Ng2DropdownButton {\n    @Output() public onMenuToggled: EventEmitter<boolean> = new EventEmitter<boolean>();\n    @Input() public showCaret: boolean = true;\n\n    constructor(private element: ElementRef) {}\n\n    /**\n     * @name toggleMenu\n     * @desc emits event to toggle menu\n     */\n    public toggleMenu(): void {\n        this.onMenuToggled.emit(true);\n    }\n\n    /**\n     * @name getPosition\n     * @desc returns position of the button\n     */\n    public getPosition(): ClientRect {\n      return this.element.nativeElement.getBoundingClientRect();\n    }\n}\n","import { Ng2MenuItem } from '../menu-item/ng2-menu-item';\nimport { Ng2DropdownMenu } from './ng2-dropdown-menu';\nimport { Ng2DropdownState } from '../../services/ng2-dropdown-state';\n\nconst KEYS = {\n    BACKSPACE: 9,\n    PREV: 38,\n    NEXT: 40,\n    ENTER: 13,\n    ESCAPE: 27\n};\n\n/**\n * @name onSwitchNext\n * @param index\n * @param items\n * @param state\n */\nconst onSwitchNext = (index: number, items: Ng2MenuItem[], state: Ng2DropdownState) => {\n    if (index < items.length - 1) {\n        state.select(items[index + 1], true);\n    }\n};\n\n/**\n * @name onSwitchPrev\n * @param index\n * @param items\n * @param state\n */\nconst onSwitchPrev = (index: number, items: Ng2MenuItem[], state: Ng2DropdownState) => {\n    if (index > 0) {\n        state.select(items[index - 1], true);\n    }\n};\n\n/**\n * @name onBackspace\n * @param index\n * @param items\n * @param state\n */\nconst onBackspace = (index: number, items: Ng2MenuItem[], state: Ng2DropdownState) => {\n    if (index < items.length - 1) {\n        state.select(items[index + 1], true);\n    } else {\n        state.select(items[0], true);\n    }\n};\n\nfunction onEscape(this: Ng2DropdownMenu) {\n    this.hide();\n};\n\n/**\n * @name onItemClicked\n * @param index\n * @param items\n * @param state\n */\nconst onItemClicked = (index: number, items: Ng2MenuItem[], state: Ng2DropdownState) => {\n    return state.selectedItem ? state.selectedItem.click() : undefined;\n};\n\nexport const ACTIONS = {\n    [KEYS.BACKSPACE]: onBackspace,\n    [KEYS.PREV]: onSwitchPrev,\n    [KEYS.NEXT]: onSwitchNext,\n    [KEYS.ENTER]: onItemClicked,\n    [KEYS.ESCAPE]: onEscape\n};\n\nexport function arrowKeysHandler(event): void {\n    if ([38, 40].indexOf(event.keyCode) > -1) {\n        event.preventDefault();\n    }\n}\n","import { EventEmitter } from '@angular/core';\nimport { Ng2MenuItem } from '../components/menu-item/ng2-menu-item';\nexport class Ng2DropdownState {\n    public onItemSelected: EventEmitter<Ng2MenuItem> = new EventEmitter<Ng2MenuItem>();\n    public onItemClicked: EventEmitter<Ng2MenuItem> = new EventEmitter<Ng2MenuItem>();\n    public onItemDestroyed: EventEmitter<Ng2MenuItem> = new EventEmitter<Ng2MenuItem>();\n\n    private _selectedItem: Ng2MenuItem;\n\n    /**\n     * @name selectedItem\n     * @desc getter for _selectedItem\n     */\n    public get selectedItem(): Ng2MenuItem {\n        return this._selectedItem;\n    }\n\n    /**\n     * @name selects a menu item and emits event\n     * @param item\n     */\n    public select(item: Ng2MenuItem | undefined, dispatchEvent = true): void {\n        this._selectedItem = item;\n\n        if (!dispatchEvent || !item) {\n            return;\n        }\n\n        item.focus();\n\n        this.onItemSelected.emit(item);\n    }\n\n    /**\n     * @name unselect\n     * @desc sets _selectedItem as undefined\n     */\n    public unselect(): void {\n        this._selectedItem = undefined;\n    }\n}\n","import { Injectable } from '@angular/core';\nimport { Ng2DropdownState } from './ng2-dropdown-state';\n\n@Injectable()\nexport class DropdownStateService {\n    public menuState = {\n        isVisible: <boolean>false,\n        toString(): string {\n            return this.isVisible === true ? 'visible' : 'hidden';\n        }\n    };\n\n    public dropdownState: Ng2DropdownState = new Ng2DropdownState();\n}\n","import {\n    Component,\n    Input,\n    Renderer,\n    ElementRef,\n    OnDestroy\n} from '@angular/core';\n\nimport { DropdownStateService } from '../../services/dropdown-state.service';\n\n@Component({\n    selector: 'ng2-menu-item',\n    styles: [`.ng2-menu-item{font-family:Roboto,\"Helvetica Neue\",Helvetica,Arial;background:#fff;color:rgba(0,0,0,.87);cursor:pointer;font-size:.9em;text-transform:none;font-weight:400;letter-spacing:.03em;height:48px;line-height:48px;padding:.3em 1.25rem;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;transition:background .25s}.ng2-menu-item--selected{background:rgba(158,158,158,.2);outline:0}.ng2-menu-item:focus{outline:0}.ng2-menu-item:active{background:rgba(158,158,158,.4)}:host(ng2-menu-item) /deep/ [ng2-menu-item-icon]{vertical-align:middle;font-size:28px;width:1.5em;height:30px;color:rgba(0,0,0,.44)}`],\n    template: `<div class='ng2-menu-item'\n     role=\"button\"\n     tabindex=\"0\"\n     [class.ng2-menu-item--selected]=\"isSelected\"\n     (keydown.enter)=\"click()\"\n     (click)=\"click()\"\n     (mouseover)=\"select()\">\n        <ng-content></ng-content>\n</div>\n`\n})\nexport class Ng2MenuItem implements OnDestroy {\n    /**\n     * @preventClose\n     * @desc if true, clicking on the item won't close the dropdown\n     */\n    @Input() public preventClose: boolean = false;\n\n    /**\n     * @name value\n     * @desc any value associated to the item\n     */\n    @Input() public value: any;\n\n    constructor(private state: DropdownStateService,\n                private element: ElementRef,\n                private renderer: Renderer) {}\n\n    public ngOnDestroy(): void {\n        this.state.dropdownState.onItemDestroyed.emit(this);\n    }\n\n    /**\n     * @name isSelected\n     * @desc returns current selected item\n     */\n    public get isSelected(): boolean {\n        return this === this.state.dropdownState.selectedItem;\n    }\n\n    /**\n     * @name click\n     * @desc emits select event\n     */\n    public select($event?): void {\n        this.state.dropdownState.select(this, true);\n\n        if ($event) {\n            $event.stopPropagation();\n            $event.preventDefault();\n        }\n    }\n\n    /**\n     * @name click\n     * @desc emits click event\n     */\n    public click(): void {\n        this.state.dropdownState.onItemClicked.emit(this);\n    }\n\n    /**\n     * @name focus\n     */\n    public focus() {\n        this.renderer.invokeElementMethod(this.element.nativeElement.children[0], 'focus');\n    }\n}\n","import {\n    Component,\n    ElementRef,\n    Renderer,\n    ContentChildren,\n    QueryList,\n    Input\n} from '@angular/core';\n\nimport {\n    trigger,\n    style,\n    transition,\n    animate,\n    keyframes,\n    state\n} from '@angular/animations';\n\nimport { ACTIONS, arrowKeysHandler } from './actions';\n\nimport { Ng2MenuItem } from '../menu-item/ng2-menu-item';\nimport { DropdownStateService } from '../../services/dropdown-state.service';\n\n@Component({\n    selector: 'ng2-dropdown-menu',\n    styles: [`:host{display:block}.ng2-dropdown-menu{overflow-y:auto;box-shadow:0 1px 2px 0 rgba(0,0,0,.3);position:absolute;padding:.5em 0;background:#fff;border-radius:1px;max-height:400px;width:260px;min-height:0;display:block}.ng2-dropdown-menu.ng2-dropdown-menu--inside-element{position:fixed}.ng2-dropdown-menu.ng2-dropdown-menu--width--2{width:200px}.ng2-dropdown-menu.ng2-dropdown-menu--width--4{width:260px}.ng2-dropdown-menu.ng2-dropdown-menu--width--6{width:320px}.ng2-dropdown-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1;overflow:hidden}:host /deep/ .ng2-menu-divider{height:1px;min-height:1px;max-height:1px;width:100%;display:block;background:#f9f9f9}`],\n    template: `<!-- MENU -->\n<div class='ng2-dropdown-menu ng2-dropdown-menu---width--{{ width }}'\n     [class.ng2-dropdown-menu--inside-element]=\"!appendToBody\"\n     [class.ng2-dropdown-menu--open]=\"state.menuState.isVisible\"\n     [style.z-index]=\"zIndex\"\n     [@fade]=\"state.menuState.toString()\">\n        <div class=\"ng2-dropdown-menu__options-container\"\n             [@opacity]=\"state.menuState.toString()\">\n            <ng-content></ng-content>\n        </div>\n</div>\n\n<!-- BACKDROP -->\n<div class=\"ng2-dropdown-backdrop\" *ngIf=\"state.menuState.isVisible\" (click)=\"hide()\"></div>\n`,\n    animations: [\n        trigger('fade', [\n            state('visible', style(\n                {display: 'block', opacity: 1, height: '*', width: '*'}\n            )),\n            state('hidden', style(\n                {display: 'none', opacity: 0, overflow: 'hidden', height: 0, width: 0}\n            )),\n            transition('hidden => visible', [\n                animate('250ms ease-in',\n                    style({opacity: 1, height: '*', width: '*'})\n                )\n            ]),\n            transition('visible => hidden', [\n                animate('350ms ease-out',\n                    style({opacity: 0, width: 0, height: 0})\n                )\n            ])\n        ]),\n        trigger('opacity', [\n            transition('hidden => visible', [\n                animate('450ms ease-in', keyframes([\n                    style({opacity: 0, offset: 0}),\n                    style({opacity: 1, offset: 1}),\n                ]))\n            ]),\n            transition('visible => hidden', [\n                animate('250ms ease-out', keyframes([\n                    style({opacity: 1, offset: 0}),\n                    style({opacity: 0.5, offset: 0.3}),\n                    style({opacity: 0, offset: 1}),\n                ]))\n            ])\n        ])\n    ]\n})\nexport class Ng2DropdownMenu {\n    /**\n     * @name width\n     */\n    @Input() public width: number = 4;\n\n    /**\n     * @description if set to true, the first element of the dropdown will be automatically focused\n     * @name focusFirstElement\n     */\n    @Input() public focusFirstElement: boolean = true;\n\n    /**\n     * @description sets dropdown offset from the button\n     * @name offset {string} follow format '<number> <number>' ex. '0 20'\n     */\n    @Input() public offset: string;\n\n    /**\n     * @name appendToBody\n     */\n    @Input() public appendToBody: boolean = true;\n\n    /**\n     * @name zIndex\n     */\n    @Input() public zIndex = 1000;\n\n    /**\n     * @name items\n     */\n    @ContentChildren(Ng2MenuItem) public items: QueryList<Ng2MenuItem>;\n\n    private position: ClientRect;\n\n    private listeners = {\n        arrowHandler: undefined,\n        handleKeypress: undefined\n    };\n\n    constructor(public state: DropdownStateService,\n                private element: ElementRef,\n                private renderer: Renderer) {}\n\n    /**\n     * @name show\n     * @shows menu and selects first item\n     */\n    public show(position?: ClientRect, dynamic = true): void {\n        const dc = typeof document !== 'undefined' ? document : undefined;\n        const wd = typeof window !== 'undefined' ? window : undefined;\n\n        if (!this.state.menuState.isVisible) {\n            // setting handlers\n            this.listeners.handleKeypress = this.renderer.listen(dc.body, 'keydown', this.handleKeypress.bind(this));\n            this.listeners.arrowHandler = this.renderer.listen(wd, 'keydown', arrowKeysHandler);\n        }\n\n        // update state\n        this.state.menuState.isVisible = true;\n\n        if (position) {\n            this.updatePosition(position, dynamic);\n        }\n    }\n\n    /**\n     * @name hide\n     * @desc hides menu\n     */\n    public hide(): void {\n        this.state.menuState.isVisible = false;\n\n        // reset selected item state\n        this.state.dropdownState.unselect();\n\n        // call function to unlisten\n        this.listeners.arrowHandler ? this.listeners.arrowHandler() : undefined;\n        this.listeners.handleKeypress ? this.listeners.handleKeypress() : undefined;\n    }\n\n    /**\n     * @name updatePosition\n     * @desc updates the menu position every time it is toggled\n     * @param position {ClientRect}\n     * @param dynamic {boolean}\n     */\n    public updatePosition(position: ClientRect, dynamic: boolean): void {\n        this.position = position;\n        this.updateOnChange(dynamic);\n    }\n\n    /**\n     * @name handleKeypress\n     * @desc executes functions on keyPress based on the key pressed\n     * @param $event\n     */\n    public handleKeypress($event): void {\n        const key = $event.keyCode;\n        const items = this.items.toArray();\n        const index = items.indexOf(this.state.dropdownState.selectedItem);\n\n        if (!ACTIONS.hasOwnProperty(key)) {\n            return;\n        }\n\n        ACTIONS[key].call(this, index, items, this.state.dropdownState);\n    }\n\n    /**\n     * @name getMenuElement\n     */\n    private getMenuElement(): Element {\n        return this.element.nativeElement.children[0];\n    }\n\n    /**\n     * @name calcPositionOffset\n     * @param position\n     */\n    private calcPositionOffset(position): { top: string, left: string } {\n        const wd = typeof window !== 'undefined' ? window : undefined;\n        const dc = typeof document !== 'undefined' ? document : undefined;\n\n        if (!wd || !dc || !position) {\n            return;\n        }\n\n        const element = this.getMenuElement();\n        const supportPageOffset = wd.pageXOffset !== undefined;\n        const isCSS1Compat = ((dc.compatMode || '') === 'CSS1Compat');\n\n        const x = supportPageOffset ? wd.pageXOffset : isCSS1Compat ?\n            dc.documentElement.scrollLeft : dc.body.scrollLeft;\n\n        const y = supportPageOffset ? wd.pageYOffset : isCSS1Compat ?\n            dc.documentElement.scrollTop : dc.body.scrollTop;\n\n        let { top, left } = this.applyOffset(\n            `${position.top + (this.appendToBody ? y - 15 : 0)}px`,\n            `${position.left + x - 5}px`\n        );\n\n        const clientWidth = element.clientWidth;\n        const clientHeight = element.clientHeight;\n\n        const marginFromBottom = parseInt(top) + clientHeight + (this.appendToBody ? 0 : y - 15);\n        const marginFromRight = parseInt(left) + clientWidth;\n\n        const windowScrollHeight = wd.innerHeight + wd.scrollY;\n        const windowScrollWidth = wd.innerWidth + wd.scrollX;\n\n        if (marginFromBottom >= windowScrollHeight) {\n            top = `${parseInt(top.replace('px', '')) - clientHeight}px`;\n        }\n\n        if (marginFromRight >= windowScrollWidth) {\n            const marginRight = marginFromRight - windowScrollWidth + 30;\n            left = `${parseInt(left.replace('px', '')) - marginRight}px`;\n        }\n\n        return { top, left };\n    }\n\n    private applyOffset(top: string, left: string): { top: string, left: string } {\n        if (!this.offset) {\n            return { top, left };\n        }\n\n        const offset = this.offset.split(' ');\n\n        if (!offset[1]) {\n            offset[1] = '0';\n        }\n\n        top = `${parseInt(top.replace('px', '')) + parseInt(offset[0])}px`;\n        left = `${parseInt(left.replace('px', '')) + parseInt(offset[1])}px`;\n\n        return { top, left };\n    }\n\n    public ngOnInit() {\n        const dc = typeof document !== 'undefined' ? document : undefined;\n        if (this.appendToBody) {\n            // append menu element to the body\n            dc.body.appendChild(this.element.nativeElement);\n        }\n    }\n\n    public updateOnChange(dynamic = true) {\n        const element = this.getMenuElement();\n        const position = this.calcPositionOffset(this.position);\n\n        if (position) {\n            this.renderer.setElementStyle(element, 'top', position.top.toString());\n            this.renderer.setElementStyle(element, 'left', position.left.toString());\n        }\n\n        // select first item unless user disabled this option\n        if (this.focusFirstElement &&\n            this.items.first &&\n            !this.state.dropdownState.selectedItem) {\n            this.state.dropdownState.select(this.items.first, false);\n        }\n    }\n\n    public ngOnDestroy() {\n        const elem = this.element.nativeElement;\n        elem.parentNode.removeChild(elem);\n\n        if (this.listeners.handleKeypress) {\n            this.listeners.handleKeypress();\n        }\n    }\n}\n","import {\n    HostListener,\n    Component,\n    ContentChild,\n    Output,\n    EventEmitter,\n    Input\n} from '@angular/core';\n\nimport { Ng2DropdownButton } from '../button/ng2-dropdown-button';\nimport { Ng2DropdownMenu } from '../menu/ng2-dropdown-menu';\nimport { DropdownStateService } from '../../services/dropdown-state.service';\nimport { Ng2MenuItem } from '../menu-item/ng2-menu-item';\n\n@Component({\n    selector: 'ng2-dropdown',\n    template: `<div class=\"ng2-dropdown-container\">\n    <ng-content select=\"ng2-dropdown-button\"></ng-content>\n    <ng-content select=\"ng2-dropdown-menu\"></ng-content>\n</div>\n`,\n    providers: [ DropdownStateService ]\n})\nexport class Ng2Dropdown {\n    // get children components\n    @ContentChild(Ng2DropdownButton) public button: Ng2DropdownButton;\n    @ContentChild(Ng2DropdownMenu) public menu: Ng2DropdownMenu;\n\n    @Input() public dynamicUpdate = true;\n\n    // outputs\n    @Output() public onItemClicked: EventEmitter<string> = new EventEmitter<string>();\n    @Output() public onItemSelected: EventEmitter<string> = new EventEmitter<string>();\n    @Output() public onShow: EventEmitter<Ng2Dropdown> = new EventEmitter<Ng2Dropdown>();\n    @Output() public onHide: EventEmitter<Ng2Dropdown> = new EventEmitter<Ng2Dropdown>();\n\n    constructor(private state: DropdownStateService) {}\n\n    public ngOnInit() {\n        this.state.dropdownState.onItemClicked.subscribe(item => {\n            this.onItemClicked.emit(item);\n\n            if (item.preventClose) {\n                return;\n            }\n\n            this.hide.call(this);\n        });\n\n        if (this.button) {\n            this.button.onMenuToggled.subscribe(() => {\n                this.toggleMenu();\n            });\n        }\n\n        this.state.dropdownState.onItemSelected.subscribe(item => {\n            this.onItemSelected.emit(item);\n        });\n\n        this.state.dropdownState.onItemDestroyed.subscribe((item: Ng2MenuItem) => {\n            let newSelectedItem: Ng2MenuItem | undefined;\n            const items = this.menu.items.toArray();\n\n            if (item !== this.state.dropdownState.selectedItem) {\n                return;\n            }\n\n            if (this.menu.focusFirstElement) {\n                newSelectedItem = item === items[0] && items.length > 1 ? items[1] : items[0];\n            }\n\n            this.state.dropdownState.select(newSelectedItem);\n        });\n    }\n\n    /**\n     * @name toggleMenu\n     * @desc toggles menu visibility\n     */\n    public toggleMenu(position = this.button.getPosition()): void {\n        this.state.menuState.isVisible ? this.hide() : this.show(position);\n    }\n\n    /**\n     * - hides dropdown\n     * @name hide\n     */\n    public hide(): void {\n        this.menu.hide();\n        this.onHide.emit(this);\n    }\n\n    /**\n     * - shows dropdown\n     * @name show\n     * @param position\n     */\n    public show(position = this.button.getPosition()): void {\n        this.menu.show(position, this.dynamicUpdate);\n        this.onShow.emit(this);\n    }\n\n    /**\n     * @name scrollListener\n     */\n    @HostListener('window:scroll')\n    public scrollListener() {\n        if (this.button && this.dynamicUpdate) {\n            this.menu.updatePosition(this.button.getPosition(), true);\n        }\n    }\n}\n","import { Ng2Dropdown } from './components/dropdown/ng2-dropdown';\nimport { Ng2DropdownMenu } from './components/menu/ng2-dropdown-menu';\nimport { Ng2DropdownButton } from './components/button/ng2-dropdown-button';\nimport { Ng2MenuItem } from './components/menu-item/ng2-menu-item';\n\nimport { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { DropdownStateService } from './services/dropdown-state.service';\n\n@NgModule({\n    exports: [\n        Ng2MenuItem,\n        Ng2DropdownButton,\n        Ng2DropdownMenu,\n        Ng2Dropdown\n    ],\n    declarations: [\n        Ng2Dropdown,\n        Ng2MenuItem,\n        Ng2DropdownButton,\n        Ng2DropdownMenu,\n    ],\n    imports: [\n        CommonModule\n    ]\n})\nexport class Ng2DropdownModule {}\n\nexport {\n    Ng2Dropdown,\n    Ng2DropdownMenu,\n    Ng2MenuItem,\n    Ng2DropdownButton,\n    DropdownStateService\n}\n"],"names":["state"],"mappings":"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"}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/ng2-material-dropdown/fesm5/ng2-material-dropdown.js\n// module id = 1016\n// module chunks = 8","import { NgModule } from '@angular/core';\r\nimport { IonicPageModule } from 'ionic-angular';\r\nimport { EmailTemplatePage } from './email-template';\r\nimport { TagInputModule } from 'ngx-chips';\r\n//import { BrowserAnimationsModule } from '@angular/platform-browser/animations';\r\nimport {IonTagsInputModule} from \"ionic-tags-input\";\r\n\r\n@NgModule({\r\n declarations: [\r\n EmailTemplatePage,\r\n ],\r\n providers: [ TagInputModule, IonTagsInputModule ],\r\n imports: [\r\n IonicPageModule.forChild(EmailTemplatePage),\r\n TagInputModule,\r\n IonTagsInputModule,\r\n ],\r\n})\r\nexport class EmailTemplatePageModule {}\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/pages/email-template/email-template.module.ts"],"sourceRoot":""}
\\n {{ error }}\\n