2 <div id="image-manager">
3 <div class="overlay" v-el:overlay @click="overlayClick">
4 <div class="image-manager-body">
5 <div class="image-manager-content">
6 <div class="image-manager-list">
7 <div v-for="image in images">
8 <img class="anim fadeIn"
9 :class="{selected: (image==selectedImage)}"
10 :src="image.thumbs.gallery" :alt="image.title" :title="image.name"
11 @click="imageClick(image)"
12 :style="{animationDelay: ($index > 26) ? '160ms' : ($index * 25) + 'ms'}">
14 <div class="load-more" v-show="hasMore" @click="fetchData">Load More</div>
17 <button class="neg button image-manager-close" @click="hide">x</button>
18 <div class="image-manager-sidebar">
19 <h2 v-el:image-title>Images</h2>
21 <div class="dropzone-container" v-el:drop-zone>
22 <div class="dz-message">Drop files or click here to upload</div>
24 <div class="image-manager-details anim fadeIn" v-show="selectedImage">
26 <form @submit="saveImageDetails" v-el:image-form>
27 <div class="form-group">
28 <label for="name">Image Name</label>
29 <input type="text" id="name" name="name" v-model="selectedImage.name">
33 <div v-show="dependantPages">
34 <p class="text-neg text-small">
35 This image is used in the pages below, Click delete again to confirm you want to delete
39 <li v-for="page in dependantPages">
40 <a :href="page.url" target="_blank" class="text-neg">{{ page.name }}</a>
45 <form @submit="deleteImage" v-el:image-delete-form>
46 <button class="button neg"><i class="zmdi zmdi-delete"></i>Delete Image</button>
49 <div class="image-manager-bottom">
50 <button class="button pos anim fadeIn" v-show="selectedImage" @click="selectButtonClick"><i
51 class="zmdi zmdi-square-right"></i>Select Image
62 var Dropzone = require('dropzone');
72 dependantPages: false,
74 token: document.querySelector('meta[name=token]').getAttribute('content'),
95 created: function () {
96 window.ImageManager = this;
101 this.setupDropZone();
105 fetchData: function () {
107 this.$http.get('/images/' + _this.imageType + '/all/' + _this.page, function (data) {
108 _this.images = _this.images.concat(data.images);
109 _this.hasMore = data.hasMore;
114 setupDropZone: function () {
116 var dropZone = new Dropzone(_this.$els.dropZone, {
117 url: '/images/' + _this.imageType + '/upload',
120 this.on("sending", function (file, xhr, data) {
121 data.append("_token", _this.token);
123 this.on("success", function (file, data) {
124 _this.images.unshift(data);
125 $(file.previewElement).fadeOut(400, function () {
129 this.on('error', function (file, errorMessage, xhr) {
130 if (errorMessage.file) {
131 $(file.previewElement).find('[data-dz-errormessage]').text(errorMessage.file[0]);
133 console.log(errorMessage);
139 returnCallback: function (image) {
141 var isResized = _this.resizeWidth && _this.resizeHeight;
144 _this.callback(image);
148 var cropped = _this.resizeCrop ? 'true' : 'false';
149 var requestString = '/images/thumb/' + image.id + '/' + _this.resizeWidth + '/' + _this.resizeHeight + '/' + cropped;
150 _this.$http.get(requestString, function(data) {
151 image.thumbs.custom = data.url;
152 _this.callback(image);
157 imageClick: function (image) {
158 var dblClickTime = 380;
159 var cTime = (new Date()).getTime();
160 var timeDiff = cTime - this.cClickTime;
161 if (this.cClickTime !== 0 && timeDiff < dblClickTime && this.selectedImage === image) {
164 this.returnCallback(image);
168 this.selectedImage = (this.selectedImage === image) ? false : image;
169 this.dependantPages = false;
171 this.cClickTime = cTime;
174 selectButtonClick: function () {
176 this.returnCallback(this.selectedImage);
181 show: function (callback) {
182 this.callback = callback;
183 this.$els.overlay.style.display = 'block';
184 // Get initial images if they have not yet been loaded in.
185 if (!this.dataLoaded) {
186 this.fetchData(this.page);
187 this.dataLoaded = true;
191 overlayClick: function (e) {
192 if (e.target.className === 'overlay') {
198 this.$els.overlay.style.display = 'none';
201 saveImageDetails: function (e) {
204 _this.selectedImage._token = _this.token;
205 var form = $(_this.$els.imageForm);
206 $.ajax('/images/update/' + _this.selectedImage.id, {
208 data: _this.selectedImage
209 }).done(function () {
210 form.showSuccess('Image name updated');
211 }).fail(function (jqXHR) {
212 form.showFailure(jqXHR.responseJSON);
216 deleteImage: function (e) {
219 _this.deleteForm.force = _this.dependantPages !== false;
220 _this.deleteForm._token = _this.token;
221 $.ajax('/images/' + _this.selectedImage.id, {
223 data: _this.deleteForm
224 }).done(function () {
225 _this.images.splice(_this.images.indexOf(_this.selectedImage), 1);
226 _this.selectedImage = false;
227 $(_this.$els.imageTitle).showSuccess('Image Deleted');
228 }).fail(function (jqXHR, textStatus) {
230 if (jqXHR.status === 400) {
231 _this.dependantPages = jqXHR.responseJSON;