├── .editorconfig
├── .gitignore
├── .npmignore
├── CHANGELOG.md
├── LICENSE
├── README.md
├── babel.config.js
├── bower.json
├── demo
├── Demo.vue
├── animate.css
├── index.html
└── main.js
├── dist
├── vue-toastr.common.js
├── vue-toastr.esm.js
├── vue-toastr.umd.js
└── vue-toastr.umd.min.js
├── docs
├── .vuepress
│ ├── config.js
│ └── plugin.js
├── README.md
├── global_options.md
├── installation.md
├── started.md
├── toast_options.md
├── usage_browser.md
└── usage_module.md
├── jest.config.js
├── package-lock.json
├── package.json
├── src
├── components
│ ├── IntervalTimeManager.js
│ ├── Toast.vue
│ ├── ToastProgress.vue
│ ├── Toastr.vue
│ └── VueToastr.vue
├── index.js
└── vue-toastr.scss
├── tests
└── unit
│ ├── .eslintrc.js
│ ├── Toast.spec.js
│ ├── ToastProgress.spec.js
│ └── __snapshots__
│ ├── Toast.spec.js.snap
│ └── ToastProgress.spec.js.snap
└── yarn.lock
/.editorconfig:
--------------------------------------------------------------------------------
1 | root = true
2 |
3 | [*]
4 | charset = utf-8
5 | indent_style = space
6 | indent_size = 2
7 | end_of_line = lf
8 | insert_final_newline = true
9 | trim_trailing_whitespace = true
10 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | .DS_Store
2 | node_modules
3 | public
4 | dist/*.gz
5 | dist/*.map
6 | coverage
7 | docs/.vuepress/dist
8 |
9 | # local env files
10 | .env.local
11 | .env.*.local
12 |
13 | # related test files
14 | /tests/e2e/reports
15 | /tests/e2e/videos
16 | /tests/e2e/screenshots
17 |
18 | # editor directories and files
19 | .idea
20 | .vscode
21 | *.suo
22 | *.ntvs*
23 | *.njsproj
24 | *.sln
25 | *.sw*
26 |
--------------------------------------------------------------------------------
/.npmignore:
--------------------------------------------------------------------------------
1 | build
2 | docs
3 | bower.json
--------------------------------------------------------------------------------
/CHANGELOG.md:
--------------------------------------------------------------------------------
1 | // TODO: release log here ...
2 |
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | The MIT License (MIT)
2 |
3 | Copyright (c) 2019
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy of
6 | this software and associated documentation files (the "Software"), to deal in
7 | the Software without restriction, including without limitation the rights to
8 | use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
9 | the Software, and to permit persons to whom the Software is furnished to do so,
10 | subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
17 | FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
18 | COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
19 | IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
20 | CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
21 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # vue-toastr
2 |
3 | You can find **React.js** version of this library from [here](https://github.com/s4l1h/react-toasted)
4 |
5 |
6 |
7 | ```
8 | For Vue.js 3 => vue-toastr@3.0.5 (still beta) There is no breaking changes.The api is as same as v2.
9 | The Only changed thing is JS files doesn't include css file content.
10 | You need to import dist/style.css or src/vue-toastr.scss to your project.
11 | This gives more flexibility to library.
12 |
13 | Dev branch: https://github.com/s4l1h/vue-toastr/tree/dev-v3
14 | Demo: https://codesandbox.io/s/quizzical-grass-eb62u
15 |
16 |
17 | ```
18 | For Vue.js 3 => [vue-toastr@3.0.5](https://github.com/s4l1h/vue-toastr/tree/dev-v3)
19 |
20 | For Vue.js 2 => [vue-toastr@2.1.2](https://github.com/s4l1h/vue-toastr/tree/master)
21 |
22 | For Vue.js 1 => [vue-toastr@1.0.4](https://github.com/s4l1h/vue-toastr/tree/1.0)
23 |
24 |
25 | ## Project setup
26 |
27 | ```
28 | yarn install
29 | ```
30 |
31 | ### Compiles and hot-reloads for development
32 |
33 | ```
34 | yarn run demo
35 | ```
36 |
37 | ### Compiles and minifies for production
38 |
39 | ```
40 | yarn run build
41 | ```
42 |
43 | ### Lints and fixes files
44 |
45 | ```
46 | yarn run lint
47 | ```
48 |
49 | ### Build and Watch Documentation
50 |
51 | ```
52 | yarn run docs
53 | ```
54 |
55 | ### Reference and documentation
56 |
57 | See [http://s4l1h.github.io/vue-toastr/](http://s4l1h.github.io/vue-toastr/).
58 |
59 | ### Basic Demo
60 |
61 | [https://codepen.io/s4l1h/pen/PyaRGQ](https://codepen.io/s4l1h/pen/PyaRGQ)
62 |
63 | ### Contribute
64 |
65 | You can send your pull requests via the dev branch.
66 |
--------------------------------------------------------------------------------
/babel.config.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | presets: ["@vue/app"]
3 | }
4 |
--------------------------------------------------------------------------------
/bower.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "vue-toastr",
3 | "main": "dist/vue-toastr.umd.min.js",
4 | "description": "Toastr for Vue.js",
5 | "version": "2.1.2",
6 | "homepage": "https://github.com/s4l1h/vue-toastr",
7 | "license": "MIT",
8 | "ignore": [".*", "build", "docs", "demo", "package.json"]
9 | }
10 |
--------------------------------------------------------------------------------
/demo/Demo.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | SHOW ME
6 | Remove Sticky Toast By Name
11 |
12 |
13 |
14 |
15 |
16 |
17 |
117 |
118 |
119 |
131 |
--------------------------------------------------------------------------------
/demo/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | Vue Toastr Plugin Demo
6 |
7 |
8 |
9 |
10 |
11 |
--------------------------------------------------------------------------------
/demo/main.js:
--------------------------------------------------------------------------------
1 | import Vue from "vue";
2 | import App from "./Demo.vue";
3 | // import "../src/plugin";
4 | require("./animate.css");
5 | // import VueToastr, { Toastr, Toast, ToastProgress } from "../src/index";
6 | import VueToastr from "../src/index";
7 |
8 | Vue.use(VueToastr);
9 |
10 | Vue.config.productionTip = false;
11 |
12 | new Vue({
13 | render: h => h(App)
14 | }).$mount("#app");
15 |
--------------------------------------------------------------------------------
/dist/vue-toastr.common.js:
--------------------------------------------------------------------------------
1 | /*!
2 | * vue-toastr v2.1.2
3 | * (c) 2019 s4l1h
4 | * Released under the MIT License.
5 | */
6 | 'use strict';
7 |
8 | function _typeof(obj) {
9 | if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") {
10 | _typeof = function (obj) {
11 | return typeof obj;
12 | };
13 | } else {
14 | _typeof = function (obj) {
15 | return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
16 | };
17 | }
18 |
19 | return _typeof(obj);
20 | }
21 |
22 | //
23 | //
24 | //
25 | var script = {
26 | props: {
27 | percent: {
28 | type: Number,
29 | default: 100
30 | }
31 | },
32 | computed: {
33 | style: function style() {
34 | return {
35 | width: this.percent.toString() + "%"
36 | };
37 | }
38 | }
39 | };
40 |
41 | function normalizeComponent(template, style, script, scopeId, isFunctionalTemplate, moduleIdentifier
42 | /* server only */
43 | , shadowMode, createInjector, createInjectorSSR, createInjectorShadow) {
44 | if (typeof shadowMode !== 'boolean') {
45 | createInjectorSSR = createInjector;
46 | createInjector = shadowMode;
47 | shadowMode = false;
48 | } // Vue.extend constructor export interop.
49 |
50 |
51 | var options = typeof script === 'function' ? script.options : script; // render functions
52 |
53 | if (template && template.render) {
54 | options.render = template.render;
55 | options.staticRenderFns = template.staticRenderFns;
56 | options._compiled = true; // functional template
57 |
58 | if (isFunctionalTemplate) {
59 | options.functional = true;
60 | }
61 | } // scopedId
62 |
63 |
64 | if (scopeId) {
65 | options._scopeId = scopeId;
66 | }
67 |
68 | var hook;
69 |
70 | if (moduleIdentifier) {
71 | // server build
72 | hook = function hook(context) {
73 | // 2.3 injection
74 | context = context || // cached call
75 | this.$vnode && this.$vnode.ssrContext || // stateful
76 | this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext; // functional
77 | // 2.2 with runInNewContext: true
78 |
79 | if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
80 | context = __VUE_SSR_CONTEXT__;
81 | } // inject component styles
82 |
83 |
84 | if (style) {
85 | style.call(this, createInjectorSSR(context));
86 | } // register component module identifier for async chunk inference
87 |
88 |
89 | if (context && context._registeredComponents) {
90 | context._registeredComponents.add(moduleIdentifier);
91 | }
92 | }; // used by ssr in case component is cached and beforeCreate
93 | // never gets called
94 |
95 |
96 | options._ssrRegister = hook;
97 | } else if (style) {
98 | hook = shadowMode ? function () {
99 | style.call(this, createInjectorShadow(this.$root.$options.shadowRoot));
100 | } : function (context) {
101 | style.call(this, createInjector(context));
102 | };
103 | }
104 |
105 | if (hook) {
106 | if (options.functional) {
107 | // register for functional component in vue file
108 | var originalRender = options.render;
109 |
110 | options.render = function renderWithStyleInjection(h, context) {
111 | hook.call(context);
112 | return originalRender(h, context);
113 | };
114 | } else {
115 | // inject component registration as beforeCreate hook
116 | var existing = options.beforeCreate;
117 | options.beforeCreate = existing ? [].concat(existing, hook) : [hook];
118 | }
119 | }
120 |
121 | return script;
122 | }
123 |
124 | var normalizeComponent_1 = normalizeComponent;
125 |
126 | /* script */
127 | const __vue_script__ = script;
128 |
129 | /* template */
130 | var __vue_render__ = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"toast-progress",style:(_vm.style)})};
131 | var __vue_staticRenderFns__ = [];
132 |
133 | /* style */
134 | const __vue_inject_styles__ = undefined;
135 | /* scoped */
136 | const __vue_scope_id__ = undefined;
137 | /* module identifier */
138 | const __vue_module_identifier__ = undefined;
139 | /* functional template */
140 | const __vue_is_functional_template__ = false;
141 | /* style inject */
142 |
143 | /* style inject SSR */
144 |
145 |
146 |
147 | var ToastProgress = normalizeComponent_1(
148 | { render: __vue_render__, staticRenderFns: __vue_staticRenderFns__ },
149 | __vue_inject_styles__,
150 | __vue_script__,
151 | __vue_scope_id__,
152 | __vue_is_functional_template__,
153 | __vue_module_identifier__,
154 | undefined,
155 | undefined
156 | );
157 |
158 | var IntervalTimeManager = function IntervalTimeManager(params) {
159 | return {
160 | id: false,
161 | times: {},
162 | estimated: null,
163 | remaning: null,
164 | totalTime: params.totalTime || 5000,
165 | stepTime: params.stepTime || 50,
166 | callbackFunctions: params.callbackFunctions || {},
167 | callback: function callback() {
168 | this.times["callback"] = this.getTime();
169 | this.remaning = this.remaning - this.stepTime;
170 | this.estimated = this.estimated + this.stepTime;
171 | this.callCallbackFN("callback");
172 |
173 | if (this.remaning <= 0) {
174 | return this.finish();
175 | }
176 | },
177 | getTime: function getTime() {
178 | return new Date().getTime();
179 | },
180 | getPercent: function getPercent() {
181 | return Math.floor(this.remaning / this.totalTime * 100);
182 | },
183 | start: function start() {
184 | this.times["started"] = this.getTime();
185 | this.callCallbackFN("before:start");
186 | this.remaning = this.totalTime;
187 |
188 | this._setupInterval();
189 |
190 | this.callCallbackFN("after:start");
191 | },
192 | finish: function finish() {
193 | this.times["finished"] = this.getTime();
194 | this.callCallbackFN("before:finish");
195 |
196 | this._clearInterval(this.id);
197 |
198 | this.callCallbackFN("after:finish");
199 | },
200 | stop: function stop() {
201 | this.times["stoped"] = this.getTime(); // People can stop manualy
202 |
203 | this.callCallbackFN("before:stop");
204 |
205 | this._clearInterval(this.id);
206 |
207 | this.callCallbackFN("after:stop");
208 | },
209 | pause: function pause() {
210 | this.times["paused"] = this.getTime();
211 | this.callCallbackFN("before:pause");
212 |
213 | this._clearInterval(this.id);
214 |
215 | this.callCallbackFN("after:pause");
216 | },
217 | resume: function resume() {
218 | this.times["resumed"] = this.getTime();
219 | this.callCallbackFN("before:resume");
220 |
221 | this._setupInterval();
222 |
223 | this.callCallbackFN("after:resume");
224 | },
225 | callCallbackFN: function callCallbackFN(type) {
226 | // console.log(this.callbackFunctions, type);
227 | if (typeof this.callbackFunctions[type] === "function") {
228 | this.callbackFunctions[type]();
229 | }
230 | },
231 | _clearInterval: function _clearInterval() {
232 | clearInterval(this.id);
233 | },
234 | _setupInterval: function _setupInterval() {
235 | var _this = this;
236 |
237 | this.id = setInterval(function () {
238 | _this.callback();
239 | }, this.stepTime);
240 | }
241 | };
242 | };
243 |
244 | //
245 | var script$1 = {
246 | components: {
247 | ToastProgress: ToastProgress
248 | },
249 | props: ["data"],
250 | data: function data() {
251 | return {
252 | progressbar: false,
253 | progressBarTimer: null,
254 | timeoutTimer: null
255 | };
256 | },
257 | mounted: function mounted() {
258 | // console.log("ready", this.data);
259 | if (this.progressBarTimer != null) {
260 | this.progressBarTimer.start();
261 | }
262 |
263 | if (this.timeoutTimer != null) {
264 | this.timeoutTimer.start();
265 | }
266 | },
267 | created: function created() {
268 | var _this = this;
269 |
270 | if (typeof this.data.timeout !== "undefined" && this.data.timeout !== 0) {
271 | // SetUP timeout Manager
272 | this.timeoutTimer = IntervalTimeManager({
273 | totalTime: this.data.timeout,
274 | callbackFunctions: {
275 | "after:finish": function afterFinish() {
276 | _this.close(); // console.log("Timeout Fired");
277 |
278 | }
279 | }
280 | }); // SetUP progressbar Time Manager
281 |
282 | if (this.data.progressbar !== false) {
283 | this.progressbar = true;
284 | this.progressBarTimer = IntervalTimeManager({
285 | totalTime: this.data.timeout
286 | });
287 | }
288 | } else if (this.data.progressBarValue !== null && this.data.progressbar !== false) {
289 | this.progressbar = true;
290 | }
291 | },
292 | computed: {
293 | classNames: function classNames() {
294 | return ["toast", "toast-" + this.data.type].concat(this.data.classNames);
295 | },
296 | progressBarPercent: function progressBarPercent() {
297 | if (this.data.progressBarValue != null) {
298 | return this.data.progressBarValue;
299 | }
300 |
301 | return this.progressBarTimer.getPercent();
302 | }
303 | },
304 | beforeDestroy: function beforeDestroy() {
305 | if (this.progressBarTimer != null) {
306 | this.progressBarTimer.stop();
307 | }
308 |
309 | if (this.timeoutTimer != null) {
310 | this.timeoutTimer.stop();
311 | }
312 | },
313 | methods: {
314 | // Enter Hover
315 | onMouseOver: function onMouseOver() {
316 | // console.log("onMouseOver")
317 | if (typeof this.data.onMouseOver !== "undefined") {
318 | this.data.onMouseOver();
319 | }
320 |
321 | if (this.data.closeOnHover) {
322 | if (this.progressBarTimer != null) {
323 | this.progressBarTimer.pause();
324 | }
325 |
326 | if (this.timeoutTimer != null) {
327 | this.timeoutTimer.pause();
328 | }
329 | }
330 | },
331 | // Leave Hover
332 | onMouseOut: function onMouseOut() {
333 | // console.log("onMouseOut")
334 | if (typeof this.data.onMouseOut !== "undefined") {
335 | this.data.onMouseOut();
336 | }
337 |
338 | if (this.data.closeOnHover) {
339 | if (this.progressBarTimer != null) {
340 | this.progressBarTimer.resume();
341 | }
342 |
343 | if (this.timeoutTimer != null) {
344 | this.timeoutTimer.resume();
345 | }
346 | }
347 | },
348 | // Clicked Toast
349 | clicked: function clicked() {
350 | if (typeof this.data.onClicked !== "undefined") {
351 | this.data.onClicked();
352 | }
353 |
354 | this.clickClose();
355 | },
356 | // Click Close?
357 | clickClose: function clickClose() {
358 | if (typeof this.data.clickClose !== "undefined" && this.data.clickClose === false) {
359 | return;
360 | }
361 |
362 | this.close();
363 | },
364 | // Close Toast
365 | close: function close() {
366 | // console.log(typeof this.$parent, this);
367 | // if toast not manuel closed.
368 | if (this.$parent != null) {
369 | this.$parent.Close(this.data);
370 | }
371 | }
372 | }
373 | };
374 |
375 | /* script */
376 | const __vue_script__$1 = script$1;
377 |
378 | /* template */
379 | var __vue_render__$1 = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{class:_vm.classNames,staticStyle:{"display":"block"},style:(_vm.data.style),on:{"click":function($event){return _vm.clicked()},"mouseover":_vm.onMouseOver,"mouseout":_vm.onMouseOut}},[(_vm.progressbar)?_c('toast-progress',{ref:"progressBar",attrs:{"percent":_vm.progressBarPercent}}):_vm._e(),_vm._v(" "),(_vm.data.title)?_c('div',{staticClass:"toast-title",domProps:{"innerHTML":_vm._s(_vm.data.title)}}):_vm._e(),_vm._v(" "),(_vm.data.msg && !_vm.$slots.default)?_c('div',{staticClass:"toast-message",domProps:{"innerHTML":_vm._s(_vm.data.msg)}}):_vm._e(),_vm._v(" "),(_vm.$slots.default)?_c('div',{staticClass:"toast-message"},[_vm._t("default")],2):_vm._e()],1)};
380 | var __vue_staticRenderFns__$1 = [];
381 |
382 | /* style */
383 | const __vue_inject_styles__$1 = undefined;
384 | /* scoped */
385 | const __vue_scope_id__$1 = undefined;
386 | /* module identifier */
387 | const __vue_module_identifier__$1 = undefined;
388 | /* functional template */
389 | const __vue_is_functional_template__$1 = false;
390 | /* style inject */
391 |
392 | /* style inject SSR */
393 |
394 |
395 |
396 | var toast = normalizeComponent_1(
397 | { render: __vue_render__$1, staticRenderFns: __vue_staticRenderFns__$1 },
398 | __vue_inject_styles__$1,
399 | __vue_script__$1,
400 | __vue_scope_id__$1,
401 | __vue_is_functional_template__$1,
402 | __vue_module_identifier__$1,
403 | undefined,
404 | undefined
405 | );
406 |
407 | var script$2 = {
408 | name: "VueToastr",
409 | props: {
410 | options: {
411 | type: Object,
412 | default: function _default() {
413 | return {};
414 | }
415 | }
416 | },
417 | data: function data() {
418 | var positions = ["toast-top-right", "toast-bottom-right", "toast-bottom-left", "toast-top-left", "toast-top-full-width", "toast-bottom-full-width", "toast-top-center", "toast-bottom-center"];
419 | var list = {};
420 |
421 | for (var i = 0; i <= positions.length - 1; i++) {
422 | list[positions[i]] = {};
423 | }
424 |
425 | return {
426 | positions: positions,
427 | defaultClassNames: this.processOption("defaultClassNames", []),
428 | defaultPosition: this.processOption("defaultPosition", "toast-top-right"),
429 | defaultType: this.processOption("defaultType", "success"),
430 | defaultCloseOnHover: this.processOption("defaultCloseOnHover", true),
431 | defaultTimeout: this.processOption("defaultTimeout", 5000),
432 | defaultProgressBar: this.processOption("defaultProgressBar", true),
433 | defaultProgressBarValue: this.processOption("defaultProgressBarValue", null),
434 | defaultPreventDuplicates: this.processOption("defaultPreventDuplicates", false),
435 | defaultStyle: this.processOption("defaultStyle", {}),
436 | list: list,
437 | index: 0,
438 | savedNames: {}
439 | };
440 | },
441 | created: function created() {// console.log("Created");
442 | },
443 | mounted: function mounted() {// console.log("ready", this.list);
444 | },
445 | components: {
446 | toast: toast
447 | },
448 | methods: {
449 | addToast: function addToast(data) {
450 | this.index++;
451 | data["index"] = this.index;
452 | this.$set(this.list[data.position], this.index, data);
453 |
454 | if (typeof data["name"] !== "undefined") {
455 | this.$set(this.savedNames, data["name"], data);
456 | } // if have onCreated
457 |
458 |
459 | if (typeof data.onCreated !== "undefined") {
460 | // wait doom update after call cb
461 | this.$nextTick(function () {
462 | data.onCreated();
463 | });
464 | }
465 | },
466 | removeByName: function removeByName(name) {
467 | if (typeof this.savedNames[name] !== "undefined") {
468 | this.Close(this.savedNames[name]);
469 | this.$delete(this.savedNames, name);
470 | }
471 | },
472 | removeToast: function removeToast(data) {
473 | var item = this.list[data.position][data.index]; // console.log("remove toast", data, item);
474 |
475 | if (typeof item !== "undefined") {
476 | this.$delete(this.list[data.position], data.index); // if have onClosed
477 |
478 | if (typeof data.onClosed !== "undefined") {
479 | // wait doom update after call cb
480 | this.$nextTick(function () {
481 | data.onClosed();
482 | });
483 | }
484 | }
485 | },
486 | setProgress: function setProgress(data, newValue) {
487 | var item = this.list[data.position][data.index];
488 |
489 | if (typeof item !== "undefined") {
490 | this.$set(item, "progressBarValue", newValue);
491 | }
492 | },
493 | Add: function Add(d) {
494 | return this.AddData(this.processObjectData(d));
495 | },
496 | AddData: function AddData(data) {
497 | if (_typeof(data) !== "object") {
498 | //console.log("AddData accept only Object", data);
499 | return false;
500 | }
501 |
502 | if (data.preventDuplicates) {
503 | var listKeys = Object.keys(this.list[data.position]);
504 |
505 | for (var i = 0; i < listKeys.length; i++) {
506 | if (this.list[data.position][listKeys[i]].title === data.title && this.list[data.position][listKeys[i]].msg === data.msg) {
507 | //console.log("Prevent Duplicates", data);
508 | return false;
509 | }
510 | }
511 | }
512 |
513 | this.addToast(data);
514 | return data;
515 | },
516 | processOption: function processOption(optionValue, defaultValue) {
517 | if (!this.options) {
518 | return defaultValue;
519 | }
520 |
521 | return typeof this.options[optionValue] !== "undefined" ? this.options[optionValue] : defaultValue;
522 | },
523 | processObjectData: function processObjectData(data) {
524 | // if Object
525 | if (_typeof(data) === "object" && typeof data.msg !== "undefined") {
526 | if (typeof data.classNames === "undefined") {
527 | data.classNames = this.defaultClassNames;
528 | }
529 |
530 | if (typeof data.position === "undefined") {
531 | data.position = this.defaultPosition;
532 | }
533 |
534 | if (typeof data.type === "undefined") {
535 | data.type = this.defaultType;
536 | }
537 |
538 | if (typeof data.timeout === "undefined") {
539 | data.timeout = this.defaultTimeout;
540 | } // have progressBar ?
541 |
542 |
543 | if (typeof data.progressbar === "undefined") {
544 | data.progressbar = this.defaultProgressBar;
545 | } // should progressBar be bound to timer or is set manually ?
546 |
547 |
548 | if (typeof data.progressBarValue === "undefined") {
549 | data.progressBarValue = this.defaultProgressBarValue;
550 | }
551 |
552 | if (typeof data.closeOnHover === "undefined") {
553 | data.closeOnHover = this.defaultCloseOnHover;
554 | }
555 |
556 | if (typeof data.preventDuplicates === "undefined") {
557 | data.preventDuplicates = this.defaultPreventDuplicates;
558 | }
559 |
560 | if (typeof data.style === "undefined") {
561 | data.style = this.defaultStyle;
562 | }
563 |
564 | return data;
565 | } // if String
566 |
567 |
568 | return {
569 | msg: data.toString(),
570 | position: this.defaultPosition,
571 | type: this.defaultType,
572 | timeout: this.defaultTimeout,
573 | closeOnHover: this.defaultCloseOnHover,
574 | progressbar: this.defaultProgressBar,
575 | progressBarValue: this.defaultProgressBarValue,
576 | preventDuplicates: this.defaultPreventDuplicates,
577 | style: this.defaultStyle,
578 | classNames: this.defaultClassNames
579 | };
580 | },
581 | e: function e(msg, title) {
582 | var data = this.processObjectData(msg);
583 | data["type"] = "error";
584 |
585 | if (typeof title !== "undefined") {
586 | data["title"] = title;
587 | }
588 |
589 | return this.AddData(data);
590 | },
591 | s: function s(msg, title) {
592 | var data = this.processObjectData(msg);
593 | data["type"] = "success";
594 |
595 | if (typeof title !== "undefined") {
596 | data["title"] = title;
597 | }
598 |
599 | return this.AddData(data);
600 | },
601 | w: function w(msg, title) {
602 | var data = this.processObjectData(msg);
603 | data["type"] = "warning";
604 |
605 | if (typeof title !== "undefined") {
606 | data["title"] = title;
607 | }
608 |
609 | return this.AddData(data);
610 | },
611 | i: function i(msg, title) {
612 | var data = this.processObjectData(msg);
613 | data["type"] = "info";
614 |
615 | if (typeof title !== "undefined") {
616 | data["title"] = title;
617 | }
618 |
619 | return this.AddData(data);
620 | },
621 | Close: function Close(data) {
622 | // console.log(data)
623 | this.removeToast(data);
624 | },
625 | removeByType: function removeByType(toastType) {
626 | for (var i = 0; i < this.positions.length; i++) {
627 | var listKeys = Object.keys(this.list[this.positions[i]]);
628 |
629 | for (var j = 0; j < listKeys.length; j++) {
630 | if (this.list[this.positions[i]][listKeys[j]]["type"] === toastType) {
631 | this.Close(this.list[this.positions[i]][listKeys[j]]);
632 | }
633 | }
634 | }
635 | },
636 | clearAll: function clearAll() {
637 | for (var i = 0; i < this.positions.length; i++) {
638 | var listKeys = Object.keys(this.list[this.positions[i]]);
639 |
640 | for (var j = 0; j < listKeys.length; j++) {
641 | this.Close(this.list[this.positions[i]][listKeys[j]]);
642 | }
643 | }
644 | }
645 | }
646 | };
647 |
648 | var isOldIE = typeof navigator !== 'undefined' && /msie [6-9]\\b/.test(navigator.userAgent.toLowerCase());
649 |
650 | function createInjector(context) {
651 | return function (id, style) {
652 | return addStyle(id, style);
653 | };
654 | }
655 |
656 | var HEAD = document.head || document.getElementsByTagName('head')[0];
657 | var styles = {};
658 |
659 | function addStyle(id, css) {
660 | var group = isOldIE ? css.media || 'default' : id;
661 | var style = styles[group] || (styles[group] = {
662 | ids: new Set(),
663 | styles: []
664 | });
665 |
666 | if (!style.ids.has(id)) {
667 | style.ids.add(id);
668 | var code = css.source;
669 |
670 | if (css.map) {
671 | // https://developer.chrome.com/devtools/docs/javascript-debugging
672 | // this makes source maps inside style tags work properly in Chrome
673 | code += '\n/*# sourceURL=' + css.map.sources[0] + ' */'; // http://stackoverflow.com/a/26603875
674 |
675 | code += '\n/*# sourceMappingURL=data:application/json;base64,' + btoa(unescape(encodeURIComponent(JSON.stringify(css.map)))) + ' */';
676 | }
677 |
678 | if (!style.element) {
679 | style.element = document.createElement('style');
680 | style.element.type = 'text/css';
681 | if (css.media) style.element.setAttribute('media', css.media);
682 | HEAD.appendChild(style.element);
683 | }
684 |
685 | if ('styleSheet' in style.element) {
686 | style.styles.push(code);
687 | style.element.styleSheet.cssText = style.styles.filter(Boolean).join('\n');
688 | } else {
689 | var index = style.ids.size - 1;
690 | var textNode = document.createTextNode(code);
691 | var nodes = style.element.childNodes;
692 | if (nodes[index]) style.element.removeChild(nodes[index]);
693 | if (nodes.length) style.element.insertBefore(textNode, nodes[index]);else style.element.appendChild(textNode);
694 | }
695 | }
696 | }
697 |
698 | var browser = createInjector;
699 |
700 | /* script */
701 | const __vue_script__$2 = script$2;
702 |
703 | /* template */
704 | var __vue_render__$2 = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',_vm._l((_vm.list),function(toasts,position){return _c('div',{key:position,class:'toast-container ' + position},_vm._l((toasts),function(toast,index){return _c('toast',{key:index,attrs:{"data":toast}},[_vm._t("default")],2)}),1)}),0)};
705 | var __vue_staticRenderFns__$2 = [];
706 |
707 | /* style */
708 | const __vue_inject_styles__$2 = function (inject) {
709 | if (!inject) return
710 | inject("data-v-04a3f5a4_0", { source: ".toast-title{font-weight:700}.toast-message{-ms-word-wrap:break-word;word-wrap:break-word}.toast-message a,.toast-message label{color:#fff}.toast-message a:hover{color:#ccc;text-decoration:none}.toast-close-button{position:relative;right:-.3em;top:-.3em;float:right;font-size:20px;font-weight:700;color:#fff;-webkit-text-shadow:0 1px 0 #fff;text-shadow:0 1px 0 #fff;opacity:.8}.toast-close-button:focus,.toast-close-button:hover{color:#000;text-decoration:none;cursor:pointer;opacity:.4}button.toast-close-button{padding:0;cursor:pointer;background:0 0;border:0;-webkit-appearance:none}.toast-top-center{top:0;right:0;width:100%}.toast-bottom-center{bottom:0;right:0;width:100%}.toast-top-full-width{top:0;right:0;width:100%}.toast-bottom-full-width{bottom:0;right:0;width:100%}.toast-top-left{top:12px;left:12px}.toast-top-right{top:12px;right:12px}.toast-bottom-right{right:12px;bottom:12px}.toast-bottom-left{bottom:12px;left:12px}.toast-container{position:fixed;z-index:999999;pointer-events:none}.toast-container *{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}.toast-container>div{position:relative;pointer-events:auto;overflow:hidden;margin:0 0 6px;padding:15px 15px 15px 50px;width:300px;-moz-border-radius:3px 3px 3px 3px;-webkit-border-radius:3px 3px 3px 3px;border-radius:3px 3px 3px 3px;background-position:15px center;background-repeat:no-repeat;-moz-box-shadow:0 0 12px #999;-webkit-box-shadow:0 0 12px #999;box-shadow:0 0 12px #999;color:#fff;opacity:.8}.toast-container>:hover{-moz-box-shadow:0 0 12px #000;-webkit-box-shadow:0 0 12px #000;box-shadow:0 0 12px #000;opacity:1;cursor:pointer}.toast-container>.toast-info{background-image:url()!important}.toast-container>.toast-error{background-image:url()!important}.toast-container>.toast-success{background-image:url()!important}.toast-container>.toast-warning{background-image:url()!important}.toast-container.toast-bottom-center>div,.toast-container.toast-top-center>div{width:300px;margin-left:auto;margin-right:auto}.toast-container.toast-bottom-full-width>div,.toast-container.toast-top-full-width>div{width:96%;margin-left:auto;margin-right:auto}.toast{background-color:#030303}.toast-success{background-color:#51a351}.toast-error{background-color:#bd362f}.toast-info{background-color:#2f96b4}.toast-warning{background-color:#f89406}.toast-progress{position:absolute;left:0;bottom:0;height:4px;background-color:#000;opacity:.4}@media all and (max-width:240px){.toast-container>div{padding:8px 8px 8px 50px;width:11em}.toast-container .toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:241px) and (max-width:480px){.toast-container>div{padding:8px 8px 8px 50px;width:18em}.toast-container .toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:481px) and (max-width:768px){.toast-container>div{padding:15px 15px 15px 50px;width:25em}}", map: undefined, media: undefined });
711 |
712 | };
713 | /* scoped */
714 | const __vue_scope_id__$2 = undefined;
715 | /* module identifier */
716 | const __vue_module_identifier__$2 = undefined;
717 | /* functional template */
718 | const __vue_is_functional_template__$2 = false;
719 | /* style inject SSR */
720 |
721 |
722 |
723 | var VueToastr = normalizeComponent_1(
724 | { render: __vue_render__$2, staticRenderFns: __vue_staticRenderFns__$2 },
725 | __vue_inject_styles__$2,
726 | __vue_script__$2,
727 | __vue_scope_id__$2,
728 | __vue_is_functional_template__$2,
729 | __vue_module_identifier__$2,
730 | browser,
731 | undefined
732 | );
733 |
734 | VueToastr.install = function (Vue) {
735 | var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
736 | // console.log("install vuetoastr")
737 | // Create component instance
738 | var MyComponent = Vue.extend({
739 | render: function render(h) {
740 | return h(VueToastr, {
741 | props: {
742 | options: options
743 | },
744 | ref: "vueToastr"
745 | });
746 | }
747 | }); // or, render off-document and append afterwards:
748 |
749 | var component = new MyComponent().$mount(); // console.log(document.body, component.$el)
750 |
751 | document.body.appendChild(component.$el); // 4. add an instance method
752 |
753 | Vue.prototype.$toastr = component.$refs.vueToastr;
754 | }; // Install by default if using the script tag
755 | // equal to Vue.use(window.vueToastr)
756 |
757 |
758 | if (typeof window !== "undefined" && window.Vue) {
759 | // console.log(window.Vue)
760 | window.Vue.use(VueToastr);
761 | }
762 |
763 | /* script */
764 | const __vue_script__$3 = VueToastr;
765 |
766 | /* template */
767 |
768 | /* style */
769 | const __vue_inject_styles__$3 = undefined;
770 | /* scoped */
771 | const __vue_scope_id__$3 = undefined;
772 | /* module identifier */
773 | const __vue_module_identifier__$3 = undefined;
774 | /* functional template */
775 | const __vue_is_functional_template__$3 = undefined;
776 | /* style inject */
777 |
778 | /* style inject SSR */
779 |
780 |
781 |
782 | var VueToastr$1 = normalizeComponent_1(
783 | {},
784 | __vue_inject_styles__$3,
785 | __vue_script__$3,
786 | __vue_scope_id__$3,
787 | __vue_is_functional_template__$3,
788 | __vue_module_identifier__$3,
789 | undefined,
790 | undefined
791 | );
792 |
793 | // export { default } from "./components/VueToastr.vue";
794 |
795 | module.exports = VueToastr$1;
796 |
--------------------------------------------------------------------------------
/dist/vue-toastr.esm.js:
--------------------------------------------------------------------------------
1 | /*!
2 | * vue-toastr v2.1.2
3 | * (c) 2019 s4l1h
4 | * Released under the MIT License.
5 | */
6 | function _typeof(obj) {
7 | if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") {
8 | _typeof = function (obj) {
9 | return typeof obj;
10 | };
11 | } else {
12 | _typeof = function (obj) {
13 | return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
14 | };
15 | }
16 |
17 | return _typeof(obj);
18 | }
19 |
20 | //
21 | //
22 | //
23 | var script = {
24 | props: {
25 | percent: {
26 | type: Number,
27 | default: 100
28 | }
29 | },
30 | computed: {
31 | style: function style() {
32 | return {
33 | width: this.percent.toString() + "%"
34 | };
35 | }
36 | }
37 | };
38 |
39 | function normalizeComponent(template, style, script, scopeId, isFunctionalTemplate, moduleIdentifier
40 | /* server only */
41 | , shadowMode, createInjector, createInjectorSSR, createInjectorShadow) {
42 | if (typeof shadowMode !== 'boolean') {
43 | createInjectorSSR = createInjector;
44 | createInjector = shadowMode;
45 | shadowMode = false;
46 | } // Vue.extend constructor export interop.
47 |
48 |
49 | var options = typeof script === 'function' ? script.options : script; // render functions
50 |
51 | if (template && template.render) {
52 | options.render = template.render;
53 | options.staticRenderFns = template.staticRenderFns;
54 | options._compiled = true; // functional template
55 |
56 | if (isFunctionalTemplate) {
57 | options.functional = true;
58 | }
59 | } // scopedId
60 |
61 |
62 | if (scopeId) {
63 | options._scopeId = scopeId;
64 | }
65 |
66 | var hook;
67 |
68 | if (moduleIdentifier) {
69 | // server build
70 | hook = function hook(context) {
71 | // 2.3 injection
72 | context = context || // cached call
73 | this.$vnode && this.$vnode.ssrContext || // stateful
74 | this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext; // functional
75 | // 2.2 with runInNewContext: true
76 |
77 | if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
78 | context = __VUE_SSR_CONTEXT__;
79 | } // inject component styles
80 |
81 |
82 | if (style) {
83 | style.call(this, createInjectorSSR(context));
84 | } // register component module identifier for async chunk inference
85 |
86 |
87 | if (context && context._registeredComponents) {
88 | context._registeredComponents.add(moduleIdentifier);
89 | }
90 | }; // used by ssr in case component is cached and beforeCreate
91 | // never gets called
92 |
93 |
94 | options._ssrRegister = hook;
95 | } else if (style) {
96 | hook = shadowMode ? function () {
97 | style.call(this, createInjectorShadow(this.$root.$options.shadowRoot));
98 | } : function (context) {
99 | style.call(this, createInjector(context));
100 | };
101 | }
102 |
103 | if (hook) {
104 | if (options.functional) {
105 | // register for functional component in vue file
106 | var originalRender = options.render;
107 |
108 | options.render = function renderWithStyleInjection(h, context) {
109 | hook.call(context);
110 | return originalRender(h, context);
111 | };
112 | } else {
113 | // inject component registration as beforeCreate hook
114 | var existing = options.beforeCreate;
115 | options.beforeCreate = existing ? [].concat(existing, hook) : [hook];
116 | }
117 | }
118 |
119 | return script;
120 | }
121 |
122 | var normalizeComponent_1 = normalizeComponent;
123 |
124 | /* script */
125 | const __vue_script__ = script;
126 |
127 | /* template */
128 | var __vue_render__ = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"toast-progress",style:(_vm.style)})};
129 | var __vue_staticRenderFns__ = [];
130 |
131 | /* style */
132 | const __vue_inject_styles__ = undefined;
133 | /* scoped */
134 | const __vue_scope_id__ = undefined;
135 | /* module identifier */
136 | const __vue_module_identifier__ = undefined;
137 | /* functional template */
138 | const __vue_is_functional_template__ = false;
139 | /* style inject */
140 |
141 | /* style inject SSR */
142 |
143 |
144 |
145 | var ToastProgress = normalizeComponent_1(
146 | { render: __vue_render__, staticRenderFns: __vue_staticRenderFns__ },
147 | __vue_inject_styles__,
148 | __vue_script__,
149 | __vue_scope_id__,
150 | __vue_is_functional_template__,
151 | __vue_module_identifier__,
152 | undefined,
153 | undefined
154 | );
155 |
156 | var IntervalTimeManager = function IntervalTimeManager(params) {
157 | return {
158 | id: false,
159 | times: {},
160 | estimated: null,
161 | remaning: null,
162 | totalTime: params.totalTime || 5000,
163 | stepTime: params.stepTime || 50,
164 | callbackFunctions: params.callbackFunctions || {},
165 | callback: function callback() {
166 | this.times["callback"] = this.getTime();
167 | this.remaning = this.remaning - this.stepTime;
168 | this.estimated = this.estimated + this.stepTime;
169 | this.callCallbackFN("callback");
170 |
171 | if (this.remaning <= 0) {
172 | return this.finish();
173 | }
174 | },
175 | getTime: function getTime() {
176 | return new Date().getTime();
177 | },
178 | getPercent: function getPercent() {
179 | return Math.floor(this.remaning / this.totalTime * 100);
180 | },
181 | start: function start() {
182 | this.times["started"] = this.getTime();
183 | this.callCallbackFN("before:start");
184 | this.remaning = this.totalTime;
185 |
186 | this._setupInterval();
187 |
188 | this.callCallbackFN("after:start");
189 | },
190 | finish: function finish() {
191 | this.times["finished"] = this.getTime();
192 | this.callCallbackFN("before:finish");
193 |
194 | this._clearInterval(this.id);
195 |
196 | this.callCallbackFN("after:finish");
197 | },
198 | stop: function stop() {
199 | this.times["stoped"] = this.getTime(); // People can stop manualy
200 |
201 | this.callCallbackFN("before:stop");
202 |
203 | this._clearInterval(this.id);
204 |
205 | this.callCallbackFN("after:stop");
206 | },
207 | pause: function pause() {
208 | this.times["paused"] = this.getTime();
209 | this.callCallbackFN("before:pause");
210 |
211 | this._clearInterval(this.id);
212 |
213 | this.callCallbackFN("after:pause");
214 | },
215 | resume: function resume() {
216 | this.times["resumed"] = this.getTime();
217 | this.callCallbackFN("before:resume");
218 |
219 | this._setupInterval();
220 |
221 | this.callCallbackFN("after:resume");
222 | },
223 | callCallbackFN: function callCallbackFN(type) {
224 | // console.log(this.callbackFunctions, type);
225 | if (typeof this.callbackFunctions[type] === "function") {
226 | this.callbackFunctions[type]();
227 | }
228 | },
229 | _clearInterval: function _clearInterval() {
230 | clearInterval(this.id);
231 | },
232 | _setupInterval: function _setupInterval() {
233 | var _this = this;
234 |
235 | this.id = setInterval(function () {
236 | _this.callback();
237 | }, this.stepTime);
238 | }
239 | };
240 | };
241 |
242 | //
243 | var script$1 = {
244 | components: {
245 | ToastProgress: ToastProgress
246 | },
247 | props: ["data"],
248 | data: function data() {
249 | return {
250 | progressbar: false,
251 | progressBarTimer: null,
252 | timeoutTimer: null
253 | };
254 | },
255 | mounted: function mounted() {
256 | // console.log("ready", this.data);
257 | if (this.progressBarTimer != null) {
258 | this.progressBarTimer.start();
259 | }
260 |
261 | if (this.timeoutTimer != null) {
262 | this.timeoutTimer.start();
263 | }
264 | },
265 | created: function created() {
266 | var _this = this;
267 |
268 | if (typeof this.data.timeout !== "undefined" && this.data.timeout !== 0) {
269 | // SetUP timeout Manager
270 | this.timeoutTimer = IntervalTimeManager({
271 | totalTime: this.data.timeout,
272 | callbackFunctions: {
273 | "after:finish": function afterFinish() {
274 | _this.close(); // console.log("Timeout Fired");
275 |
276 | }
277 | }
278 | }); // SetUP progressbar Time Manager
279 |
280 | if (this.data.progressbar !== false) {
281 | this.progressbar = true;
282 | this.progressBarTimer = IntervalTimeManager({
283 | totalTime: this.data.timeout
284 | });
285 | }
286 | } else if (this.data.progressBarValue !== null && this.data.progressbar !== false) {
287 | this.progressbar = true;
288 | }
289 | },
290 | computed: {
291 | classNames: function classNames() {
292 | return ["toast", "toast-" + this.data.type].concat(this.data.classNames);
293 | },
294 | progressBarPercent: function progressBarPercent() {
295 | if (this.data.progressBarValue != null) {
296 | return this.data.progressBarValue;
297 | }
298 |
299 | return this.progressBarTimer.getPercent();
300 | }
301 | },
302 | beforeDestroy: function beforeDestroy() {
303 | if (this.progressBarTimer != null) {
304 | this.progressBarTimer.stop();
305 | }
306 |
307 | if (this.timeoutTimer != null) {
308 | this.timeoutTimer.stop();
309 | }
310 | },
311 | methods: {
312 | // Enter Hover
313 | onMouseOver: function onMouseOver() {
314 | // console.log("onMouseOver")
315 | if (typeof this.data.onMouseOver !== "undefined") {
316 | this.data.onMouseOver();
317 | }
318 |
319 | if (this.data.closeOnHover) {
320 | if (this.progressBarTimer != null) {
321 | this.progressBarTimer.pause();
322 | }
323 |
324 | if (this.timeoutTimer != null) {
325 | this.timeoutTimer.pause();
326 | }
327 | }
328 | },
329 | // Leave Hover
330 | onMouseOut: function onMouseOut() {
331 | // console.log("onMouseOut")
332 | if (typeof this.data.onMouseOut !== "undefined") {
333 | this.data.onMouseOut();
334 | }
335 |
336 | if (this.data.closeOnHover) {
337 | if (this.progressBarTimer != null) {
338 | this.progressBarTimer.resume();
339 | }
340 |
341 | if (this.timeoutTimer != null) {
342 | this.timeoutTimer.resume();
343 | }
344 | }
345 | },
346 | // Clicked Toast
347 | clicked: function clicked() {
348 | if (typeof this.data.onClicked !== "undefined") {
349 | this.data.onClicked();
350 | }
351 |
352 | this.clickClose();
353 | },
354 | // Click Close?
355 | clickClose: function clickClose() {
356 | if (typeof this.data.clickClose !== "undefined" && this.data.clickClose === false) {
357 | return;
358 | }
359 |
360 | this.close();
361 | },
362 | // Close Toast
363 | close: function close() {
364 | // console.log(typeof this.$parent, this);
365 | // if toast not manuel closed.
366 | if (this.$parent != null) {
367 | this.$parent.Close(this.data);
368 | }
369 | }
370 | }
371 | };
372 |
373 | /* script */
374 | const __vue_script__$1 = script$1;
375 |
376 | /* template */
377 | var __vue_render__$1 = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{class:_vm.classNames,staticStyle:{"display":"block"},style:(_vm.data.style),on:{"click":function($event){return _vm.clicked()},"mouseover":_vm.onMouseOver,"mouseout":_vm.onMouseOut}},[(_vm.progressbar)?_c('toast-progress',{ref:"progressBar",attrs:{"percent":_vm.progressBarPercent}}):_vm._e(),_vm._v(" "),(_vm.data.title)?_c('div',{staticClass:"toast-title",domProps:{"innerHTML":_vm._s(_vm.data.title)}}):_vm._e(),_vm._v(" "),(_vm.data.msg && !_vm.$slots.default)?_c('div',{staticClass:"toast-message",domProps:{"innerHTML":_vm._s(_vm.data.msg)}}):_vm._e(),_vm._v(" "),(_vm.$slots.default)?_c('div',{staticClass:"toast-message"},[_vm._t("default")],2):_vm._e()],1)};
378 | var __vue_staticRenderFns__$1 = [];
379 |
380 | /* style */
381 | const __vue_inject_styles__$1 = undefined;
382 | /* scoped */
383 | const __vue_scope_id__$1 = undefined;
384 | /* module identifier */
385 | const __vue_module_identifier__$1 = undefined;
386 | /* functional template */
387 | const __vue_is_functional_template__$1 = false;
388 | /* style inject */
389 |
390 | /* style inject SSR */
391 |
392 |
393 |
394 | var toast = normalizeComponent_1(
395 | { render: __vue_render__$1, staticRenderFns: __vue_staticRenderFns__$1 },
396 | __vue_inject_styles__$1,
397 | __vue_script__$1,
398 | __vue_scope_id__$1,
399 | __vue_is_functional_template__$1,
400 | __vue_module_identifier__$1,
401 | undefined,
402 | undefined
403 | );
404 |
405 | var script$2 = {
406 | name: "VueToastr",
407 | props: {
408 | options: {
409 | type: Object,
410 | default: function _default() {
411 | return {};
412 | }
413 | }
414 | },
415 | data: function data() {
416 | var positions = ["toast-top-right", "toast-bottom-right", "toast-bottom-left", "toast-top-left", "toast-top-full-width", "toast-bottom-full-width", "toast-top-center", "toast-bottom-center"];
417 | var list = {};
418 |
419 | for (var i = 0; i <= positions.length - 1; i++) {
420 | list[positions[i]] = {};
421 | }
422 |
423 | return {
424 | positions: positions,
425 | defaultClassNames: this.processOption("defaultClassNames", []),
426 | defaultPosition: this.processOption("defaultPosition", "toast-top-right"),
427 | defaultType: this.processOption("defaultType", "success"),
428 | defaultCloseOnHover: this.processOption("defaultCloseOnHover", true),
429 | defaultTimeout: this.processOption("defaultTimeout", 5000),
430 | defaultProgressBar: this.processOption("defaultProgressBar", true),
431 | defaultProgressBarValue: this.processOption("defaultProgressBarValue", null),
432 | defaultPreventDuplicates: this.processOption("defaultPreventDuplicates", false),
433 | defaultStyle: this.processOption("defaultStyle", {}),
434 | list: list,
435 | index: 0,
436 | savedNames: {}
437 | };
438 | },
439 | created: function created() {// console.log("Created");
440 | },
441 | mounted: function mounted() {// console.log("ready", this.list);
442 | },
443 | components: {
444 | toast: toast
445 | },
446 | methods: {
447 | addToast: function addToast(data) {
448 | this.index++;
449 | data["index"] = this.index;
450 | this.$set(this.list[data.position], this.index, data);
451 |
452 | if (typeof data["name"] !== "undefined") {
453 | this.$set(this.savedNames, data["name"], data);
454 | } // if have onCreated
455 |
456 |
457 | if (typeof data.onCreated !== "undefined") {
458 | // wait doom update after call cb
459 | this.$nextTick(function () {
460 | data.onCreated();
461 | });
462 | }
463 | },
464 | removeByName: function removeByName(name) {
465 | if (typeof this.savedNames[name] !== "undefined") {
466 | this.Close(this.savedNames[name]);
467 | this.$delete(this.savedNames, name);
468 | }
469 | },
470 | removeToast: function removeToast(data) {
471 | var item = this.list[data.position][data.index]; // console.log("remove toast", data, item);
472 |
473 | if (typeof item !== "undefined") {
474 | this.$delete(this.list[data.position], data.index); // if have onClosed
475 |
476 | if (typeof data.onClosed !== "undefined") {
477 | // wait doom update after call cb
478 | this.$nextTick(function () {
479 | data.onClosed();
480 | });
481 | }
482 | }
483 | },
484 | setProgress: function setProgress(data, newValue) {
485 | var item = this.list[data.position][data.index];
486 |
487 | if (typeof item !== "undefined") {
488 | this.$set(item, "progressBarValue", newValue);
489 | }
490 | },
491 | Add: function Add(d) {
492 | return this.AddData(this.processObjectData(d));
493 | },
494 | AddData: function AddData(data) {
495 | if (_typeof(data) !== "object") {
496 | //console.log("AddData accept only Object", data);
497 | return false;
498 | }
499 |
500 | if (data.preventDuplicates) {
501 | var listKeys = Object.keys(this.list[data.position]);
502 |
503 | for (var i = 0; i < listKeys.length; i++) {
504 | if (this.list[data.position][listKeys[i]].title === data.title && this.list[data.position][listKeys[i]].msg === data.msg) {
505 | //console.log("Prevent Duplicates", data);
506 | return false;
507 | }
508 | }
509 | }
510 |
511 | this.addToast(data);
512 | return data;
513 | },
514 | processOption: function processOption(optionValue, defaultValue) {
515 | if (!this.options) {
516 | return defaultValue;
517 | }
518 |
519 | return typeof this.options[optionValue] !== "undefined" ? this.options[optionValue] : defaultValue;
520 | },
521 | processObjectData: function processObjectData(data) {
522 | // if Object
523 | if (_typeof(data) === "object" && typeof data.msg !== "undefined") {
524 | if (typeof data.classNames === "undefined") {
525 | data.classNames = this.defaultClassNames;
526 | }
527 |
528 | if (typeof data.position === "undefined") {
529 | data.position = this.defaultPosition;
530 | }
531 |
532 | if (typeof data.type === "undefined") {
533 | data.type = this.defaultType;
534 | }
535 |
536 | if (typeof data.timeout === "undefined") {
537 | data.timeout = this.defaultTimeout;
538 | } // have progressBar ?
539 |
540 |
541 | if (typeof data.progressbar === "undefined") {
542 | data.progressbar = this.defaultProgressBar;
543 | } // should progressBar be bound to timer or is set manually ?
544 |
545 |
546 | if (typeof data.progressBarValue === "undefined") {
547 | data.progressBarValue = this.defaultProgressBarValue;
548 | }
549 |
550 | if (typeof data.closeOnHover === "undefined") {
551 | data.closeOnHover = this.defaultCloseOnHover;
552 | }
553 |
554 | if (typeof data.preventDuplicates === "undefined") {
555 | data.preventDuplicates = this.defaultPreventDuplicates;
556 | }
557 |
558 | if (typeof data.style === "undefined") {
559 | data.style = this.defaultStyle;
560 | }
561 |
562 | return data;
563 | } // if String
564 |
565 |
566 | return {
567 | msg: data.toString(),
568 | position: this.defaultPosition,
569 | type: this.defaultType,
570 | timeout: this.defaultTimeout,
571 | closeOnHover: this.defaultCloseOnHover,
572 | progressbar: this.defaultProgressBar,
573 | progressBarValue: this.defaultProgressBarValue,
574 | preventDuplicates: this.defaultPreventDuplicates,
575 | style: this.defaultStyle,
576 | classNames: this.defaultClassNames
577 | };
578 | },
579 | e: function e(msg, title) {
580 | var data = this.processObjectData(msg);
581 | data["type"] = "error";
582 |
583 | if (typeof title !== "undefined") {
584 | data["title"] = title;
585 | }
586 |
587 | return this.AddData(data);
588 | },
589 | s: function s(msg, title) {
590 | var data = this.processObjectData(msg);
591 | data["type"] = "success";
592 |
593 | if (typeof title !== "undefined") {
594 | data["title"] = title;
595 | }
596 |
597 | return this.AddData(data);
598 | },
599 | w: function w(msg, title) {
600 | var data = this.processObjectData(msg);
601 | data["type"] = "warning";
602 |
603 | if (typeof title !== "undefined") {
604 | data["title"] = title;
605 | }
606 |
607 | return this.AddData(data);
608 | },
609 | i: function i(msg, title) {
610 | var data = this.processObjectData(msg);
611 | data["type"] = "info";
612 |
613 | if (typeof title !== "undefined") {
614 | data["title"] = title;
615 | }
616 |
617 | return this.AddData(data);
618 | },
619 | Close: function Close(data) {
620 | // console.log(data)
621 | this.removeToast(data);
622 | },
623 | removeByType: function removeByType(toastType) {
624 | for (var i = 0; i < this.positions.length; i++) {
625 | var listKeys = Object.keys(this.list[this.positions[i]]);
626 |
627 | for (var j = 0; j < listKeys.length; j++) {
628 | if (this.list[this.positions[i]][listKeys[j]]["type"] === toastType) {
629 | this.Close(this.list[this.positions[i]][listKeys[j]]);
630 | }
631 | }
632 | }
633 | },
634 | clearAll: function clearAll() {
635 | for (var i = 0; i < this.positions.length; i++) {
636 | var listKeys = Object.keys(this.list[this.positions[i]]);
637 |
638 | for (var j = 0; j < listKeys.length; j++) {
639 | this.Close(this.list[this.positions[i]][listKeys[j]]);
640 | }
641 | }
642 | }
643 | }
644 | };
645 |
646 | var isOldIE = typeof navigator !== 'undefined' && /msie [6-9]\\b/.test(navigator.userAgent.toLowerCase());
647 |
648 | function createInjector(context) {
649 | return function (id, style) {
650 | return addStyle(id, style);
651 | };
652 | }
653 |
654 | var HEAD = document.head || document.getElementsByTagName('head')[0];
655 | var styles = {};
656 |
657 | function addStyle(id, css) {
658 | var group = isOldIE ? css.media || 'default' : id;
659 | var style = styles[group] || (styles[group] = {
660 | ids: new Set(),
661 | styles: []
662 | });
663 |
664 | if (!style.ids.has(id)) {
665 | style.ids.add(id);
666 | var code = css.source;
667 |
668 | if (css.map) {
669 | // https://developer.chrome.com/devtools/docs/javascript-debugging
670 | // this makes source maps inside style tags work properly in Chrome
671 | code += '\n/*# sourceURL=' + css.map.sources[0] + ' */'; // http://stackoverflow.com/a/26603875
672 |
673 | code += '\n/*# sourceMappingURL=data:application/json;base64,' + btoa(unescape(encodeURIComponent(JSON.stringify(css.map)))) + ' */';
674 | }
675 |
676 | if (!style.element) {
677 | style.element = document.createElement('style');
678 | style.element.type = 'text/css';
679 | if (css.media) style.element.setAttribute('media', css.media);
680 | HEAD.appendChild(style.element);
681 | }
682 |
683 | if ('styleSheet' in style.element) {
684 | style.styles.push(code);
685 | style.element.styleSheet.cssText = style.styles.filter(Boolean).join('\n');
686 | } else {
687 | var index = style.ids.size - 1;
688 | var textNode = document.createTextNode(code);
689 | var nodes = style.element.childNodes;
690 | if (nodes[index]) style.element.removeChild(nodes[index]);
691 | if (nodes.length) style.element.insertBefore(textNode, nodes[index]);else style.element.appendChild(textNode);
692 | }
693 | }
694 | }
695 |
696 | var browser = createInjector;
697 |
698 | /* script */
699 | const __vue_script__$2 = script$2;
700 |
701 | /* template */
702 | var __vue_render__$2 = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',_vm._l((_vm.list),function(toasts,position){return _c('div',{key:position,class:'toast-container ' + position},_vm._l((toasts),function(toast,index){return _c('toast',{key:index,attrs:{"data":toast}},[_vm._t("default")],2)}),1)}),0)};
703 | var __vue_staticRenderFns__$2 = [];
704 |
705 | /* style */
706 | const __vue_inject_styles__$2 = function (inject) {
707 | if (!inject) return
708 | inject("data-v-04a3f5a4_0", { source: ".toast-title{font-weight:700}.toast-message{-ms-word-wrap:break-word;word-wrap:break-word}.toast-message a,.toast-message label{color:#fff}.toast-message a:hover{color:#ccc;text-decoration:none}.toast-close-button{position:relative;right:-.3em;top:-.3em;float:right;font-size:20px;font-weight:700;color:#fff;-webkit-text-shadow:0 1px 0 #fff;text-shadow:0 1px 0 #fff;opacity:.8}.toast-close-button:focus,.toast-close-button:hover{color:#000;text-decoration:none;cursor:pointer;opacity:.4}button.toast-close-button{padding:0;cursor:pointer;background:0 0;border:0;-webkit-appearance:none}.toast-top-center{top:0;right:0;width:100%}.toast-bottom-center{bottom:0;right:0;width:100%}.toast-top-full-width{top:0;right:0;width:100%}.toast-bottom-full-width{bottom:0;right:0;width:100%}.toast-top-left{top:12px;left:12px}.toast-top-right{top:12px;right:12px}.toast-bottom-right{right:12px;bottom:12px}.toast-bottom-left{bottom:12px;left:12px}.toast-container{position:fixed;z-index:999999;pointer-events:none}.toast-container *{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}.toast-container>div{position:relative;pointer-events:auto;overflow:hidden;margin:0 0 6px;padding:15px 15px 15px 50px;width:300px;-moz-border-radius:3px 3px 3px 3px;-webkit-border-radius:3px 3px 3px 3px;border-radius:3px 3px 3px 3px;background-position:15px center;background-repeat:no-repeat;-moz-box-shadow:0 0 12px #999;-webkit-box-shadow:0 0 12px #999;box-shadow:0 0 12px #999;color:#fff;opacity:.8}.toast-container>:hover{-moz-box-shadow:0 0 12px #000;-webkit-box-shadow:0 0 12px #000;box-shadow:0 0 12px #000;opacity:1;cursor:pointer}.toast-container>.toast-info{background-image:url()!important}.toast-container>.toast-error{background-image:url()!important}.toast-container>.toast-success{background-image:url()!important}.toast-container>.toast-warning{background-image:url()!important}.toast-container.toast-bottom-center>div,.toast-container.toast-top-center>div{width:300px;margin-left:auto;margin-right:auto}.toast-container.toast-bottom-full-width>div,.toast-container.toast-top-full-width>div{width:96%;margin-left:auto;margin-right:auto}.toast{background-color:#030303}.toast-success{background-color:#51a351}.toast-error{background-color:#bd362f}.toast-info{background-color:#2f96b4}.toast-warning{background-color:#f89406}.toast-progress{position:absolute;left:0;bottom:0;height:4px;background-color:#000;opacity:.4}@media all and (max-width:240px){.toast-container>div{padding:8px 8px 8px 50px;width:11em}.toast-container .toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:241px) and (max-width:480px){.toast-container>div{padding:8px 8px 8px 50px;width:18em}.toast-container .toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:481px) and (max-width:768px){.toast-container>div{padding:15px 15px 15px 50px;width:25em}}", map: undefined, media: undefined });
709 |
710 | };
711 | /* scoped */
712 | const __vue_scope_id__$2 = undefined;
713 | /* module identifier */
714 | const __vue_module_identifier__$2 = undefined;
715 | /* functional template */
716 | const __vue_is_functional_template__$2 = false;
717 | /* style inject SSR */
718 |
719 |
720 |
721 | var VueToastr = normalizeComponent_1(
722 | { render: __vue_render__$2, staticRenderFns: __vue_staticRenderFns__$2 },
723 | __vue_inject_styles__$2,
724 | __vue_script__$2,
725 | __vue_scope_id__$2,
726 | __vue_is_functional_template__$2,
727 | __vue_module_identifier__$2,
728 | browser,
729 | undefined
730 | );
731 |
732 | VueToastr.install = function (Vue) {
733 | var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
734 | // console.log("install vuetoastr")
735 | // Create component instance
736 | var MyComponent = Vue.extend({
737 | render: function render(h) {
738 | return h(VueToastr, {
739 | props: {
740 | options: options
741 | },
742 | ref: "vueToastr"
743 | });
744 | }
745 | }); // or, render off-document and append afterwards:
746 |
747 | var component = new MyComponent().$mount(); // console.log(document.body, component.$el)
748 |
749 | document.body.appendChild(component.$el); // 4. add an instance method
750 |
751 | Vue.prototype.$toastr = component.$refs.vueToastr;
752 | }; // Install by default if using the script tag
753 | // equal to Vue.use(window.vueToastr)
754 |
755 |
756 | if (typeof window !== "undefined" && window.Vue) {
757 | // console.log(window.Vue)
758 | window.Vue.use(VueToastr);
759 | }
760 |
761 | /* script */
762 | const __vue_script__$3 = VueToastr;
763 |
764 | /* template */
765 |
766 | /* style */
767 | const __vue_inject_styles__$3 = undefined;
768 | /* scoped */
769 | const __vue_scope_id__$3 = undefined;
770 | /* module identifier */
771 | const __vue_module_identifier__$3 = undefined;
772 | /* functional template */
773 | const __vue_is_functional_template__$3 = undefined;
774 | /* style inject */
775 |
776 | /* style inject SSR */
777 |
778 |
779 |
780 | var VueToastr$1 = normalizeComponent_1(
781 | {},
782 | __vue_inject_styles__$3,
783 | __vue_script__$3,
784 | __vue_scope_id__$3,
785 | __vue_is_functional_template__$3,
786 | __vue_module_identifier__$3,
787 | undefined,
788 | undefined
789 | );
790 |
791 | // export { default } from "./components/VueToastr.vue";
792 |
793 | export default VueToastr$1;
794 |
--------------------------------------------------------------------------------
/dist/vue-toastr.umd.js:
--------------------------------------------------------------------------------
1 | /*!
2 | * vue-toastr v2.1.2
3 | * (c) 2019 s4l1h
4 | * Released under the MIT License.
5 | */
6 | (function (global, factory) {
7 | typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
8 | typeof define === 'function' && define.amd ? define(factory) :
9 | (global = global || self, global.VueToastr = factory());
10 | }(this, function () { 'use strict';
11 |
12 | function _typeof(obj) {
13 | if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") {
14 | _typeof = function (obj) {
15 | return typeof obj;
16 | };
17 | } else {
18 | _typeof = function (obj) {
19 | return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
20 | };
21 | }
22 |
23 | return _typeof(obj);
24 | }
25 |
26 | //
27 | //
28 | //
29 | var script = {
30 | props: {
31 | percent: {
32 | type: Number,
33 | default: 100
34 | }
35 | },
36 | computed: {
37 | style: function style() {
38 | return {
39 | width: this.percent.toString() + "%"
40 | };
41 | }
42 | }
43 | };
44 |
45 | function normalizeComponent(template, style, script, scopeId, isFunctionalTemplate, moduleIdentifier
46 | /* server only */
47 | , shadowMode, createInjector, createInjectorSSR, createInjectorShadow) {
48 | if (typeof shadowMode !== 'boolean') {
49 | createInjectorSSR = createInjector;
50 | createInjector = shadowMode;
51 | shadowMode = false;
52 | } // Vue.extend constructor export interop.
53 |
54 |
55 | var options = typeof script === 'function' ? script.options : script; // render functions
56 |
57 | if (template && template.render) {
58 | options.render = template.render;
59 | options.staticRenderFns = template.staticRenderFns;
60 | options._compiled = true; // functional template
61 |
62 | if (isFunctionalTemplate) {
63 | options.functional = true;
64 | }
65 | } // scopedId
66 |
67 |
68 | if (scopeId) {
69 | options._scopeId = scopeId;
70 | }
71 |
72 | var hook;
73 |
74 | if (moduleIdentifier) {
75 | // server build
76 | hook = function hook(context) {
77 | // 2.3 injection
78 | context = context || // cached call
79 | this.$vnode && this.$vnode.ssrContext || // stateful
80 | this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext; // functional
81 | // 2.2 with runInNewContext: true
82 |
83 | if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
84 | context = __VUE_SSR_CONTEXT__;
85 | } // inject component styles
86 |
87 |
88 | if (style) {
89 | style.call(this, createInjectorSSR(context));
90 | } // register component module identifier for async chunk inference
91 |
92 |
93 | if (context && context._registeredComponents) {
94 | context._registeredComponents.add(moduleIdentifier);
95 | }
96 | }; // used by ssr in case component is cached and beforeCreate
97 | // never gets called
98 |
99 |
100 | options._ssrRegister = hook;
101 | } else if (style) {
102 | hook = shadowMode ? function () {
103 | style.call(this, createInjectorShadow(this.$root.$options.shadowRoot));
104 | } : function (context) {
105 | style.call(this, createInjector(context));
106 | };
107 | }
108 |
109 | if (hook) {
110 | if (options.functional) {
111 | // register for functional component in vue file
112 | var originalRender = options.render;
113 |
114 | options.render = function renderWithStyleInjection(h, context) {
115 | hook.call(context);
116 | return originalRender(h, context);
117 | };
118 | } else {
119 | // inject component registration as beforeCreate hook
120 | var existing = options.beforeCreate;
121 | options.beforeCreate = existing ? [].concat(existing, hook) : [hook];
122 | }
123 | }
124 |
125 | return script;
126 | }
127 |
128 | var normalizeComponent_1 = normalizeComponent;
129 |
130 | /* script */
131 | const __vue_script__ = script;
132 |
133 | /* template */
134 | var __vue_render__ = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"toast-progress",style:(_vm.style)})};
135 | var __vue_staticRenderFns__ = [];
136 |
137 | /* style */
138 | const __vue_inject_styles__ = undefined;
139 | /* scoped */
140 | const __vue_scope_id__ = undefined;
141 | /* module identifier */
142 | const __vue_module_identifier__ = undefined;
143 | /* functional template */
144 | const __vue_is_functional_template__ = false;
145 | /* style inject */
146 |
147 | /* style inject SSR */
148 |
149 |
150 |
151 | var ToastProgress = normalizeComponent_1(
152 | { render: __vue_render__, staticRenderFns: __vue_staticRenderFns__ },
153 | __vue_inject_styles__,
154 | __vue_script__,
155 | __vue_scope_id__,
156 | __vue_is_functional_template__,
157 | __vue_module_identifier__,
158 | undefined,
159 | undefined
160 | );
161 |
162 | var IntervalTimeManager = function IntervalTimeManager(params) {
163 | return {
164 | id: false,
165 | times: {},
166 | estimated: null,
167 | remaning: null,
168 | totalTime: params.totalTime || 5000,
169 | stepTime: params.stepTime || 50,
170 | callbackFunctions: params.callbackFunctions || {},
171 | callback: function callback() {
172 | this.times["callback"] = this.getTime();
173 | this.remaning = this.remaning - this.stepTime;
174 | this.estimated = this.estimated + this.stepTime;
175 | this.callCallbackFN("callback");
176 |
177 | if (this.remaning <= 0) {
178 | return this.finish();
179 | }
180 | },
181 | getTime: function getTime() {
182 | return new Date().getTime();
183 | },
184 | getPercent: function getPercent() {
185 | return Math.floor(this.remaning / this.totalTime * 100);
186 | },
187 | start: function start() {
188 | this.times["started"] = this.getTime();
189 | this.callCallbackFN("before:start");
190 | this.remaning = this.totalTime;
191 |
192 | this._setupInterval();
193 |
194 | this.callCallbackFN("after:start");
195 | },
196 | finish: function finish() {
197 | this.times["finished"] = this.getTime();
198 | this.callCallbackFN("before:finish");
199 |
200 | this._clearInterval(this.id);
201 |
202 | this.callCallbackFN("after:finish");
203 | },
204 | stop: function stop() {
205 | this.times["stoped"] = this.getTime(); // People can stop manualy
206 |
207 | this.callCallbackFN("before:stop");
208 |
209 | this._clearInterval(this.id);
210 |
211 | this.callCallbackFN("after:stop");
212 | },
213 | pause: function pause() {
214 | this.times["paused"] = this.getTime();
215 | this.callCallbackFN("before:pause");
216 |
217 | this._clearInterval(this.id);
218 |
219 | this.callCallbackFN("after:pause");
220 | },
221 | resume: function resume() {
222 | this.times["resumed"] = this.getTime();
223 | this.callCallbackFN("before:resume");
224 |
225 | this._setupInterval();
226 |
227 | this.callCallbackFN("after:resume");
228 | },
229 | callCallbackFN: function callCallbackFN(type) {
230 | // console.log(this.callbackFunctions, type);
231 | if (typeof this.callbackFunctions[type] === "function") {
232 | this.callbackFunctions[type]();
233 | }
234 | },
235 | _clearInterval: function _clearInterval() {
236 | clearInterval(this.id);
237 | },
238 | _setupInterval: function _setupInterval() {
239 | var _this = this;
240 |
241 | this.id = setInterval(function () {
242 | _this.callback();
243 | }, this.stepTime);
244 | }
245 | };
246 | };
247 |
248 | //
249 | var script$1 = {
250 | components: {
251 | ToastProgress: ToastProgress
252 | },
253 | props: ["data"],
254 | data: function data() {
255 | return {
256 | progressbar: false,
257 | progressBarTimer: null,
258 | timeoutTimer: null
259 | };
260 | },
261 | mounted: function mounted() {
262 | // console.log("ready", this.data);
263 | if (this.progressBarTimer != null) {
264 | this.progressBarTimer.start();
265 | }
266 |
267 | if (this.timeoutTimer != null) {
268 | this.timeoutTimer.start();
269 | }
270 | },
271 | created: function created() {
272 | var _this = this;
273 |
274 | if (typeof this.data.timeout !== "undefined" && this.data.timeout !== 0) {
275 | // SetUP timeout Manager
276 | this.timeoutTimer = IntervalTimeManager({
277 | totalTime: this.data.timeout,
278 | callbackFunctions: {
279 | "after:finish": function afterFinish() {
280 | _this.close(); // console.log("Timeout Fired");
281 |
282 | }
283 | }
284 | }); // SetUP progressbar Time Manager
285 |
286 | if (this.data.progressbar !== false) {
287 | this.progressbar = true;
288 | this.progressBarTimer = IntervalTimeManager({
289 | totalTime: this.data.timeout
290 | });
291 | }
292 | } else if (this.data.progressBarValue !== null && this.data.progressbar !== false) {
293 | this.progressbar = true;
294 | }
295 | },
296 | computed: {
297 | classNames: function classNames() {
298 | return ["toast", "toast-" + this.data.type].concat(this.data.classNames);
299 | },
300 | progressBarPercent: function progressBarPercent() {
301 | if (this.data.progressBarValue != null) {
302 | return this.data.progressBarValue;
303 | }
304 |
305 | return this.progressBarTimer.getPercent();
306 | }
307 | },
308 | beforeDestroy: function beforeDestroy() {
309 | if (this.progressBarTimer != null) {
310 | this.progressBarTimer.stop();
311 | }
312 |
313 | if (this.timeoutTimer != null) {
314 | this.timeoutTimer.stop();
315 | }
316 | },
317 | methods: {
318 | // Enter Hover
319 | onMouseOver: function onMouseOver() {
320 | // console.log("onMouseOver")
321 | if (typeof this.data.onMouseOver !== "undefined") {
322 | this.data.onMouseOver();
323 | }
324 |
325 | if (this.data.closeOnHover) {
326 | if (this.progressBarTimer != null) {
327 | this.progressBarTimer.pause();
328 | }
329 |
330 | if (this.timeoutTimer != null) {
331 | this.timeoutTimer.pause();
332 | }
333 | }
334 | },
335 | // Leave Hover
336 | onMouseOut: function onMouseOut() {
337 | // console.log("onMouseOut")
338 | if (typeof this.data.onMouseOut !== "undefined") {
339 | this.data.onMouseOut();
340 | }
341 |
342 | if (this.data.closeOnHover) {
343 | if (this.progressBarTimer != null) {
344 | this.progressBarTimer.resume();
345 | }
346 |
347 | if (this.timeoutTimer != null) {
348 | this.timeoutTimer.resume();
349 | }
350 | }
351 | },
352 | // Clicked Toast
353 | clicked: function clicked() {
354 | if (typeof this.data.onClicked !== "undefined") {
355 | this.data.onClicked();
356 | }
357 |
358 | this.clickClose();
359 | },
360 | // Click Close?
361 | clickClose: function clickClose() {
362 | if (typeof this.data.clickClose !== "undefined" && this.data.clickClose === false) {
363 | return;
364 | }
365 |
366 | this.close();
367 | },
368 | // Close Toast
369 | close: function close() {
370 | // console.log(typeof this.$parent, this);
371 | // if toast not manuel closed.
372 | if (this.$parent != null) {
373 | this.$parent.Close(this.data);
374 | }
375 | }
376 | }
377 | };
378 |
379 | /* script */
380 | const __vue_script__$1 = script$1;
381 |
382 | /* template */
383 | var __vue_render__$1 = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{class:_vm.classNames,staticStyle:{"display":"block"},style:(_vm.data.style),on:{"click":function($event){return _vm.clicked()},"mouseover":_vm.onMouseOver,"mouseout":_vm.onMouseOut}},[(_vm.progressbar)?_c('toast-progress',{ref:"progressBar",attrs:{"percent":_vm.progressBarPercent}}):_vm._e(),_vm._v(" "),(_vm.data.title)?_c('div',{staticClass:"toast-title",domProps:{"innerHTML":_vm._s(_vm.data.title)}}):_vm._e(),_vm._v(" "),(_vm.data.msg && !_vm.$slots.default)?_c('div',{staticClass:"toast-message",domProps:{"innerHTML":_vm._s(_vm.data.msg)}}):_vm._e(),_vm._v(" "),(_vm.$slots.default)?_c('div',{staticClass:"toast-message"},[_vm._t("default")],2):_vm._e()],1)};
384 | var __vue_staticRenderFns__$1 = [];
385 |
386 | /* style */
387 | const __vue_inject_styles__$1 = undefined;
388 | /* scoped */
389 | const __vue_scope_id__$1 = undefined;
390 | /* module identifier */
391 | const __vue_module_identifier__$1 = undefined;
392 | /* functional template */
393 | const __vue_is_functional_template__$1 = false;
394 | /* style inject */
395 |
396 | /* style inject SSR */
397 |
398 |
399 |
400 | var toast = normalizeComponent_1(
401 | { render: __vue_render__$1, staticRenderFns: __vue_staticRenderFns__$1 },
402 | __vue_inject_styles__$1,
403 | __vue_script__$1,
404 | __vue_scope_id__$1,
405 | __vue_is_functional_template__$1,
406 | __vue_module_identifier__$1,
407 | undefined,
408 | undefined
409 | );
410 |
411 | var script$2 = {
412 | name: "VueToastr",
413 | props: {
414 | options: {
415 | type: Object,
416 | default: function _default() {
417 | return {};
418 | }
419 | }
420 | },
421 | data: function data() {
422 | var positions = ["toast-top-right", "toast-bottom-right", "toast-bottom-left", "toast-top-left", "toast-top-full-width", "toast-bottom-full-width", "toast-top-center", "toast-bottom-center"];
423 | var list = {};
424 |
425 | for (var i = 0; i <= positions.length - 1; i++) {
426 | list[positions[i]] = {};
427 | }
428 |
429 | return {
430 | positions: positions,
431 | defaultClassNames: this.processOption("defaultClassNames", []),
432 | defaultPosition: this.processOption("defaultPosition", "toast-top-right"),
433 | defaultType: this.processOption("defaultType", "success"),
434 | defaultCloseOnHover: this.processOption("defaultCloseOnHover", true),
435 | defaultTimeout: this.processOption("defaultTimeout", 5000),
436 | defaultProgressBar: this.processOption("defaultProgressBar", true),
437 | defaultProgressBarValue: this.processOption("defaultProgressBarValue", null),
438 | defaultPreventDuplicates: this.processOption("defaultPreventDuplicates", false),
439 | defaultStyle: this.processOption("defaultStyle", {}),
440 | list: list,
441 | index: 0,
442 | savedNames: {}
443 | };
444 | },
445 | created: function created() {// console.log("Created");
446 | },
447 | mounted: function mounted() {// console.log("ready", this.list);
448 | },
449 | components: {
450 | toast: toast
451 | },
452 | methods: {
453 | addToast: function addToast(data) {
454 | this.index++;
455 | data["index"] = this.index;
456 | this.$set(this.list[data.position], this.index, data);
457 |
458 | if (typeof data["name"] !== "undefined") {
459 | this.$set(this.savedNames, data["name"], data);
460 | } // if have onCreated
461 |
462 |
463 | if (typeof data.onCreated !== "undefined") {
464 | // wait doom update after call cb
465 | this.$nextTick(function () {
466 | data.onCreated();
467 | });
468 | }
469 | },
470 | removeByName: function removeByName(name) {
471 | if (typeof this.savedNames[name] !== "undefined") {
472 | this.Close(this.savedNames[name]);
473 | this.$delete(this.savedNames, name);
474 | }
475 | },
476 | removeToast: function removeToast(data) {
477 | var item = this.list[data.position][data.index]; // console.log("remove toast", data, item);
478 |
479 | if (typeof item !== "undefined") {
480 | this.$delete(this.list[data.position], data.index); // if have onClosed
481 |
482 | if (typeof data.onClosed !== "undefined") {
483 | // wait doom update after call cb
484 | this.$nextTick(function () {
485 | data.onClosed();
486 | });
487 | }
488 | }
489 | },
490 | setProgress: function setProgress(data, newValue) {
491 | var item = this.list[data.position][data.index];
492 |
493 | if (typeof item !== "undefined") {
494 | this.$set(item, "progressBarValue", newValue);
495 | }
496 | },
497 | Add: function Add(d) {
498 | return this.AddData(this.processObjectData(d));
499 | },
500 | AddData: function AddData(data) {
501 | if (_typeof(data) !== "object") {
502 | //console.log("AddData accept only Object", data);
503 | return false;
504 | }
505 |
506 | if (data.preventDuplicates) {
507 | var listKeys = Object.keys(this.list[data.position]);
508 |
509 | for (var i = 0; i < listKeys.length; i++) {
510 | if (this.list[data.position][listKeys[i]].title === data.title && this.list[data.position][listKeys[i]].msg === data.msg) {
511 | //console.log("Prevent Duplicates", data);
512 | return false;
513 | }
514 | }
515 | }
516 |
517 | this.addToast(data);
518 | return data;
519 | },
520 | processOption: function processOption(optionValue, defaultValue) {
521 | if (!this.options) {
522 | return defaultValue;
523 | }
524 |
525 | return typeof this.options[optionValue] !== "undefined" ? this.options[optionValue] : defaultValue;
526 | },
527 | processObjectData: function processObjectData(data) {
528 | // if Object
529 | if (_typeof(data) === "object" && typeof data.msg !== "undefined") {
530 | if (typeof data.classNames === "undefined") {
531 | data.classNames = this.defaultClassNames;
532 | }
533 |
534 | if (typeof data.position === "undefined") {
535 | data.position = this.defaultPosition;
536 | }
537 |
538 | if (typeof data.type === "undefined") {
539 | data.type = this.defaultType;
540 | }
541 |
542 | if (typeof data.timeout === "undefined") {
543 | data.timeout = this.defaultTimeout;
544 | } // have progressBar ?
545 |
546 |
547 | if (typeof data.progressbar === "undefined") {
548 | data.progressbar = this.defaultProgressBar;
549 | } // should progressBar be bound to timer or is set manually ?
550 |
551 |
552 | if (typeof data.progressBarValue === "undefined") {
553 | data.progressBarValue = this.defaultProgressBarValue;
554 | }
555 |
556 | if (typeof data.closeOnHover === "undefined") {
557 | data.closeOnHover = this.defaultCloseOnHover;
558 | }
559 |
560 | if (typeof data.preventDuplicates === "undefined") {
561 | data.preventDuplicates = this.defaultPreventDuplicates;
562 | }
563 |
564 | if (typeof data.style === "undefined") {
565 | data.style = this.defaultStyle;
566 | }
567 |
568 | return data;
569 | } // if String
570 |
571 |
572 | return {
573 | msg: data.toString(),
574 | position: this.defaultPosition,
575 | type: this.defaultType,
576 | timeout: this.defaultTimeout,
577 | closeOnHover: this.defaultCloseOnHover,
578 | progressbar: this.defaultProgressBar,
579 | progressBarValue: this.defaultProgressBarValue,
580 | preventDuplicates: this.defaultPreventDuplicates,
581 | style: this.defaultStyle,
582 | classNames: this.defaultClassNames
583 | };
584 | },
585 | e: function e(msg, title) {
586 | var data = this.processObjectData(msg);
587 | data["type"] = "error";
588 |
589 | if (typeof title !== "undefined") {
590 | data["title"] = title;
591 | }
592 |
593 | return this.AddData(data);
594 | },
595 | s: function s(msg, title) {
596 | var data = this.processObjectData(msg);
597 | data["type"] = "success";
598 |
599 | if (typeof title !== "undefined") {
600 | data["title"] = title;
601 | }
602 |
603 | return this.AddData(data);
604 | },
605 | w: function w(msg, title) {
606 | var data = this.processObjectData(msg);
607 | data["type"] = "warning";
608 |
609 | if (typeof title !== "undefined") {
610 | data["title"] = title;
611 | }
612 |
613 | return this.AddData(data);
614 | },
615 | i: function i(msg, title) {
616 | var data = this.processObjectData(msg);
617 | data["type"] = "info";
618 |
619 | if (typeof title !== "undefined") {
620 | data["title"] = title;
621 | }
622 |
623 | return this.AddData(data);
624 | },
625 | Close: function Close(data) {
626 | // console.log(data)
627 | this.removeToast(data);
628 | },
629 | removeByType: function removeByType(toastType) {
630 | for (var i = 0; i < this.positions.length; i++) {
631 | var listKeys = Object.keys(this.list[this.positions[i]]);
632 |
633 | for (var j = 0; j < listKeys.length; j++) {
634 | if (this.list[this.positions[i]][listKeys[j]]["type"] === toastType) {
635 | this.Close(this.list[this.positions[i]][listKeys[j]]);
636 | }
637 | }
638 | }
639 | },
640 | clearAll: function clearAll() {
641 | for (var i = 0; i < this.positions.length; i++) {
642 | var listKeys = Object.keys(this.list[this.positions[i]]);
643 |
644 | for (var j = 0; j < listKeys.length; j++) {
645 | this.Close(this.list[this.positions[i]][listKeys[j]]);
646 | }
647 | }
648 | }
649 | }
650 | };
651 |
652 | var isOldIE = typeof navigator !== 'undefined' && /msie [6-9]\\b/.test(navigator.userAgent.toLowerCase());
653 |
654 | function createInjector(context) {
655 | return function (id, style) {
656 | return addStyle(id, style);
657 | };
658 | }
659 |
660 | var HEAD = document.head || document.getElementsByTagName('head')[0];
661 | var styles = {};
662 |
663 | function addStyle(id, css) {
664 | var group = isOldIE ? css.media || 'default' : id;
665 | var style = styles[group] || (styles[group] = {
666 | ids: new Set(),
667 | styles: []
668 | });
669 |
670 | if (!style.ids.has(id)) {
671 | style.ids.add(id);
672 | var code = css.source;
673 |
674 | if (css.map) {
675 | // https://developer.chrome.com/devtools/docs/javascript-debugging
676 | // this makes source maps inside style tags work properly in Chrome
677 | code += '\n/*# sourceURL=' + css.map.sources[0] + ' */'; // http://stackoverflow.com/a/26603875
678 |
679 | code += '\n/*# sourceMappingURL=data:application/json;base64,' + btoa(unescape(encodeURIComponent(JSON.stringify(css.map)))) + ' */';
680 | }
681 |
682 | if (!style.element) {
683 | style.element = document.createElement('style');
684 | style.element.type = 'text/css';
685 | if (css.media) style.element.setAttribute('media', css.media);
686 | HEAD.appendChild(style.element);
687 | }
688 |
689 | if ('styleSheet' in style.element) {
690 | style.styles.push(code);
691 | style.element.styleSheet.cssText = style.styles.filter(Boolean).join('\n');
692 | } else {
693 | var index = style.ids.size - 1;
694 | var textNode = document.createTextNode(code);
695 | var nodes = style.element.childNodes;
696 | if (nodes[index]) style.element.removeChild(nodes[index]);
697 | if (nodes.length) style.element.insertBefore(textNode, nodes[index]);else style.element.appendChild(textNode);
698 | }
699 | }
700 | }
701 |
702 | var browser = createInjector;
703 |
704 | /* script */
705 | const __vue_script__$2 = script$2;
706 |
707 | /* template */
708 | var __vue_render__$2 = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',_vm._l((_vm.list),function(toasts,position){return _c('div',{key:position,class:'toast-container ' + position},_vm._l((toasts),function(toast,index){return _c('toast',{key:index,attrs:{"data":toast}},[_vm._t("default")],2)}),1)}),0)};
709 | var __vue_staticRenderFns__$2 = [];
710 |
711 | /* style */
712 | const __vue_inject_styles__$2 = function (inject) {
713 | if (!inject) return
714 | inject("data-v-04a3f5a4_0", { source: ".toast-title{font-weight:700}.toast-message{-ms-word-wrap:break-word;word-wrap:break-word}.toast-message a,.toast-message label{color:#fff}.toast-message a:hover{color:#ccc;text-decoration:none}.toast-close-button{position:relative;right:-.3em;top:-.3em;float:right;font-size:20px;font-weight:700;color:#fff;-webkit-text-shadow:0 1px 0 #fff;text-shadow:0 1px 0 #fff;opacity:.8}.toast-close-button:focus,.toast-close-button:hover{color:#000;text-decoration:none;cursor:pointer;opacity:.4}button.toast-close-button{padding:0;cursor:pointer;background:0 0;border:0;-webkit-appearance:none}.toast-top-center{top:0;right:0;width:100%}.toast-bottom-center{bottom:0;right:0;width:100%}.toast-top-full-width{top:0;right:0;width:100%}.toast-bottom-full-width{bottom:0;right:0;width:100%}.toast-top-left{top:12px;left:12px}.toast-top-right{top:12px;right:12px}.toast-bottom-right{right:12px;bottom:12px}.toast-bottom-left{bottom:12px;left:12px}.toast-container{position:fixed;z-index:999999;pointer-events:none}.toast-container *{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}.toast-container>div{position:relative;pointer-events:auto;overflow:hidden;margin:0 0 6px;padding:15px 15px 15px 50px;width:300px;-moz-border-radius:3px 3px 3px 3px;-webkit-border-radius:3px 3px 3px 3px;border-radius:3px 3px 3px 3px;background-position:15px center;background-repeat:no-repeat;-moz-box-shadow:0 0 12px #999;-webkit-box-shadow:0 0 12px #999;box-shadow:0 0 12px #999;color:#fff;opacity:.8}.toast-container>:hover{-moz-box-shadow:0 0 12px #000;-webkit-box-shadow:0 0 12px #000;box-shadow:0 0 12px #000;opacity:1;cursor:pointer}.toast-container>.toast-info{background-image:url()!important}.toast-container>.toast-error{background-image:url()!important}.toast-container>.toast-success{background-image:url()!important}.toast-container>.toast-warning{background-image:url()!important}.toast-container.toast-bottom-center>div,.toast-container.toast-top-center>div{width:300px;margin-left:auto;margin-right:auto}.toast-container.toast-bottom-full-width>div,.toast-container.toast-top-full-width>div{width:96%;margin-left:auto;margin-right:auto}.toast{background-color:#030303}.toast-success{background-color:#51a351}.toast-error{background-color:#bd362f}.toast-info{background-color:#2f96b4}.toast-warning{background-color:#f89406}.toast-progress{position:absolute;left:0;bottom:0;height:4px;background-color:#000;opacity:.4}@media all and (max-width:240px){.toast-container>div{padding:8px 8px 8px 50px;width:11em}.toast-container .toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:241px) and (max-width:480px){.toast-container>div{padding:8px 8px 8px 50px;width:18em}.toast-container .toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:481px) and (max-width:768px){.toast-container>div{padding:15px 15px 15px 50px;width:25em}}", map: undefined, media: undefined });
715 |
716 | };
717 | /* scoped */
718 | const __vue_scope_id__$2 = undefined;
719 | /* module identifier */
720 | const __vue_module_identifier__$2 = undefined;
721 | /* functional template */
722 | const __vue_is_functional_template__$2 = false;
723 | /* style inject SSR */
724 |
725 |
726 |
727 | var VueToastr = normalizeComponent_1(
728 | { render: __vue_render__$2, staticRenderFns: __vue_staticRenderFns__$2 },
729 | __vue_inject_styles__$2,
730 | __vue_script__$2,
731 | __vue_scope_id__$2,
732 | __vue_is_functional_template__$2,
733 | __vue_module_identifier__$2,
734 | browser,
735 | undefined
736 | );
737 |
738 | VueToastr.install = function (Vue) {
739 | var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
740 | // console.log("install vuetoastr")
741 | // Create component instance
742 | var MyComponent = Vue.extend({
743 | render: function render(h) {
744 | return h(VueToastr, {
745 | props: {
746 | options: options
747 | },
748 | ref: "vueToastr"
749 | });
750 | }
751 | }); // or, render off-document and append afterwards:
752 |
753 | var component = new MyComponent().$mount(); // console.log(document.body, component.$el)
754 |
755 | document.body.appendChild(component.$el); // 4. add an instance method
756 |
757 | Vue.prototype.$toastr = component.$refs.vueToastr;
758 | }; // Install by default if using the script tag
759 | // equal to Vue.use(window.vueToastr)
760 |
761 |
762 | if (typeof window !== "undefined" && window.Vue) {
763 | // console.log(window.Vue)
764 | window.Vue.use(VueToastr);
765 | }
766 |
767 | /* script */
768 | const __vue_script__$3 = VueToastr;
769 |
770 | /* template */
771 |
772 | /* style */
773 | const __vue_inject_styles__$3 = undefined;
774 | /* scoped */
775 | const __vue_scope_id__$3 = undefined;
776 | /* module identifier */
777 | const __vue_module_identifier__$3 = undefined;
778 | /* functional template */
779 | const __vue_is_functional_template__$3 = undefined;
780 | /* style inject */
781 |
782 | /* style inject SSR */
783 |
784 |
785 |
786 | var VueToastr$1 = normalizeComponent_1(
787 | {},
788 | __vue_inject_styles__$3,
789 | __vue_script__$3,
790 | __vue_scope_id__$3,
791 | __vue_is_functional_template__$3,
792 | __vue_module_identifier__$3,
793 | undefined,
794 | undefined
795 | );
796 |
797 | // export { default } from "./components/VueToastr.vue";
798 |
799 | return VueToastr$1;
800 |
801 | }));
802 |
--------------------------------------------------------------------------------
/dist/vue-toastr.umd.min.js:
--------------------------------------------------------------------------------
1 | /*!
2 | * vue-toastr v2.1.2
3 | * (c) 2019 s4l1h
4 | * Released under the MIT License.
5 | */
6 | !function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(t=t||self,t.VueToastr=e())}(this,function(){"use strict";function t(e){return(t="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(e)}function e(t,e,s,o,i,a,r,n,l,d){"boolean"!=typeof r&&(l=n,n=r,r=!1);var c="function"==typeof s?s.options:s;t&&t.render&&(c.render=t.render,c.staticRenderFns=t.staticRenderFns,c._compiled=!0,i&&(c.functional=!0)),o&&(c._scopeId=o);var u;if(a?(u=function(t){t=t||this.$vnode&&this.$vnode.ssrContext||this.parent&&this.parent.$vnode&&this.parent.$vnode.ssrContext,t||"undefined"==typeof __VUE_SSR_CONTEXT__||(t=__VUE_SSR_CONTEXT__),e&&e.call(this,l(t)),t&&t._registeredComponents&&t._registeredComponents.add(a)},c._ssrRegister=u):e&&(u=r?function(){e.call(this,d(this.$root.$options.shadowRoot))}:function(t){e.call(this,n(t))}),u)if(c.functional){var p=c.render;c.render=function(t,e){return u.call(e),p(t,e)}}else{var h=c.beforeCreate;c.beforeCreate=h?[].concat(h,u):[u]}return s}function s(t){return function(t,e){return o(t,e)}}function o(t,e){var s=g?e.media||"default":t,o=b[s]||(b[s]={ids:new Set,styles:[]});if(!o.ids.has(t)){o.ids.add(t);var i=e.source;if(e.map&&(i+="\n/*# sourceURL="+e.map.sources[0]+" */",i+="\n/*# sourceMappingURL=data:application/json;base64,"+btoa(unescape(encodeURIComponent(JSON.stringify(e.map))))+" */"),o.element||(o.element=document.createElement("style"),o.element.type="text/css",e.media&&o.element.setAttribute("media",e.media),v.appendChild(o.element)),"styleSheet"in o.element)o.styles.push(i),o.element.styleSheet.cssText=o.styles.filter(Boolean).join("\n");else{var a=o.ids.size-1,r=document.createTextNode(i),n=o.element.childNodes;n[a]&&o.element.removeChild(n[a]),n.length?o.element.insertBefore(r,n[a]):o.element.appendChild(r)}}}var i={props:{percent:{type:Number,default:100}},computed:{style:function(){return{width:this.percent.toString()+"%"}}}},a=e;const r=i;var n=function(){var t=this,e=t.$createElement;return(t._self._c||e)("div",{staticClass:"toast-progress",style:t.style})},l=[];var d=a({render:n,staticRenderFns:l},void 0,r,void 0,!1,void 0,void 0,void 0),c=function(t){return{id:!1,times:{},estimated:null,remaning:null,totalTime:t.totalTime||5e3,stepTime:t.stepTime||50,callbackFunctions:t.callbackFunctions||{},callback:function(){if(this.times.callback=this.getTime(),this.remaning=this.remaning-this.stepTime,this.estimated=this.estimated+this.stepTime,this.callCallbackFN("callback"),this.remaning<=0)return this.finish()},getTime:function(){return(new Date).getTime()},getPercent:function(){return Math.floor(this.remaning/this.totalTime*100)},start:function(){this.times.started=this.getTime(),this.callCallbackFN("before:start"),this.remaning=this.totalTime,this._setupInterval(),this.callCallbackFN("after:start")},finish:function(){this.times.finished=this.getTime(),this.callCallbackFN("before:finish"),this._clearInterval(this.id),this.callCallbackFN("after:finish")},stop:function(){this.times.stoped=this.getTime(),this.callCallbackFN("before:stop"),this._clearInterval(this.id),this.callCallbackFN("after:stop")},pause:function(){this.times.paused=this.getTime(),this.callCallbackFN("before:pause"),this._clearInterval(this.id),this.callCallbackFN("after:pause")},resume:function(){this.times.resumed=this.getTime(),this.callCallbackFN("before:resume"),this._setupInterval(),this.callCallbackFN("after:resume")},callCallbackFN:function(t){"function"==typeof this.callbackFunctions[t]&&this.callbackFunctions[t]()},_clearInterval:function(){clearInterval(this.id)},_setupInterval:function(){var t=this;this.id=setInterval(function(){t.callback()},this.stepTime)}}},u={components:{ToastProgress:d},props:["data"],data:function(){return{progressbar:!1,progressBarTimer:null,timeoutTimer:null}},mounted:function(){null!=this.progressBarTimer&&this.progressBarTimer.start(),null!=this.timeoutTimer&&this.timeoutTimer.start()},created:function(){var t=this;void 0!==this.data.timeout&&0!==this.data.timeout?(this.timeoutTimer=c({totalTime:this.data.timeout,callbackFunctions:{"after:finish":function(){t.close()}}}),!1!==this.data.progressbar&&(this.progressbar=!0,this.progressBarTimer=c({totalTime:this.data.timeout}))):null!==this.data.progressBarValue&&!1!==this.data.progressbar&&(this.progressbar=!0)},computed:{classNames:function(){return["toast","toast-"+this.data.type].concat(this.data.classNames)},progressBarPercent:function(){return null!=this.data.progressBarValue?this.data.progressBarValue:this.progressBarTimer.getPercent()}},beforeDestroy:function(){null!=this.progressBarTimer&&this.progressBarTimer.stop(),null!=this.timeoutTimer&&this.timeoutTimer.stop()},methods:{onMouseOver:function(){void 0!==this.data.onMouseOver&&this.data.onMouseOver(),this.data.closeOnHover&&(null!=this.progressBarTimer&&this.progressBarTimer.pause(),null!=this.timeoutTimer&&this.timeoutTimer.pause())},onMouseOut:function(){void 0!==this.data.onMouseOut&&this.data.onMouseOut(),this.data.closeOnHover&&(null!=this.progressBarTimer&&this.progressBarTimer.resume(),null!=this.timeoutTimer&&this.timeoutTimer.resume())},clicked:function(){void 0!==this.data.onClicked&&this.data.onClicked(),this.clickClose()},clickClose:function(){void 0!==this.data.clickClose&&!1===this.data.clickClose||this.close()},close:function(){null!=this.$parent&&this.$parent.Close(this.data)}}};const p=u;var h=function(){var t=this,e=t.$createElement,s=t._self._c||e;return s("div",{class:t.classNames,staticStyle:{display:"block"},style:t.data.style,on:{click:function(e){return t.clicked()},mouseover:t.onMouseOver,mouseout:t.onMouseOut}},[t.progressbar?s("toast-progress",{ref:"progressBar",attrs:{percent:t.progressBarPercent}}):t._e(),t._v(" "),t.data.title?s("div",{staticClass:"toast-title",domProps:{innerHTML:t._s(t.data.title)}}):t._e(),t._v(" "),t.data.msg&&!t.$slots.default?s("div",{staticClass:"toast-message",domProps:{innerHTML:t._s(t.data.msg)}}):t._e(),t._v(" "),t.$slots.default?s("div",{staticClass:"toast-message"},[t._t("default")],2):t._e()],1)},m=[];var A=a({render:h,staticRenderFns:m},void 0,p,void 0,!1,void 0,void 0,void 0),f={name:"VueToastr",props:{options:{type:Object,default:function(){return{}}}},data:function(){for(var t=["toast-top-right","toast-bottom-right","toast-bottom-left","toast-top-left","toast-top-full-width","toast-bottom-full-width","toast-top-center","toast-bottom-center"],e={},s=0;s<=t.length-1;s++)e[t[s]]={};return{positions:t,defaultClassNames:this.processOption("defaultClassNames",[]),defaultPosition:this.processOption("defaultPosition","toast-top-right"),defaultType:this.processOption("defaultType","success"),defaultCloseOnHover:this.processOption("defaultCloseOnHover",!0),defaultTimeout:this.processOption("defaultTimeout",5e3),defaultProgressBar:this.processOption("defaultProgressBar",!0),defaultProgressBarValue:this.processOption("defaultProgressBarValue",null),defaultPreventDuplicates:this.processOption("defaultPreventDuplicates",!1),defaultStyle:this.processOption("defaultStyle",{}),list:e,index:0,savedNames:{}}},created:function(){},mounted:function(){},components:{toast:A},methods:{addToast:function(t){this.index++,t.index=this.index,this.$set(this.list[t.position],this.index,t),void 0!==t.name&&this.$set(this.savedNames,t.name,t),void 0!==t.onCreated&&this.$nextTick(function(){t.onCreated()})},removeByName:function(t){void 0!==this.savedNames[t]&&(this.Close(this.savedNames[t]),this.$delete(this.savedNames,t))},removeToast:function(t){void 0!==this.list[t.position][t.index]&&(this.$delete(this.list[t.position],t.index),void 0!==t.onClosed&&this.$nextTick(function(){t.onClosed()}))},setProgress:function(t,e){var s=this.list[t.position][t.index];void 0!==s&&this.$set(s,"progressBarValue",e)},Add:function(t){return this.AddData(this.processObjectData(t))},AddData:function(e){if("object"!==t(e))return!1;if(e.preventDuplicates)for(var s=Object.keys(this.list[e.position]),o=0;odiv{position:relative;pointer-events:auto;overflow:hidden;margin:0 0 6px;padding:15px 15px 15px 50px;width:300px;-moz-border-radius:3px 3px 3px 3px;-webkit-border-radius:3px 3px 3px 3px;border-radius:3px 3px 3px 3px;background-position:15px center;background-repeat:no-repeat;-moz-box-shadow:0 0 12px #999;-webkit-box-shadow:0 0 12px #999;box-shadow:0 0 12px #999;color:#fff;opacity:.8}.toast-container>:hover{-moz-box-shadow:0 0 12px #000;-webkit-box-shadow:0 0 12px #000;box-shadow:0 0 12px #000;opacity:1;cursor:pointer}.toast-container>.toast-info{background-image:url()!important}.toast-container>.toast-error{background-image:url()!important}.toast-container>.toast-success{background-image:url()!important}.toast-container>.toast-warning{background-image:url()!important}.toast-container.toast-bottom-center>div,.toast-container.toast-top-center>div{width:300px;margin-left:auto;margin-right:auto}.toast-container.toast-bottom-full-width>div,.toast-container.toast-top-full-width>div{width:96%;margin-left:auto;margin-right:auto}.toast{background-color:#030303}.toast-success{background-color:#51a351}.toast-error{background-color:#bd362f}.toast-info{background-color:#2f96b4}.toast-warning{background-color:#f89406}.toast-progress{position:absolute;left:0;bottom:0;height:4px;background-color:#000;opacity:.4}@media all and (max-width:240px){.toast-container>div{padding:8px 8px 8px 50px;width:11em}.toast-container .toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:241px) and (max-width:480px){.toast-container>div{padding:8px 8px 8px 50px;width:18em}.toast-container .toast-close-button{right:-.2em;top:-.2em}}@media all and (min-width:481px) and (max-width:768px){.toast-container>div{padding:15px 15px 15px 50px;width:25em}}",map:void 0,media:void 0})};var k=a({render:w,staticRenderFns:y},B,C,void 0,!1,void 0,x,void 0);k.install=function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},s=t.extend({render:function(t){return t(k,{props:{options:e},ref:"vueToastr"})}}),o=(new s).$mount();document.body.appendChild(o.$el),t.prototype.$toastr=o.$refs.vueToastr},"undefined"!=typeof window&&window.Vue&&window.Vue.use(k);return a({},void 0,k,void 0,void 0,void 0,void 0,void 0)});
--------------------------------------------------------------------------------
/docs/.vuepress/config.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | plugins: [require("./plugin.js")],
3 | base: "/vue-toastr/",
4 | locales: {
5 | "/": {
6 | lang: "en-US",
7 | title: "Vuejs Toast",
8 | description: "Vuejs Toast"
9 | }
10 | },
11 | themeConfig: {
12 | repo: "/s4l1h/vue-toastr",
13 | docsDir: "docs",
14 | locales: {
15 | "/": {
16 | label: "English",
17 | selectText: "Languages",
18 | editLinkText: "Edit this page on GitHub",
19 | nav: [
20 | {
21 | text: "Release Notes",
22 | link: "https://github.com/s4l1h/vue-toastr/releases"
23 | }
24 | ],
25 | sidebar: [
26 | "/installation.md",
27 | "/started.md",
28 | "/usage_browser.md",
29 | "/usage_module.md",
30 | "/global_options.md",
31 | "/toast_options.md"
32 | ]
33 | }
34 | }
35 | }
36 | };
37 |
--------------------------------------------------------------------------------
/docs/.vuepress/plugin.js:
--------------------------------------------------------------------------------
1 | const { version } = require("../../package.json");
2 |
3 | module.exports = (/*options, ctx*/) => ({
4 | async enhanceAppFiles() {
5 | const code = `export default ({ Vue }) => {
6 | Vue.mixin({
7 | computed: {
8 | $version () {
9 | return '${version}'
10 | }
11 | }
12 | })
13 | }`;
14 | return [
15 | {
16 | name: "vuepress-plugin-vue-cli-plugin-p11n",
17 | content: code
18 | }
19 | ];
20 | }
21 | });
22 |
--------------------------------------------------------------------------------
/docs/README.md:
--------------------------------------------------------------------------------
1 | # Introduction
2 |
3 | `vue-toastr` is Toast plugin for [Vue.js](http://vuejs.org).
4 |
--------------------------------------------------------------------------------
/docs/global_options.md:
--------------------------------------------------------------------------------
1 | # Global Options
2 |
3 | ## Overwrite default options within Application
4 |
5 | **_this.\$toastr_** could be **_this.\$refs.toastr_**. It is depends on how you use it.
6 |
7 | #### Change Default Plugin Timeout
8 |
9 | ```javascript
10 | this.$toastr.defaultTimeout = 3000; // default timeout : 5000
11 | ```
12 |
13 | #### Change Default Plugin ProgressBar
14 |
15 | ```javascript
16 | this.$toastr.defaultProgressBar = false; // default active : true
17 | ```
18 |
19 | #### Change Default Plugin ProgressBar Manual Value
20 |
21 | ```javascript
22 | this.$toastr.defaultProgressBarValue = 0; // default value : null (managed by JS timer)
23 | ```
24 |
25 | #### Change Default Plugin Type
26 |
27 | ```javascript
28 | this.$toastr.defaultType = "error"; // default type : success
29 | ```
30 |
31 | #### Change Default Plugin Position
32 |
33 | ```javascript
34 | this.$toastr.defaultPosition = "toast-bottom-left"; // default position: toast-top-right
35 | ```
36 |
37 | #### Change Default Plugin Close On Mouse Hover
38 |
39 | ```javascript
40 | this.$toastr.defaultCloseOnHover = false; // default close on hover: true
41 | ```
42 |
43 | #### Change Default Style
44 |
45 | ```javascript
46 | this.$toastr.defaultStyle = { "background-color": "red" }; // default style: { }
47 | ```
48 |
49 | ### Inject your class names to toast
50 |
51 | ```javascript
52 | this.$toastr.defaultClassNames = ["animated", "zoomInUp"]; // default classNames: []
53 | ```
54 |
55 | ## Overwrite default options via plugin options
56 |
57 | _You can also overwrite defaults by passing options object during plugin registration_
58 |
59 | ```javascript
60 | Vue.use(VueToastr, {
61 | defaultTimeout: 3000,
62 | defaultProgressBar: false,
63 | defaultProgressBarValue: 0,
64 | defaultType: "error",
65 | defaultPosition: "toast-bottom-left",
66 | defaultCloseOnHover: false,
67 | defaultStyle: { "background-color": "red" },
68 | defaultClassNames: ["animated", "zoomInUp"]
69 | });
70 | ```
71 |
--------------------------------------------------------------------------------
/docs/installation.md:
--------------------------------------------------------------------------------
1 | # Installation
2 |
3 | ## Direct Download / CDN
4 |
5 | https://unpkg.com/vue-toastr/dist/vue-toastr
6 |
7 | [unpkg.com](https://unpkg.com) provides NPM-based CDN links. The above link will always point to the latest release on NPM. You can also use a specific version/tag via URLs like https://unpkg.com/vue-toastr@{{ \$version }}/dist/vue-toastr.js
8 |
9 | Include vue-toastr after Vue and it will install itself automatically:
10 |
11 | ```html
12 |
13 |
14 | ```
15 |
16 | You can use **runtime only build of Vue** (`vue.runtime.min.js`) because
17 | `vue-toastr` doesn't need to template compiler..
18 |
19 | ## NPM
20 |
21 | ```sh
22 | $ npm install vue-toastr
23 | ```
24 |
25 | ## Yarn
26 |
27 | ```sh
28 | $ yarn add vue-toastr
29 | ```
30 |
31 | ## Dev Build
32 |
33 | You will have to clone directly from GitHub and build `vue-toastr` yourself if
34 | you want to use the latest dev build.
35 |
36 | ```sh
37 | $ git clone https://github.com/s4l1h/vue-toastr.git node_modules/vue-toastr
38 | $ cd node_modules/vue-toastr
39 | $ yarn install
40 | $ yarn run build
41 | ```
42 |
--------------------------------------------------------------------------------
/docs/started.md:
--------------------------------------------------------------------------------
1 | # Getting Started
2 |
3 | After installation you will be able to use **_vue-toastr_** as a **_component_** or as a **_plugin_**.
4 |
5 | Next step you should choose how you are going to use **_vue-toastr_**.
6 |
7 | [Usage On Browser](./usage_browser.md) or [Usage On Module](./usage_module.md) after than you can create your first toast!
8 |
9 | ## Create Toast
10 |
11 | We created some methods for you which are help you quick use the plugin.
12 |
13 | ```javascript
14 | this.$toastr.s("SUCCESS MESSAGE", "Success Toast Title");
15 | this.$toastr.e("ERRROR MESSAGE");
16 | this.$toastr.w("WARNING MESSAGE");
17 | this.$toastr.i("INFORMATION MESSAGE");
18 | ```
19 |
20 | If you need more control. You can use Add method.
21 |
22 | ```javascript
23 | this.$toastr.Add({
24 | name: "UniqueToastName", // this is give you ability to use removeByName method
25 | title: "Easy Toast", // Toast Title
26 | msg: "Hi", // Toast Message
27 | clickClose: false, // Click Close Disable
28 | timeout: 0, // Remember defaultTimeout is 5 sec.(5000) in this case the toast won't close automatically
29 | //progressBarValue: 50, // Manually update progress bar value later; null (not 0) is default
30 | position: "toast-top-full-width", // Toast Position.
31 | type: "error", // Toast type,
32 | preventDuplicates: true, //Default is false,
33 | style: { backgroundColor: "blue", width: "150px" } // bind inline style to toast (check [Vue doc](https://vuejs.org/v2/guide/class-and-style.html#Binding-Inline-Styles) for more examples)
34 | });
35 | ```
36 |
37 | if you need more details about [toast options](./toast_options.md)
38 |
39 | ## Remove Toast
40 |
41 | You can remove toast by removeByName, removeByType or with toast variable.
42 |
43 | ```javascript
44 | var myFirstToast = this.$toastr.Add({
45 | name: "UniqName", // this is give you ability to use removeByName method
46 | msg: "Hi", // Toast Message
47 | type: "error" // Toast type,
48 | });
49 | this.$toastr.Close(myFirstToast); // remove toast
50 | this.$toastr.removeByName("UniqName"); // remove toast by name
51 | this.$toastr.removeByType("error"); // remove all error type message
52 | ```
53 |
54 | ## Demo
55 |
56 | Basic [Demo](https://github.com/s4l1h/vue-toastr/tree/master/demo) Files
57 |
--------------------------------------------------------------------------------
/docs/toast_options.md:
--------------------------------------------------------------------------------
1 | # Toast Options
2 |
3 | | Varitable | default | Can Be | Desc. |
4 | | ---------------- | :-------------: | -----------------------------------------------------------------------------------------------------------------------------------------------------------------------------: | -------------------------------------------------------------------------------------------------------------------------------------------------------------- |
5 | | name | | it is up to you | Toast Name |
6 | | title | | **_required_** | Toast Title |
7 | | msg | | **_required_** | Toast Message |
8 | | position | toast-top-right | `'toast-top-right', 'toast-bottom-right', 'toast-bottom-left', 'toast-top-left', 'toast-top-full-width', 'toast-bottom-full-width', 'toast-top-center', 'toast-bottom-center'` | Toast Position |
9 | | type | success | info,warning,error,success | Toast Message Type |
10 | | classNames | [] | array | Inline classNames option should be an array [More details](https://vuejs.org/v2/guide/class-and-style.html#Binding-Inline-Styles) | |
11 | | style | {} | style object | Inline style option should be an object [More details](https://vuejs.org/v2/guide/class-and-style.html#Binding-Inline-Styles) |
12 | | timeout | 5000 | number miliseconds | Toast Timeout Time for auto close |
13 | | closeOnHover | true | true or false | OnMouseOver toast pause/resume timeout |
14 | | clickClose | false | true or false | OnClick toast close it |
15 | | onCreated | | function | toast created event |
16 | | onClosed | | function | toast closed event |
17 | | onClicked | | function | toast clicked event |
18 | | onMouseOver | | function | toast mouseover event |
19 | | onMouseOut | | function | toast mouseout event |
20 | | progressbar | true | true or false | show progressbar or not |
21 | | progressBarValue | | 0..100 | Initial value of the progress bar in percents which does mean the progress bar is controlled by timeout; use this.\$toastr.setProgress(aToast, newValue) later |
22 |
23 | ```javascript
24 | {
25 | name: "Toast Name",
26 | title: "Toast Title",
27 | msg: "Toast Message",
28 | position: "toast-top-right",
29 | type: "success",
30 | timeout: 5000,
31 | progressbar: true,
32 | //progressBarValue:"", // if you want set progressbar value
33 | style:{},
34 | classNames: ["animated", "zoomInUp"],
35 | closeOnHover: true
36 | clickClose: false
37 | onCreated: ()=>{},
38 | onClicked: ()=>{},
39 | onClosed: ()=>{},
40 | onMouseOver: ()=>{},
41 | onMouseOut: ()=>{},
42 | }
43 | ```
44 |
--------------------------------------------------------------------------------
/docs/usage_browser.md:
--------------------------------------------------------------------------------
1 | # Browser use
2 |
3 | ## Usage as a Plugin
4 |
5 | When you add vue-toastr to your page you won't need to install it because it will be installed automatically.
6 |
7 | ### HTML
8 |
9 | ```html
10 |
11 |
12 |
13 |
14 |
20 |
21 |
22 |
23 |
24 |
25 | ```
26 |
27 | ### JavaScript
28 |
29 | ```javascript
30 | // Now the app has started!
31 | // you can access the plugin from everywhere via this.$toastr
32 | new Vue({
33 | mounted() {
34 | // Inject your class names for animation
35 | this.$toastr.defaultClassNames = ["animated", "zoomInUp"];
36 | // Change Toast Position
37 | this.$toastr.defaultPosition = "toast-top-left";
38 | // Send message to browser screen
39 | this.$toastr.s(
40 | "This Message From Toastr Plugin\n You can access this plugin : this.$toastr "
41 | );
42 | }
43 | }).$mount("#app");
44 | ```
45 |
46 | ## Usage as a Component
47 |
48 | when you decited to use as a component you have to register it.
49 |
50 | ### HTML
51 |
52 | ```html
53 |
54 |
55 |
56 |
57 |
58 |
59 |
60 | ```
61 |
62 | ### JavaScript
63 |
64 | ```javascript
65 | // Now the app has started!
66 | new Vue({
67 | components: {
68 | "vue-toastr": window.VueToastr
69 | },
70 | mounted() {
71 | // Change default toast position.
72 | this.$refs.mytoast.defaultPosition = "toast-top-left";
73 | // Send message to browser screen
74 | this.$refs.mytoast.s(
75 | "This Message From Toastr Plugin\n You can access this plugin : this.$toastr "
76 | );
77 | }
78 | }).$mount("#app");
79 | ```
80 |
--------------------------------------------------------------------------------
/docs/usage_module.md:
--------------------------------------------------------------------------------
1 | # Modular use
2 |
3 | ## Usage as a Plugin
4 |
5 | If you use vue.js plugin before. it will be easy for you.Just import and use.
6 |
7 | ### JavaScript
8 |
9 | ```javascript
10 | import Vue from "vue";
11 | import App from "./App.vue";
12 |
13 | // import plugin
14 | import VueToastr from "vue-toastr";
15 | // use plugin
16 | Vue.use(VueToastr, {
17 | /* OverWrite Plugin Options if you need */
18 | });
19 |
20 | Vue.config.productionTip = false;
21 |
22 | new Vue({
23 | render: h => h(App),
24 | mounted() {
25 | // You are able to access plugin from everywhere via this.$toastr
26 | this.$toastr.defaultPosition = "toast-top-left";
27 | // Send message to browser screen
28 | this.$toastr.s(
29 | "This Message From Toastr Plugin\n You can access this plugin : this.$toastr "
30 | );
31 | }
32 | }).$mount("#app");
33 | ```
34 |
35 | ## Usage as a Component
36 |
37 | ### HTML
38 |
39 | ```html
40 |
41 |
42 |
43 |
44 | ```
45 |
46 | ### JavaScript
47 |
48 | ```javascript
49 | import Vue from "vue";
50 | import App from "./App.vue";
51 |
52 | // import plugin
53 | import VueToastr from "vue-toastr";
54 | // register component
55 | Vue.component("vue-toastr", VueToastr);
56 |
57 | Vue.config.productionTip = false;
58 | // for more details about using component please check vue.js documentation out.
59 | new Vue({
60 | render: h => h(App),
61 | components: {
62 | // "vue-toastr": VueToastr,
63 | // VueToastr,
64 | },
65 | mounted() {
66 | // Change default toast position.
67 | this.$refs.mytoast.defaultPosition = "toast-top-left";
68 | // Send message to browser screen
69 | this.$refs.mytoast.s(
70 | "This Message From Toastr Plugin\n You can access this plugin : this.$toastr "
71 | );
72 | }
73 | }).$mount("#app");
74 | ```
75 |
--------------------------------------------------------------------------------
/jest.config.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | moduleFileExtensions: ["js", "jsx", "json", "vue"],
3 | transform: {
4 | "^.+\\.vue$": "vue-jest",
5 | ".+\\.(css|styl|less|sass|scss|svg|png|jpg|ttf|woff|woff2)$":
6 | "jest-transform-stub",
7 | "^.+\\.jsx?$": "babel-jest"
8 | },
9 | transformIgnorePatterns: ["/node_modules/"],
10 | moduleNameMapper: {
11 | "^@/(.*)$": "/src/$1"
12 | },
13 | snapshotSerializers: ["jest-serializer-vue"],
14 | testMatch: [
15 | "**/tests/unit/**/*.spec.(js|jsx|ts|tsx)|**/__tests__/*.(js|jsx|ts|tsx)"
16 | ],
17 | testURL: "http://localhost/",
18 | watchPlugins: [
19 | "jest-watch-typeahead/filename",
20 | "jest-watch-typeahead/testname"
21 | ]
22 | }
23 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "vue-toastr",
3 | "version": "2.1.2",
4 | "description": "Toastr for Vue.js no jquery dependencies",
5 | "author": "s4l1h",
6 | "scripts": {
7 | "build": "vue-cli-service build",
8 | "test": "vue-cli-service test",
9 | "lint": "vue-cli-service lint",
10 | "demo": "vue-cli-service demo",
11 | "docs": "npm run docs:serve",
12 | "docs:build": "vue-cli-service docs --mode build",
13 | "docs:serve": "vue-cli-service docs --mode serve",
14 | "prepublish": "vue-cli-service lint && vue-cli-service docs --mode build && vue-cli-service build",
15 | "test:unit": "vue-cli-service test:unit"
16 | },
17 | "husky": {
18 | "hooks": {
19 | "pre-commit": "npm run lint",
20 | "pre-push": "npm run lint && npm run test:unit"
21 | }
22 | },
23 | "main": "dist/vue-toastr.common.js",
24 | "module": "dist/vue-toastr.esm.js",
25 | "unpkg": "dist/vue-toastr.umd.min.js",
26 | "files": [
27 | "dist/vue-toastr.common.js",
28 | "dist/vue-toastr.umd.min.js",
29 | "dist/vue-toastr.umd.js",
30 | "dist/vue-toastr.esm.js",
31 | "src"
32 | ],
33 | "dependencies": {},
34 | "devDependencies": {
35 | "@vue/cli-plugin-babel": "^3.8.0",
36 | "@vue/cli-plugin-eslint": "^3.8.0",
37 | "@vue/cli-plugin-unit-jest": "^3.8.0",
38 | "@vue/cli-service": "^3.8.0",
39 | "@vue/eslint-config-prettier": "5.0.0",
40 | "@vue/test-utils": "1.0.0-beta.29",
41 | "babel-core": "7.0.0-bridge.0",
42 | "babel-eslint": "^10.0.1",
43 | "babel-jest": "^23.6.0",
44 | "eslint": "^5.16.0",
45 | "eslint-plugin-prettier": "3.1.0",
46 | "eslint-plugin-vue": "^5.0.0",
47 | "husky": "^3.0.5",
48 | "node-sass": "^4.12.0",
49 | "prettier": "1.18.2",
50 | "sass-loader": "^7.1.0",
51 | "vue": "^2.6.10",
52 | "vue-cli-plugin-p11n": "^0.3.0",
53 | "vue-template-compiler": "^2.6.10"
54 | },
55 | "eslintConfig": {
56 | "root": true,
57 | "env": {
58 | "node": true
59 | },
60 | "extends": [
61 | "plugin:vue/essential",
62 | "@vue/prettier"
63 | ],
64 | "rules": {
65 | "prettier/prettier": [
66 | "warn",
67 | {
68 | "singleQuote": false,
69 | "semi": false,
70 | "trailingComma": "none"
71 | }
72 | ]
73 | },
74 | "parserOptions": {
75 | "parser": "babel-eslint"
76 | }
77 | },
78 | "eslintIgnore": [
79 | "dist/*"
80 | ],
81 | "postcss": {
82 | "plugins": {
83 | "autoprefixer": {}
84 | }
85 | },
86 | "browserslist": [
87 | "> 1%",
88 | "last 2 versions"
89 | ],
90 | "bugs": {
91 | "url": "https://github.com/s4l1h/vue-toastr/issues"
92 | },
93 | "homepage": "https://github.com/s4l1h/vue-toastr#readme",
94 | "jsdelivr": "dist/vue-toastr.umd.min.js",
95 | "keywords": [
96 | "vuejs",
97 | "vue",
98 | "vue-component",
99 | "component"
100 | ],
101 | "license": "MIT",
102 | "repository": {
103 | "type": "git",
104 | "url": "git+https://github.com/s4l1h/vue-toastr.git"
105 | },
106 | "sideeffects": false
107 | }
108 |
--------------------------------------------------------------------------------
/src/components/IntervalTimeManager.js:
--------------------------------------------------------------------------------
1 | const IntervalTimeManager = params => ({
2 | id: false,
3 | times: {},
4 | estimated: null,
5 | remaning: null,
6 | totalTime: params.totalTime || 5000,
7 | stepTime: params.stepTime || 50,
8 | callbackFunctions: params.callbackFunctions || {},
9 | callback() {
10 | this.times["callback"] = this.getTime()
11 |
12 | this.remaning = this.remaning - this.stepTime
13 | this.estimated = this.estimated + this.stepTime
14 |
15 | this.callCallbackFN("callback")
16 |
17 | if (this.remaning <= 0) {
18 | return this.finish()
19 | }
20 | },
21 | getTime() {
22 | return new Date().getTime()
23 | },
24 | getPercent() {
25 | return Math.floor((this.remaning / this.totalTime) * 100)
26 | },
27 | start() {
28 | this.times["started"] = this.getTime()
29 | this.callCallbackFN("before:start")
30 | this.remaning = this.totalTime
31 | this._setupInterval()
32 | this.callCallbackFN("after:start")
33 | },
34 | finish() {
35 | this.times["finished"] = this.getTime()
36 | this.callCallbackFN("before:finish")
37 | this._clearInterval(this.id)
38 | this.callCallbackFN("after:finish")
39 | },
40 | stop() {
41 | this.times["stoped"] = this.getTime()
42 | // People can stop manualy
43 | this.callCallbackFN("before:stop")
44 | this._clearInterval(this.id)
45 | this.callCallbackFN("after:stop")
46 | },
47 | pause() {
48 | this.times["paused"] = this.getTime()
49 | this.callCallbackFN("before:pause")
50 | this._clearInterval(this.id)
51 | this.callCallbackFN("after:pause")
52 | },
53 | resume() {
54 | this.times["resumed"] = this.getTime()
55 | this.callCallbackFN("before:resume")
56 | this._setupInterval()
57 | this.callCallbackFN("after:resume")
58 | },
59 | callCallbackFN(type) {
60 | // console.log(this.callbackFunctions, type);
61 | if (typeof this.callbackFunctions[type] === "function") {
62 | this.callbackFunctions[type]()
63 | }
64 | },
65 | _clearInterval() {
66 | clearInterval(this.id)
67 | },
68 | _setupInterval() {
69 | this.id = setInterval(() => {
70 | this.callback()
71 | }, this.stepTime)
72 | }
73 | })
74 | export default IntervalTimeManager
75 |
--------------------------------------------------------------------------------
/src/components/Toast.vue:
--------------------------------------------------------------------------------
1 |
2 |
10 |
15 |
16 |
21 |
22 |
23 |
24 |
25 |
26 |
155 |
--------------------------------------------------------------------------------
/src/components/ToastProgress.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
21 |
--------------------------------------------------------------------------------
/src/components/Toastr.vue:
--------------------------------------------------------------------------------
1 |
2 |
3 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
251 |
254 |
--------------------------------------------------------------------------------
/src/components/VueToastr.vue:
--------------------------------------------------------------------------------
1 |
32 |
--------------------------------------------------------------------------------
/src/index.js:
--------------------------------------------------------------------------------
1 | // export { default } from "./components/VueToastr.vue";
2 | // export { default as Toastr } from "./components/Toastr.vue";
3 | // export { default as Toast } from "./components/Toast.vue";
4 | // export { default as ToastProgress } from "./components/ToastProgress.vue";
5 | import VueToastr from "./components/VueToastr.vue"
6 | export default VueToastr
7 |
--------------------------------------------------------------------------------
/src/vue-toastr.scss:
--------------------------------------------------------------------------------
1 | // Mix-ins
2 | @mixin borderRadius($radius) {
3 | -moz-border-radius: $radius;
4 | -webkit-border-radius: $radius;
5 | border-radius: $radius;
6 | }
7 |
8 | @mixin boxShadow($boxShadow) {
9 | -moz-box-shadow: $boxShadow;
10 | -webkit-box-shadow: $boxShadow;
11 | box-shadow: $boxShadow;
12 | }
13 |
14 | @mixin opacity($opacity) {
15 | $opacityPercent: $opacity * 100;
16 | opacity: $opacity;
17 | }
18 |
19 | @mixin wordWrap($wordWrap: break-word) {
20 | -ms-word-wrap: $wordWrap;
21 | word-wrap: $wordWrap;
22 | }
23 |
24 | // Variables
25 | $black: #000000;
26 | $grey: #999999;
27 | $light-grey: #CCCCCC;
28 | $white: #FFFFFF;
29 | $near-black: #030303;
30 | $green: #51A351;
31 | $red: #BD362F;
32 | $blue: #2F96B4;
33 | $orange: #F89406;
34 | $default-container-opacity: .8;
35 |
36 | // Styles
37 | .toast-title {
38 | font-weight: bold;
39 | }
40 |
41 | .toast-message {
42 | @include wordWrap();
43 |
44 | a,
45 | label {
46 | color: $white;
47 | }
48 |
49 | a:hover {
50 | color: $light-grey;
51 | text-decoration: none;
52 | }
53 | }
54 |
55 | .toast-close-button {
56 | position: relative;
57 | right: -0.3em;
58 | top: -0.3em;
59 | float: right;
60 | font-size: 20px;
61 | font-weight: bold;
62 | color: $white;
63 | -webkit-text-shadow: 0 1px 0 rgba(255, 255, 255, 1);
64 | text-shadow: 0 1px 0 rgba(255, 255, 255, 1);
65 | @include opacity(0.8);
66 |
67 | &:hover,
68 | &:focus {
69 | color: $black;
70 | text-decoration: none;
71 | cursor: pointer;
72 | @include opacity(0.4);
73 | }
74 | }
75 |
76 | /*Additional properties for button version
77 | iOS requires the button element instead of an anchor tag.
78 | If you want the anchor version, it requires `href="#"`.*/
79 | button.toast-close-button {
80 | padding: 0;
81 | cursor: pointer;
82 | background: transparent;
83 | border: 0;
84 | -webkit-appearance: none;
85 | }
86 |
87 | //#endregion
88 |
89 | .toast-top-center {
90 | top: 0;
91 | right: 0;
92 | width: 100%;
93 | }
94 |
95 | .toast-bottom-center {
96 | bottom: 0;
97 | right: 0;
98 | width: 100%;
99 | }
100 |
101 | .toast-top-full-width {
102 | top: 0;
103 | right: 0;
104 | width: 100%;
105 | }
106 |
107 | .toast-bottom-full-width {
108 | bottom: 0;
109 | right: 0;
110 | width: 100%;
111 | }
112 |
113 | .toast-top-left {
114 | top: 12px;
115 | left: 12px;
116 | }
117 |
118 | .toast-top-right {
119 | top: 12px;
120 | right: 12px;
121 | }
122 |
123 | .toast-bottom-right {
124 | right: 12px;
125 | bottom: 12px;
126 | }
127 |
128 | .toast-bottom-left {
129 | bottom: 12px;
130 | left: 12px;
131 | }
132 |
133 | .toast-container {
134 | position: fixed;
135 | z-index: 999999;
136 | // The container should not be clickable.
137 | pointer-events: none;
138 |
139 | * {
140 | -moz-box-sizing: border-box;
141 | -webkit-box-sizing: border-box;
142 | box-sizing: border-box;
143 | }
144 |
145 | >div {
146 | position: relative;
147 | pointer-events: auto;
148 | overflow: hidden;
149 | margin: 0 0 6px;
150 | padding: 15px 15px 15px 50px;
151 | width: 300px;
152 | @include borderRadius(3px 3px 3px 3px);
153 | background-position: 15px center;
154 | background-repeat: no-repeat;
155 | @include boxShadow(0 0 12px $grey);
156 | color: $white;
157 | @include opacity($default-container-opacity);
158 | }
159 |
160 | > :hover {
161 | @include boxShadow(0 0 12px $black);
162 | @include opacity(1);
163 | cursor: pointer;
164 | }
165 |
166 | >.toast-info {
167 | background-image: url("") !important;
168 | }
169 |
170 | >.toast-error {
171 | background-image: url("") !important;
172 | }
173 |
174 | >.toast-success {
175 | background-image: url("") !important;
176 | }
177 |
178 | >.toast-warning {
179 | background-image: url("") !important;
180 | }
181 |
182 | /*overrides*/
183 | &.toast-top-center>div,
184 | &.toast-bottom-center>div {
185 | width: 300px;
186 | margin-left: auto;
187 | margin-right: auto;
188 | }
189 |
190 | &.toast-top-full-width>div,
191 | &.toast-bottom-full-width>div {
192 | width: 96%;
193 | margin-left: auto;
194 | margin-right: auto;
195 | }
196 | }
197 |
198 | .toast {
199 | background-color: $near-black;
200 | }
201 |
202 | .toast-success {
203 | background-color: $green;
204 | }
205 |
206 | .toast-error {
207 | background-color: $red;
208 | }
209 |
210 | .toast-info {
211 | background-color: $blue;
212 | }
213 |
214 | .toast-warning {
215 | background-color: $orange;
216 | }
217 |
218 | .toast-progress {
219 | position: absolute;
220 | left: 0;
221 | bottom: 0;
222 | height: 4px;
223 | background-color: $black;
224 | @include opacity(0.4);
225 | }
226 |
227 | /*Responsive Design*/
228 |
229 | @media all and (max-width: 240px) {
230 | .toast-container {
231 |
232 | >div {
233 | padding: 8px 8px 8px 50px;
234 | width: 11em;
235 | }
236 |
237 | & .toast-close-button {
238 | right: -0.2em;
239 | top: -0.2em;
240 | }
241 | }
242 | }
243 |
244 | @media all and (min-width: 241px) and (max-width: 480px) {
245 | .toast-container {
246 | >div {
247 | padding: 8px 8px 8px 50px;
248 | width: 18em;
249 | }
250 |
251 | & .toast-close-button {
252 | right: -0.2em;
253 | top: -0.2em;
254 | }
255 | }
256 | }
257 |
258 | @media all and (min-width: 481px) and (max-width: 768px) {
259 | .toast-container {
260 | >div {
261 | padding: 15px 15px 15px 50px;
262 | width: 25em;
263 | }
264 | }
265 | }
--------------------------------------------------------------------------------
/tests/unit/.eslintrc.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | env: {
3 | jest: true
4 | }
5 | }
6 |
--------------------------------------------------------------------------------
/tests/unit/Toast.spec.js:
--------------------------------------------------------------------------------
1 | import { shallowMount } from "@vue/test-utils"
2 | import Toast from "@/components/Toast.vue"
3 |
4 | const mockProps = {
5 | data: {
6 | msg: "Toast Msg",
7 | progressbar: false,
8 | timeout: 1000,
9 | title: "Toast Title",
10 | type: "error"
11 | }
12 | }
13 | describe("Toast.vue", () => {
14 | // it("default props value", () => {
15 | // const wrapper = shallowMount(Toast, {});
16 | // expect(wrapper.props()).toEqual(mockProps);
17 | // });
18 |
19 | it("renders props when passed", () => {
20 | const wrapper = shallowMount(Toast, {
21 | propsData: mockProps
22 | })
23 | expect(wrapper.props()).toEqual(mockProps)
24 | })
25 |
26 | it("match attributes", () => {
27 | const wrapper = shallowMount(Toast, {
28 | propsData: mockProps
29 | })
30 | expect(wrapper.attributes()).toEqual({
31 | class: "toast toast-error",
32 | style: "display: block;"
33 | })
34 | })
35 | it("match classNames", () => {
36 | const props = {
37 | data: { ...mockProps.data, classNames: ["animated", "bounce"] }
38 | }
39 | const wrapper = shallowMount(Toast, {
40 | propsData: props
41 | })
42 | expect(wrapper.attributes()).toEqual({
43 | class: "toast toast-error animated bounce",
44 | style: "display: block;"
45 | })
46 | })
47 | it("matches slot msg", () => {
48 | const wrapper = shallowMount(Toast, {
49 | propsData: mockProps,
50 | slots: {
51 | default: '
'
52 | }
53 | })
54 | expect(wrapper.contains(".fake-msg")).toBe(true)
55 | })
56 |
57 | it("matches snapshot", () => {
58 | const wrapper = shallowMount(Toast, {
59 | propsData: mockProps
60 | })
61 | expect(wrapper.html()).toMatchSnapshot()
62 | })
63 | })
64 |
--------------------------------------------------------------------------------
/tests/unit/ToastProgress.spec.js:
--------------------------------------------------------------------------------
1 | import { shallowMount } from "@vue/test-utils"
2 | import ToastProgress from "@/components/ToastProgress.vue"
3 |
4 | describe("ToastProgress.vue", () => {
5 | it("default props value", () => {
6 | const wrapper = shallowMount(ToastProgress, {})
7 | expect(wrapper.props()).toEqual({ percent: 100 })
8 | })
9 |
10 | it("renders props.percent when passed", () => {
11 | const props = { percent: 90 }
12 | const wrapper = shallowMount(ToastProgress, {
13 | propsData: props
14 | })
15 | expect(wrapper.props()).toEqual(props)
16 | })
17 |
18 | it("match attributes", () => {
19 | const wrapper = shallowMount(ToastProgress, {
20 | propsData: { percent: 90 }
21 | })
22 | expect(wrapper.attributes()).toEqual({
23 | class: "toast-progress",
24 | style: "width: 90%;"
25 | })
26 | })
27 |
28 | it("matches snapshot", () => {
29 | const wrapper = shallowMount(ToastProgress, {
30 | propsData: { percent: 90 }
31 | })
32 | expect(wrapper.html()).toMatchSnapshot()
33 | })
34 | })
35 |
--------------------------------------------------------------------------------
/tests/unit/__snapshots__/Toast.spec.js.snap:
--------------------------------------------------------------------------------
1 | // Jest Snapshot v1, https://goo.gl/fbAQLP
2 |
3 | exports[`Toast.vue matches snapshot 1`] = `
4 |
5 |
6 |
Toast Title
7 |
Toast Msg
8 |
9 |
10 | `;
11 |
--------------------------------------------------------------------------------
/tests/unit/__snapshots__/ToastProgress.spec.js.snap:
--------------------------------------------------------------------------------
1 | // Jest Snapshot v1, https://goo.gl/fbAQLP
2 |
3 | exports[`ToastProgress.vue matches snapshot 1`] = `
`;
4 |
--------------------------------------------------------------------------------