فهرست منبع

feat(AdvancedTable): Reset and select query operator buttons, and reset popup position

Owen Diffey 3 سال پیش
والد
کامیت
3d42c93949
3فایلهای تغییر یافته به همراه84 افزوده شده و 26 حذف شده
  1. 4 2
      backend/logic/actions/songs.js
  2. 8 3
      backend/logic/songs.js
  3. 72 21
      frontend/src/components/AdvancedTable.vue

+ 4 - 2
backend/logic/actions/songs.js

@@ -210,9 +210,10 @@ export default {
 	 * @param properties - the properties to return for each song
 	 * @param properties - the properties to return for each song
 	 * @param sort - the sort object
 	 * @param sort - the sort object
 	 * @param queries - the queries array
 	 * @param queries - the queries array
+	 * @param operator - the operator for queries
 	 * @param cb
 	 * @param cb
 	 */
 	 */
-	getData: isAdminRequired(async function getSet(session, page, pageSize, properties, sort, queries, cb) {
+	getData: isAdminRequired(async function getSet(session, page, pageSize, properties, sort, queries, operator, cb) {
 		async.waterfall(
 		async.waterfall(
 			[
 			[
 				next => {
 				next => {
@@ -223,7 +224,8 @@ export default {
 							pageSize,
 							pageSize,
 							properties,
 							properties,
 							sort,
 							sort,
-							queries
+							queries,
+							operator
 						},
 						},
 						this
 						this
 					)
 					)

+ 8 - 3
backend/logic/songs.js

@@ -215,11 +215,12 @@ class _SongsModule extends CoreClass {
 	 * @param {string} payload.properties - the properties to return for each song
 	 * @param {string} payload.properties - the properties to return for each song
 	 * @param {string} payload.sort - the sort object
 	 * @param {string} payload.sort - the sort object
 	 * @param {string} payload.queries - the queries array
 	 * @param {string} payload.queries - the queries array
+	 * @param {string} payload.operator - the operator for queries
 	 * @returns {Promise} - returns a promise (resolve, reject)
 	 * @returns {Promise} - returns a promise (resolve, reject)
 	 */
 	 */
 	GET_DATA(payload) {
 	GET_DATA(payload) {
 		return new Promise((resolve, reject) => {
 		return new Promise((resolve, reject) => {
-			const { page, pageSize, properties, sort, queries } = payload;
+			const { page, pageSize, properties, sort, queries, operator } = payload;
 
 
 			console.log("GET_DATA", payload);
 			console.log("GET_DATA", payload);
 
 
@@ -236,16 +237,20 @@ class _SongsModule extends CoreClass {
 				return newQuery;
 				return newQuery;
 			});
 			});
 
 
+			const queryObject = {};
+			if (operator === "and") queryObject.$and = newQueries;
+			else queryObject.$or = newQueries;
+
 			async.waterfall(
 			async.waterfall(
 				[
 				[
 					next => {
 					next => {
-						SongsModule.SongModel.find({ $and: newQueries }).count((err, count) => {
+						SongsModule.SongModel.find(queryObject).count((err, count) => {
 							next(err, count);
 							next(err, count);
 						});
 						});
 					},
 					},
 
 
 					(count, next) => {
 					(count, next) => {
-						SongsModule.SongModel.find({ $and: newQueries })
+						SongsModule.SongModel.find(queryObject)
 							.sort(sort)
 							.sort(sort)
 							.skip(pageSize * (page - 1))
 							.skip(pageSize * (page - 1))
 							.limit(pageSize)
 							.limit(pageSize)

+ 72 - 21
frontend/src/components/AdvancedTable.vue

@@ -89,12 +89,40 @@
 								</button>
 								</button>
 							</div>
 							</div>
 						</div>
 						</div>
-						<a class="button is-info" @click="getData()">
-							<i class="material-icons icon-with-button"
-								>search</i
-							>
-							Search
-						</a>
+						<div class="advanced-query-bottom">
+							<div class="control select">
+								<select v-model="queryOperator">
+									<option
+										v-for="operator in queryOperators"
+										:key="operator.name"
+										:value="operator.name"
+									>
+										{{ operator.displayName }}
+									</option>
+								</select>
+							</div>
+							<div class="control is-expanded">
+								<button
+									class="button is-info"
+									@click="getData()"
+								>
+									<i class="material-icons icon-with-button"
+										>search</i
+									>
+									Search
+								</button>
+							</div>
+							<div class="control">
+								<button
+									class="button is-warning material-icons"
+									@click="resetQuery()"
+									content="Reset query"
+									v-tippy="{ theme: 'info' }"
+								>
+									refresh
+								</button>
+							</div>
+						</div>
 					</template>
 					</template>
 				</tippy>
 				</tippy>
 				<tippy
 				<tippy
@@ -406,6 +434,7 @@
 				<span
 				<span
 					class="material-icons drag-icon"
 					class="material-icons drag-icon"
 					@mousedown.left="onDragBox"
 					@mousedown.left="onDragBox"
+					@dblclick="resetBulkActionsPosition()"
 				>
 				>
 					drag_indicator
 					drag_indicator
 				</span>
 				</span>
@@ -468,6 +497,17 @@ export default {
 				};
 				};
 			},
 			},
 			advancedQuery: [],
 			advancedQuery: [],
+			queryOperator: "or",
+			queryOperators: [
+				{
+					name: "or",
+					displayName: "OR"
+				},
+				{
+					name: "and",
+					displayName: "AND"
+				}
+			],
 			resizing: {},
 			resizing: {},
 			allFilterTypes: {
 			allFilterTypes: {
 				contains: {
 				contains: {
@@ -552,15 +592,9 @@ export default {
 		const pageSize = parseInt(localStorage.getItem("adminPageSize"));
 		const pageSize = parseInt(localStorage.getItem("adminPageSize"));
 		if (!Number.isNaN(pageSize)) this.pageSize = pageSize;
 		if (!Number.isNaN(pageSize)) this.pageSize = pageSize;
 
 
-		if (this.filters.length > 0)
-			this.advancedQuery.push({
-				data: "",
-				filter: {},
-				filterType: ""
-			});
+		this.addQueryItem();
 
 
-		this.bulkPopup.top = document.body.clientHeight - 56;
-		this.bulkPopup.left = document.body.clientWidth / 2 - 200;
+		this.resetBulkActionsPosition();
 
 
 		ws.onConnect(this.init);
 		ws.onConnect(this.init);
 	},
 	},
@@ -576,6 +610,7 @@ export default {
 				this.properties,
 				this.properties,
 				this.sort,
 				this.sort,
 				this.advancedQuery,
 				this.advancedQuery,
+				this.queryOperator,
 				res => {
 				res => {
 					console.log(111, res);
 					console.log(111, res);
 					if (res.status === "success") {
 					if (res.status === "success") {
@@ -684,17 +719,22 @@ export default {
 			this.data[itemIndex].highlighted = true;
 			this.data[itemIndex].highlighted = true;
 		},
 		},
 		addQueryItem() {
 		addQueryItem() {
-			if (this.filters.length > 0)
-				this.advancedQuery.push({
-					data: "",
-					filter: {},
-					filterType: ""
-				});
+			this.advancedQuery.push({
+				data: "",
+				filter: {},
+				filterType: ""
+			});
 		},
 		},
 		removeQueryItem(index) {
 		removeQueryItem(index) {
 			if (this.advancedQuery.length > 1)
 			if (this.advancedQuery.length > 1)
 				this.advancedQuery.splice(index, 1);
 				this.advancedQuery.splice(index, 1);
 		},
 		},
+		resetQuery() {
+			this.advancedQuery = [];
+			this.queryOperator = "or";
+			this.addQueryItem();
+			this.getData();
+		},
 		columnResizingMouseDown(column, event) {
 		columnResizingMouseDown(column, event) {
 			this.resizing.resizing = true;
 			this.resizing.resizing = true;
 			this.resizing.resizingColumn = column;
 			this.resizing.resizingColumn = column;
@@ -783,6 +823,10 @@ export default {
 				document.onmouseup = null;
 				document.onmouseup = null;
 				document.onmousemove = null;
 				document.onmousemove = null;
 			};
 			};
+		},
+		resetBulkActionsPosition() {
+			this.bulkPopup.top = document.body.clientHeight - 56;
+			this.bulkPopup.left = document.body.clientWidth / 2 - 200;
 		}
 		}
 	}
 	}
 };
 };
@@ -988,8 +1032,11 @@ export default {
 }
 }
 
 
 .advanced-query {
 .advanced-query {
-	display: flex;
 	margin-bottom: 5px;
 	margin-bottom: 5px;
+}
+.advanced-query,
+.advanced-query-bottom {
+	display: flex;
 
 
 	& > .control {
 	& > .control {
 		& > input,
 		& > input,
@@ -1016,6 +1063,10 @@ export default {
 		}
 		}
 	}
 	}
 }
 }
+.advanced-query-bottom .button {
+	font-size: 16px !important;
+	width: 100%;
+}
 
 
 .bulk-popup {
 .bulk-popup {
 	display: flex;
 	display: flex;