mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-25 15:43:44 +02:00 
			
		
		
		
	Compare commits
	
		
			5 Commits
		
	
	
		
			chore/v7/d
			...
			debug/home
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | ac285cae99 | ||
|   | 612402d9cb | ||
|   | c9d210bd64 | ||
|   | 25defaac07 | ||
|   | 0661d0d5a1 | 
							
								
								
									
										630
									
								
								.editorconfig
									
									
									
									
									
								
							
							
						
						
									
										630
									
								
								.editorconfig
									
									
									
									
									
								
							| @@ -13,6 +13,40 @@ ij_formatter_tags_enabled = false | |||||||
| ij_smart_tabs = false | ij_smart_tabs = false | ||||||
| ij_wrap_on_typing = true | ij_wrap_on_typing = true | ||||||
|  |  | ||||||
|  | [*.conf] | ||||||
|  | indent_size = 2 | ||||||
|  | tab_width = 2 | ||||||
|  | ij_continuation_indent_size = 2 | ||||||
|  | ij_hocon_keep_blank_lines_before_right_brace = 2 | ||||||
|  | ij_hocon_keep_indents_on_empty_lines = false | ||||||
|  | ij_hocon_keep_line_breaks = true | ||||||
|  | ij_hocon_space_after_colon = true | ||||||
|  | ij_hocon_space_after_comma = true | ||||||
|  | ij_hocon_space_before_colon = true | ||||||
|  | ij_hocon_space_before_comma = false | ||||||
|  | ij_hocon_spaces_within_braces = false | ||||||
|  | ij_hocon_spaces_within_brackets = false | ||||||
|  | ij_hocon_spaces_within_method_call_parentheses = false | ||||||
|  |  | ||||||
|  | [*.css] | ||||||
|  | ij_css_align_closing_brace_with_properties = false | ||||||
|  | ij_css_blank_lines_around_nested_selector = 1 | ||||||
|  | ij_css_blank_lines_between_blocks = 1 | ||||||
|  | ij_css_brace_placement = end_of_line | ||||||
|  | ij_css_enforce_quotes_on_format = false | ||||||
|  | ij_css_hex_color_long_format = false | ||||||
|  | ij_css_hex_color_lower_case = false | ||||||
|  | ij_css_hex_color_short_format = false | ||||||
|  | ij_css_hex_color_upper_case = false | ||||||
|  | ij_css_keep_blank_lines_in_code = 2 | ||||||
|  | ij_css_keep_indents_on_empty_lines = false | ||||||
|  | ij_css_keep_single_line_blocks = false | ||||||
|  | ij_css_properties_order = font, font-family, font-size, font-weight, font-style, font-variant, font-size-adjust, font-stretch, line-height, position, z-index, top, right, bottom, left, display, visibility, float, clear, overflow, overflow-x, overflow-y, clip, zoom, align-content, align-items, align-self, flex, flex-flow, flex-basis, flex-direction, flex-grow, flex-shrink, flex-wrap, justify-content, order, box-sizing, width, min-width, max-width, height, min-height, max-height, margin, margin-top, margin-right, margin-bottom, margin-left, padding, padding-top, padding-right, padding-bottom, padding-left, table-layout, empty-cells, caption-side, border-spacing, border-collapse, list-style, list-style-position, list-style-type, list-style-image, content, quotes, counter-reset, counter-increment, resize, cursor, user-select, nav-index, nav-up, nav-right, nav-down, nav-left, transition, transition-delay, transition-timing-function, transition-duration, transition-property, transform, transform-origin, animation, animation-name, animation-duration, animation-play-state, animation-timing-function, animation-delay, animation-iteration-count, animation-direction, text-align, text-align-last, vertical-align, white-space, text-decoration, text-emphasis, text-emphasis-color, text-emphasis-style, text-emphasis-position, text-indent, text-justify, letter-spacing, word-spacing, text-outline, text-transform, text-wrap, text-overflow, text-overflow-ellipsis, text-overflow-mode, word-wrap, word-break, tab-size, hyphens, pointer-events, opacity, color, border, border-width, border-style, border-color, border-top, border-top-width, border-top-style, border-top-color, border-right, border-right-width, border-right-style, border-right-color, border-bottom, border-bottom-width, border-bottom-style, border-bottom-color, border-left, border-left-width, border-left-style, border-left-color, border-radius, border-top-left-radius, border-top-right-radius, border-bottom-right-radius, border-bottom-left-radius, border-image, border-image-source, border-image-slice, border-image-width, border-image-outset, border-image-repeat, outline, outline-width, outline-style, outline-color, outline-offset, background, background-color, background-image, background-repeat, background-attachment, background-position, background-position-x, background-position-y, background-clip, background-origin, background-size, box-decoration-break, box-shadow, text-shadow | ||||||
|  | ij_css_space_after_colon = true | ||||||
|  | ij_css_space_before_opening_brace = true | ||||||
|  | ij_css_use_double_quotes = true | ||||||
|  | ij_css_value_alignment = do_not_align | ||||||
|  |  | ||||||
| [*.java] | [*.java] | ||||||
| ij_java_align_consecutive_assignments = false | ij_java_align_consecutive_assignments = false | ||||||
| ij_java_align_consecutive_variable_declarations = false | ij_java_align_consecutive_variable_declarations = false | ||||||
| @@ -243,12 +277,63 @@ ij_java_wrap_comments = false | |||||||
| ij_java_wrap_first_method_in_call_chain = true | ij_java_wrap_first_method_in_call_chain = true | ||||||
| ij_java_wrap_long_lines = false | ij_java_wrap_long_lines = false | ||||||
|  |  | ||||||
|  | [*.nbtt] | ||||||
|  | max_line_length = 150 | ||||||
|  | ij_continuation_indent_size = 4 | ||||||
|  | ij_nbtt_keep_indents_on_empty_lines = false | ||||||
|  | ij_nbtt_space_after_colon = true | ||||||
|  | ij_nbtt_space_after_comma = true | ||||||
|  | ij_nbtt_space_before_colon = true | ||||||
|  | ij_nbtt_space_before_comma = false | ||||||
|  | ij_nbtt_spaces_within_brackets = false | ||||||
|  | ij_nbtt_spaces_within_parentheses = false | ||||||
|  |  | ||||||
| [*.properties] | [*.properties] | ||||||
| ij_properties_align_group_field_declarations = false | ij_properties_align_group_field_declarations = false | ||||||
| ij_properties_keep_blank_lines = false | ij_properties_keep_blank_lines = false | ||||||
| ij_properties_key_value_delimiter = equals | ij_properties_key_value_delimiter = equals | ||||||
| ij_properties_spaces_around_key_value_delimiter = false | ij_properties_spaces_around_key_value_delimiter = false | ||||||
|  |  | ||||||
|  | [*.sass] | ||||||
|  | indent_size = 2 | ||||||
|  | ij_sass_align_closing_brace_with_properties = false | ||||||
|  | ij_sass_blank_lines_around_nested_selector = 1 | ||||||
|  | ij_sass_blank_lines_between_blocks = 1 | ||||||
|  | ij_sass_brace_placement = 0 | ||||||
|  | ij_sass_enforce_quotes_on_format = false | ||||||
|  | ij_sass_hex_color_long_format = false | ||||||
|  | ij_sass_hex_color_lower_case = false | ||||||
|  | ij_sass_hex_color_short_format = false | ||||||
|  | ij_sass_hex_color_upper_case = false | ||||||
|  | ij_sass_keep_blank_lines_in_code = 2 | ||||||
|  | ij_sass_keep_indents_on_empty_lines = false | ||||||
|  | ij_sass_keep_single_line_blocks = false | ||||||
|  | ij_sass_properties_order = font, font-family, font-size, font-weight, font-style, font-variant, font-size-adjust, font-stretch, line-height, position, z-index, top, right, bottom, left, display, visibility, float, clear, overflow, overflow-x, overflow-y, clip, zoom, align-content, align-items, align-self, flex, flex-flow, flex-basis, flex-direction, flex-grow, flex-shrink, flex-wrap, justify-content, order, box-sizing, width, min-width, max-width, height, min-height, max-height, margin, margin-top, margin-right, margin-bottom, margin-left, padding, padding-top, padding-right, padding-bottom, padding-left, table-layout, empty-cells, caption-side, border-spacing, border-collapse, list-style, list-style-position, list-style-type, list-style-image, content, quotes, counter-reset, counter-increment, resize, cursor, user-select, nav-index, nav-up, nav-right, nav-down, nav-left, transition, transition-delay, transition-timing-function, transition-duration, transition-property, transform, transform-origin, animation, animation-name, animation-duration, animation-play-state, animation-timing-function, animation-delay, animation-iteration-count, animation-direction, text-align, text-align-last, vertical-align, white-space, text-decoration, text-emphasis, text-emphasis-color, text-emphasis-style, text-emphasis-position, text-indent, text-justify, letter-spacing, word-spacing, text-outline, text-transform, text-wrap, text-overflow, text-overflow-ellipsis, text-overflow-mode, word-wrap, word-break, tab-size, hyphens, pointer-events, opacity, color, border, border-width, border-style, border-color, border-top, border-top-width, border-top-style, border-top-color, border-right, border-right-width, border-right-style, border-right-color, border-bottom, border-bottom-width, border-bottom-style, border-bottom-color, border-left, border-left-width, border-left-style, border-left-color, border-radius, border-top-left-radius, border-top-right-radius, border-bottom-right-radius, border-bottom-left-radius, border-image, border-image-source, border-image-slice, border-image-width, border-image-outset, border-image-repeat, outline, outline-width, outline-style, outline-color, outline-offset, background, background-color, background-image, background-repeat, background-attachment, background-position, background-position-x, background-position-y, background-clip, background-origin, background-size, box-decoration-break, box-shadow, text-shadow | ||||||
|  | ij_sass_space_after_colon = true | ||||||
|  | ij_sass_space_before_opening_brace = true | ||||||
|  | ij_sass_use_double_quotes = true | ||||||
|  | ij_sass_value_alignment = 0 | ||||||
|  |  | ||||||
|  | [*.scss] | ||||||
|  | indent_size = 2 | ||||||
|  | ij_scss_align_closing_brace_with_properties = false | ||||||
|  | ij_scss_blank_lines_around_nested_selector = 1 | ||||||
|  | ij_scss_blank_lines_between_blocks = 1 | ||||||
|  | ij_scss_brace_placement = 0 | ||||||
|  | ij_scss_enforce_quotes_on_format = false | ||||||
|  | ij_scss_hex_color_long_format = false | ||||||
|  | ij_scss_hex_color_lower_case = false | ||||||
|  | ij_scss_hex_color_short_format = false | ||||||
|  | ij_scss_hex_color_upper_case = false | ||||||
|  | ij_scss_keep_blank_lines_in_code = 2 | ||||||
|  | ij_scss_keep_indents_on_empty_lines = false | ||||||
|  | ij_scss_keep_single_line_blocks = false | ||||||
|  | ij_scss_properties_order = font, font-family, font-size, font-weight, font-style, font-variant, font-size-adjust, font-stretch, line-height, position, z-index, top, right, bottom, left, display, visibility, float, clear, overflow, overflow-x, overflow-y, clip, zoom, align-content, align-items, align-self, flex, flex-flow, flex-basis, flex-direction, flex-grow, flex-shrink, flex-wrap, justify-content, order, box-sizing, width, min-width, max-width, height, min-height, max-height, margin, margin-top, margin-right, margin-bottom, margin-left, padding, padding-top, padding-right, padding-bottom, padding-left, table-layout, empty-cells, caption-side, border-spacing, border-collapse, list-style, list-style-position, list-style-type, list-style-image, content, quotes, counter-reset, counter-increment, resize, cursor, user-select, nav-index, nav-up, nav-right, nav-down, nav-left, transition, transition-delay, transition-timing-function, transition-duration, transition-property, transform, transform-origin, animation, animation-name, animation-duration, animation-play-state, animation-timing-function, animation-delay, animation-iteration-count, animation-direction, text-align, text-align-last, vertical-align, white-space, text-decoration, text-emphasis, text-emphasis-color, text-emphasis-style, text-emphasis-position, text-indent, text-justify, letter-spacing, word-spacing, text-outline, text-transform, text-wrap, text-overflow, text-overflow-ellipsis, text-overflow-mode, word-wrap, word-break, tab-size, hyphens, pointer-events, opacity, color, border, border-width, border-style, border-color, border-top, border-top-width, border-top-style, border-top-color, border-right, border-right-width, border-right-style, border-right-color, border-bottom, border-bottom-width, border-bottom-style, border-bottom-color, border-left, border-left-width, border-left-style, border-left-color, border-radius, border-top-left-radius, border-top-right-radius, border-bottom-right-radius, border-bottom-left-radius, border-image, border-image-source, border-image-slice, border-image-width, border-image-outset, border-image-repeat, outline, outline-width, outline-style, outline-color, outline-offset, background, background-color, background-image, background-repeat, background-attachment, background-position, background-position-x, background-position-y, background-clip, background-origin, background-size, box-decoration-break, box-shadow, text-shadow | ||||||
|  | ij_scss_space_after_colon = true | ||||||
|  | ij_scss_space_before_opening_brace = true | ||||||
|  | ij_scss_use_double_quotes = true | ||||||
|  | ij_scss_value_alignment = 0 | ||||||
|  |  | ||||||
| [.editorconfig] | [.editorconfig] | ||||||
| ij_editorconfig_align_group_field_declarations = false | ij_editorconfig_align_group_field_declarations = false | ||||||
| ij_editorconfig_space_after_colon = false | ij_editorconfig_space_after_colon = false | ||||||
| @@ -257,6 +342,548 @@ ij_editorconfig_space_before_colon = false | |||||||
| ij_editorconfig_space_before_comma = false | ij_editorconfig_space_before_comma = false | ||||||
| ij_editorconfig_spaces_around_assignment_operators = true | ij_editorconfig_spaces_around_assignment_operators = true | ||||||
|  |  | ||||||
|  | [{*.ant, *.fxml, *.jhm, *.jnlp, *.jrxml, *.pom, *.rng, *.tld, *.wsdl, *.xml, *.xsd, *.xsl, *.xslt, *.xul}] | ||||||
|  | ij_xml_align_attributes = true | ||||||
|  | ij_xml_align_text = false | ||||||
|  | ij_xml_attribute_wrap = normal | ||||||
|  | ij_xml_block_comment_at_first_column = true | ||||||
|  | ij_xml_keep_blank_lines = 2 | ||||||
|  | ij_xml_keep_indents_on_empty_lines = false | ||||||
|  | ij_xml_keep_line_breaks = true | ||||||
|  | ij_xml_keep_line_breaks_in_text = true | ||||||
|  | ij_xml_keep_whitespaces = false | ||||||
|  | ij_xml_keep_whitespaces_around_cdata = preserve | ||||||
|  | ij_xml_keep_whitespaces_inside_cdata = false | ||||||
|  | ij_xml_line_comment_at_first_column = true | ||||||
|  | ij_xml_space_after_tag_name = false | ||||||
|  | ij_xml_space_around_equals_in_attribute = false | ||||||
|  | ij_xml_space_inside_empty_tag = false | ||||||
|  | ij_xml_text_wrap = normal | ||||||
|  |  | ||||||
|  | [{*.ats, *.ts}] | ||||||
|  | ij_continuation_indent_size = 4 | ||||||
|  | ij_typescript_align_imports = false | ||||||
|  | ij_typescript_align_multiline_array_initializer_expression = false | ||||||
|  | ij_typescript_align_multiline_binary_operation = false | ||||||
|  | ij_typescript_align_multiline_chained_methods = false | ||||||
|  | ij_typescript_align_multiline_extends_list = false | ||||||
|  | ij_typescript_align_multiline_for = true | ||||||
|  | ij_typescript_align_multiline_parameters = true | ||||||
|  | ij_typescript_align_multiline_parameters_in_calls = false | ||||||
|  | ij_typescript_align_multiline_ternary_operation = false | ||||||
|  | ij_typescript_align_object_properties = 0 | ||||||
|  | ij_typescript_align_union_types = false | ||||||
|  | ij_typescript_align_var_statements = 0 | ||||||
|  | ij_typescript_array_initializer_new_line_after_left_brace = false | ||||||
|  | ij_typescript_array_initializer_right_brace_on_new_line = false | ||||||
|  | ij_typescript_array_initializer_wrap = off | ||||||
|  | ij_typescript_assignment_wrap = off | ||||||
|  | ij_typescript_binary_operation_sign_on_next_line = false | ||||||
|  | ij_typescript_binary_operation_wrap = off | ||||||
|  | ij_typescript_blacklist_imports = rxjs/Rx, node_modules/**, **/node_modules/**, @angular/material, @angular/material/typings/** | ||||||
|  | ij_typescript_blank_lines_after_imports = 1 | ||||||
|  | ij_typescript_blank_lines_around_class = 1 | ||||||
|  | ij_typescript_blank_lines_around_field = 0 | ||||||
|  | ij_typescript_blank_lines_around_field_in_interface = 0 | ||||||
|  | ij_typescript_blank_lines_around_function = 1 | ||||||
|  | ij_typescript_blank_lines_around_method = 1 | ||||||
|  | ij_typescript_blank_lines_around_method_in_interface = 1 | ||||||
|  | ij_typescript_block_brace_style = end_of_line | ||||||
|  | ij_typescript_call_parameters_new_line_after_left_paren = false | ||||||
|  | ij_typescript_call_parameters_right_paren_on_new_line = false | ||||||
|  | ij_typescript_call_parameters_wrap = off | ||||||
|  | ij_typescript_catch_on_new_line = false | ||||||
|  | ij_typescript_chained_call_dot_on_new_line = true | ||||||
|  | ij_typescript_class_brace_style = end_of_line | ||||||
|  | ij_typescript_comma_on_new_line = false | ||||||
|  | ij_typescript_do_while_brace_force = never | ||||||
|  | ij_typescript_else_on_new_line = false | ||||||
|  | ij_typescript_enforce_trailing_comma = keep | ||||||
|  | ij_typescript_extends_keyword_wrap = off | ||||||
|  | ij_typescript_extends_list_wrap = off | ||||||
|  | ij_typescript_field_prefix = _ | ||||||
|  | ij_typescript_file_name_style = relaxed | ||||||
|  | ij_typescript_finally_on_new_line = false | ||||||
|  | ij_typescript_for_brace_force = never | ||||||
|  | ij_typescript_for_statement_new_line_after_left_paren = false | ||||||
|  | ij_typescript_for_statement_right_paren_on_new_line = false | ||||||
|  | ij_typescript_for_statement_wrap = off | ||||||
|  | ij_typescript_force_quote_style = false | ||||||
|  | ij_typescript_force_semicolon_style = false | ||||||
|  | ij_typescript_function_expression_brace_style = end_of_line | ||||||
|  | ij_typescript_if_brace_force = never | ||||||
|  | ij_typescript_import_merge_members = global | ||||||
|  | ij_typescript_import_prefer_absolute_path = global | ||||||
|  | ij_typescript_import_sort_members = true | ||||||
|  | ij_typescript_import_sort_module_name = false | ||||||
|  | ij_typescript_import_use_node_resolution = true | ||||||
|  | ij_typescript_imports_wrap = on_every_item | ||||||
|  | ij_typescript_indent_case_from_switch = true | ||||||
|  | ij_typescript_indent_chained_calls = true | ||||||
|  | ij_typescript_indent_package_children = 0 | ||||||
|  | ij_typescript_jsdoc_include_types = false | ||||||
|  | ij_typescript_jsx_attribute_value = braces | ||||||
|  | ij_typescript_keep_blank_lines_in_code = 2 | ||||||
|  | ij_typescript_keep_first_column_comment = true | ||||||
|  | ij_typescript_keep_indents_on_empty_lines = false | ||||||
|  | ij_typescript_keep_line_breaks = true | ||||||
|  | ij_typescript_keep_simple_blocks_in_one_line = false | ||||||
|  | ij_typescript_keep_simple_methods_in_one_line = false | ||||||
|  | ij_typescript_line_comment_add_space = true | ||||||
|  | ij_typescript_line_comment_at_first_column = false | ||||||
|  | ij_typescript_method_brace_style = end_of_line | ||||||
|  | ij_typescript_method_call_chain_wrap = off | ||||||
|  | ij_typescript_method_parameters_new_line_after_left_paren = false | ||||||
|  | ij_typescript_method_parameters_right_paren_on_new_line = false | ||||||
|  | ij_typescript_method_parameters_wrap = off | ||||||
|  | ij_typescript_object_literal_wrap = on_every_item | ||||||
|  | ij_typescript_parentheses_expression_new_line_after_left_paren = false | ||||||
|  | ij_typescript_parentheses_expression_right_paren_on_new_line = false | ||||||
|  | ij_typescript_place_assignment_sign_on_next_line = false | ||||||
|  | ij_typescript_prefer_as_type_cast = false | ||||||
|  | ij_typescript_prefer_explicit_types_function_expression_returns = false | ||||||
|  | ij_typescript_prefer_explicit_types_function_returns = false | ||||||
|  | ij_typescript_prefer_explicit_types_vars_fields = false | ||||||
|  | ij_typescript_prefer_parameters_wrap = false | ||||||
|  | ij_typescript_reformat_c_style_comments = false | ||||||
|  | ij_typescript_space_after_colon = true | ||||||
|  | ij_typescript_space_after_comma = true | ||||||
|  | ij_typescript_space_after_dots_in_rest_parameter = false | ||||||
|  | ij_typescript_space_after_generator_mult = true | ||||||
|  | ij_typescript_space_after_property_colon = true | ||||||
|  | ij_typescript_space_after_quest = true | ||||||
|  | ij_typescript_space_after_type_colon = true | ||||||
|  | ij_typescript_space_after_unary_not = false | ||||||
|  | ij_typescript_space_before_async_arrow_lparen = true | ||||||
|  | ij_typescript_space_before_catch_keyword = true | ||||||
|  | ij_typescript_space_before_catch_left_brace = true | ||||||
|  | ij_typescript_space_before_catch_parentheses = true | ||||||
|  | ij_typescript_space_before_class_lbrace = true | ||||||
|  | ij_typescript_space_before_class_left_brace = true | ||||||
|  | ij_typescript_space_before_colon = true | ||||||
|  | ij_typescript_space_before_comma = false | ||||||
|  | ij_typescript_space_before_do_left_brace = true | ||||||
|  | ij_typescript_space_before_else_keyword = true | ||||||
|  | ij_typescript_space_before_else_left_brace = true | ||||||
|  | ij_typescript_space_before_finally_keyword = true | ||||||
|  | ij_typescript_space_before_finally_left_brace = true | ||||||
|  | ij_typescript_space_before_for_left_brace = true | ||||||
|  | ij_typescript_space_before_for_parentheses = true | ||||||
|  | ij_typescript_space_before_for_semicolon = false | ||||||
|  | ij_typescript_space_before_function_left_parenth = true | ||||||
|  | ij_typescript_space_before_generator_mult = false | ||||||
|  | ij_typescript_space_before_if_left_brace = true | ||||||
|  | ij_typescript_space_before_if_parentheses = true | ||||||
|  | ij_typescript_space_before_method_call_parentheses = false | ||||||
|  | ij_typescript_space_before_method_left_brace = true | ||||||
|  | ij_typescript_space_before_method_parentheses = false | ||||||
|  | ij_typescript_space_before_property_colon = false | ||||||
|  | ij_typescript_space_before_quest = true | ||||||
|  | ij_typescript_space_before_switch_left_brace = true | ||||||
|  | ij_typescript_space_before_switch_parentheses = true | ||||||
|  | ij_typescript_space_before_try_left_brace = true | ||||||
|  | ij_typescript_space_before_type_colon = false | ||||||
|  | ij_typescript_space_before_unary_not = false | ||||||
|  | ij_typescript_space_before_while_keyword = true | ||||||
|  | ij_typescript_space_before_while_left_brace = true | ||||||
|  | ij_typescript_space_before_while_parentheses = true | ||||||
|  | ij_typescript_spaces_around_additive_operators = true | ||||||
|  | ij_typescript_spaces_around_arrow_function_operator = true | ||||||
|  | ij_typescript_spaces_around_assignment_operators = true | ||||||
|  | ij_typescript_spaces_around_bitwise_operators = true | ||||||
|  | ij_typescript_spaces_around_equality_operators = true | ||||||
|  | ij_typescript_spaces_around_logical_operators = true | ||||||
|  | ij_typescript_spaces_around_multiplicative_operators = true | ||||||
|  | ij_typescript_spaces_around_relational_operators = true | ||||||
|  | ij_typescript_spaces_around_shift_operators = true | ||||||
|  | ij_typescript_spaces_around_unary_operator = false | ||||||
|  | ij_typescript_spaces_within_array_initializer_brackets = false | ||||||
|  | ij_typescript_spaces_within_brackets = false | ||||||
|  | ij_typescript_spaces_within_catch_parentheses = false | ||||||
|  | ij_typescript_spaces_within_for_parentheses = false | ||||||
|  | ij_typescript_spaces_within_if_parentheses = false | ||||||
|  | ij_typescript_spaces_within_imports = false | ||||||
|  | ij_typescript_spaces_within_interpolation_expressions = false | ||||||
|  | ij_typescript_spaces_within_method_call_parentheses = false | ||||||
|  | ij_typescript_spaces_within_method_parentheses = false | ||||||
|  | ij_typescript_spaces_within_object_literal_braces = false | ||||||
|  | ij_typescript_spaces_within_object_type_braces = true | ||||||
|  | ij_typescript_spaces_within_parentheses = false | ||||||
|  | ij_typescript_spaces_within_switch_parentheses = false | ||||||
|  | ij_typescript_spaces_within_type_assertion = false | ||||||
|  | ij_typescript_spaces_within_union_types = true | ||||||
|  | ij_typescript_spaces_within_while_parentheses = false | ||||||
|  | ij_typescript_special_else_if_treatment = true | ||||||
|  | ij_typescript_ternary_operation_signs_on_next_line = false | ||||||
|  | ij_typescript_ternary_operation_wrap = off | ||||||
|  | ij_typescript_union_types_wrap = on_every_item | ||||||
|  | ij_typescript_use_chained_calls_group_indents = false | ||||||
|  | ij_typescript_use_double_quotes = true | ||||||
|  | ij_typescript_use_explicit_js_extension = global | ||||||
|  | ij_typescript_use_path_mapping = always | ||||||
|  | ij_typescript_use_public_modifier = false | ||||||
|  | ij_typescript_use_semicolon_after_statement = true | ||||||
|  | ij_typescript_var_declaration_wrap = normal | ||||||
|  | ij_typescript_while_brace_force = never | ||||||
|  | ij_typescript_while_on_new_line = false | ||||||
|  | ij_typescript_wrap_comments = false | ||||||
|  |  | ||||||
|  | [{*.bash, *.sh, *.zsh}] | ||||||
|  | indent_size = 2 | ||||||
|  | tab_width = 2 | ||||||
|  | ij_shell_binary_ops_start_line = false | ||||||
|  | ij_shell_keep_column_alignment_padding = false | ||||||
|  | ij_shell_minify_program = false | ||||||
|  | ij_shell_redirect_followed_by_space = false | ||||||
|  | ij_shell_switch_cases_indented = false | ||||||
|  |  | ||||||
|  | [{*.cjs, *.js}] | ||||||
|  | ij_continuation_indent_size = 4 | ||||||
|  | ij_javascript_align_imports = false | ||||||
|  | ij_javascript_align_multiline_array_initializer_expression = false | ||||||
|  | ij_javascript_align_multiline_binary_operation = false | ||||||
|  | ij_javascript_align_multiline_chained_methods = false | ||||||
|  | ij_javascript_align_multiline_extends_list = false | ||||||
|  | ij_javascript_align_multiline_for = true | ||||||
|  | ij_javascript_align_multiline_parameters = true | ||||||
|  | ij_javascript_align_multiline_parameters_in_calls = false | ||||||
|  | ij_javascript_align_multiline_ternary_operation = false | ||||||
|  | ij_javascript_align_object_properties = 0 | ||||||
|  | ij_javascript_align_union_types = false | ||||||
|  | ij_javascript_align_var_statements = 0 | ||||||
|  | ij_javascript_array_initializer_new_line_after_left_brace = false | ||||||
|  | ij_javascript_array_initializer_right_brace_on_new_line = false | ||||||
|  | ij_javascript_array_initializer_wrap = off | ||||||
|  | ij_javascript_assignment_wrap = off | ||||||
|  | ij_javascript_binary_operation_sign_on_next_line = false | ||||||
|  | ij_javascript_binary_operation_wrap = off | ||||||
|  | ij_javascript_blacklist_imports = rxjs/Rx, node_modules/**, **/node_modules/**, @angular/material, @angular/material/typings/** | ||||||
|  | ij_javascript_blank_lines_after_imports = 1 | ||||||
|  | ij_javascript_blank_lines_around_class = 1 | ||||||
|  | ij_javascript_blank_lines_around_field = 0 | ||||||
|  | ij_javascript_blank_lines_around_function = 1 | ||||||
|  | ij_javascript_blank_lines_around_method = 1 | ||||||
|  | ij_javascript_block_brace_style = end_of_line | ||||||
|  | ij_javascript_call_parameters_new_line_after_left_paren = false | ||||||
|  | ij_javascript_call_parameters_right_paren_on_new_line = false | ||||||
|  | ij_javascript_call_parameters_wrap = off | ||||||
|  | ij_javascript_catch_on_new_line = false | ||||||
|  | ij_javascript_chained_call_dot_on_new_line = true | ||||||
|  | ij_javascript_class_brace_style = end_of_line | ||||||
|  | ij_javascript_comma_on_new_line = false | ||||||
|  | ij_javascript_do_while_brace_force = never | ||||||
|  | ij_javascript_else_on_new_line = false | ||||||
|  | ij_javascript_enforce_trailing_comma = keep | ||||||
|  | ij_javascript_extends_keyword_wrap = off | ||||||
|  | ij_javascript_extends_list_wrap = off | ||||||
|  | ij_javascript_field_prefix = _ | ||||||
|  | ij_javascript_file_name_style = relaxed | ||||||
|  | ij_javascript_finally_on_new_line = false | ||||||
|  | ij_javascript_for_brace_force = never | ||||||
|  | ij_javascript_for_statement_new_line_after_left_paren = false | ||||||
|  | ij_javascript_for_statement_right_paren_on_new_line = false | ||||||
|  | ij_javascript_for_statement_wrap = off | ||||||
|  | ij_javascript_force_quote_style = false | ||||||
|  | ij_javascript_force_semicolon_style = false | ||||||
|  | ij_javascript_function_expression_brace_style = end_of_line | ||||||
|  | ij_javascript_if_brace_force = never | ||||||
|  | ij_javascript_import_merge_members = global | ||||||
|  | ij_javascript_import_prefer_absolute_path = global | ||||||
|  | ij_javascript_import_sort_members = true | ||||||
|  | ij_javascript_import_sort_module_name = false | ||||||
|  | ij_javascript_import_use_node_resolution = true | ||||||
|  | ij_javascript_imports_wrap = on_every_item | ||||||
|  | ij_javascript_indent_case_from_switch = true | ||||||
|  | ij_javascript_indent_chained_calls = true | ||||||
|  | ij_javascript_indent_package_children = 0 | ||||||
|  | ij_javascript_jsx_attribute_value = braces | ||||||
|  | ij_javascript_keep_blank_lines_in_code = 2 | ||||||
|  | ij_javascript_keep_first_column_comment = true | ||||||
|  | ij_javascript_keep_indents_on_empty_lines = false | ||||||
|  | ij_javascript_keep_line_breaks = true | ||||||
|  | ij_javascript_keep_simple_blocks_in_one_line = false | ||||||
|  | ij_javascript_keep_simple_methods_in_one_line = false | ||||||
|  | ij_javascript_line_comment_add_space = true | ||||||
|  | ij_javascript_line_comment_at_first_column = false | ||||||
|  | ij_javascript_method_brace_style = end_of_line | ||||||
|  | ij_javascript_method_call_chain_wrap = off | ||||||
|  | ij_javascript_method_parameters_new_line_after_left_paren = false | ||||||
|  | ij_javascript_method_parameters_right_paren_on_new_line = false | ||||||
|  | ij_javascript_method_parameters_wrap = off | ||||||
|  | ij_javascript_object_literal_wrap = on_every_item | ||||||
|  | ij_javascript_parentheses_expression_new_line_after_left_paren = false | ||||||
|  | ij_javascript_parentheses_expression_right_paren_on_new_line = false | ||||||
|  | ij_javascript_place_assignment_sign_on_next_line = false | ||||||
|  | ij_javascript_prefer_as_type_cast = false | ||||||
|  | ij_javascript_prefer_explicit_types_function_expression_returns = false | ||||||
|  | ij_javascript_prefer_explicit_types_function_returns = false | ||||||
|  | ij_javascript_prefer_explicit_types_vars_fields = false | ||||||
|  | ij_javascript_prefer_parameters_wrap = false | ||||||
|  | ij_javascript_reformat_c_style_comments = false | ||||||
|  | ij_javascript_space_after_colon = true | ||||||
|  | ij_javascript_space_after_comma = true | ||||||
|  | ij_javascript_space_after_dots_in_rest_parameter = false | ||||||
|  | ij_javascript_space_after_generator_mult = true | ||||||
|  | ij_javascript_space_after_property_colon = true | ||||||
|  | ij_javascript_space_after_quest = true | ||||||
|  | ij_javascript_space_after_type_colon = true | ||||||
|  | ij_javascript_space_after_unary_not = false | ||||||
|  | ij_javascript_space_before_async_arrow_lparen = true | ||||||
|  | ij_javascript_space_before_catch_keyword = true | ||||||
|  | ij_javascript_space_before_catch_left_brace = true | ||||||
|  | ij_javascript_space_before_catch_parentheses = true | ||||||
|  | ij_javascript_space_before_class_lbrace = true | ||||||
|  | ij_javascript_space_before_class_left_brace = true | ||||||
|  | ij_javascript_space_before_colon = true | ||||||
|  | ij_javascript_space_before_comma = false | ||||||
|  | ij_javascript_space_before_do_left_brace = true | ||||||
|  | ij_javascript_space_before_else_keyword = true | ||||||
|  | ij_javascript_space_before_else_left_brace = true | ||||||
|  | ij_javascript_space_before_finally_keyword = true | ||||||
|  | ij_javascript_space_before_finally_left_brace = true | ||||||
|  | ij_javascript_space_before_for_left_brace = true | ||||||
|  | ij_javascript_space_before_for_parentheses = true | ||||||
|  | ij_javascript_space_before_for_semicolon = false | ||||||
|  | ij_javascript_space_before_function_left_parenth = true | ||||||
|  | ij_javascript_space_before_generator_mult = false | ||||||
|  | ij_javascript_space_before_if_left_brace = true | ||||||
|  | ij_javascript_space_before_if_parentheses = true | ||||||
|  | ij_javascript_space_before_method_call_parentheses = false | ||||||
|  | ij_javascript_space_before_method_left_brace = true | ||||||
|  | ij_javascript_space_before_method_parentheses = false | ||||||
|  | ij_javascript_space_before_property_colon = false | ||||||
|  | ij_javascript_space_before_quest = true | ||||||
|  | ij_javascript_space_before_switch_left_brace = true | ||||||
|  | ij_javascript_space_before_switch_parentheses = true | ||||||
|  | ij_javascript_space_before_try_left_brace = true | ||||||
|  | ij_javascript_space_before_type_colon = false | ||||||
|  | ij_javascript_space_before_unary_not = false | ||||||
|  | ij_javascript_space_before_while_keyword = true | ||||||
|  | ij_javascript_space_before_while_left_brace = true | ||||||
|  | ij_javascript_space_before_while_parentheses = true | ||||||
|  | ij_javascript_spaces_around_additive_operators = true | ||||||
|  | ij_javascript_spaces_around_arrow_function_operator = true | ||||||
|  | ij_javascript_spaces_around_assignment_operators = true | ||||||
|  | ij_javascript_spaces_around_bitwise_operators = true | ||||||
|  | ij_javascript_spaces_around_equality_operators = true | ||||||
|  | ij_javascript_spaces_around_logical_operators = true | ||||||
|  | ij_javascript_spaces_around_multiplicative_operators = true | ||||||
|  | ij_javascript_spaces_around_relational_operators = true | ||||||
|  | ij_javascript_spaces_around_shift_operators = true | ||||||
|  | ij_javascript_spaces_around_unary_operator = false | ||||||
|  | ij_javascript_spaces_within_array_initializer_brackets = false | ||||||
|  | ij_javascript_spaces_within_brackets = false | ||||||
|  | ij_javascript_spaces_within_catch_parentheses = false | ||||||
|  | ij_javascript_spaces_within_for_parentheses = false | ||||||
|  | ij_javascript_spaces_within_if_parentheses = false | ||||||
|  | ij_javascript_spaces_within_imports = false | ||||||
|  | ij_javascript_spaces_within_interpolation_expressions = false | ||||||
|  | ij_javascript_spaces_within_method_call_parentheses = false | ||||||
|  | ij_javascript_spaces_within_method_parentheses = false | ||||||
|  | ij_javascript_spaces_within_object_literal_braces = false | ||||||
|  | ij_javascript_spaces_within_object_type_braces = true | ||||||
|  | ij_javascript_spaces_within_parentheses = false | ||||||
|  | ij_javascript_spaces_within_switch_parentheses = false | ||||||
|  | ij_javascript_spaces_within_type_assertion = false | ||||||
|  | ij_javascript_spaces_within_union_types = true | ||||||
|  | ij_javascript_spaces_within_while_parentheses = false | ||||||
|  | ij_javascript_special_else_if_treatment = true | ||||||
|  | ij_javascript_ternary_operation_signs_on_next_line = false | ||||||
|  | ij_javascript_ternary_operation_wrap = off | ||||||
|  | ij_javascript_union_types_wrap = on_every_item | ||||||
|  | ij_javascript_use_chained_calls_group_indents = false | ||||||
|  | ij_javascript_use_double_quotes = true | ||||||
|  | ij_javascript_use_explicit_js_extension = global | ||||||
|  | ij_javascript_use_path_mapping = always | ||||||
|  | ij_javascript_use_public_modifier = false | ||||||
|  | ij_javascript_use_semicolon_after_statement = true | ||||||
|  | ij_javascript_var_declaration_wrap = normal | ||||||
|  | ij_javascript_while_brace_force = never | ||||||
|  | ij_javascript_while_on_new_line = false | ||||||
|  | ij_javascript_wrap_comments = false | ||||||
|  |  | ||||||
|  | [{*.ft, *.vm, *.vsl}] | ||||||
|  | ij_vtl_keep_indents_on_empty_lines = false | ||||||
|  |  | ||||||
|  | [{*.gant, *.gradle, *.groovy, *.gy}] | ||||||
|  | ij_groovy_align_group_field_declarations = false | ||||||
|  | ij_groovy_align_multiline_array_initializer_expression = false | ||||||
|  | ij_groovy_align_multiline_assignment = false | ||||||
|  | ij_groovy_align_multiline_binary_operation = false | ||||||
|  | ij_groovy_align_multiline_chained_methods = false | ||||||
|  | ij_groovy_align_multiline_extends_list = false | ||||||
|  | ij_groovy_align_multiline_for = true | ||||||
|  | ij_groovy_align_multiline_list_or_map = true | ||||||
|  | ij_groovy_align_multiline_method_parentheses = false | ||||||
|  | ij_groovy_align_multiline_parameters = true | ||||||
|  | ij_groovy_align_multiline_parameters_in_calls = false | ||||||
|  | ij_groovy_align_multiline_resources = true | ||||||
|  | ij_groovy_align_multiline_ternary_operation = false | ||||||
|  | ij_groovy_align_multiline_throws_list = false | ||||||
|  | ij_groovy_align_named_args_in_map = true | ||||||
|  | ij_groovy_align_throws_keyword = false | ||||||
|  | ij_groovy_array_initializer_new_line_after_left_brace = false | ||||||
|  | ij_groovy_array_initializer_right_brace_on_new_line = false | ||||||
|  | ij_groovy_array_initializer_wrap = off | ||||||
|  | ij_groovy_assert_statement_wrap = off | ||||||
|  | ij_groovy_assignment_wrap = off | ||||||
|  | ij_groovy_binary_operation_wrap = off | ||||||
|  | ij_groovy_blank_lines_after_class_header = 0 | ||||||
|  | ij_groovy_blank_lines_after_imports = 1 | ||||||
|  | ij_groovy_blank_lines_after_package = 1 | ||||||
|  | ij_groovy_blank_lines_around_class = 1 | ||||||
|  | ij_groovy_blank_lines_around_field = 0 | ||||||
|  | ij_groovy_blank_lines_around_field_in_interface = 0 | ||||||
|  | ij_groovy_blank_lines_around_method = 1 | ||||||
|  | ij_groovy_blank_lines_around_method_in_interface = 1 | ||||||
|  | ij_groovy_blank_lines_before_imports = 1 | ||||||
|  | ij_groovy_blank_lines_before_method_body = 0 | ||||||
|  | ij_groovy_blank_lines_before_package = 0 | ||||||
|  | ij_groovy_block_brace_style = end_of_line | ||||||
|  | ij_groovy_block_comment_at_first_column = true | ||||||
|  | ij_groovy_call_parameters_new_line_after_left_paren = false | ||||||
|  | ij_groovy_call_parameters_right_paren_on_new_line = false | ||||||
|  | ij_groovy_call_parameters_wrap = off | ||||||
|  | ij_groovy_catch_on_new_line = false | ||||||
|  | ij_groovy_class_annotation_wrap = split_into_lines | ||||||
|  | ij_groovy_class_brace_style = end_of_line | ||||||
|  | ij_groovy_class_count_to_use_import_on_demand = 5 | ||||||
|  | ij_groovy_do_while_brace_force = never | ||||||
|  | ij_groovy_else_on_new_line = false | ||||||
|  | ij_groovy_enum_constants_wrap = off | ||||||
|  | ij_groovy_extends_keyword_wrap = off | ||||||
|  | ij_groovy_extends_list_wrap = off | ||||||
|  | ij_groovy_field_annotation_wrap = split_into_lines | ||||||
|  | ij_groovy_finally_on_new_line = false | ||||||
|  | ij_groovy_for_brace_force = never | ||||||
|  | ij_groovy_for_statement_new_line_after_left_paren = false | ||||||
|  | ij_groovy_for_statement_right_paren_on_new_line = false | ||||||
|  | ij_groovy_for_statement_wrap = off | ||||||
|  | ij_groovy_if_brace_force = never | ||||||
|  | ij_groovy_import_annotation_wrap = 2 | ||||||
|  | ij_groovy_imports_layout = *, |, javax.**, java.**, |, $* | ||||||
|  | ij_groovy_indent_case_from_switch = true | ||||||
|  | ij_groovy_indent_label_blocks = true | ||||||
|  | ij_groovy_insert_inner_class_imports = false | ||||||
|  | ij_groovy_keep_blank_lines_before_right_brace = 2 | ||||||
|  | ij_groovy_keep_blank_lines_in_code = 2 | ||||||
|  | ij_groovy_keep_blank_lines_in_declarations = 2 | ||||||
|  | ij_groovy_keep_control_statement_in_one_line = true | ||||||
|  | ij_groovy_keep_first_column_comment = true | ||||||
|  | ij_groovy_keep_indents_on_empty_lines = false | ||||||
|  | ij_groovy_keep_line_breaks = true | ||||||
|  | ij_groovy_keep_multiple_expressions_in_one_line = false | ||||||
|  | ij_groovy_keep_simple_blocks_in_one_line = false | ||||||
|  | ij_groovy_keep_simple_classes_in_one_line = true | ||||||
|  | ij_groovy_keep_simple_lambdas_in_one_line = true | ||||||
|  | ij_groovy_keep_simple_methods_in_one_line = true | ||||||
|  | ij_groovy_label_indent_absolute = false | ||||||
|  | ij_groovy_label_indent_size = 0 | ||||||
|  | ij_groovy_lambda_brace_style = end_of_line | ||||||
|  | ij_groovy_layout_static_imports_separately = true | ||||||
|  | ij_groovy_line_comment_add_space = false | ||||||
|  | ij_groovy_line_comment_at_first_column = true | ||||||
|  | ij_groovy_method_annotation_wrap = split_into_lines | ||||||
|  | ij_groovy_method_brace_style = end_of_line | ||||||
|  | ij_groovy_method_call_chain_wrap = off | ||||||
|  | ij_groovy_method_parameters_new_line_after_left_paren = false | ||||||
|  | ij_groovy_method_parameters_right_paren_on_new_line = false | ||||||
|  | ij_groovy_method_parameters_wrap = off | ||||||
|  | ij_groovy_modifier_list_wrap = false | ||||||
|  | ij_groovy_names_count_to_use_import_on_demand = 3 | ||||||
|  | ij_groovy_parameter_annotation_wrap = off | ||||||
|  | ij_groovy_parentheses_expression_new_line_after_left_paren = false | ||||||
|  | ij_groovy_parentheses_expression_right_paren_on_new_line = false | ||||||
|  | ij_groovy_prefer_parameters_wrap = false | ||||||
|  | ij_groovy_resource_list_new_line_after_left_paren = false | ||||||
|  | ij_groovy_resource_list_right_paren_on_new_line = false | ||||||
|  | ij_groovy_resource_list_wrap = off | ||||||
|  | ij_groovy_space_after_assert_separator = true | ||||||
|  | ij_groovy_space_after_colon = true | ||||||
|  | ij_groovy_space_after_comma = true | ||||||
|  | ij_groovy_space_after_comma_in_type_arguments = true | ||||||
|  | ij_groovy_space_after_for_semicolon = true | ||||||
|  | ij_groovy_space_after_quest = true | ||||||
|  | ij_groovy_space_after_type_cast = true | ||||||
|  | ij_groovy_space_before_annotation_parameter_list = false | ||||||
|  | ij_groovy_space_before_array_initializer_left_brace = false | ||||||
|  | ij_groovy_space_before_assert_separator = false | ||||||
|  | ij_groovy_space_before_catch_keyword = true | ||||||
|  | ij_groovy_space_before_catch_left_brace = true | ||||||
|  | ij_groovy_space_before_catch_parentheses = true | ||||||
|  | ij_groovy_space_before_class_left_brace = true | ||||||
|  | ij_groovy_space_before_closure_left_brace = true | ||||||
|  | ij_groovy_space_before_colon = true | ||||||
|  | ij_groovy_space_before_comma = false | ||||||
|  | ij_groovy_space_before_do_left_brace = true | ||||||
|  | ij_groovy_space_before_else_keyword = true | ||||||
|  | ij_groovy_space_before_else_left_brace = true | ||||||
|  | ij_groovy_space_before_finally_keyword = true | ||||||
|  | ij_groovy_space_before_finally_left_brace = true | ||||||
|  | ij_groovy_space_before_for_left_brace = true | ||||||
|  | ij_groovy_space_before_for_parentheses = true | ||||||
|  | ij_groovy_space_before_for_semicolon = false | ||||||
|  | ij_groovy_space_before_if_left_brace = true | ||||||
|  | ij_groovy_space_before_if_parentheses = true | ||||||
|  | ij_groovy_space_before_method_call_parentheses = false | ||||||
|  | ij_groovy_space_before_method_left_brace = true | ||||||
|  | ij_groovy_space_before_method_parentheses = false | ||||||
|  | ij_groovy_space_before_quest = true | ||||||
|  | ij_groovy_space_before_switch_left_brace = true | ||||||
|  | ij_groovy_space_before_switch_parentheses = true | ||||||
|  | ij_groovy_space_before_synchronized_left_brace = true | ||||||
|  | ij_groovy_space_before_synchronized_parentheses = true | ||||||
|  | ij_groovy_space_before_try_left_brace = true | ||||||
|  | ij_groovy_space_before_try_parentheses = true | ||||||
|  | ij_groovy_space_before_while_keyword = true | ||||||
|  | ij_groovy_space_before_while_left_brace = true | ||||||
|  | ij_groovy_space_before_while_parentheses = true | ||||||
|  | ij_groovy_space_in_named_argument = true | ||||||
|  | ij_groovy_space_in_named_argument_before_colon = false | ||||||
|  | ij_groovy_space_within_empty_array_initializer_braces = false | ||||||
|  | ij_groovy_space_within_empty_method_call_parentheses = false | ||||||
|  | ij_groovy_spaces_around_additive_operators = true | ||||||
|  | ij_groovy_spaces_around_assignment_operators = true | ||||||
|  | ij_groovy_spaces_around_bitwise_operators = true | ||||||
|  | ij_groovy_spaces_around_equality_operators = true | ||||||
|  | ij_groovy_spaces_around_lambda_arrow = true | ||||||
|  | ij_groovy_spaces_around_logical_operators = true | ||||||
|  | ij_groovy_spaces_around_multiplicative_operators = true | ||||||
|  | ij_groovy_spaces_around_regex_operators = true | ||||||
|  | ij_groovy_spaces_around_relational_operators = true | ||||||
|  | ij_groovy_spaces_around_shift_operators = true | ||||||
|  | ij_groovy_spaces_within_annotation_parentheses = false | ||||||
|  | ij_groovy_spaces_within_array_initializer_braces = false | ||||||
|  | ij_groovy_spaces_within_braces = true | ||||||
|  | ij_groovy_spaces_within_brackets = false | ||||||
|  | ij_groovy_spaces_within_cast_parentheses = false | ||||||
|  | ij_groovy_spaces_within_catch_parentheses = false | ||||||
|  | ij_groovy_spaces_within_for_parentheses = false | ||||||
|  | ij_groovy_spaces_within_gstring_injection_braces = false | ||||||
|  | ij_groovy_spaces_within_if_parentheses = false | ||||||
|  | ij_groovy_spaces_within_list_or_map = false | ||||||
|  | ij_groovy_spaces_within_method_call_parentheses = false | ||||||
|  | ij_groovy_spaces_within_method_parentheses = false | ||||||
|  | ij_groovy_spaces_within_parentheses = false | ||||||
|  | ij_groovy_spaces_within_switch_parentheses = false | ||||||
|  | ij_groovy_spaces_within_synchronized_parentheses = false | ||||||
|  | ij_groovy_spaces_within_try_parentheses = false | ||||||
|  | ij_groovy_spaces_within_tuple_expression = false | ||||||
|  | ij_groovy_spaces_within_while_parentheses = false | ||||||
|  | ij_groovy_special_else_if_treatment = true | ||||||
|  | ij_groovy_ternary_operation_wrap = off | ||||||
|  | ij_groovy_throws_keyword_wrap = off | ||||||
|  | ij_groovy_throws_list_wrap = off | ||||||
|  | ij_groovy_use_flying_geese_braces = false | ||||||
|  | ij_groovy_use_fq_class_names = false | ||||||
|  | ij_groovy_use_fq_class_names_in_javadoc = true | ||||||
|  | ij_groovy_use_relative_indents = false | ||||||
|  | ij_groovy_use_single_class_imports = true | ||||||
|  | ij_groovy_variable_annotation_wrap = off | ||||||
|  | ij_groovy_while_brace_force = never | ||||||
|  | ij_groovy_while_on_new_line = false | ||||||
|  | ij_groovy_wrap_long_lines = false | ||||||
|  |  | ||||||
| [{*.gradle.kts, *.kt, *.kts, *.main.kts}] | [{*.gradle.kts, *.kt, *.kts, *.main.kts}] | ||||||
| ij_kotlin_align_in_columns_case_branch = false | ij_kotlin_align_in_columns_case_branch = false | ||||||
| ij_kotlin_align_multiline_binary_operation = false | ij_kotlin_align_multiline_binary_operation = false | ||||||
| @@ -336,8 +963,7 @@ ij_kotlin_wrap_elvis_expressions = 1 | |||||||
| ij_kotlin_wrap_expression_body_functions = 0 | ij_kotlin_wrap_expression_body_functions = 0 | ||||||
| ij_kotlin_wrap_first_method_in_call_chain = false | ij_kotlin_wrap_first_method_in_call_chain = false | ||||||
|  |  | ||||||
|  | [{*.har, *.jsb2, *.jsb3, *.json, .babelrc, .eslintrc, .stylelintrc, bowerrc, jest.config, mcmod.info}] | ||||||
| [*.json] |  | ||||||
| indent_size = 2 | indent_size = 2 | ||||||
| ij_json_keep_blank_lines_in_code = 0 | ij_json_keep_blank_lines_in_code = 0 | ||||||
| ij_json_keep_indents_on_empty_lines = false | ij_json_keep_indents_on_empty_lines = false | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
								
							| @@ -1,4 +0,0 @@ | |||||||
| * text=auto |  | ||||||
|  |  | ||||||
| *.java text |  | ||||||
| *.jar binary |  | ||||||
							
								
								
									
										1
									
								
								.github/ISSUE_TEMPLATE/bug_report.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/ISSUE_TEMPLATE/bug_report.yml
									
									
									
									
										vendored
									
									
								
							| @@ -27,7 +27,6 @@ body: | |||||||
|       description: Which server version version you using? If your server version is not listed, it is not supported. Update to a supported version first. |       description: Which server version version you using? If your server version is not listed, it is not supported. Update to a supported version first. | ||||||
|       multiple: false |       multiple: false | ||||||
|       options: |       options: | ||||||
|         - '1.19.3' |  | ||||||
|         - '1.19.2' |         - '1.19.2' | ||||||
|         - '1.19.1' |         - '1.19.1' | ||||||
|         - '1.19' |         - '1.19' | ||||||
|   | |||||||
							
								
								
									
										23
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										23
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,23 +0,0 @@ | |||||||
| name: Build PR |  | ||||||
|  |  | ||||||
| on: [ pull_request ] |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   build_pr: |  | ||||||
|     if: github.repository_owner == 'IntellectualSites' |  | ||||||
|     runs-on: ${{ matrix.os }} |  | ||||||
|     strategy: |  | ||||||
|       matrix: |  | ||||||
|         os: [ ubuntu-latest, windows-latest, macos-latest ] |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout Repository |  | ||||||
|         uses: actions/checkout@v3 |  | ||||||
|       - name: Validate Gradle Wrapper |  | ||||||
|         uses: gradle/wrapper-validation-action@v1 |  | ||||||
|       - name: Setup Java |  | ||||||
|         uses: actions/setup-java@v3 |  | ||||||
|         with: |  | ||||||
|           distribution: temurin |  | ||||||
|           java-version: 17 |  | ||||||
|       - name: Clean Build |  | ||||||
|         run: ./gradlew clean build |  | ||||||
							
								
								
									
										23
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										23
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,18 +1,15 @@ | |||||||
| name: build | name: build | ||||||
|  |  | ||||||
| on: | on: [ pull_request, push ] | ||||||
|   push: |  | ||||||
|     branches: |  | ||||||
|       - v7 |  | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   build: |   build: | ||||||
|     if: github.repository_owner == 'IntellectualSites' |     if: ${{ github.event_name != 'pull_request' || github.repository != github.event.pull_request.head.repo.full_name }} | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout Repository |       - name: Checkout Repository | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
|       - name: Validate Gradle Wrapper |       - name: Validate Gradle Wrapper" | ||||||
|         uses: gradle/wrapper-validation-action@v1 |         uses: gradle/wrapper-validation-action@v1 | ||||||
|       - name: Setup Java |       - name: Setup Java | ||||||
|         uses: actions/setup-java@v3 |         uses: actions/setup-java@v3 | ||||||
| @@ -30,7 +27,7 @@ jobs: | |||||||
|             echo "STATUS=release" >> $GITHUB_ENV |             echo "STATUS=release" >> $GITHUB_ENV | ||||||
|           fi |           fi | ||||||
|       - name: Publish Release |       - name: Publish Release | ||||||
|         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v7'}} |         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v6'}} | ||||||
|         run: ./gradlew publishToSonatype closeAndReleaseSonatypeStagingRepository |         run: ./gradlew publishToSonatype closeAndReleaseSonatypeStagingRepository | ||||||
|         env: |         env: | ||||||
|           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} |           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} | ||||||
| @@ -38,14 +35,13 @@ jobs: | |||||||
|           ORG_GRADLE_PROJECT_signingKey: ${{ secrets.SIGNING_KEY }} |           ORG_GRADLE_PROJECT_signingKey: ${{ secrets.SIGNING_KEY }} | ||||||
|           ORG_GRADLE_PROJECT_signingPassword: ${{ secrets.SIGNING_PASSWORD }} |           ORG_GRADLE_PROJECT_signingPassword: ${{ secrets.SIGNING_PASSWORD }} | ||||||
|       - name: Publish Snapshot |       - name: Publish Snapshot | ||||||
|         if: ${{ runner.os == 'Linux' && env.STATUS != 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v7' }} |         if: ${{ runner.os == 'Linux' && env.STATUS != 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v6' }} | ||||||
|         run: ./gradlew publishToSonatype |         run: ./gradlew publishToSonatype | ||||||
|         env: |         env: | ||||||
|           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} |           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} | ||||||
|           ORG_GRADLE_PROJECT_sonatypePassword: ${{ secrets.SONATYPE_PASSWORD }} |           ORG_GRADLE_PROJECT_sonatypePassword: ${{ secrets.SONATYPE_PASSWORD }} | ||||||
|       - name: Publish core javadoc |       - name: Publish core javadoc | ||||||
|        # if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v7'}} |         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v6'}} | ||||||
|         if: ${{ runner.os == 'Linux' && env.STATUS == 'snapshot' && github.event_name == 'push' && github.ref == 'refs/heads/v7'}} |  | ||||||
|         uses: cpina/github-action-push-to-another-repository@main |         uses: cpina/github-action-push-to-another-repository@main | ||||||
|         env: |         env: | ||||||
|           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} |           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} | ||||||
| @@ -55,10 +51,9 @@ jobs: | |||||||
|           destination-repository-name: 'plotsquared-javadocs' |           destination-repository-name: 'plotsquared-javadocs' | ||||||
|           user-email: ${{ secrets.USER_EMAIL }} |           user-email: ${{ secrets.USER_EMAIL }} | ||||||
|           target-branch: main |           target-branch: main | ||||||
|           target-directory: v7/core |           target-directory: core | ||||||
|       - name: Publish bukkit javadoc |       - name: Publish bukkit javadoc | ||||||
|        # if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v7'}} |         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v6'}} | ||||||
|         if: ${{ runner.os == 'Linux' && env.STATUS == 'snapshot' && github.event_name == 'push' && github.ref == 'refs/heads/v7'}} |  | ||||||
|         uses: cpina/github-action-push-to-another-repository@main |         uses: cpina/github-action-push-to-another-repository@main | ||||||
|         env: |         env: | ||||||
|           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} |           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} | ||||||
| @@ -68,4 +63,4 @@ jobs: | |||||||
|           destination-repository-name: 'plotsquared-javadocs' |           destination-repository-name: 'plotsquared-javadocs' | ||||||
|           user-email: ${{ secrets.USER_EMAIL }} |           user-email: ${{ secrets.USER_EMAIL }} | ||||||
|           target-branch: main |           target-branch: main | ||||||
|           target-directory: v7/bukkit |           target-directory: bukkit | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							| @@ -2,10 +2,10 @@ name: "CodeQL" | |||||||
|  |  | ||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: [ v7 ] |     branches: [ v6 ] | ||||||
|   pull_request: |   pull_request: | ||||||
|     # The branches below must be a subset of the branches above |     # The branches below must be a subset of the branches above | ||||||
|     branches: [ v7 ] |     branches: [ v6 ] | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   analyze: |   analyze: | ||||||
|   | |||||||
| @@ -48,6 +48,7 @@ dependencies { | |||||||
|  |  | ||||||
|     // Our libraries |     // Our libraries | ||||||
|     implementation(libs.arkitektonika) |     implementation(libs.arkitektonika) | ||||||
|  |     implementation(libs.http4j) | ||||||
|     implementation("com.intellectualsites.paster:Paster") |     implementation("com.intellectualsites.paster:Paster") | ||||||
|     implementation("com.intellectualsites.informative-annotations:informative-annotations") |     implementation("com.intellectualsites.informative-annotations:informative-annotations") | ||||||
|  |  | ||||||
| @@ -87,7 +88,7 @@ tasks.named<ShadowJar>("shadowJar") { | |||||||
|     relocate("javax.inject", "com.plotsquared.core.annotation.inject") |     relocate("javax.inject", "com.plotsquared.core.annotation.inject") | ||||||
|     relocate("net.jcip", "com.plotsquared.core.annotations.jcip") |     relocate("net.jcip", "com.plotsquared.core.annotations.jcip") | ||||||
|     relocate("edu.umd.cs.findbugs", "com.plotsquared.core.annotations.findbugs") |     relocate("edu.umd.cs.findbugs", "com.plotsquared.core.annotations.findbugs") | ||||||
|     relocate("com.intellectualsites.annotations", "com.plotsquared.core.annotations.informative") |     relocate("com.intellectualsites.informative-annotations", "com.plotsquared.core.annotation.informative") | ||||||
|  |  | ||||||
|     // Get rid of all the libs which are 100% unused. |     // Get rid of all the libs which are 100% unused. | ||||||
|     minimize() |     minimize() | ||||||
| @@ -97,19 +98,13 @@ tasks.named<ShadowJar>("shadowJar") { | |||||||
|  |  | ||||||
| tasks { | tasks { | ||||||
|     withType<Javadoc> { |     withType<Javadoc> { | ||||||
|         val isRelease = if (rootProject.version.toString().endsWith("-SNAPSHOT")) "TODO" else rootProject.version.toString() |  | ||||||
|         val opt = options as StandardJavadocDocletOptions |         val opt = options as StandardJavadocDocletOptions | ||||||
|         opt.links("https://jd.papermc.io/paper/1.19/") |         opt.links("https://jd.papermc.io/paper/1.18/") | ||||||
|         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-bukkit/" + libs.worldeditBukkit.get().versionConstraint.toString()) |         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-bukkit/" + libs.worldeditBukkit.get().versionConstraint.toString()) | ||||||
|         opt.links("https://intellectualsites.github.io/plotsquared-javadocs/core/") |         opt.links("https://intellectualsites.github.io/plotsquared-javadocs/core/") | ||||||
|         opt.links("https://jd.adventure.kyori.net/api/4.12.0/") |         opt.links("https://jd.adventure.kyori.net/api/4.9.3/") | ||||||
|         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") |         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") | ||||||
|         opt.links("https://checkerframework.org/api/") |         opt.links("https://checkerframework.org/api/") | ||||||
|         opt.isLinkSource = true |  | ||||||
|         opt.bottom(File("$rootDir/javadocfooter.html").readText()) |  | ||||||
|         opt.isUse = true |  | ||||||
|         opt.encoding("UTF-8") |         opt.encoding("UTF-8") | ||||||
|         opt.keyWords() |  | ||||||
|         opt.addStringOption("-since", isRelease) |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -36,6 +36,7 @@ import com.plotsquared.bukkit.listener.ChunkListener; | |||||||
| import com.plotsquared.bukkit.listener.EntityEventListener; | import com.plotsquared.bukkit.listener.EntityEventListener; | ||||||
| import com.plotsquared.bukkit.listener.EntitySpawnListener; | import com.plotsquared.bukkit.listener.EntitySpawnListener; | ||||||
| import com.plotsquared.bukkit.listener.PaperListener; | import com.plotsquared.bukkit.listener.PaperListener; | ||||||
|  | import com.plotsquared.bukkit.listener.PaperListener113; | ||||||
| import com.plotsquared.bukkit.listener.PlayerEventListener; | import com.plotsquared.bukkit.listener.PlayerEventListener; | ||||||
| import com.plotsquared.bukkit.listener.ProjectileEventListener; | import com.plotsquared.bukkit.listener.ProjectileEventListener; | ||||||
| import com.plotsquared.bukkit.listener.ServerListener; | import com.plotsquared.bukkit.listener.ServerListener; | ||||||
| @@ -50,7 +51,6 @@ import com.plotsquared.bukkit.util.BukkitUtil; | |||||||
| import com.plotsquared.bukkit.util.BukkitWorld; | import com.plotsquared.bukkit.util.BukkitWorld; | ||||||
| import com.plotsquared.bukkit.util.SetGenCB; | import com.plotsquared.bukkit.util.SetGenCB; | ||||||
| import com.plotsquared.bukkit.util.UpdateUtility; | import com.plotsquared.bukkit.util.UpdateUtility; | ||||||
| import com.plotsquared.bukkit.util.TranslationUpdateManager; |  | ||||||
| import com.plotsquared.bukkit.util.task.BukkitTaskManager; | import com.plotsquared.bukkit.util.task.BukkitTaskManager; | ||||||
| import com.plotsquared.bukkit.util.task.PaperTimeConverter; | import com.plotsquared.bukkit.util.task.PaperTimeConverter; | ||||||
| import com.plotsquared.bukkit.util.task.SpigotTimeConverter; | import com.plotsquared.bukkit.util.task.SpigotTimeConverter; | ||||||
| @@ -138,7 +138,6 @@ import org.checkerframework.checker.nullness.qual.Nullable; | |||||||
| import org.incendo.serverlib.ServerLib; | import org.incendo.serverlib.ServerLib; | ||||||
|  |  | ||||||
| import java.io.File; | import java.io.File; | ||||||
| import java.io.IOException; |  | ||||||
| import java.lang.reflect.Method; | import java.lang.reflect.Method; | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
| @@ -292,12 +291,6 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                 ); |                 ); | ||||||
|         this.injector.injectMembers(this); |         this.injector.injectMembers(this); | ||||||
|  |  | ||||||
|         try { |  | ||||||
|             this.injector.getInstance(TranslationUpdateManager.class).upgradeTranslationFile(); |  | ||||||
|         } catch (IOException e) { |  | ||||||
|             throw new RuntimeException(e); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         this.serverLocale = Locale.forLanguageTag(Settings.Enabled_Components.DEFAULT_LOCALE); |         this.serverLocale = Locale.forLanguageTag(Settings.Enabled_Components.DEFAULT_LOCALE); | ||||||
|  |  | ||||||
|         if (PremiumVerification.isPremium() && Settings.Enabled_Components.UPDATE_NOTIFICATIONS) { |         if (PremiumVerification.isPremium() && Settings.Enabled_Components.UPDATE_NOTIFICATIONS) { | ||||||
| @@ -363,7 +356,11 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|             getServer().getPluginManager().registerEvents(injector().getInstance(ServerListener.class), this); |             getServer().getPluginManager().registerEvents(injector().getInstance(ServerListener.class), this); | ||||||
|             getServer().getPluginManager().registerEvents(injector().getInstance(EntitySpawnListener.class), this); |             getServer().getPluginManager().registerEvents(injector().getInstance(EntitySpawnListener.class), this); | ||||||
|             if (PaperLib.isPaper() && Settings.Paper_Components.PAPER_LISTENERS) { |             if (PaperLib.isPaper() && Settings.Paper_Components.PAPER_LISTENERS) { | ||||||
|  |                 if (serverVersion()[1] == 13) { | ||||||
|  |                     getServer().getPluginManager().registerEvents(injector().getInstance(PaperListener113.class), this); | ||||||
|  |                 } else { | ||||||
|                     getServer().getPluginManager().registerEvents(injector().getInstance(PaperListener.class), this); |                     getServer().getPluginManager().registerEvents(injector().getInstance(PaperListener.class), this); | ||||||
|  |                 } | ||||||
|             } else { |             } else { | ||||||
|                 getServer().getPluginManager().registerEvents(injector().getInstance(SpigotListener.class), this); |                 getServer().getPluginManager().registerEvents(injector().getInstance(SpigotListener.class), this); | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -24,8 +24,9 @@ import com.plotsquared.core.generator.IndependentPlotGenerator; | |||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.location.UncheckedWorldLocation; | import com.plotsquared.core.location.UncheckedWorldLocation; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
|  | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.plot.world.SinglePlotArea; | import com.plotsquared.core.plot.world.SinglePlotArea; | ||||||
| import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | import com.plotsquared.core.queue.ScopedQueueCoordinator; | ||||||
| import org.bukkit.generator.BlockPopulator; | import org.bukkit.generator.BlockPopulator; | ||||||
| import org.bukkit.generator.LimitedRegion; | import org.bukkit.generator.LimitedRegion; | ||||||
| import org.bukkit.generator.WorldInfo; | import org.bukkit.generator.WorldInfo; | ||||||
| @@ -46,6 +47,17 @@ final class BlockStatePopulator extends BlockPopulator { | |||||||
|         this.plotGenerator = plotGenerator; |         this.plotGenerator = plotGenerator; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @deprecated Use {@link BlockStatePopulator#BlockStatePopulator(IndependentPlotGenerator)} as plotAreManager is unused | ||||||
|  |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "6.9.0") | ||||||
|  |     public BlockStatePopulator( | ||||||
|  |             final @NonNull IndependentPlotGenerator plotGenerator, | ||||||
|  |             final @NonNull PlotAreaManager plotAreaManager | ||||||
|  |     ) { | ||||||
|  |         this.plotGenerator = plotGenerator; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void populate( |     public void populate( | ||||||
|             @NonNull final WorldInfo worldInfo, |             @NonNull final WorldInfo worldInfo, | ||||||
| @@ -68,7 +80,7 @@ final class BlockStatePopulator extends BlockPopulator { | |||||||
|                 worldInfo.getMaxHeight(), |                 worldInfo.getMaxHeight(), | ||||||
|                 (chunkZ << 4) + 15 |                 (chunkZ << 4) + 15 | ||||||
|         ); |         ); | ||||||
|         ZeroedDelegateScopedQueueCoordinator offsetChunkQueue = new ZeroedDelegateScopedQueueCoordinator(wrapped, min, max); |         ScopedQueueCoordinator offsetChunkQueue = new ScopedQueueCoordinator(wrapped, min, max); | ||||||
|         this.plotGenerator.populateChunk(offsetChunkQueue, area); |         this.plotGenerator.populateChunk(offsetChunkQueue, area); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -22,30 +22,20 @@ import com.plotsquared.bukkit.queue.GenChunk; | |||||||
| import com.plotsquared.bukkit.util.BukkitUtil; | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
| import com.plotsquared.bukkit.util.BukkitWorld; | import com.plotsquared.bukkit.util.BukkitWorld; | ||||||
| import com.plotsquared.core.PlotSquared; | import com.plotsquared.core.PlotSquared; | ||||||
| import com.plotsquared.core.generator.ClassicPlotWorld; |  | ||||||
| import com.plotsquared.core.generator.GeneratorWrapper; | import com.plotsquared.core.generator.GeneratorWrapper; | ||||||
| import com.plotsquared.core.generator.IndependentPlotGenerator; | import com.plotsquared.core.generator.IndependentPlotGenerator; | ||||||
| import com.plotsquared.core.generator.SingleWorldGenerator; | import com.plotsquared.core.generator.SingleWorldGenerator; | ||||||
| import com.plotsquared.core.location.ChunkWrapper; | import com.plotsquared.core.location.ChunkWrapper; | ||||||
| import com.plotsquared.core.location.UncheckedWorldLocation; |  | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | import com.plotsquared.core.queue.ScopedQueueCoordinator; | ||||||
| import com.plotsquared.core.util.ChunkManager; | import com.plotsquared.core.util.ChunkManager; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; |  | ||||||
| import com.sk89q.worldedit.math.BlockVector2; | import com.sk89q.worldedit.math.BlockVector2; | ||||||
| import org.apache.logging.log4j.LogManager; |  | ||||||
| import org.apache.logging.log4j.Logger; |  | ||||||
| import org.bukkit.HeightMap; |  | ||||||
| import org.bukkit.World; | import org.bukkit.World; | ||||||
| import org.bukkit.block.Biome; | import org.bukkit.block.Biome; | ||||||
| import org.bukkit.generator.BiomeProvider; |  | ||||||
| import org.bukkit.generator.BlockPopulator; | import org.bukkit.generator.BlockPopulator; | ||||||
| import org.bukkit.generator.ChunkGenerator; | import org.bukkit.generator.ChunkGenerator; | ||||||
| import org.bukkit.generator.WorldInfo; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.jetbrains.annotations.NotNull; |  | ||||||
| import org.jetbrains.annotations.Nullable; |  | ||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| @@ -54,8 +44,6 @@ import java.util.Set; | |||||||
|  |  | ||||||
| public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrapper<ChunkGenerator> { | public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrapper<ChunkGenerator> { | ||||||
|  |  | ||||||
|     private static final Logger LOGGER =  LogManager.getLogger("PlotSquared/" + BukkitPlotGenerator.class.getSimpleName()); |  | ||||||
|  |  | ||||||
|     @SuppressWarnings("unused") |     @SuppressWarnings("unused") | ||||||
|     public final boolean PAPER_ASYNC_SAFE = true; |     public final boolean PAPER_ASYNC_SAFE = true; | ||||||
|  |  | ||||||
| @@ -64,15 +52,9 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|     private final ChunkGenerator platformGenerator; |     private final ChunkGenerator platformGenerator; | ||||||
|     private final boolean full; |     private final boolean full; | ||||||
|     private final String levelName; |     private final String levelName; | ||||||
|     private final boolean useNewGenerationMethods; |  | ||||||
|     private final BiomeProvider biomeProvider; |  | ||||||
|     private List<BlockPopulator> populators; |     private List<BlockPopulator> populators; | ||||||
|     private boolean loaded = false; |     private boolean loaded = false; | ||||||
|  |  | ||||||
|     private PlotArea lastPlotArea; |  | ||||||
|     private int lastChunkX = Integer.MIN_VALUE; |  | ||||||
|     private int lastChunkZ = Integer.MIN_VALUE; |  | ||||||
|  |  | ||||||
|     public BukkitPlotGenerator( |     public BukkitPlotGenerator( | ||||||
|             final @NonNull String name, |             final @NonNull String name, | ||||||
|             final @NonNull IndependentPlotGenerator generator, |             final @NonNull IndependentPlotGenerator generator, | ||||||
| @@ -90,23 +72,18 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|             this.populators.add(new LegacyBlockStatePopulator(this.plotGenerator)); |             this.populators.add(new LegacyBlockStatePopulator(this.plotGenerator)); | ||||||
|         } |         } | ||||||
|         this.full = true; |         this.full = true; | ||||||
|         this.useNewGenerationMethods = PlotSquared.platform().serverVersion()[1] >= 19; |  | ||||||
|         this.biomeProvider = new BukkitPlotBiomeProvider(); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public BukkitPlotGenerator(final String world, final ChunkGenerator cg, final @NonNull PlotAreaManager plotAreaManager) { |     public BukkitPlotGenerator(final String world, final ChunkGenerator cg, final @NonNull PlotAreaManager plotAreaManager) { | ||||||
|         if (cg instanceof BukkitPlotGenerator) { |         if (cg instanceof BukkitPlotGenerator) { | ||||||
|             throw new IllegalArgumentException("ChunkGenerator: " + cg |             throw new IllegalArgumentException("ChunkGenerator: " + cg.getClass().getName() | ||||||
|                     .getClass() |                     + " is already a BukkitPlotGenerator!"); | ||||||
|                     .getName() + " is already a BukkitPlotGenerator!"); |  | ||||||
|         } |         } | ||||||
|         this.plotAreaManager = plotAreaManager; |         this.plotAreaManager = plotAreaManager; | ||||||
|         this.levelName = world; |         this.levelName = world; | ||||||
|         this.full = false; |         this.full = false; | ||||||
|         this.platformGenerator = cg; |         this.platformGenerator = cg; | ||||||
|         this.plotGenerator = new DelegatePlotGenerator(cg, world); |         this.plotGenerator = new DelegatePlotGenerator(cg, world); | ||||||
|         this.useNewGenerationMethods = PlotSquared.platform().serverVersion()[1] >= 19; |  | ||||||
|         this.biomeProvider = null; |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -134,7 +111,7 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|         try { |         try { | ||||||
|             checkLoaded(world); |             checkLoaded(world); | ||||||
|         } catch (Exception e) { |         } catch (Exception e) { | ||||||
|             LOGGER.error("Error attempting to load world into PlotSquared.", e); |             e.printStackTrace(); | ||||||
|         } |         } | ||||||
|         ArrayList<BlockPopulator> toAdd = new ArrayList<>(); |         ArrayList<BlockPopulator> toAdd = new ArrayList<>(); | ||||||
|         List<BlockPopulator> existing = world.getPopulators(); |         List<BlockPopulator> existing = world.getPopulators(); | ||||||
| @@ -151,7 +128,6 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|         return toAdd; |         return toAdd; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     // Extracted to synchronized method for thread-safety, preventing multiple internal world load calls |  | ||||||
|     private synchronized void checkLoaded(@NonNull World world) { |     private synchronized void checkLoaded(@NonNull World world) { | ||||||
|         // Do not attempt to load configurations until WorldEdit has a platform ready. |         // Do not attempt to load configurations until WorldEdit has a platform ready. | ||||||
|         if (!PlotSquared.get().isWeInitialised()) { |         if (!PlotSquared.get().isWeInitialised()) { | ||||||
| @@ -177,7 +153,7 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @SuppressWarnings("deprecation") // Kept for compatibility with <=1.17.1 |     @SuppressWarnings("deprecation") | ||||||
|     private void setSpawnLimits(@NonNull World world, int limit) { |     private void setSpawnLimits(@NonNull World world, int limit) { | ||||||
|         world.setAmbientSpawnLimit(limit); |         world.setAmbientSpawnLimit(limit); | ||||||
|         world.setAnimalSpawnLimit(limit); |         world.setAnimalSpawnLimit(limit); | ||||||
| @@ -186,112 +162,10 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void generateNoise( |  | ||||||
|             @NotNull final WorldInfo worldInfo, |  | ||||||
|             @NotNull final Random random, |  | ||||||
|             final int chunkX, |  | ||||||
|             final int chunkZ, |  | ||||||
|             @NotNull final ChunkData chunkData |  | ||||||
|     ) { |  | ||||||
|         if (this.platformGenerator != this) { |  | ||||||
|             this.platformGenerator.generateNoise(worldInfo, random, chunkX, chunkZ, chunkData); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         int minY = chunkData.getMinHeight(); |  | ||||||
|         int maxY = chunkData.getMaxHeight(); |  | ||||||
|         GenChunk result = new GenChunk(minY, maxY); |  | ||||||
|         // Set the chunk location |  | ||||||
|         result.setChunk(new ChunkWrapper(worldInfo.getName(), chunkX, chunkZ)); |  | ||||||
|         // Set the result data |  | ||||||
|         result.setChunkData(chunkData); |  | ||||||
|         result.result = null; |  | ||||||
|  |  | ||||||
|         // Catch any exceptions (as exceptions usually thrown) |  | ||||||
|         try { |  | ||||||
|             generate(BlockVector2.at(chunkX, chunkZ), worldInfo.getName(), result, false); |  | ||||||
|         } catch (Throwable e) { |  | ||||||
|             LOGGER.error("Error attempting to generate chunk.", e); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public void generateSurface( |  | ||||||
|             @NotNull final WorldInfo worldInfo, |  | ||||||
|             @NotNull final Random random, |  | ||||||
|             final int chunkX, |  | ||||||
|             final int chunkZ, |  | ||||||
|             @NotNull final ChunkData chunkData |  | ||||||
|     ) { |  | ||||||
|         if (platformGenerator != this) { |  | ||||||
|             platformGenerator.generateSurface(worldInfo, random, chunkX, chunkZ, chunkData); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public void generateBedrock( |  | ||||||
|             @NotNull final WorldInfo worldInfo, |  | ||||||
|             @NotNull final Random random, |  | ||||||
|             final int chunkX, |  | ||||||
|             final int chunkZ, |  | ||||||
|             @NotNull final ChunkData chunkData |  | ||||||
|     ) { |  | ||||||
|         if (platformGenerator != this) { |  | ||||||
|             platformGenerator.generateBedrock(worldInfo, random, chunkX, chunkZ, chunkData); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public void generateCaves( |  | ||||||
|             @NotNull final WorldInfo worldInfo, |  | ||||||
|             @NotNull final Random random, |  | ||||||
|             final int chunkX, |  | ||||||
|             final int chunkZ, |  | ||||||
|             @NotNull final ChunkData chunkData |  | ||||||
|     ) { |  | ||||||
|         if (platformGenerator != this) { |  | ||||||
|             platformGenerator.generateCaves(worldInfo, random, chunkX, chunkZ, chunkData); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public @Nullable BiomeProvider getDefaultBiomeProvider(@NotNull final WorldInfo worldInfo) { |  | ||||||
|         if (platformGenerator != this) { |  | ||||||
|             return platformGenerator.getDefaultBiomeProvider(worldInfo); |  | ||||||
|         } |  | ||||||
|         return biomeProvider; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public int getBaseHeight( |  | ||||||
|             @NotNull final WorldInfo worldInfo, |  | ||||||
|             @NotNull final Random random, |  | ||||||
|             final int x, |  | ||||||
|             final int z, |  | ||||||
|             @NotNull final HeightMap heightMap |  | ||||||
|     ) { |  | ||||||
|         PlotArea area = getPlotArea(worldInfo.getName(), x, z); |  | ||||||
|         if (area instanceof ClassicPlotWorld cpw) { |  | ||||||
|             // Default to plot height being the heighest point before decoration (i.e. roads, walls etc.) |  | ||||||
|             return cpw.PLOT_HEIGHT; |  | ||||||
|         } |  | ||||||
|         return super.getBaseHeight(worldInfo, random, x, z, heightMap); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @SuppressWarnings("deprecation") // The entire method is deprecated, but kept for compatibility with <=1.16.2 |  | ||||||
|     @Override |  | ||||||
|     @Deprecated(since = "TODO") |  | ||||||
|     public @NonNull ChunkData generateChunkData( |     public @NonNull ChunkData generateChunkData( | ||||||
|             @NonNull World world, @NonNull Random random, int x, int z, @NonNull BiomeGrid biome |             @NonNull World world, @NonNull Random random, int x, int z, | ||||||
|  |             @NonNull BiomeGrid biome | ||||||
|     ) { |     ) { | ||||||
|         if (useNewGenerationMethods) { |  | ||||||
|             if (this.platformGenerator != this) { |  | ||||||
|                 return this.platformGenerator.generateChunkData(world, random, x, z, biome); |  | ||||||
|             } else { |  | ||||||
|                 // Return super as it will throw an exception caught by the server that will mean this method is no longer used. |  | ||||||
|                 return super.generateChunkData(world, random, x, z, biome); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         int minY = BukkitWorld.getMinWorldHeight(world); |         int minY = BukkitWorld.getMinWorldHeight(world); | ||||||
|         int maxY = BukkitWorld.getMaxWorldHeight(world); |         int maxY = BukkitWorld.getMaxWorldHeight(world); | ||||||
|         GenChunk result = new GenChunk(minY, maxY); |         GenChunk result = new GenChunk(minY, maxY); | ||||||
| @@ -301,6 +175,7 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|                     for (int chunkZ = 0; chunkZ < 16; chunkZ++) { |                     for (int chunkZ = 0; chunkZ < 16; chunkZ++) { | ||||||
|                         for (int y = minY; y < maxY; y++) { |                         for (int y = minY; y < maxY; y++) { | ||||||
|                             biome.setBiome(chunkX, y, chunkZ, Biome.PLAINS); |                             biome.setBiome(chunkX, y, chunkZ, Biome.PLAINS); | ||||||
|  |  | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| @@ -320,32 +195,35 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|             if (this.platformGenerator != this) { |             if (this.platformGenerator != this) { | ||||||
|                 return this.platformGenerator.generateChunkData(world, random, x, z, biome); |                 return this.platformGenerator.generateChunkData(world, random, x, z, biome); | ||||||
|             } else { |             } else { | ||||||
|                 generate(BlockVector2.at(x, z), world.getName(), result, true); |                 generate(BlockVector2.at(x, z), world, result); | ||||||
|             } |             } | ||||||
|         } catch (Throwable e) { |         } catch (Throwable e) { | ||||||
|             LOGGER.error("Error attempting to load world into PlotSquared.", e); |             e.printStackTrace(); | ||||||
|         } |         } | ||||||
|         // Return the result data |         // Return the result data | ||||||
|         return result.getChunkData(); |         return result.getChunkData(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private void generate(BlockVector2 loc, String world, ZeroedDelegateScopedQueueCoordinator result, boolean biomes) { |     private void generate(BlockVector2 loc, World world, ScopedQueueCoordinator result) { | ||||||
|         // Load if improperly loaded |         // Load if improperly loaded | ||||||
|         if (!this.loaded) { |         if (!this.loaded) { | ||||||
|             synchronized (this) { |             checkLoaded(world); | ||||||
|                 PlotSquared.get().loadWorld(world, this); |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
|         // Process the chunk |         // Process the chunk | ||||||
|         if (ChunkManager.preProcessChunk(loc, result)) { |         if (ChunkManager.preProcessChunk(loc, result)) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         PlotArea area = getPlotArea(world, loc.getX(), loc.getZ()); |         PlotArea area = this.plotAreaManager.getPlotArea(world.getName(), null); | ||||||
|  |         if (area == null && (area = this.plotAreaManager.getPlotArea(this.levelName, null)) == null) { | ||||||
|  |             throw new IllegalStateException( | ||||||
|  |                     "Cannot regenerate chunk that does not belong to a plot area." + " Location: " + loc | ||||||
|  |                             + ", world: " + world); | ||||||
|  |         } | ||||||
|         try { |         try { | ||||||
|             this.plotGenerator.generateChunk(result, area, biomes); |             this.plotGenerator.generateChunk(result, area); | ||||||
|         } catch (Throwable e) { |         } catch (Throwable e) { | ||||||
|             // Recover from generator error |             // Recover from generator error | ||||||
|             LOGGER.error("Error attempting to generate chunk.", e); |             e.printStackTrace(); | ||||||
|         } |         } | ||||||
|         ChunkManager.postProcessChunk(loc, result); |         ChunkManager.postProcessChunk(loc, result); | ||||||
|     } |     } | ||||||
| @@ -399,51 +277,4 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|         return this.levelName; |         return this.levelName; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private synchronized PlotArea getPlotArea(String name, int chunkX, int chunkZ) { |  | ||||||
|         // Load if improperly loaded |  | ||||||
|         if (!this.loaded) { |  | ||||||
|             PlotSquared.get().loadWorld(name, this); |  | ||||||
|             // Do not set loaded to true as we want to ensure spawn limits are set when "loading" is actually able to be |  | ||||||
|             // completed properly. |  | ||||||
|         } |  | ||||||
|         if (lastPlotArea != null && name.equals(this.levelName) && chunkX == lastChunkX && chunkZ == lastChunkZ) { |  | ||||||
|             return lastPlotArea; |  | ||||||
|         } |  | ||||||
|         PlotArea area = UncheckedWorldLocation.at(name, chunkX << 4, 0, chunkZ << 4).getPlotArea(); |  | ||||||
|         if (area == null) { |  | ||||||
|             throw new IllegalStateException(String.format("Cannot generate chunk that does not belong to a plot area. World: %s", |  | ||||||
|                     name |  | ||||||
|             )); |  | ||||||
|         } |  | ||||||
|         this.lastChunkX = chunkX; |  | ||||||
|         this.lastChunkZ = chunkZ; |  | ||||||
|         return this.lastPlotArea = area; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Biome provider should never need to be accessed outside of this class. |  | ||||||
|      */ |  | ||||||
|     private final class BukkitPlotBiomeProvider extends BiomeProvider { |  | ||||||
|  |  | ||||||
|         private static final List<Biome> BIOMES; |  | ||||||
|  |  | ||||||
|         static { |  | ||||||
|             ArrayList<Biome> biomes = new ArrayList<>(List.of(Biome.values())); |  | ||||||
|             biomes.remove(Biome.CUSTOM); |  | ||||||
|             BIOMES = List.copyOf(biomes); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         @Override |  | ||||||
|         public @NotNull Biome getBiome(@NotNull final WorldInfo worldInfo, final int x, final int y, final int z) { |  | ||||||
|             PlotArea area = getPlotArea(worldInfo.getName(), x >> 4, z >> 4); |  | ||||||
|             return BukkitAdapter.adapt(plotGenerator.getBiome(area, x, y, z)); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         @Override |  | ||||||
|         public @NotNull List<Biome> getBiomes(@NotNull final WorldInfo worldInfo) { |  | ||||||
|             return BIOMES; // Allow all biomes |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -24,10 +24,9 @@ import com.plotsquared.core.generator.IndependentPlotGenerator; | |||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.PlotId; | import com.plotsquared.core.plot.PlotId; | ||||||
| import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | import com.plotsquared.core.queue.ScopedQueueCoordinator; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import com.sk89q.worldedit.world.biome.BiomeType; |  | ||||||
| import org.bukkit.World; | import org.bukkit.World; | ||||||
| import org.bukkit.block.Biome; | import org.bukkit.block.Biome; | ||||||
| import org.bukkit.generator.BlockPopulator; | import org.bukkit.generator.BlockPopulator; | ||||||
| @@ -50,11 +49,6 @@ final class DelegatePlotGenerator extends IndependentPlotGenerator { | |||||||
|     public void initialize(PlotArea area) { |     public void initialize(PlotArea area) { | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public BiomeType getBiome(final PlotArea settings, final int x, final int y, final int z) { |  | ||||||
|         return null; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public String getName() { |     public String getName() { | ||||||
|         return this.chunkGenerator.getClass().getName(); |         return this.chunkGenerator.getClass().getName(); | ||||||
| @@ -66,7 +60,7 @@ final class DelegatePlotGenerator extends IndependentPlotGenerator { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void generateChunk(final ZeroedDelegateScopedQueueCoordinator result, PlotArea settings, boolean biomes) { |     public void generateChunk(final ScopedQueueCoordinator result, PlotArea settings) { | ||||||
|         World world = BukkitUtil.getWorld(this.world); |         World world = BukkitUtil.getWorld(this.world); | ||||||
|         Location min = result.getMin(); |         Location min = result.getMin(); | ||||||
|         int chunkX = min.getX() >> 4; |         int chunkX = min.getX() >> 4; | ||||||
|   | |||||||
| @@ -26,7 +26,7 @@ import com.plotsquared.core.location.UncheckedWorldLocation; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.world.SinglePlotArea; | import com.plotsquared.core.plot.world.SinglePlotArea; | ||||||
| import com.plotsquared.core.queue.QueueCoordinator; | import com.plotsquared.core.queue.QueueCoordinator; | ||||||
| import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | import com.plotsquared.core.queue.ScopedQueueCoordinator; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitWorld; | import com.sk89q.worldedit.bukkit.BukkitWorld; | ||||||
| import com.sk89q.worldedit.util.SideEffectSet; | import com.sk89q.worldedit.util.SideEffectSet; | ||||||
| import org.bukkit.Chunk; | import org.bukkit.Chunk; | ||||||
| @@ -65,7 +65,7 @@ final class LegacyBlockStatePopulator extends BlockPopulator { | |||||||
|         queue.setChunkObject(source); |         queue.setChunkObject(source); | ||||||
|         Location min = UncheckedWorldLocation.at(world.getName(), chunkMinX, world.getMinHeight(), chunkMinZ); |         Location min = UncheckedWorldLocation.at(world.getName(), chunkMinX, world.getMinHeight(), chunkMinZ); | ||||||
|         Location max = UncheckedWorldLocation.at(world.getName(), chunkMinX + 15, world.getMaxHeight(), chunkMinZ + 15); |         Location max = UncheckedWorldLocation.at(world.getName(), chunkMinX + 15, world.getMaxHeight(), chunkMinZ + 15); | ||||||
|         ZeroedDelegateScopedQueueCoordinator offsetChunkQueue = new ZeroedDelegateScopedQueueCoordinator(queue, min, max); |         ScopedQueueCoordinator offsetChunkQueue = new ScopedQueueCoordinator(queue, min, max); | ||||||
|         this.plotGenerator.populateChunk(offsetChunkQueue, area); |         this.plotGenerator.populateChunk(offsetChunkQueue, area); | ||||||
|         queue.enqueue(); |         queue.enqueue(); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -55,23 +55,22 @@ import com.plotsquared.core.plot.flag.implementations.VineGrowFlag; | |||||||
| import com.plotsquared.core.plot.flag.types.BlockTypeWrapper; | import com.plotsquared.core.plot.flag.types.BlockTypeWrapper; | ||||||
| import com.plotsquared.core.plot.flag.types.BooleanFlag; | import com.plotsquared.core.plot.flag.types.BooleanFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.PlotFlagUtil; | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import com.plotsquared.core.util.task.TaskTime; | import com.plotsquared.core.util.task.TaskTime; | ||||||
| import com.sk89q.worldedit.WorldEdit; | import com.sk89q.worldedit.WorldEdit; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import com.sk89q.worldedit.world.block.BlockType; | import com.sk89q.worldedit.world.block.BlockType; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.bukkit.Bukkit; | import org.bukkit.Bukkit; | ||||||
| import org.bukkit.GameMode; | import org.bukkit.GameMode; | ||||||
| import org.bukkit.Material; | import org.bukkit.Material; | ||||||
|  | import org.bukkit.Tag; | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.block.BlockFace; | import org.bukkit.block.BlockFace; | ||||||
| import org.bukkit.block.BlockState; | import org.bukkit.block.BlockState; | ||||||
| import org.bukkit.block.data.BlockData; | import org.bukkit.block.data.BlockData; | ||||||
| import org.bukkit.block.data.type.Dispenser; |  | ||||||
| import org.bukkit.entity.Entity; | import org.bukkit.entity.Entity; | ||||||
| import org.bukkit.entity.Fireball; | import org.bukkit.entity.Fireball; | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.entity.Player; | ||||||
| @@ -101,6 +100,7 @@ import org.bukkit.event.block.EntityBlockFormEvent; | |||||||
| import org.bukkit.event.block.LeavesDecayEvent; | import org.bukkit.event.block.LeavesDecayEvent; | ||||||
| import org.bukkit.event.block.SpongeAbsorbEvent; | import org.bukkit.event.block.SpongeAbsorbEvent; | ||||||
| import org.bukkit.event.world.StructureGrowEvent; | import org.bukkit.event.world.StructureGrowEvent; | ||||||
|  | import org.bukkit.material.Directional; | ||||||
| import org.bukkit.projectiles.BlockProjectileSource; | import org.bukkit.projectiles.BlockProjectileSource; | ||||||
| import org.bukkit.util.Vector; | import org.bukkit.util.Vector; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| @@ -113,10 +113,6 @@ import java.util.UUID; | |||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
| import java.util.stream.Stream; | import java.util.stream.Stream; | ||||||
|  |  | ||||||
| import static org.bukkit.Tag.CORALS; |  | ||||||
| import static org.bukkit.Tag.CORAL_BLOCKS; |  | ||||||
| import static org.bukkit.Tag.WALL_CORALS; |  | ||||||
|  |  | ||||||
| @SuppressWarnings("unused") | @SuppressWarnings("unused") | ||||||
| public class BlockEventListener implements Listener { | public class BlockEventListener implements Listener { | ||||||
|  |  | ||||||
| @@ -279,23 +275,13 @@ public class BlockEventListener implements Listener { | |||||||
|         if (plot != null) { |         if (plot != null) { | ||||||
|             if (area.notifyIfOutsideBuildArea(pp, location.getY())) { |             if (area.notifyIfOutsideBuildArea(pp, location.getY())) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 pp.sendMessage( |  | ||||||
|                         TranslatableCaption.of("height.height_limit"), |  | ||||||
|                         TagResolver.builder() |  | ||||||
|                                 .tag("minheight", Tag.inserting(Component.text(area.getMinBuildHeight()))) |  | ||||||
|                                 .tag("maxheight", Tag.inserting(Component.text(area.getMaxBuildHeight()))) |  | ||||||
|                                 .build() |  | ||||||
|                 ); |  | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (!plot.hasOwner()) { |             if (!plot.hasOwner()) { | ||||||
|                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_UNOWNED) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
| @@ -309,13 +295,10 @@ public class BlockEventListener implements Listener { | |||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_OTHER)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_OTHER) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     plot.debug(player.getName() + " could not place " + event.getBlock().getType() |                     plot.debug(player.getName() + " could not place " + event.getBlock().getType() | ||||||
| @@ -323,7 +306,7 @@ public class BlockEventListener implements Listener { | |||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |             } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("done.building_restricted") |                             TranslatableCaption.of("done.building_restricted") | ||||||
|                     ); |                     ); | ||||||
| @@ -339,13 +322,10 @@ public class BlockEventListener implements Listener { | |||||||
|                             + " did not fall because of disable-physics = true"); |                             + " did not fall because of disable-physics = true"); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } else if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_ROAD)) { |         } else if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_ROAD)) { | ||||||
|             pp.sendMessage( |             pp.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission_event"), |                     TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                     TagResolver.resolver( |                     Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_ROAD)) | ||||||
|                             "node", |  | ||||||
|                             Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_ROAD) |  | ||||||
|                     ) |  | ||||||
|             ); |             ); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } |         } | ||||||
| @@ -364,30 +344,22 @@ public class BlockEventListener implements Listener { | |||||||
|             BukkitPlayer plotPlayer = BukkitUtil.adapt(player); |             BukkitPlayer plotPlayer = BukkitUtil.adapt(player); | ||||||
|             // == rather than <= as we only care about the "ground level" not being destroyed |             // == rather than <= as we only care about the "ground level" not being destroyed | ||||||
|             if (event.getBlock().getY() == area.getMinGenHeight()) { |             if (event.getBlock().getY() == area.getMinGenHeight()) { | ||||||
|                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_GROUNDLEVEL)) { |                 if (!Permissions | ||||||
|  |                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_GROUNDLEVEL)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_DESTROY_GROUNDLEVEL)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ADMIN_DESTROY_GROUNDLEVEL) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } else if (area.notifyIfOutsideBuildArea(plotPlayer, location.getY())) { |             } else if (area.notifyIfOutsideBuildArea(plotPlayer, location.getY())) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 plotPlayer.sendMessage( |  | ||||||
|                         TranslatableCaption.of("height.height_limit"), |  | ||||||
|                         TagResolver.builder() |  | ||||||
|                                 .tag("minheight", Tag.inserting(Component.text(area.getMinBuildHeight()))) |  | ||||||
|                                 .tag("maxheight", Tag.inserting(Component.text(area.getMaxBuildHeight()))) |  | ||||||
|                                 .build() |  | ||||||
|                 ); |  | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (!plot.hasOwner()) { |             if (!plot.hasOwner()) { | ||||||
|                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_UNOWNED, true)) { |                 if (!Permissions | ||||||
|  |                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_UNOWNED, true)) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
| @@ -401,19 +373,17 @@ public class BlockEventListener implements Listener { | |||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { |                 if (Permissions | ||||||
|  |                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 plotPlayer.sendMessage( |                 plotPlayer.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_DESTROY_OTHER)) | ||||||
|                                 "node", |  | ||||||
|                                 Tag.inserting(Permission.PERMISSION_ADMIN_DESTROY_OTHER) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |             } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("done.building_restricted") |                             TranslatableCaption.of("done.building_restricted") | ||||||
|                     ); |                     ); | ||||||
| @@ -424,7 +394,7 @@ public class BlockEventListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         BukkitPlayer pp = BukkitUtil.adapt(player); |         BukkitPlayer pp = BukkitUtil.adapt(player); | ||||||
|         if (pp.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_ROAD)) { |         if (Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_DESTROY_ROAD)) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (this.worldEdit != null && pp.getAttribute("worldedit")) { |         if (this.worldEdit != null && pp.getAttribute("worldedit")) { | ||||||
| @@ -435,10 +405,7 @@ public class BlockEventListener implements Listener { | |||||||
|         } |         } | ||||||
|         pp.sendMessage( |         pp.sendMessage( | ||||||
|                 TranslatableCaption.of("permission.no_permission_event"), |                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                 TagResolver.resolver( |                 Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_DESTROY_ROAD)) | ||||||
|                         "node", |  | ||||||
|                         Tag.inserting(Permission.PERMISSION_ADMIN_DESTROY_ROAD) |  | ||||||
|                 ) |  | ||||||
|         ); |         ); | ||||||
|         event.setCancelled(true); |         event.setCancelled(true); | ||||||
|     } |     } | ||||||
| @@ -512,18 +479,18 @@ public class BlockEventListener implements Listener { | |||||||
|                     BukkitPlayer plotPlayer = BukkitUtil.adapt(player); |                     BukkitPlayer plotPlayer = BukkitUtil.adapt(player); | ||||||
|                     if (plot != null) { |                     if (plot != null) { | ||||||
|                         if (!plot.hasOwner()) { |                         if (!plot.hasOwner()) { | ||||||
|                             if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_UNOWNED)) { |                             if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_INTERACT_UNOWNED)) { | ||||||
|                                 return; |                                 return; | ||||||
|                             } |                             } | ||||||
|                         } else if (!plot.isAdded(plotPlayer.getUUID())) { |                         } else if (!plot.isAdded(plotPlayer.getUUID())) { | ||||||
|                             if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { |                             if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { | ||||||
|                                 return; |                                 return; | ||||||
|                             } |                             } | ||||||
|                         } else { |                         } else { | ||||||
|                             return; |                             return; | ||||||
|                         } |                         } | ||||||
|                     } else { |                     } else { | ||||||
|                         if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_ROAD)) { |                         if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_INTERACT_ROAD)) { | ||||||
|                             return; |                             return; | ||||||
|                         } |                         } | ||||||
|                         if (this.worldEdit != null && plotPlayer.getAttribute("worldedit")) { |                         if (this.worldEdit != null && plotPlayer.getAttribute("worldedit")) { | ||||||
| @@ -571,14 +538,14 @@ public class BlockEventListener implements Listener { | |||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (org.bukkit.Tag.SNOW.isTagged(event.getNewState().getType())) { |         if (SNOW.contains(event.getNewState().getType())) { | ||||||
|             if (!plot.getFlag(SnowFormFlag.class)) { |             if (!plot.getFlag(SnowFormFlag.class)) { | ||||||
|                 plot.debug("Snow could not form because snow-form = false"); |                 plot.debug("Snow could not form because snow-form = false"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (org.bukkit.Tag.ICE.isTagged(event.getNewState().getType())) { |         if (Tag.ICE.isTagged(event.getNewState().getType())) { | ||||||
|             if (!plot.getFlag(IceFormFlag.class)) { |             if (!plot.getFlag(IceFormFlag.class)) { | ||||||
|                 plot.debug("Ice could not form because ice-form = false"); |                 plot.debug("Ice could not form because ice-form = false"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
| @@ -603,9 +570,9 @@ public class BlockEventListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Class<? extends BooleanFlag<?>> flag; |         Class<? extends BooleanFlag<?>> flag; | ||||||
|         if (org.bukkit.Tag.SNOW.isTagged(event.getNewState().getType())) { |         if (SNOW.contains(event.getNewState().getType())) { | ||||||
|             flag = SnowFormFlag.class; |             flag = SnowFormFlag.class; | ||||||
|         } else if (org.bukkit.Tag.ICE.isTagged(event.getNewState().getType())) { |         } else if (Tag.ICE.isTagged(event.getNewState().getType())) { | ||||||
|             flag = IceFormFlag.class; |             flag = IceFormFlag.class; | ||||||
|         } else { |         } else { | ||||||
|             return; |             return; | ||||||
| @@ -668,7 +635,8 @@ public class BlockEventListener implements Listener { | |||||||
|             } |             } | ||||||
|             if (!plot.hasOwner()) { |             if (!plot.hasOwner()) { | ||||||
|                 BukkitPlayer plotPlayer = BukkitUtil.adapt(player); |                 BukkitPlayer plotPlayer = BukkitUtil.adapt(player); | ||||||
|                 if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_UNOWNED)) { |                 if (Permissions | ||||||
|  |                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_UNOWNED)) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
| @@ -680,7 +648,8 @@ public class BlockEventListener implements Listener { | |||||||
|                 Block block = event.getBlock(); |                 Block block = event.getBlock(); | ||||||
|                 if (destroy |                 if (destroy | ||||||
|                         .contains(BlockTypeWrapper.get(BukkitAdapter.asBlockType(block.getType()))) |                         .contains(BlockTypeWrapper.get(BukkitAdapter.asBlockType(block.getType()))) | ||||||
|                         || plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { |                         || Permissions | ||||||
|  |                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 plot.debug(player.getName() + " could not break " + block.getType() |                 plot.debug(player.getName() + " could not break " + block.getType() | ||||||
| @@ -691,7 +660,7 @@ public class BlockEventListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         BukkitPlayer plotPlayer = BukkitUtil.adapt(player); |         BukkitPlayer plotPlayer = BukkitUtil.adapt(player); | ||||||
|         if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_ROAD)) { |         if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_ROAD)) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         event.setCancelled(true); |         event.setCancelled(true); | ||||||
| @@ -711,14 +680,14 @@ public class BlockEventListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Material blockType = block.getType(); |         Material blockType = block.getType(); | ||||||
|         if (org.bukkit.Tag.ICE.isTagged(blockType)) { |         if (Tag.ICE.isTagged(blockType)) { | ||||||
|             if (!plot.getFlag(IceMeltFlag.class)) { |             if (!plot.getFlag(IceMeltFlag.class)) { | ||||||
|                 plot.debug("Ice could not melt because ice-melt = false"); |                 plot.debug("Ice could not melt because ice-melt = false"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (org.bukkit.Tag.SNOW.isTagged(blockType)) { |         if (SNOW.contains(blockType)) { | ||||||
|             if (!plot.getFlag(SnowMeltFlag.class)) { |             if (!plot.getFlag(SnowMeltFlag.class)) { | ||||||
|                 plot.debug("Snow could not melt because snow-melt = false"); |                 plot.debug("Snow could not melt because snow-melt = false"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
| @@ -732,7 +701,7 @@ public class BlockEventListener implements Listener { | |||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (CORAL_BLOCKS.isTagged(blockType) || CORALS.isTagged(blockType) || WALL_CORALS.isTagged(blockType)) { |         if (Tag.CORAL_BLOCKS.isTagged(blockType) || Tag.CORALS.isTagged(blockType) || Tag.WALL_CORALS.isTagged(blockType)) { | ||||||
|             if (!plot.getFlag(CoralDryFlag.class)) { |             if (!plot.getFlag(CoralDryFlag.class)) { | ||||||
|                 plot.debug("Coral could not dry because coral-dry = false"); |                 plot.debug("Coral could not dry because coral-dry = false"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
| @@ -785,10 +754,7 @@ public class BlockEventListener implements Listener { | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         if (toPlot != null) { |         if (toPlot != null) { | ||||||
|             if (!toArea.contains(fromLocation.getX(), fromLocation.getZ()) || !Objects.equals( |             if (!toArea.contains(fromLocation.getX(), fromLocation.getZ()) || !Objects.equals(toPlot, toArea.getOwnedPlot(fromLocation))) { | ||||||
|                     toPlot, |  | ||||||
|                     toArea.getOwnedPlot(fromLocation) |  | ||||||
|             )) { |  | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| @@ -804,10 +770,7 @@ public class BlockEventListener implements Listener { | |||||||
|                 toPlot.debug("Liquid could not flow because liquid-flow = disabled"); |                 toPlot.debug("Liquid could not flow because liquid-flow = disabled"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (!toArea.contains(fromLocation.getX(), fromLocation.getZ()) || !Objects.equals( |         } else if (!toArea.contains(fromLocation.getX(), fromLocation.getZ()) || !Objects.equals(null, toArea.getOwnedPlot(fromLocation))) { | ||||||
|                 null, |  | ||||||
|                 toArea.getOwnedPlot(fromLocation) |  | ||||||
|         )) { |  | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } else if (event.getBlock().isLiquid()) { |         } else if (event.getBlock().isLiquid()) { | ||||||
|             final org.bukkit.Location location = event.getBlock().getLocation(); |             final org.bukkit.Location location = event.getBlock().getLocation(); | ||||||
| @@ -963,9 +926,6 @@ public class BlockEventListener implements Listener { | |||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|     public void onBlockDispense(BlockDispenseEvent event) { |     public void onBlockDispense(BlockDispenseEvent event) { | ||||||
|         if (!this.plotAreaManager.hasPlotArea(event.getBlock().getWorld().getName())) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         Material type = event.getItem().getType(); |         Material type = event.getItem().getType(); | ||||||
|         switch (type.toString()) { |         switch (type.toString()) { | ||||||
|             case "SHULKER_BOX", "WHITE_SHULKER_BOX", "ORANGE_SHULKER_BOX", "MAGENTA_SHULKER_BOX", "LIGHT_BLUE_SHULKER_BOX", |             case "SHULKER_BOX", "WHITE_SHULKER_BOX", "ORANGE_SHULKER_BOX", "MAGENTA_SHULKER_BOX", "LIGHT_BLUE_SHULKER_BOX", | ||||||
| @@ -977,7 +937,7 @@ public class BlockEventListener implements Listener { | |||||||
|                 if (event.getBlock().getType() == Material.DROPPER) { |                 if (event.getBlock().getType() == Material.DROPPER) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 BlockFace targetFace = ((Dispenser) event.getBlock().getBlockData()).getFacing(); |                 BlockFace targetFace = ((Directional) event.getBlock().getState().getData()).getFacing(); | ||||||
|                 Location location = BukkitUtil.adapt(event.getBlock().getRelative(targetFace).getLocation()); |                 Location location = BukkitUtil.adapt(event.getBlock().getRelative(targetFace).getLocation()); | ||||||
|                 if (location.isPlotRoad()) { |                 if (location.isPlotRoad()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
| @@ -1125,39 +1085,32 @@ public class BlockEventListener implements Listener { | |||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, BlockIgnitionFlag.class, true) && !pp.hasPermission( |                 if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, BlockIgnitionFlag.class, true) && !Permissions.hasPermission( | ||||||
|  |                         pp, | ||||||
|                         Permission.PERMISSION_ADMIN_BUILD_ROAD |                         Permission.PERMISSION_ADMIN_BUILD_ROAD | ||||||
|                 )) { |                 )) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_ROAD)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_ROAD) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|             } else if (!plot.hasOwner()) { |             } else if (!plot.hasOwner()) { | ||||||
|                 if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, BlockIgnitionFlag.class, true) && !pp.hasPermission( |                 if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, BlockIgnitionFlag.class, true) && !Permissions.hasPermission( | ||||||
|  |                         pp, | ||||||
|                         Permission.PERMISSION_ADMIN_BUILD_UNOWNED |                         Permission.PERMISSION_ADMIN_BUILD_UNOWNED | ||||||
|                 )) { |                 )) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_UNOWNED) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|             } else if (!plot.isAdded(pp.getUUID())) { |             } else if (!plot.isAdded(pp.getUUID())) { | ||||||
|                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_OTHER)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_OTHER) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
| @@ -1278,34 +1231,22 @@ public class BlockEventListener implements Listener { | |||||||
|  |  | ||||||
|         for (final BlockState state : event.getReplacedBlockStates()) { |         for (final BlockState state : event.getReplacedBlockStates()) { | ||||||
|             Location currentLocation = BukkitUtil.adapt(state.getLocation()); |             Location currentLocation = BukkitUtil.adapt(state.getLocation()); | ||||||
|             if (!pp.hasPermission( |             if (!Permissions.hasPermission( | ||||||
|  |                     pp, | ||||||
|                     Permission.PERMISSION_ADMIN_BUILD_ROAD |                     Permission.PERMISSION_ADMIN_BUILD_ROAD | ||||||
|             ) && !(Objects.equals(currentLocation.getPlot(), plot))) { |             ) && !(Objects.equals(currentLocation.getPlot(), plot))) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_ROAD)) |                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_ROAD)) | ||||||
|                 ); |                 ); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|             if (pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_HEIGHT_LIMIT)) { |             if (area.notifyIfOutsideBuildArea(pp, currentLocation.getY())) { | ||||||
|                 continue; |                 event.setCancelled(true); | ||||||
|             } |                 break; | ||||||
|             if (currentLocation.getY() >= area.getMaxBuildHeight() || currentLocation.getY() < area.getMinBuildHeight()) { |  | ||||||
|                 pp.sendMessage( |  | ||||||
|                         TranslatableCaption.of("height.height_limit"), |  | ||||||
|                         TagResolver.builder() |  | ||||||
|                                 .tag("minheight", Tag.inserting(Component.text(area.getMinBuildHeight()))) |  | ||||||
|                                 .tag("maxheight", Tag.inserting(Component.text(area.getMaxBuildHeight()))) |  | ||||||
|                                 .build() |  | ||||||
|                 ); |  | ||||||
|                 if (area.notifyIfOutsideBuildArea(pp, currentLocation.getY())) { |  | ||||||
|                     event.setCancelled(true); |  | ||||||
|                     break; |  | ||||||
|                 } |  | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -37,6 +37,7 @@ import com.plotsquared.core.plot.flag.implementations.ExplosionFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.InvincibleFlag; | import com.plotsquared.core.plot.flag.implementations.InvincibleFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.PlotFlagUtil; | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import com.sk89q.worldedit.world.block.BlockType; | import com.sk89q.worldedit.world.block.BlockType; | ||||||
| @@ -370,13 +371,14 @@ public class EntityEventListener implements Listener { | |||||||
|             if (shooter instanceof Player) { |             if (shooter instanceof Player) { | ||||||
|                 PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); |                 PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); | ||||||
|                 if (plot == null) { |                 if (plot == null) { | ||||||
|                     if (!pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { |                     if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { | ||||||
|                         entity.remove(); |                         entity.remove(); | ||||||
|                         event.setCancelled(true); |                         event.setCancelled(true); | ||||||
|                     } |                     } | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 if (plot.isAdded(pp.getUUID()) || pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { |                 if (plot.isAdded(pp.getUUID()) || Permissions | ||||||
|  |                         .hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|   | |||||||
| @@ -25,6 +25,7 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.flag.implementations.ForcefieldFlag; | import com.plotsquared.core.plot.flag.implementations.ForcefieldFlag; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.entity.Player; | ||||||
| import org.bukkit.util.Vector; | import org.bukkit.util.Vector; | ||||||
|  |  | ||||||
| @@ -108,7 +109,8 @@ public class ForceFieldListener { | |||||||
|             if (plot.isAdded(uuid)) { |             if (plot.isAdded(uuid)) { | ||||||
|                 Set<PlotPlayer<?>> players = getNearbyPlayers(player, plot); |                 Set<PlotPlayer<?>> players = getNearbyPlayers(player, plot); | ||||||
|                 for (PlotPlayer<?> oPlayer : players) { |                 for (PlotPlayer<?> oPlayer : players) { | ||||||
|                     if (!oPlayer.hasPermission(Permission.PERMISSION_ADMIN_ENTRY_FORCEFIELD)) { |                     if (!Permissions | ||||||
|  |                             .hasPermission(oPlayer, Permission.PERMISSION_ADMIN_ENTRY_FORCEFIELD)) { | ||||||
|                         ((BukkitPlayer) oPlayer).player |                         ((BukkitPlayer) oPlayer).player | ||||||
|                                 .setVelocity(calculateVelocity(plotPlayer, oPlayer)); |                                 .setVelocity(calculateVelocity(plotPlayer, oPlayer)); | ||||||
|                     } |                     } | ||||||
| @@ -118,7 +120,8 @@ public class ForceFieldListener { | |||||||
|                 if (oPlayer == null) { |                 if (oPlayer == null) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_ENTRY_FORCEFIELD)) { |                 if (!Permissions | ||||||
|  |                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_ENTRY_FORCEFIELD)) { | ||||||
|                     player.setVelocity(calculateVelocity(oPlayer, plotPlayer)); |                     player.setVelocity(calculateVelocity(oPlayer, plotPlayer)); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -43,10 +43,9 @@ import com.plotsquared.core.plot.flag.implementations.DoneFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | ||||||
| import com.plotsquared.core.plot.flag.types.BooleanFlag; | import com.plotsquared.core.plot.flag.types.BooleanFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import net.kyori.adventure.text.Component; | import com.plotsquared.core.util.Permissions; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import com.plotsquared.core.util.PlotFlagUtil; | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
|  | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import org.bukkit.Chunk; | import org.bukkit.Chunk; | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.block.TileState; | import org.bukkit.block.TileState; | ||||||
| @@ -304,7 +303,7 @@ public class PaperListener implements Listener { | |||||||
|             final PlotPlayer<?> plotPlayer = BukkitUtil.adapt(event.getPlayer()); |             final PlotPlayer<?> plotPlayer = BukkitUtil.adapt(event.getPlayer()); | ||||||
|             plotPlayer.sendMessage( |             plotPlayer.sendMessage( | ||||||
|                     TranslatableCaption.of("errors.tile_entity_cap_reached"), |                     TranslatableCaption.of("errors.tile_entity_cap_reached"), | ||||||
|                     TagResolver.resolver("amount", Tag.inserting(Component.text(Settings.Chunk_Processor.MAX_TILES))) |                     Template.of("amount", String.valueOf(Settings.Chunk_Processor.MAX_TILES)) | ||||||
|             ); |             ); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|             event.setBuild(false); |             event.setBuild(false); | ||||||
| @@ -336,40 +335,32 @@ public class PaperListener implements Listener { | |||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|  |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true) && !pp.hasPermission( |             if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true) && !Permissions.hasPermission( | ||||||
|  |                     pp, | ||||||
|                     Permission.PERMISSION_ADMIN_PROJECTILE_ROAD |                     Permission.PERMISSION_ADMIN_PROJECTILE_ROAD | ||||||
|             )) { |             )) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_PROJECTILE_ROAD)) | ||||||
|                                 "node", |  | ||||||
|                                 Tag.inserting(Permission.PERMISSION_ADMIN_PROJECTILE_ROAD) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (!plot.hasOwner()) { |         } else if (!plot.hasOwner()) { | ||||||
|             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { |             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) | ||||||
|                                 "node", |  | ||||||
|                                 Tag.inserting(Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (!plot.isAdded(pp.getUUID())) { |         } else if (!plot.isAdded(pp.getUUID())) { | ||||||
|             if (!plot.getFlag(ProjectilesFlag.class)) { |             if (!plot.getFlag(ProjectilesFlag.class)) { | ||||||
|                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     entity.remove(); |                     entity.remove(); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|   | |||||||
| @@ -0,0 +1,91 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU General Public License as published by | ||||||
|  |  * the Free Software Foundation, either version 3 of the License, or | ||||||
|  |  * (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU General Public License | ||||||
|  |  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.bukkit.listener; | ||||||
|  |  | ||||||
|  | import com.google.inject.Inject; | ||||||
|  | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
|  | import com.plotsquared.core.configuration.Settings; | ||||||
|  | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
|  | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.PlotArea; | ||||||
|  | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
|  | import net.kyori.adventure.text.minimessage.Template; | ||||||
|  | import org.bukkit.block.Banner; | ||||||
|  | import org.bukkit.block.Beacon; | ||||||
|  | import org.bukkit.block.BlockState; | ||||||
|  | import org.bukkit.block.CommandBlock; | ||||||
|  | import org.bukkit.block.Comparator; | ||||||
|  | import org.bukkit.block.Conduit; | ||||||
|  | import org.bukkit.block.Container; | ||||||
|  | import org.bukkit.block.CreatureSpawner; | ||||||
|  | import org.bukkit.block.DaylightDetector; | ||||||
|  | import org.bukkit.block.EnchantingTable; | ||||||
|  | import org.bukkit.block.EndGateway; | ||||||
|  | import org.bukkit.block.EnderChest; | ||||||
|  | import org.bukkit.block.Jukebox; | ||||||
|  | import org.bukkit.block.Sign; | ||||||
|  | import org.bukkit.block.Skull; | ||||||
|  | import org.bukkit.block.Structure; | ||||||
|  | import org.bukkit.block.data.type.Bed; | ||||||
|  | import org.bukkit.event.EventHandler; | ||||||
|  | import org.bukkit.event.block.BlockPlaceEvent; | ||||||
|  | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @deprecated P2 effectively no longer supports 1.13 | ||||||
|  |  */ | ||||||
|  | @Deprecated(forRemoval = true, since = "6.10.4") | ||||||
|  | public class PaperListener113 extends PaperListener { | ||||||
|  |  | ||||||
|  |     @Inject | ||||||
|  |     public PaperListener113(@NonNull PlotAreaManager plotAreaManager) { | ||||||
|  |         super(plotAreaManager); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @EventHandler | ||||||
|  |     public void onBlockPlace(BlockPlaceEvent event) { | ||||||
|  |         if (!Settings.Paper_Components.TILE_ENTITY_CHECK || !Settings.Enabled_Components.CHUNK_PROCESSOR) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         BlockState state = event.getBlock().getState(false); | ||||||
|  |         if (!(state instanceof Banner || state instanceof Beacon || state instanceof Bed || state instanceof CommandBlock | ||||||
|  |                 || state instanceof Comparator || state instanceof Conduit || state instanceof Container || state instanceof CreatureSpawner | ||||||
|  |                 || state instanceof DaylightDetector || state instanceof EnchantingTable || state instanceof EnderChest || state instanceof EndGateway | ||||||
|  |                 || state instanceof Jukebox || state instanceof Sign || state instanceof Skull || state instanceof Structure)) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         final Location location = BukkitUtil.adapt(event.getBlock().getLocation()); | ||||||
|  |         final PlotArea plotArea = location.getPlotArea(); | ||||||
|  |         if (plotArea == null) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         final int tileEntityCount = event.getBlock().getChunk().getTileEntities(false).length; | ||||||
|  |         if (tileEntityCount >= Settings.Chunk_Processor.MAX_TILES) { | ||||||
|  |             final PlotPlayer<?> plotPlayer = BukkitUtil.adapt(event.getPlayer()); | ||||||
|  |             plotPlayer.sendMessage( | ||||||
|  |                     TranslatableCaption.of("errors.tile_entity_cap_reached"), | ||||||
|  |                     Template.of("amount", String.valueOf(Settings.Chunk_Processor.MAX_TILES)) | ||||||
|  |             ); | ||||||
|  |             event.setCancelled(true); | ||||||
|  |             event.setBuild(false); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -67,6 +67,7 @@ import com.plotsquared.core.plot.flag.implementations.VillagerInteractFlag; | |||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.PlotFlagUtil; | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import com.plotsquared.core.util.PremiumVerification; | import com.plotsquared.core.util.PremiumVerification; | ||||||
| import com.plotsquared.core.util.entity.EntityCategories; | import com.plotsquared.core.util.entity.EntityCategories; | ||||||
| @@ -77,13 +78,12 @@ import com.sk89q.worldedit.bukkit.BukkitAdapter; | |||||||
| import com.sk89q.worldedit.world.block.BlockType; | import com.sk89q.worldedit.world.block.BlockType; | ||||||
| import io.papermc.lib.PaperLib; | import io.papermc.lib.PaperLib; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.MiniMessage; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.standard.StandardTags; |  | ||||||
| import org.bukkit.Bukkit; | import org.bukkit.Bukkit; | ||||||
|  | import org.bukkit.ChatColor; | ||||||
| import org.bukkit.FluidCollisionMode; | import org.bukkit.FluidCollisionMode; | ||||||
| import org.bukkit.Material; | import org.bukkit.Material; | ||||||
|  | import org.bukkit.Tag; | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.block.BlockFace; | import org.bukkit.block.BlockFace; | ||||||
| import org.bukkit.block.BlockState; | import org.bukkit.block.BlockState; | ||||||
| @@ -275,10 +275,8 @@ public class PlayerEventListener implements Listener { | |||||||
|         switch (parts[0]) { |         switch (parts[0]) { | ||||||
|             case "up": |             case "up": | ||||||
|             case "worldedit:up": |             case "worldedit:up": | ||||||
|                 if (plot == null || (!plot.isAdded(plotPlayer.getUUID()) && !plotPlayer.hasPermission( |                 if (plot == null || (!plot.isAdded(plotPlayer.getUUID()) && !Permissions | ||||||
|                         Permission.PERMISSION_ADMIN_BUILD_OTHER, |                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_OTHER, true))) { | ||||||
|                         true |  | ||||||
|                 ))) { |  | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
| @@ -293,7 +291,7 @@ public class PlayerEventListener implements Listener { | |||||||
|         if (blockedCommands.isEmpty()) { |         if (blockedCommands.isEmpty()) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_BLOCKED_CMDS)) { |         if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_INTERACT_BLOCKED_CMDS)) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         // When using namespaced commands, we're not interested in the namespace |         // When using namespaced commands, we're not interested in the namespace | ||||||
| @@ -312,7 +310,7 @@ public class PlayerEventListener implements Listener { | |||||||
|                 } else { |                 } else { | ||||||
|                     perm = "plots.admin.command.blocked-cmds.road"; |                     perm = "plots.admin.command.blocked-cmds.road"; | ||||||
|                 } |                 } | ||||||
|                 if (!plotPlayer.hasPermission(perm)) { |                 if (!Permissions.hasPermission(plotPlayer, perm)) { | ||||||
|                     plotPlayer.sendMessage(TranslatableCaption.of("blockedcmds.command_blocked")); |                     plotPlayer.sendMessage(TranslatableCaption.of("blockedcmds.command_blocked")); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
| @@ -399,15 +397,11 @@ public class PlayerEventListener implements Listener { | |||||||
|                 && PremiumVerification.isPremium() && UpdateUtility.hasUpdate) { |                 && PremiumVerification.isPremium() && UpdateUtility.hasUpdate) { | ||||||
|             Caption boundary = TranslatableCaption.of("update.update_boundary"); |             Caption boundary = TranslatableCaption.of("update.update_boundary"); | ||||||
|             Caption updateNotification = TranslatableCaption.of("update.update_notification"); |             Caption updateNotification = TranslatableCaption.of("update.update_notification"); | ||||||
|  |             Template internalVersion = Template.of("p2version", UpdateUtility.internalVersion.versionString()); | ||||||
|  |             Template spigotVersion = Template.of("spigotversion", UpdateUtility.spigotVersion); | ||||||
|  |             Template downloadUrl = Template.of("downloadurl", "https://www.spigotmc.org/resources/77506/updates"); | ||||||
|             pp.sendMessage(boundary); |             pp.sendMessage(boundary); | ||||||
|             pp.sendMessage( |             pp.sendMessage(updateNotification, internalVersion, spigotVersion, downloadUrl); | ||||||
|                     updateNotification, |  | ||||||
|                     TagResolver.builder() |  | ||||||
|                             .tag("p2version", Tag.inserting(Component.text(UpdateUtility.internalVersion.versionString()))) |  | ||||||
|                             .tag("spigotversion", Tag.inserting(Component.text(UpdateUtility.spigotVersion))) |  | ||||||
|                             .tag("downloadurl", Tag.preProcessParsed("https://www.spigotmc.org/resources/77506/updates")) |  | ||||||
|                             .build() |  | ||||||
|             ); |  | ||||||
|             pp.sendMessage(boundary); |             pp.sendMessage(boundary); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -459,7 +453,7 @@ public class PlayerEventListener implements Listener { | |||||||
|                             .equals(BukkitUtil.adaptComplete(to)))) { |                             .equals(BukkitUtil.adaptComplete(to)))) { | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("deny.no_enter"), |                                 TranslatableCaption.of("deny.no_enter"), | ||||||
|                                 TagResolver.resolver("plot", Tag.inserting(Component.text(plot.toString()))) |                                 Template.of("plot", plot.toString()) | ||||||
|                         ); |                         ); | ||||||
|                         event.setCancelled(true); |                         event.setCancelled(true); | ||||||
|                     } |                     } | ||||||
| @@ -575,10 +569,7 @@ public class PlayerEventListener implements Listener { | |||||||
|                     if (lastPlot != null && !plotListener.plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse(false)) { |                     if (lastPlot != null && !plotListener.plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse(false)) { | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_EXIT_DENIED)) | ||||||
|                                         "node", |  | ||||||
|                                         Tag.inserting(Permission.PERMISSION_ADMIN_EXIT_DENIED) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         this.tmpTeleport = false; |                         this.tmpTeleport = false; | ||||||
|                         if (lastPlot.equals(BukkitUtil.adapt(from).getPlot())) { |                         if (lastPlot.equals(BukkitUtil.adapt(from).getPlot())) { | ||||||
| @@ -596,7 +587,7 @@ public class PlayerEventListener implements Listener { | |||||||
|             } else if (!plotListener.plotEntry(pp, now) && this.tmpTeleport) { |             } else if (!plotListener.plotEntry(pp, now) && this.tmpTeleport) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("deny.no_enter"), |                         TranslatableCaption.of("deny.no_enter"), | ||||||
|                         TagResolver.resolver("plot", Tag.inserting(Component.text(now.toString()))) |                         Template.of("plot", now.toString()) | ||||||
|                 ); |                 ); | ||||||
|                 this.tmpTeleport = false; |                 this.tmpTeleport = false; | ||||||
|                 to.setX(from.getBlockX()); |                 to.setX(from.getBlockX()); | ||||||
| @@ -609,7 +600,7 @@ public class PlayerEventListener implements Listener { | |||||||
|             int border = area.getBorder(); |             int border = area.getBorder(); | ||||||
|             int x1; |             int x1; | ||||||
|             if (x2 > border && this.tmpTeleport) { |             if (x2 > border && this.tmpTeleport) { | ||||||
|                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { | ||||||
|                     to.setX(border - 1); |                     to.setX(border - 1); | ||||||
|                     this.tmpTeleport = false; |                     this.tmpTeleport = false; | ||||||
|                     player.teleport(event.getTo()); |                     player.teleport(event.getTo()); | ||||||
| @@ -619,7 +610,7 @@ public class PlayerEventListener implements Listener { | |||||||
|                     pp.sendMessage(TranslatableCaption.of("border.bypass.exited")); |                     pp.sendMessage(TranslatableCaption.of("border.bypass.exited")); | ||||||
|                 } |                 } | ||||||
|             } else if (x2 < -border && this.tmpTeleport) { |             } else if (x2 < -border && this.tmpTeleport) { | ||||||
|                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { | ||||||
|                     to.setX(-border + 1); |                     to.setX(-border + 1); | ||||||
|                     this.tmpTeleport = false; |                     this.tmpTeleport = false; | ||||||
|                     player.teleport(event.getTo()); |                     player.teleport(event.getTo()); | ||||||
| @@ -629,7 +620,7 @@ public class PlayerEventListener implements Listener { | |||||||
|                     pp.sendMessage(TranslatableCaption.of("border.bypass.exited")); |                     pp.sendMessage(TranslatableCaption.of("border.bypass.exited")); | ||||||
|                 } |                 } | ||||||
|             } else if (((x1 = MathMan.roundInt(from.getX())) >= border && x2 <= border) || (x1 <= -border && x2 >= -border)) { |             } else if (((x1 = MathMan.roundInt(from.getX())) >= border && x2 <= border) || (x1 <= -border && x2 >= -border)) { | ||||||
|                 if (pp.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { |                 if (Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { | ||||||
|                     pp.sendMessage(TranslatableCaption.of("border.bypass.entered")); |                     pp.sendMessage(TranslatableCaption.of("border.bypass.entered")); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -668,10 +659,7 @@ public class PlayerEventListener implements Listener { | |||||||
|                     if (lastPlot != null && !plotListener.plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse(false)) { |                     if (lastPlot != null && !plotListener.plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse(false)) { | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_EXIT_DENIED)) | ||||||
|                                         "node", |  | ||||||
|                                         Tag.inserting(Permission.PERMISSION_ADMIN_EXIT_DENIED) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         this.tmpTeleport = false; |                         this.tmpTeleport = false; | ||||||
|                         if (lastPlot.equals(BukkitUtil.adapt(from).getPlot())) { |                         if (lastPlot.equals(BukkitUtil.adapt(from).getPlot())) { | ||||||
| @@ -689,7 +677,7 @@ public class PlayerEventListener implements Listener { | |||||||
|             } else if (!plotListener.plotEntry(pp, plot) && this.tmpTeleport) { |             } else if (!plotListener.plotEntry(pp, plot) && this.tmpTeleport) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("deny.no_enter"), |                         TranslatableCaption.of("deny.no_enter"), | ||||||
|                         TagResolver.resolver("plot", Tag.inserting(Component.text(plot.toString()))) |                         Template.of("plot", plot.toString()) | ||||||
|                 ); |                 ); | ||||||
|                 this.tmpTeleport = false; |                 this.tmpTeleport = false; | ||||||
|                 player.teleport(from); |                 player.teleport(from); | ||||||
| @@ -703,7 +691,7 @@ public class PlayerEventListener implements Listener { | |||||||
|             int border = area.getBorder(); |             int border = area.getBorder(); | ||||||
|             int z1; |             int z1; | ||||||
|             if (z2 > border && this.tmpTeleport) { |             if (z2 > border && this.tmpTeleport) { | ||||||
|                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { | ||||||
|                     to.setZ(border - 1); |                     to.setZ(border - 1); | ||||||
|                     this.tmpTeleport = false; |                     this.tmpTeleport = false; | ||||||
|                     player.teleport(event.getTo()); |                     player.teleport(event.getTo()); | ||||||
| @@ -713,7 +701,7 @@ public class PlayerEventListener implements Listener { | |||||||
|                     pp.sendMessage(TranslatableCaption.of("border.bypass.exited")); |                     pp.sendMessage(TranslatableCaption.of("border.bypass.exited")); | ||||||
|                 } |                 } | ||||||
|             } else if (z2 < -border && this.tmpTeleport) { |             } else if (z2 < -border && this.tmpTeleport) { | ||||||
|                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { | ||||||
|                     to.setZ(-border + 1); |                     to.setZ(-border + 1); | ||||||
|                     this.tmpTeleport = false; |                     this.tmpTeleport = false; | ||||||
|                     player.teleport(event.getTo()); |                     player.teleport(event.getTo()); | ||||||
| @@ -723,7 +711,7 @@ public class PlayerEventListener implements Listener { | |||||||
|                     pp.sendMessage(TranslatableCaption.of("border.bypass.exited")); |                     pp.sendMessage(TranslatableCaption.of("border.bypass.exited")); | ||||||
|                 } |                 } | ||||||
|             } else if (((z1 = MathMan.roundInt(from.getZ())) >= border && z2 <= border) || (z1 <= -border && z2 >= -border)) { |             } else if (((z1 = MathMan.roundInt(from.getZ())) >= border && z2 <= border) || (z1 <= -border && z2 >= -border)) { | ||||||
|                 if (pp.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { |                 if (Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { | ||||||
|                     pp.sendMessage(TranslatableCaption.of("border.bypass.entered")); |                     pp.sendMessage(TranslatableCaption.of("border.bypass.entered")); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -750,7 +738,8 @@ public class PlayerEventListener implements Listener { | |||||||
|                 || area.isForcingPlotChat())) { |                 || area.isForcingPlotChat())) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (plot.isDenied(plotPlayer.getUUID()) && !plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_CHAT_BYPASS)) { |         if (plot.isDenied(plotPlayer.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_CHAT_BYPASS)) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         event.setCancelled(true); |         event.setCancelled(true); | ||||||
| @@ -773,34 +762,46 @@ public class PlayerEventListener implements Listener { | |||||||
|         PlotId id = plot.getId(); |         PlotId id = plot.getId(); | ||||||
|         String worldName = plot.getWorldName(); |         String worldName = plot.getWorldName(); | ||||||
|         Caption msg = TranslatableCaption.of("chat.plot_chat_format"); |         Caption msg = TranslatableCaption.of("chat.plot_chat_format"); | ||||||
|         TagResolver.Builder builder = TagResolver.builder(); |         Template msgTemplate; | ||||||
|         builder.tag("world", Tag.inserting(Component.text(worldName))); |         Template worldNameTemplate = Template.of("world", worldName); | ||||||
|         builder.tag("plot_id", Tag.inserting(Component.text(id.toString()))); |         Template plotTemplate = Template.of("plot_id", id.toString()); | ||||||
|         builder.tag("sender", Tag.inserting(Component.text(sender))); |         Template senderTemplate = Template.of("sender", sender); | ||||||
|  |         // If we do/don't want colour, we need to be careful about how to go about it, as players could attempt either <gold></gold> or &6 etc. | ||||||
|  |         // In both cases, we want to use a Component Template to ensure that the player cannot use any placeholders in their message on purpose | ||||||
|  |         //  or accidentally, as component templates are done at the end. We also need to deserialize from legacy color codes to a Component if | ||||||
|  |         //  allowing colour. | ||||||
|         if (plotPlayer.hasPermission("plots.chat.color")) { |         if (plotPlayer.hasPermission("plots.chat.color")) { | ||||||
|             builder.tag("msg", Tag.inserting(MiniMessage.miniMessage().deserialize( |             msgTemplate = Template | ||||||
|                     message, |                     .of( | ||||||
|                     TagResolver.resolver(StandardTags.color(), StandardTags.gradient(), |                             "msg", | ||||||
|                             StandardTags.rainbow(), StandardTags.decorations() |                             BukkitUtil.LEGACY_COMPONENT_SERIALIZER.deserialize(ChatColor.translateAlternateColorCodes( | ||||||
|                     ) |                                     '&', | ||||||
|             ))); |                                     message | ||||||
|  |                             )) | ||||||
|  |                     ); | ||||||
|         } else { |         } else { | ||||||
|             builder.tag("msg", Tag.inserting(Component.text(message))); |             msgTemplate = Template.of("msg", BukkitUtil.MINI_MESSAGE.deserialize( | ||||||
|  |                     ChatColor.stripColor(BukkitUtil.LEGACY_COMPONENT_SERIALIZER.serialize(Component.text(message))))); | ||||||
|         } |         } | ||||||
|         for (PlotPlayer<?> receiver : plotRecipients) { |         for (PlotPlayer<?> receiver : plotRecipients) { | ||||||
|             receiver.sendMessage(msg, builder.build()); |             receiver.sendMessage(msg, worldNameTemplate, msgTemplate, plotTemplate, senderTemplate); | ||||||
|         } |         } | ||||||
|         if (!spies.isEmpty()) { |         if (!spies.isEmpty()) { | ||||||
|             Caption spymsg = TranslatableCaption.of("chat.plot_chat_spy_format"); |             Caption spymsg = TranslatableCaption.of("chat.plot_chat_spy_format"); | ||||||
|  |             Template plotidTemplate = Template.of("plot_id", id.getX() + ";" + id.getY()); | ||||||
|  |             Template spysenderTemplate = Template.of("sender", sender); | ||||||
|  |             Template spymessageTemplate = Template.of("msg", Component.text(message)); | ||||||
|             for (PlotPlayer<?> player : spies) { |             for (PlotPlayer<?> player : spies) { | ||||||
|                 player.sendMessage(spymsg, builder.tag("message", Tag.inserting(Component.text(message))).build()); |                 player.sendMessage(spymsg, worldNameTemplate, plotidTemplate, spysenderTemplate, spymessageTemplate); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         if (Settings.Chat.LOG_PLOTCHAT_TO_CONSOLE) { |         if (Settings.Chat.LOG_PLOTCHAT_TO_CONSOLE) { | ||||||
|             Caption spymsg = TranslatableCaption.of("chat.plot_chat_spy_format"); |             Caption spymsg = TranslatableCaption.of("chat.plot_chat_spy_format"); | ||||||
|             ConsolePlayer.getConsole().sendMessage( |             Template plotidTemplate = Template.of("plot_id", id.getX() + ";" + id.getY()); | ||||||
|                     spymsg, |             Template spysenderTemplate = Template.of("sender", sender); | ||||||
|                     builder.tag("message", Tag.inserting(Component.text(message))).build() |             Template spymessageTemplate = Template.of("msg", Component.text(message)); | ||||||
|  |             ConsolePlayer.getConsole().sendMessage(spymsg, worldNameTemplate, plotidTemplate, spysenderTemplate, | ||||||
|  |                     spymessageTemplate | ||||||
|             ); |             ); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -823,7 +824,7 @@ public class PlayerEventListener implements Listener { | |||||||
|             plotListener.plotExit(pp, plot); |             plotListener.plotExit(pp, plot); | ||||||
|         } |         } | ||||||
|         if (this.worldEdit != null) { |         if (this.worldEdit != null) { | ||||||
|             if (!pp.hasPermission(Permission.PERMISSION_WORLDEDIT_BYPASS)) { |             if (!Permissions.hasPermission(pp, Permission.PERMISSION_WORLDEDIT_BYPASS)) { | ||||||
|                 if (pp.getAttribute("worldedit")) { |                 if (pp.getAttribute("worldedit")) { | ||||||
|                     pp.removeAttribute("worldedit"); |                     pp.removeAttribute("worldedit"); | ||||||
|                 } |                 } | ||||||
| @@ -879,7 +880,8 @@ public class PlayerEventListener implements Listener { | |||||||
|             final Plot plot = pp.getCurrentPlot(); |             final Plot plot = pp.getCurrentPlot(); | ||||||
|             if (plot != null) { |             if (plot != null) { | ||||||
|                 if (plot.getFlag(PreventCreativeCopyFlag.class) && !plot |                 if (plot.getFlag(PreventCreativeCopyFlag.class) && !plot | ||||||
|                         .isAdded(player.getUniqueId()) && !pp.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { |                         .isAdded(player.getUniqueId()) && !Permissions | ||||||
|  |                         .hasPermission(pp, Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { | ||||||
|                     final ItemStack newStack = |                     final ItemStack newStack = | ||||||
|                             new ItemStack(newItem.getType(), newItem.getAmount()); |                             new ItemStack(newItem.getType(), newItem.getAmount()); | ||||||
|                     event.setCursor(newStack); |                     event.setCursor(newStack); | ||||||
| @@ -941,37 +943,28 @@ public class PlayerEventListener implements Listener { | |||||||
|         Plot plot = area.getPlotAbs(location); |         Plot plot = area.getPlotAbs(location); | ||||||
|         boolean cancelled = false; |         boolean cancelled = false; | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_ROAD)) { |             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_INTERACT_ROAD)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_INTERACT_ROAD)) | ||||||
|                                 "node", |  | ||||||
|                                 Tag.inserting(Permission.PERMISSION_ADMIN_INTERACT_ROAD) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 cancelled = true; |                 cancelled = true; | ||||||
|             } |             } | ||||||
|         } else if (!plot.hasOwner()) { |         } else if (!plot.hasOwner()) { | ||||||
|             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_UNOWNED)) { |             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_INTERACT_UNOWNED)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_INTERACT_UNOWNED)) | ||||||
|                                 "node", |  | ||||||
|                                 Tag.inserting(Permission.PERMISSION_ADMIN_INTERACT_UNOWNED) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 cancelled = true; |                 cancelled = true; | ||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|             UUID uuid = pp.getUUID(); |             UUID uuid = pp.getUUID(); | ||||||
|             if (!plot.isAdded(uuid)) { |             if (!plot.isAdded(uuid)) { | ||||||
|                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_INTERACT_OTHER)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ADMIN_INTERACT_OTHER) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     cancelled = true; |                     cancelled = true; | ||||||
|                 } |                 } | ||||||
| @@ -1005,34 +998,29 @@ public class PlayerEventListener implements Listener { | |||||||
|         Plot plot = location.getPlotAbs(); |         Plot plot = location.getPlotAbs(); | ||||||
|         BukkitPlayer pp = BukkitUtil.adapt(e.getPlayer()); |         BukkitPlayer pp = BukkitUtil.adapt(e.getPlayer()); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, MiscInteractFlag.class, true) && !pp.hasPermission( |             if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, MiscInteractFlag.class, true) && !Permissions.hasPermission( | ||||||
|  |                     pp, | ||||||
|                     Permission.PERMISSION_ADMIN_INTERACT_ROAD |                     Permission.PERMISSION_ADMIN_INTERACT_ROAD | ||||||
|             )) { |             )) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_INTERACT_ROAD)) | ||||||
|                                 "node", |  | ||||||
|                                 Tag.inserting(Permission.PERMISSION_ADMIN_INTERACT_ROAD) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 e.setCancelled(true); |                 e.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|             if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |             if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                     pp.sendMessage(TranslatableCaption.of("done.building_restricted")); |                     pp.sendMessage(TranslatableCaption.of("done.building_restricted")); | ||||||
|                     e.setCancelled(true); |                     e.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             if (!plot.hasOwner()) { |             if (!plot.hasOwner()) { | ||||||
|                 if (!pp.hasPermission("plots.admin.interact.unowned")) { |                 if (!Permissions.hasPermission(pp, "plots.admin.interact.unowned")) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_INTERACT_UNOWNED)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ADMIN_INTERACT_UNOWNED) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     e.setCancelled(true); |                     e.setCancelled(true); | ||||||
|                 } |                 } | ||||||
| @@ -1044,13 +1032,10 @@ public class PlayerEventListener implements Listener { | |||||||
|                 if (plot.getFlag(MiscInteractFlag.class)) { |                 if (plot.getFlag(MiscInteractFlag.class)) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_INTERACT_OTHER)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ADMIN_INTERACT_OTHER) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     e.setCancelled(true); |                     e.setCancelled(true); | ||||||
|                     plot.debug(pp.getName() + " could not interact with " + entity.getType() |                     plot.debug(pp.getName() + " could not interact with " + entity.getType() | ||||||
| @@ -1177,7 +1162,7 @@ public class PlayerEventListener implements Listener { | |||||||
|                     location = BukkitUtil.adapt(block.getRelative(event.getBlockFace()).getLocation()); |                     location = BukkitUtil.adapt(block.getRelative(event.getBlockFace()).getLocation()); | ||||||
|                     eventType = PlayerBlockEventType.PLACE_MISC; |                     eventType = PlayerBlockEventType.PLACE_MISC; | ||||||
|                 } |                 } | ||||||
|                 if (org.bukkit.Tag.ITEMS_BOATS.isTagged(type) || MINECARTS.contains(type)) { |                 if (Tag.ITEMS_BOATS.isTagged(type) || MINECARTS.contains(type)) { | ||||||
|                     eventType = PlayerBlockEventType.PLACE_VEHICLE; |                     eventType = PlayerBlockEventType.PLACE_VEHICLE; | ||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
| @@ -1272,40 +1257,34 @@ public class PlayerEventListener implements Listener { | |||||||
|         BukkitPlayer pp = BukkitUtil.adapt(event.getPlayer()); |         BukkitPlayer pp = BukkitUtil.adapt(event.getPlayer()); | ||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_ROAD)) { |             if (Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_ROAD)) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             pp.sendMessage( |             pp.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission_event"), |                     TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                     TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_ROAD)) |                     Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_ROAD)) | ||||||
|             ); |             ); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } else if (!plot.hasOwner()) { |         } else if (!plot.hasOwner()) { | ||||||
|             if (pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { |             if (Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             pp.sendMessage( |             pp.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission_event"), |                     TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                     TagResolver.resolver( |                     Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) | ||||||
|                             "node", |  | ||||||
|                             Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_UNOWNED) |  | ||||||
|                     ) |  | ||||||
|             ); |             ); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } else if (!plot.isAdded(pp.getUUID())) { |         } else if (!plot.isAdded(pp.getUUID())) { | ||||||
|             if (pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |             if (Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             pp.sendMessage( |             pp.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission_event"), |                     TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                     TagResolver.resolver( |                     Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_OTHER)) | ||||||
|                             "node", |  | ||||||
|                             Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_OTHER) |  | ||||||
|                     ) |  | ||||||
|             ); |             ); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |         } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("done.building_restricted") |                         TranslatableCaption.of("done.building_restricted") | ||||||
|                 ); |                 ); | ||||||
| @@ -1343,40 +1322,34 @@ public class PlayerEventListener implements Listener { | |||||||
|         BukkitPlayer plotPlayer = BukkitUtil.adapt(player); |         BukkitPlayer plotPlayer = BukkitUtil.adapt(player); | ||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_BUILD_ROAD)) { |             if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_ROAD)) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             plotPlayer.sendMessage( |             plotPlayer.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission_event"), |                     TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                     TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_ROAD)) |                     Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_ROAD)) | ||||||
|             ); |             ); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } else if (!plot.hasOwner()) { |         } else if (!plot.hasOwner()) { | ||||||
|             if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { |             if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             plotPlayer.sendMessage( |             plotPlayer.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission_event"), |                     TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                     TagResolver.resolver( |                     Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) | ||||||
|                             "node", |  | ||||||
|                             Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_UNOWNED) |  | ||||||
|                     ) |  | ||||||
|             ); |             ); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } else if (!plot.isAdded(plotPlayer.getUUID())) { |         } else if (!plot.isAdded(plotPlayer.getUUID())) { | ||||||
|             if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |             if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             plotPlayer.sendMessage( |             plotPlayer.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission_event"), |                     TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                     TagResolver.resolver( |                     Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_OTHER)) | ||||||
|                             "node", |  | ||||||
|                             Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_OTHER) |  | ||||||
|                     ) |  | ||||||
|             ); |             ); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |         } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|             if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |             if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                 plotPlayer.sendMessage( |                 plotPlayer.sendMessage( | ||||||
|                         TranslatableCaption.of("done.building_restricted") |                         TranslatableCaption.of("done.building_restricted") | ||||||
|                 ); |                 ); | ||||||
| @@ -1401,25 +1374,19 @@ public class PlayerEventListener implements Listener { | |||||||
|         BukkitPlayer pp = BukkitUtil.adapt(p); |         BukkitPlayer pp = BukkitUtil.adapt(p); | ||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_ROAD)) { |             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_ROAD)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_ROAD)) | ||||||
|                                 "node", |  | ||||||
|                                 Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_ROAD) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|             if (!plot.hasOwner()) { |             if (!plot.hasOwner()) { | ||||||
|                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_UNOWNED) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
| @@ -1427,13 +1394,10 @@ public class PlayerEventListener implements Listener { | |||||||
|             } |             } | ||||||
|             if (!plot.isAdded(pp.getUUID())) { |             if (!plot.isAdded(pp.getUUID())) { | ||||||
|                 if (!plot.getFlag(HangingPlaceFlag.class)) { |                 if (!plot.getFlag(HangingPlaceFlag.class)) { | ||||||
|                     if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |                     if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_OTHER)) | ||||||
|                                         "node", |  | ||||||
|                                         Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_OTHER) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         event.setCancelled(true); |                         event.setCancelled(true); | ||||||
|                     } |                     } | ||||||
| @@ -1459,24 +1423,18 @@ public class PlayerEventListener implements Listener { | |||||||
|             BukkitPlayer pp = BukkitUtil.adapt(p); |             BukkitPlayer pp = BukkitUtil.adapt(p); | ||||||
|             Plot plot = area.getPlot(location); |             Plot plot = area.getPlot(location); | ||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_ROAD)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_DESTROY_ROAD)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_DESTROY_ROAD)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ADMIN_DESTROY_ROAD) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|             } else if (!plot.hasOwner()) { |             } else if (!plot.hasOwner()) { | ||||||
|                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_UNOWNED)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_DESTROY_UNOWNED)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_DESTROY_UNOWNED)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ADMIN_DESTROY_UNOWNED) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
| @@ -1484,13 +1442,10 @@ public class PlayerEventListener implements Listener { | |||||||
|                 if (plot.getFlag(HangingBreakFlag.class)) { |                 if (plot.getFlag(HangingBreakFlag.class)) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_DESTROY_OTHER)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ADMIN_DESTROY_OTHER) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     plot.debug(p.getName() |                     plot.debug(p.getName() | ||||||
| @@ -1508,25 +1463,21 @@ public class PlayerEventListener implements Listener { | |||||||
|                 Plot plot = area.getPlot(BukkitUtil.adapt(event.getEntity().getLocation())); |                 Plot plot = area.getPlot(BukkitUtil.adapt(event.getEntity().getLocation())); | ||||||
|                 if (plot != null) { |                 if (plot != null) { | ||||||
|                     if (!plot.hasOwner()) { |                     if (!plot.hasOwner()) { | ||||||
|                         if (!player.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_UNOWNED)) { |                         if (!Permissions | ||||||
|  |                                 .hasPermission(player, Permission.PERMISSION_ADMIN_DESTROY_UNOWNED)) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("permission.no_permission_event"), |                                     TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                     TagResolver.resolver( |                                     Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_DESTROY_UNOWNED)) | ||||||
|                                             "node", |  | ||||||
|                                             Tag.inserting(Permission.PERMISSION_ADMIN_DESTROY_UNOWNED) |  | ||||||
|                                     ) |  | ||||||
|                             ); |                             ); | ||||||
|                             event.setCancelled(true); |                             event.setCancelled(true); | ||||||
|                         } |                         } | ||||||
|                     } else if (!plot.isAdded(player.getUUID())) { |                     } else if (!plot.isAdded(player.getUUID())) { | ||||||
|                         if (!plot.getFlag(HangingBreakFlag.class)) { |                         if (!plot.getFlag(HangingBreakFlag.class)) { | ||||||
|                             if (!player.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { |                             if (!Permissions | ||||||
|  |                                     .hasPermission(player, Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("permission.no_permission_event"), |                                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                         TagResolver.resolver( |                                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_DESTROY_OTHER)) | ||||||
|                                                 "node", |  | ||||||
|                                                 Tag.inserting(Permission.PERMISSION_ADMIN_DESTROY_OTHER) |  | ||||||
|                                         ) |  | ||||||
|                                 ); |                                 ); | ||||||
|                                 event.setCancelled(true); |                                 event.setCancelled(true); | ||||||
|                                 plot.debug(player.getName() |                                 plot.debug(player.getName() | ||||||
| @@ -1555,24 +1506,18 @@ public class PlayerEventListener implements Listener { | |||||||
|         BukkitPlayer pp = BukkitUtil.adapt(p); |         BukkitPlayer pp = BukkitUtil.adapt(p); | ||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|         if (plot == null && !area.isRoadFlags()) { |         if (plot == null && !area.isRoadFlags()) { | ||||||
|             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_ROAD)) { |             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_INTERACT_ROAD)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_INTERACT_ROAD)) | ||||||
|                                 "node", |  | ||||||
|                                 Tag.inserting(Permission.PERMISSION_ADMIN_INTERACT_ROAD) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (plot != null && !plot.hasOwner()) { |         } else if (plot != null && !plot.hasOwner()) { | ||||||
|             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_UNOWNED)) { |             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_INTERACT_UNOWNED)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_INTERACT_UNOWNED)) | ||||||
|                                 "node", |  | ||||||
|                                 Tag.inserting(Permission.PERMISSION_ADMIN_INTERACT_UNOWNED) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
| @@ -1627,13 +1572,10 @@ public class PlayerEventListener implements Listener { | |||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { |             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_INTERACT_OTHER)) | ||||||
|                                 "node", |  | ||||||
|                                 Tag.inserting(Permission.PERMISSION_ADMIN_INTERACT_OTHER) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
| @@ -1652,27 +1594,22 @@ public class PlayerEventListener implements Listener { | |||||||
|             BukkitPlayer pp = BukkitUtil.adapt(p); |             BukkitPlayer pp = BukkitUtil.adapt(p); | ||||||
|             Plot plot = area.getPlot(location); |             Plot plot = area.getPlot(location); | ||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, VehicleBreakFlag.class, true) && !pp.hasPermission( |                 if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, VehicleBreakFlag.class, true) && !Permissions.hasPermission( | ||||||
|  |                         pp, | ||||||
|                         Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_ROAD |                         Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_ROAD | ||||||
|                 )) { |                 )) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_ROAD)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_ROAD) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|             } else { |             } else { | ||||||
|                 if (!plot.hasOwner()) { |                 if (!plot.hasOwner()) { | ||||||
|                     if (!pp.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_UNOWNED)) { |                     if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_UNOWNED)) { | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_UNOWNED)) | ||||||
|                                         "node", |  | ||||||
|                                         Tag.inserting(Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_UNOWNED) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         event.setCancelled(true); |                         event.setCancelled(true); | ||||||
|                         return; |                         return; | ||||||
| @@ -1683,13 +1620,10 @@ public class PlayerEventListener implements Listener { | |||||||
|                     if (plot.getFlag(VehicleBreakFlag.class)) { |                     if (plot.getFlag(VehicleBreakFlag.class)) { | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                     if (!pp.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_OTHER)) { |                     if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_OTHER)) { | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_OTHER)) | ||||||
|                                         "node", |  | ||||||
|                                         Tag.inserting(Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_OTHER) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         event.setCancelled(true); |                         event.setCancelled(true); | ||||||
|                         plot.debug(pp.getName() |                         plot.debug(pp.getName() | ||||||
|   | |||||||
| @@ -30,9 +30,9 @@ import com.plotsquared.core.plot.PlotArea; | |||||||
| import com.plotsquared.core.plot.PlotHandler; | import com.plotsquared.core.plot.PlotHandler; | ||||||
| import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import com.plotsquared.core.util.Permissions; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import com.plotsquared.core.util.PlotFlagUtil; | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
|  | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import org.bukkit.entity.Entity; | import org.bukkit.entity.Entity; | ||||||
| import org.bukkit.entity.LivingEntity; | import org.bukkit.entity.LivingEntity; | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.entity.Player; | ||||||
| @@ -106,40 +106,32 @@ public class ProjectileEventListener implements Listener { | |||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|  |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true) && !pp.hasPermission( |             if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true) && !Permissions.hasPermission( | ||||||
|  |                     pp, | ||||||
|                     Permission.PERMISSION_ADMIN_PROJECTILE_ROAD |                     Permission.PERMISSION_ADMIN_PROJECTILE_ROAD | ||||||
|             )) { |             )) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_PROJECTILE_ROAD)) | ||||||
|                                 "node", |  | ||||||
|                                 Tag.inserting(Permission.PERMISSION_ADMIN_PROJECTILE_ROAD) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (!plot.hasOwner()) { |         } else if (!plot.hasOwner()) { | ||||||
|             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { |             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) | ||||||
|                                 "node", |  | ||||||
|                                 Tag.inserting(Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (!plot.isAdded(pp.getUUID())) { |         } else if (!plot.isAdded(pp.getUUID())) { | ||||||
|             if (!plot.getFlag(ProjectilesFlag.class)) { |             if (!plot.getFlag(ProjectilesFlag.class)) { | ||||||
|                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     entity.remove(); |                     entity.remove(); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
| @@ -178,7 +170,8 @@ public class ProjectileEventListener implements Listener { | |||||||
|  |  | ||||||
|             PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); |             PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); | ||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true) && !pp.hasPermission( |                 if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true) && !Permissions.hasPermission( | ||||||
|  |                         pp, | ||||||
|                         Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED |                         Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED | ||||||
|                 )) { |                 )) { | ||||||
|                     entity.remove(); |                     entity.remove(); | ||||||
| @@ -186,8 +179,8 @@ public class ProjectileEventListener implements Listener { | |||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (plot.isAdded(pp.getUUID()) || pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER) || plot.getFlag( |             if (plot.isAdded(pp.getUUID()) || Permissions | ||||||
|                     ProjectilesFlag.class)) { |                     .hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_OTHER) || plot.getFlag(ProjectilesFlag.class)) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             entity.remove(); |             entity.remove(); | ||||||
|   | |||||||
| @@ -30,9 +30,8 @@ import org.checkerframework.checker.nullness.qual.Nullable; | |||||||
|  * |  * | ||||||
|  * @deprecated Deprecated and scheduled for removal without replacement |  * @deprecated Deprecated and scheduled for removal without replacement | ||||||
|  *         in favor of the build in setup wizard. |  *         in favor of the build in setup wizard. | ||||||
|  *         However, this class will be kept around for a while, given it's not a maintenance burden. |  | ||||||
|  */ |  */ | ||||||
| @Deprecated | @Deprecated(forRemoval = true, since = "6.0.0") | ||||||
| @Singleton | @Singleton | ||||||
| public class MultiverseWorldManager extends BukkitWorldManager { | public class MultiverseWorldManager extends BukkitWorldManager { | ||||||
|  |  | ||||||
|   | |||||||
| @@ -87,9 +87,4 @@ public class BukkitOfflinePlayer implements OfflinePlotPlayer { | |||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean hasPermission(@NonNull final String permission, final boolean notify) { |  | ||||||
|         return hasPermission(permission); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -67,15 +67,24 @@ public class BukkitPlayer extends PlotPlayer<Player> { | |||||||
|     private String name; |     private String name; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|  |      * <p>Please do not use this method. Instead use | ||||||
|  |      * BukkitUtil.getPlayer(Player), as it caches player objects.</p> | ||||||
|  |      * | ||||||
|      * @param plotAreaManager   PlotAreaManager instance |      * @param plotAreaManager   PlotAreaManager instance | ||||||
|      * @param eventDispatcher   EventDispatcher instance |      * @param eventDispatcher   EventDispatcher instance | ||||||
|      * @param player            Bukkit player instance |      * @param player            Bukkit player instance | ||||||
|      * @param permissionHandler PermissionHandler instance |      * @param permissionHandler PermissionHandler instance | ||||||
|      */ |      */ | ||||||
|     BukkitPlayer( |     public BukkitPlayer( | ||||||
|             final @NonNull PlotAreaManager plotAreaManager, |             final @NonNull PlotAreaManager plotAreaManager, final @NonNull EventDispatcher eventDispatcher, | ||||||
|             final @NonNull EventDispatcher eventDispatcher, |             final @NonNull Player player, final @NonNull PermissionHandler permissionHandler | ||||||
|             final @NonNull Player player, |     ) { | ||||||
|  |         this(plotAreaManager, eventDispatcher, player, false, permissionHandler); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public BukkitPlayer( | ||||||
|  |             final @NonNull PlotAreaManager plotAreaManager, final @NonNull | ||||||
|  |             EventDispatcher eventDispatcher, final @NonNull Player player, | ||||||
|             final boolean realPlayer, |             final boolean realPlayer, | ||||||
|             final @NonNull PermissionHandler permissionHandler |             final @NonNull PermissionHandler permissionHandler | ||||||
|     ) { |     ) { | ||||||
|   | |||||||
| @@ -54,7 +54,6 @@ public class BukkitPlayerManager extends PlayerManager<BukkitPlayer, Player> { | |||||||
|  |  | ||||||
|     @NonNull |     @NonNull | ||||||
|     @Override |     @Override | ||||||
|     @SuppressWarnings("deprecation") |  | ||||||
|     public BukkitPlayer getPlayer(final @NonNull Player object) { |     public BukkitPlayer getPlayer(final @NonNull Player object) { | ||||||
|         if (object.getUniqueId().version() == 2) { // not a real player |         if (object.getUniqueId().version() == 2) { // not a real player | ||||||
|             return new BukkitPlayer(this.plotAreaManager, this.eventDispatcher, object, false, this.permissionHandler); |             return new BukkitPlayer(this.plotAreaManager, this.eventDispatcher, object, false, this.permissionHandler); | ||||||
| @@ -71,7 +70,7 @@ public class BukkitPlayerManager extends PlayerManager<BukkitPlayer, Player> { | |||||||
|         if (player == null || !player.isOnline()) { |         if (player == null || !player.isOnline()) { | ||||||
|             throw new NoSuchPlayerException(uuid); |             throw new NoSuchPlayerException(uuid); | ||||||
|         } |         } | ||||||
|         return new BukkitPlayer(this.plotAreaManager, this.eventDispatcher, player, false, this.permissionHandler); |         return new BukkitPlayer(this.plotAreaManager, this.eventDispatcher, player, this.permissionHandler); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Nullable |     @Nullable | ||||||
|   | |||||||
| @@ -239,11 +239,9 @@ public final class BukkitChunkCoordinator extends ChunkCoordinator { | |||||||
|      * server's main thread. |      * server's main thread. | ||||||
|      */ |      */ | ||||||
|     private void processChunk(final @NonNull Chunk chunk) { |     private void processChunk(final @NonNull Chunk chunk) { | ||||||
|         /* Chunk#isLoaded does not necessarily return true shortly after PaperLib#getChunkAtAsync completes, but the chunk is |  | ||||||
|         still loaded. |  | ||||||
|         if (!chunk.isLoaded()) { |         if (!chunk.isLoaded()) { | ||||||
|             throw new IllegalArgumentException(String.format("Chunk %d;%d is is not loaded", chunk.getX(), chunk.getZ()); |             throw new IllegalArgumentException(String.format("Chunk %d;%d is is not loaded", chunk.getX(), chunk.getZ())); | ||||||
|         }*/ |         } | ||||||
|         if (finished) { |         if (finished) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -24,7 +24,7 @@ import com.plotsquared.bukkit.util.BukkitBlockUtil; | |||||||
| import com.plotsquared.bukkit.util.BukkitUtil; | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
| import com.plotsquared.core.location.ChunkWrapper; | import com.plotsquared.core.location.ChunkWrapper; | ||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | import com.plotsquared.core.queue.ScopedQueueCoordinator; | ||||||
| import com.plotsquared.core.util.ChunkUtil; | import com.plotsquared.core.util.ChunkUtil; | ||||||
| import com.plotsquared.core.util.PatternUtil; | import com.plotsquared.core.util.PatternUtil; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| @@ -44,11 +44,8 @@ import org.checkerframework.checker.nullness.qual.Nullable; | |||||||
|  |  | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Internal use only. Subject to changes at any time. |  | ||||||
|  */ |  | ||||||
| @DoNotUse | @DoNotUse | ||||||
| public class GenChunk extends ZeroedDelegateScopedQueueCoordinator { | public class GenChunk extends ScopedQueueCoordinator { | ||||||
|  |  | ||||||
|     public final Biome[] biomes; |     public final Biome[] biomes; | ||||||
|     public BlockState[][] result; |     public BlockState[][] result; | ||||||
|   | |||||||
| @@ -37,6 +37,7 @@ import org.bukkit.block.Sign; | |||||||
| import org.bukkit.block.Skull; | import org.bukkit.block.Skull; | ||||||
| import org.bukkit.enchantments.Enchantment; | import org.bukkit.enchantments.Enchantment; | ||||||
| import org.bukkit.inventory.Inventory; | import org.bukkit.inventory.Inventory; | ||||||
|  | import org.bukkit.inventory.InventoryHolder; | ||||||
| import org.bukkit.inventory.ItemStack; | import org.bukkit.inventory.ItemStack; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| @@ -51,6 +52,15 @@ public class StateWrapper { | |||||||
|     public org.bukkit.block.BlockState state = null; |     public org.bukkit.block.BlockState state = null; | ||||||
|     public CompoundTag tag = null; |     public CompoundTag tag = null; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @deprecated in favour of using WE methods for obtaining NBT, specifically by obtaining a | ||||||
|  |      *         {@link com.sk89q.worldedit.world.block.BaseBlock} and then using {@link com.sk89q.worldedit.world.block.BaseBlock#getNbtData()} | ||||||
|  |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "6.9.0") | ||||||
|  |     public StateWrapper(org.bukkit.block.BlockState state) { | ||||||
|  |         this.state = state; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public StateWrapper(CompoundTag tag) { |     public StateWrapper(CompoundTag tag) { | ||||||
|         this.tag = tag; |         this.tag = tag; | ||||||
|     } |     } | ||||||
| @@ -244,6 +254,26 @@ public class StateWrapper { | |||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get a CompoundTag of the contents of a block's inventory (chest, furnace, etc.). | ||||||
|  |      * | ||||||
|  |      * @deprecated in favour of using WorldEdit methods for obtaining NBT, specifically by obtaining a | ||||||
|  |      *         {@link com.sk89q.worldedit.world.block.BaseBlock} and then using {@link com.sk89q.worldedit.world.block.BaseBlock#getNbtData()} | ||||||
|  |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "6.9.0") | ||||||
|  |     public CompoundTag getTag() { | ||||||
|  |         if (this.tag != null) { | ||||||
|  |             return this.tag; | ||||||
|  |         } | ||||||
|  |         if (this.state instanceof InventoryHolder inv) { | ||||||
|  |             ItemStack[] contents = inv.getInventory().getContents(); | ||||||
|  |             Map<String, Tag> values = new HashMap<>(); | ||||||
|  |             values.put("Items", new ListTag(CompoundTag.class, serializeInventory(contents))); | ||||||
|  |             return new CompoundTag(values); | ||||||
|  |         } | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public String getId() { |     public String getId() { | ||||||
|         String tileid = this.tag.getString("id").toLowerCase(); |         String tileid = this.tag.getString("id").toLowerCase(); | ||||||
|         if (tileid.startsWith("minecraft:")) { |         if (tileid.startsWith("minecraft:")) { | ||||||
|   | |||||||
| @@ -40,11 +40,10 @@ import com.plotsquared.core.plot.flag.implementations.PvpFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.TamedAttackFlag; | import com.plotsquared.core.plot.flag.implementations.TamedAttackFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.VehicleCapFlag; | import com.plotsquared.core.plot.flag.implementations.VehicleCapFlag; | ||||||
| import com.plotsquared.core.util.EntityUtil; | import com.plotsquared.core.util.EntityUtil; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.entity.EntityCategories; | import com.plotsquared.core.util.entity.EntityCategories; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.bukkit.entity.Arrow; | import org.bukkit.entity.Arrow; | ||||||
| import org.bukkit.entity.Creature; | import org.bukkit.entity.Creature; | ||||||
| import org.bukkit.entity.Entity; | import org.bukkit.entity.Entity; | ||||||
| @@ -169,7 +168,8 @@ public class BukkitEntityUtil { | |||||||
|                 if (plot != null && (plot.getFlag(HangingBreakFlag.class) || plot |                 if (plot != null && (plot.getFlag(HangingBreakFlag.class) || plot | ||||||
|                         .isAdded(plotPlayer.getUUID()))) { |                         .isAdded(plotPlayer.getUUID()))) { | ||||||
|                     if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |                     if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|                         if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |                         if (!Permissions | ||||||
|  |                                 .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                             plotPlayer.sendMessage( |                             plotPlayer.sendMessage( | ||||||
|                                     TranslatableCaption.of("done.building_restricted") |                                     TranslatableCaption.of("done.building_restricted") | ||||||
|                             ); |                             ); | ||||||
| @@ -178,13 +178,10 @@ public class BukkitEntityUtil { | |||||||
|                     } |                     } | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY + "." + stub)) { |                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", Permission.PERMISSION_ADMIN_DESTROY + "." + stub) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_DESTROY + "." + stub)) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -193,13 +190,10 @@ public class BukkitEntityUtil { | |||||||
|                         .isAdded(plotPlayer.getUUID()))) { |                         .isAdded(plotPlayer.getUUID()))) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY + "." + stub)) { |                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", Permission.PERMISSION_ADMIN_DESTROY + "." + stub) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_DESTROY + "." + stub)) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     if (plot != null) { |                     if (plot != null) { | ||||||
|                         plot.debug(player.getName() |                         plot.debug(player.getName() | ||||||
| @@ -217,13 +211,10 @@ public class BukkitEntityUtil { | |||||||
|                         .getFlag(PveFlag.class))) { |                         .getFlag(PveFlag.class))) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVE + "." + stub)) { |                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVE + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", Permission.PERMISSION_ADMIN_PVE + "." + stub) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_PVE + "." + stub)) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     if (plot != null) { |                     if (plot != null) { | ||||||
|                         plot.debug(player.getName() + " could not attack " + entityType |                         plot.debug(player.getName() + " could not attack " + entityType | ||||||
| @@ -241,13 +232,10 @@ public class BukkitEntityUtil { | |||||||
|                         .getFlag(PveFlag.class))) { |                         .getFlag(PveFlag.class))) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVE + "." + stub)) { |                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVE + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", Permission.PERMISSION_ADMIN_PVE + "." + stub) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_PVE + "." + stub)) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     if (plot != null) { |                     if (plot != null) { | ||||||
|                         plot.debug(player.getName() + " could not attack " + entityType |                         plot.debug(player.getName() + " could not attack " + entityType | ||||||
| @@ -257,13 +245,11 @@ public class BukkitEntityUtil { | |||||||
|                 } |                 } | ||||||
|             } else if (EntityCategories.PLAYER.contains(entityType)) { |             } else if (EntityCategories.PLAYER.contains(entityType)) { | ||||||
|                 if (isPlot) { |                 if (isPlot) { | ||||||
|                     if (!plot.getFlag(PvpFlag.class) && !plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVP + "." + stub)) { |                     if (!plot.getFlag(PvpFlag.class) && !Permissions | ||||||
|  |                             .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVP + "." + stub)) { | ||||||
|                         plotPlayer.sendMessage( |                         plotPlayer.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("node", Permission.PERMISSION_ADMIN_PVP + "." + stub) | ||||||
|                                         "node", |  | ||||||
|                                         Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_PVP + "." + stub)) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         plot.debug(player.getName() + " could not attack " + entityType |                         plot.debug(player.getName() + " could not attack " + entityType | ||||||
|                                 + " because pve = false"); |                                 + " because pve = false"); | ||||||
| @@ -274,13 +260,10 @@ public class BukkitEntityUtil { | |||||||
|                 } else if (roadFlags && area.getRoadFlag(PvpFlag.class)) { |                 } else if (roadFlags && area.getRoadFlag(PvpFlag.class)) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVP + "." + stub)) { |                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVP + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", Permission.PERMISSION_ADMIN_PVP + "." + stub) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_PVP + "." + stub)) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -294,13 +277,10 @@ public class BukkitEntityUtil { | |||||||
|                         .getFlag(PveFlag.class))) { |                         .getFlag(PveFlag.class))) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVE + "." + stub)) { |                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVE + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", Permission.PERMISSION_ADMIN_PVE + "." + stub) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_PVE + "." + stub)) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     if (plot != null) { |                     if (plot != null) { | ||||||
|                         plot.debug(player.getName() + " could not attack " + entityType |                         plot.debug(player.getName() + " could not attack " + entityType | ||||||
| @@ -319,13 +299,10 @@ public class BukkitEntityUtil { | |||||||
|                 } else if (roadFlags && area.getRoadFlag(PveFlag.class)) { |                 } else if (roadFlags && area.getRoadFlag(PveFlag.class)) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVE + "." + stub)) { |                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVE + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", Permission.PERMISSION_ADMIN_PVE + "." + stub) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_PVE + "." + stub)) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     if (plot != null) { |                     if (plot != null) { | ||||||
|                         plot.debug(player.getName() + " could not attack " + entityType |                         plot.debug(player.getName() + " could not attack " + entityType | ||||||
|   | |||||||
| @@ -56,7 +56,7 @@ public class BukkitInventoryUtil extends InventoryUtil { | |||||||
|         ItemMeta meta = null; |         ItemMeta meta = null; | ||||||
|         if (item.getName() != null) { |         if (item.getName() != null) { | ||||||
|             meta = stack.getItemMeta(); |             meta = stack.getItemMeta(); | ||||||
|             Component nameComponent = BukkitUtil.MINI_MESSAGE.deserialize(item.getName()); |             Component nameComponent = BukkitUtil.MINI_MESSAGE.parse(item.getName()); | ||||||
|             meta.setDisplayName(BukkitUtil.LEGACY_COMPONENT_SERIALIZER.serialize(nameComponent)); |             meta.setDisplayName(BukkitUtil.LEGACY_COMPONENT_SERIALIZER.serialize(nameComponent)); | ||||||
|         } |         } | ||||||
|         if (item.getLore() != null) { |         if (item.getLore() != null) { | ||||||
|   | |||||||
| @@ -30,7 +30,7 @@ import com.plotsquared.core.plot.PlotArea; | |||||||
| import com.plotsquared.core.plot.PlotManager; | import com.plotsquared.core.plot.PlotManager; | ||||||
| import com.plotsquared.core.queue.GlobalBlockQueue; | import com.plotsquared.core.queue.GlobalBlockQueue; | ||||||
| import com.plotsquared.core.queue.QueueCoordinator; | import com.plotsquared.core.queue.QueueCoordinator; | ||||||
| import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | import com.plotsquared.core.queue.ScopedQueueCoordinator; | ||||||
| import com.plotsquared.core.util.ChunkManager; | import com.plotsquared.core.util.ChunkManager; | ||||||
| import com.plotsquared.core.util.RegionManager; | import com.plotsquared.core.util.RegionManager; | ||||||
| import com.plotsquared.core.util.WorldUtil; | import com.plotsquared.core.util.WorldUtil; | ||||||
| @@ -257,9 +257,9 @@ public class BukkitRegionManager extends RegionManager { | |||||||
|             map.saveEntitiesOut(Bukkit.getWorld(world.getName()).getChunkAt(x, z), currentPlotClear); |             map.saveEntitiesOut(Bukkit.getWorld(world.getName()).getChunkAt(x, z), currentPlotClear); | ||||||
|             AugmentedUtils.bypass( |             AugmentedUtils.bypass( | ||||||
|                     ignoreAugment, |                     ignoreAugment, | ||||||
|                     () -> ChunkManager.setChunkInPlotArea(null, new RunnableVal<ZeroedDelegateScopedQueueCoordinator>() { |                     () -> ChunkManager.setChunkInPlotArea(null, new RunnableVal<ScopedQueueCoordinator>() { | ||||||
|                         @Override |                         @Override | ||||||
|                         public void run(ZeroedDelegateScopedQueueCoordinator value) { |                         public void run(ScopedQueueCoordinator value) { | ||||||
|                             Location min = value.getMin(); |                             Location min = value.getMin(); | ||||||
|                             int bx = min.getX(); |                             int bx = min.getX(); | ||||||
|                             int bz = min.getZ(); |                             int bz = min.getZ(); | ||||||
|   | |||||||
| @@ -45,7 +45,7 @@ import com.sk89q.worldedit.world.block.BlockTypes; | |||||||
| import io.papermc.lib.PaperLib; | import io.papermc.lib.PaperLib; | ||||||
| import net.kyori.adventure.platform.bukkit.BukkitAudiences; | import net.kyori.adventure.platform.bukkit.BukkitAudiences; | ||||||
| import net.kyori.adventure.text.minimessage.MiniMessage; | import net.kyori.adventure.text.minimessage.MiniMessage; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer; | import net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer; | ||||||
| import org.apache.logging.log4j.LogManager; | import org.apache.logging.log4j.LogManager; | ||||||
| import org.apache.logging.log4j.Logger; | import org.apache.logging.log4j.Logger; | ||||||
| @@ -333,7 +333,7 @@ public class BukkitUtil extends WorldUtil { | |||||||
|     @SuppressWarnings("deprecation") |     @SuppressWarnings("deprecation") | ||||||
|     public void setSign( |     public void setSign( | ||||||
|             final @NonNull Location location, final @NonNull Caption[] lines, |             final @NonNull Location location, final @NonNull Caption[] lines, | ||||||
|             final @NonNull TagResolver... replacements |             final @NonNull Template... replacements | ||||||
|     ) { |     ) { | ||||||
|         ensureLoaded(location.getWorldName(), location.getX(), location.getZ(), chunk -> { |         ensureLoaded(location.getWorldName(), location.getX(), location.getZ(), chunk -> { | ||||||
|             PlotArea area = location.getPlotArea(); |             PlotArea area = location.getPlotArea(); | ||||||
| @@ -366,9 +366,8 @@ public class BukkitUtil extends WorldUtil { | |||||||
|             final org.bukkit.block.BlockState blockstate = block.getState(); |             final org.bukkit.block.BlockState blockstate = block.getState(); | ||||||
|             if (blockstate instanceof final Sign sign) { |             if (blockstate instanceof final Sign sign) { | ||||||
|                 for (int i = 0; i < lines.length; i++) { |                 for (int i = 0; i < lines.length; i++) { | ||||||
|                     sign.setLine(i, LEGACY_COMPONENT_SERIALIZER.serialize( |                     sign.setLine(i, LEGACY_COMPONENT_SERIALIZER | ||||||
|                             MINI_MESSAGE.deserialize(lines[i].getComponent(LocaleHolder.console()), replacements) |                             .serialize(MINI_MESSAGE.parse(lines[i].getComponent(LocaleHolder.console()), replacements))); | ||||||
|                     )); |  | ||||||
|                 } |                 } | ||||||
|                 sign.update(true, false); |                 sign.update(true, false); | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -24,6 +24,7 @@ import org.bukkit.Bukkit; | |||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
|  | import java.util.Objects; | ||||||
|  |  | ||||||
| public class BukkitWorld implements World<org.bukkit.World> { | public class BukkitWorld implements World<org.bukkit.World> { | ||||||
|  |  | ||||||
| @@ -132,6 +133,14 @@ public class BukkitWorld implements World<org.bukkit.World> { | |||||||
|         return world.hashCode(); |         return world.hashCode(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @deprecated This method is not meant to be invoked or overridden, with no replacement. | ||||||
|  |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "6.6.0") | ||||||
|  |     protected boolean canEqual(final Object other) { | ||||||
|  |         return other instanceof BukkitWorld; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public String toString() { |     public String toString() { | ||||||
|         return "BukkitWorld(world=" + this.world + ")"; |         return "BukkitWorld(world=" + this.world + ")"; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -1,63 +0,0 @@ | |||||||
| /* |  | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  | ||||||
|  * |  | ||||||
|  * This program is free software: you can redistribute it and/or modify |  | ||||||
|  * it under the terms of the GNU General Public License as published by |  | ||||||
|  * the Free Software Foundation, either version 3 of the License, or |  | ||||||
|  * (at your option) any later version. |  | ||||||
|  * |  | ||||||
|  * This program is distributed in the hope that it will be useful, |  | ||||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the |  | ||||||
|  * GNU General Public License for more details. |  | ||||||
|  * |  | ||||||
|  * You should have received a copy of the GNU General Public License |  | ||||||
|  * along with this program.  If not, see <https://www.gnu.org/licenses/>. |  | ||||||
|  */ |  | ||||||
| package com.plotsquared.bukkit.util; |  | ||||||
|  |  | ||||||
| import com.intellectualsites.annotations.NotPublic; |  | ||||||
| import com.plotsquared.core.PlotSquared; |  | ||||||
|  |  | ||||||
| import java.io.IOException; |  | ||||||
| import java.nio.file.Files; |  | ||||||
| import java.nio.file.Path; |  | ||||||
| import java.nio.file.Paths; |  | ||||||
| import java.util.stream.Stream; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * This is a helper class which replaces occurrences of 'suggest_command' with 'run_command' in messages_%.json. |  | ||||||
|  * MiniMessage changed the syntax between major releases. To warrant a smooth upgrade, we attempt to replace any occurrences |  | ||||||
|  * while loading PlotSquared. |  | ||||||
|  * |  | ||||||
|  * @since TODO |  | ||||||
|  */ |  | ||||||
| @NotPublic |  | ||||||
| public class TranslationUpdateManager { |  | ||||||
|  |  | ||||||
|     public static void upgradeTranslationFile() throws IOException { |  | ||||||
|         String searchText = "suggest_command"; |  | ||||||
|         String replacementText = "run_command"; |  | ||||||
|  |  | ||||||
|         try (Stream<Path> paths = Files.walk(Paths.get(PlotSquared.platform().getDirectory().toPath().resolve("lang").toUri()))) { |  | ||||||
|             paths |  | ||||||
|                     .filter(Files::isRegularFile) |  | ||||||
|                     .filter(p -> p.getFileName().toString().matches("messages_[a-z]{2}\\.json")) |  | ||||||
|                     .forEach(p -> replaceInFile(p, searchText, replacementText)); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private static void replaceInFile(Path path, String searchText, String replacementText) { |  | ||||||
|         try { |  | ||||||
|             String content = Files.readString(path); |  | ||||||
|             if (content.contains(searchText)) { |  | ||||||
|                 content = content.replaceAll(searchText, replacementText); |  | ||||||
|                 Files.writeString(path, content); |  | ||||||
|             } |  | ||||||
|         } catch (IOException e) { |  | ||||||
|             e.printStackTrace(); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -94,6 +94,11 @@ public class FaweRegionManager extends BukkitRegionManager { | |||||||
|         delegate.swap(pos1, pos2, swapPos, whenDone); |         delegate.swap(pos1, pos2, swapPos, whenDone); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void setBiome(CuboidRegion region, int extendBiome, BiomeType biome, String world, Runnable whenDone) { | ||||||
|  |         delegate.setBiome(region, extendBiome, biome, world, whenDone); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void setBiome(CuboidRegion region, int extendBiome, BiomeType biome, PlotArea area, Runnable whenDone) { |     public void setBiome(CuboidRegion region, int extendBiome, BiomeType biome, PlotArea area, Runnable whenDone) { | ||||||
|         delegate.setBiome(region, extendBiome, biome, area.getWorldName(), whenDone); |         delegate.setBiome(region, extendBiome, biome, area.getWorldName(), whenDone); | ||||||
|   | |||||||
| @@ -80,3 +80,4 @@ public class FaweSchematicHandler extends SchematicHandler { | |||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -65,19 +65,12 @@ tasks.processResources { | |||||||
|  |  | ||||||
| tasks { | tasks { | ||||||
|     withType<Javadoc> { |     withType<Javadoc> { | ||||||
|         val isRelease = if (rootProject.version.toString().endsWith("-SNAPSHOT")) "TODO" else rootProject.version.toString() |  | ||||||
|         val opt = options as StandardJavadocDocletOptions |         val opt = options as StandardJavadocDocletOptions | ||||||
|         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-core/" + libs.worldeditCore.get().versionConstraint.toString()) |         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-core/" + libs.worldeditCore.get().versionConstraint.toString()) | ||||||
|         opt.links("https://jd.adventure.kyori.net/api/4.12.0/") |         opt.links("https://jd.adventure.kyori.net/api/4.9.3/") | ||||||
|         opt.links("https://jd.adventure.kyori.net/text-minimessage/4.12.0/") |  | ||||||
|         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") |         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") | ||||||
|         opt.links("https://checkerframework.org/api/") |         opt.links("https://checkerframework.org/api/") | ||||||
|         opt.links("https://javadoc.io/doc/com.intellectualsites.informative-annotations/informative-annotations/latest/") |         opt.links("https://javadoc.io/doc/com.intellectualsites.informative-annotations/informative-annotations/latest/") | ||||||
|         opt.isLinkSource = true |  | ||||||
|         opt.bottom(File("$rootDir/javadocfooter.html").readText()) |  | ||||||
|         opt.isUse = true |  | ||||||
|         opt.encoding("UTF-8") |         opt.encoding("UTF-8") | ||||||
|         opt.keyWords() |  | ||||||
|         opt.addStringOption("-since", isRelease) |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -30,7 +30,7 @@ import com.plotsquared.core.util.ChunkManager; | |||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.SchematicHandler; | import com.plotsquared.core.util.SchematicHandler; | ||||||
| import com.plotsquared.core.util.query.PlotQuery; | import com.plotsquared.core.util.query.PlotQuery; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
| @@ -145,7 +145,7 @@ public class PlotAPI { | |||||||
|      */ |      */ | ||||||
|     public void sendConsoleMessage( |     public void sendConsoleMessage( | ||||||
|             final @NonNull String message, |             final @NonNull String message, | ||||||
|             final @NonNull TagResolver @NonNull ... replacements |             final @NonNull Template @NonNull ... replacements | ||||||
|     ) { |     ) { | ||||||
|         ConsolePlayer.getConsole().sendMessage(StaticCaption.of(message), replacements); |         ConsolePlayer.getConsole().sendMessage(StaticCaption.of(message), replacements); | ||||||
|     } |     } | ||||||
| @@ -158,7 +158,7 @@ public class PlotAPI { | |||||||
|      */ |      */ | ||||||
|     public void sendConsoleMessage( |     public void sendConsoleMessage( | ||||||
|             final @NonNull Caption caption, |             final @NonNull Caption caption, | ||||||
|             final @NonNull TagResolver @NonNull ... replacements |             final @NonNull Template @NonNull ... replacements | ||||||
|     ) { |     ) { | ||||||
|         ConsolePlayer.getConsole().sendMessage(caption, replacements); |         ConsolePlayer.getConsole().sendMessage(caption, replacements); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -790,9 +790,7 @@ public class PlotSquared { | |||||||
|         if (world.equals("CheckingPlotSquaredGenerator")) { |         if (world.equals("CheckingPlotSquaredGenerator")) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (!this.getPlotAreaManager().addWorld(world)) { |         this.getPlotAreaManager().addWorld(world); | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         Set<String> worlds; |         Set<String> worlds; | ||||||
|         if (this.worldConfiguration.contains("worlds")) { |         if (this.worldConfiguration.contains("worlds")) { | ||||||
|             worlds = this.worldConfiguration.getConfigurationSection("worlds").getKeys(false); |             worlds = this.worldConfiguration.getConfigurationSection("worlds").getKeys(false); | ||||||
|   | |||||||
| @@ -200,7 +200,7 @@ public class PlayerBackupProfile implements BackupProfile { | |||||||
|                                     if (value) { |                                     if (value) { | ||||||
|                                         future.complete(null); |                                         future.complete(null); | ||||||
|                                     } else { |                                     } else { | ||||||
|                                         future.completeExceptionally(new RuntimeException(MINI_MESSAGE.escapeTags( |                                         future.completeExceptionally(new RuntimeException(MINI_MESSAGE.stripTokens( | ||||||
|                                                 TranslatableCaption |                                                 TranslatableCaption | ||||||
|                                                         .of("schematics.schematic_paste_failed") |                                                         .of("schematics.schematic_paste_failed") | ||||||
|                                                         .getComponent(ConsolePlayer.getConsole())))); |                                                         .getComponent(ConsolePlayer.getConsole())))); | ||||||
|   | |||||||
| @@ -24,14 +24,13 @@ import com.google.inject.Inject; | |||||||
| import com.google.inject.Singleton; | import com.google.inject.Singleton; | ||||||
| import com.plotsquared.core.PlotSquared; | import com.plotsquared.core.PlotSquared; | ||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
|  | import com.plotsquared.core.configuration.caption.Templates; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.inject.factory.PlayerBackupProfileFactory; | import com.plotsquared.core.inject.factory.PlayerBackupProfileFactory; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
| @@ -101,7 +100,7 @@ public class SimpleBackupManager implements BackupManager { | |||||||
|             if (player != null) { |             if (player != null) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("backups.backup_automatic_started"), |                         TranslatableCaption.of("backups.backup_automatic_started"), | ||||||
|                         TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                         Template.of("plot", plot.getId().toString()) | ||||||
|                 ); |                 ); | ||||||
|             } |             } | ||||||
|             profile.createBackup().whenComplete((backup, throwable) -> { |             profile.createBackup().whenComplete((backup, throwable) -> { | ||||||
| @@ -109,7 +108,7 @@ public class SimpleBackupManager implements BackupManager { | |||||||
|                     if (player != null) { |                     if (player != null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("backups.backup_automatic_failure"), |                                 TranslatableCaption.of("backups.backup_automatic_failure"), | ||||||
|                                 TagResolver.resolver("reason", Tag.inserting(Component.text(throwable.getMessage()))) |                                 Templates.of("reason", throwable.getMessage()) | ||||||
|                         ); |                         ); | ||||||
|                     } |                     } | ||||||
|                     throwable.printStackTrace(); |                     throwable.printStackTrace(); | ||||||
|   | |||||||
| @@ -26,13 +26,12 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.PlayerManager; | import com.plotsquared.core.util.PlayerManager; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| @@ -59,20 +58,19 @@ public class Add extends Command { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public CompletableFuture<Boolean> execute( |     public CompletableFuture<Boolean> execute( | ||||||
|             final PlotPlayer<?> player, |             final PlotPlayer<?> player, String[] args, | ||||||
|             String[] args, |  | ||||||
|             RunnableVal3<Command, Runnable, Runnable> confirm, |             RunnableVal3<Command, Runnable, Runnable> confirm, | ||||||
|             RunnableVal2<Command, CommandResult> whenDone |             RunnableVal2<Command, CommandResult> whenDone | ||||||
|     ) throws CommandException { |     ) throws CommandException { | ||||||
|         final Plot plot = check(player.getCurrentPlot(), TranslatableCaption.of("errors.not_in_plot")); |         final Plot plot = check(player.getCurrentPlot(), TranslatableCaption.of("errors.not_in_plot")); | ||||||
|         checkTrue(plot.hasOwner(), TranslatableCaption.of("info.plot_unowned")); |         checkTrue(plot.hasOwner(), TranslatableCaption.of("info.plot_unowned")); | ||||||
|         checkTrue( |         checkTrue( | ||||||
|                 plot.isOwner(player.getUUID()) || player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_TRUST), |                 plot.isOwner(player.getUUID()) || Permissions | ||||||
|  |                         .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_TRUST), | ||||||
|                 TranslatableCaption.of("permission.no_plot_perms") |                 TranslatableCaption.of("permission.no_plot_perms") | ||||||
|         ); |         ); | ||||||
|         checkTrue(args.length == 1, |         checkTrue(args.length == 1, TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                 TranslatableCaption.of("commandconfig.command_syntax"), |                 Template.of("value", "/plot add <player | *>") | ||||||
|                 TagResolver.resolver("value", Tag.inserting(Component.text("/plot add <player | *>"))) |  | ||||||
|         ); |         ); | ||||||
|         final CompletableFuture<Boolean> future = new CompletableFuture<>(); |         final CompletableFuture<Boolean> future = new CompletableFuture<>(); | ||||||
|         PlayerManager.getUUIDsFromString(args[0], (uuids, throwable) -> { |         PlayerManager.getUUIDsFromString(args[0], (uuids, throwable) -> { | ||||||
| @@ -82,7 +80,7 @@ public class Add extends Command { | |||||||
|                 } else { |                 } else { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("errors.invalid_player"), |                             TranslatableCaption.of("errors.invalid_player"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) |                             Template.of("value", args[0]) | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|                 future.completeExceptionally(throwable); |                 future.completeExceptionally(throwable); | ||||||
| @@ -90,19 +88,18 @@ public class Add extends Command { | |||||||
|             } else { |             } else { | ||||||
|                 try { |                 try { | ||||||
|                     checkTrue(!uuids.isEmpty(), TranslatableCaption.of("errors.invalid_player"), |                     checkTrue(!uuids.isEmpty(), TranslatableCaption.of("errors.invalid_player"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) |                             Template.of("value", args[0]) | ||||||
|                     ); |                     ); | ||||||
|                     Iterator<UUID> iterator = uuids.iterator(); |                     Iterator<UUID> iterator = uuids.iterator(); | ||||||
|                     int size = plot.getTrusted().size() + plot.getMembers().size(); |                     int size = plot.getTrusted().size() + plot.getMembers().size(); | ||||||
|                     while (iterator.hasNext()) { |                     while (iterator.hasNext()) { | ||||||
|                         UUID uuid = iterator.next(); |                         UUID uuid = iterator.next(); | ||||||
|                         if (uuid == DBFunc.EVERYONE && !(player.hasPermission(Permission.PERMISSION_TRUST_EVERYONE) || player.hasPermission( |                         if (uuid == DBFunc.EVERYONE && !( | ||||||
|                                 Permission.PERMISSION_ADMIN_COMMAND_TRUST))) { |                                 Permissions.hasPermission(player, Permission.PERMISSION_TRUST_EVERYONE) || Permissions | ||||||
|  |                                         .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_TRUST))) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("errors.invalid_player"), |                                     TranslatableCaption.of("errors.invalid_player"), | ||||||
|                                     TagResolver.resolver("value", Tag.inserting( |                                     Template.of("value", PlayerManager.resolveName(uuid).getComponent(player)) | ||||||
|                                             PlayerManager.resolveName(uuid).toComponent(player) |  | ||||||
|                                     )) |  | ||||||
|                             ); |                             ); | ||||||
|                             iterator.remove(); |                             iterator.remove(); | ||||||
|                             continue; |                             continue; | ||||||
| @@ -110,9 +107,7 @@ public class Add extends Command { | |||||||
|                         if (plot.isOwner(uuid)) { |                         if (plot.isOwner(uuid)) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("member.already_added"), |                                     TranslatableCaption.of("member.already_added"), | ||||||
|                                     TagResolver.resolver("player", Tag.inserting( |                                     Template.of("player", PlayerManager.resolveName(uuid).getComponent(player)) | ||||||
|                                             PlayerManager.resolveName(uuid).toComponent(player) |  | ||||||
|                                     )) |  | ||||||
|                             ); |                             ); | ||||||
|                             iterator.remove(); |                             iterator.remove(); | ||||||
|                             continue; |                             continue; | ||||||
| @@ -120,9 +115,7 @@ public class Add extends Command { | |||||||
|                         if (plot.getMembers().contains(uuid)) { |                         if (plot.getMembers().contains(uuid)) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("member.already_added"), |                                     TranslatableCaption.of("member.already_added"), | ||||||
|                                     TagResolver.resolver("player", Tag.inserting( |                                     Template.of("player", PlayerManager.resolveName(uuid).getComponent(player)) | ||||||
|                                             PlayerManager.resolveName(uuid).toComponent(player) |  | ||||||
|                                     )) |  | ||||||
|                             ); |                             ); | ||||||
|                             iterator.remove(); |                             iterator.remove(); | ||||||
|                             continue; |                             continue; | ||||||
| @@ -131,11 +124,11 @@ public class Add extends Command { | |||||||
|                     } |                     } | ||||||
|                     checkTrue(!uuids.isEmpty(), null); |                     checkTrue(!uuids.isEmpty(), null); | ||||||
|                     int localAddSize = plot.getMembers().size(); |                     int localAddSize = plot.getMembers().size(); | ||||||
|                     int maxAddSize = player.hasPermissionRange(Permission.PERMISSION_ADD, Settings.Limit.MAX_PLOTS); |                     int maxAddSize = Permissions.hasPermissionRange(player, Permission.PERMISSION_ADD, Settings.Limit.MAX_PLOTS); | ||||||
|                     if (localAddSize >= maxAddSize) { |                     if (localAddSize >= maxAddSize) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("members.plot_max_members_added"), |                                 TranslatableCaption.of("members.plot_max_members_added"), | ||||||
|                                 TagResolver.resolver("amount", Tag.inserting(Component.text(localAddSize))) |                                 Template.of("amount", String.valueOf(localAddSize)) | ||||||
|                         ); |                         ); | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|   | |||||||
| @@ -26,10 +26,9 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.query.PlotQuery; | import com.plotsquared.core.util.query.PlotQuery; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| @@ -93,10 +92,7 @@ public class Alias extends SubCommand { | |||||||
|                 } else { |                 } else { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ALIAS_SET)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ALIAS_SET) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -112,10 +108,7 @@ public class Alias extends SubCommand { | |||||||
|                 } else { |                 } else { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_ALIAS_REMOVE)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_ALIAS_REMOVE) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -156,16 +149,13 @@ public class Alias extends SubCommand { | |||||||
|                     .anyMatch()) { |                     .anyMatch()) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("alias.alias_is_taken"), |                         TranslatableCaption.of("alias.alias_is_taken"), | ||||||
|                         TagResolver.resolver("alias", Tag.inserting(Component.text(alias))) |                         Template.of("alias", alias) | ||||||
|                 ); |                 ); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (Settings.UUID.OFFLINE) { |             if (Settings.UUID.OFFLINE) { | ||||||
|                 plot.setAlias(alias); |                 plot.setAlias(alias); | ||||||
|                 player.sendMessage( |                 player.sendMessage(TranslatableCaption.of("alias.alias_set_to"), Template.of("alias", alias)); | ||||||
|                         TranslatableCaption.of("alias.alias_set_to"), |  | ||||||
|                         TagResolver.resolver("alias", Tag.inserting(Component.text(alias))) |  | ||||||
|                 ); |  | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             PlotSquared.get().getImpromptuUUIDPipeline().getSingle(alias, ((uuid, throwable) -> { |             PlotSquared.get().getImpromptuUUIDPipeline().getSingle(alias, ((uuid, throwable) -> { | ||||||
| @@ -174,13 +164,13 @@ public class Alias extends SubCommand { | |||||||
|                 } else if (uuid != null) { |                 } else if (uuid != null) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("alias.alias_is_taken"), |                             TranslatableCaption.of("alias.alias_is_taken"), | ||||||
|                             TagResolver.resolver("alias", Tag.inserting(Component.text(alias))) |                             Template.of("alias", alias) | ||||||
|                     ); |                     ); | ||||||
|                 } else { |                 } else { | ||||||
|                     plot.setAlias(alias); |                     plot.setAlias(alias); | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("alias.alias_set_to"), |                             TranslatableCaption.of("alias.alias_set_to"), | ||||||
|                             TagResolver.resolver("alias", Tag.inserting(Component.text(alias))) |                             Template.of("alias", alias) | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|             })); |             })); | ||||||
| @@ -192,7 +182,7 @@ public class Alias extends SubCommand { | |||||||
|         if (!plot.getAlias().isEmpty()) { |         if (!plot.getAlias().isEmpty()) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("alias.alias_removed"), |                     TranslatableCaption.of("alias.alias_removed"), | ||||||
|                     TagResolver.resolver("alias", Tag.inserting(Component.text(alias))) |                     Template.of("alias", alias) | ||||||
|             ); |             ); | ||||||
|         } else { |         } else { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
| @@ -204,7 +194,7 @@ public class Alias extends SubCommand { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     private boolean isPermitted(PlotPlayer<?> player, Permission permission) { |     private boolean isPermitted(PlotPlayer<?> player, Permission permission) { | ||||||
|         return player.hasPermission(permission); |         return Permissions.hasPermission(player, permission); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -24,6 +24,7 @@ import com.plotsquared.core.configuration.ConfigurationSection; | |||||||
| import com.plotsquared.core.configuration.ConfigurationUtil; | import com.plotsquared.core.configuration.ConfigurationUtil; | ||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.CaptionHolder; | import com.plotsquared.core.configuration.caption.CaptionHolder; | ||||||
|  | import com.plotsquared.core.configuration.caption.Templates; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.configuration.file.YamlConfiguration; | import com.plotsquared.core.configuration.file.YamlConfiguration; | ||||||
| import com.plotsquared.core.events.TeleportCause; | import com.plotsquared.core.events.TeleportCause; | ||||||
| @@ -47,6 +48,7 @@ import com.plotsquared.core.queue.QueueCoordinator; | |||||||
| import com.plotsquared.core.setup.PlotAreaBuilder; | import com.plotsquared.core.setup.PlotAreaBuilder; | ||||||
| import com.plotsquared.core.util.FileUtils; | import com.plotsquared.core.util.FileUtils; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.RegionUtil; | import com.plotsquared.core.util.RegionUtil; | ||||||
| import com.plotsquared.core.util.SchematicHandler; | import com.plotsquared.core.util.SchematicHandler; | ||||||
| import com.plotsquared.core.util.SetupUtils; | import com.plotsquared.core.util.SetupUtils; | ||||||
| @@ -67,9 +69,7 @@ import com.sk89q.worldedit.math.BlockVector3; | |||||||
| import com.sk89q.worldedit.regions.CuboidRegion; | import com.sk89q.worldedit.regions.CuboidRegion; | ||||||
| import com.sk89q.worldedit.regions.Region; | import com.sk89q.worldedit.regions.Region; | ||||||
| import com.sk89q.worldedit.world.World; | import com.sk89q.worldedit.world.World; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.io.File; | import java.io.File; | ||||||
| @@ -138,20 +138,17 @@ public class Area extends SubCommand { | |||||||
|                     player.sendMessage(RequiredType.CONSOLE.getErrorMessage()); |                     player.sendMessage(RequiredType.CONSOLE.getErrorMessage()); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_AREA_CREATE)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_AREA_CREATE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_AREA_CREATE)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_AREA_CREATE) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (args.length < 2) { |                 if (args.length < 2) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("single.single_area_needs_name"), |                             TranslatableCaption.of("single.single_area_needs_name"), | ||||||
|                             TagResolver.resolver("command", Tag.inserting(Component.text("/plot area single <name>"))) |                             Template.of("command", "/plot area single <name>") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -283,7 +280,7 @@ public class Area extends SubCommand { | |||||||
|                     } else { |                     } else { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("errors.error_create"), |                                 TranslatableCaption.of("errors.error_create"), | ||||||
|                                 TagResolver.resolver("world", Tag.inserting(Component.text(hybridPlotWorld.getWorldName()))) |                                 Template.of("world", hybridPlotWorld.getWorldName()) | ||||||
|                         ); |                         ); | ||||||
|                     } |                     } | ||||||
|                 }; |                 }; | ||||||
| @@ -291,13 +288,10 @@ public class Area extends SubCommand { | |||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "c", "setup", "create" -> { |             case "c", "setup", "create" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_AREA_CREATE)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_AREA_CREATE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_AREA_CREATE)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_AREA_CREATE) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -305,10 +299,7 @@ public class Area extends SubCommand { | |||||||
|                     case 1: |                     case 1: | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("commandconfig.command_syntax"), |                                 TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                                 TagResolver.resolver( |                                 Templates.of("value", "/plot area create [world[:id]] [<modifier>=<value>]...") | ||||||
|                                         "value", |  | ||||||
|                                         Tag.inserting(Component.text("/plot area create [world[:id]] [<modifier>=<value>]...")) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     case 2: |                     case 2: | ||||||
| @@ -322,11 +313,7 @@ public class Area extends SubCommand { | |||||||
|                                 if (area == null) { |                                 if (area == null) { | ||||||
|                                     player.sendMessage( |                                     player.sendMessage( | ||||||
|                                             TranslatableCaption.of("commandconfig.command_syntax"), |                                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                                             TagResolver.resolver( |                                             Templates.of("value", "/plot area create [world[:id]] [<modifier>=<value>]...") | ||||||
|                                                     "value", |  | ||||||
|                                                     Tag.inserting(Component.text( |  | ||||||
|                                                             "/plot area create [world[:id]] [<modifier>=<value>]...")) |  | ||||||
|                                             ) |  | ||||||
|                                     ); |                                     ); | ||||||
|                                     return false; |                                     return false; | ||||||
|                                 } |                                 } | ||||||
| @@ -337,18 +324,12 @@ public class Area extends SubCommand { | |||||||
|                                 ); |                                 ); | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("set.set_attribute"), |                                         TranslatableCaption.of("set.set_attribute"), | ||||||
|                                         TagResolver.builder() |                                         Template.of("attribute", "area_pos1"), | ||||||
|                                                 .tag("attribute", Tag.inserting(Component.text("area_pos1"))) |                                         Template.of("value", location.getX() + "," + location.getZ()) | ||||||
|                                                 .tag("value", Tag.inserting( |  | ||||||
|                                                         Component.text(location.getX()) |  | ||||||
|                                                                 .append(Component.text(",")) |  | ||||||
|                                                                 .append(Component.text(location.getZ())) |  | ||||||
|                                                 )) |  | ||||||
|                                                 .build() |  | ||||||
|                                 ); |                                 ); | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("area.set_pos2"), |                                         TranslatableCaption.of("area.set_pos2"), | ||||||
|                                         TagResolver.resolver("command", Tag.inserting(Component.text("/plot area create pos2"))) |                                         Template.of("command", "/plot area create pos2") | ||||||
|                                 ); |                                 ); | ||||||
|                                 return true; |                                 return true; | ||||||
|                             } |                             } | ||||||
| @@ -362,11 +343,7 @@ public class Area extends SubCommand { | |||||||
|                                 if (area == null) { |                                 if (area == null) { | ||||||
|                                     player.sendMessage( |                                     player.sendMessage( | ||||||
|                                             TranslatableCaption.of("commandconfig.command_syntax"), |                                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                                             TagResolver.resolver( |                                             Templates.of("value", "/plot area create [world[:id]] [<modifier>=<value>]...") | ||||||
|                                                     "value", |  | ||||||
|                                                     Tag.inserting(Component.text( |  | ||||||
|                                                             "/plot area create [world[:id]] [<modifier>=<value>]...")) |  | ||||||
|                                             ) |  | ||||||
|                                     ); |                                     ); | ||||||
|                                     return false; |                                     return false; | ||||||
|                                 } |                                 } | ||||||
| @@ -393,10 +370,7 @@ public class Area extends SubCommand { | |||||||
|                                 if (!areas.isEmpty()) { |                                 if (!areas.isEmpty()) { | ||||||
|                                     player.sendMessage( |                                     player.sendMessage( | ||||||
|                                             TranslatableCaption.of("cluster.cluster_intersection"), |                                             TranslatableCaption.of("cluster.cluster_intersection"), | ||||||
|                                             TagResolver.resolver( |                                             Template.of("cluster", areas.iterator().next().toString()) | ||||||
|                                                     "cluster", |  | ||||||
|                                                     Tag.inserting(areas.iterator().next()) |  | ||||||
|                                             ) |  | ||||||
|                                     ); |                                     ); | ||||||
|                                     return false; |                                     return false; | ||||||
|                                 } |                                 } | ||||||
| @@ -422,7 +396,8 @@ public class Area extends SubCommand { | |||||||
|                                         player.sendMessage(TranslatableCaption.of("setup.setup_finished")); |                                         player.sendMessage(TranslatableCaption.of("setup.setup_finished")); | ||||||
|                                         if (area.getTerrain() != PlotAreaTerrainType.ALL) { |                                         if (area.getTerrain() != PlotAreaTerrainType.ALL) { | ||||||
|                                             QueueCoordinator queue = blockQueue.getNewQueue(worldUtil.getWeWorld(world)); |                                             QueueCoordinator queue = blockQueue.getNewQueue(worldUtil.getWeWorld(world)); | ||||||
|                                             queue.setChunkConsumer(chunk -> AugmentedUtils.generateChunk( |                                             queue.setChunkConsumer(chunk -> AugmentedUtils.generate( | ||||||
|  |                                                     null, | ||||||
|                                                     world, |                                                     world, | ||||||
|                                                     chunk.getX(), |                                                     chunk.getX(), | ||||||
|                                                     chunk.getZ(), |                                                     chunk.getZ(), | ||||||
| @@ -434,7 +409,7 @@ public class Area extends SubCommand { | |||||||
|                                     } else { |                                     } else { | ||||||
|                                         player.sendMessage( |                                         player.sendMessage( | ||||||
|                                                 TranslatableCaption.of("errors.error_create"), |                                                 TranslatableCaption.of("errors.error_create"), | ||||||
|                                                 TagResolver.resolver("world", Tag.inserting(Component.text(area.getWorldName()))) |                                                 Template.of("world", area.getWorldName()) | ||||||
|                                         ); |                                         ); | ||||||
|                                     } |                                     } | ||||||
|                                 }; |                                 }; | ||||||
| @@ -468,7 +443,7 @@ public class Area extends SubCommand { | |||||||
|                         if (other != null && Objects.equals(pa.getId(), other.getId())) { |                         if (other != null && Objects.equals(pa.getId(), other.getId())) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("setup.setup_world_taken"), |                                     TranslatableCaption.of("setup.setup_world_taken"), | ||||||
|                                     TagResolver.resolver("value", Tag.inserting(Component.text(pa.getId()))) |                                     Template.of("value", pa.toString()) | ||||||
|                             ); |                             ); | ||||||
|                             return false; |                             return false; | ||||||
|                         } |                         } | ||||||
| @@ -483,13 +458,8 @@ public class Area extends SubCommand { | |||||||
|                             if (pair.length != 2) { |                             if (pair.length != 2) { | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("commandconfig.command_syntax_extended"), |                                         TranslatableCaption.of("commandconfig.command_syntax_extended"), | ||||||
|                                         TagResolver.builder() |                                         Template.of("value1,", getCommandString()), | ||||||
|                                                 .tag("value1", Tag.inserting(Component.text(getCommandString()))) |                                         Template.of("value2", " create [world[:id]] [<modifier>=<value>]...") | ||||||
|                                                 .tag( |  | ||||||
|                                                         "value2", |  | ||||||
|                                                         Tag.inserting(Component.text("create [world[:id]] [<modifier>=<value>]...")) |  | ||||||
|                                                 ) |  | ||||||
|                                                 .build() |  | ||||||
|                                 ); |                                 ); | ||||||
|                                 return false; |                                 return false; | ||||||
|                             } |                             } | ||||||
| @@ -525,14 +495,8 @@ public class Area extends SubCommand { | |||||||
|                                 default -> { |                                 default -> { | ||||||
|                                     player.sendMessage( |                                     player.sendMessage( | ||||||
|                                             TranslatableCaption.of("commandconfig.command_syntax_extended"), |                                             TranslatableCaption.of("commandconfig.command_syntax_extended"), | ||||||
|                                             TagResolver.builder() |                                             Template.of("value1", getCommandString()), | ||||||
|                                                     .tag("value1", Tag.inserting(Component.text(getCommandString()))) |                                             Template.of("value2", " create [world[:id]] [<modifier>=<value>]...") | ||||||
|                                                     .tag( |  | ||||||
|                                                             "value2", |  | ||||||
|                                                             Tag.inserting(Component.text( |  | ||||||
|                                                                     " create [world[:id]] [<modifier>=<value>]...")) |  | ||||||
|                                                     ) |  | ||||||
|                                                     .build() |  | ||||||
|                                     ); |                                     ); | ||||||
|                                     return false; |                                     return false; | ||||||
|                                 } |                                 } | ||||||
| @@ -542,7 +506,7 @@ public class Area extends SubCommand { | |||||||
|                             if (this.worldUtil.isWorld(pa.getWorldName())) { |                             if (this.worldUtil.isWorld(pa.getWorldName())) { | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("setup.setup_world_taken"), |                                         TranslatableCaption.of("setup.setup_world_taken"), | ||||||
|                                         TagResolver.resolver("value", Tag.inserting(Component.text(pa.getWorldName()))) |                                         Template.of("value", pa.getWorldName()) | ||||||
|                                 ); |                                 ); | ||||||
|                                 return false; |                                 return false; | ||||||
|                             } |                             } | ||||||
| @@ -563,7 +527,7 @@ public class Area extends SubCommand { | |||||||
|                                 } else { |                                 } else { | ||||||
|                                     player.sendMessage( |                                     player.sendMessage( | ||||||
|                                             TranslatableCaption.of("errors.error_create"), |                                             TranslatableCaption.of("errors.error_create"), | ||||||
|                                             TagResolver.resolver("world", Tag.inserting(Component.text(pa.getWorldName()))) |                                             Template.of("world", pa.getWorldName()) | ||||||
|                                     ); |                                     ); | ||||||
|                                 } |                                 } | ||||||
|                                 try { |                                 try { | ||||||
| @@ -582,18 +546,12 @@ public class Area extends SubCommand { | |||||||
|                         if (pa.getId() == null) { |                         if (pa.getId() == null) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("commandconfig.command_syntax"), |                                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                                     TagResolver.resolver("value", Tag.inserting(Component.text(getUsage()))) |                                     Template.of("value", getUsage()) | ||||||
|                             ); |                             ); | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("commandconfig.command_syntax_extended"), |                                     TranslatableCaption.of("commandconfig.command_syntax_extended"), | ||||||
|                                     TagResolver.builder() |                                     Template.of("value1", getCommandString()), | ||||||
|                                             .tag("value1", Tag.inserting(Component.text(getCommandString()))) |                                     Template.of("value2", " create [world[:id]] [<modifier>=<value>]...") | ||||||
|                                             .tag( |  | ||||||
|                                                     "value2", |  | ||||||
|                                                     Tag.inserting(Component.text( |  | ||||||
|                                                             " create [world[:id]] [<modifier>=<value>]...")) |  | ||||||
|                                             ) |  | ||||||
|                                             .build() |  | ||||||
|                             ); |                             ); | ||||||
|                             return false; |                             return false; | ||||||
|                         } |                         } | ||||||
| @@ -610,20 +568,17 @@ public class Area extends SubCommand { | |||||||
|                         metaData.computeIfAbsent(player.getUUID(), missingUUID -> new HashMap<>()).put("area_create_area", pa); |                         metaData.computeIfAbsent(player.getUUID(), missingUUID -> new HashMap<>()).put("area_create_area", pa); | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("single.get_position"), |                                 TranslatableCaption.of("single.get_position"), | ||||||
|                                 TagResolver.resolver("command", Tag.inserting(Component.text(getCommandString()))) |                                 Template.of("command", getCommandString()) | ||||||
|                         ); |                         ); | ||||||
|                         break; |                         break; | ||||||
|                 } |                 } | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "i", "info" -> { |             case "i", "info" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_AREA_INFO)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_AREA_INFO)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_AREA_INFO)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_AREA_INFO) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -634,20 +589,15 @@ public class Area extends SubCommand { | |||||||
|                     default -> { |                     default -> { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("commandconfig.command_syntax_extended"), |                                 TranslatableCaption.of("commandconfig.command_syntax_extended"), | ||||||
|                                 TagResolver.builder() |                                 Template.of("value1", getCommandString()), | ||||||
|                                         .tag("value1", Tag.inserting(Component.text(getCommandString()))) |                                 Template.of("value2", " info [area]") | ||||||
|                                         .tag("value2", Tag.inserting(Component.text(" info [area]"))) |  | ||||||
|                                         .build() |  | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 if (area == null) { |                 if (area == null) { | ||||||
|                     if (args.length == 2) { |                     if (args.length == 2) { | ||||||
|                         player.sendMessage( |                         player.sendMessage(TranslatableCaption.of("errors.not_valid_plot_world"), Template.of("value", args[1])); | ||||||
|                                 TranslatableCaption.of("errors.not_valid_plot_world"), |  | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(args[1]))) |  | ||||||
|                         ); |  | ||||||
|                     } else { |                     } else { | ||||||
|                         player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); |                         player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||||
|                     } |                     } | ||||||
| @@ -671,35 +621,42 @@ public class Area extends SubCommand { | |||||||
|                     percent = claimed == 0 ? 0 : 100d * claimed / Integer.MAX_VALUE; |                     percent = claimed == 0 ? 0 : 100d * claimed / Integer.MAX_VALUE; | ||||||
|                     region = "N/A"; |                     region = "N/A"; | ||||||
|                 } |                 } | ||||||
|                 TagResolver resolver = TagResolver.builder() |                 Template headerTemplate = Template.of( | ||||||
|                         .tag( |                         "header", | ||||||
|                                 "header", |                         TranslatableCaption.of("info.plot_info_header").getComponent(player) | ||||||
|                                 Tag.inserting(TranslatableCaption.of("info.plot_info_header").toComponent(player)) |                 ); | ||||||
|                         ) |                 Template nameTemplate = Template.of("name", name); | ||||||
|                         .tag("name", Tag.inserting(Component.text(name))) |                 Template typeTemplate = Template.of("type", area.getType().name()); | ||||||
|                         .tag("type", Tag.inserting(Component.text(area.getType().name()))) |                 Template terrainTemplate = Template.of("terrain", area.getTerrain().name()); | ||||||
|                         .tag("terrain", Tag.inserting(Component.text(area.getTerrain().name()))) |                 Template usageTemplate = Template.of("usage", String.format("%.2f", percent)); | ||||||
|                         .tag("usage", Tag.inserting(Component.text(String.format("%.2f", percent)))) |                 Template claimedTemplate = Template.of("claimed", String.valueOf(claimed)); | ||||||
|                         .tag("claimed", Tag.inserting(Component.text(claimed))) |                 Template clustersTemplate = Template.of("clusters", String.valueOf(clusters)); | ||||||
|                         .tag("clusters", Tag.inserting(Component.text(clusters))) |                 Template regionTemplate = Template.of("region", region); | ||||||
|                         .tag("region", Tag.inserting(Component.text(region))) |                 Template generatorTemplate = Template.of("generator", generator); | ||||||
|                         .tag("generator", Tag.inserting(Component.text(generator))) |                 Template footerTemplate = Template.of( | ||||||
|                         .tag( |                         "footer", | ||||||
|                                 "footer", |                         TranslatableCaption.of("info.plot_info_footer").getComponent(player) | ||||||
|                                 Tag.inserting(TranslatableCaption.of("info.plot_info_footer").toComponent(player)) |                 ); | ||||||
|                         ) |                 player.sendMessage( | ||||||
|                         .build(); |                         TranslatableCaption.of("info.area_info_format"), | ||||||
|                 player.sendMessage(TranslatableCaption.of("info.area_info_format"), resolver); |                         headerTemplate, | ||||||
|  |                         nameTemplate, | ||||||
|  |                         typeTemplate, | ||||||
|  |                         terrainTemplate, | ||||||
|  |                         usageTemplate, | ||||||
|  |                         claimedTemplate, | ||||||
|  |                         clustersTemplate, | ||||||
|  |                         regionTemplate, | ||||||
|  |                         generatorTemplate, | ||||||
|  |                         footerTemplate | ||||||
|  |                 ); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "l", "list" -> { |             case "l", "list" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_AREA_LIST)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_AREA_LIST)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_AREA_LIST)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_AREA_LIST) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -716,10 +673,8 @@ public class Area extends SubCommand { | |||||||
|                     default: |                     default: | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("commandconfig.command_syntax_extended"), |                                 TranslatableCaption.of("commandconfig.command_syntax_extended"), | ||||||
|                                 TagResolver.builder() |                                 Template.of("value1", getCommandString()), | ||||||
|                                         .tag("value1", Tag.inserting(Component.text(getCommandString()))) |                                 Template.of("value2", " list [#]") | ||||||
|                                         .tag("value2", Tag.inserting(Component.text(" list [#]"))) |  | ||||||
|                                         .build() |  | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                 } |                 } | ||||||
| @@ -745,39 +700,46 @@ public class Area extends SubCommand { | |||||||
|                             percent = claimed == 0 ? 0 : (double) claimed / Short.MAX_VALUE * Short.MAX_VALUE; |                             percent = claimed == 0 ? 0 : (double) claimed / Short.MAX_VALUE * Short.MAX_VALUE; | ||||||
|                             region = "N/A"; |                             region = "N/A"; | ||||||
|                         } |                         } | ||||||
|                         Component tooltip = MINI_MESSAGE.deserialize( |                         Template claimedTemplate = Template.of("claimed", String.valueOf(claimed)); | ||||||
|                                 TranslatableCaption.of("info.area_list_tooltip").getComponent(player), |                         Template usageTemplate = Template.of("usage", String.format("%.2f", percent) + "%"); | ||||||
|                                 TagResolver.builder() |                         Template clustersTemplate = Template.of("clusters", String.valueOf(clusters)); | ||||||
|                                         .tag("claimed", Tag.inserting(Component.text(claimed))) |                         Template regionTemplate = Template.of("region", region); | ||||||
|                                         .tag("usage", Tag.inserting(Component.text(String.format("%.2f", percent) + "%"))) |                         Template generatorTemplate = Template.of("generator", generator); | ||||||
|                                         .tag("clusters", Tag.inserting(Component.text(clusters))) |                         String tooltip = MINI_MESSAGE.serialize(MINI_MESSAGE | ||||||
|                                         .tag("region", Tag.inserting(Component.text(region))) |                                 .parse( | ||||||
|                                         .tag("generator", Tag.inserting(Component.text(generator))) |                                         TranslatableCaption.of("info.area_list_tooltip").getComponent(player), | ||||||
|                                         .build() |                                         claimedTemplate, | ||||||
|                         ); |                                         usageTemplate, | ||||||
|                         TagResolver resolver = TagResolver.builder() |                                         clustersTemplate, | ||||||
|                                 .tag("hover_info", Tag.inserting(tooltip)) |                                         regionTemplate, | ||||||
|                                 .tag("command_tp", Tag.preProcessParsed("/plot area tp " + name)) |                                         generatorTemplate | ||||||
|                                 .tag("command_info", Tag.preProcessParsed("/plot area info " + name)) |                                 )); | ||||||
|                                 .tag("number", Tag.inserting(Component.text(i))) |                         Template tooltipTemplate = Template.of("hover_info", tooltip); | ||||||
|                                 .tag("area_name", Tag.inserting(Component.text(name))) |                         Template visitcmdTemplate = Template.of("command_tp", "/plot area tp " + area); | ||||||
|                                 .tag("area_type", Tag.inserting(Component.text(area.getType().name()))) |                         Template infocmdTemplate = Template.of("command_info", "/plot area info " + area); | ||||||
|                                 .tag("area_terrain", Tag.inserting(Component.text(area.getTerrain().name()))) |                         Template numberTemplate = Template.of("number", String.valueOf(i)); | ||||||
|                                 .build(); |                         Template nameTemplate = Template.of("area_name", name); | ||||||
|  |                         Template typeTemplate = Template.of("area_type", area.getType().name()); | ||||||
|  |                         Template terrainTemplate = Template.of("area_terrain", area.getTerrain().name()); | ||||||
|                         caption.set(TranslatableCaption.of("info.area_list_item")); |                         caption.set(TranslatableCaption.of("info.area_list_item")); | ||||||
|                         caption.setTagResolvers(resolver); |                         caption.setTemplates( | ||||||
|  |                                 tooltipTemplate, | ||||||
|  |                                 visitcmdTemplate, | ||||||
|  |                                 numberTemplate, | ||||||
|  |                                 nameTemplate, | ||||||
|  |                                 typeTemplate, | ||||||
|  |                                 terrainTemplate, | ||||||
|  |                                 infocmdTemplate | ||||||
|  |                         ); | ||||||
|                     } |                     } | ||||||
|                 }, "/plot area list", TranslatableCaption.of("list.area_list_header_paged")); |                 }, "/plot area list", TranslatableCaption.of("list.area_list_header_paged")); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "regen", "clear", "reset", "regenerate" -> { |             case "regen", "clear", "reset", "regenerate" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_AREA_REGEN)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_AREA_REGEN)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_AREA_REGEN)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_AREA_REGEN) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -789,12 +751,13 @@ public class Area extends SubCommand { | |||||||
|                 if (area.getType() != PlotAreaType.PARTIAL) { |                 if (area.getType() != PlotAreaType.PARTIAL) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("single.delete_world_region"), |                             TranslatableCaption.of("single.delete_world_region"), | ||||||
|                             TagResolver.resolver("world", Tag.inserting(Component.text(area.getWorldName()))) |                             Template.of("world", area.getWorldName()) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 QueueCoordinator queue = blockQueue.getNewQueue(worldUtil.getWeWorld(area.getWorldName())); |                 QueueCoordinator queue = blockQueue.getNewQueue(worldUtil.getWeWorld(area.getWorldName())); | ||||||
|                 queue.setChunkConsumer(chunk -> AugmentedUtils.generateChunk( |                 queue.setChunkConsumer(chunk -> AugmentedUtils.generate( | ||||||
|  |                         null, | ||||||
|                         area.getWorldName(), |                         area.getWorldName(), | ||||||
|                         chunk.getX(), |                         chunk.getX(), | ||||||
|                         chunk.getZ(), |                         chunk.getZ(), | ||||||
| @@ -806,26 +769,23 @@ public class Area extends SubCommand { | |||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "goto", "v", "teleport", "visit", "tp" -> { |             case "goto", "v", "teleport", "visit", "tp" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_AREA_TP)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_AREA_TP)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_AREA_TP)) |                             Template.of("node", String.valueOf(Permission.PERMISSION_AREA_TP)) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (args.length != 2) { |                 if (args.length != 2) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text("/plot area tp [area]"))) |                             Template.of("value", "/plot area tp [area]") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 PlotArea area = this.plotAreaManager.getPlotAreaByString(args[1]); |                 PlotArea area = this.plotAreaManager.getPlotAreaByString(args[1]); | ||||||
|                 if (area == null) { |                 if (area == null) { | ||||||
|                     player.sendMessage( |                     player.sendMessage(TranslatableCaption.of("errors.not_valid_plot_world"), Template.of("value", args[1])); | ||||||
|                             TranslatableCaption.of("errors.not_valid_plot_world"), |  | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text(args[1]))) |  | ||||||
|                     ); |  | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 Location center; |                 Location center; | ||||||
| @@ -865,19 +825,19 @@ public class Area extends SubCommand { | |||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         if (args.length == 1) { |         if (args.length == 1) { | ||||||
|             final List<String> completions = new LinkedList<>(); |             final List<String> completions = new LinkedList<>(); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_AREA_CREATE)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_AREA_CREATE)) { | ||||||
|                 completions.add("create"); |                 completions.add("create"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_AREA_CREATE)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_AREA_CREATE)) { | ||||||
|                 completions.add("single"); |                 completions.add("single"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_AREA_LIST)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_AREA_LIST)) { | ||||||
|                 completions.add("list"); |                 completions.add("list"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_AREA_INFO)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_AREA_INFO)) { | ||||||
|                 completions.add("info"); |                 completions.add("info"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_AREA_TP)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_AREA_TP)) { | ||||||
|                 completions.add("tp"); |                 completions.add("tp"); | ||||||
|             } |             } | ||||||
|             final List<Command> commands = completions.stream().filter(completion -> completion |             final List<Command> commands = completions.stream().filter(completion -> completion | ||||||
| @@ -892,7 +852,7 @@ public class Area extends SubCommand { | |||||||
|                             CommandCategory.ADMINISTRATION |                             CommandCategory.ADMINISTRATION | ||||||
|                     ) { |                     ) { | ||||||
|                     }).collect(Collectors.toCollection(LinkedList::new)); |                     }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_AREA) && args[0].length() > 0) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_AREA) && args[0].length() > 0) { | ||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             return commands; | ||||||
|   | |||||||
| @@ -38,14 +38,13 @@ import com.plotsquared.core.plot.world.PlotAreaManager; | |||||||
| import com.plotsquared.core.services.plots.AutoService; | import com.plotsquared.core.services.plots.AutoService; | ||||||
| import com.plotsquared.core.util.EconHandler; | import com.plotsquared.core.util.EconHandler; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.PlotExpression; | import com.plotsquared.core.util.PlotExpression; | ||||||
| import com.plotsquared.core.util.task.AutoClaimFinishTask; | import com.plotsquared.core.util.task.AutoClaimFinishTask; | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import io.leangen.geantyref.TypeToken; | import io.leangen.geantyref.TypeToken; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
| @@ -111,13 +110,13 @@ public class Auto extends SubCommand { | |||||||
|                     if (diff < 0 && grantedPlots < sizeX * sizeZ) { |                     if (diff < 0 && grantedPlots < sizeX * sizeZ) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.cant_claim_more_plots"), |                                 TranslatableCaption.of("permission.cant_claim_more_plots"), | ||||||
|                                 TagResolver.resolver("amount", Tag.inserting(Component.text(diff + grantedPlots))) |                                 Template.of("amount", String.valueOf(diff + grantedPlots)) | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } else if (diff >= 0 && grantedPlots + diff < sizeX * sizeZ) { |                     } else if (diff >= 0 && grantedPlots + diff < sizeX * sizeZ) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.cant_claim_more_plots"), |                                 TranslatableCaption.of("permission.cant_claim_more_plots"), | ||||||
|                                 TagResolver.resolver("amount", Tag.inserting(Component.text(diff + grantedPlots))) |                                 Template.of("amount", String.valueOf(diff + grantedPlots)) | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } else { |                     } else { | ||||||
| @@ -129,16 +128,15 @@ public class Auto extends SubCommand { | |||||||
|                         } |                         } | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("economy.removed_granted_plot"), |                                 TranslatableCaption.of("economy.removed_granted_plot"), | ||||||
|                                 TagResolver.builder() |                                 Template.of("usedGrants", String.valueOf(grantedPlots - left)), | ||||||
|                                         .tag("usedGrants", Tag.inserting(Component.text(grantedPlots - left))) |                                 Template.of("remainingGrants", String.valueOf(left)) | ||||||
|                                         .tag("remainingGrants", Tag.inserting(Component.text(left))) |  | ||||||
|                                         .build() |  | ||||||
|                         ); |                         ); | ||||||
|                     } |                     } | ||||||
|                 } else { |                 } else { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.cant_claim_more_plots"), |                             TranslatableCaption.of("permission.cant_claim_more_plots"), | ||||||
|                             TagResolver.resolver("amount", Tag.inserting(Component.text(player.getAllowedPlots()))) |                             Template.of("amount", String.valueOf(player.getAllowedPlots()) | ||||||
|  |                             ) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -217,7 +215,7 @@ public class Auto extends SubCommand { | |||||||
|                 } else { |                 } else { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text(getUsage()))) |                             Template.of("value", getUsage()) | ||||||
|                     ); |                     ); | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
| @@ -240,7 +238,7 @@ public class Auto extends SubCommand { | |||||||
|         if (event.getEventResult() == Result.DENY) { |         if (event.getEventResult() == Result.DENY) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("events.event_denied"), |                     TranslatableCaption.of("events.event_denied"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("Auto claim"))) |                     Template.of("value", "Auto claim") | ||||||
|             ); |             ); | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
| @@ -248,17 +246,17 @@ public class Auto extends SubCommand { | |||||||
|         sizeX = event.getSizeX(); |         sizeX = event.getSizeX(); | ||||||
|         sizeZ = event.getSizeZ(); |         sizeZ = event.getSizeZ(); | ||||||
|         schematic = event.getSchematic(); |         schematic = event.getSchematic(); | ||||||
|         if (!force && mega && !player.hasPermission(Permission.PERMISSION_AUTO_MEGA)) { |         if (!force && mega && !Permissions.hasPermission(player, Permission.PERMISSION_AUTO_MEGA)) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_AUTO_MEGA)) |                     Template.of("node", String.valueOf(Permission.PERMISSION_AUTO_MEGA)) | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!force && sizeX * sizeZ > Settings.Claim.MAX_AUTO_AREA) { |         if (!force && sizeX * sizeZ > Settings.Claim.MAX_AUTO_AREA) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.cant_claim_more_plots_num"), |                     TranslatableCaption.of("permission.cant_claim_more_plots_num"), | ||||||
|                     TagResolver.resolver("amount", Tag.inserting(Component.text(Settings.Claim.MAX_AUTO_AREA))) |                     Template.of("amount", String.valueOf(Settings.Claim.MAX_AUTO_AREA)) | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -276,19 +274,19 @@ public class Auto extends SubCommand { | |||||||
|             if (!plotarea.hasSchematic(schematic)) { |             if (!plotarea.hasSchematic(schematic)) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("schematics.schematic_invalid_named"), |                         TranslatableCaption.of("schematics.schematic_invalid_named"), | ||||||
|                         TagResolver.builder() |                         Template.of("schemname", schematic), | ||||||
|                                 .tag("schemname", Tag.inserting(Component.text(schematic))) |                         Template.of("reason", "non-existent") | ||||||
|                                 .tag("reason", Tag.inserting(Component.text("non-existent"))) |  | ||||||
|                                 .build() |  | ||||||
|                 ); |                 ); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             if (!force && !player.hasPermission( |             if (!force && !Permissions.hasPermission( | ||||||
|  |                     player, | ||||||
|                     Permission.PERMISSION_CLAIM_SCHEMATIC.format(schematic) |                     Permission.PERMISSION_CLAIM_SCHEMATIC.format(schematic) | ||||||
|             ) && !player.hasPermission("plots.admin.command.schematic")) { |             ) && !Permissions | ||||||
|  |                     .hasPermission(player, "plots.admin.command.schematic")) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission"), |                         TranslatableCaption.of("permission.no_permission"), | ||||||
|                         TagResolver.resolver("node", Tag.inserting(Component.text("plots.claim.%s0"))) |                         Template.of("node", "plots.claim.%s0") | ||||||
|                 ); |                 ); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
| @@ -307,20 +305,15 @@ public class Auto extends SubCommand { | |||||||
|                 if (!force && this.econHandler.getMoney(player) < cost) { |                 if (!force && this.econHandler.getMoney(player) < cost) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("economy.cannot_afford_plot"), |                             TranslatableCaption.of("economy.cannot_afford_plot"), | ||||||
|                             TagResolver.builder() |                             Template.of("money", this.econHandler.format(cost)), | ||||||
|                                     .tag("money", Tag.inserting(Component.text(this.econHandler.format(cost)))) |                             Template.of("balance", this.econHandler.format(this.econHandler.getMoney(player))) | ||||||
|                                     .tag( |  | ||||||
|                                             "balance", |  | ||||||
|                                             Tag.inserting(Component.text(this.econHandler.format(this.econHandler.getMoney(player)))) |  | ||||||
|                                     ) |  | ||||||
|                                     .build() |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 this.econHandler.withdrawMoney(player, cost); |                 this.econHandler.withdrawMoney(player, cost); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("economy.removed_balance"), |                         TranslatableCaption.of("economy.removed_balance"), | ||||||
|                         TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(cost)))) |                         Template.of("money", this.econHandler.format(cost)) | ||||||
|                 ); |                 ); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @@ -354,7 +347,7 @@ public class Auto extends SubCommand { | |||||||
|             if (!force && mergeEvent.getEventResult() == Result.DENY) { |             if (!force && mergeEvent.getEventResult() == Result.DENY) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("events.event_denied"), |                         TranslatableCaption.of("events.event_denied"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text("Auto merge"))) |                         Template.of("value", "Auto merge") | ||||||
|                 ); |                 ); | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -27,11 +27,10 @@ import com.plotsquared.core.configuration.caption.TranslatableCaption; | |||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.nio.file.Files; | import java.nio.file.Files; | ||||||
| @@ -68,7 +67,7 @@ public final class Backup extends Command { | |||||||
|     private static boolean sendMessage(PlotPlayer<?> player) { |     private static boolean sendMessage(PlotPlayer<?> player) { | ||||||
|         player.sendMessage( |         player.sendMessage( | ||||||
|                 TranslatableCaption.of("commandconfig.command_syntax"), |                 TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                 TagResolver.resolver("value", Tag.inserting(Component.text("/plot backup <save | list | load>"))) |                 Template.of("value", "/plot backup <save | list | load>") | ||||||
|         ); |         ); | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| @@ -136,44 +135,34 @@ public final class Backup extends Command { | |||||||
|         } else if (!plot.hasOwner()) { |         } else if (!plot.hasOwner()) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("backups.backup_impossible"), |                     TranslatableCaption.of("backups.backup_impossible"), | ||||||
|                     TagResolver.resolver("plot", Tag.inserting( |                     Template.of("plot", TranslatableCaption.of("generic.generic_unowned").getComponent(player)) | ||||||
|                             TranslatableCaption.of("generic.generic_unowned").toComponent(player) |  | ||||||
|                     )) |  | ||||||
|             ); |             ); | ||||||
|         } else if (plot.getVolume() > Integer.MAX_VALUE) { |         } else if (plot.getVolume() > Integer.MAX_VALUE) { | ||||||
|             player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); |             player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); | ||||||
|         } else if (plot.isMerged()) { |         } else if (plot.isMerged()) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("backups.backup_impossible"), |                     TranslatableCaption.of("backups.backup_impossible"), | ||||||
|                     TagResolver.resolver("plot", Tag.inserting( |                     Template.of("plot", TranslatableCaption.of("generic.generic_merged").getComponent(player)) | ||||||
|                             TranslatableCaption.of("generic.generic_merged").toComponent(player) |  | ||||||
|                     )) |  | ||||||
|             ); |             ); | ||||||
|         } else if (!plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_BACKUP_OTHER)) { |         } else if (!plot.isOwner(player.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN_BACKUP_OTHER)) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver( |                     Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BACKUP_OTHER)) | ||||||
|                             "node", |  | ||||||
|                             Tag.inserting(Permission.PERMISSION_ADMIN_BACKUP_OTHER) |  | ||||||
|                     ) |  | ||||||
|             ); |             ); | ||||||
|         } else { |         } else { | ||||||
|             final BackupProfile backupProfile = Objects.requireNonNull(this.backupManager.getProfile(plot)); |             final BackupProfile backupProfile = Objects.requireNonNull(this.backupManager.getProfile(plot)); | ||||||
|             if (backupProfile instanceof NullBackupProfile) { |             if (backupProfile instanceof NullBackupProfile) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("backups.backup_impossible"), |                         TranslatableCaption.of("backups.backup_impossible"), | ||||||
|                         TagResolver.resolver( |                         Template.of("plot", TranslatableCaption.of("generic.generic_other").getComponent(player)) | ||||||
|                                 "plot", Tag.inserting(TranslatableCaption |  | ||||||
|                                         .of("generic.generic_other") |  | ||||||
|                                         .toComponent(player)) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|             } else { |             } else { | ||||||
|                 backupProfile.createBackup().whenComplete((backup, throwable) -> { |                 backupProfile.createBackup().whenComplete((backup, throwable) -> { | ||||||
|                     if (throwable != null) { |                     if (throwable != null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("backups.backup_save_failed"), |                                 TranslatableCaption.of("backups.backup_save_failed"), | ||||||
|                                 TagResolver.resolver("reason", Tag.inserting(Component.text(throwable.getMessage()))) |                                 Template.of("reason", throwable.getMessage()) | ||||||
|                         ); |                         ); | ||||||
|                         throwable.printStackTrace(); |                         throwable.printStackTrace(); | ||||||
|                     } else { |                     } else { | ||||||
| @@ -200,64 +189,50 @@ public final class Backup extends Command { | |||||||
|         } else if (!plot.hasOwner()) { |         } else if (!plot.hasOwner()) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("backups.backup_impossible"), |                     TranslatableCaption.of("backups.backup_impossible"), | ||||||
|                     TagResolver.resolver("plot", Tag.inserting( |                     Template.of("plot", TranslatableCaption.of("generic.generic_unowned").getComponent(player)) | ||||||
|                             TranslatableCaption.of("generic.generic_unowned").toComponent(player) |  | ||||||
|                     )) |  | ||||||
|             ); |             ); | ||||||
|         } else if (plot.isMerged()) { |         } else if (plot.isMerged()) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("backups.backup_impossible"), |                     TranslatableCaption.of("backups.backup_impossible"), | ||||||
|                     TagResolver.resolver("plot", Tag.inserting( |                     Template.of("plot", TranslatableCaption.of("generic.generic_merged").getComponent(player)) | ||||||
|                             TranslatableCaption.of("generic.generic_merged").toComponent(player) |  | ||||||
|                     )) |  | ||||||
|             ); |             ); | ||||||
|         } else if (plot.getVolume() > Integer.MAX_VALUE) { |         } else if (plot.getVolume() > Integer.MAX_VALUE) { | ||||||
|             player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); |             player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); | ||||||
|         } else if (!plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_BACKUP_OTHER)) { |         } else if (!plot.isOwner(player.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN_BACKUP_OTHER)) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver( |                     Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BACKUP_OTHER)) | ||||||
|                             "node", |  | ||||||
|                             Tag.inserting(Permission.PERMISSION_ADMIN_BACKUP_OTHER) |  | ||||||
|                     ) |  | ||||||
|             ); |             ); | ||||||
|         } else { |         } else { | ||||||
|             final BackupProfile backupProfile = Objects.requireNonNull(this.backupManager.getProfile(plot)); |             final BackupProfile backupProfile = Objects.requireNonNull(this.backupManager.getProfile(plot)); | ||||||
|             if (backupProfile instanceof NullBackupProfile) { |             if (backupProfile instanceof NullBackupProfile) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("backups.backup_impossible"), |                         TranslatableCaption.of("backups.backup_impossible"), | ||||||
|                         TagResolver.resolver("plot", Tag.inserting( |                         Template.of("plot", TranslatableCaption.of("generic.generic_other").getComponent(player)) | ||||||
|                                 TranslatableCaption.of("generic.generic_other").toComponent(player) |  | ||||||
|                         )) |  | ||||||
|                 ); |                 ); | ||||||
|             } else { |             } else { | ||||||
|                 backupProfile.listBackups().whenComplete((backups, throwable) -> { |                 backupProfile.listBackups().whenComplete((backups, throwable) -> { | ||||||
|                     if (throwable != null) { |                     if (throwable != null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("backups.backup_list_failed"), |                                 TranslatableCaption.of("backups.backup_list_failed"), | ||||||
|                                 TagResolver.resolver("reason", Tag.inserting(Component.text(throwable.getMessage()))) |                                 Template.of("reason", throwable.getMessage()) | ||||||
|                         ); |                         ); | ||||||
|                         throwable.printStackTrace(); |                         throwable.printStackTrace(); | ||||||
|                     } else { |                     } else { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("backups.backup_list_header"), |                                 TranslatableCaption.of("backups.backup_list_header"), | ||||||
|                                 TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toCommaSeparatedString()))) |                                 Template.of("plot", plot.getId().toCommaSeparatedString()) | ||||||
|                         ); |                         ); | ||||||
|                         try { |                         try { | ||||||
|                             for (int i = 0; i < backups.size(); i++) { |                             for (int i = 0; i < backups.size(); i++) { | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("backups.backup_list_entry"), |                                         TranslatableCaption.of("backups.backup_list_entry"), | ||||||
|                                         TagResolver.builder() |                                         Template.of("number", Integer.toString(i + 1)), | ||||||
|                                                 .tag("number", Tag.inserting(Component.text(i + 1))) |                                         Template.of("value", DateTimeFormatter.RFC_1123_DATE_TIME.format(ZonedDateTime.ofInstant( | ||||||
|                                                 .tag( |                                                 Instant.ofEpochMilli(backups.get(i).getCreationTime()), | ||||||
|                                                         "value", |                                                 ZoneId.systemDefault() | ||||||
|                                                         Tag.inserting(Component.text(DateTimeFormatter.RFC_1123_DATE_TIME.format( |                                         ))) | ||||||
|                                                                 ZonedDateTime.ofInstant( |  | ||||||
|                                                                         Instant.ofEpochMilli(backups.get(i).getCreationTime()), |  | ||||||
|                                                                         ZoneId.systemDefault() |  | ||||||
|                                                                 )))) |  | ||||||
|                                                 ) |  | ||||||
|                                                 .build() |  | ||||||
|                                 ); |                                 ); | ||||||
|                             } |                             } | ||||||
|                         } catch (final Exception e) { |                         } catch (final Exception e) { | ||||||
| @@ -285,31 +260,25 @@ public final class Backup extends Command { | |||||||
|         } else if (!plot.hasOwner()) { |         } else if (!plot.hasOwner()) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("backups.backup_impossible"), |                     TranslatableCaption.of("backups.backup_impossible"), | ||||||
|                     TagResolver.resolver("plot", Tag.inserting( |                     Template.of("plot", TranslatableCaption.of("generic.generic_unowned").getComponent(player)) | ||||||
|                             TranslatableCaption.of("generic.generic_unowned").toComponent(player) |  | ||||||
|                     )) |  | ||||||
|             ); |             ); | ||||||
|         } else if (plot.isMerged()) { |         } else if (plot.isMerged()) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("backups.backup_impossible"), |                     TranslatableCaption.of("backups.backup_impossible"), | ||||||
|                     TagResolver.resolver("plot", Tag.inserting( |                     Template.of("plot", TranslatableCaption.of("generic.generic_merged").getComponent(player)) | ||||||
|                             TranslatableCaption.of("generic.generic_merged").toComponent(player) |  | ||||||
|                     )) |  | ||||||
|             ); |             ); | ||||||
|         } else if (plot.getVolume() > Integer.MAX_VALUE) { |         } else if (plot.getVolume() > Integer.MAX_VALUE) { | ||||||
|             player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); |             player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); | ||||||
|         } else if (!plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_BACKUP_OTHER)) { |         } else if (!plot.isOwner(player.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN_BACKUP_OTHER)) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver( |                     Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BACKUP_OTHER)) | ||||||
|                             "node", |  | ||||||
|                             Tag.inserting(Permission.PERMISSION_ADMIN_BACKUP_OTHER) |  | ||||||
|                     ) |  | ||||||
|             ); |             ); | ||||||
|         } else if (args.length == 0) { |         } else if (args.length == 0) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("Usage: /plot backup save/list/load"))) |                     Template.of("value", "Usage: /plot backup save/list/load") | ||||||
|             ); |             ); | ||||||
|         } else { |         } else { | ||||||
|             final int number; |             final int number; | ||||||
| @@ -318,7 +287,7 @@ public final class Backup extends Command { | |||||||
|             } catch (final Exception e) { |             } catch (final Exception e) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("invalid.not_a_number"), |                         TranslatableCaption.of("invalid.not_a_number"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) |                         Template.of("value", args[0]) | ||||||
|                 ); |                 ); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| @@ -326,27 +295,23 @@ public final class Backup extends Command { | |||||||
|             if (backupProfile instanceof NullBackupProfile) { |             if (backupProfile instanceof NullBackupProfile) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("backups.backup_impossible"), |                         TranslatableCaption.of("backups.backup_impossible"), | ||||||
|                         TagResolver.resolver("plot", Tag.inserting( |                         Template.of("plot", TranslatableCaption.of("generic.generic_other").getComponent(player)) | ||||||
|                                 TranslatableCaption.of("generic.generic_other").toComponent(player) |  | ||||||
|                         )) |  | ||||||
|                 ); |                 ); | ||||||
|             } else { |             } else { | ||||||
|                 backupProfile.listBackups().whenComplete((backups, throwable) -> { |                 backupProfile.listBackups().whenComplete((backups, throwable) -> { | ||||||
|                     if (throwable != null) { |                     if (throwable != null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("backups.backup_load_failure"), |                                 TranslatableCaption.of("backups.backup_load_failure"), | ||||||
|                                 TagResolver.resolver("reason", Tag.inserting(Component.text(throwable.getMessage()))) |                                 Template.of("reason", throwable.getMessage()) | ||||||
|                         ); |                         ); | ||||||
|                         throwable.printStackTrace(); |                         throwable.printStackTrace(); | ||||||
|                     } else { |                     } else { | ||||||
|                         if (number < 1 || number > backups.size()) { |                         if (number < 1 || number > backups.size()) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("backups.backup_impossible"), |                                     TranslatableCaption.of("backups.backup_impossible"), | ||||||
|                                     TagResolver.resolver( |                                     Template.of( | ||||||
|                                             "plot", |                                             "plot", | ||||||
|                                             Tag.inserting(TranslatableCaption |                                             TranslatableCaption.of("generic.generic_invalid_choice").getComponent(player) | ||||||
|                                                     .of("generic.generic_invalid_choice") |  | ||||||
|                                                     .toComponent(player)) |  | ||||||
|                                     ) |                                     ) | ||||||
|                             ); |                             ); | ||||||
|                         } else { |                         } else { | ||||||
| @@ -356,11 +321,9 @@ public final class Backup extends Command { | |||||||
|                                     .exists(backup.getFile())) { |                                     .exists(backup.getFile())) { | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("backups.backup_impossible"), |                                         TranslatableCaption.of("backups.backup_impossible"), | ||||||
|                                         TagResolver.resolver( |                                         Template.of( | ||||||
|                                                 "plot", |                                                 "plot", | ||||||
|                                                 Tag.inserting(TranslatableCaption |                                                 TranslatableCaption.of("generic.generic_invalid_choice").getComponent(player) | ||||||
|                                                         .of("generic.generic_invalid_choice") |  | ||||||
|                                                         .toComponent(player)) |  | ||||||
|                                         ) |                                         ) | ||||||
|                                 ); |                                 ); | ||||||
|                             } else { |                             } else { | ||||||
| @@ -370,10 +333,7 @@ public final class Backup extends Command { | |||||||
|                                                     if (error != null) { |                                                     if (error != null) { | ||||||
|                                                         player.sendMessage( |                                                         player.sendMessage( | ||||||
|                                                                 TranslatableCaption.of("backups.backup_load_failure"), |                                                                 TranslatableCaption.of("backups.backup_load_failure"), | ||||||
|                                                                 TagResolver.resolver( |                                                                 Template.of("reason", error.getMessage()) | ||||||
|                                                                         "reason", |  | ||||||
|                                                                         Tag.inserting(Component.text(error.getMessage())) |  | ||||||
|                                                                 ) |  | ||||||
|                                                         ); |                                                         ); | ||||||
|                                                     } else { |                                                     } else { | ||||||
|                                                         player.sendMessage(TranslatableCaption.of("backups.backup_load_success")); |                                                         player.sendMessage(TranslatableCaption.of("backups.backup_load_success")); | ||||||
|   | |||||||
| @@ -18,7 +18,6 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.core.command; | package com.plotsquared.core.command; | ||||||
|  |  | ||||||
| import com.plotsquared.core.configuration.caption.StaticCaption; |  | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| @@ -26,9 +25,7 @@ import com.plotsquared.core.util.StringMan; | |||||||
| import com.sk89q.worldedit.command.util.SuggestionHelper; | import com.sk89q.worldedit.command.util.SuggestionHelper; | ||||||
| import com.sk89q.worldedit.world.biome.BiomeType; | import com.sk89q.worldedit.world.biome.BiomeType; | ||||||
| import com.sk89q.worldedit.world.biome.BiomeTypes; | import com.sk89q.worldedit.world.biome.BiomeTypes; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
|  |  | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| import java.util.Locale; | import java.util.Locale; | ||||||
| @@ -50,13 +47,16 @@ public class Biome extends SetCommand { | |||||||
|         } catch (final Exception ignore) { |         } catch (final Exception ignore) { | ||||||
|         } |         } | ||||||
|         if (biome == null) { |         if (biome == null) { | ||||||
|             String separator = TranslatableCaption.of("blocklist.block_list_separator").getComponent(player); |             String biomes = StringMan.join( | ||||||
|  |                     BiomeType.REGISTRY.values(), | ||||||
|  |                     MINI_MESSAGE.serialize(MINI_MESSAGE.parse(TranslatableCaption | ||||||
|  |                             .of("blocklist.block_list_separator") | ||||||
|  |                             .getComponent(player))) | ||||||
|  |             ); | ||||||
|             player.sendMessage(TranslatableCaption.of("biome.need_biome")); |             player.sendMessage(TranslatableCaption.of("biome.need_biome")); | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     StaticCaption.of( |                     TranslatableCaption.of("commandconfig.subcommand_set_options_header"), | ||||||
|                             TranslatableCaption.of("commandconfig.subcommand_set_options_header_only").getComponent(player) |                     Template.of("values", biomes) | ||||||
|                                     + StringMan.join(BiomeType.REGISTRY.values(), separator) |  | ||||||
|                     ) |  | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -73,7 +73,7 @@ public class Biome extends SetCommand { | |||||||
|             plot.removeRunning(); |             plot.removeRunning(); | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("biome.biome_set_to"), |                     TranslatableCaption.of("biome.biome_set_to"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text(value.toLowerCase()))) |                     Template.of("value", value.toLowerCase()) | ||||||
|             ); |             ); | ||||||
|         }); |         }); | ||||||
|         return true; |         return true; | ||||||
|   | |||||||
| @@ -32,9 +32,7 @@ import com.plotsquared.core.util.EconHandler; | |||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
| @@ -86,7 +84,7 @@ public class Buy extends Command { | |||||||
|         checkTrue( |         checkTrue( | ||||||
|                 player.getPlotCount() + plots.size() <= player.getAllowedPlots(), |                 player.getPlotCount() + plots.size() <= player.getAllowedPlots(), | ||||||
|                 TranslatableCaption.of("permission.cant_claim_more_plots"), |                 TranslatableCaption.of("permission.cant_claim_more_plots"), | ||||||
|                 TagResolver.resolver("amount", Tag.inserting(Component.text(player.getAllowedPlots()))) |                 Template.of("amount", String.valueOf(player.getAllowedPlots())) | ||||||
|         ); |         ); | ||||||
|         double price = plot.getFlag(PriceFlag.class); |         double price = plot.getFlag(PriceFlag.class); | ||||||
|         if (price <= 0) { |         if (price <= 0) { | ||||||
| @@ -99,10 +97,8 @@ public class Buy extends Command { | |||||||
|         checkTrue( |         checkTrue( | ||||||
|                 this.econHandler.getMoney(player) >= price, |                 this.econHandler.getMoney(player) >= price, | ||||||
|                 TranslatableCaption.of("economy.cannot_afford_plot"), |                 TranslatableCaption.of("economy.cannot_afford_plot"), | ||||||
|                 TagResolver.builder() |                 Template.of("money", this.econHandler.format(price)), | ||||||
|                         .tag("money", Tag.inserting(Component.text(this.econHandler.format(price)))) |                 Template.of("balance", this.econHandler.format(this.econHandler.getMoney(player))) | ||||||
|                         .tag("balance", Tag.inserting(Component.text(this.econHandler.format(this.econHandler.getMoney(player))))) |  | ||||||
|                         .build() |  | ||||||
|         ); |         ); | ||||||
|         this.econHandler.withdrawMoney(player, price); |         this.econHandler.withdrawMoney(player, price); | ||||||
|         // Failure |         // Failure | ||||||
| @@ -110,7 +106,7 @@ public class Buy extends Command { | |||||||
|         confirm.run(this, () -> { |         confirm.run(this, () -> { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("economy.removed_balance"), |                     TranslatableCaption.of("economy.removed_balance"), | ||||||
|                     TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(price)))) |                     Template.of("money", this.econHandler.format(price)) | ||||||
|             ); |             ); | ||||||
|  |  | ||||||
|             this.econHandler.depositMoney(PlotSquared.platform().playerManager().getOfflinePlayer(plot.getOwnerAbs()), price); |             this.econHandler.depositMoney(PlotSquared.platform().playerManager().getOfflinePlayer(plot.getOwnerAbs()), price); | ||||||
| @@ -119,11 +115,9 @@ public class Buy extends Command { | |||||||
|             if (owner != null) { |             if (owner != null) { | ||||||
|                 owner.sendMessage( |                 owner.sendMessage( | ||||||
|                         TranslatableCaption.of("economy.plot_sold"), |                         TranslatableCaption.of("economy.plot_sold"), | ||||||
|                         TagResolver.builder() |                         Template.of("plot", plot.getId().toString()), | ||||||
|                                 .tag("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                         Template.of("player", player.getName()), | ||||||
|                                 .tag("player", Tag.inserting(Component.text(player.getName()))) |                         Template.of("price", this.econHandler.format(price)) | ||||||
|                                 .tag("price", Tag.inserting(Component.text(this.econHandler.format(price)))) |  | ||||||
|                                 .build() |  | ||||||
|                 ); |                 ); | ||||||
|             } |             } | ||||||
|             PlotFlag<?, ?> plotFlag = plot.getFlagContainer().getFlag(PriceFlag.class); |             PlotFlag<?, ?> plotFlag = plot.getFlagContainer().getFlag(PriceFlag.class); | ||||||
| @@ -135,7 +129,7 @@ public class Buy extends Command { | |||||||
|             plot.getPlotModificationManager().setSign(player.getName()); |             plot.getPlotModificationManager().setSign(player.getName()); | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("working.claimed"), |                     TranslatableCaption.of("working.claimed"), | ||||||
|                     TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                     Template.of("plot", plot.getId().toString()) | ||||||
|             ); |             ); | ||||||
|             whenDone.run(Buy.this, CommandResult.SUCCESS); |             whenDone.run(Buy.this, CommandResult.SUCCESS); | ||||||
|         }, () -> { |         }, () -> { | ||||||
|   | |||||||
| @@ -29,10 +29,8 @@ import com.plotsquared.core.plot.flag.implementations.HostileCapFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.MiscCapFlag; | import com.plotsquared.core.plot.flag.implementations.MiscCapFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.MobCapFlag; | import com.plotsquared.core.plot.flag.implementations.MobCapFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.VehicleCapFlag; | import com.plotsquared.core.plot.flag.implementations.VehicleCapFlag; | ||||||
| import net.kyori.adventure.text.Component; | import com.plotsquared.core.util.Permissions; | ||||||
| import net.kyori.adventure.text.ComponentLike; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
|  |  | ||||||
| import static com.plotsquared.core.util.entity.EntityCategories.CAP_ANIMAL; | import static com.plotsquared.core.util.entity.EntityCategories.CAP_ANIMAL; | ||||||
| import static com.plotsquared.core.util.entity.EntityCategories.CAP_ENTITY; | import static com.plotsquared.core.util.entity.EntityCategories.CAP_ENTITY; | ||||||
| @@ -53,10 +51,11 @@ public class Caps extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!plot.isAdded(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_CAPS_OTHER)) { |         if (!plot.isAdded(player.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN_CAPS_OTHER)) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_ADMIN_CAPS_OTHER)) |                     Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_CAPS_OTHER)) | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -83,17 +82,15 @@ public class Caps extends SubCommand { | |||||||
|         final int current = countedEntities[type]; |         final int current = countedEntities[type]; | ||||||
|         final int max = plot.getFlag(capFlag); |         final int max = plot.getFlag(capFlag); | ||||||
|         final String percentage = String.format("%.1f", 100 * ((float) current / max)); |         final String percentage = String.format("%.1f", 100 * ((float) current / max)); | ||||||
|         ComponentLike maxBeautified = max >= Integer.MAX_VALUE |         String maxBeautified = max >= Integer.MAX_VALUE | ||||||
|                 ? TranslatableCaption.of("info.infinite").toComponent(player) |                 ? TranslatableCaption.of("info.infinite").getComponent(player) | ||||||
|                 : Component.text(max); |                 : String.valueOf(max); | ||||||
|         player.sendMessage( |         player.sendMessage( | ||||||
|                 TranslatableCaption.of("info.plot_caps_format"), |                 TranslatableCaption.of("info.plot_caps_format"), | ||||||
|                 TagResolver.builder() |                 Template.of("cap", name), | ||||||
|                         .tag("cap", Tag.inserting(Component.text(name))) |                 Template.of("current", String.valueOf(current)), | ||||||
|                         .tag("current", Tag.inserting(Component.text(current))) |                 Template.of("limit", maxBeautified), | ||||||
|                         .tag("limit", Tag.inserting(maxBeautified)) |                 Template.of("percentage", percentage) | ||||||
|                         .tag("percentage", Tag.inserting(Component.text(percentage))) |  | ||||||
|                         .build() |  | ||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										54
									
								
								Core/src/main/java/com/plotsquared/core/command/Chat.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								Core/src/main/java/com/plotsquared/core/command/Chat.java
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,54 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU General Public License as published by | ||||||
|  |  * the Free Software Foundation, either version 3 of the License, or | ||||||
|  |  * (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU General Public License | ||||||
|  |  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.core.command; | ||||||
|  |  | ||||||
|  | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
|  | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.PlotArea; | ||||||
|  | import net.kyori.adventure.text.minimessage.Template; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @deprecated In favor of "/plot toggle chat" and | ||||||
|  |  *         scheduled for removal within the next major release. | ||||||
|  |  */ | ||||||
|  | @Deprecated(forRemoval = true, since = "6.0.0") | ||||||
|  | @CommandDeclaration(command = "chat", | ||||||
|  |         usage = "/plot chat", | ||||||
|  |         permission = "plots.chat", | ||||||
|  |         category = CommandCategory.CHAT, | ||||||
|  |         requiredType = RequiredType.PLAYER) | ||||||
|  | public class Chat extends SubCommand { | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||||
|  |         PlotArea area = player.getPlotAreaAbs(); | ||||||
|  |         check(area, TranslatableCaption.of("errors.not_in_plot_world")); | ||||||
|  |         player.sendMessage( | ||||||
|  |                 TranslatableCaption.of("errors.deprecated_commands"), | ||||||
|  |                 Template.of("replacement", "/plot toggle chat") | ||||||
|  |         ); | ||||||
|  |         if (player.getPlotAreaAbs().isForcingPlotChat()) { | ||||||
|  |             player.sendMessage(TranslatableCaption.of("chat.plot_chat_forced")); | ||||||
|  |             return true; | ||||||
|  |         } | ||||||
|  |         MainCommand.getInstance().toggle.chat(this, player, args, null, null); | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -35,11 +35,10 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.util.EconHandler; | import com.plotsquared.core.util.EconHandler; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.PlotExpression; | import com.plotsquared.core.util.PlotExpression; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.apache.logging.log4j.LogManager; | import org.apache.logging.log4j.LogManager; | ||||||
| import org.apache.logging.log4j.Logger; | import org.apache.logging.log4j.Logger; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| @@ -83,7 +82,7 @@ public class Claim extends SubCommand { | |||||||
|         if (event.getEventResult() == Result.DENY) { |         if (event.getEventResult() == Result.DENY) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("events.event_denied"), |                     TranslatableCaption.of("events.event_denied"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("Claim"))) |                     Template.of("value", "Claim") | ||||||
|             ); |             ); | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
| @@ -102,14 +101,14 @@ public class Claim extends SubCommand { | |||||||
|                     if (grants <= 0) { |                     if (grants <= 0) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.cant_claim_more_plots"), |                                 TranslatableCaption.of("permission.cant_claim_more_plots"), | ||||||
|                                 TagResolver.resolver("amount", Tag.inserting(Component.text(grants))) |                                 Template.of("amount", String.valueOf(grants)) | ||||||
|                         ); |                         ); | ||||||
|                         metaDataAccess.remove(); |                         metaDataAccess.remove(); | ||||||
|                     } |                     } | ||||||
|                 } else { |                 } else { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.cant_claim_more_plots"), |                             TranslatableCaption.of("permission.cant_claim_more_plots"), | ||||||
|                             TagResolver.resolver("amount", Tag.inserting(Component.text(player.getAllowedPlots()))) |                             Template.of("amount", String.valueOf(player.getAllowedPlots())) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -124,19 +123,18 @@ public class Claim extends SubCommand { | |||||||
|                     if (!area.hasSchematic(schematic)) { |                     if (!area.hasSchematic(schematic)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("schematics.schematic_invalid_named"), |                                 TranslatableCaption.of("schematics.schematic_invalid_named"), | ||||||
|                                 TagResolver.builder() |                                 Template.of("schemname", schematic), | ||||||
|                                         .tag("schemname", Tag.inserting(Component.text(schematic))) |                                 Template.of("reason", "non-existent") | ||||||
|                                         .tag("reason", Tag.inserting(Component.text("non-existent"))) |  | ||||||
|                                         .build() |  | ||||||
|                         ); |                         ); | ||||||
|                     } |                     } | ||||||
|                     if (!player.hasPermission(Permission.PERMISSION_CLAIM_SCHEMATIC |                     if (!Permissions.hasPermission(player, Permission.PERMISSION_CLAIM_SCHEMATIC | ||||||
|                             .format(schematic)) && !player.hasPermission( |                             .format(schematic)) && !Permissions.hasPermission( | ||||||
|  |                             player, | ||||||
|                             "plots.admin.command.schematic" |                             "plots.admin.command.schematic" | ||||||
|                     ) && !force) { |                     ) && !force) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_schematic_permission"), |                                 TranslatableCaption.of("permission.no_schematic_permission"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(schematic))) |                                 Template.of("value", schematic) | ||||||
|                         ); |                         ); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| @@ -152,28 +150,16 @@ public class Claim extends SubCommand { | |||||||
|                     if (this.econHandler.getMoney(player) < cost) { |                     if (this.econHandler.getMoney(player) < cost) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("economy.cannot_afford_plot"), |                                 TranslatableCaption.of("economy.cannot_afford_plot"), | ||||||
|                                 TagResolver.builder() |                                 Template.of("money", this.econHandler.format(cost)), | ||||||
|                                         .tag("money", Tag.inserting(Component.text(this.econHandler.format(cost)))) |                                 Template.of("balance", this.econHandler.format(this.econHandler.getMoney(player))) | ||||||
|                                         .tag( |  | ||||||
|                                                 "balance", |  | ||||||
|                                                 Tag.inserting(Component.text(this.econHandler.format(this.econHandler.getMoney( |  | ||||||
|                                                         player)))) |  | ||||||
|                                         ) |  | ||||||
|                                         .build() |  | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                     this.econHandler.withdrawMoney(player, cost); |                     this.econHandler.withdrawMoney(player, cost); | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("economy.removed_balance"), |                             TranslatableCaption.of("economy.removed_balance"), | ||||||
|                             TagResolver.builder() |                             Template.of("money", this.econHandler.format(cost)), | ||||||
|                                     .tag("money", Tag.inserting(Component.text(this.econHandler.format(cost)))) |                             Template.of("balance", this.econHandler.format(this.econHandler.getMoney(player))) | ||||||
|                                     .tag( |  | ||||||
|                                             "balance", |  | ||||||
|                                             Tag.inserting(Component.text(this.econHandler.format(this.econHandler.getMoney( |  | ||||||
|                                                     player)))) |  | ||||||
|                                     ) |  | ||||||
|                                     .build() |  | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -185,14 +171,12 @@ public class Claim extends SubCommand { | |||||||
|                 } |                 } | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("economy.removed_granted_plot"), |                         TranslatableCaption.of("economy.removed_granted_plot"), | ||||||
|                         TagResolver.builder() |                         Template.of("usedGrants", String.valueOf((grants - 1))), | ||||||
|                                 .tag("usedGrants", Tag.inserting(Component.text(grants - 1))) |                         Template.of("remainingGrants", String.valueOf(grants)) | ||||||
|                                 .tag("remainingGrants", Tag.inserting(Component.text(grants))) |  | ||||||
|                                 .build() |  | ||||||
|                 ); |                 ); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         if (!player.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { |         if (!Permissions.hasPermission(player, Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { | ||||||
|             int border = area.getBorder(); |             int border = area.getBorder(); | ||||||
|             if (border != Integer.MAX_VALUE && plot.getDistanceFromOrigin() > border && !force) { |             if (border != Integer.MAX_VALUE && plot.getDistanceFromOrigin() > border && !force) { | ||||||
|                 player.sendMessage(TranslatableCaption.of("border.denied")); |                 player.sendMessage(TranslatableCaption.of("border.denied")); | ||||||
| @@ -214,7 +198,7 @@ public class Claim extends SubCommand { | |||||||
|                         if (mergeEvent.getEventResult() == Result.DENY) { |                         if (mergeEvent.getEventResult() == Result.DENY) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("events.event_denied"), |                                     TranslatableCaption.of("events.event_denied"), | ||||||
|                                     TagResolver.resolver("value", Tag.inserting(Component.text("Auto merge on claim"))) |                                     Template.of("value", "Auto merge on claim") | ||||||
|                             ); |                             ); | ||||||
|                         } else { |                         } else { | ||||||
|                             if (plot.getPlotModificationManager().autoMerge( |                             if (plot.getPlotModificationManager().autoMerge( | ||||||
|   | |||||||
| @@ -32,12 +32,11 @@ import com.plotsquared.core.plot.flag.implementations.AnalysisFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.DoneFlag; | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
| import com.plotsquared.core.queue.GlobalBlockQueue; | import com.plotsquared.core.queue.GlobalBlockQueue; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.concurrent.CompletableFuture; | import java.util.concurrent.CompletableFuture; | ||||||
| @@ -80,7 +79,7 @@ public class Clear extends Command { | |||||||
|         if (eventResult == Result.DENY) { |         if (eventResult == Result.DENY) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("events.event_denied"), |                     TranslatableCaption.of("events.event_denied"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("Clear"))) |                     Template.of("value", "Clear") | ||||||
|             ); |             ); | ||||||
|             return CompletableFuture.completedFuture(true); |             return CompletableFuture.completedFuture(true); | ||||||
|         } |         } | ||||||
| @@ -90,14 +89,13 @@ public class Clear extends Command { | |||||||
|         } |         } | ||||||
|         boolean force = eventResult == Result.FORCE; |         boolean force = eventResult == Result.FORCE; | ||||||
|         checkTrue( |         checkTrue( | ||||||
|                 force || plot.isOwner(player.getUUID()) || player.hasPermission("plots.admin.command.clear"), |                 force || plot.isOwner(player.getUUID()) || Permissions | ||||||
|  |                         .hasPermission(player, "plots.admin.command.clear"), | ||||||
|                 TranslatableCaption.of("permission.no_plot_perms") |                 TranslatableCaption.of("permission.no_plot_perms") | ||||||
|         ); |         ); | ||||||
|         checkTrue(plot.getRunning() == 0, TranslatableCaption.of("errors.wait_for_timer")); |         checkTrue(plot.getRunning() == 0, TranslatableCaption.of("errors.wait_for_timer")); | ||||||
|         checkTrue( |         checkTrue(force || !Settings.Done.RESTRICT_BUILDING || !DoneFlag.isDone(plot) || Permissions | ||||||
|                 force || !Settings.Done.RESTRICT_BUILDING || !DoneFlag.isDone(plot) || player.hasPermission("plots.continue"), |                 .hasPermission(player, "plots.continue"), TranslatableCaption.of("done.done_already_done")); | ||||||
|                 TranslatableCaption.of("done.done_already_done") |  | ||||||
|         ); |  | ||||||
|         confirm.run(this, () -> { |         confirm.run(this, () -> { | ||||||
|             if (Settings.Teleport.ON_CLEAR) { |             if (Settings.Teleport.ON_CLEAR) { | ||||||
|                 plot.getPlayersInPlot().forEach(playerInPlot -> plot.teleportPlayer(playerInPlot, TeleportCause.COMMAND_CLEAR, |                 plot.getPlayersInPlot().forEach(playerInPlot -> plot.teleportPlayer(playerInPlot, TeleportCause.COMMAND_CLEAR, | ||||||
| @@ -132,10 +130,8 @@ public class Clear extends Command { | |||||||
|                         } |                         } | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("working.clearing_done"), |                                 TranslatableCaption.of("working.clearing_done"), | ||||||
|                                 TagResolver.builder() |                                 Template.of("amount", String.valueOf(System.currentTimeMillis() - start)), | ||||||
|                                         .tag("amount", Tag.inserting(Component.text(System.currentTimeMillis() - start))) |                                 Template.of("plot", plot.getId().toString()) | ||||||
|                                         .tag("plot", Tag.inserting(Component.text(plot.getId().toString()))) |  | ||||||
|                                         .build() |  | ||||||
|                         ); |                         ); | ||||||
|                     }); |                     }); | ||||||
|                 }); |                 }); | ||||||
|   | |||||||
| @@ -32,14 +32,10 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.PlotCluster; | import com.plotsquared.core.plot.PlotCluster; | ||||||
| import com.plotsquared.core.plot.PlotId; | import com.plotsquared.core.plot.PlotId; | ||||||
| import com.plotsquared.core.util.ComponentHelper; | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.query.PlotQuery; | import com.plotsquared.core.util.query.PlotQuery; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.format.NamedTextColor; |  | ||||||
| import net.kyori.adventure.text.format.Style; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
|  |  | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| import java.util.Collections; | import java.util.Collections; | ||||||
| @@ -50,7 +46,6 @@ import java.util.Set; | |||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
| import java.util.concurrent.TimeoutException; | import java.util.concurrent.TimeoutException; | ||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
| import java.util.stream.Stream; |  | ||||||
|  |  | ||||||
| @CommandDeclaration(command = "cluster", | @CommandDeclaration(command = "cluster", | ||||||
|         aliases = "clusters", |         aliases = "clusters", | ||||||
| @@ -59,19 +54,18 @@ import java.util.stream.Stream; | |||||||
|         permission = "plots.cluster") |         permission = "plots.cluster") | ||||||
| public class Cluster extends SubCommand { | public class Cluster extends SubCommand { | ||||||
|  |  | ||||||
|     private static final Component[] AVAILABLE_ARGS = Stream.of( |  | ||||||
|             "list", "create", "delete", "resize", "invite", "kick", "leave", "helpers", "tp", "sethome" |  | ||||||
|     ).map(s -> Component.text(s).style(Style.style(NamedTextColor.DARK_AQUA))).toArray(Component[]::new); |  | ||||||
|     private static final Component SEPARATOR = Component.text(", ").style(Style.style(NamedTextColor.GRAY)); |  | ||||||
|  |  | ||||||
|     // list, create, delete, resize, invite, kick, leave, helpers, tp, sethome |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { |     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||||
|  |  | ||||||
|  |         // list, create, delete, resize, invite, kick, leave, helpers, tp, sethome | ||||||
|         if (args.length == 0) { |         if (args.length == 0) { | ||||||
|             // return arguments |             // return arguments | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("cluster.cluster_available_args"), |                     TranslatableCaption.of("cluster.cluster_available_args"), | ||||||
|                     TagResolver.resolver("list", Tag.inserting(ComponentHelper.join(AVAILABLE_ARGS, SEPARATOR))) |                     Template.of( | ||||||
|  |                             "list", | ||||||
|  |                             "<dark_aqua>list</dark_aqua><gray>, </gray><dark_aqua>create</dark_aqua><gray>, </gray><dark_aqua>delete</dark_aqua><gray>, </gray><dark_aqua>resize</dark_aqua><gray>, </gray><dark_aqua>invite</dark_aqua><gray>, </gray><dark_aqua>kick</dark_aqua><gray>, </gray><dark_aqua>leave</dark_aqua><gray>, </gray><dark_aqua>members</dark_aqua><gray>, </gray><dark_aqua>info</dark_aqua><gray>, </gray><dark_aqua>tp</dark_aqua><gray>, </gray><dark_aqua>sethome</dark_aqua>" | ||||||
|  |                     ) | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -79,20 +73,17 @@ public class Cluster extends SubCommand { | |||||||
|         switch (sub) { |         switch (sub) { | ||||||
|             case "l": |             case "l": | ||||||
|             case "list": { |             case "list": { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_LIST)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_LIST)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_CLUSTER_LIST)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_CLUSTER_LIST) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (args.length != 1) { |                 if (args.length != 1) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text("/plot cluster list"))) |                             Template.of("value", "/plot cluster list") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -104,7 +95,7 @@ public class Cluster extends SubCommand { | |||||||
|                 Set<PlotCluster> clusters = area.getClusters(); |                 Set<PlotCluster> clusters = area.getClusters(); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("cluster.cluster_list_heading"), |                         TranslatableCaption.of("cluster.cluster_list_heading"), | ||||||
|                         TagResolver.resolver("amount", Tag.inserting(Component.text(clusters.size()))) |                         Template.of("amount", clusters.size() + "") | ||||||
|                 ); |                 ); | ||||||
|                 for (PlotCluster cluster : clusters) { |                 for (PlotCluster cluster : clusters) { | ||||||
|                     // Ignore unmanaged clusters |                     // Ignore unmanaged clusters | ||||||
| @@ -112,22 +103,22 @@ public class Cluster extends SubCommand { | |||||||
|                     if (player.getUUID().equals(cluster.owner)) { |                     if (player.getUUID().equals(cluster.owner)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("cluster.cluster_list_element_owner"), |                                 TranslatableCaption.of("cluster.cluster_list_element_owner"), | ||||||
|                                 TagResolver.resolver("cluster", Tag.inserting(Component.text(name))) |                                 Template.of("cluster", name) | ||||||
|                         ); |                         ); | ||||||
|                     } else if (cluster.helpers.contains(player.getUUID())) { |                     } else if (cluster.helpers.contains(player.getUUID())) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("cluster.cluster_list_element_helpers"), |                                 TranslatableCaption.of("cluster.cluster_list_element_helpers"), | ||||||
|                                 TagResolver.resolver("cluster", Tag.inserting(Component.text(name))) |                                 Template.of("cluster", name) | ||||||
|                         ); |                         ); | ||||||
|                     } else if (cluster.invited.contains(player.getUUID())) { |                     } else if (cluster.invited.contains(player.getUUID())) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("cluster.cluster_list_element_invited"), |                                 TranslatableCaption.of("cluster.cluster_list_element_invited"), | ||||||
|                                 TagResolver.resolver("cluster", Tag.inserting(Component.text(name))) |                                 Template.of("cluster", name) | ||||||
|                         ); |                         ); | ||||||
|                     } else { |                     } else { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("cluster.cluster_list_element"), |                                 TranslatableCaption.of("cluster.cluster_list_element"), | ||||||
|                                 TagResolver.resolver("cluster", Tag.inserting(Component.text(cluster.toString()))) |                                 Template.of("cluster", cluster.toString()) | ||||||
|                         ); |                         ); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| @@ -135,13 +126,10 @@ public class Cluster extends SubCommand { | |||||||
|             } |             } | ||||||
|             case "c": |             case "c": | ||||||
|             case "create": { |             case "create": { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_CREATE)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_CREATE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_CLUSTER_CREATE)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_CLUSTER_CREATE) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -153,10 +141,7 @@ public class Cluster extends SubCommand { | |||||||
|                 if (args.length != 4) { |                 if (args.length != 4) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver( |                             Template.of("value", "/plot cluster create <name> <id-bot> <id-top>") | ||||||
|                                     "value", |  | ||||||
|                                     Tag.inserting(Component.text("/plot cluster create <name> <id-bot> <id-top>")) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -166,7 +151,7 @@ public class Cluster extends SubCommand { | |||||||
|                 if (currentClusters >= player.getAllowedPlots()) { |                 if (currentClusters >= player.getAllowedPlots()) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.cant_claim_more_clusters"), |                             TranslatableCaption.of("permission.cant_claim_more_clusters"), | ||||||
|                             TagResolver.resolver("amount", Tag.inserting(Component.text(player.getAllowedPlots()))) |                             Template.of("amount", String.valueOf(player.getAllowedPlots())) | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|                 PlotId pos1; |                 PlotId pos1; | ||||||
| @@ -184,7 +169,7 @@ public class Cluster extends SubCommand { | |||||||
|                 if (area.getCluster(name) != null) { |                 if (area.getCluster(name) != null) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("alias.alias_is_taken"), |                             TranslatableCaption.of("alias.alias_is_taken"), | ||||||
|                             TagResolver.resolver("alias", Tag.inserting(Component.text(name))) |                             Template.of("alias", name) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -198,7 +183,7 @@ public class Cluster extends SubCommand { | |||||||
|                 if (cluster != null) { |                 if (cluster != null) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("cluster.cluster_intersection"), |                             TranslatableCaption.of("cluster.cluster_intersection"), | ||||||
|                             TagResolver.resolver("cluster", Tag.inserting(Component.text(cluster.getName()))) |                             Template.of("cluster", cluster.getName()) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -206,22 +191,20 @@ public class Cluster extends SubCommand { | |||||||
|                 if (!area.contains(pos1) || !area.contains(pos2)) { |                 if (!area.contains(pos1) || !area.contains(pos2)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("cluster.cluster_outside"), |                             TranslatableCaption.of("cluster.cluster_outside"), | ||||||
|                             TagResolver.resolver("area", Tag.inserting(Component.text(area.toString()))) |                             Template.of("area", String.valueOf(area)) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 Set<Plot> plots = area.getPlotSelectionOwned(pos1, pos2); |                 Set<Plot> plots = area.getPlotSelectionOwned(pos1, pos2); | ||||||
|                 if (!plots.isEmpty()) { |                 if (!plots.isEmpty()) { | ||||||
|                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_CREATE_OTHER)) { |                     if (!Permissions | ||||||
|  |                             .hasPermission(player, Permission.PERMISSION_CLUSTER_CREATE_OTHER)) { | ||||||
|                         UUID uuid = player.getUUID(); |                         UUID uuid = player.getUUID(); | ||||||
|                         for (Plot plot : plots) { |                         for (Plot plot : plots) { | ||||||
|                             if (!plot.isOwner(uuid)) { |                             if (!plot.isOwner(uuid)) { | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("permission.no_permission"), |                                         TranslatableCaption.of("permission.no_permission"), | ||||||
|                                         TagResolver.resolver( |                                         Template.of("node", String.valueOf(Permission.PERMISSION_CLUSTER_CREATE_OTHER)) | ||||||
|                                                 "node", |  | ||||||
|                                                 Tag.inserting(Permission.PERMISSION_CLUSTER_CREATE_OTHER) |  | ||||||
|                                         ) |  | ||||||
|                                 ); |                                 ); | ||||||
|                                 return false; |                                 return false; | ||||||
|                             } |                             } | ||||||
| @@ -236,17 +219,14 @@ public class Cluster extends SubCommand { | |||||||
|                 } else { |                 } else { | ||||||
|                     current = player.getPlayerClusterCount(player.getLocation().getWorldName()); |                     current = player.getPlayerClusterCount(player.getLocation().getWorldName()); | ||||||
|                 } |                 } | ||||||
|                 int allowed = player.hasPermissionRange( |                 int allowed = Permissions | ||||||
|                         Permission.PERMISSION_CLUSTER_SIZE, |                         .hasPermissionRange(player, Permission.PERMISSION_CLUSTER_SIZE, | ||||||
|                         Settings.Limit.MAX_PLOTS |                                 Settings.Limit.MAX_PLOTS | ||||||
|                 ); |                         ); | ||||||
|                 if (current + cluster.getArea() > allowed) { |                 if (current + cluster.getArea() > allowed) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", Permission.PERMISSION_CLUSTER_SIZE + "." + (current + cluster.getArea())) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Component.text(Permission.PERMISSION_CLUSTER_SIZE + "." + (current + cluster.getArea()))) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -265,27 +245,24 @@ public class Cluster extends SubCommand { | |||||||
|                 } |                 } | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("cluster.cluster_created"), |                         TranslatableCaption.of("cluster.cluster_created"), | ||||||
|                         TagResolver.resolver("name", Tag.inserting(Component.text(name))) |                         Template.of("name", name) | ||||||
|                 ); |                 ); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "disband": |             case "disband": | ||||||
|             case "del": |             case "del": | ||||||
|             case "delete": { |             case "delete": { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_DELETE)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_DELETE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_CLUSTER_DELETE)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_CLUSTER_DELETE) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (args.length != 1 && args.length != 2) { |                 if (args.length != 1 && args.length != 2) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text("/plot cluster delete [name]"))) |                             Template.of("value", "/plot cluster delete [name]") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -300,7 +277,7 @@ public class Cluster extends SubCommand { | |||||||
|                     if (cluster == null) { |                     if (cluster == null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("cluster.invalid_cluster_name"), |                                 TranslatableCaption.of("cluster.invalid_cluster_name"), | ||||||
|                                 TagResolver.resolver("cluster", Tag.inserting(Component.text(args[1]))) |                                 Template.of("cluster", args[1]) | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -312,40 +289,35 @@ public class Cluster extends SubCommand { | |||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 if (!cluster.owner.equals(player.getUUID())) { |                 if (!cluster.owner.equals(player.getUUID())) { | ||||||
|                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_DELETE_OTHER)) { |                     if (!Permissions | ||||||
|  |                             .hasPermission(player, Permission.PERMISSION_CLUSTER_DELETE_OTHER)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("node", String.valueOf(Permission.PERMISSION_CLUSTER_DELETE_OTHER)) | ||||||
|                                         "node", |  | ||||||
|                                         Tag.inserting(Permission.PERMISSION_CLUSTER_DELETE_OTHER) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 DBFunc.delete(cluster); |                 DBFunc.delete(cluster); | ||||||
|                 player.sendMessage(TranslatableCaption.of("cluster.cluster_deleted"), TagResolver.resolver( |                 player.sendMessage(TranslatableCaption.of("cluster.cluster_deleted"), Template.of( | ||||||
|                         "cluster", |                         "cluster", | ||||||
|                         Tag.inserting(Component.text(cluster.toString())) |                         String.valueOf(cluster) | ||||||
|                 )); |                 )); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "res": |             case "res": | ||||||
|             case "resize": { |             case "resize": { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_RESIZE)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_RESIZE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_CLUSTER_RESIZE)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_CLUSTER_RESIZE) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (args.length != 3) { |                 if (args.length != 3) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text("/plot cluster resize [name]"))) |                             Template.of("value", "/plot cluster resize [name]") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -375,13 +347,11 @@ public class Cluster extends SubCommand { | |||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (!cluster.hasHelperRights(player.getUUID())) { |                 if (!cluster.hasHelperRights(player.getUUID())) { | ||||||
|                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_RESIZE_OTHER)) { |                     if (!Permissions | ||||||
|  |                             .hasPermission(player, Permission.PERMISSION_CLUSTER_RESIZE_OTHER)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("node", String.valueOf(Permission.PERMISSION_CLUSTER_RESIZE_OTHER)) | ||||||
|                                         "node", |  | ||||||
|                                         Tag.inserting(Permission.PERMISSION_CLUSTER_RESIZE_OTHER) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -391,37 +361,34 @@ public class Cluster extends SubCommand { | |||||||
|                 if (intersect != null) { |                 if (intersect != null) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("cluster.cluster_intersection"), |                             TranslatableCaption.of("cluster.cluster_intersection"), | ||||||
|                             TagResolver.resolver("cluster", Tag.inserting(Component.text(intersect.getName()))) |                             Template.of("cluster", intersect.getName()) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 Set<Plot> existing = area.getPlotSelectionOwned(cluster.getP1(), cluster.getP2()); |                 Set<Plot> existing = area.getPlotSelectionOwned(cluster.getP1(), cluster.getP2()); | ||||||
|                 Set<Plot> newPlots = area.getPlotSelectionOwned(pos1, pos2); |                 Set<Plot> newPlots = area.getPlotSelectionOwned(pos1, pos2); | ||||||
|  |                 // Set<Plot> removed = (HashSet<Plot>) existing.clone(); | ||||||
|                 Set<Plot> removed = new HashSet<>(existing); |                 Set<Plot> removed = new HashSet<>(existing); | ||||||
|  |  | ||||||
|                 removed.removeAll(newPlots); |                 removed.removeAll(newPlots); | ||||||
|                 // Check expand / shrink |                 // Check expand / shrink | ||||||
|                 if (!removed.isEmpty()) { |                 if (!removed.isEmpty()) { | ||||||
|                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_RESIZE_SHRINK)) { |                     if (!Permissions | ||||||
|  |                             .hasPermission(player, Permission.PERMISSION_CLUSTER_RESIZE_SHRINK)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("node", String.valueOf(Permission.PERMISSION_CLUSTER_RESIZE_SHRINK)) | ||||||
|                                         "node", |  | ||||||
|                                         Tag.inserting(Permission.PERMISSION_CLUSTER_RESIZE_SHRINK) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 newPlots.removeAll(existing); |                 newPlots.removeAll(existing); | ||||||
|                 if (!newPlots.isEmpty()) { |                 if (!newPlots.isEmpty()) { | ||||||
|                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_RESIZE_EXPAND)) { |                     if (!Permissions | ||||||
|  |                             .hasPermission(player, Permission.PERMISSION_CLUSTER_RESIZE_EXPAND)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("node", String.valueOf(Permission.PERMISSION_CLUSTER_RESIZE_EXPAND)) | ||||||
|                                         "node", |  | ||||||
|                                         Tag.inserting(Permission.PERMISSION_CLUSTER_RESIZE_EXPAND) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -434,16 +401,13 @@ public class Cluster extends SubCommand { | |||||||
|                     current = player.getPlayerClusterCount(player.getLocation().getWorldName()); |                     current = player.getPlayerClusterCount(player.getLocation().getWorldName()); | ||||||
|                 } |                 } | ||||||
|                 current -= cluster.getArea() + (1 + pos2.getX() - pos1.getX()) * (1 + pos2.getY() - pos1.getY()); |                 current -= cluster.getArea() + (1 + pos2.getX() - pos1.getX()) * (1 + pos2.getY() - pos1.getY()); | ||||||
|                 int allowed = player.hasPermissionRange( |                 int allowed = Permissions.hasPermissionRange(player, Permission.PERMISSION_CLUSTER, | ||||||
|                         Permission.PERMISSION_CLUSTER, |  | ||||||
|                         Settings.Limit.MAX_PLOTS |                         Settings.Limit.MAX_PLOTS | ||||||
|                 ); |                 ); | ||||||
|                 if (current + cluster.getArea() > allowed) { |                 if (current + cluster.getArea() > allowed) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text( |                             Template.of("node", Permission.PERMISSION_CLUSTER + "." + (current + cluster.getArea())) | ||||||
|                                     Permission.PERMISSION_CLUSTER + "." + (current + cluster.getArea()) |  | ||||||
|                             ))) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -455,20 +419,17 @@ public class Cluster extends SubCommand { | |||||||
|             case "add": |             case "add": | ||||||
|             case "inv": |             case "inv": | ||||||
|             case "invite": { |             case "invite": { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_INVITE)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_INVITE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_CLUSTER_INVITE)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_CLUSTER_INVITE) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (args.length != 2) { |                 if (args.length != 2) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text("/plot cluster invite <player>"))) |                             Template.of("value", "/plot cluster invite <player>") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -483,13 +444,11 @@ public class Cluster extends SubCommand { | |||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (!cluster.hasHelperRights(player.getUUID())) { |                 if (!cluster.hasHelperRights(player.getUUID())) { | ||||||
|                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_INVITE_OTHER)) { |                     if (!Permissions | ||||||
|  |                             .hasPermission(player, Permission.PERMISSION_CLUSTER_INVITE_OTHER)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("node", Permission.PERMISSION_CLUSTER_INVITE_OTHER.toString()) | ||||||
|                                         "node", |  | ||||||
|                                         Tag.inserting(Permission.PERMISSION_CLUSTER_INVITE_OTHER) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -502,7 +461,7 @@ public class Cluster extends SubCommand { | |||||||
|                             } else if (throwable != null) { |                             } else if (throwable != null) { | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("errors.invalid_player"), |                                         TranslatableCaption.of("errors.invalid_player"), | ||||||
|                                         TagResolver.resolver("value", Tag.inserting(Component.text(args[1]))) |                                         Template.of("value", args[1]) | ||||||
|                                 ); |                                 ); | ||||||
|                             } else { |                             } else { | ||||||
|                                 if (!cluster.isAdded(uuid)) { |                                 if (!cluster.isAdded(uuid)) { | ||||||
| @@ -514,7 +473,7 @@ public class Cluster extends SubCommand { | |||||||
|                                     if (otherPlayer != null) { |                                     if (otherPlayer != null) { | ||||||
|                                         player.sendMessage( |                                         player.sendMessage( | ||||||
|                                                 TranslatableCaption.of("cluster.cluster_invited"), |                                                 TranslatableCaption.of("cluster.cluster_invited"), | ||||||
|                                                 TagResolver.resolver("cluster", Tag.inserting(Component.text(cluster.getName()))) |                                                 Template.of("cluster", cluster.getName()) | ||||||
|                                         ); |                                         ); | ||||||
|                                     } |                                     } | ||||||
|                                 } |                                 } | ||||||
| @@ -526,20 +485,17 @@ public class Cluster extends SubCommand { | |||||||
|             case "k": |             case "k": | ||||||
|             case "remove": |             case "remove": | ||||||
|             case "kick": { |             case "kick": { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_KICK)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_KICK)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", Permission.PERMISSION_CLUSTER_KICK.toString()) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_CLUSTER_KICK) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (args.length != 2) { |                 if (args.length != 2) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text("/plot cluster kick <player>"))) |                             Template.of("value", "/plot cluster kick <player>") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -553,13 +509,11 @@ public class Cluster extends SubCommand { | |||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (!cluster.hasHelperRights(player.getUUID())) { |                 if (!cluster.hasHelperRights(player.getUUID())) { | ||||||
|                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_KICK_OTHER)) { |                     if (!Permissions | ||||||
|  |                             .hasPermission(player, Permission.PERMISSION_CLUSTER_KICK_OTHER)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("node", Permission.PERMISSION_CLUSTER_KICK_OTHER.toString()) | ||||||
|                                         "node", |  | ||||||
|                                         Tag.inserting(Permission.PERMISSION_CLUSTER_KICK_OTHER) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -572,7 +526,7 @@ public class Cluster extends SubCommand { | |||||||
|                             } else if (throwable != null) { |                             } else if (throwable != null) { | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("errors.invalid_player"), |                                         TranslatableCaption.of("errors.invalid_player"), | ||||||
|                                         TagResolver.resolver("value", Tag.inserting(Component.text(args[1]))) |                                         Template.of("value", args[1]) | ||||||
|                                 ); |                                 ); | ||||||
|                             } else { |                             } else { | ||||||
|                                 // Can't kick if the player is yourself, the owner, or not added to the cluster |                                 // Can't kick if the player is yourself, the owner, or not added to the cluster | ||||||
| @@ -580,7 +534,7 @@ public class Cluster extends SubCommand { | |||||||
|                                         || !cluster.isAdded(uuid)) { |                                         || !cluster.isAdded(uuid)) { | ||||||
|                                     player.sendMessage( |                                     player.sendMessage( | ||||||
|                                             TranslatableCaption.of("cluster.cannot_kick_player"), |                                             TranslatableCaption.of("cluster.cannot_kick_player"), | ||||||
|                                             TagResolver.resolver("value", Tag.inserting(Component.text(cluster.getName()))) |                                             Template.of("value", cluster.getName()) | ||||||
|                                     ); |                                     ); | ||||||
|                                 } else { |                                 } else { | ||||||
|                                     if (cluster.helpers.contains(uuid)) { |                                     if (cluster.helpers.contains(uuid)) { | ||||||
| @@ -595,7 +549,7 @@ public class Cluster extends SubCommand { | |||||||
|                                     if (player2 != null) { |                                     if (player2 != null) { | ||||||
|                                         player.sendMessage( |                                         player.sendMessage( | ||||||
|                                                 TranslatableCaption.of("cluster.cluster_removed"), |                                                 TranslatableCaption.of("cluster.cluster_removed"), | ||||||
|                                                 TagResolver.resolver("cluster", Tag.inserting(Component.text(cluster.getName()))) |                                                 Template.of("cluster", cluster.getName()) | ||||||
|                                         ); |                                         ); | ||||||
|                                     } |                                     } | ||||||
|                                     removePlayerPlots(cluster, uuid, player2.getLocation().getWorldName()); |                                     removePlayerPlots(cluster, uuid, player2.getLocation().getWorldName()); | ||||||
| @@ -607,20 +561,17 @@ public class Cluster extends SubCommand { | |||||||
|             } |             } | ||||||
|             case "quit": |             case "quit": | ||||||
|             case "leave": { |             case "leave": { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_LEAVE)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_LEAVE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", Permission.PERMISSION_CLUSTER_LEAVE.toString()) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_CLUSTER_LEAVE) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (args.length != 1 && args.length != 2) { |                 if (args.length != 1 && args.length != 2) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text("/plot cluster leave [name]"))) |                             Template.of("value", "/plot cluster leave [name]") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -634,7 +585,7 @@ public class Cluster extends SubCommand { | |||||||
|                     if (cluster == null) { |                     if (cluster == null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("cluster.invalid_cluster_name"), |                                 TranslatableCaption.of("cluster.invalid_cluster_name"), | ||||||
|                                 TagResolver.resolver("cluster", Tag.inserting(Component.text(args[1]))) |                                 Template.of("cluster", args[1]) | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -662,29 +613,23 @@ public class Cluster extends SubCommand { | |||||||
|                 DBFunc.removeInvited(cluster, uuid); |                 DBFunc.removeInvited(cluster, uuid); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("cluster.cluster_removed"), |                         TranslatableCaption.of("cluster.cluster_removed"), | ||||||
|                         TagResolver.resolver("cluster", Tag.inserting(Component.text(cluster.getName()))) |                         Template.of("cluster", cluster.getName()) | ||||||
|                 ); |                 ); | ||||||
|                 removePlayerPlots(cluster, uuid, player.getLocation().getWorldName()); |                 removePlayerPlots(cluster, uuid, player.getLocation().getWorldName()); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "members": { |             case "members": { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_HELPERS)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_HELPERS)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", Permission.PERMISSION_CLUSTER_HELPERS.toString()) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Component.text(Permission.PERMISSION_CLUSTER_HELPERS.toString())) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (args.length != 3) { |                 if (args.length != 3) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver( |                             Template.of("value", "/plot cluster members <add | remove> <player>") | ||||||
|                                     "value", |  | ||||||
|                                     Tag.inserting(Component.text("/plot cluster members <add | remove> <player>")) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -705,7 +650,7 @@ public class Cluster extends SubCommand { | |||||||
|                             } else if (throwable != null) { |                             } else if (throwable != null) { | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("errors.invalid_player"), |                                         TranslatableCaption.of("errors.invalid_player"), | ||||||
|                                         TagResolver.resolver("value", Tag.inserting(Component.text(args[2]))) |                                         Template.of("value", args[2]) | ||||||
|                                 ); |                                 ); | ||||||
|                             } else { |                             } else { | ||||||
|                                 if (args[1].equalsIgnoreCase("add")) { |                                 if (args[1].equalsIgnoreCase("add")) { | ||||||
| @@ -719,9 +664,7 @@ public class Cluster extends SubCommand { | |||||||
|                                 } else { |                                 } else { | ||||||
|                                     player.sendMessage( |                                     player.sendMessage( | ||||||
|                                             TranslatableCaption.of("commandconfig.command_syntax"), |                                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                                             TagResolver.resolver("value", Tag.inserting(Component.text( |                                             Template.of("value", "/plot cluster members <add | remove> <player>") | ||||||
|                                                     "/plot cluster members <add | remove> <player>" |  | ||||||
|                                             ))) |  | ||||||
|                                     ); |                                     ); | ||||||
|                                 } |                                 } | ||||||
|                             } |                             } | ||||||
| @@ -731,20 +674,17 @@ public class Cluster extends SubCommand { | |||||||
|             case "spawn": |             case "spawn": | ||||||
|             case "home": |             case "home": | ||||||
|             case "tp": { |             case "tp": { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_TP)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_TP)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", Permission.PERMISSION_CLUSTER_TP.toString()) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_CLUSTER_TP) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (args.length != 2) { |                 if (args.length != 2) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text("/plot cluster tp <name>"))) |                             Template.of("value", "/plot cluster tp <name>") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -757,19 +697,16 @@ public class Cluster extends SubCommand { | |||||||
|                 if (cluster == null) { |                 if (cluster == null) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("cluster.invalid_cluster_name"), |                             TranslatableCaption.of("cluster.invalid_cluster_name"), | ||||||
|                             TagResolver.resolver("cluster", Tag.inserting(Component.text(args[1]))) |                             Template.of("cluster", args[1]) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 UUID uuid = player.getUUID(); |                 UUID uuid = player.getUUID(); | ||||||
|                 if (!cluster.isAdded(uuid)) { |                 if (!cluster.isAdded(uuid)) { | ||||||
|                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_TP_OTHER)) { |                     if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_TP_OTHER)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("node", Permission.PERMISSION_CLUSTER_TP_OTHER.toString()) | ||||||
|                                         "node", |  | ||||||
|                                         Tag.inserting(Permission.PERMISSION_CLUSTER_TP_OTHER) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -782,20 +719,17 @@ public class Cluster extends SubCommand { | |||||||
|             case "info": |             case "info": | ||||||
|             case "show": |             case "show": | ||||||
|             case "information": { |             case "information": { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_INFO)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_INFO)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", Permission.PERMISSION_CLUSTER_TP.toString()) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_CLUSTER_TP) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (args.length != 1 && args.length != 2) { |                 if (args.length != 1 && args.length != 2) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text("/plot cluster info [name]"))) |                             Template.of("value", "/plot cluster info [name]") | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|                 PlotArea area = player.getApplicablePlotArea(); |                 PlotArea area = player.getApplicablePlotArea(); | ||||||
| @@ -809,7 +743,7 @@ public class Cluster extends SubCommand { | |||||||
|                     if (cluster == null) { |                     if (cluster == null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("cluster.invalid_cluster_name"), |                                 TranslatableCaption.of("cluster.invalid_cluster_name"), | ||||||
|                                 TagResolver.resolver("cluster", Tag.inserting(Component.text(args[1]))) |                                 Template.of("cluster", args[1]) | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -838,14 +772,19 @@ public class Cluster extends SubCommand { | |||||||
|                                         cluster.getP2().getY() - cluster.getP1().getY() + 1); |                                         cluster.getP2().getY() - cluster.getP1().getY() + 1); | ||||||
|                                 String rights = cluster.isAdded(player.getUUID()) + ""; |                                 String rights = cluster.isAdded(player.getUUID()) + ""; | ||||||
|                                 Caption message = TranslatableCaption.of("cluster.cluster_info"); |                                 Caption message = TranslatableCaption.of("cluster.cluster_info"); | ||||||
|                                 TagResolver resolver = TagResolver.builder() |                                 Template idTemplate = Template.of("id", id); | ||||||
|                                         .tag("id", Tag.inserting(Component.text(id))) |                                 Template ownerTemplate = Template.of("owner", owner); | ||||||
|                                         .tag("owner", Tag.inserting(Component.text(owner))) |                                 Template nameTemplate = Template.of("name", name); | ||||||
|                                         .tag("name", Tag.inserting(Component.text(name))) |                                 Template sizeTemplate = Template.of("size", size); | ||||||
|                                         .tag("size", Tag.inserting(Component.text(size))) |                                 Template rightsTemplate = Template.of("rights", rights); | ||||||
|                                         .tag("rights", Tag.inserting(Component.text(rights))) |                                 player.sendMessage( | ||||||
|                                         .build(); |                                         message, | ||||||
|                                 player.sendMessage(message, resolver); |                                         idTemplate, | ||||||
|  |                                         ownerTemplate, | ||||||
|  |                                         nameTemplate, | ||||||
|  |                                         sizeTemplate, | ||||||
|  |                                         rightsTemplate | ||||||
|  |                                 ); | ||||||
|                             } |                             } | ||||||
|                         }); |                         }); | ||||||
|                 return true; |                 return true; | ||||||
| @@ -853,17 +792,17 @@ public class Cluster extends SubCommand { | |||||||
|             case "sh": |             case "sh": | ||||||
|             case "setspawn": |             case "setspawn": | ||||||
|             case "sethome": { |             case "sethome": { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_SETHOME)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_SETHOME)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_CLUSTER_SETHOME)) |                             Template.of("node", Permission.PERMISSION_CLUSTER_SETHOME.toString()) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (args.length != 1 && args.length != 2) { |                 if (args.length != 1 && args.length != 2) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text("/plot cluster sethome"))) |                             Template.of("value", "/plot cluster sethome") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -877,13 +816,11 @@ public class Cluster extends SubCommand { | |||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (!cluster.hasHelperRights(player.getUUID())) { |                 if (!cluster.hasHelperRights(player.getUUID())) { | ||||||
|                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_SETHOME_OTHER)) { |                     if (!Permissions | ||||||
|  |                             .hasPermission(player, Permission.PERMISSION_CLUSTER_SETHOME_OTHER)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("node", Permission.PERMISSION_CLUSTER_SETHOME_OTHER.toString()) | ||||||
|                                         "node", |  | ||||||
|                                         Tag.inserting(Permission.PERMISSION_CLUSTER_SETHOME_OTHER) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -902,7 +839,10 @@ public class Cluster extends SubCommand { | |||||||
|         } |         } | ||||||
|         player.sendMessage( |         player.sendMessage( | ||||||
|                 TranslatableCaption.of("cluster.cluster_available_args"), |                 TranslatableCaption.of("cluster.cluster_available_args"), | ||||||
|                 TagResolver.resolver("list", Tag.inserting(ComponentHelper.join(AVAILABLE_ARGS, SEPARATOR))) |                 Template.of( | ||||||
|  |                         "list", | ||||||
|  |                         "<dark_aqua>list</dark_aqua><gray>, </gray><dark_aqua>create</dark_aqua><gray>, </gray><dark_aqua>delete</dark_aqua><gray>, </gray><dark_aqua>resize</dark_aqua><gray>, </gray><dark_aqua>invite</dark_aqua><gray>, </gray><dark_aqua>kick</dark_aqua><gray>, </gray><dark_aqua>leave</dark_aqua><gray>, </gray><dark_aqua>members</dark_aqua><gray>, </gray><dark_aqua>info</dark_aqua><gray>, </gray><dark_aqua>tp</dark_aqua><gray>, </gray><dark_aqua>sethome</dark_aqua>" | ||||||
|  |                 ) | ||||||
|         ); |         ); | ||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
| @@ -929,37 +869,37 @@ public class Cluster extends SubCommand { | |||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         if (args.length == 1) { |         if (args.length == 1) { | ||||||
|             final List<String> completions = new LinkedList<>(); |             final List<String> completions = new LinkedList<>(); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_CLUSTER_LIST)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_LIST)) { | ||||||
|                 completions.add("list"); |                 completions.add("list"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_CLUSTER_CREATE)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_CREATE)) { | ||||||
|                 completions.add("create"); |                 completions.add("create"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_CLUSTER_DELETE)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_DELETE)) { | ||||||
|                 completions.add("delete"); |                 completions.add("delete"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_CLUSTER_RESIZE)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_RESIZE)) { | ||||||
|                 completions.add("resize"); |                 completions.add("resize"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_CLUSTER_INVITE)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_INVITE)) { | ||||||
|                 completions.add("invite"); |                 completions.add("invite"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_CLUSTER_KICK)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_KICK)) { | ||||||
|                 completions.add("kick"); |                 completions.add("kick"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_CLUSTER_KICK)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_KICK)) { | ||||||
|                 completions.add("leave"); |                 completions.add("leave"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_CLUSTER_HELPERS)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_HELPERS)) { | ||||||
|                 completions.add("members"); |                 completions.add("members"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_CLUSTER_INFO)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_INFO)) { | ||||||
|                 completions.add("info"); |                 completions.add("info"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_CLUSTER_TP)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_TP)) { | ||||||
|                 completions.add("tp"); |                 completions.add("tp"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_CLUSTER_SETHOME)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_SETHOME)) { | ||||||
|                 completions.add("sethome"); |                 completions.add("sethome"); | ||||||
|             } |             } | ||||||
|             final List<Command> commands = completions.stream().filter(completion -> completion |             final List<Command> commands = completions.stream().filter(completion -> completion | ||||||
| @@ -974,7 +914,7 @@ public class Cluster extends SubCommand { | |||||||
|                             CommandCategory.ADMINISTRATION |                             CommandCategory.ADMINISTRATION | ||||||
|                     ) { |                     ) { | ||||||
|                     }).collect(Collectors.toCollection(LinkedList::new)); |                     }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_CLUSTER) && args[0].length() > 0) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER) && args[0].length() > 0) { | ||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             return commands; | ||||||
|   | |||||||
| @@ -25,9 +25,7 @@ import com.plotsquared.core.player.PlayerMetaDataKeys; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import com.plotsquared.core.util.task.TaskTime; | import com.plotsquared.core.util.task.TaskTime; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
| public class CmdConfirm { | public class CmdConfirm { | ||||||
| @@ -54,11 +52,9 @@ public class CmdConfirm { | |||||||
|         if (commandStr != null) { |         if (commandStr != null) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("confirm.requires_confirm"), |                     TranslatableCaption.of("confirm.requires_confirm"), | ||||||
|                     TagResolver.builder() |                     Template.of("command", commandStr), | ||||||
|                             .tag("command", Tag.inserting(Component.text(commandStr))) |                     Template.of("timeout", String.valueOf(Settings.Confirmation.CONFIRMATION_TIMEOUT_SECONDS)), | ||||||
|                             .tag("timeout", Tag.inserting(Component.text(Settings.Confirmation.CONFIRMATION_TIMEOUT_SECONDS))) |                     Template.of("value", "/plot confirm") | ||||||
|                             .tag("value", Tag.inserting(Component.text("/plot confirm"))) |  | ||||||
|                             .build() |  | ||||||
|             ); |             ); | ||||||
|         } |         } | ||||||
|         TaskManager.runTaskLater(() -> { |         TaskManager.runTaskLater(() -> { | ||||||
|   | |||||||
| @@ -25,14 +25,13 @@ import com.plotsquared.core.configuration.caption.TranslatableCaption; | |||||||
| import com.plotsquared.core.permissions.PermissionHolder; | import com.plotsquared.core.permissions.PermissionHolder; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.StringComparison; | import com.plotsquared.core.util.StringComparison; | ||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import net.kyori.adventure.text.Component; |  | ||||||
| import net.kyori.adventure.text.minimessage.MiniMessage; | import net.kyori.adventure.text.minimessage.MiniMessage; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
| import java.lang.reflect.InvocationTargetException; | import java.lang.reflect.InvocationTargetException; | ||||||
| @@ -257,14 +256,10 @@ public abstract class Command { | |||||||
|             max = c.size(); |             max = c.size(); | ||||||
|         } |         } | ||||||
|         // Send the header |         // Send the header | ||||||
|         player.sendMessage( |         Template curTemplate = Template.of("cur", String.valueOf(page + 1)); | ||||||
|                 header, |         Template maxTemplate = Template.of("max", String.valueOf(totalPages + 1)); | ||||||
|                 TagResolver.builder() |         Template amountTemplate = Template.of("amount", String.valueOf(c.size())); | ||||||
|                         .tag("cur", Tag.inserting(Component.text(page + 1))) |         player.sendMessage(header, curTemplate, maxTemplate, amountTemplate); | ||||||
|                         .tag("max", Tag.inserting(Component.text(totalPages + 1))) |  | ||||||
|                         .tag("amount", Tag.inserting(Component.text(c.size()))) |  | ||||||
|                         .build() |  | ||||||
|         ); |  | ||||||
|         // Send the page content |         // Send the page content | ||||||
|         List<T> subList = c.subList(page * size, max); |         List<T> subList = c.subList(page * size, max); | ||||||
|         int i = page * size; |         int i = page * size; | ||||||
| @@ -272,24 +267,13 @@ public abstract class Command { | |||||||
|             i++; |             i++; | ||||||
|             final CaptionHolder msg = new CaptionHolder(); |             final CaptionHolder msg = new CaptionHolder(); | ||||||
|             add.run(i, obj, msg); |             add.run(i, obj, msg); | ||||||
|             player.sendMessage(msg.get(), msg.getTagResolvers()); |             player.sendMessage(msg.get(), msg.getTemplates()); | ||||||
|         } |         } | ||||||
|         // Send the footer |         // Send the footer | ||||||
|         player.sendMessage( |         Template command1 = Template.of("command1", baseCommand + " " + page); | ||||||
|                 TranslatableCaption.of("list.page_turn"), |         Template command2 = Template.of("command2", baseCommand + " " + (page + 2)); | ||||||
|                 TagResolver.builder() |         Template clickable = Template.of("clickable", TranslatableCaption.of("list.clickable").getComponent(player)); | ||||||
|                         .tag("cur", Tag.inserting(Component.text(page + 1))) |         player.sendMessage(TranslatableCaption.of("list.page_turn"), command1, command2, clickable); | ||||||
|                         .tag( |  | ||||||
|                                 "command1", |  | ||||||
|                                 Tag.preProcessParsed(baseCommand + " " + page) |  | ||||||
|                         ) |  | ||||||
|                         .tag("command2", Tag.preProcessParsed(baseCommand + " " + (page + 2))) |  | ||||||
|                         .tag( |  | ||||||
|                                 "clickable", |  | ||||||
|                                 Tag.inserting(TranslatableCaption.of("list.clickable").toComponent(player)) |  | ||||||
|                         ) |  | ||||||
|                         .build() |  | ||||||
|         ); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @@ -341,7 +325,7 @@ public abstract class Command { | |||||||
|             if (commands.isEmpty()) { |             if (commands.isEmpty()) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("commandconfig.did_you_mean"), |                         TranslatableCaption.of("commandconfig.did_you_mean"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text(MainCommand.getInstance().help.getUsage()))) |                         Template.of("value", MainCommand.getInstance().help.getUsage()) | ||||||
|                 ); |                 ); | ||||||
|                 return CompletableFuture.completedFuture(false); |                 return CompletableFuture.completedFuture(false); | ||||||
|             } |             } | ||||||
| @@ -362,7 +346,7 @@ public abstract class Command { | |||||||
|             } |             } | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.did_you_mean"), |                     TranslatableCaption.of("commandconfig.did_you_mean"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text(cmd.getUsage()))) |                     Template.of("value", cmd.getUsage()) | ||||||
|             ); |             ); | ||||||
|             return CompletableFuture.completedFuture(false); |             return CompletableFuture.completedFuture(false); | ||||||
|         } |         } | ||||||
| @@ -397,7 +381,7 @@ public abstract class Command { | |||||||
|                 // TODO improve or remove the Argument system |                 // TODO improve or remove the Argument system | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("commandconfig.command_syntax"), |                         TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text(StringMan.join(fullSplit, " ")))) |                         Template.of("value", StringMan.join(fullSplit, " ")) | ||||||
|                 ); |                 ); | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
| @@ -482,11 +466,11 @@ public abstract class Command { | |||||||
|             if (message) { |             if (message) { | ||||||
|                 player.sendMessage(this.required.getErrorMessage()); |                 player.sendMessage(this.required.getErrorMessage()); | ||||||
|             } |             } | ||||||
|         } else if (!player.hasPermission(getPermission())) { |         } else if (!Permissions.hasPermission(player, getPermission())) { | ||||||
|             if (message) { |             if (message) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission"), |                         TranslatableCaption.of("permission.no_permission"), | ||||||
|                         TagResolver.resolver("node", Tag.inserting(Component.text(getPermission()))) |                         Template.of("node", getPermission()) | ||||||
|                 ); |                 ); | ||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
| @@ -511,7 +495,7 @@ public abstract class Command { | |||||||
|     public void sendUsage(PlotPlayer<?> player) { |     public void sendUsage(PlotPlayer<?> player) { | ||||||
|         player.sendMessage( |         player.sendMessage( | ||||||
|                 TranslatableCaption.of("commandconfig.command_syntax"), |                 TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                 TagResolver.resolver("value", Tag.inserting(Component.text(getUsage()))) |                 Template.of("value", getUsage()) | ||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -615,13 +599,13 @@ public abstract class Command { | |||||||
|         return this.getFullId().hashCode(); |         return this.getFullId().hashCode(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public void checkTrue(boolean mustBeTrue, Caption message, TagResolver... args) { |     public void checkTrue(boolean mustBeTrue, Caption message, Template... args) { | ||||||
|         if (!mustBeTrue) { |         if (!mustBeTrue) { | ||||||
|             throw new CommandException(message, args); |             throw new CommandException(message, args); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public <T> T check(T object, Caption message, TagResolver... args) { |     public <T> T check(T object, Caption message, Template... args) { | ||||||
|         if (object == null) { |         if (object == null) { | ||||||
|             throw new CommandException(message, args); |             throw new CommandException(message, args); | ||||||
|         } |         } | ||||||
| @@ -637,10 +621,10 @@ public abstract class Command { | |||||||
|  |  | ||||||
|     public static class CommandException extends RuntimeException { |     public static class CommandException extends RuntimeException { | ||||||
|  |  | ||||||
|  |         private final Template[] args; | ||||||
|         private final Caption message; |         private final Caption message; | ||||||
|         private final TagResolver[] args; |  | ||||||
|  |  | ||||||
|         public CommandException(final @Nullable Caption message, final TagResolver... args) { |         public CommandException(final @Nullable Caption message, final Template... args) { | ||||||
|             this.message = message; |             this.message = message; | ||||||
|             this.args = args; |             this.args = args; | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -19,7 +19,7 @@ | |||||||
| package com.plotsquared.core.command; | package com.plotsquared.core.command; | ||||||
|  |  | ||||||
| import com.plotsquared.core.configuration.caption.Caption; | import com.plotsquared.core.configuration.caption.Caption; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -34,7 +34,7 @@ public interface CommandCaller { | |||||||
|      * @param caption      Caption to send |      * @param caption      Caption to send | ||||||
|      * @param replacements Variable replacements |      * @param replacements Variable replacements | ||||||
|      */ |      */ | ||||||
|     void sendMessage(@NonNull Caption caption, @NonNull TagResolver... replacements); |     void sendMessage(@NonNull Caption caption, @NonNull Template... replacements); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Check the player's permissions. <i>Will be cached if permission caching is enabled.</i> |      * Check the player's permissions. <i>Will be cached if permission caching is enabled.</i> | ||||||
|   | |||||||
| @@ -22,8 +22,6 @@ import com.plotsquared.core.configuration.caption.Caption; | |||||||
| import com.plotsquared.core.configuration.caption.LocaleHolder; | import com.plotsquared.core.configuration.caption.LocaleHolder; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import net.kyori.adventure.text.Component; |  | ||||||
| import net.kyori.adventure.text.minimessage.MiniMessage; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -92,11 +90,6 @@ public enum CommandCategory implements Caption { | |||||||
|         return this.caption.getComponent(localeHolder); |         return this.caption.getComponent(localeHolder); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public @NonNull Component toComponent(@NonNull final LocaleHolder localeHolder) { |  | ||||||
|         return MiniMessage.miniMessage().deserialize(getComponent(localeHolder)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Checks if a player has access to this command category |      * Checks if a player has access to this command category | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -27,9 +27,7 @@ import com.plotsquared.core.plot.comment.CommentInbox; | |||||||
| import com.plotsquared.core.plot.comment.CommentManager; | import com.plotsquared.core.plot.comment.CommentManager; | ||||||
| import com.plotsquared.core.plot.comment.PlotComment; | import com.plotsquared.core.plot.comment.PlotComment; | ||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
|  |  | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
| import java.util.Locale; | import java.util.Locale; | ||||||
| @@ -46,10 +44,8 @@ public class Comment extends SubCommand { | |||||||
|         if (args.length < 2) { |         if (args.length < 2) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("comment.comment_syntax"), |                     TranslatableCaption.of("comment.comment_syntax"), | ||||||
|                     TagResolver.builder() |                     Template.of("command", "/plot comment [X;Z]"), | ||||||
|                             .tag("command", Tag.inserting(Component.text("/plot comment [X;Z]"))) |                     Template.of("list", StringMan.join(CommentManager.inboxes.keySet(), "|")) | ||||||
|                             .tag("list", Tag.inserting(Component.text(StringMan.join(CommentManager.inboxes.keySet(), "|")))) |  | ||||||
|                             .build() |  | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -68,10 +64,8 @@ public class Comment extends SubCommand { | |||||||
|             if (args.length < 3) { |             if (args.length < 3) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("comment.comment_syntax"), |                         TranslatableCaption.of("comment.comment_syntax"), | ||||||
|                         TagResolver.builder() |                         Template.of("command", "/plot comment [X;Z]"), | ||||||
|                                 .tag("command", Tag.inserting(Component.text("/plot comment [X;Z]"))) |                         Template.of("list", StringMan.join(CommentManager.inboxes.keySet(), "|")) | ||||||
|                                 .tag("list", Tag.inserting(Component.text(StringMan.join(CommentManager.inboxes.keySet(), "|")))) |  | ||||||
|                                 .build() |  | ||||||
|                 ); |                 ); | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
| @@ -82,10 +76,8 @@ public class Comment extends SubCommand { | |||||||
|         if (inbox == null) { |         if (inbox == null) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("comment.comment_syntax"), |                     TranslatableCaption.of("comment.comment_syntax"), | ||||||
|                     TagResolver.builder() |                     Template.of("command", "/plot comment [X;Z]"), | ||||||
|                             .tag("command", Tag.inserting(Component.text("/plot comment [X;Z]"))) |                     Template.of("list", StringMan.join(CommentManager.inboxes.keySet(), "|")) | ||||||
|                             .tag("list", Tag.inserting(Component.text(StringMan.join(CommentManager.inboxes.keySet(), "|")))) |  | ||||||
|                             .build() |  | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -105,10 +97,8 @@ public class Comment extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("comment.no_plot_inbox")); |             player.sendMessage(TranslatableCaption.of("comment.no_plot_inbox")); | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("comment.comment_syntax"), |                     TranslatableCaption.of("comment.comment_syntax"), | ||||||
|                     TagResolver.builder() |                     Template.of("command", "/plot comment [X;Z]"), | ||||||
|                             .tag("command", Tag.inserting(Component.text("/plot comment [X;Z]"))) |                     Template.of("list", StringMan.join(CommentManager.inboxes.keySet(), "|")) | ||||||
|                             .tag("list", Tag.inserting(Component.text(StringMan.join(CommentManager.inboxes.keySet(), "|")))) |  | ||||||
|                             .build() |  | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -29,9 +29,7 @@ import com.plotsquared.core.util.MathMan; | |||||||
| import com.plotsquared.core.util.WorldUtil; | import com.plotsquared.core.util.WorldUtil; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import com.plotsquared.core.util.task.TaskTime; | import com.plotsquared.core.util.task.TaskTime; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| @@ -70,9 +68,7 @@ public class Condense extends SubCommand { | |||||||
|         if (args.length != 2 && args.length != 3) { |         if (args.length != 2 && args.length != 3) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text( |                     Template.of("value", "/plot condense <area> <start | stop | info> [radius]") | ||||||
|                             "/plot condense <area> <start | stop | info> [radius]" |  | ||||||
|                     ))) |  | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -86,10 +82,7 @@ public class Condense extends SubCommand { | |||||||
|                 if (args.length == 2) { |                 if (args.length == 2) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver( |                             Template.of("value", "/plot condense" + area + " start <radius>") | ||||||
|                                     "value", |  | ||||||
|                                     Tag.inserting(Component.text("/plot condense" + area + " start " + "<radius>")) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -188,10 +181,8 @@ public class Condense extends SubCommand { | |||||||
|                                     if (result.get()) { |                                     if (result.get()) { | ||||||
|                                         player.sendMessage( |                                         player.sendMessage( | ||||||
|                                                 TranslatableCaption.of("condense.moving"), |                                                 TranslatableCaption.of("condense.moving"), | ||||||
|                                                 TagResolver.builder() |                                                 Template.of("origin", String.valueOf(origin)), | ||||||
|                                                         .tag("origin", Tag.inserting(Component.text(origin.toString()))) |                                                 Template.of("possible", String.valueOf(possible)) | ||||||
|                                                         .tag("possible", Tag.inserting(Component.text(possible.toString()))) |  | ||||||
|                                                         .build() |  | ||||||
|                                         ); |                                         ); | ||||||
|                                         TaskManager.runTaskLater(task, TaskTime.ticks(1L)); |                                         TaskManager.runTaskLater(task, TaskTime.ticks(1L)); | ||||||
|                                     } |                                     } | ||||||
| @@ -211,7 +202,7 @@ public class Condense extends SubCommand { | |||||||
|                         if (i >= free.size()) { |                         if (i >= free.size()) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("condense.skipping"), |                                     TranslatableCaption.of("condense.skipping"), | ||||||
|                                     TagResolver.resolver("plot", Tag.inserting(Component.text(origin.toString()))) |                                     Template.of("plot", String.valueOf(origin)) | ||||||
|                             ); |                             ); | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
| @@ -232,10 +223,7 @@ public class Condense extends SubCommand { | |||||||
|                 if (args.length == 2) { |                 if (args.length == 2) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver( |                             Template.of("value", "/plot condense " + area + " info <radius>") | ||||||
|                                     "value", |  | ||||||
|                                     Tag.inserting(Component.text("/plot condense " + area + " info <radius>")) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -256,20 +244,20 @@ public class Condense extends SubCommand { | |||||||
|                 player.sendMessage(TranslatableCaption.of("condense.default_eval")); |                 player.sendMessage(TranslatableCaption.of("condense.default_eval")); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("condense.minimum_radius"), |                         TranslatableCaption.of("condense.minimum_radius"), | ||||||
|                         TagResolver.resolver("minimumRadius", Tag.inserting(Component.text(minimumRadius))) |                         Template.of("minimumRadius", String.valueOf(minimumRadius)) | ||||||
|                 ); |                 ); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("condense.maximum_moved"), |                         TranslatableCaption.of("condense.minimum_radius"), | ||||||
|                         TagResolver.resolver("maxMove", Tag.inserting(Component.text(maxMove))) |                         Template.of("maxMove", String.valueOf(maxMove)) | ||||||
|                 ); |                 ); | ||||||
|                 player.sendMessage(TranslatableCaption.of("condense.input_eval")); |                 player.sendMessage(TranslatableCaption.of("condense.input_eval")); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("condense.input_radius"), |                         TranslatableCaption.of("condense.input_radius"), | ||||||
|                         TagResolver.resolver("radius", Tag.inserting(Component.text(radius))) |                         Template.of("radius", String.valueOf(radius)) | ||||||
|                 ); |                 ); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("condense.estimated_moves"), |                         TranslatableCaption.of("condense.estimated_moves"), | ||||||
|                         TagResolver.resolver("userMove", Tag.inserting(Component.text(userMove))) |                         Template.of("userMove", String.valueOf(userMove)) | ||||||
|                 ); |                 ); | ||||||
|                 player.sendMessage(TranslatableCaption.of("condense.eta")); |                 player.sendMessage(TranslatableCaption.of("condense.eta")); | ||||||
|                 player.sendMessage(TranslatableCaption.of("condense.radius_measured")); |                 player.sendMessage(TranslatableCaption.of("condense.radius_measured")); | ||||||
| @@ -278,10 +266,7 @@ public class Condense extends SubCommand { | |||||||
|         } |         } | ||||||
|         player.sendMessage( |         player.sendMessage( | ||||||
|                 TranslatableCaption.of("commandconfig.command_syntax"), |                 TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                 TagResolver.resolver( |                 Template.of("value", "/plot condense " + area.getWorldName() + " <start | stop | info> [radius]") | ||||||
|                         "value", |  | ||||||
|                         Tag.inserting(Component.text("/plot condense " + area.getWorldName() + " <start | stop | info> [radius]")) |  | ||||||
|                 ) |  | ||||||
|         ); |         ); | ||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -29,9 +29,8 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.flag.PlotFlag; | import com.plotsquared.core.plot.flag.PlotFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.DoneFlag; | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import net.kyori.adventure.text.Component; | import com.plotsquared.core.util.Permissions; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| @CommandDeclaration(command = "continue", | @CommandDeclaration(command = "continue", | ||||||
| @@ -54,12 +53,11 @@ public class Continue extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_CONTINUE)) { |         if (!plot.isOwner(player.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_CONTINUE)) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver("node", Tag.inserting( |                     Template.of("node", TranslatableCaption.of("permission.no_plot_perms").getComponent(player)) | ||||||
|                             TranslatableCaption.of("permission.no_plot_perms").toComponent(player) |  | ||||||
|                     )) |  | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -72,7 +70,7 @@ public class Continue extends SubCommand { | |||||||
|                 < player.getPlotCount() + size)) { |                 < player.getPlotCount() + size)) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.cant_claim_more_plots"), |                     TranslatableCaption.of("permission.cant_claim_more_plots"), | ||||||
|                     TagResolver.resolver("amount", Tag.inserting(Component.text(player.getAllowedPlots()))) |                     Template.of("amount", String.valueOf(player.getAllowedPlots())) | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -86,7 +84,7 @@ public class Continue extends SubCommand { | |||||||
|         if (event.getEventResult() == Result.DENY) { |         if (event.getEventResult() == Result.DENY) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("events.event_denied"), |                     TranslatableCaption.of("events.event_denied"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("Done flag removal"))) |                     Template.of("value", "Done flag removal") | ||||||
|             ); |             ); | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -23,9 +23,8 @@ import com.plotsquared.core.location.Location; | |||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import net.kyori.adventure.text.Component; | import com.plotsquared.core.util.Permissions; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
|  |  | ||||||
| @CommandDeclaration(command = "copy", | @CommandDeclaration(command = "copy", | ||||||
|         permission = "plots.copy", |         permission = "plots.copy", | ||||||
| @@ -43,14 +42,15 @@ public class Copy extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!plot1.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN.toString())) { |         if (!plot1.isOwner(player.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN.toString())) { | ||||||
|             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (args.length != 1) { |         if (args.length != 1) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("/plot copy <X;Z>"))) |                     Template.of("value", "/plot copy <X;Z>") | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -69,11 +69,8 @@ public class Copy extends SubCommand { | |||||||
|  |  | ||||||
|         plot1.getPlotModificationManager().copy(plot2, player).thenAccept(result -> { |         plot1.getPlotModificationManager().copy(plot2, player).thenAccept(result -> { | ||||||
|             if (result) { |             if (result) { | ||||||
|                 player.sendMessage(TranslatableCaption.of("move.copy_success"), |                 player.sendMessage(TranslatableCaption.of("move.copy_success"), Template.of("origin", String.valueOf(plot1)), | ||||||
|                         TagResolver.builder() |                         Template.of("target", String.valueOf(plot2)) | ||||||
|                                 .tag("origin", Tag.inserting(Component.text(plot1.toString()))) |  | ||||||
|                                 .tag("target", Tag.inserting(Component.text(plot2.toString()))) |  | ||||||
|                                 .build() |  | ||||||
|                 ); |                 ); | ||||||
|             } else { |             } else { | ||||||
|                 player.sendMessage(TranslatableCaption.of("move.requires_unowned")); |                 player.sendMessage(TranslatableCaption.of("move.requires_unowned")); | ||||||
|   | |||||||
| @@ -25,9 +25,7 @@ import com.plotsquared.core.generator.HybridUtils; | |||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| @CommandDeclaration(command = "createroadschematic", | @CommandDeclaration(command = "createroadschematic", | ||||||
| @@ -63,7 +61,7 @@ public class CreateRoadSchematic extends SubCommand { | |||||||
|         this.hybridUtils.setupRoadSchematic(plot); |         this.hybridUtils.setupRoadSchematic(plot); | ||||||
|         player.sendMessage( |         player.sendMessage( | ||||||
|                 TranslatableCaption.of("schematics.schematic_road_created"), |                 TranslatableCaption.of("schematics.schematic_road_created"), | ||||||
|                 TagResolver.resolver("command", Tag.inserting(Component.text("/plot debugroadregen"))) |                 Template.of("command", "/plot debugroadregen") | ||||||
|         ); |         ); | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -40,9 +40,7 @@ import com.plotsquared.core.util.EventDispatcher; | |||||||
| import com.plotsquared.core.util.FileUtils; | import com.plotsquared.core.util.FileUtils; | ||||||
| import com.plotsquared.core.util.query.PlotQuery; | import com.plotsquared.core.util.query.PlotQuery; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.io.File; | import java.io.File; | ||||||
| @@ -103,10 +101,7 @@ public class DatabaseCommand extends SubCommand { | |||||||
|         if (args.length < 1) { |         if (args.length < 1) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver( |                     Template.of("value", "/plot database [area] <sqlite | mysql | import>") | ||||||
|                             "value", |  | ||||||
|                             Tag.inserting(Component.text("/plot database [area] <sqlite | mysql | import>")) |  | ||||||
|                     ) |  | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -121,7 +116,7 @@ public class DatabaseCommand extends SubCommand { | |||||||
|         if (args.length < 1) { |         if (args.length < 1) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("/plot database [area] <sqlite|mysql|import>"))) |                     Template.of("value", "/plot database [area] <sqlite|mysql|import>") | ||||||
|             ); |             ); | ||||||
|             player.sendMessage(TranslatableCaption.of("database.arg")); |             player.sendMessage(TranslatableCaption.of("database.arg")); | ||||||
|             return false; |             return false; | ||||||
| @@ -134,10 +129,7 @@ public class DatabaseCommand extends SubCommand { | |||||||
|                     if (args.length < 2) { |                     if (args.length < 2) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("commandconfig.command_syntax"), |                                 TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("value", "/plot database import <sqlite file> [prefix]") | ||||||
|                                         "value", |  | ||||||
|                                         Tag.inserting(Component.text("/plot database import <sqlite file> [prefix]")) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -148,7 +140,7 @@ public class DatabaseCommand extends SubCommand { | |||||||
|                     if (!file.exists()) { |                     if (!file.exists()) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("database.does_not_exist"), |                                 TranslatableCaption.of("database.does_not_exist"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(file.toString()))) |                                 Template.of("value", String.valueOf(file)) | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -192,10 +184,8 @@ public class DatabaseCommand extends SubCommand { | |||||||
|                                     } |                                     } | ||||||
|                                     player.sendMessage( |                                     player.sendMessage( | ||||||
|                                             TranslatableCaption.of("database.skipping_duplicated_plot"), |                                             TranslatableCaption.of("database.skipping_duplicated_plot"), | ||||||
|                                             TagResolver.builder() |                                             Template.of("plot", String.valueOf(plot)), | ||||||
|                                                     .tag("plot", Tag.inserting(Component.text(plot.toString()))) |                                             Template.of("id", String.valueOf(plot.temp)) | ||||||
|                                                     .tag("id", Tag.inserting(Component.text(plot.temp))) |  | ||||||
|                                                     .build() |  | ||||||
|                                     ); |                                     ); | ||||||
|                                     continue; |                                     continue; | ||||||
|                                 } |                                 } | ||||||
|   | |||||||
| @@ -34,8 +34,7 @@ import com.plotsquared.core.uuid.UUIDMapping; | |||||||
| import com.sk89q.worldedit.world.entity.EntityType; | import com.sk89q.worldedit.world.entity.EntityType; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.TextComponent; | import net.kyori.adventure.text.TextComponent; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| @@ -69,10 +68,7 @@ public class Debug extends SubCommand { | |||||||
|         if (args.length == 0) { |         if (args.length == 0) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver( |                     Template.of("value", "/plot debug <loadedchunks | player | debug-players | entitytypes | msg>") | ||||||
|                             "value", |  | ||||||
|                             Tag.inserting(Component.text("/plot debug <loadedchunks | player | debug-players | entitytypes | msg>")) |  | ||||||
|                     ) |  | ||||||
|             ); |             ); | ||||||
|         } |         } | ||||||
|         if (args.length > 0) { |         if (args.length > 0) { | ||||||
| @@ -99,7 +95,7 @@ public class Debug extends SubCommand { | |||||||
|             final Collection<UUIDMapping> mappings = PlotSquared.get().getImpromptuUUIDPipeline().getAllImmediately(); |             final Collection<UUIDMapping> mappings = PlotSquared.get().getImpromptuUUIDPipeline().getAllImmediately(); | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("debug.cached_uuids"), |                     TranslatableCaption.of("debug.cached_uuids"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text(mappings.size()))) |                     Template.of("value", String.valueOf(mappings.size())) | ||||||
|             ); |             ); | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
| @@ -108,7 +104,7 @@ public class Debug extends SubCommand { | |||||||
|             for (final PlotPlayer<?> pp : PlotPlayer.getDebugModePlayers()) { |             for (final PlotPlayer<?> pp : PlotPlayer.getDebugModePlayers()) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("debug.player_in_debugmode_list"), |                         TranslatableCaption.of("debug.player_in_debugmode_list"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text(pp.getName()))) |                         Template.of("value", pp.getName()) | ||||||
|                 ); |                 ); | ||||||
|             } |             } | ||||||
|             return true; |             return true; | ||||||
| @@ -118,11 +114,10 @@ public class Debug extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("debug.entity_categories")); |             player.sendMessage(TranslatableCaption.of("debug.entity_categories")); | ||||||
|             EntityCategory.REGISTRY.forEach(category -> { |             EntityCategory.REGISTRY.forEach(category -> { | ||||||
|                 final StringBuilder builder = |                 final StringBuilder builder = | ||||||
|                         new StringBuilder("<gray>-</gray> <gold>").append(category.getId()).append("</gold><gray>: <gold>"); |                         new StringBuilder("§7- §6").append(category.getId()).append("§7: §6"); | ||||||
|                 for (final EntityType entityType : category.getAll()) { |                 for (final EntityType entityType : category.getAll()) { | ||||||
|                     builder.append(entityType.getId()).append(" "); |                     builder.append(entityType.getId()).append(" "); | ||||||
|                 } |                 } | ||||||
|                 builder.append("</gold>"); |  | ||||||
|                 player.sendMessage(StaticCaption.of("<prefix>" + builder)); |                 player.sendMessage(StaticCaption.of("<prefix>" + builder)); | ||||||
|             }); |             }); | ||||||
|             EntityType.REGISTRY.values().stream().sorted(Comparator.comparing(EntityType::getId)) |             EntityType.REGISTRY.values().stream().sorted(Comparator.comparing(EntityType::getId)) | ||||||
| @@ -142,53 +137,28 @@ public class Debug extends SubCommand { | |||||||
|                 .getCaptionMap(TranslatableCaption.DEFAULT_NAMESPACE) |                 .getCaptionMap(TranslatableCaption.DEFAULT_NAMESPACE) | ||||||
|                 .getCaptions(); |                 .getCaptions(); | ||||||
|         TextComponent.Builder information = Component.text(); |         TextComponent.Builder information = Component.text(); | ||||||
|         Component header = TranslatableCaption.of("debug.debug_header").toComponent(player) |         Component header = MINI_MESSAGE.parse(TranslatableCaption.of("debug.debug_header").getComponent(player) + "\n"); | ||||||
|                 .append(Component.newline()); |  | ||||||
|         String line = TranslatableCaption.of("debug.debug_line").getComponent(player) + "\n"; |         String line = TranslatableCaption.of("debug.debug_line").getComponent(player) + "\n"; | ||||||
|         String section = TranslatableCaption.of("debug.debug_section").getComponent(player) + "\n"; |         String section = TranslatableCaption.of("debug.debug_section").getComponent(player) + "\n"; | ||||||
|         information.append(header); |         information.append(header); | ||||||
|         information.append(MINI_MESSAGE.deserialize( |         information.append(MINI_MESSAGE.parse(section, Template.of("val", "PlotArea"))); | ||||||
|                 section, |  | ||||||
|                 TagResolver.resolver("val", Tag.inserting(Component.text("PlotArea"))) |  | ||||||
|         )); |  | ||||||
|         information.append(MINI_MESSAGE |         information.append(MINI_MESSAGE | ||||||
|                 .deserialize( |                 .parse( | ||||||
|                         line, |                         line, | ||||||
|                         TagResolver.builder() |                         Template.of("var", "Plot Worlds"), | ||||||
|                                 .tag("var", Tag.inserting(Component.text("Plot Worlds"))) |                         Template.of("val", StringMan.join(this.plotAreaManager.getAllPlotAreas(), ", ")) | ||||||
|                                 .tag( |  | ||||||
|                                         "val", |  | ||||||
|                                         Tag.inserting(Component.text(StringMan.join( |  | ||||||
|                                                 this.plotAreaManager.getAllPlotAreas(), |  | ||||||
|                                                 ", " |  | ||||||
|                                         ))) |  | ||||||
|                                 ) |  | ||||||
|                                 .build() |  | ||||||
|                 )); |                 )); | ||||||
|         information.append( |         information.append( | ||||||
|                 MINI_MESSAGE.deserialize( |                 MINI_MESSAGE.parse( | ||||||
|                         line, |                         line, | ||||||
|                         TagResolver.builder() |                         Template.of("var", "Owned Plots"), | ||||||
|                                 .tag("var", Tag.inserting(Component.text("Owned Plots"))) |                         Template.of("val", String.valueOf(PlotQuery.newQuery().allPlots().count())) | ||||||
|                                 .tag( |  | ||||||
|                                         "val", |  | ||||||
|                                         Tag.inserting(Component.text(PlotQuery.newQuery().allPlots().count())) |  | ||||||
|                                 ) |  | ||||||
|                                 .build() |  | ||||||
|                 )); |                 )); | ||||||
|         information.append(MINI_MESSAGE.deserialize( |         information.append(MINI_MESSAGE.parse(section, Template.of("val", "Messages"))); | ||||||
|                 section, |         information.append(MINI_MESSAGE.parse( | ||||||
|                 TagResolver.resolver("val", Tag.inserting(Component.text("Messages"))) |  | ||||||
|         )); |  | ||||||
|         information.append(MINI_MESSAGE.deserialize( |  | ||||||
|                 line, |                 line, | ||||||
|                 TagResolver.builder() |                 Template.of("var", "Total Messages"), | ||||||
|                         .tag("var", Tag.inserting(Component.text("Total Messages"))) |                 Template.of("val", String.valueOf(captions.size())) | ||||||
|                         .tag( |  | ||||||
|                                 "val", |  | ||||||
|                                 Tag.inserting(Component.text(captions.size())) |  | ||||||
|                         ) |  | ||||||
|                         .build() |  | ||||||
|         )); |         )); | ||||||
|         player.sendMessage(StaticCaption.of(MINI_MESSAGE.serialize(information.build()))); |         player.sendMessage(StaticCaption.of(MINI_MESSAGE.serialize(information.build()))); | ||||||
|         return true; |         return true; | ||||||
|   | |||||||
| @@ -28,6 +28,7 @@ import com.plotsquared.core.generator.HybridUtils; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
|  | import com.plotsquared.core.plot.expiration.ExpireManager; | ||||||
| import com.plotsquared.core.plot.expiration.PlotAnalysis; | import com.plotsquared.core.plot.expiration.PlotAnalysis; | ||||||
| import com.plotsquared.core.plot.flag.GlobalFlagContainer; | import com.plotsquared.core.plot.flag.GlobalFlagContainer; | ||||||
| import com.plotsquared.core.plot.flag.PlotFlag; | import com.plotsquared.core.plot.flag.PlotFlag; | ||||||
| @@ -36,13 +37,12 @@ import com.plotsquared.core.util.EventDispatcher; | |||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| import com.plotsquared.core.util.query.PlotQuery; | import com.plotsquared.core.util.query.PlotQuery; | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
|  | import java.util.HashSet; | ||||||
| import java.util.LinkedHashSet; | import java.util.LinkedHashSet; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Locale; | import java.util.Locale; | ||||||
| @@ -97,7 +97,7 @@ public class DebugExec extends SubCommand { | |||||||
|                     if (analysis != null) { |                     if (analysis != null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("debugexec.changes_column"), |                                 TranslatableCaption.of("debugexec.changes_column"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(analysis.changes))) |                                 Template.of("value", String.valueOf(analysis.changes)) | ||||||
|                         ); |                         ); | ||||||
|                         return true; |                         return true; | ||||||
|                     } |                     } | ||||||
| @@ -107,7 +107,7 @@ public class DebugExec extends SubCommand { | |||||||
|                         public void run(PlotAnalysis value) { |                         public void run(PlotAnalysis value) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("debugexec.analyze_done"), |                                     TranslatableCaption.of("debugexec.analyze_done"), | ||||||
|                                     TagResolver.resolver("command", Tag.inserting(Component.text("/plot debugexec analyze"))) |                                     Template.of("command", "/plot debugexec analyze") | ||||||
|                             ); |                             ); | ||||||
|                         } |                         } | ||||||
|                     }); |                     }); | ||||||
| @@ -117,10 +117,7 @@ public class DebugExec extends SubCommand { | |||||||
|                     if (args.length != 2) { |                     if (args.length != 2) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("commandconfig.command_syntax"), |                                 TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("value", "/plot debugexec analyze <threshold>") | ||||||
|                                         "value", |  | ||||||
|                                         Tag.inserting(Component.text("/plot debugexec analyze <threshold>")) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         player.sendMessage(TranslatableCaption.of("debugexec.threshold_default")); |                         player.sendMessage(TranslatableCaption.of("debugexec.threshold_default")); | ||||||
|                         return false; |                         return false; | ||||||
| @@ -131,7 +128,7 @@ public class DebugExec extends SubCommand { | |||||||
|                     } catch (NumberFormatException ignored) { |                     } catch (NumberFormatException ignored) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("debugexec.invalid_threshold"), |                                 TranslatableCaption.of("debugexec.invalid_threshold"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(args[1]))) |                                 Template.of("value", args[1]) | ||||||
|                         ); |                         ); | ||||||
|                         player.sendMessage(TranslatableCaption.of("debugexec.threshold_default_double")); |                         player.sendMessage(TranslatableCaption.of("debugexec.threshold_default_double")); | ||||||
|                         return false; |                         return false; | ||||||
| @@ -162,7 +159,7 @@ public class DebugExec extends SubCommand { | |||||||
|                     if (args.length != 2) { |                     if (args.length != 2) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("commandconfig.command_syntax"), |                                 TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text("/plot debugexec remove-flag <flag>"))) |                                 Template.of("value", "/plot debugexec remove-flag <flag>") | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -180,7 +177,7 @@ public class DebugExec extends SubCommand { | |||||||
|                     } |                     } | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("debugexec.cleared_flag"), |                             TranslatableCaption.of("debugexec.cleared_flag"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text(flag))) |                             Template.of("value", flag) | ||||||
|                     ); |                     ); | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
| @@ -188,10 +185,7 @@ public class DebugExec extends SubCommand { | |||||||
|                     if (args.length != 2) { |                     if (args.length != 2) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("commandconfig.command_syntax"), |                                 TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("value", "Invalid syntax: /plot debugexec start-rgar <world>") | ||||||
|                                         "value", |  | ||||||
|                                         Tag.inserting(Component.text("Invalid syntax: /plot debugexec start-rgar <world>")) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -199,7 +193,7 @@ public class DebugExec extends SubCommand { | |||||||
|                     if (area == null) { |                     if (area == null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("errors.not_valid_plot_world"), |                                 TranslatableCaption.of("errors.not_valid_plot_world"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(args[1]))) |                                 Template.of("value", args[1]) | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|   | |||||||
| @@ -31,9 +31,7 @@ import com.plotsquared.core.inject.annotations.WorldFile; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.util.PremiumVerification; | import com.plotsquared.core.util.PremiumVerification; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.io.File; | import java.io.File; | ||||||
| @@ -133,10 +131,8 @@ public class DebugPaste extends SubCommand { | |||||||
|                 } catch (IOException ignored) { |                 } catch (IOException ignored) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("debugpaste.latest_log"), |                             TranslatableCaption.of("debugpaste.latest_log"), | ||||||
|                             TagResolver.builder() |                             Template.of("file", "latest.log"), | ||||||
|                                     .tag("file", Tag.inserting(Component.text("latest.log"))) |                             Template.of("size", "14MB") | ||||||
|                                     .tag("size", Tag.inserting(Component.text("14MB"))) |  | ||||||
|                                     .build() |  | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
| @@ -145,7 +141,7 @@ public class DebugPaste extends SubCommand { | |||||||
|                 } catch (final IllegalArgumentException ignored) { |                 } catch (final IllegalArgumentException ignored) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("debugpaste.empty_file"), |                             TranslatableCaption.of("debugpaste.empty_file"), | ||||||
|                             TagResolver.resolver("file", Tag.inserting(Component.text("settings.yml"))) |                             Template.of("file", "settings.yml") | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|                 try { |                 try { | ||||||
| @@ -153,7 +149,7 @@ public class DebugPaste extends SubCommand { | |||||||
|                 } catch (final IllegalArgumentException ignored) { |                 } catch (final IllegalArgumentException ignored) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("debugpaste.empty_file"), |                             TranslatableCaption.of("debugpaste.empty_file"), | ||||||
|                             TagResolver.resolver("file", Tag.inserting(Component.text("worlds.yml"))) |                             Template.of("file", "worlds.yml") | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
| @@ -166,7 +162,7 @@ public class DebugPaste extends SubCommand { | |||||||
|                 } catch (final IOException ignored) { |                 } catch (final IOException ignored) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("debugpaste.skip_multiverse"), |                             TranslatableCaption.of("debugpaste.skip_multiverse"), | ||||||
|                             TagResolver.resolver("file", Tag.inserting(Component.text("worlds.yml"))) |                             Template.of("file", "worlds.yml") | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
| @@ -181,20 +177,20 @@ public class DebugPaste extends SubCommand { | |||||||
|                                 String.format("https://athion.net/ISPaster/paste/view/%s", pasteId); |                                 String.format("https://athion.net/ISPaster/paste/view/%s", pasteId); | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("debugpaste.debug_report_created"), |                                 TranslatableCaption.of("debugpaste.debug_report_created"), | ||||||
|                                 TagResolver.resolver("url", Tag.preProcessParsed(link)) |                                 Template.of("url", link) | ||||||
|                         ); |                         ); | ||||||
|                     } else { |                     } else { | ||||||
|                         final String responseMessage = jsonObject.get("response").getAsString(); |                         final String responseMessage = jsonObject.get("response").getAsString(); | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("debugpaste.creation_failed"), |                                 TranslatableCaption.of("debugpaste.creation_failed"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(responseMessage))) |                                 Template.of("value", responseMessage) | ||||||
|                         ); |                         ); | ||||||
|                     } |                     } | ||||||
|                 } catch (final Throwable throwable) { |                 } catch (final Throwable throwable) { | ||||||
|                     throwable.printStackTrace(); |                     throwable.printStackTrace(); | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("debugpaste.creation_failed"), |                             TranslatableCaption.of("debugpaste.creation_failed"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text(throwable.getMessage()))) |                             Template.of("value", throwable.getMessage()) | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|             } catch (IOException e) { |             } catch (IOException e) { | ||||||
|   | |||||||
| @@ -28,9 +28,7 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.PlotManager; | import com.plotsquared.core.plot.PlotManager; | ||||||
| import com.plotsquared.core.queue.QueueCoordinator; | import com.plotsquared.core.queue.QueueCoordinator; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
| @@ -62,7 +60,7 @@ public class DebugRoadRegen extends SubCommand { | |||||||
|         if (args.length < 1) { |         if (args.length < 1) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text(DebugRoadRegen.USAGE))) |                     Template.of("value", DebugRoadRegen.USAGE) | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -82,7 +80,7 @@ public class DebugRoadRegen extends SubCommand { | |||||||
|             default: |             default: | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("commandconfig.command_syntax"), |                         TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text(DebugRoadRegen.USAGE))) |                         Template.of("value", DebugRoadRegen.USAGE) | ||||||
|                 ); |                 ); | ||||||
|                 return false; |                 return false; | ||||||
|         } |         } | ||||||
| @@ -105,11 +103,11 @@ public class DebugRoadRegen extends SubCommand { | |||||||
|             queue.setCompleteTask(() -> { |             queue.setCompleteTask(() -> { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("debugroadregen.regen_done"), |                         TranslatableCaption.of("debugroadregen.regen_done"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text(plot.getId().toString()))) |                         Template.of("value", plot.getId().toString()) | ||||||
|                 ); |                 ); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("debugroadregen.regen_all"), |                         TranslatableCaption.of("debugroadregen.regen_all"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text("/plot regenallroads"))) |                         Template.of("value", "/plot regenallroads") | ||||||
|                 ); |                 ); | ||||||
|             }); |             }); | ||||||
|             manager.createRoadEast(plot, queue); |             manager.createRoadEast(plot, queue); | ||||||
| @@ -128,18 +126,18 @@ public class DebugRoadRegen extends SubCommand { | |||||||
|             } catch (NumberFormatException ignored) { |             } catch (NumberFormatException ignored) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("invalid.not_valid_number"), |                         TranslatableCaption.of("invalid.not_valid_number"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text("0, 256"))) |                         Template.of("value", "0, 256") | ||||||
|                 ); |                 ); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("commandconfig.command_syntax"), |                         TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text(DebugRoadRegen.USAGE))) |                         Template.of("value", DebugRoadRegen.USAGE) | ||||||
|                 ); |                 ); | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|         } else if (args.length != 0) { |         } else if (args.length != 0) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text(DebugRoadRegen.USAGE))) |                     Template.of("value", DebugRoadRegen.USAGE) | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -157,11 +155,11 @@ public class DebugRoadRegen extends SubCommand { | |||||||
|         } |         } | ||||||
|         player.sendMessage( |         player.sendMessage( | ||||||
|                 TranslatableCaption.of("debugroadregen.schematic"), |                 TranslatableCaption.of("debugroadregen.schematic"), | ||||||
|                 TagResolver.resolver("command", Tag.inserting(Component.text("/plot createroadschematic"))) |                 Template.of("command", "/plot createroadschematic") | ||||||
|         ); |         ); | ||||||
|         player.sendMessage( |         player.sendMessage( | ||||||
|                 TranslatableCaption.of("debugroadregen.regenallroads"), |                 TranslatableCaption.of("debugroadregen.regenallroads"), | ||||||
|                 TagResolver.resolver("command", Tag.inserting(Component.text("/plot regenallroads"))) |                 Template.of("command", "/plot regenallroads") | ||||||
|         ); |         ); | ||||||
|         boolean result = this.hybridUtils.scheduleSingleRegionRoadUpdate(plot, height); |         boolean result = this.hybridUtils.scheduleSingleRegionRoadUpdate(plot, height); | ||||||
|         if (!result) { |         if (!result) { | ||||||
|   | |||||||
| @@ -30,11 +30,10 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.util.EconHandler; | import com.plotsquared.core.util.EconHandler; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.PlotExpression; | import com.plotsquared.core.util.PlotExpression; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -79,12 +78,13 @@ public class Delete extends SubCommand { | |||||||
|         if (eventResult == Result.DENY) { |         if (eventResult == Result.DENY) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("events.event_denied"), |                     TranslatableCaption.of("events.event_denied"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("Delete"))) |                     Template.of("value", "Delete") | ||||||
|             ); |             ); | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
|         boolean force = eventResult == Result.FORCE; |         boolean force = eventResult == Result.FORCE; | ||||||
|         if (!force && !plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_DELETE)) { |         if (!force && !plot.isOwner(player.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_DELETE)) { | ||||||
|             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -114,17 +114,14 @@ public class Delete extends SubCommand { | |||||||
|                         this.econHandler.depositMoney(player, value); |                         this.econHandler.depositMoney(player, value); | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("economy.added_balance"), |                                 TranslatableCaption.of("economy.added_balance"), | ||||||
|                                 TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(value)))) |                                 Template.of("money", this.econHandler.format(value)) | ||||||
|                         ); |                         ); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("working.deleting_done"), |                         TranslatableCaption.of("working.deleting_done"), | ||||||
|                         TagResolver.resolver( |                         Template.of("amount", String.valueOf(System.currentTimeMillis() - start)), | ||||||
|                                 "amount", |                         Template.of("plot", plot.getId().toString()) | ||||||
|                                 Tag.inserting(Component.text(String.valueOf(System.currentTimeMillis() - start))) |  | ||||||
|                         ), |  | ||||||
|                         TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) |  | ||||||
|                 ); |                 ); | ||||||
|                 eventDispatcher.callPostDelete(plot); |                 eventDispatcher.callPostDelete(plot); | ||||||
|             }); |             }); | ||||||
|   | |||||||
| @@ -30,13 +30,12 @@ import com.plotsquared.core.player.PlotPlayer; | |||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.PlayerManager; | import com.plotsquared.core.util.PlayerManager; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.WorldUtil; | import com.plotsquared.core.util.WorldUtil; | ||||||
| import com.sk89q.worldedit.world.gamemode.GameModes; | import com.sk89q.worldedit.world.gamemode.GameModes; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| @@ -80,17 +79,18 @@ public class Deny extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("info.plot_unowned")); |             player.sendMessage(TranslatableCaption.of("info.plot_unowned")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_DENY)) { |         if (!plot.isOwner(player.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_DENY)) { | ||||||
|             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         int maxDenySize = player.hasPermissionRange(Permission.PERMISSION_DENY, Settings.Limit.MAX_PLOTS); |         int maxDenySize = Permissions.hasPermissionRange(player, Permission.PERMISSION_DENY, Settings.Limit.MAX_PLOTS); | ||||||
|         int size = plot.getDenied().size(); |         int size = plot.getDenied().size(); | ||||||
|         if (size >= maxDenySize) { |         if (size >= maxDenySize) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("members.plot_max_members_denied"), |                     TranslatableCaption.of("members.plot_max_members_denied"), | ||||||
|                     TagResolver.resolver("amount", Tag.inserting(Component.text(size))) |                     Template.of("amount", String.valueOf(size)) | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -101,15 +101,16 @@ public class Deny extends SubCommand { | |||||||
|             } else if (throwable != null || uuids.isEmpty()) { |             } else if (throwable != null || uuids.isEmpty()) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("errors.invalid_player"), |                         TranslatableCaption.of("errors.invalid_player"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) |                         Template.of("value", args[0]) | ||||||
|                 ); |                 ); | ||||||
|             } else { |             } else { | ||||||
|                 for (UUID uuid : uuids) { |                 for (UUID uuid : uuids) { | ||||||
|                     if (uuid == DBFunc.EVERYONE && !( |                     if (uuid == DBFunc.EVERYONE && !( | ||||||
|                             player.hasPermission(Permission.PERMISSION_DENY_EVERYONE) || player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_DENY))) { |                             Permissions.hasPermission(player, Permission.PERMISSION_DENY_EVERYONE) || Permissions | ||||||
|  |                                     .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_DENY))) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("errors.invalid_player"), |                                 TranslatableCaption.of("errors.invalid_player"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) |                                 Template.of("value", args[0]) | ||||||
|                         ); |                         ); | ||||||
|                     } else if (plot.isOwner(uuid)) { |                     } else if (plot.isOwner(uuid)) { | ||||||
|                         player.sendMessage(TranslatableCaption.of("deny.cant_remove_owner")); |                         player.sendMessage(TranslatableCaption.of("deny.cant_remove_owner")); | ||||||
| @@ -117,10 +118,7 @@ public class Deny extends SubCommand { | |||||||
|                     } else if (plot.getDenied().contains(uuid)) { |                     } else if (plot.getDenied().contains(uuid)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("member.already_added"), |                                 TranslatableCaption.of("member.already_added"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("player", PlayerManager.resolveName(uuid).getComponent(player)) | ||||||
|                                         "player", |  | ||||||
|                                         Tag.inserting(PlayerManager.resolveName(uuid).toComponent(player)) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         return; |                         return; | ||||||
|                     } else { |                     } else { | ||||||
|   | |||||||
| @@ -27,9 +27,7 @@ import com.plotsquared.core.player.PlotPlayer; | |||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.flag.implementations.DescriptionFlag; | import com.plotsquared.core.plot.flag.implementations.DescriptionFlag; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| @CommandDeclaration(command = "setdescription", | @CommandDeclaration(command = "setdescription", | ||||||
| @@ -56,7 +54,7 @@ public class Desc extends SetCommand { | |||||||
|             if (event.getEventResult() == Result.DENY) { |             if (event.getEventResult() == Result.DENY) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("events.event_denied"), |                         TranslatableCaption.of("events.event_denied"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text("Description removal"))) |                         Template.of("value", "Description removal") | ||||||
|                 ); |                 ); | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
| @@ -71,7 +69,7 @@ public class Desc extends SetCommand { | |||||||
|         if (event.getEventResult() == Result.DENY) { |         if (event.getEventResult() == Result.DENY) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("events.event_denied"), |                     TranslatableCaption.of("events.event_denied"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("Description set"))) |                     Template.of("value", "Description set") | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -21,6 +21,7 @@ package com.plotsquared.core.command; | |||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| @@ -53,7 +54,7 @@ public class Dislike extends SubCommand { | |||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         if (args.length == 1) { |         if (args.length == 1) { | ||||||
|             final List<String> completions = new LinkedList<>(); |             final List<String> completions = new LinkedList<>(); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_PURGE_RATINGS)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_PURGE_RATINGS)) { | ||||||
|                 completions.add("purge"); |                 completions.add("purge"); | ||||||
|             } |             } | ||||||
|             final List<Command> commands = completions.stream().filter(completion -> completion |             final List<Command> commands = completions.stream().filter(completion -> completion | ||||||
| @@ -61,7 +62,7 @@ public class Dislike extends SubCommand { | |||||||
|                             .startsWith(args[0].toLowerCase())) |                             .startsWith(args[0].toLowerCase())) | ||||||
|                     .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.INFO) { |                     .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.INFO) { | ||||||
|                     }).collect(Collectors.toCollection(LinkedList::new)); |                     }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_RATE) && args[0].length() > 0) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_RATE) && args[0].length() > 0) { | ||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             return commands; | ||||||
|   | |||||||
| @@ -34,10 +34,9 @@ import com.plotsquared.core.plot.expiration.PlotAnalysis; | |||||||
| import com.plotsquared.core.plot.flag.PlotFlag; | import com.plotsquared.core.plot.flag.PlotFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.DoneFlag; | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| @CommandDeclaration(command = "done", | @CommandDeclaration(command = "done", | ||||||
| @@ -71,12 +70,13 @@ public class Done extends SubCommand { | |||||||
|         if (event.getEventResult() == Result.DENY) { |         if (event.getEventResult() == Result.DENY) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("events.event_denied"), |                     TranslatableCaption.of("events.event_denied"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("Done"))) |                     Template.of("value", "Done") | ||||||
|             ); |             ); | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
|         boolean force = event.getEventResult() == Result.FORCE; |         boolean force = event.getEventResult() == Result.FORCE; | ||||||
|         if (!force && !plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_DONE)) { |         if (!force && !plot.isOwner(player.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_DONE)) { | ||||||
|             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -91,7 +91,7 @@ public class Done extends SubCommand { | |||||||
|         plot.addRunning(); |         plot.addRunning(); | ||||||
|         player.sendMessage( |         player.sendMessage( | ||||||
|                 TranslatableCaption.of("web.generating_link"), |                 TranslatableCaption.of("web.generating_link"), | ||||||
|                 TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                 Template.of("plot", plot.getId().toString()) | ||||||
|         ); |         ); | ||||||
|         final Settings.Auto_Clear doneRequirements = Settings.AUTO_CLEAR.get("done"); |         final Settings.Auto_Clear doneRequirements = Settings.AUTO_CLEAR.get("done"); | ||||||
|         if (PlotSquared.platform().expireManager() == null || doneRequirements == null) { |         if (PlotSquared.platform().expireManager() == null || doneRequirements == null) { | ||||||
|   | |||||||
| @@ -27,15 +27,14 @@ import com.plotsquared.core.player.PlotPlayer; | |||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.flag.implementations.DoneFlag; | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.PlotUploader; | import com.plotsquared.core.util.PlotUploader; | ||||||
| import com.plotsquared.core.util.SchematicHandler; | import com.plotsquared.core.util.SchematicHandler; | ||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.WorldUtil; | import com.plotsquared.core.util.WorldUtil; | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.net.URL; | import java.net.URL; | ||||||
| @@ -88,11 +87,13 @@ public class Download extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("info.plot_unowned")); |             player.sendMessage(TranslatableCaption.of("info.plot_unowned")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if ((Settings.Done.REQUIRED_FOR_DOWNLOAD && !DoneFlag.isDone(plot)) && !player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_DOWNLOAD)) { |         if ((Settings.Done.REQUIRED_FOR_DOWNLOAD && !DoneFlag.isDone(plot)) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_DOWNLOAD)) { | ||||||
|             player.sendMessage(TranslatableCaption.of("done.done_not_done")); |             player.sendMessage(TranslatableCaption.of("done.done_not_done")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN.toString())) { |         if (!plot.isOwner(player.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN.toString())) { | ||||||
|             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -110,13 +111,10 @@ public class Download extends SubCommand { | |||||||
|             upload(player, plot); |             upload(player, plot); | ||||||
|         } else if (args.length == 1 && StringMan |         } else if (args.length == 1 && StringMan | ||||||
|                 .isEqualIgnoreCaseToAny(args[0], "mcr", "world", "mca")) { |                 .isEqualIgnoreCaseToAny(args[0], "mcr", "world", "mca")) { | ||||||
|             if (!player.hasPermission(Permission.PERMISSION_DOWNLOAD_WORLD)) { |             if (!Permissions.hasPermission(player, Permission.PERMISSION_DOWNLOAD_WORLD)) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission"), |                         TranslatableCaption.of("permission.no_permission"), | ||||||
|                         TagResolver.resolver( |                         Template.of("node", Permission.PERMISSION_DOWNLOAD_WORLD.toString()) | ||||||
|                                 "node", |  | ||||||
|                                 Tag.inserting(Permission.PERMISSION_DOWNLOAD_WORLD) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
| @@ -130,24 +128,18 @@ public class Download extends SubCommand { | |||||||
|                     if (url == null) { |                     if (url == null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("web.generating_link_failed"), |                                 TranslatableCaption.of("web.generating_link_failed"), | ||||||
|                                 TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                                 Template.of("plot", plot.getId().toString()) | ||||||
|                         ); |                         ); | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                     player.sendMessage( |                     player.sendMessage(TranslatableCaption.of("web.generation_link_success_legacy_world"), Template.of("url", url.toString())); | ||||||
|                             TranslatableCaption.of("web.generation_link_success_legacy_world"), |  | ||||||
|                             TagResolver.resolver("url", Tag.inserting(Component.text(url.toString()))) |  | ||||||
|                     ); |  | ||||||
|                 } |                 } | ||||||
|             }); |             }); | ||||||
|         } else { |         } else { | ||||||
|             sendUsage(player); |             sendUsage(player); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         player.sendMessage( |         player.sendMessage(TranslatableCaption.of("web.generating_link"), Template.of("plot", plot.getId().toString())); | ||||||
|                 TranslatableCaption.of("web.generating_link"), |  | ||||||
|                 TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) |  | ||||||
|         ); |  | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -155,10 +147,10 @@ public class Download extends SubCommand { | |||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         if (args.length == 1) { |         if (args.length == 1) { | ||||||
|             final List<String> completions = new LinkedList<>(); |             final List<String> completions = new LinkedList<>(); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_DOWNLOAD)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_DOWNLOAD)) { | ||||||
|                 completions.add("schem"); |                 completions.add("schem"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_DOWNLOAD_WORLD)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_DOWNLOAD_WORLD)) { | ||||||
|                 completions.add("world"); |                 completions.add("world"); | ||||||
|             } |             } | ||||||
|             final List<Command> commands = completions.stream().filter(completion -> completion |             final List<Command> commands = completions.stream().filter(completion -> completion | ||||||
| @@ -173,7 +165,7 @@ public class Download extends SubCommand { | |||||||
|                             CommandCategory.ADMINISTRATION |                             CommandCategory.ADMINISTRATION | ||||||
|                     ) { |                     ) { | ||||||
|                     }).collect(Collectors.toCollection(LinkedList::new)); |                     }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_DOWNLOAD) && args[0].length() > 0) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_DOWNLOAD) && args[0].length() > 0) { | ||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             return commands; | ||||||
| @@ -192,10 +184,8 @@ public class Download extends SubCommand { | |||||||
|                                 plot.removeRunning(); |                                 plot.removeRunning(); | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("web.generation_link_success"), |                                         TranslatableCaption.of("web.generation_link_success"), | ||||||
|                                         TagResolver.builder() |                                         Template.of("download", value.toString()), | ||||||
|                                                 .tag("download", Tag.preProcessParsed(value.toString())) |                                         Template.of("delete", "Not available") | ||||||
|                                                 .tag("delete", Tag.preProcessParsed("Not available")) |  | ||||||
|                                                 .build() |  | ||||||
|                                 ); |                                 ); | ||||||
|                                 player.sendMessage(StaticCaption.of(value.toString())); |                                 player.sendMessage(StaticCaption.of(value.toString())); | ||||||
|                             } |                             } | ||||||
| @@ -209,15 +199,13 @@ public class Download extends SubCommand { | |||||||
|                     if (throwable != null || !result.isSuccess()) { |                     if (throwable != null || !result.isSuccess()) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("web.generating_link_failed"), |                                 TranslatableCaption.of("web.generating_link_failed"), | ||||||
|                                 TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                                 Template.of("plot", plot.getId().toString()) | ||||||
|                         ); |                         ); | ||||||
|                     } else { |                     } else { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("web.generation_link_success"), |                                 TranslatableCaption.of("web.generation_link_success"), | ||||||
|                                 TagResolver.builder() |                                 Template.of("download", result.getDownloadUrl()), | ||||||
|                                         .tag("download", Tag.preProcessParsed(result.getDownloadUrl())) |                                 Template.of("delete", result.getDeletionUrl()) | ||||||
|                                         .tag("delete", Tag.preProcessParsed(result.getDeletionUrl())) |  | ||||||
|                                         .build() |  | ||||||
|                         ); |                         ); | ||||||
|                     } |                     } | ||||||
|                 }); |                 }); | ||||||
|   | |||||||
| @@ -23,6 +23,7 @@ import com.plotsquared.core.PlotSquared; | |||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.CaptionUtility; | import com.plotsquared.core.configuration.caption.CaptionUtility; | ||||||
| import com.plotsquared.core.configuration.caption.StaticCaption; | import com.plotsquared.core.configuration.caption.StaticCaption; | ||||||
|  | import com.plotsquared.core.configuration.caption.Templates; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.events.PlotFlagAddEvent; | import com.plotsquared.core.events.PlotFlagAddEvent; | ||||||
| import com.plotsquared.core.events.PlotFlagRemoveEvent; | import com.plotsquared.core.events.PlotFlagRemoveEvent; | ||||||
| @@ -39,6 +40,7 @@ import com.plotsquared.core.plot.flag.types.IntegerFlag; | |||||||
| import com.plotsquared.core.plot.flag.types.ListFlag; | import com.plotsquared.core.plot.flag.types.ListFlag; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.StringComparison; | import com.plotsquared.core.util.StringComparison; | ||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| import com.plotsquared.core.util.helpmenu.HelpMenu; | import com.plotsquared.core.util.helpmenu.HelpMenu; | ||||||
| @@ -46,9 +48,7 @@ import com.plotsquared.core.util.task.RunnableVal2; | |||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.TextComponent; | import net.kyori.adventure.text.TextComponent; | ||||||
| import net.kyori.adventure.text.format.Style; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
| @@ -85,10 +85,7 @@ public final class FlagCommand extends Command { | |||||||
|     private static boolean sendMessage(PlotPlayer<?> player) { |     private static boolean sendMessage(PlotPlayer<?> player) { | ||||||
|         player.sendMessage( |         player.sendMessage( | ||||||
|                 TranslatableCaption.of("commandconfig.command_syntax"), |                 TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                 TagResolver.resolver( |                 Template.of("value", "/plot flag <set | remove | add | list | info> <flag> <value>") | ||||||
|                         "value", |  | ||||||
|                         Tag.inserting(Component.text("/plot flag <set | remove | add | list | info> <flag> <value>")) |  | ||||||
|                 ) |  | ||||||
|         ); |         ); | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| @@ -114,9 +111,9 @@ public final class FlagCommand extends Command { | |||||||
|                 if (!result) { |                 if (!result) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of( | ||||||
|                                     "node", |                                     "node", | ||||||
|                                     Tag.inserting(Component.text(perm + "." + numeric)) |                                     perm + "." + numeric | ||||||
|                             ) |                             ) | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
| @@ -131,23 +128,18 @@ public final class FlagCommand extends Command { | |||||||
|                             key.toLowerCase(), |                             key.toLowerCase(), | ||||||
|                             entry.toString().toLowerCase() |                             entry.toString().toLowerCase() | ||||||
|                     ); |                     ); | ||||||
|                     final boolean result = player.hasPermission(permission); |                     final boolean result = Permissions.hasPermission(player, permission); | ||||||
|                     if (!result) { |                     if (!result) { | ||||||
|                         player.sendMessage( |                         player.sendMessage(TranslatableCaption.of("permission.no_permission"), Template.of("node", permission)); | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |  | ||||||
|                                 TagResolver.resolver("node", Tag.inserting(Component.text(permission))) |  | ||||||
|                         ); |  | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } catch (final FlagParseException e) { |             } catch (final FlagParseException e) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("flag.flag_parse_error"), |                         TranslatableCaption.of("flag.flag_parse_error"), | ||||||
|                         TagResolver.builder() |                         Template.of("flag_name", flag.getName()), | ||||||
|                                 .tag("flag_name", Tag.inserting(Component.text(flag.getName()))) |                         Template.of("flag_value", e.getValue()), | ||||||
|                                 .tag("flag_value", Tag.inserting(Component.text(e.getValue()))) |                         Template.of("error", e.getErrorMessage().getComponent(player)) | ||||||
|                                 .tag("error", Tag.inserting(e.getErrorMessage().toComponent(player))) |  | ||||||
|                                 .build() |  | ||||||
|                 ); |                 ); | ||||||
|                 return false; |                 return false; | ||||||
|             } catch (final Exception e) { |             } catch (final Exception e) { | ||||||
| @@ -158,16 +150,13 @@ public final class FlagCommand extends Command { | |||||||
|         boolean result; |         boolean result; | ||||||
|         String basePerm = Permission.PERMISSION_SET_FLAG_KEY.format(key.toLowerCase()); |         String basePerm = Permission.PERMISSION_SET_FLAG_KEY.format(key.toLowerCase()); | ||||||
|         if (flag.isValuedPermission()) { |         if (flag.isValuedPermission()) { | ||||||
|             result = player.hasKeyedPermission(basePerm, value); |             result = Permissions.hasKeyedPermission(player, basePerm, value); | ||||||
|         } else { |         } else { | ||||||
|             result = player.hasPermission(basePerm); |             result = Permissions.hasPermission(player, basePerm); | ||||||
|             perm = basePerm; |             perm = basePerm; | ||||||
|         } |         } | ||||||
|         if (!result) { |         if (!result) { | ||||||
|             player.sendMessage( |             player.sendMessage(TranslatableCaption.of("permission.no_permission"), Template.of("node", perm)); | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |  | ||||||
|                     TagResolver.resolver("node", Tag.inserting(Component.text(perm))) |  | ||||||
|             ); |  | ||||||
|         } |         } | ||||||
|         return result; |         return result; | ||||||
|     } |     } | ||||||
| @@ -188,10 +177,11 @@ public final class FlagCommand extends Command { | |||||||
|             player.sendMessage(TranslatableCaption.of("working.plot_not_claimed")); |             player.sendMessage(TranslatableCaption.of("working.plot_not_claimed")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_SET_FLAG_OTHER)) { |         if (!plot.isOwner(player.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_SET_FLAG_OTHER)) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_SET_FLAG_OTHER)) |                     Template.of("node", String.valueOf(Permission.PERMISSION_SET_FLAG_OTHER)) | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -226,7 +216,7 @@ public final class FlagCommand extends Command { | |||||||
|                     if (best != null) { |                     if (best != null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("flag.not_valid_flag_suggested"), |                                 TranslatableCaption.of("flag.not_valid_flag_suggested"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(best))) |                                 Template.of("value", best) | ||||||
|                         ); |                         ); | ||||||
|                         suggested = true; |                         suggested = true; | ||||||
|                     } |                     } | ||||||
| @@ -335,7 +325,7 @@ public final class FlagCommand extends Command { | |||||||
|         if (args.length < 2) { |         if (args.length < 2) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("/plot flag set <flag> <value>"))) |                     Template.of("value", "/plot flag set <flag> <value>") | ||||||
|             ); |             ); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -348,7 +338,7 @@ public final class FlagCommand extends Command { | |||||||
|         if (event.getEventResult() == Result.DENY) { |         if (event.getEventResult() == Result.DENY) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("events.event_denied"), |                     TranslatableCaption.of("events.event_denied"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("Flag set"))) |                     Template.of("value", "Flag set") | ||||||
|             ); |             ); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -364,21 +354,15 @@ public final class FlagCommand extends Command { | |||||||
|         } catch (final FlagParseException e) { |         } catch (final FlagParseException e) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("flag.flag_parse_error"), |                     TranslatableCaption.of("flag.flag_parse_error"), | ||||||
|                     TagResolver.builder() |                     Template.of("flag_name", plotFlag.getName()), | ||||||
|                             .tag("flag_name", Tag.inserting(Component.text(plotFlag.getName()))) |                     Template.of("flag_value", e.getValue()), | ||||||
|                             .tag("flag_value", Tag.inserting(Component.text(e.getValue()))) |                     Template.of("error", e.getErrorMessage().getComponent(player)) | ||||||
|                             .tag("error", Tag.inserting(e.getErrorMessage().toComponent(player))) |  | ||||||
|                             .build() |  | ||||||
|             ); |             ); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         plot.setFlag(parsed); |         plot.setFlag(parsed); | ||||||
|         player.sendMessage( |         player.sendMessage(TranslatableCaption.of("flag.flag_added"), Template.of("flag", String.valueOf(args[0])), | ||||||
|                 TranslatableCaption.of("flag.flag_added"), |                 Template.of("value", String.valueOf(parsed)) | ||||||
|                 TagResolver.builder() |  | ||||||
|                         .tag("flag", Tag.inserting(Component.text(args[0]))) |  | ||||||
|                         .tag("value", Tag.inserting(Component.text(parsed.toString()))) |  | ||||||
|                         .build() |  | ||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -400,7 +384,7 @@ public final class FlagCommand extends Command { | |||||||
|         if (args.length < 2) { |         if (args.length < 2) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("/plot flag add <flag> <values>"))) |                     Template.of("value", "/plot flag add <flag> <values>") | ||||||
|             ); |             ); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -413,7 +397,7 @@ public final class FlagCommand extends Command { | |||||||
|         if (event.getEventResult() == Result.DENY) { |         if (event.getEventResult() == Result.DENY) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("events.event_denied"), |                     TranslatableCaption.of("events.event_denied"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("Flag add"))) |                     Template.of("value", "Flag add") | ||||||
|             ); |             ); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -434,11 +418,9 @@ public final class FlagCommand extends Command { | |||||||
|         } catch (FlagParseException e) { |         } catch (FlagParseException e) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("flag.flag_parse_error"), |                     TranslatableCaption.of("flag.flag_parse_error"), | ||||||
|                     TagResolver.builder() |                     Template.of("flag_name", plotFlag.getName()), | ||||||
|                             .tag("flag_name", Tag.inserting(Component.text(plotFlag.getName()))) |                     Template.of("flag_value", e.getValue()), | ||||||
|                             .tag("flag_value", Tag.inserting(Component.text(e.getValue()))) |                     Template.of("error", e.getErrorMessage().getComponent(player)) | ||||||
|                             .tag("error", Tag.inserting(e.getErrorMessage().toComponent(player))) |  | ||||||
|                             .build() |  | ||||||
|             ); |             ); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -448,12 +430,8 @@ public final class FlagCommand extends Command { | |||||||
|             player.sendMessage(TranslatableCaption.of("flag.flag_not_added")); |             player.sendMessage(TranslatableCaption.of("flag.flag_not_added")); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         player.sendMessage( |         player.sendMessage(TranslatableCaption.of("flag.flag_added"), Template.of("flag", String.valueOf(args[0])), | ||||||
|                 TranslatableCaption.of("flag.flag_added"), |                 Template.of("value", String.valueOf(parsed)) | ||||||
|                 TagResolver.builder() |  | ||||||
|                         .tag("flag", Tag.inserting(Component.text(args[0]))) |  | ||||||
|                         .tag("value", Tag.inserting(Component.text(parsed.toString()))) |  | ||||||
|                         .build() |  | ||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -475,7 +453,7 @@ public final class FlagCommand extends Command { | |||||||
|         if (args.length != 1 && args.length != 2) { |         if (args.length != 1 && args.length != 2) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("/plot flag remove <flag> [values]"))) |                     Template.of("value", "/plot flag remove <flag> [values]") | ||||||
|             ); |             ); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -489,20 +467,17 @@ public final class FlagCommand extends Command { | |||||||
|         if (event.getEventResult() == Result.DENY) { |         if (event.getEventResult() == Result.DENY) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("events.event_denied"), |                     TranslatableCaption.of("events.event_denied"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("Flag remove"))) |                     Template.of("value", "Flag remove") | ||||||
|             ); |             ); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         boolean force = event.getEventResult() == Result.FORCE; |         boolean force = event.getEventResult() == Result.FORCE; | ||||||
|         flag = event.getFlag(); |         flag = event.getFlag(); | ||||||
|         if (!force && !player.hasPermission(Permission.PERMISSION_SET_FLAG_KEY.format(args[0].toLowerCase()))) { |         if (!force && !Permissions.hasPermission(player, Permission.PERMISSION_SET_FLAG_KEY.format(args[0].toLowerCase()))) { | ||||||
|             if (args.length != 2) { |             if (args.length != 2) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission"), |                         TranslatableCaption.of("permission.no_permission"), | ||||||
|                         TagResolver.resolver( |                         Template.of("node", Permission.PERMISSION_SET_FLAG_KEY.format(args[0].toLowerCase())) | ||||||
|                                 "node", |  | ||||||
|                                 Tag.inserting(Component.text(Permission.PERMISSION_SET_FLAG_KEY.format(args[0].toLowerCase()))) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| @@ -517,11 +492,9 @@ public final class FlagCommand extends Command { | |||||||
|             } catch (final FlagParseException e) { |             } catch (final FlagParseException e) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("flag.flag_parse_error"), |                         TranslatableCaption.of("flag.flag_parse_error"), | ||||||
|                         TagResolver.builder() |                         Template.of("flag_name", flag.getName()), | ||||||
|                                 .tag("flag_name", Tag.inserting(Component.text(flag.getName()))) |                         Template.of("flag_value", e.getValue()), | ||||||
|                                 .tag("flag_value", Tag.inserting(Component.text(e.getValue()))) |                         Template.of("error", String.valueOf(e.getErrorMessage())) | ||||||
|                                 .tag("error", Tag.inserting(e.getErrorMessage().toComponent(player))) |  | ||||||
|                                 .build() |  | ||||||
|                 ); |                 ); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| @@ -532,13 +505,10 @@ public final class FlagCommand extends Command { | |||||||
|             if (list.removeAll((List) parsedFlag.getValue())) { |             if (list.removeAll((List) parsedFlag.getValue())) { | ||||||
|                 if (list.isEmpty()) { |                 if (list.isEmpty()) { | ||||||
|                     if (plot.removeFlag(flag)) { |                     if (plot.removeFlag(flag)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage(TranslatableCaption.of("flag.flag_removed"), Template.of("flag", args[0]), Template.of( | ||||||
|                                 TranslatableCaption.of("flag.flag_removed"), |                                 "value", | ||||||
|                                 TagResolver.builder() |                                 String.valueOf(flagWithOldValue) | ||||||
|                                         .tag("flag", Tag.inserting(Component.text(args[0]))) |                         )); | ||||||
|                                         .tag("value", Tag.inserting(Component.text(flag.toString()))) |  | ||||||
|                                         .build() |  | ||||||
|                         ); |  | ||||||
|                         return; |                         return; | ||||||
|                     } else { |                     } else { | ||||||
|                         player.sendMessage(TranslatableCaption.of("flag.flag_not_removed")); |                         player.sendMessage(TranslatableCaption.of("flag.flag_not_removed")); | ||||||
| @@ -550,10 +520,7 @@ public final class FlagCommand extends Command { | |||||||
|                     if (addEvent.getEventResult() == Result.DENY) { |                     if (addEvent.getEventResult() == Result.DENY) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("events.event_denied"), |                                 TranslatableCaption.of("events.event_denied"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("value", "Re-addition of " + plotFlag.getName()) | ||||||
|                                         "value", |  | ||||||
|                                         Tag.inserting(Component.text("Re-addition of " + plotFlag.getName())) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
| @@ -576,13 +543,10 @@ public final class FlagCommand extends Command { | |||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         player.sendMessage( |         player.sendMessage(TranslatableCaption.of("flag.flag_removed"), Template.of("flag", args[0]), Template.of( | ||||||
|                 TranslatableCaption.of("flag.flag_removed"), |                 "value", | ||||||
|                 TagResolver.builder() |                 String.valueOf(flagWithOldValue) | ||||||
|                         .tag("flag", Tag.inserting(Component.text(args[0]))) |         )); | ||||||
|                         .tag("value", Tag.inserting(Component.text(flag.toString()))) |  | ||||||
|                         .build() |  | ||||||
|         ); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @CommandDeclaration(command = "list", |     @CommandDeclaration(command = "list", | ||||||
| @@ -600,35 +564,34 @@ public final class FlagCommand extends Command { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         final Map<Component, ArrayList<String>> flags = new HashMap<>(); |         final Map<String, ArrayList<String>> flags = new HashMap<>(); | ||||||
|         for (PlotFlag<?, ?> plotFlag : GlobalFlagContainer.getInstance().getRecognizedPlotFlags()) { |         for (PlotFlag<?, ?> plotFlag : GlobalFlagContainer.getInstance().getRecognizedPlotFlags()) { | ||||||
|             if (plotFlag instanceof InternalFlag) { |             if (plotFlag instanceof InternalFlag) { | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|             final Component category = plotFlag.getFlagCategory().toComponent(player); |             final String category = MINI_MESSAGE.stripTokens(plotFlag.getFlagCategory().getComponent(player)); | ||||||
|             final Collection<String> flagList = flags.computeIfAbsent(category, k -> new ArrayList<>()); |             final Collection<String> flagList = | ||||||
|  |                     flags.computeIfAbsent(category, k -> new ArrayList<>()); | ||||||
|             flagList.add(plotFlag.getName()); |             flagList.add(plotFlag.getName()); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         for (final Map.Entry<Component, ArrayList<String>> entry : flags.entrySet()) { |         for (final Map.Entry<String, ArrayList<String>> entry : flags.entrySet()) { | ||||||
|             Collections.sort(entry.getValue()); |             Collections.sort(entry.getValue()); | ||||||
|             Component category = |             Component category = | ||||||
|                     MINI_MESSAGE.deserialize( |                     MINI_MESSAGE.parse( | ||||||
|                             TranslatableCaption.of("flag.flag_list_categories").getComponent(player), |                             TranslatableCaption.of("flag.flag_list_categories").getComponent(player), | ||||||
|                             TagResolver.resolver("category", Tag.inserting(entry.getKey().style(Style.empty()))) |                             Template.of("category", entry.getKey()) | ||||||
|                     ); |                     ); | ||||||
|             TextComponent.Builder builder = Component.text().append(category); |             TextComponent.Builder builder = Component.text().append(category); | ||||||
|             final Iterator<String> flagIterator = entry.getValue().iterator(); |             final Iterator<String> flagIterator = entry.getValue().iterator(); | ||||||
|             while (flagIterator.hasNext()) { |             while (flagIterator.hasNext()) { | ||||||
|                 final String flag = flagIterator.next(); |                 final String flag = flagIterator.next(); | ||||||
|                 builder.append(MINI_MESSAGE |                 builder.append(MINI_MESSAGE | ||||||
|                         .deserialize( |                         .parse( | ||||||
|                                 TranslatableCaption.of("flag.flag_list_flag").getComponent(player), |                                 TranslatableCaption.of("flag.flag_list_flag").getComponent(player), | ||||||
|                                 TagResolver.builder() |                                 Template.of("command", "/plot flag info " + flag), | ||||||
|                                         .tag("command", Tag.preProcessParsed("/plot flag info " + flag)) |                                 Template.of("flag", flag), | ||||||
|                                         .tag("flag", Tag.inserting(Component.text(flag))) |                                 Template.of("suffix", flagIterator.hasNext() ? ", " : "") | ||||||
|                                         .tag("suffix", Tag.inserting(Component.text(flagIterator.hasNext() ? ", " : ""))) |  | ||||||
|                                         .build() |  | ||||||
|                         )); |                         )); | ||||||
|             } |             } | ||||||
|             player.sendMessage(StaticCaption.of(MINI_MESSAGE.serialize(builder.build()))); |             player.sendMessage(StaticCaption.of(MINI_MESSAGE.serialize(builder.build()))); | ||||||
| @@ -652,7 +615,7 @@ public final class FlagCommand extends Command { | |||||||
|         if (args.length < 1) { |         if (args.length < 1) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("/plot flag info <flag>"))) |                     Template.of("value", "/plot flag info <flag>") | ||||||
|             ); |             ); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -660,17 +623,11 @@ public final class FlagCommand extends Command { | |||||||
|         if (plotFlag != null) { |         if (plotFlag != null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("flag.flag_info_header")); |             player.sendMessage(TranslatableCaption.of("flag.flag_info_header")); | ||||||
|             // Flag name |             // Flag name | ||||||
|             player.sendMessage( |             player.sendMessage(TranslatableCaption.of("flag.flag_info_name"), Template.of("flag", plotFlag.getName())); | ||||||
|                     TranslatableCaption.of("flag.flag_info_name"), |  | ||||||
|                     TagResolver.resolver("flag", Tag.inserting(Component.text(plotFlag.getName()))) |  | ||||||
|             ); |  | ||||||
|             // Flag category |             // Flag category | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("flag.flag_info_category"), |                     TranslatableCaption.of("flag.flag_info_category"), | ||||||
|                     TagResolver.resolver( |                     Templates.of(player, "value", plotFlag.getFlagCategory()) | ||||||
|                             "value", |  | ||||||
|                             Tag.inserting(plotFlag.getFlagCategory().toComponent(player)) |  | ||||||
|                     ) |  | ||||||
|             ); |             ); | ||||||
|             // Flag description |             // Flag description | ||||||
|             // TODO maybe merge and \n instead? |             // TODO maybe merge and \n instead? | ||||||
| @@ -679,18 +636,16 @@ public final class FlagCommand extends Command { | |||||||
|             // Flag example |             // Flag example | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("flag.flag_info_example"), |                     TranslatableCaption.of("flag.flag_info_example"), | ||||||
|                     TagResolver.builder() |                     Template.of("command", "/plot flag set"), | ||||||
|                             .tag("command", Tag.preProcessParsed("/plot flag set")) |                     Template.of("flag", plotFlag.getName()), | ||||||
|                             .tag("flag", Tag.preProcessParsed(plotFlag.getName())) |                     Template.of("value", plotFlag.getExample()) | ||||||
|                             .tag("value", Tag.preProcessParsed(plotFlag.getExample())) |  | ||||||
|                             .build() |  | ||||||
|             ); |             ); | ||||||
|             // Default value |             // Default value | ||||||
|             final String defaultValue = player.getLocation().getPlotArea().getFlagContainer() |             final String defaultValue = player.getLocation().getPlotArea().getFlagContainer() | ||||||
|                     .getFlagErased(plotFlag.getClass()).toString(); |                     .getFlagErased(plotFlag.getClass()).toString(); | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("flag.flag_info_default_value"), |                     TranslatableCaption.of("flag.flag_info_default_value"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text(defaultValue))) |                     Template.of("value", defaultValue) | ||||||
|             ); |             ); | ||||||
|             // Footer. Done this way to prevent the duplicate-message-thingy from catching it |             // Footer. Done this way to prevent the duplicate-message-thingy from catching it | ||||||
|             player.sendMessage(TranslatableCaption.of("flag.flag_info_footer")); |             player.sendMessage(TranslatableCaption.of("flag.flag_info_footer")); | ||||||
|   | |||||||
| @@ -26,14 +26,13 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.MetaDataAccess; | import com.plotsquared.core.player.MetaDataAccess; | ||||||
| import com.plotsquared.core.player.PlayerMetaDataKeys; | import com.plotsquared.core.player.PlayerMetaDataKeys; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.PlayerManager; | import com.plotsquared.core.util.PlayerManager; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
|  |  | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| import java.util.Collections; | import java.util.Collections; | ||||||
| @@ -65,15 +64,15 @@ public class Grant extends Command { | |||||||
|         checkTrue( |         checkTrue( | ||||||
|                 args.length >= 1 && args.length <= 2, |                 args.length >= 1 && args.length <= 2, | ||||||
|                 TranslatableCaption.of("commandconfig.command_syntax"), |                 TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                 TagResolver.resolver("value", Tag.inserting(Component.text("/plot grant <check | add> [player]"))) |                 Template.of("value", "/plot grant <check | add> [player]") | ||||||
|         ); |         ); | ||||||
|         final String arg0 = args[0].toLowerCase(); |         final String arg0 = args[0].toLowerCase(); | ||||||
|         switch (arg0) { |         switch (arg0) { | ||||||
|             case "add", "check" -> { |             case "add", "check" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_GRANT.format(arg0))) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_GRANT.format(arg0))) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text(Permission.PERMISSION_GRANT.format(arg0)))) |                             Template.of("node", Permission.PERMISSION_GRANT.format(arg0)) | ||||||
|                     ); |                     ); | ||||||
|                     return CompletableFuture.completedFuture(false); |                     return CompletableFuture.completedFuture(false); | ||||||
|                 } |                 } | ||||||
| @@ -86,7 +85,7 @@ public class Grant extends Command { | |||||||
|                     } else if (throwable != null || uuids.size() != 1) { |                     } else if (throwable != null || uuids.size() != 1) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("errors.invalid_player"), |                                 TranslatableCaption.of("errors.invalid_player"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(String.valueOf(uuids)))) |                                 Template.of("value", String.valueOf(uuids)) | ||||||
|                         ); |                         ); | ||||||
|                     } else { |                     } else { | ||||||
|                         final UUID uuid = uuids.iterator().next(); |                         final UUID uuid = uuids.iterator().next(); | ||||||
| @@ -97,7 +96,7 @@ public class Grant extends Command { | |||||||
|                                 if (args[0].equalsIgnoreCase("check")) { |                                 if (args[0].equalsIgnoreCase("check")) { | ||||||
|                                     player.sendMessage( |                                     player.sendMessage( | ||||||
|                                             TranslatableCaption.of("grants.granted_plots"), |                                             TranslatableCaption.of("grants.granted_plots"), | ||||||
|                                             TagResolver.resolver("amount", Tag.inserting(Component.text(access.get().orElse(0)))) |                                             Template.of("amount", String.valueOf(access.get().orElse(0))) | ||||||
|                                     ); |                                     ); | ||||||
|                                 } else { |                                 } else { | ||||||
|                                     access.set(access.get().orElse(0) + 1); |                                     access.set(access.get().orElse(0) + 1); | ||||||
| @@ -117,7 +116,7 @@ public class Grant extends Command { | |||||||
|                                         } |                                         } | ||||||
|                                         player.sendMessage( |                                         player.sendMessage( | ||||||
|                                                 TranslatableCaption.of("grants.granted_plots"), |                                                 TranslatableCaption.of("grants.granted_plots"), | ||||||
|                                                 TagResolver.resolver("amount", Tag.inserting(Component.text(granted))) |                                                 Template.of("amount", String.valueOf(granted)) | ||||||
|                                         ); |                                         ); | ||||||
|                                     } else { // add |                                     } else { // add | ||||||
|                                         int amount; |                                         int amount; | ||||||
| @@ -132,7 +131,7 @@ public class Grant extends Command { | |||||||
|                                         DBFunc.addPersistentMeta(uuid, key, rawData, replace); |                                         DBFunc.addPersistentMeta(uuid, key, rawData, replace); | ||||||
|                                         player.sendMessage( |                                         player.sendMessage( | ||||||
|                                                 TranslatableCaption.of("grants.added"), |                                                 TranslatableCaption.of("grants.added"), | ||||||
|                                                 TagResolver.resolver("grants", Tag.inserting(Component.text(amount))) |                                                 Template.of("grants", String.valueOf(amount)) | ||||||
|                                         ); |                                         ); | ||||||
|                                     } |                                     } | ||||||
|                                 } |                                 } | ||||||
| @@ -151,10 +150,10 @@ public class Grant extends Command { | |||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         if (args.length == 1) { |         if (args.length == 1) { | ||||||
|             final List<String> completions = new LinkedList<>(); |             final List<String> completions = new LinkedList<>(); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_GRANT_ADD)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_GRANT_ADD)) { | ||||||
|                 completions.add("add"); |                 completions.add("add"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_GRANT_CHECK)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_GRANT_CHECK)) { | ||||||
|                 completions.add("check"); |                 completions.add("check"); | ||||||
|             } |             } | ||||||
|             final List<Command> commands = completions.stream().filter(completion -> completion |             final List<Command> commands = completions.stream().filter(completion -> completion | ||||||
| @@ -169,7 +168,7 @@ public class Grant extends Command { | |||||||
|                             CommandCategory.ADMINISTRATION |                             CommandCategory.ADMINISTRATION | ||||||
|                     ) { |                     ) { | ||||||
|                     }).collect(Collectors.toCollection(LinkedList::new)); |                     }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_GRANT_SINGLE) && args[0].length() > 0) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_GRANT_SINGLE) && args[0].length() > 0) { | ||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             return commands; | ||||||
|   | |||||||
| @@ -28,8 +28,7 @@ import com.plotsquared.core.util.task.RunnableVal2; | |||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.TextComponent; | import net.kyori.adventure.text.TextComponent; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| @@ -111,31 +110,27 @@ public class Help extends Command { | |||||||
|             } |             } | ||||||
|             if (cat == null && page == 0) { |             if (cat == null && page == 0) { | ||||||
|                 TextComponent.Builder builder = Component.text(); |                 TextComponent.Builder builder = Component.text(); | ||||||
|                 builder.append(MINI_MESSAGE.deserialize(TranslatableCaption.of("help.help_header").getComponent(player))); |                 builder.append(MINI_MESSAGE.parse(TranslatableCaption.of("help.help_header").getComponent(player))); | ||||||
|                 for (CommandCategory c : CommandCategory.values()) { |                 for (CommandCategory c : CommandCategory.values()) { | ||||||
|                     if (!c.canAccess(player)) { |                     if (!c.canAccess(player)) { | ||||||
|                         continue; |                         continue; | ||||||
|                     } |                     } | ||||||
|                     builder.append(Component.newline()).append(MINI_MESSAGE |                     builder.append(Component.newline()).append(MINI_MESSAGE | ||||||
|                             .deserialize( |                             .parse( | ||||||
|                                     TranslatableCaption.of("help.help_info_item").getComponent(player), |                                     TranslatableCaption.of("help.help_info_item").getComponent(player), | ||||||
|                                     TagResolver.builder() |                                     Template.of("command", "/plot help"), | ||||||
|                                             .tag("command", Tag.inserting(Component.text("/plot help"))) |                                     Template.of("category", c.name().toLowerCase()), | ||||||
|                                             .tag("category", Tag.inserting(Component.text(c.name().toLowerCase()))) |                                     Template.of("category_desc", c.getComponent(player)) | ||||||
|                                             .tag("category_desc", Tag.inserting(c.toComponent(player))) |  | ||||||
|                                             .build() |  | ||||||
|                             )); |                             )); | ||||||
|                 } |                 } | ||||||
|                 builder.append(Component.newline()).append(MINI_MESSAGE |                 builder.append(Component.newline()).append(MINI_MESSAGE | ||||||
|                         .deserialize( |                         .parse( | ||||||
|                                 TranslatableCaption.of("help.help_info_item").getComponent(player), |                                 TranslatableCaption.of("help.help_info_item").getComponent(player), | ||||||
|                                 TagResolver.builder() |                                 Template.of("command", "/plot help"), | ||||||
|                                         .tag("command", Tag.inserting(Component.text("/plot help"))) |                                 Template.of("category", "all"), | ||||||
|                                         .tag("category", Tag.inserting(Component.text("all"))) |                                 Template.of("category_desc", "Display all commands") | ||||||
|                                         .tag("category_desc", Tag.inserting(TranslatableCaption.of("help.help_display_all_commands").toComponent(player))) |  | ||||||
|                                         .build() |  | ||||||
|                         )); |                         )); | ||||||
|                 builder.append(Component.newline()).append(MINI_MESSAGE.deserialize(TranslatableCaption |                 builder.append(Component.newline()).append(MINI_MESSAGE.parse(TranslatableCaption | ||||||
|                         .of("help.help_footer") |                         .of("help.help_footer") | ||||||
|                         .getComponent(player))); |                         .getComponent(player))); | ||||||
|                 player.sendMessage(StaticCaption.of(MINI_MESSAGE.serialize(builder.asComponent()))); |                 player.sendMessage(StaticCaption.of(MINI_MESSAGE.serialize(builder.asComponent()))); | ||||||
|   | |||||||
| @@ -29,14 +29,16 @@ import com.plotsquared.core.plot.PlotArea; | |||||||
| import com.plotsquared.core.plot.PlotId; | import com.plotsquared.core.plot.PlotId; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.query.PlotQuery; | import com.plotsquared.core.util.query.PlotQuery; | ||||||
| import com.plotsquared.core.util.query.SortingStrategy; | import com.plotsquared.core.util.query.SortingStrategy; | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import net.kyori.adventure.text.Component; | import jdk.jfr.Category; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import jdk.jfr.Event; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import jdk.jfr.Label; | ||||||
|  | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| @@ -60,23 +62,32 @@ public class HomeCommand extends Command { | |||||||
|         this.plotAreaManager = plotAreaManager; |         this.plotAreaManager = plotAreaManager; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Label("Home Query") | ||||||
|  |     @Category("PlotSquared") | ||||||
|  |     static class HomeQueryEvent extends Event { | ||||||
|  |         @Label("Result Size") | ||||||
|  |         public int size; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     private void home( |     private void home( | ||||||
|             final @NonNull PlotPlayer<?> player, |             final @NonNull PlotPlayer<?> player, | ||||||
|             final @NonNull PlotQuery query, final int page, |             final @NonNull PlotQuery query, final int page, | ||||||
|             final RunnableVal3<Command, Runnable, Runnable> confirm, |             final RunnableVal3<Command, Runnable, Runnable> confirm, | ||||||
|             final RunnableVal2<Command, CommandResult> whenDone |             final RunnableVal2<Command, CommandResult> whenDone | ||||||
|     ) { |     ) { | ||||||
|  |         final HomeQueryEvent event = new HomeQueryEvent(); | ||||||
|  |         event.begin(); | ||||||
|         List<Plot> plots = query.asList(); |         List<Plot> plots = query.asList(); | ||||||
|  |         event.size = plots.size(); | ||||||
|  |         event.commit(); | ||||||
|         if (plots.isEmpty()) { |         if (plots.isEmpty()) { | ||||||
|             player.sendMessage(TranslatableCaption.of("invalid.found_no_plots")); |             player.sendMessage(TranslatableCaption.of("invalid.found_no_plots")); | ||||||
|             return; |             return; | ||||||
|         } else if (plots.size() < page || page < 1) { |         } else if (plots.size() < page || page < 1) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("invalid.number_not_in_range"), |                     TranslatableCaption.of("invalid.number_not_in_range"), | ||||||
|                     TagResolver.builder() |                     Template.of("min", "1"), | ||||||
|                             .tag("min", Tag.inserting(Component.text(1))) |                     Template.of("max", String.valueOf(plots.size())) | ||||||
|                             .tag("max", Tag.inserting(Component.text(plots.size()))) |  | ||||||
|                             .build() |  | ||||||
|             ); |             ); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -107,10 +118,11 @@ public class HomeCommand extends Command { | |||||||
|         // /plot home <[area;]x;y> |         // /plot home <[area;]x;y> | ||||||
|         // /plot home <area> <x;y> |         // /plot home <area> <x;y> | ||||||
|         // /plot home <area> <page> |         // /plot home <area> <page> | ||||||
|         if (!player.hasPermission(Permission.PERMISSION_VISIT_OWNED) && !player.hasPermission(Permission.PERMISSION_HOME)) { |         if (!Permissions.hasPermission(player, Permission.PERMISSION_VISIT_OWNED) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_HOME)) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver("node", Tag.inserting(Component.text(Permission.PERMISSION_VISIT_OWNED.toString()))) |                     Template.of("node", Permission.PERMISSION_VISIT_OWNED.toString()) | ||||||
|             ); |             ); | ||||||
|             return CompletableFuture.completedFuture(false); |             return CompletableFuture.completedFuture(false); | ||||||
|         } |         } | ||||||
| @@ -132,7 +144,7 @@ public class HomeCommand extends Command { | |||||||
|                     } catch (NumberFormatException ignored) { |                     } catch (NumberFormatException ignored) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("invalid.not_a_number"), |                                 TranslatableCaption.of("invalid.not_a_number"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(identifier))) |                                 Template.of("value", identifier) | ||||||
|                         ); |                         ); | ||||||
|                         return CompletableFuture.completedFuture(false); |                         return CompletableFuture.completedFuture(false); | ||||||
|                     } |                     } | ||||||
| @@ -173,7 +185,7 @@ public class HomeCommand extends Command { | |||||||
|                     } catch (NumberFormatException ignored) { |                     } catch (NumberFormatException ignored) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("invalid.not_a_number"), |                                 TranslatableCaption.of("invalid.not_a_number"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(identifier))) |                                 Template.of("value", identifier) | ||||||
|                         ); |                         ); | ||||||
|                         return CompletableFuture.completedFuture(false); |                         return CompletableFuture.completedFuture(false); | ||||||
|                     } |                     } | ||||||
|   | |||||||
| @@ -20,6 +20,7 @@ package com.plotsquared.core.command; | |||||||
|  |  | ||||||
| import com.google.inject.TypeLiteral; | import com.google.inject.TypeLiteral; | ||||||
| import com.plotsquared.core.configuration.caption.StaticCaption; | import com.plotsquared.core.configuration.caption.StaticCaption; | ||||||
|  | import com.plotsquared.core.configuration.caption.Templates; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.MetaDataAccess; | import com.plotsquared.core.player.MetaDataAccess; | ||||||
| @@ -29,13 +30,13 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.comment.CommentInbox; | import com.plotsquared.core.plot.comment.CommentInbox; | ||||||
| import com.plotsquared.core.plot.comment.CommentManager; | import com.plotsquared.core.plot.comment.CommentManager; | ||||||
| import com.plotsquared.core.plot.comment.PlotComment; | import com.plotsquared.core.plot.comment.PlotComment; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.TextComponent; | import net.kyori.adventure.text.TextComponent; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
|  |  | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| import java.util.Collections; | import java.util.Collections; | ||||||
| @@ -71,14 +72,9 @@ public class Inbox extends SubCommand { | |||||||
|             max = comments.length; |             max = comments.length; | ||||||
|         } |         } | ||||||
|         TextComponent.Builder builder = Component.text(); |         TextComponent.Builder builder = Component.text(); | ||||||
|         builder.append(MINI_MESSAGE.deserialize( |         builder.append(MINI_MESSAGE.parse(TranslatableCaption.of("list.comment_list_header_paged").getComponent(player) + '\n', | ||||||
|                 TranslatableCaption.of("list.comment_list_header_paged").getComponent(player) + '\n', |                 Template.of("amount", String.valueOf(comments.length)), Template.of("cur", String.valueOf(page + 1)), | ||||||
|                 TagResolver.builder() |                 Template.of("max", String.valueOf(totalPages + 1)), Template.of("word", "all") | ||||||
|                         .tag("amount", Tag.inserting(Component.text(comments.length))) |  | ||||||
|                         .tag("cur", Tag.inserting(Component.text(page + 1))) |  | ||||||
|                         .tag("max", Tag.inserting(Component.text(totalPages + 1))) |  | ||||||
|                         .tag("word", Tag.inserting(Component.text("all"))) |  | ||||||
|                         .build() |  | ||||||
|         )); |         )); | ||||||
|  |  | ||||||
|         // This might work xD |         // This might work xD | ||||||
| @@ -87,28 +83,30 @@ public class Inbox extends SubCommand { | |||||||
|             Component commentColored; |             Component commentColored; | ||||||
|             if (player.getName().equals(comment.senderName)) { |             if (player.getName().equals(comment.senderName)) { | ||||||
|                 commentColored = MINI_MESSAGE |                 commentColored = MINI_MESSAGE | ||||||
|                         .deserialize( |                         .parse( | ||||||
|                                 TranslatableCaption.of("list.comment_list_by_lister").getComponent(player), |                                 TranslatableCaption.of("list.comment_list_by_lister").getComponent(player), | ||||||
|                                 TagResolver.resolver("comment", Tag.inserting(Component.text(comment.comment))) |                                 Template.of("comment", comment.comment) | ||||||
|                         ); |                         ); | ||||||
|             } else { |             } else { | ||||||
|                 commentColored = MINI_MESSAGE |                 commentColored = MINI_MESSAGE | ||||||
|                         .deserialize( |                         .parse( | ||||||
|                                 TranslatableCaption.of("list.comment_list_by_other").getComponent(player), |                                 TranslatableCaption.of("list.comment_list_by_other").getComponent(player), | ||||||
|                                 TagResolver.resolver("comment", Tag.inserting(Component.text(comment.comment))) |                                 Template.of("comment", comment.comment) | ||||||
|                         ); |                         ); | ||||||
|             } |             } | ||||||
|             TagResolver resolver = TagResolver.builder() |             Template number = Template.of("number", String.valueOf(x)); | ||||||
|                     .tag("number", Tag.inserting(Component.text(x))) |             Template world = Template.of("world", comment.world); | ||||||
|                     .tag("world", Tag.inserting(Component.text(comment.world))) |             Template plot_id = Template.of("plot_id", comment.id.getX() + ";" + comment.id.getY()); | ||||||
|                     .tag("plot_id", Tag.inserting(Component.text(comment.id.getX() + ";" + comment.id.getY()))) |             Template commenter = Template.of("commenter", comment.senderName); | ||||||
|                     .tag("commenter", Tag.inserting(Component.text(comment.senderName))) |             Template commentTemplate = Template.of("comment", commentColored); | ||||||
|                     .tag("comment", Tag.inserting(commentColored)) |  | ||||||
|                     .build(); |  | ||||||
|             builder.append(MINI_MESSAGE |             builder.append(MINI_MESSAGE | ||||||
|                     .deserialize( |                     .parse( | ||||||
|                             TranslatableCaption.of("list.comment_list_comment").getComponent(player), |                             TranslatableCaption.of("list.comment_list_comment").getComponent(player), | ||||||
|                             resolver |                             number, | ||||||
|  |                             world, | ||||||
|  |                             plot_id, | ||||||
|  |                             commenter, | ||||||
|  |                             commentTemplate | ||||||
|                     )); |                     )); | ||||||
|         } |         } | ||||||
|         player.sendMessage(StaticCaption.of(MINI_MESSAGE.serialize(builder.build()))); |         player.sendMessage(StaticCaption.of(MINI_MESSAGE.serialize(builder.build()))); | ||||||
| @@ -145,23 +143,20 @@ public class Inbox extends SubCommand { | |||||||
|                                 if (total != 0) { |                                 if (total != 0) { | ||||||
|                                     player.sendMessage( |                                     player.sendMessage( | ||||||
|                                             TranslatableCaption.of("comment.inbox_item"), |                                             TranslatableCaption.of("comment.inbox_item"), | ||||||
|                                             TagResolver.resolver( |                                             Template.of("value", inbox + " (" + total + '/' + unread + ')') | ||||||
|                                                     "value", |  | ||||||
|                                                     Tag.inserting(Component.text(inbox + " (" + total + '/' + unread + ')')) |  | ||||||
|                                             ) |  | ||||||
|                                     ); |                                     ); | ||||||
|                                     return; |                                     return; | ||||||
|                                 } |                                 } | ||||||
|                             } |                             } | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("comment.inbox_item"), |                                     TranslatableCaption.of("comment.inbox_item"), | ||||||
|                                     TagResolver.resolver("value", Tag.inserting(Component.text(inbox.toString()))) |                                     Template.of("value", inbox.toString()) | ||||||
|                             ); |                             ); | ||||||
|                         } |                         } | ||||||
|                     })) { |                     })) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("comment.inbox_item"), |                                 TranslatableCaption.of("comment.inbox_item"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(inbox.toString()))) |                                 Template.of("value", inbox.toString()) | ||||||
|                         ); |                         ); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| @@ -172,10 +167,7 @@ public class Inbox extends SubCommand { | |||||||
|         if (inbox == null) { |         if (inbox == null) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("comment.invalid_inbox"), |                     TranslatableCaption.of("comment.invalid_inbox"), | ||||||
|                     TagResolver.resolver( |                     Template.of("list", StringMan.join(CommentManager.inboxes.keySet(), ", ")) | ||||||
|                             "list", |  | ||||||
|                             Tag.inserting(Component.text(StringMan.join(CommentManager.inboxes.keySet(), ", "))) |  | ||||||
|                     ) |  | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -198,10 +190,7 @@ public class Inbox extends SubCommand { | |||||||
|                     if (args.length != 3) { |                     if (args.length != 3) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("commandconfig.command_syntax"), |                                 TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("value", "/plot inbox " + inbox + " delete <index>") | ||||||
|                                         "value", |  | ||||||
|                                         Tag.inserting(Component.text("/plot inbox " + inbox + " delete <index>")) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         return true; |                         return true; | ||||||
|                     } |                     } | ||||||
| @@ -211,17 +200,14 @@ public class Inbox extends SubCommand { | |||||||
|                         if (index < 1) { |                         if (index < 1) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("comment.not_valid_inbox_index"), |                                     TranslatableCaption.of("comment.not_valid_inbox_index"), | ||||||
|                                     TagResolver.resolver("number", Tag.inserting(Component.text(index))) |                                     Templates.of("number", index) | ||||||
|                             ); |                             ); | ||||||
|                             return false; |                             return false; | ||||||
|                         } |                         } | ||||||
|                     } catch (NumberFormatException ignored) { |                     } catch (NumberFormatException ignored) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("commandconfig.command_syntax"), |                                 TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("value", "/plot inbox " + inbox + " delete <index>") | ||||||
|                                         "value", |  | ||||||
|                                         Tag.inserting(Component.text("/plot inbox " + inbox + " delete <index>")) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -232,7 +218,7 @@ public class Inbox extends SubCommand { | |||||||
|                             if (index > value.size()) { |                             if (index > value.size()) { | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("comment.not_valid_inbox_index"), |                                         TranslatableCaption.of("comment.not_valid_inbox_index"), | ||||||
|                                         TagResolver.resolver("number", Tag.inserting(Component.text(index))) |                                         Templates.of("number", index) | ||||||
|                                 ); |                                 ); | ||||||
|                                 return; |                                 return; | ||||||
|                             } |                             } | ||||||
| @@ -242,7 +228,7 @@ public class Inbox extends SubCommand { | |||||||
|                             if (success) { |                             if (success) { | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("comment.comment_removed_success"), |                                         TranslatableCaption.of("comment.comment_removed_success"), | ||||||
|                                         TagResolver.resolver("value", Tag.inserting(Component.text(comment.comment))) |                                         Template.of("value", comment.comment) | ||||||
|                                 ); |                                 ); | ||||||
|                             } else { |                             } else { | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
| @@ -263,7 +249,7 @@ public class Inbox extends SubCommand { | |||||||
|                     if (!comments.isEmpty()) { |                     if (!comments.isEmpty()) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("comment.comment_removed_success"), |                                 TranslatableCaption.of("comment.comment_removed_success"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text("*"))) |                                 Template.of("value", String.valueOf(comments)) | ||||||
|                         ); |                         ); | ||||||
|                         plot.getPlotCommentContainer().removeComments(comments); |                         plot.getPlotCommentContainer().removeComments(comments); | ||||||
|                     } |                     } | ||||||
| @@ -299,13 +285,13 @@ public class Inbox extends SubCommand { | |||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         if (args.length == 1) { |         if (args.length == 1) { | ||||||
|             final List<String> completions = new LinkedList<>(); |             final List<String> completions = new LinkedList<>(); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_INBOX_READ_OWNER)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_INBOX_READ_OWNER)) { | ||||||
|                 completions.add("owner"); |                 completions.add("owner"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_INBOX_READ_PUBLIC)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_INBOX_READ_PUBLIC)) { | ||||||
|                 completions.add("public"); |                 completions.add("public"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_INBOX_READ_REPORT)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_INBOX_READ_REPORT)) { | ||||||
|                 completions.add("report"); |                 completions.add("report"); | ||||||
|             } |             } | ||||||
|             final List<Command> commands = completions.stream().filter(completion -> completion |             final List<Command> commands = completions.stream().filter(completion -> completion | ||||||
| @@ -313,7 +299,7 @@ public class Inbox extends SubCommand { | |||||||
|                             .startsWith(args[0].toLowerCase())) |                             .startsWith(args[0].toLowerCase())) | ||||||
|                     .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.CHAT) { |                     .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.CHAT) { | ||||||
|                     }).collect(Collectors.toCollection(LinkedList::new)); |                     }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_INBOX) && args[0].length() > 0) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_INBOX) && args[0].length() > 0) { | ||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             return commands; | ||||||
|   | |||||||
| @@ -27,10 +27,9 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.flag.implementations.HideInfoFlag; | import com.plotsquared.core.plot.flag.implementations.HideInfoFlag; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
|  |  | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| import java.util.Collections; | import java.util.Collections; | ||||||
| @@ -92,10 +91,7 @@ public class Info extends SubCommand { | |||||||
|                             .hasPermission(Permission.PERMISSION_AREA_INFO_FORCE.toString())) { |                             .hasPermission(Permission.PERMISSION_AREA_INFO_FORCE.toString())) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("node", Permission.PERMISSION_AREA_INFO_FORCE.toString()) | ||||||
|                                         "node", |  | ||||||
|                                         Tag.inserting(Permission.PERMISSION_AREA_INFO_FORCE) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         return true; |                         return true; | ||||||
|                     } |                     } | ||||||
| @@ -117,10 +113,7 @@ public class Info extends SubCommand { | |||||||
|         if (!hasOwner && !containsEveryone && !trustedEveryone) { |         if (!hasOwner && !containsEveryone && !trustedEveryone) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("info.plot_info_unclaimed"), |                     TranslatableCaption.of("info.plot_info_unclaimed"), | ||||||
|                     TagResolver.resolver( |                     Template.of("plot", plot.getId().getX() + ";" + plot.getId().getY()) | ||||||
|                             "plot", |  | ||||||
|                             Tag.inserting(Component.text(plot.getId().getX() + ";" + plot.getId().getY())) |  | ||||||
|                     ) |  | ||||||
|             ); |             ); | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
| @@ -151,7 +144,7 @@ public class Info extends SubCommand { | |||||||
|     @Override |     @Override | ||||||
|     public Collection<Command> tab(PlotPlayer<?> player, String[] args, boolean space) { |     public Collection<Command> tab(PlotPlayer<?> player, String[] args, boolean space) { | ||||||
|         final List<String> completions = new LinkedList<>(); |         final List<String> completions = new LinkedList<>(); | ||||||
|         if (player.hasPermission(Permission.PERMISSION_AREA_INFO_FORCE)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_AREA_INFO_FORCE)) { | ||||||
|             completions.add("-f"); |             completions.add("-f"); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -161,7 +154,7 @@ public class Info extends SubCommand { | |||||||
|                 .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.INFO) { |                 .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.INFO) { | ||||||
|                 }).collect(Collectors.toCollection(LinkedList::new)); |                 }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|  |  | ||||||
|         if (player.hasPermission(Permission.PERMISSION_AREA_INFO_FORCE) && args[0].length() > 0) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_AREA_INFO_FORCE) && args[0].length() > 0) { | ||||||
|             commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |             commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -27,12 +27,11 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.PlayerManager; | import com.plotsquared.core.util.PlayerManager; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.WorldUtil; | import com.plotsquared.core.util.WorldUtil; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| @@ -71,7 +70,8 @@ public class Kick extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if ((!plot.hasOwner() || !plot.isOwner(player.getUUID())) && !player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_KICK)) { |         if ((!plot.hasOwner() || !plot.isOwner(player.getUUID())) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_KICK)) { | ||||||
|             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -82,14 +82,15 @@ public class Kick extends SubCommand { | |||||||
|             } else if (throwable != null || uuids.isEmpty()) { |             } else if (throwable != null || uuids.isEmpty()) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("errors.invalid_player"), |                         TranslatableCaption.of("errors.invalid_player"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) |                         Template.of("value", args[0]) | ||||||
|                 ); |                 ); | ||||||
|             } else { |             } else { | ||||||
|                 Set<PlotPlayer<?>> players = new HashSet<>(); |                 Set<PlotPlayer<?>> players = new HashSet<>(); | ||||||
|                 for (UUID uuid : uuids) { |                 for (UUID uuid : uuids) { | ||||||
|                     if (uuid == DBFunc.EVERYONE) { |                     if (uuid == DBFunc.EVERYONE) { | ||||||
|                         for (PlotPlayer<?> pp : plot.getPlayersInPlot()) { |                         for (PlotPlayer<?> pp : plot.getPlayersInPlot()) { | ||||||
|                             if (pp == player || pp.hasPermission(Permission.PERMISSION_ADMIN_ENTRY_DENIED)) { |                             if (pp == player || Permissions | ||||||
|  |                                     .hasPermission(pp, Permission.PERMISSION_ADMIN_ENTRY_DENIED)) { | ||||||
|                                 continue; |                                 continue; | ||||||
|                             } |                             } | ||||||
|                             players.add(pp); |                             players.add(pp); | ||||||
| @@ -105,7 +106,7 @@ public class Kick extends SubCommand { | |||||||
|                 if (players.isEmpty()) { |                 if (players.isEmpty()) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("errors.invalid_player"), |                             TranslatableCaption.of("errors.invalid_player"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) |                             Template.of("value", args[0]) | ||||||
|                     ); |                     ); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
| @@ -113,14 +114,14 @@ public class Kick extends SubCommand { | |||||||
|                     if (!plot.equals(player2.getCurrentPlot())) { |                     if (!plot.equals(player2.getCurrentPlot())) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("errors.invalid_player"), |                                 TranslatableCaption.of("errors.invalid_player"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) |                                 Template.of("value", args[0]) | ||||||
|                         ); |                         ); | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                     if (player2.hasPermission(Permission.PERMISSION_ADMIN_ENTRY_DENIED)) { |                     if (Permissions.hasPermission(player2, Permission.PERMISSION_ADMIN_ENTRY_DENIED)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("cluster.cannot_kick_player"), |                                 TranslatableCaption.of("cluster.cannot_kick_player"), | ||||||
|                                 TagResolver.resolver("name", Tag.inserting(Component.text(player2.getName()))) |                                 Template.of("name", player2.getName()) | ||||||
|                         ); |                         ); | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|   | |||||||
| @@ -25,9 +25,7 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
| @@ -69,7 +67,7 @@ public class Leave extends Command { | |||||||
|                 } |                 } | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("member.plot_left"), |                         TranslatableCaption.of("member.plot_left"), | ||||||
|                         TagResolver.resolver("player", Tag.inserting(Component.text(player.getName()))) |                         Template.of("player", player.getName()) | ||||||
|                 ); |                 ); | ||||||
|             } else { |             } else { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|   | |||||||
| @@ -30,12 +30,11 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.Rating; | import com.plotsquared.core.plot.Rating; | ||||||
| import com.plotsquared.core.plot.flag.implementations.DoneFlag; | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.query.PlotQuery; | import com.plotsquared.core.util.query.PlotQuery; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| @@ -122,7 +121,8 @@ public class Like extends SubCommand { | |||||||
|                         player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |                         player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                     if (!player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_PURGE_RATINGS, true)) { |                     if (!Permissions | ||||||
|  |                             .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_PURGE_RATINGS, true)) { | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                     plot.clearRatings(); |                     plot.clearRatings(); | ||||||
| @@ -153,7 +153,7 @@ public class Like extends SubCommand { | |||||||
|             if (oldRating != null) { |             if (oldRating != null) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("ratings.rating_already_exists"), |                         TranslatableCaption.of("ratings.rating_already_exists"), | ||||||
|                         TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                         Template.of("plot", plot.getId().toString()) | ||||||
|                 ); |                 ); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| @@ -171,12 +171,12 @@ public class Like extends SubCommand { | |||||||
|                 if (like) { |                 if (like) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("ratings.rating_liked"), |                             TranslatableCaption.of("ratings.rating_liked"), | ||||||
|                             TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                             Template.of("plot", plot.getId().toString()) | ||||||
|                     ); |                     ); | ||||||
|                 } else { |                 } else { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("ratings.rating_disliked"), |                             TranslatableCaption.of("ratings.rating_disliked"), | ||||||
|                             TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                             Template.of("plot", plot.getId().toString()) | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -204,7 +204,7 @@ public class Like extends SubCommand { | |||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         if (args.length == 1) { |         if (args.length == 1) { | ||||||
|             final List<String> completions = new LinkedList<>(); |             final List<String> completions = new LinkedList<>(); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_PURGE_RATINGS)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_PURGE_RATINGS)) { | ||||||
|                 completions.add("purge"); |                 completions.add("purge"); | ||||||
|             } |             } | ||||||
|             final List<Command> commands = completions.stream().filter(completion -> completion |             final List<Command> commands = completions.stream().filter(completion -> completion | ||||||
| @@ -212,7 +212,7 @@ public class Like extends SubCommand { | |||||||
|                             .startsWith(args[0].toLowerCase())) |                             .startsWith(args[0].toLowerCase())) | ||||||
|                     .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.INFO) { |                     .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.INFO) { | ||||||
|                     }).collect(Collectors.toCollection(LinkedList::new)); |                     }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_RATE) && args[0].length() > 0) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_RATE) && args[0].length() > 0) { | ||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             return commands; | ||||||
|   | |||||||
| @@ -23,6 +23,7 @@ import com.plotsquared.core.PlotSquared; | |||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.Caption; | import com.plotsquared.core.configuration.caption.Caption; | ||||||
| import com.plotsquared.core.configuration.caption.CaptionHolder; | import com.plotsquared.core.configuration.caption.CaptionHolder; | ||||||
|  | import com.plotsquared.core.configuration.caption.Templates; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.database.DBFunc; | import com.plotsquared.core.database.DBFunc; | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| @@ -35,6 +36,7 @@ import com.plotsquared.core.plot.flag.implementations.ServerPlotFlag; | |||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.EconHandler; | import com.plotsquared.core.util.EconHandler; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.PlayerManager; | import com.plotsquared.core.util.PlayerManager; | ||||||
| import com.plotsquared.core.util.StringComparison; | import com.plotsquared.core.util.StringComparison; | ||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| @@ -45,8 +47,7 @@ import com.plotsquared.core.util.task.RunnableVal3; | |||||||
| import com.plotsquared.core.uuid.UUIDMapping; | import com.plotsquared.core.uuid.UUIDMapping; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.TextComponent; | import net.kyori.adventure.text.TextComponent; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| @@ -81,40 +82,40 @@ public class ListCmd extends SubCommand { | |||||||
|  |  | ||||||
|     private String[] getArgumentList(PlotPlayer<?> player) { |     private String[] getArgumentList(PlotPlayer<?> player) { | ||||||
|         List<String> args = new ArrayList<>(); |         List<String> args = new ArrayList<>(); | ||||||
|         if (this.econHandler != null && player.hasPermission(Permission.PERMISSION_LIST_FOR_SALE)) { |         if (this.econHandler != null && Permissions.hasPermission(player, Permission.PERMISSION_LIST_FOR_SALE)) { | ||||||
|             args.add("forsale"); |             args.add("forsale"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_MINE)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_MINE)) { | ||||||
|             args.add("mine"); |             args.add("mine"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_SHARED)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_SHARED)) { | ||||||
|             args.add("shared"); |             args.add("shared"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_WORLD)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_WORLD)) { | ||||||
|             args.add("world"); |             args.add("world"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_TOP)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_TOP)) { | ||||||
|             args.add("top"); |             args.add("top"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_ALL)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_ALL)) { | ||||||
|             args.add("all"); |             args.add("all"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_UNOWNED)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_UNOWNED)) { | ||||||
|             args.add("unowned"); |             args.add("unowned"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_PLAYER)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_PLAYER)) { | ||||||
|             args.add("<player>"); |             args.add("<player>"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_WORLD)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_WORLD)) { | ||||||
|             args.add("<world>"); |             args.add("<world>"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_DONE)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_DONE)) { | ||||||
|             args.add("done"); |             args.add("done"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_EXPIRED)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_EXPIRED)) { | ||||||
|             args.add("expired"); |             args.add("expired"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_FUZZY)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_FUZZY)) { | ||||||
|             args.add("fuzzy <search...>"); |             args.add("fuzzy <search...>"); | ||||||
|         } |         } | ||||||
|         return args.toArray(new String[args.size()]); |         return args.toArray(new String[args.size()]); | ||||||
| @@ -123,7 +124,7 @@ public class ListCmd extends SubCommand { | |||||||
|     public void noArgs(PlotPlayer<?> player) { |     public void noArgs(PlotPlayer<?> player) { | ||||||
|         player.sendMessage( |         player.sendMessage( | ||||||
|                 TranslatableCaption.of("commandconfig.subcommand_set_options_header"), |                 TranslatableCaption.of("commandconfig.subcommand_set_options_header"), | ||||||
|                 TagResolver.resolver("values", Tag.inserting(Component.text(Arrays.toString(getArgumentList(player))))) |                 Templates.of("values", Arrays.toString(getArgumentList(player))) | ||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -159,14 +160,9 @@ public class ListCmd extends SubCommand { | |||||||
|             if (query == null) { |             if (query == null) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("commandconfig.did_you_mean"), |                         TranslatableCaption.of("commandconfig.did_you_mean"), | ||||||
|                         TagResolver.resolver( |                         Template.of( | ||||||
|                                 "value", |                                 "value", | ||||||
|                                 Tag.inserting(Component.text( |                                 new StringComparison<>(args[0], new String[]{"mine", "shared", "world", "all"}).getBestMatch() | ||||||
|                                         new StringComparison<>( |  | ||||||
|                                                 args[0], |  | ||||||
|                                                 new String[]{"mine", "shared", "world", "all"} |  | ||||||
|                                         ).getBestMatch() |  | ||||||
|                                 )) |  | ||||||
|                         ) |                         ) | ||||||
|                 ); |                 ); | ||||||
|                 return; |                 return; | ||||||
| @@ -191,10 +187,10 @@ public class ListCmd extends SubCommand { | |||||||
|  |  | ||||||
|         switch (arg) { |         switch (arg) { | ||||||
|             case "mine" -> { |             case "mine" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_LIST_MINE)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_MINE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.mine"))) |                             Templates.of("node", "plots.list.mine") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -206,10 +202,10 @@ public class ListCmd extends SubCommand { | |||||||
|                         .withSortingStrategy(SortingStrategy.SORT_BY_TEMP)); |                         .withSortingStrategy(SortingStrategy.SORT_BY_TEMP)); | ||||||
|             } |             } | ||||||
|             case "shared" -> { |             case "shared" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_LIST_SHARED)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_SHARED)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.shared"))) |                             Templates.of("node", "plots.list.shared") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -219,27 +215,27 @@ public class ListCmd extends SubCommand { | |||||||
|                         .thatPasses(plot -> !plot.isOwnerAbs(player.getUUID()))); |                         .thatPasses(plot -> !plot.isOwnerAbs(player.getUUID()))); | ||||||
|             } |             } | ||||||
|             case "world" -> { |             case "world" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_LIST_WORLD)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_WORLD)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.world"))) |                             Templates.of("node", "plots.list.world") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (!player.hasPermission("plots.list.world." + world)) { |                 if (!Permissions.hasPermission(player, "plots.list.world." + world)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.world." + world))) |                             Templates.of("node", "plots.list.world." + world) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 plotConsumer.accept(PlotQuery.newQuery().inWorld(world)); |                 plotConsumer.accept(PlotQuery.newQuery().inWorld(world)); | ||||||
|             } |             } | ||||||
|             case "expired" -> { |             case "expired" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_LIST_EXPIRED)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_EXPIRED)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.expired"))) |                             Templates.of("node", "plots.list.expired") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -250,17 +246,17 @@ public class ListCmd extends SubCommand { | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             case "area" -> { |             case "area" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_LIST_AREA)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_AREA)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.area"))) |                             Templates.of("node", "plots.list.area") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (!player.hasPermission("plots.list.world." + world)) { |                 if (!Permissions.hasPermission(player, "plots.list.world." + world)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.world." + world))) |                             Templates.of("node", "plots.list.world." + world) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -271,20 +267,20 @@ public class ListCmd extends SubCommand { | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             case "all" -> { |             case "all" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_LIST_ALL)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_ALL)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.all"))) |                             Templates.of("node", "plots.list.all") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 plotConsumer.accept(PlotQuery.newQuery().allPlots()); |                 plotConsumer.accept(PlotQuery.newQuery().allPlots()); | ||||||
|             } |             } | ||||||
|             case "done" -> { |             case "done" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_LIST_DONE)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_DONE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.done"))) |                             Templates.of("node", "plots.list.done") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -296,10 +292,10 @@ public class ListCmd extends SubCommand { | |||||||
|                         .withSortingStrategy(SortingStrategy.SORT_BY_DONE)); |                         .withSortingStrategy(SortingStrategy.SORT_BY_DONE)); | ||||||
|             } |             } | ||||||
|             case "top" -> { |             case "top" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_LIST_TOP)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_TOP)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.top"))) |                             Templates.of("node", "plots.list.top") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -307,10 +303,10 @@ public class ListCmd extends SubCommand { | |||||||
|                 plotConsumer.accept(PlotQuery.newQuery().allPlots().withSortingStrategy(SortingStrategy.SORT_BY_RATING)); |                 plotConsumer.accept(PlotQuery.newQuery().allPlots().withSortingStrategy(SortingStrategy.SORT_BY_RATING)); | ||||||
|             } |             } | ||||||
|             case "forsale" -> { |             case "forsale" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_LIST_FOR_SALE)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_FOR_SALE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.forsale"))) |                             Templates.of("node", "plots.list.forsale") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -320,27 +316,27 @@ public class ListCmd extends SubCommand { | |||||||
|                 plotConsumer.accept(PlotQuery.newQuery().allPlots().thatPasses(plot -> plot.getFlag(PriceFlag.class) > 0)); |                 plotConsumer.accept(PlotQuery.newQuery().allPlots().thatPasses(plot -> plot.getFlag(PriceFlag.class) > 0)); | ||||||
|             } |             } | ||||||
|             case "unowned" -> { |             case "unowned" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_LIST_UNOWNED)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_UNOWNED)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.unowned"))) |                             Templates.of("node", "plots.list.unowned") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 plotConsumer.accept(PlotQuery.newQuery().allPlots().thatPasses(plot -> plot.getOwner() == null)); |                 plotConsumer.accept(PlotQuery.newQuery().allPlots().thatPasses(plot -> plot.getOwner() == null)); | ||||||
|             } |             } | ||||||
|             case "fuzzy" -> { |             case "fuzzy" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_LIST_FUZZY)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_FUZZY)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.fuzzy"))) |                             Templates.of("node", "plots.list.fuzzy") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (args.length < (page == -1 ? 2 : 3)) { |                 if (args.length < (page == -1 ? 2 : 3)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text("/plot list fuzzy <search...> [#]"))) |                             Templates.of("value", "/plot list fuzzy <search...> [#]") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -355,17 +351,17 @@ public class ListCmd extends SubCommand { | |||||||
|             } |             } | ||||||
|             default -> { |             default -> { | ||||||
|                 if (this.plotAreaManager.hasPlotArea(args[0])) { |                 if (this.plotAreaManager.hasPlotArea(args[0])) { | ||||||
|                     if (!player.hasPermission(Permission.PERMISSION_LIST_WORLD)) { |                     if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_WORLD)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.world"))) |                                 Templates.of("node", "plots.list.world") | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                     if (!player.hasPermission("plots.list.world." + args[0])) { |                     if (!Permissions.hasPermission(player, "plots.list.world." + args[0])) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.world." + args[0]))) |                                 Templates.of("node", "plots.list.world." + args[0]) | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -384,15 +380,12 @@ public class ListCmd extends SubCommand { | |||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|                     if (uuid == null) { |                     if (uuid == null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage(TranslatableCaption.of("errors.invalid_player"), Templates.of("value", args[0])); | ||||||
|                                 TranslatableCaption.of("errors.invalid_player"), |  | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) |  | ||||||
|                         ); |  | ||||||
|                     } else { |                     } else { | ||||||
|                         if (!player.hasPermission(Permission.PERMISSION_LIST_PLAYER)) { |                         if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_PLAYER)) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("permission.no_permission"), |                                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                                     TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.player"))) |                                     Templates.of("node", "plots.list.player") | ||||||
|                             ); |                             ); | ||||||
|                         } else { |                         } else { | ||||||
|                             sort[0] = false; |                             sort[0] = false; | ||||||
| @@ -428,34 +421,32 @@ public class ListCmd extends SubCommand { | |||||||
|                 } else { |                 } else { | ||||||
|                     color = TranslatableCaption.of("info.plot_list_default"); |                     color = TranslatableCaption.of("info.plot_list_default"); | ||||||
|                 } |                 } | ||||||
|                 Component trusted = MINI_MESSAGE.deserialize( |                 Component trusted = MINI_MESSAGE.parse( | ||||||
|                         TranslatableCaption.of("info.plot_info_trusted").getComponent(player), |                         TranslatableCaption.of("info.plot_info_trusted").getComponent(player), | ||||||
|                         TagResolver.resolver("trusted", Tag.inserting(PlayerManager.getPlayerList(plot.getTrusted(), player))) |                         Template.of("trusted", PlayerManager.getPlayerList(plot.getTrusted(), player)) | ||||||
|                 ); |                 ); | ||||||
|                 Component members = MINI_MESSAGE.deserialize( |                 Component members = MINI_MESSAGE.parse( | ||||||
|                         TranslatableCaption.of("info.plot_info_members").getComponent(player), |                         TranslatableCaption.of("info.plot_info_members").getComponent(player), | ||||||
|                         TagResolver.resolver("members", Tag.inserting(PlayerManager.getPlayerList(plot.getMembers(), player))) |                         Template.of("members", PlayerManager.getPlayerList(plot.getMembers(), player)) | ||||||
|                 ); |                 ); | ||||||
|                 TagResolver.Builder finalResolver = TagResolver.builder(); |                 Template command_tp = Template.of("command_tp", "/plot visit " + plot.getArea() + ";" + plot.getId()); | ||||||
|                 finalResolver.tag( |                 Template command_info = Template.of("command_info", "/plot info " + plot.getArea() + ";" + plot.getId()); | ||||||
|                         "command_tp", |                 Template hover_info = | ||||||
|                         Tag.preProcessParsed("/plot visit " + plot.getArea() + ";" + plot.getId()) |                         Template.of( | ||||||
|  |                                 "hover_info", | ||||||
|  |                                 MINI_MESSAGE.serialize(Component | ||||||
|  |                                         .text() | ||||||
|  |                                         .append(trusted) | ||||||
|  |                                         .append(Component.newline()) | ||||||
|  |                                         .append(members) | ||||||
|  |                                         .asComponent()) | ||||||
|  |                         ); | ||||||
|  |                 Template numberTemplate = Template.of("number", String.valueOf(i)); | ||||||
|  |                 Template plotTemplate = Template.of( | ||||||
|  |                         "plot", | ||||||
|  |                         MINI_MESSAGE.parse(color.getComponent(player), Template.of("plot", plot.toString())) | ||||||
|                 ); |                 ); | ||||||
|                 finalResolver.tag( |  | ||||||
|                         "command_info", |  | ||||||
|                         Tag.preProcessParsed("/plot info " + plot.getArea() + ";" + plot.getId()) |  | ||||||
|                 ); |  | ||||||
|                 finalResolver.tag("hover_info", Tag.inserting( |  | ||||||
|                         Component.text() |  | ||||||
|                                 .append(trusted) |  | ||||||
|                                 .append(Component.newline()) |  | ||||||
|                                 .append(members) |  | ||||||
|                                 .asComponent() |  | ||||||
|                 )); |  | ||||||
|                 finalResolver.tag("number", Tag.inserting(Component.text(i))); |  | ||||||
|                 finalResolver.tag("plot", Tag.inserting(MINI_MESSAGE.deserialize( |  | ||||||
|                         color.getComponent(player), TagResolver.resolver("plot", Tag.inserting(Component.text(plot.toString()))) |  | ||||||
|                 ))); |  | ||||||
|                 String prefix = ""; |                 String prefix = ""; | ||||||
|                 String online = TranslatableCaption.of("info.plot_list_player_online").getComponent(player); |                 String online = TranslatableCaption.of("info.plot_list_player_online").getComponent(player); | ||||||
|                 String offline = TranslatableCaption.of("info.plot_list_player_offline").getComponent(player); |                 String offline = TranslatableCaption.of("info.plot_list_player_offline").getComponent(player); | ||||||
| @@ -464,37 +455,35 @@ public class ListCmd extends SubCommand { | |||||||
|                 String everyone = TranslatableCaption.of("info.plot_list_player_everyone").getComponent(player); |                 String everyone = TranslatableCaption.of("info.plot_list_player_everyone").getComponent(player); | ||||||
|                 TextComponent.Builder builder = Component.text(); |                 TextComponent.Builder builder = Component.text(); | ||||||
|                 if (plot.getFlag(ServerPlotFlag.class)) { |                 if (plot.getFlag(ServerPlotFlag.class)) { | ||||||
|                     TagResolver serverResolver = TagResolver.resolver( |                     Template serverTemplate = Template.of( | ||||||
|                             "info.server", |                             "info.server", | ||||||
|                             Tag.inserting(TranslatableCaption.of("info.server").toComponent(player)) |                             TranslatableCaption.of("info.server").getComponent(player) | ||||||
|                     ); |                     ); | ||||||
|                     builder.append(MINI_MESSAGE.deserialize(server, serverResolver)); |                     builder.append(MINI_MESSAGE.parse(server, serverTemplate)); | ||||||
|                 } else { |                 } else { | ||||||
|                     try { |                     try { | ||||||
|                         final List<UUIDMapping> names = PlotSquared.get().getImpromptuUUIDPipeline().getNames(plot.getOwners()) |                         final List<UUIDMapping> names = PlotSquared.get().getImpromptuUUIDPipeline().getNames(plot.getOwners()) | ||||||
|                                 .get(Settings.UUID.BLOCKING_TIMEOUT, TimeUnit.MILLISECONDS); |                                 .get(Settings.UUID.BLOCKING_TIMEOUT, TimeUnit.MILLISECONDS); | ||||||
|                         for (final UUIDMapping uuidMapping : names) { |                         for (final UUIDMapping uuidMapping : names) { | ||||||
|                             PlotPlayer<?> pp = PlotSquared.platform().playerManager().getPlayerIfExists(uuidMapping.getUuid()); |                             PlotPlayer<?> pp = PlotSquared.platform().playerManager().getPlayerIfExists(uuidMapping.getUuid()); | ||||||
|                             TagResolver resolver = TagResolver.builder() |                             Template prefixTemplate = Template.of("prefix", prefix); | ||||||
|                                 .tag("prefix", Tag.inserting(Component.text(prefix))) |                             Template playerTemplate = Template.of("player", uuidMapping.getUsername()); | ||||||
|                                 .tag("player", Tag.inserting(Component.text(uuidMapping.getUsername()))) |                             if (pp != null) { | ||||||
|                                 .build(); |                                 builder.append(MINI_MESSAGE.parse(online, prefixTemplate, playerTemplate)); | ||||||
|                         if (pp != null) { |  | ||||||
|                             builder.append(MINI_MESSAGE.deserialize(online, resolver)); |  | ||||||
|                             } else if (uuidMapping.getUsername().equalsIgnoreCase("unknown")) { |                             } else if (uuidMapping.getUsername().equalsIgnoreCase("unknown")) { | ||||||
|                                 TagResolver unknownResolver = TagResolver.resolver( |                                 Template unknownTemplate = Template.of( | ||||||
|                                         "info.unknown", |                                         "info.unknown", | ||||||
|                                         Tag.inserting(TranslatableCaption.of("info.unknown").toComponent(player)) |                                         TranslatableCaption.of("info.unknown").getComponent(player) | ||||||
|                                 ); |                                 ); | ||||||
|                                 builder.append(MINI_MESSAGE.deserialize(unknown, unknownResolver)); |                                 builder.append(MINI_MESSAGE.parse(unknown, unknownTemplate)); | ||||||
|                             } else if (uuidMapping.getUuid().equals(DBFunc.EVERYONE)) { |                             } else if (uuidMapping.getUuid().equals(DBFunc.EVERYONE)) { | ||||||
|                                 TagResolver everyoneResolver = TagResolver.resolver( |                                 Template everyoneTemplate = Template.of( | ||||||
|                                         "info.everyone", |                                         "info.everyone", | ||||||
|                                         Tag.inserting(TranslatableCaption.of("info.everyone").toComponent(player)) |                                         TranslatableCaption.of("info.everyone").getComponent(player) | ||||||
|                                 ); |                                 ); | ||||||
|                                 builder.append(MINI_MESSAGE.deserialize(everyone, everyoneResolver)); |                                 builder.append(MINI_MESSAGE.parse(everyone, everyoneTemplate)); | ||||||
|                             } else { |                             } else { | ||||||
|                                 builder.append(MINI_MESSAGE.deserialize(offline, resolver)); |                                 builder.append(MINI_MESSAGE.parse(offline, prefixTemplate, playerTemplate)); | ||||||
|                             } |                             } | ||||||
|                             prefix = ", "; |                             prefix = ", "; | ||||||
|                         } |                         } | ||||||
| @@ -510,15 +499,15 @@ public class ListCmd extends SubCommand { | |||||||
|                         } |                         } | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("errors.invalid_player"), |                                 TranslatableCaption.of("errors.invalid_player"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(playerBuilder.toString()))) |                                 Templates.of("value", playerBuilder.toString()) | ||||||
|                         ); |                         ); | ||||||
|                     } catch (TimeoutException e) { |                     } catch (TimeoutException e) { | ||||||
|                         player.sendMessage(TranslatableCaption.of("players.fetching_players_timeout")); |                         player.sendMessage(TranslatableCaption.of("players.fetching_players_timeout")); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 finalResolver.tag("players", Tag.inserting(builder.asComponent())); |                 Template players = Template.of("players", builder.asComponent()); | ||||||
|                 caption.set(TranslatableCaption.of("info.plot_list_item")); |                 caption.set(TranslatableCaption.of("info.plot_list_item")); | ||||||
|                 caption.setTagResolvers(finalResolver.build()); |                 caption.setTemplates(command_tp, command_info, hover_info, numberTemplate, plotTemplate, players); | ||||||
|             } |             } | ||||||
|         }, "/plot list " + args[0], TranslatableCaption.of("list.plot_list_header_paged")); |         }, "/plot list " + args[0], TranslatableCaption.of("list.plot_list_header_paged")); | ||||||
|     } |     } | ||||||
| @@ -526,31 +515,31 @@ public class ListCmd extends SubCommand { | |||||||
|     @Override |     @Override | ||||||
|     public Collection<Command> tab(PlotPlayer<?> player, String[] args, boolean space) { |     public Collection<Command> tab(PlotPlayer<?> player, String[] args, boolean space) { | ||||||
|         final List<String> completions = new LinkedList<>(); |         final List<String> completions = new LinkedList<>(); | ||||||
|         if (this.econHandler.isSupported() && player.hasPermission(Permission.PERMISSION_LIST_FOR_SALE)) { |         if (this.econHandler.isSupported() && Permissions.hasPermission(player, Permission.PERMISSION_LIST_FOR_SALE)) { | ||||||
|             completions.add("forsale"); |             completions.add("forsale"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_MINE)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_MINE)) { | ||||||
|             completions.add("mine"); |             completions.add("mine"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_SHARED)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_SHARED)) { | ||||||
|             completions.add("shared"); |             completions.add("shared"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_WORLD)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_WORLD)) { | ||||||
|             completions.addAll(PlotSquared.platform().worldManager().getWorlds()); |             completions.addAll(PlotSquared.platform().worldManager().getWorlds()); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_TOP)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_TOP)) { | ||||||
|             completions.add("top"); |             completions.add("top"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_ALL)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_ALL)) { | ||||||
|             completions.add("all"); |             completions.add("all"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_UNOWNED)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_UNOWNED)) { | ||||||
|             completions.add("unowned"); |             completions.add("unowned"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_DONE)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_DONE)) { | ||||||
|             completions.add("done"); |             completions.add("done"); | ||||||
|         } |         } | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_EXPIRED)) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_EXPIRED)) { | ||||||
|             completions.add("expired"); |             completions.add("expired"); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -560,7 +549,7 @@ public class ListCmd extends SubCommand { | |||||||
|                 .map(completion -> new Command(null, true, completion, "", RequiredType.NONE, CommandCategory.TELEPORT) { |                 .map(completion -> new Command(null, true, completion, "", RequiredType.NONE, CommandCategory.TELEPORT) { | ||||||
|                 }).collect(Collectors.toCollection(LinkedList::new)); |                 }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|  |  | ||||||
|         if (player.hasPermission(Permission.PERMISSION_LIST_PLAYER) && args[0].length() > 0) { |         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_PLAYER) && args[0].length() > 0) { | ||||||
|             commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |             commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -31,13 +31,12 @@ import com.plotsquared.core.plot.PlotArea; | |||||||
| import com.plotsquared.core.plot.PlotId; | import com.plotsquared.core.plot.PlotId; | ||||||
| import com.plotsquared.core.plot.schematic.Schematic; | import com.plotsquared.core.plot.schematic.Schematic; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.SchematicHandler; | import com.plotsquared.core.util.SchematicHandler; | ||||||
| import com.plotsquared.core.util.TimeUtil; | import com.plotsquared.core.util.TimeUtil; | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.net.MalformedURLException; | import java.net.MalformedURLException; | ||||||
| @@ -81,7 +80,8 @@ public class Load extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("info.plot_unowned")); |             player.sendMessage(TranslatableCaption.of("info.plot_unowned")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_LOAD)) { |         if (!plot.isOwner(player.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_LOAD)) { | ||||||
|             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -99,7 +99,7 @@ public class Load extends SubCommand { | |||||||
|                         // No schematics found: |                         // No schematics found: | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("web.load_null"), |                                 TranslatableCaption.of("web.load_null"), | ||||||
|                                 TagResolver.resolver("command", Tag.inserting(Component.text("/plot load"))) |                                 Template.of("command", "/plot load") | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -110,7 +110,7 @@ public class Load extends SubCommand { | |||||||
|                         // use /plot load <index> |                         // use /plot load <index> | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("invalid.not_valid_number"), |                                 TranslatableCaption.of("invalid.not_valid_number"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text("(1, " + schematics.size() + ')'))) |                                 Template.of("value", "(1, " + schematics.size() + ')') | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -130,10 +130,7 @@ public class Load extends SubCommand { | |||||||
|                             plot.removeRunning(); |                             plot.removeRunning(); | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("schematics.schematic_invalid"), |                                     TranslatableCaption.of("schematics.schematic_invalid"), | ||||||
|                                     TagResolver.resolver( |                                     Template.of("reason", "non-existent or not in gzip format") | ||||||
|                                             "reason", |  | ||||||
|                                             Tag.inserting(Component.text("non-existent or not in gzip format")) |  | ||||||
|                                     ) |  | ||||||
|                             ); |                             ); | ||||||
|                             return; |                             return; | ||||||
|                         } |                         } | ||||||
| @@ -164,7 +161,7 @@ public class Load extends SubCommand { | |||||||
|                 plot.removeRunning(); |                 plot.removeRunning(); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("commandconfig.command_syntax"), |                         TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text("/plot load <index>"))) |                         Template.of("value", "/plot load <index>") | ||||||
|                 ); |                 ); | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
| @@ -215,9 +212,46 @@ public class Load extends SubCommand { | |||||||
|             } |             } | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("web.load_list"), |                     TranslatableCaption.of("web.load_list"), | ||||||
|                     TagResolver.resolver("command", Tag.inserting(Component.text("/plot load #"))) |                     Template.of("command", "/plot load #") | ||||||
|             ); |             ); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @deprecated Use {@link TimeUtil#secToTime(long)} | ||||||
|  |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "6.6.2") | ||||||
|  |     public String secToTime(long time) { | ||||||
|  |         StringBuilder toreturn = new StringBuilder(); | ||||||
|  |         if (time >= 33868800) { | ||||||
|  |             int years = (int) (time / 33868800); | ||||||
|  |             time -= years * 33868800; | ||||||
|  |             toreturn.append(years).append("y "); | ||||||
|  |         } | ||||||
|  |         if (time >= 604800) { | ||||||
|  |             int weeks = (int) (time / 604800); | ||||||
|  |             time -= weeks * 604800; | ||||||
|  |             toreturn.append(weeks).append("w "); | ||||||
|  |         } | ||||||
|  |         if (time >= 86400) { | ||||||
|  |             int days = (int) (time / 86400); | ||||||
|  |             time -= days * 86400; | ||||||
|  |             toreturn.append(days).append("d "); | ||||||
|  |         } | ||||||
|  |         if (time >= 3600) { | ||||||
|  |             int hours = (int) (time / 3600); | ||||||
|  |             time -= hours * 3600; | ||||||
|  |             toreturn.append(hours).append("h "); | ||||||
|  |         } | ||||||
|  |         if (time >= 60) { | ||||||
|  |             int minutes = (int) (time / 60); | ||||||
|  |             time -= minutes * 60; | ||||||
|  |             toreturn.append(minutes).append("m "); | ||||||
|  |         } | ||||||
|  |         if (toreturn.length() == 0 || (time > 0)) { | ||||||
|  |             toreturn.append(time).append("s "); | ||||||
|  |         } | ||||||
|  |         return toreturn.toString().trim(); | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -32,12 +32,10 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.world.SinglePlotArea; | import com.plotsquared.core.plot.world.SinglePlotArea; | ||||||
| import com.plotsquared.core.util.EconHandler; | import com.plotsquared.core.util.EconHandler; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.PlotExpression; | import com.plotsquared.core.util.PlotExpression; | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import net.kyori.adventure.text.Component; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.apache.logging.log4j.LogManager; | import org.apache.logging.log4j.LogManager; | ||||||
| import org.apache.logging.log4j.Logger; | import org.apache.logging.log4j.Logger; | ||||||
|  |  | ||||||
| @@ -74,6 +72,7 @@ public class MainCommand extends Command { | |||||||
|             commands.add(Buy.class); |             commands.add(Buy.class); | ||||||
|             if (Settings.Web.LEGACY_WEBINTERFACE) { |             if (Settings.Web.LEGACY_WEBINTERFACE) { | ||||||
|                 LOGGER.warn("Legacy webinterface is used. Please note that it will be removed in future."); |                 LOGGER.warn("Legacy webinterface is used. Please note that it will be removed in future."); | ||||||
|  |                 commands.add(Save.class); | ||||||
|             } |             } | ||||||
|             commands.add(Load.class); |             commands.add(Load.class); | ||||||
|             commands.add(Confirm.class); |             commands.add(Confirm.class); | ||||||
| @@ -122,6 +121,7 @@ public class MainCommand extends Command { | |||||||
|             commands.add(Move.class); |             commands.add(Move.class); | ||||||
|             commands.add(Condense.class); |             commands.add(Condense.class); | ||||||
|             commands.add(Copy.class); |             commands.add(Copy.class); | ||||||
|  |             commands.add(Chat.class); | ||||||
|             commands.add(Trim.class); |             commands.add(Trim.class); | ||||||
|             commands.add(Done.class); |             commands.add(Done.class); | ||||||
|             commands.add(Continue.class); |             commands.add(Continue.class); | ||||||
| @@ -244,8 +244,8 @@ public class MainCommand extends Command { | |||||||
|             PlotArea area = player.getApplicablePlotArea(); |             PlotArea area = player.getApplicablePlotArea(); | ||||||
|             Plot newPlot = Plot.fromString(area, args[0]); |             Plot newPlot = Plot.fromString(area, args[0]); | ||||||
|             if (newPlot != null && (player instanceof ConsolePlayer || newPlot.getArea() |             if (newPlot != null && (player instanceof ConsolePlayer || newPlot.getArea() | ||||||
|                     .equals(area) || player.hasPermission(Permission.PERMISSION_ADMIN) |                     .equals(area) || Permissions.hasPermission(player, Permission.PERMISSION_ADMIN) | ||||||
|                     || player.hasPermission(Permission.PERMISSION_ADMIN_AREA_SUDO)) |                     || Permissions.hasPermission(player, Permission.PERMISSION_ADMIN_AREA_SUDO)) | ||||||
|                     && !newPlot.isDenied(player.getUUID())) { |                     && !newPlot.isDenied(player.getUUID())) { | ||||||
|                 final Location newLoc; |                 final Location newLoc; | ||||||
|                 if (newPlot.getArea() instanceof SinglePlotArea) { |                 if (newPlot.getArea() instanceof SinglePlotArea) { | ||||||
| @@ -311,7 +311,7 @@ public class MainCommand extends Command { | |||||||
|             if (message != null) { |             if (message != null) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("errors.error"), |                         TranslatableCaption.of("errors.error"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text(message))) |                         net.kyori.adventure.text.minimessage.Template.of("value", message) | ||||||
|                 ); |                 ); | ||||||
|             } else { |             } else { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|   | |||||||
| @@ -32,11 +32,10 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.util.EconHandler; | import com.plotsquared.core.util.EconHandler; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.PlotExpression; | import com.plotsquared.core.util.PlotExpression; | ||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
| @@ -116,24 +115,22 @@ public class Merge extends SubCommand { | |||||||
|         if (direction == null) { |         if (direction == null) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text( |                     Template.of("value", "/plot merge <" + StringMan.join(values, " | ") + "> [removeroads]") | ||||||
|                             "/plot merge <" + StringMan.join(values, " | ") + "> [removeroads]" |  | ||||||
|                     ))) |  | ||||||
|             ); |             ); | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("help.direction"), |                     TranslatableCaption.of("help.direction"), | ||||||
|                     TagResolver.resolver("dir", Tag.inserting(Component.text(direction(location.getYaw())))) |                     Template.of("dir", direction(location.getYaw())) | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         final int size = plot.getConnectedPlots().size(); |         final int size = plot.getConnectedPlots().size(); | ||||||
|         int max = player.hasPermissionRange("plots.merge", Settings.Limit.MAX_PLOTS); |         int max = Permissions.hasPermissionRange(player, "plots.merge", Settings.Limit.MAX_PLOTS); | ||||||
|         PlotMergeEvent event = |         PlotMergeEvent event = | ||||||
|                 this.eventDispatcher.callMerge(plot, direction, max, player); |                 this.eventDispatcher.callMerge(plot, direction, max, player); | ||||||
|         if (event.getEventResult() == Result.DENY) { |         if (event.getEventResult() == Result.DENY) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("events.event_denied"), |                     TranslatableCaption.of("events.event_denied"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("Merge"))) |                     Template.of("value", "Merge") | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -144,7 +141,7 @@ public class Merge extends SubCommand { | |||||||
|         if (!force && size - 1 > maxSize) { |         if (!force && size - 1 > maxSize) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver("node", Tag.inserting(Component.text(Permission.PERMISSION_MERGE + "." + (size + 1)))) |                     Template.of("node", Permission.PERMISSION_MERGE + "." + (size + 1)) | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -155,7 +152,7 @@ public class Merge extends SubCommand { | |||||||
|         UUID uuid = player.getUUID(); |         UUID uuid = player.getUUID(); | ||||||
|  |  | ||||||
|         if (!force && !plot.isOwner(uuid)) { |         if (!force && !plot.isOwner(uuid)) { | ||||||
|             if (!player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_MERGE)) { |             if (!Permissions.hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_MERGE)) { | ||||||
|                 player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |                 player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|                 return false; |                 return false; | ||||||
|             } else { |             } else { | ||||||
| @@ -167,13 +164,11 @@ public class Merge extends SubCommand { | |||||||
|             if (args.length == 2) { |             if (args.length == 2) { | ||||||
|                 terrain = "true".equalsIgnoreCase(args[1]); |                 terrain = "true".equalsIgnoreCase(args[1]); | ||||||
|             } |             } | ||||||
|             if (!force && !terrain && !player.hasPermission(Permission.PERMISSION_MERGE_KEEP_ROAD)) { |             if (!force && !terrain && !Permissions | ||||||
|  |                     .hasPermission(player, Permission.PERMISSION_MERGE_KEEP_ROAD)) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission"), |                         TranslatableCaption.of("permission.no_permission"), | ||||||
|                         TagResolver.resolver( |                         Template.of("node", String.valueOf(Permission.PERMISSION_MERGE_KEEP_ROAD)) | ||||||
|                                 "node", |  | ||||||
|                                 Tag.inserting(Permission.PERMISSION_MERGE_KEEP_ROAD) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
| @@ -182,11 +177,8 @@ public class Merge extends SubCommand { | |||||||
|                     this.econHandler.withdrawMoney(player, price); |                     this.econHandler.withdrawMoney(player, price); | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("economy.removed_balance"), |                             TranslatableCaption.of("economy.removed_balance"), | ||||||
|                             TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(price)))), |                             Template.of("money", this.econHandler.format(price)), | ||||||
|                             TagResolver.resolver( |                             Template.of("balance", this.econHandler.format(this.econHandler.getMoney(player))) | ||||||
|                                     "balance", |  | ||||||
|                                     Tag.inserting(Component.text(this.econHandler.format(this.econHandler.getMoney(player)))) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|                 player.sendMessage(TranslatableCaption.of("merge.success_merge")); |                 player.sendMessage(TranslatableCaption.of("merge.success_merge")); | ||||||
| @@ -200,7 +192,7 @@ public class Merge extends SubCommand { | |||||||
|                 && this.econHandler.getMoney(player) < price) { |                 && this.econHandler.getMoney(player) < price) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("economy.cannot_afford_merge"), |                     TranslatableCaption.of("economy.cannot_afford_merge"), | ||||||
|                     TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(price)))) |                     Template.of("money", this.econHandler.format(price)) | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -210,10 +202,11 @@ public class Merge extends SubCommand { | |||||||
|         } else { |         } else { | ||||||
|             terrain = true; |             terrain = true; | ||||||
|         } |         } | ||||||
|         if (!force && !terrain && !player.hasPermission(Permission.PERMISSION_MERGE_KEEP_ROAD)) { |         if (!force && !terrain && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_MERGE_KEEP_ROAD)) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_MERGE_KEEP_ROAD)) |                     Template.of("node", String.valueOf(Permission.PERMISSION_MERGE_KEEP_ROAD)) | ||||||
|             ); |             ); | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
| @@ -222,7 +215,7 @@ public class Merge extends SubCommand { | |||||||
|                 this.econHandler.withdrawMoney(player, price); |                 this.econHandler.withdrawMoney(player, price); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("economy.removed_balance"), |                         TranslatableCaption.of("economy.removed_balance"), | ||||||
|                         TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(price)))) |                         Template.of("money", this.econHandler.format(price)) | ||||||
|                 ); |                 ); | ||||||
|             } |             } | ||||||
|             player.sendMessage(TranslatableCaption.of("merge.success_merge")); |             player.sendMessage(TranslatableCaption.of("merge.success_merge")); | ||||||
| @@ -235,10 +228,10 @@ public class Merge extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("merge.no_available_automerge")); |             player.sendMessage(TranslatableCaption.of("merge.no_available_automerge")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!force && !player.hasPermission(Permission.PERMISSION_MERGE_OTHER)) { |         if (!force && !Permissions.hasPermission(player, Permission.PERMISSION_MERGE_OTHER)) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_MERGE_OTHER)) |                     Template.of("node", String.valueOf(Permission.PERMISSION_MERGE_OTHER)) | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -263,14 +256,14 @@ public class Merge extends SubCommand { | |||||||
|                     if (!force && this.econHandler.getMoney(player) < price) { |                     if (!force && this.econHandler.getMoney(player) < price) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("economy.cannot_afford_merge"), |                                 TranslatableCaption.of("economy.cannot_afford_merge"), | ||||||
|                                 TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(price)))) |                                 Template.of("money", this.econHandler.format(price)) | ||||||
|                         ); |                         ); | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                     this.econHandler.withdrawMoney(player, price); |                     this.econHandler.withdrawMoney(player, price); | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("economy.removed_balance"), |                             TranslatableCaption.of("economy.removed_balance"), | ||||||
|                             TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(price)))) |                             Template.of("money", this.econHandler.format(price)) | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|                 player.sendMessage(TranslatableCaption.of("merge.success_merge")); |                 player.sendMessage(TranslatableCaption.of("merge.success_merge")); | ||||||
| @@ -278,15 +271,10 @@ public class Merge extends SubCommand { | |||||||
|             }; |             }; | ||||||
|             if (!force && hasConfirmation(player)) { |             if (!force && hasConfirmation(player)) { | ||||||
|                 CmdConfirm.addPending(accepter, MINI_MESSAGE.serialize(MINI_MESSAGE |                 CmdConfirm.addPending(accepter, MINI_MESSAGE.serialize(MINI_MESSAGE | ||||||
|                                 .deserialize( |                                 .parse( | ||||||
|                                         TranslatableCaption.of("merge.merge_request_confirm").getComponent(player), |                                         TranslatableCaption.of("merge.merge_request_confirm").getComponent(player), | ||||||
|                                         TagResolver.builder() |                                         Template.of("player", player.getName()), | ||||||
|                                                 .tag("player", Tag.inserting(Component.text(player.getName()))) |                                         Template.of("location", plot.getWorldName() + ";" + plot.getId()) | ||||||
|                                                 .tag( |  | ||||||
|                                                         "location", |  | ||||||
|                                                         Tag.inserting(Component.text(plot.getWorldName() + " " + plot.getId())) |  | ||||||
|                                                 ) |  | ||||||
|                                                 .build() |  | ||||||
|                                 )), |                                 )), | ||||||
|                         run |                         run | ||||||
|                 ); |                 ); | ||||||
| @@ -295,26 +283,20 @@ public class Merge extends SubCommand { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         if (force || !isOnline) { |         if (force || !isOnline) { | ||||||
|             if (force || player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_MERGE_OTHER_OFFLINE)) { |             if (force || Permissions.hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_MERGE_OTHER_OFFLINE)) { | ||||||
|                 if (plot.getPlotModificationManager().autoMerge( |                 if (plot.getPlotModificationManager().autoMerge(direction, maxSize - size, uuids.iterator().next(), player, terrain)) { | ||||||
|                         direction, |  | ||||||
|                         maxSize - size, |  | ||||||
|                         uuids.iterator().next(), |  | ||||||
|                         player, |  | ||||||
|                         terrain |  | ||||||
|                 )) { |  | ||||||
|                     if (this.econHandler.isEnabled(plotArea) && price > 0d) { |                     if (this.econHandler.isEnabled(plotArea) && price > 0d) { | ||||||
|                         if (!force && this.econHandler.getMoney(player) < price) { |                         if (!force && this.econHandler.getMoney(player) < price) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("economy.cannot_afford_merge"), |                                     TranslatableCaption.of("economy.cannot_afford_merge"), | ||||||
|                                     TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(price)))) |                                     Template.of("money", this.econHandler.format(price)) | ||||||
|                             ); |                             ); | ||||||
|                             return false; |                             return false; | ||||||
|                         } |                         } | ||||||
|                         this.econHandler.withdrawMoney(player, price); |                         this.econHandler.withdrawMoney(player, price); | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("economy.removed_balance"), |                                 TranslatableCaption.of("economy.removed_balance"), | ||||||
|                                 TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(price)))) |                                 Template.of("money", this.econHandler.format(price)) | ||||||
|                         ); |                         ); | ||||||
|                     } |                     } | ||||||
|                     player.sendMessage(TranslatableCaption.of("merge.success_merge")); |                     player.sendMessage(TranslatableCaption.of("merge.success_merge")); | ||||||
|   | |||||||
| @@ -26,11 +26,10 @@ import com.plotsquared.core.player.PlotPlayer; | |||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.concurrent.CompletableFuture; | import java.util.concurrent.CompletableFuture; | ||||||
| @@ -61,7 +60,8 @@ public class Move extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return CompletableFuture.completedFuture(false); |             return CompletableFuture.completedFuture(false); | ||||||
|         } |         } | ||||||
|         if (!plot1.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN)) { |         if (!plot1.isOwner(player.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN)) { | ||||||
|             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|             return CompletableFuture.completedFuture(false); |             return CompletableFuture.completedFuture(false); | ||||||
|         } |         } | ||||||
| @@ -88,7 +88,8 @@ public class Move extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("invalid.origin_cant_be_target")); |             player.sendMessage(TranslatableCaption.of("invalid.origin_cant_be_target")); | ||||||
|             return CompletableFuture.completedFuture(false); |             return CompletableFuture.completedFuture(false); | ||||||
|         } |         } | ||||||
|         if (!plot1.getArea().isCompatible(plot2.getArea()) && (!override || !player.hasPermission(Permission.PERMISSION_ADMIN))) { |         if (!plot1.getArea().isCompatible(plot2.getArea()) && (!override || !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN))) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.plotworld_incompatible")); |             player.sendMessage(TranslatableCaption.of("errors.plotworld_incompatible")); | ||||||
|             return CompletableFuture.completedFuture(false); |             return CompletableFuture.completedFuture(false); | ||||||
|         } |         } | ||||||
| @@ -106,10 +107,8 @@ public class Move extends SubCommand { | |||||||
|             if (result) { |             if (result) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("move.move_success"), |                         TranslatableCaption.of("move.move_success"), | ||||||
|                         TagResolver.builder() |                         Template.of("origin", p1), | ||||||
|                                 .tag("origin", Tag.inserting(Component.text(p1))) |                         Template.of("target", p2) | ||||||
|                                 .tag("target", Tag.inserting(Component.text(p2))) |  | ||||||
|                                 .build() |  | ||||||
|                 ); |                 ); | ||||||
|                 return true; |                 return true; | ||||||
|             } else { |             } else { | ||||||
|   | |||||||
| @@ -33,11 +33,10 @@ import com.plotsquared.core.plot.flag.PlotFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.MusicFlag; | import com.plotsquared.core.plot.flag.implementations.MusicFlag; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.InventoryUtil; | import com.plotsquared.core.util.InventoryUtil; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.sk89q.worldedit.world.item.ItemType; | import com.sk89q.worldedit.world.item.ItemType; | ||||||
| import com.sk89q.worldedit.world.item.ItemTypes; | import com.sk89q.worldedit.world.item.ItemTypes; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import javax.annotation.Nullable; | import javax.annotation.Nullable; | ||||||
| @@ -80,13 +79,11 @@ public class Music extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("info.plot_unowned")); |             player.sendMessage(TranslatableCaption.of("info.plot_unowned")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!plot.isAdded(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_MUSIC_OTHER)) { |         if (!plot.isAdded(player.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN_MUSIC_OTHER)) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver( |                     Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_MUSIC_OTHER)) | ||||||
|                             "node", |  | ||||||
|                             Tag.inserting(Permission.PERMISSION_ADMIN_MUSIC_OTHER) |  | ||||||
|                     ) |  | ||||||
|             ); |             ); | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
| @@ -109,17 +106,15 @@ public class Music extends SubCommand { | |||||||
|                     if (event.getEventResult() == Result.DENY) { |                     if (event.getEventResult() == Result.DENY) { | ||||||
|                         getPlayer().sendMessage( |                         getPlayer().sendMessage( | ||||||
|                                 TranslatableCaption.of("events.event_denied"), |                                 TranslatableCaption.of("events.event_denied"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text("Music removal"))) |                                 Template.of("value", "Music removal") | ||||||
|                         ); |                         ); | ||||||
|                         return true; |                         return true; | ||||||
|                     } |                     } | ||||||
|                     plot.removeFlag(event.getFlag()); |                     plot.removeFlag(event.getFlag()); | ||||||
|                     getPlayer().sendMessage( |                     getPlayer().sendMessage( | ||||||
|                             TranslatableCaption.of("flag.flag_removed"), |                             TranslatableCaption.of("flag.flag_removed"), | ||||||
|                             TagResolver.builder() |                             Template.of("flag", "music"), | ||||||
|                                     .tag("flag", Tag.inserting(Component.text("music"))) |                             Template.of("value", "music_disc") | ||||||
|                                     .tag("value", Tag.inserting(Component.text("music_disc"))) |  | ||||||
|                                     .build() |  | ||||||
|                     ); |                     ); | ||||||
|                 } else if (item.getName().toLowerCase(Locale.ENGLISH).contains("disc")) { |                 } else if (item.getName().toLowerCase(Locale.ENGLISH).contains("disc")) { | ||||||
|                     PlotFlag<?, ?> plotFlag = plot.getFlagContainer().getFlag(MusicFlag.class) |                     PlotFlag<?, ?> plotFlag = plot.getFlagContainer().getFlag(MusicFlag.class) | ||||||
| @@ -128,17 +123,13 @@ public class Music extends SubCommand { | |||||||
|                     if (event.getEventResult() == Result.DENY) { |                     if (event.getEventResult() == Result.DENY) { | ||||||
|                         getPlayer().sendMessage( |                         getPlayer().sendMessage( | ||||||
|                                 TranslatableCaption.of("events.event_denied"), |                                 TranslatableCaption.of("events.event_denied"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text("Music addition"))) |                                 Template.of("value", "Music addition") | ||||||
|                         ); |                         ); | ||||||
|                         return true; |                         return true; | ||||||
|                     } |                     } | ||||||
|                     plot.setFlag(event.getFlag()); |                     plot.setFlag(event.getFlag()); | ||||||
|                     getPlayer().sendMessage( |                     getPlayer().sendMessage(TranslatableCaption.of("flag.flag_added"), Template.of("flag", "music"), | ||||||
|                             TranslatableCaption.of("flag.flag_added"), |                             Template.of("value", String.valueOf(event.getFlag().getValue())) | ||||||
|                             TagResolver.builder() |  | ||||||
|                                     .tag("flag", Tag.inserting(Component.text("music"))) |  | ||||||
|                                     .tag("value", Tag.inserting(Component.text(event.getFlag().getValue().toString()))) |  | ||||||
|                                     .build() |  | ||||||
|                     ); |                     ); | ||||||
|                 } else { |                 } else { | ||||||
|                     getPlayer().sendMessage(TranslatableCaption.of("flag.flag_not_added")); |                     getPlayer().sendMessage(TranslatableCaption.of("flag.flag_not_added")); | ||||||
|   | |||||||
| @@ -24,9 +24,7 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
|  |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.concurrent.CompletableFuture; | import java.util.concurrent.CompletableFuture; | ||||||
| @@ -51,7 +49,7 @@ public class Near extends Command { | |||||||
|         final Plot plot = check(player.getCurrentPlot(), TranslatableCaption.of("errors.not_in_plot")); |         final Plot plot = check(player.getCurrentPlot(), TranslatableCaption.of("errors.not_in_plot")); | ||||||
|         player.sendMessage( |         player.sendMessage( | ||||||
|                 TranslatableCaption.of("near.plot_near"), |                 TranslatableCaption.of("near.plot_near"), | ||||||
|                 TagResolver.resolver("list", Tag.inserting(Component.text(StringMan.join(plot.getPlayersInPlot(), ", ")))) |                 Template.of("list", StringMan.join(getPlayersInPlotVisible(plot, player), ", ")) | ||||||
|         ); |         ); | ||||||
|         return CompletableFuture.completedFuture(true); |         return CompletableFuture.completedFuture(true); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -31,12 +31,11 @@ import com.plotsquared.core.player.PlayerMetaDataKeys; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.PlayerManager; | import com.plotsquared.core.util.PlayerManager; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
| @@ -67,7 +66,7 @@ public class Owner extends SetCommand { | |||||||
|         if (value == null || value.isEmpty()) { |         if (value == null || value.isEmpty()) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("/plot setowner <owner>"))) |                     Template.of("value", "/plot setowner <owner>") | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -79,7 +78,7 @@ public class Owner extends SetCommand { | |||||||
|                     && !value.equalsIgnoreCase("-")) { |                     && !value.equalsIgnoreCase("-")) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("errors.invalid_player"), |                         TranslatableCaption.of("errors.invalid_player"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text(value))) |                         Template.of("value", value) | ||||||
|                 ); |                 ); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| @@ -93,17 +92,17 @@ public class Owner extends SetCommand { | |||||||
|             if (event.getEventResult() == Result.DENY) { |             if (event.getEventResult() == Result.DENY) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("events.event_denied"), |                         TranslatableCaption.of("events.event_denied"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text("Owner change"))) |                         Template.of("value", "Owner change") | ||||||
|                 ); |                 ); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             uuid = event.getNewOwner(); |             uuid = event.getNewOwner(); | ||||||
|             boolean force = event.getEventResult() == Result.FORCE; |             boolean force = event.getEventResult() == Result.FORCE; | ||||||
|             if (uuid == null) { |             if (uuid == null) { | ||||||
|                 if (!force && !player.hasPermission( |                 if (!force && !Permissions | ||||||
|                         Permission.PERMISSION_ADMIN_COMMAND_SET_OWNER, |                         .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_SET_OWNER, | ||||||
|                         true |                                 true | ||||||
|                 )) { |                         )) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 PlotUnlinkEvent unlinkEvent = this.eventDispatcher.callUnlink( |                 PlotUnlinkEvent unlinkEvent = this.eventDispatcher.callUnlink( | ||||||
| @@ -116,7 +115,7 @@ public class Owner extends SetCommand { | |||||||
|                 if (unlinkEvent.getEventResult() == Result.DENY) { |                 if (unlinkEvent.getEventResult() == Result.DENY) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("events.event_denied"), |                             TranslatableCaption.of("events.event_denied"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text("Unlink on owner change"))) |                             Template.of("value", "Unlink on owner change") | ||||||
|                     ); |                     ); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
| @@ -136,21 +135,16 @@ public class Owner extends SetCommand { | |||||||
|             if (plot.isOwner(uuid)) { |             if (plot.isOwner(uuid)) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("member.already_owner"), |                         TranslatableCaption.of("member.already_owner"), | ||||||
|                         TagResolver.resolver( |                         Template.of("player", PlayerManager.resolveName(uuid, false).getComponent(player)) | ||||||
|                                 "player", |  | ||||||
|                                 Tag.inserting(PlayerManager.resolveName(uuid, false).toComponent(player)) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (!force && !player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_SET_OWNER)) { |             if (!force && !Permissions | ||||||
|  |                     .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_SET_OWNER)) { | ||||||
|                 if (other == null) { |                 if (other == null) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("errors.invalid_player_offline"), |                             TranslatableCaption.of("errors.invalid_player_offline"), | ||||||
|                             TagResolver.resolver( |                             Template.of("player", PlayerManager.resolveName(uuid).getComponent(player)) | ||||||
|                                     "player", |  | ||||||
|                                     Tag.inserting(PlayerManager.resolveName(uuid).toComponent(player)) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
| @@ -186,10 +180,7 @@ public class Owner extends SetCommand { | |||||||
|                         if (other != null) { |                         if (other != null) { | ||||||
|                             other.sendMessage( |                             other.sendMessage( | ||||||
|                                     TranslatableCaption.of("owner.now_owner"), |                                     TranslatableCaption.of("owner.now_owner"), | ||||||
|                                     TagResolver.resolver( |                                     Template.of("plot", plot.getArea() + ";" + plot.getId()) | ||||||
|                                             "plot", |  | ||||||
|                                             Tag.inserting(Component.text(plot.getArea() + ";" + plot.getId())) |  | ||||||
|                                     ) |  | ||||||
|                             ); |                             ); | ||||||
|                         } |                         } | ||||||
|                     } else { |                     } else { | ||||||
|   | |||||||
| @@ -23,9 +23,7 @@ import com.plotsquared.core.configuration.caption.StaticCaption; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.util.PremiumVerification; | import com.plotsquared.core.util.PremiumVerification; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
|  |  | ||||||
| @CommandDeclaration(command = "plugin", | @CommandDeclaration(command = "plugin", | ||||||
|         permission = "plots.use", |         permission = "plots.use", | ||||||
| @@ -41,7 +39,7 @@ public class PluginCmd extends SubCommand { | |||||||
|                     StaticCaption.of("<gray>>> </gray><gold><bold>" + PlotSquared |                     StaticCaption.of("<gray>>> </gray><gold><bold>" + PlotSquared | ||||||
|                             .platform() |                             .platform() | ||||||
|                             .pluginName() + " <reset><gray>(<gold>Version</gold><gray>: </gray><gold><version></gold><gray>)</gray>"), |                             .pluginName() + " <reset><gray>(<gold>Version</gold><gray>: </gray><gold><version></gold><gray>)</gray>"), | ||||||
|                     TagResolver.resolver("version", Tag.inserting(Component.text(String.valueOf(PlotSquared.get().getVersion())))) |                     Template.of("version", String.valueOf(PlotSquared.get().getVersion())) | ||||||
|             ); |             ); | ||||||
|             player.sendMessage(StaticCaption.of( |             player.sendMessage(StaticCaption.of( | ||||||
|                     "<gray>>> </gray><gold><bold>Authors<reset><gray>: </gray><gold>Citymonstret </gold><gray>& </gray><gold>Empire92 </gold><gray>& </gray><gold>MattBDev </gold><gray>& </gray><gold>dordsor21 </gold><gray>& </gray><gold>NotMyFault </gold><gray>& </gray><gold>SirYwell</gold>")); |                     "<gray>>> </gray><gold><bold>Authors<reset><gray>: </gray><gold>Citymonstret </gold><gray>& </gray><gold>Empire92 </gold><gray>& </gray><gold>MattBDev </gold><gray>& </gray><gold>dordsor21 </gold><gray>& </gray><gold>NotMyFault </gold><gray>& </gray><gold>SirYwell</gold>")); | ||||||
| @@ -51,7 +49,7 @@ public class PluginCmd extends SubCommand { | |||||||
|                     "<gray>>> </gray><gold><bold>Discord<reset><gray>: </gray><gold><click:open_url:https://discord.gg/intellectualsites>https://discord.gg/intellectualsites</gold>")); |                     "<gray>>> </gray><gold><bold>Discord<reset><gray>: </gray><gold><click:open_url:https://discord.gg/intellectualsites>https://discord.gg/intellectualsites</gold>")); | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     StaticCaption.of("<gray>>> </gray><gold><bold>Premium<reset><gray>: <gold><value></gold>"), |                     StaticCaption.of("<gray>>> </gray><gold><bold>Premium<reset><gray>: <gold><value></gold>"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text(PremiumVerification.isPremium()))) |                     Template.of("value", String.valueOf(PremiumVerification.isPremium())) | ||||||
|             ); |             ); | ||||||
|         }); |         }); | ||||||
|         return true; |         return true; | ||||||
|   | |||||||
| @@ -33,9 +33,7 @@ import com.plotsquared.core.util.StringMan; | |||||||
| import com.plotsquared.core.util.query.PlotQuery; | import com.plotsquared.core.util.query.PlotQuery; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import com.plotsquared.core.uuid.UUIDMapping; | import com.plotsquared.core.uuid.UUIDMapping; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.apache.logging.log4j.LogManager; | import org.apache.logging.log4j.LogManager; | ||||||
| import org.apache.logging.log4j.Logger; | import org.apache.logging.log4j.Logger; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| @@ -100,7 +98,7 @@ public class Purge extends SubCommand { | |||||||
|                     if (area == null) { |                     if (area == null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("errors.not_valid_plot_world"), |                                 TranslatableCaption.of("errors.not_valid_plot_world"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(split[1]))) |                                 Template.of("value", split[1]) | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -112,7 +110,7 @@ public class Purge extends SubCommand { | |||||||
|                     } catch (IllegalArgumentException ignored) { |                     } catch (IllegalArgumentException ignored) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("invalid.not_valid_plot_id"), |                                 TranslatableCaption.of("invalid.not_valid_plot_id"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(split[1]))) |                                 Template.of("value", split[1]) | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -123,7 +121,7 @@ public class Purge extends SubCommand { | |||||||
|                     if (ownerMapping == null) { |                     if (ownerMapping == null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("errors.invalid_player"), |                                 TranslatableCaption.of("errors.invalid_player"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(split[1]))) |                                 Template.of("value", split[1]) | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -135,7 +133,7 @@ public class Purge extends SubCommand { | |||||||
|                     if (addedMapping == null) { |                     if (addedMapping == null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("errors.invalid_player"), |                                 TranslatableCaption.of("errors.invalid_player"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(split[1]))) |                                 Template.of("value", split[1]) | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
| @@ -260,10 +258,7 @@ public class Purge extends SubCommand { | |||||||
|                             DBFunc.purgeIds(ids); |                             DBFunc.purgeIds(ids); | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("purge.purge_success"), |                                     TranslatableCaption.of("purge.purge_success"), | ||||||
|                                     TagResolver.resolver( |                                     Template.of("amount", ids.size() + "/" + toDelete.size()) | ||||||
|                                             "amount", |  | ||||||
|                                             Tag.inserting(Component.text(ids.size() + "/" + toDelete.size())) |  | ||||||
|                                     ) |  | ||||||
|                             ); |                             ); | ||||||
|                         }); |                         }); | ||||||
|                     } |                     } | ||||||
|   | |||||||
| @@ -34,12 +34,11 @@ import com.plotsquared.core.plot.flag.implementations.DoneFlag; | |||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.InventoryUtil; | import com.plotsquared.core.util.InventoryUtil; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.query.PlotQuery; | import com.plotsquared.core.util.query.PlotQuery; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| @@ -115,7 +114,8 @@ public class Rate extends SubCommand { | |||||||
|                         player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |                         player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                     if (!player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_PURGE_RATINGS, true)) { |                     if (!Permissions | ||||||
|  |                             .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_PURGE_RATINGS, true)) { | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                     plot.clearRatings(); |                     plot.clearRatings(); | ||||||
| @@ -148,7 +148,7 @@ public class Rate extends SubCommand { | |||||||
|                     if (plot.getRatings().containsKey(player.getUUID())) { |                     if (plot.getRatings().containsKey(player.getUUID())) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("ratings.rating_already_exists"), |                                 TranslatableCaption.of("ratings.rating_already_exists"), | ||||||
|                                 TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                                 Template.of("plot", plot.getId().toString()) | ||||||
|                         ); |                         ); | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
| @@ -168,7 +168,7 @@ public class Rate extends SubCommand { | |||||||
|                                     plot.addRating(this.getPlayer().getUUID(), event.getRating()); |                                     plot.addRating(this.getPlayer().getUUID(), event.getRating()); | ||||||
|                                     getPlayer().sendMessage( |                                     getPlayer().sendMessage( | ||||||
|                                             TranslatableCaption.of("ratings.rating_applied"), |                                             TranslatableCaption.of("ratings.rating_applied"), | ||||||
|                                             TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                                             Template.of("plot", plot.getId().toString()) | ||||||
|                                     ); |                                     ); | ||||||
|                                 } |                                 } | ||||||
|                                 return false; |                                 return false; | ||||||
| @@ -241,7 +241,7 @@ public class Rate extends SubCommand { | |||||||
|             if (plot.getRatings().containsKey(uuid)) { |             if (plot.getRatings().containsKey(uuid)) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("ratings.rating_already_exists"), |                         TranslatableCaption.of("ratings.rating_already_exists"), | ||||||
|                         TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                         Template.of("plot", plot.getId().toString()) | ||||||
|                 ); |                 ); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| @@ -251,7 +251,7 @@ public class Rate extends SubCommand { | |||||||
|                 plot.addRating(uuid, event.getRating()); |                 plot.addRating(uuid, event.getRating()); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("ratings.rating_applied"), |                         TranslatableCaption.of("ratings.rating_applied"), | ||||||
|                         TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                         Template.of("plot", plot.getId().toString()) | ||||||
|                 ); |                 ); | ||||||
|             } |             } | ||||||
|         }; |         }; | ||||||
| @@ -273,10 +273,10 @@ public class Rate extends SubCommand { | |||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         if (args.length == 1) { |         if (args.length == 1) { | ||||||
|             final List<String> completions = new LinkedList<>(); |             final List<String> completions = new LinkedList<>(); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_RATE)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_RATE)) { | ||||||
|                 completions.add("1 - 10"); |                 completions.add("1 - 10"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_PURGE_RATINGS)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_PURGE_RATINGS)) { | ||||||
|                 completions.add("purge"); |                 completions.add("purge"); | ||||||
|             } |             } | ||||||
|             final List<Command> commands = completions.stream().filter(completion -> completion |             final List<Command> commands = completions.stream().filter(completion -> completion | ||||||
| @@ -284,7 +284,7 @@ public class Rate extends SubCommand { | |||||||
|                             .startsWith(args[0].toLowerCase())) |                             .startsWith(args[0].toLowerCase())) | ||||||
|                     .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.INFO) { |                     .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.INFO) { | ||||||
|                     }).collect(Collectors.toCollection(LinkedList::new)); |                     }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_RATE) && args[0].length() > 0) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_RATE) && args[0].length() > 0) { | ||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             return commands; | ||||||
|   | |||||||
| @@ -26,9 +26,7 @@ import com.plotsquared.core.player.PlotPlayer; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.PlotManager; | import com.plotsquared.core.plot.PlotManager; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| @CommandDeclaration(command = "regenallroads", | @CommandDeclaration(command = "regenallroads", | ||||||
| @@ -60,18 +58,18 @@ public class RegenAllRoads extends SubCommand { | |||||||
|             } catch (NumberFormatException ignored) { |             } catch (NumberFormatException ignored) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("invalid.not_valid_number"), |                         TranslatableCaption.of("invalid.not_valid_number"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text("(0, 256)"))) |                         Template.of("value", "(0, 256)") | ||||||
|                 ); |                 ); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("commandconfig.command_syntax"), |                         TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text("/plot regenallroads <world> [height]"))) |                         Template.of("value", "/plot regenallroads <world> [height]") | ||||||
|                 ); |                 ); | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|         } else if (args.length != 1) { |         } else if (args.length != 1) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("/plot regenallroads <world> [height]"))) |                     Template.of("value", "/plot regenallroads <world> [height]") | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -79,7 +77,7 @@ public class RegenAllRoads extends SubCommand { | |||||||
|         if (area == null) { |         if (area == null) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("errors.not_valid_plot_world"), |                     TranslatableCaption.of("errors.not_valid_plot_world"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) |                     Template.of("value", args[0]) | ||||||
|             ); |             ); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -90,7 +88,7 @@ public class RegenAllRoads extends SubCommand { | |||||||
|         } |         } | ||||||
|         player.sendMessage( |         player.sendMessage( | ||||||
|                 TranslatableCaption.of("debugroadregen.schematic"), |                 TranslatableCaption.of("debugroadregen.schematic"), | ||||||
|                 TagResolver.resolver("command", Tag.inserting(Component.text("/plot createroadschematic"))) |                 Template.of("command", "/plot createroadschematic") | ||||||
|         ); |         ); | ||||||
|         player.sendMessage(TranslatableCaption.of("debugroadregen.regenallroads_started")); |         player.sendMessage(TranslatableCaption.of("debugroadregen.regenallroads_started")); | ||||||
|         boolean result = this.hybridUtils.scheduleRoadUpdate(area, height); |         boolean result = this.hybridUtils.scheduleRoadUpdate(area, height); | ||||||
|   | |||||||
| @@ -26,11 +26,10 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.PlayerManager; | import com.plotsquared.core.util.PlayerManager; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| @@ -66,7 +65,8 @@ public class Remove extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("info.plot_unowned")); |             player.sendMessage(TranslatableCaption.of("info.plot_unowned")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_REMOVE)) { |         if (!plot.isOwner(player.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_REMOVE)) { | ||||||
|             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
| @@ -79,7 +79,7 @@ public class Remove extends SubCommand { | |||||||
|             } else if (throwable != null) { |             } else if (throwable != null) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("errors.invalid_player"), |                         TranslatableCaption.of("errors.invalid_player"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) |                         Template.of("value", args[0]) | ||||||
|                 ); |                 ); | ||||||
|                 return; |                 return; | ||||||
|             } else if (!uuids.isEmpty()) { |             } else if (!uuids.isEmpty()) { | ||||||
| @@ -115,13 +115,13 @@ public class Remove extends SubCommand { | |||||||
|             } |             } | ||||||
|             if (count == 0) { |             if (count == 0) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("errors.invalid_player"), |                         TranslatableCaption.of("member.player_not_removed"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) |                         Template.of("player", args[0]) | ||||||
|                 ); |                 ); | ||||||
|             } else { |             } else { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("member.removed_players"), |                         TranslatableCaption.of("member.removed_players"), | ||||||
|                         TagResolver.resolver("amount", Tag.inserting(Component.text(count))) |                         Template.of("amount", count + "") | ||||||
|                 ); |                 ); | ||||||
|             } |             } | ||||||
|         }); |         }); | ||||||
|   | |||||||
							
								
								
									
										132
									
								
								Core/src/main/java/com/plotsquared/core/command/Save.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										132
									
								
								Core/src/main/java/com/plotsquared/core/command/Save.java
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,132 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU General Public License as published by | ||||||
|  |  * the Free Software Foundation, either version 3 of the License, or | ||||||
|  |  * (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU General Public License | ||||||
|  |  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.core.command; | ||||||
|  |  | ||||||
|  | import com.google.inject.Inject; | ||||||
|  | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
|  | import com.plotsquared.core.permissions.Permission; | ||||||
|  | import com.plotsquared.core.player.MetaDataAccess; | ||||||
|  | import com.plotsquared.core.player.PlayerMetaDataKeys; | ||||||
|  | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.Plot; | ||||||
|  | import com.plotsquared.core.plot.PlotId; | ||||||
|  | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
|  | import com.plotsquared.core.util.SchematicHandler; | ||||||
|  | import com.plotsquared.core.util.task.RunnableVal; | ||||||
|  | import com.plotsquared.core.util.task.TaskManager; | ||||||
|  | import net.kyori.adventure.text.minimessage.Template; | ||||||
|  | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
|  | import java.net.URL; | ||||||
|  | import java.util.List; | ||||||
|  | import java.util.UUID; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @deprecated In favor of "/plot download" (Arkitektonika) and scheduled | ||||||
|  |  *         for removal within the next major release. | ||||||
|  |  */ | ||||||
|  | @Deprecated(forRemoval = true, since = "6.0.9") | ||||||
|  | @CommandDeclaration(command = "save", | ||||||
|  |         category = CommandCategory.SCHEMATIC, | ||||||
|  |         requiredType = RequiredType.NONE, | ||||||
|  |         permission = "plots.save") | ||||||
|  | public class Save extends SubCommand { | ||||||
|  |  | ||||||
|  |     private final PlotAreaManager plotAreaManager; | ||||||
|  |     private final SchematicHandler schematicHandler; | ||||||
|  |  | ||||||
|  |     @Inject | ||||||
|  |     public Save( | ||||||
|  |             final @NonNull PlotAreaManager plotAreaManager, | ||||||
|  |             final @NonNull SchematicHandler schematicHandler | ||||||
|  |     ) { | ||||||
|  |         this.plotAreaManager = plotAreaManager; | ||||||
|  |         this.schematicHandler = schematicHandler; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public boolean onCommand(final PlotPlayer<?> player, final String[] args) { | ||||||
|  |         final String world = player.getLocation().getWorldName(); | ||||||
|  |         if (!this.plotAreaManager.hasPlotArea(world)) { | ||||||
|  |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |         final Plot plot = player.getCurrentPlot(); | ||||||
|  |         if (plot == null) { | ||||||
|  |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |         if (!plot.hasOwner()) { | ||||||
|  |             player.sendMessage(TranslatableCaption.of("info.plot_unowned")); | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |         if (plot.getVolume() > Integer.MAX_VALUE) { | ||||||
|  |             player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |         if (!plot.isOwner(player.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_SAVE)) { | ||||||
|  |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |         if (plot.getRunning() > 0) { | ||||||
|  |             player.sendMessage(TranslatableCaption.of("errors.wait_for_timer")); | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |         plot.addRunning(); | ||||||
|  |         this.schematicHandler.getCompoundTag(plot) | ||||||
|  |                 .whenComplete((compoundTag, throwable) -> { | ||||||
|  |                     TaskManager.runTaskAsync(() -> { | ||||||
|  |                         String time = (System.currentTimeMillis() / 1000) + ""; | ||||||
|  |                         Location[] corners = plot.getCorners(); | ||||||
|  |                         corners[0] = corners[0].withY(plot.getArea().getMinBuildHeight()); | ||||||
|  |                         corners[1] = corners[1].withY(plot.getArea().getMaxBuildHeight()); | ||||||
|  |                         int size = (corners[1].getX() - corners[0].getX()) + 1; | ||||||
|  |                         PlotId id = plot.getId(); | ||||||
|  |                         String world1 = plot.getArea().toString().replaceAll(";", "-") | ||||||
|  |                                 .replaceAll("[^A-Za-z0-9]", ""); | ||||||
|  |                         final String file = time + '_' + world1 + '_' + id.getX() + '_' + id.getY() + '_' + size; | ||||||
|  |                         UUID uuid = player.getUUID(); | ||||||
|  |                         schematicHandler.upload(compoundTag, uuid, file, new RunnableVal<>() { | ||||||
|  |                             @Override | ||||||
|  |                             public void run(URL url) { | ||||||
|  |                                 plot.removeRunning(); | ||||||
|  |                                 if (url == null) { | ||||||
|  |                                     player.sendMessage(TranslatableCaption.of("backups.backup_save_failed")); | ||||||
|  |                                     return; | ||||||
|  |                                 } | ||||||
|  |                                 player.sendMessage(TranslatableCaption.of("web.save_success")); | ||||||
|  |                                 player.sendMessage( | ||||||
|  |                                         TranslatableCaption.of("errors.deprecated_commands"), | ||||||
|  |                                         Template.of("replacement", "/plot download") | ||||||
|  |                                 ); | ||||||
|  |                                 try (final MetaDataAccess<List<String>> schematicAccess = | ||||||
|  |                                              player.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_SCHEMATICS)) { | ||||||
|  |                                     schematicAccess.get().ifPresent(schematics -> schematics.add(file + ".schem")); | ||||||
|  |                                 } | ||||||
|  |                             } | ||||||
|  |                         }); | ||||||
|  |                     }); | ||||||
|  |                 }); | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -30,14 +30,13 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.schematic.Schematic; | import com.plotsquared.core.plot.schematic.Schematic; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.SchematicHandler; | import com.plotsquared.core.util.SchematicHandler; | ||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.net.URL; | import java.net.URL; | ||||||
| @@ -74,30 +73,24 @@ public class SchematicCmd extends SubCommand { | |||||||
|         if (args.length < 1) { |         if (args.length < 1) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("Possible values: save, paste, exportall, list"))) |                     Template.of("value", "Possible values: save, paste, exportall, list") | ||||||
|             ); |             ); | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
|         String arg = args[0].toLowerCase(); |         String arg = args[0].toLowerCase(); | ||||||
|         switch (arg) { |         switch (arg) { | ||||||
|             case "paste" -> { |             case "paste" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_SCHEMATIC_PASTE)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_SCHEMATIC_PASTE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_SCHEMATIC_PASTE)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_SCHEMATIC_PASTE) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (args.length < 2) { |                 if (args.length < 2) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver( |                             Template.of("value", "Possible values: save, paste, exportall, list") | ||||||
|                                     "value", |  | ||||||
|                                     Tag.inserting(Component.text("Possible values: save, paste, exportall, list")) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
| @@ -111,7 +104,8 @@ public class SchematicCmd extends SubCommand { | |||||||
|                     player.sendMessage(TranslatableCaption.of("info.plot_unowned")); |                     player.sendMessage(TranslatableCaption.of("info.plot_unowned")); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (!plot.isOwner(player.getUUID()) && !player.hasPermission("plots.admin.command.schematic.paste")) { |                 if (!plot.isOwner(player.getUUID()) && !Permissions | ||||||
|  |                         .hasPermission(player, "plots.admin.command.schematic.paste")) { | ||||||
|                     player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |                     player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -137,10 +131,7 @@ public class SchematicCmd extends SubCommand { | |||||||
|                             e.printStackTrace(); |                             e.printStackTrace(); | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("schematics.schematic_invalid"), |                                     TranslatableCaption.of("schematics.schematic_invalid"), | ||||||
|                                     TagResolver.resolver( |                                     Template.of("reason", "non-existent url: " + location) | ||||||
|                                             "reason", |  | ||||||
|                                             Tag.inserting(Component.text("non-existent url: " + location)) |  | ||||||
|                                     ) |  | ||||||
|                             ); |                             ); | ||||||
|                             SchematicCmd.this.running = false; |                             SchematicCmd.this.running = false; | ||||||
|                             return; |                             return; | ||||||
| @@ -156,10 +147,7 @@ public class SchematicCmd extends SubCommand { | |||||||
|                         SchematicCmd.this.running = false; |                         SchematicCmd.this.running = false; | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("schematics.schematic_invalid"), |                                 TranslatableCaption.of("schematics.schematic_invalid"), | ||||||
|                                 TagResolver.resolver( |                                 Template.of("reason", "non-existent or not in gzip format") | ||||||
|                                         "reason", |  | ||||||
|                                         Tag.inserting(Component.text("non-existent or not in gzip format")) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
| @@ -194,10 +182,7 @@ public class SchematicCmd extends SubCommand { | |||||||
|                     player.sendMessage(TranslatableCaption.of("schematics.schematic_exportall_world_args")); |                     player.sendMessage(TranslatableCaption.of("schematics.schematic_exportall_world_args")); | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver( |                             Template.of("value", "Use /plot schematic exportall <area>") | ||||||
|                                     "value", |  | ||||||
|                                     Tag.inserting(Component.text("Use /plot schematic exportall <area>")) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -205,7 +190,7 @@ public class SchematicCmd extends SubCommand { | |||||||
|                 if (area == null) { |                 if (area == null) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("errors.not_valid_plot_world"), |                             TranslatableCaption.of("errors.not_valid_plot_world"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text(args[1]))) |                             Template.of("value", args[1]) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -214,7 +199,7 @@ public class SchematicCmd extends SubCommand { | |||||||
|                     player.sendMessage(TranslatableCaption.of("schematic.schematic_exportall_world")); |                     player.sendMessage(TranslatableCaption.of("schematic.schematic_exportall_world")); | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver("value", Tag.inserting(Component.text("Use /plot sch exportall <area>"))) |                             Template.of("value", "Use /plot sch exportall <area>") | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -228,18 +213,15 @@ public class SchematicCmd extends SubCommand { | |||||||
|                     player.sendMessage(TranslatableCaption.of("schematics.schematic_exportall_started")); |                     player.sendMessage(TranslatableCaption.of("schematics.schematic_exportall_started")); | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("schematics.plot_to_schem"), |                             TranslatableCaption.of("schematics.plot_to_schem"), | ||||||
|                             TagResolver.resolver("amount", Tag.inserting(Component.text(plots.size()))) |                             Template.of("amount", String.valueOf(plots.size())) | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             case "export", "save" -> { |             case "export", "save" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_SCHEMATIC_SAVE)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_SCHEMATIC_SAVE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_SCHEMATIC_SAVE)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_SCHEMATIC_SAVE) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -261,7 +243,8 @@ public class SchematicCmd extends SubCommand { | |||||||
|                     player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); |                     player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (!plot.isOwner(player.getUUID()) && !player.hasPermission("plots.admin.command.schematic.save")) { |                 if (!plot.isOwner(player.getUUID()) && !Permissions | ||||||
|  |                         .hasPermission(player, "plots.admin.command.schematic.save")) { | ||||||
|                     player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |                     player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -278,25 +261,22 @@ public class SchematicCmd extends SubCommand { | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             case "list" -> { |             case "list" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_SCHEMATIC_LIST)) { |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_SCHEMATIC_LIST)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             Template.of("node", String.valueOf(Permission.PERMISSION_SCHEMATIC_LIST)) | ||||||
|                                     "node", |  | ||||||
|                                     Tag.inserting(Permission.PERMISSION_SCHEMATIC_LIST) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 final String string = StringMan.join(this.schematicHandler.getSchematicNames(), "$2, $1"); |                 final String string = StringMan.join(this.schematicHandler.getSchematicNames(), "$2, $1"); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("schematics.schematic_list"), |                         TranslatableCaption.of("schematics.schematic_list"), | ||||||
|                         TagResolver.resolver("list", Tag.inserting(Component.text(string))) |                         Template.of("list", string) | ||||||
|                 ); |                 ); | ||||||
|             } |             } | ||||||
|             default -> player.sendMessage( |             default -> player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text("Possible values: save, paste, exportall, list"))) |                     Template.of("value", "Possible values: save, paste, exportall, list") | ||||||
|             ); |             ); | ||||||
|         } |         } | ||||||
|         return true; |         return true; | ||||||
| @@ -306,13 +286,13 @@ public class SchematicCmd extends SubCommand { | |||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         if (args.length == 1) { |         if (args.length == 1) { | ||||||
|             final List<String> completions = new LinkedList<>(); |             final List<String> completions = new LinkedList<>(); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_SCHEMATIC_SAVE)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_SCHEMATIC_SAVE)) { | ||||||
|                 completions.add("save"); |                 completions.add("save"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_SCHEMATIC_LIST)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_SCHEMATIC_LIST)) { | ||||||
|                 completions.add("list"); |                 completions.add("list"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_SCHEMATIC_PASTE)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_SCHEMATIC_PASTE)) { | ||||||
|                 completions.add("paste"); |                 completions.add("paste"); | ||||||
|             } |             } | ||||||
|             final List<Command> commands = completions.stream().filter(completion -> completion |             final List<Command> commands = completions.stream().filter(completion -> completion | ||||||
| @@ -327,7 +307,7 @@ public class SchematicCmd extends SubCommand { | |||||||
|                             CommandCategory.ADMINISTRATION |                             CommandCategory.ADMINISTRATION | ||||||
|                     ) { |                     ) { | ||||||
|                     }).collect(Collectors.toCollection(LinkedList::new)); |                     }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|             if (player.hasPermission(Permission.PERMISSION_SCHEMATIC) && args[0].length() > 0) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_SCHEMATIC) && args[0].length() > 0) { | ||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             return commands; | ||||||
|   | |||||||
| @@ -32,6 +32,7 @@ import com.plotsquared.core.plot.PlotArea; | |||||||
| import com.plotsquared.core.plot.PlotManager; | import com.plotsquared.core.plot.PlotManager; | ||||||
| import com.plotsquared.core.queue.QueueCoordinator; | import com.plotsquared.core.queue.QueueCoordinator; | ||||||
| import com.plotsquared.core.util.PatternUtil; | import com.plotsquared.core.util.PatternUtil; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.WorldUtil; | import com.plotsquared.core.util.WorldUtil; | ||||||
| @@ -39,9 +40,7 @@ import com.sk89q.worldedit.function.pattern.Pattern; | |||||||
| import com.sk89q.worldedit.world.block.BlockCategory; | import com.sk89q.worldedit.world.block.BlockCategory; | ||||||
| import com.sk89q.worldedit.world.block.BlockType; | import com.sk89q.worldedit.world.block.BlockType; | ||||||
| import com.sk89q.worldedit.world.block.BlockTypes; | import com.sk89q.worldedit.world.block.BlockTypes; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| @@ -97,7 +96,7 @@ public class Set extends SubCommand { | |||||||
|                             BlockType::getName).toList()); |                             BlockType::getName).toList()); | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_ADMIN_ALLOW_UNSAFE) && |                 if (!Permissions.hasPermission(player, Permission.PERMISSION_ADMIN_ALLOW_UNSAFE) && | ||||||
|                         !forbiddenTypes.isEmpty()) { |                         !forbiddenTypes.isEmpty()) { | ||||||
|                     for (String forbiddenType : forbiddenTypes) { |                     for (String forbiddenType : forbiddenTypes) { | ||||||
|                         forbiddenType = forbiddenType.toLowerCase(Locale.ENGLISH); |                         forbiddenType = forbiddenType.toLowerCase(Locale.ENGLISH); | ||||||
| @@ -124,7 +123,7 @@ public class Set extends SubCommand { | |||||||
|                             } |                             } | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("invalid.component_illegal_block"), |                                     TranslatableCaption.of("invalid.component_illegal_block"), | ||||||
|                                     TagResolver.resolver("value", Tag.inserting(Component.text(forbiddenType))) |                                     Template.of("value", forbiddenType) | ||||||
|                             ); |                             ); | ||||||
|                             return true; |                             return true; | ||||||
|                         } |                         } | ||||||
| @@ -133,13 +132,10 @@ public class Set extends SubCommand { | |||||||
|  |  | ||||||
|                 for (String component : components) { |                 for (String component : components) { | ||||||
|                     if (component.equalsIgnoreCase(args[0])) { |                     if (component.equalsIgnoreCase(args[0])) { | ||||||
|                         if (!player.hasPermission(Permission.PERMISSION_SET_COMPONENT.format(component))) { |                         if (!Permissions.hasPermission(player, Permission.PERMISSION_SET_COMPONENT.format(component))) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("permission.no_permission"), |                                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                                     TagResolver.resolver( |                                     Template.of("node", Permission.PERMISSION_SET_COMPONENT.format(component)) | ||||||
|                                             "node", |  | ||||||
|                                             Tag.inserting(Component.text(Permission.PERMISSION_SET_COMPONENT.format(component))) |  | ||||||
|                                     ) |  | ||||||
|                             ); |                             ); | ||||||
|                             return false; |                             return false; | ||||||
|                         } |                         } | ||||||
| @@ -162,7 +158,7 @@ public class Set extends SubCommand { | |||||||
|                                 plot.removeRunning(); |                                 plot.removeRunning(); | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("working.component_complete"), |                                         TranslatableCaption.of("working.component_complete"), | ||||||
|                                         TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                                         Template.of("plot", plot.getId().toString()) | ||||||
|                                 ); |                                 ); | ||||||
|                             }); |                             }); | ||||||
|                             if (Settings.QUEUE.NOTIFY_PROGRESS) { |                             if (Settings.QUEUE.NOTIFY_PROGRESS) { | ||||||
| @@ -215,7 +211,7 @@ public class Set extends SubCommand { | |||||||
|         } |         } | ||||||
|         Command cmd = MainCommand.getInstance().getCommand("set" + args[0]); |         Command cmd = MainCommand.getInstance().getCommand("set" + args[0]); | ||||||
|         if (cmd != null) { |         if (cmd != null) { | ||||||
|             if (!player.hasPermission(cmd.getPermission(), true)) { |             if (!Permissions.hasPermission(player, cmd.getPermission(), true)) { | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|             cmd.execute(player, Arrays.copyOfRange(args, 1, args.length), null, null); |             cmd.execute(player, Arrays.copyOfRange(args, 1, args.length), null, null); | ||||||
| @@ -245,37 +241,37 @@ public class Set extends SubCommand { | |||||||
|         if (args.length == 1) { |         if (args.length == 1) { | ||||||
|             final List<String> completions = new LinkedList<>(); |             final List<String> completions = new LinkedList<>(); | ||||||
|  |  | ||||||
|             if (player.hasPermission(Permission.PERMISSION_SET_BIOME)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_SET_BIOME)) { | ||||||
|                 completions.add("biome"); |                 completions.add("biome"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_SET_ALIAS)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_SET_ALIAS)) { | ||||||
|                 completions.add("alias"); |                 completions.add("alias"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_SET_HOME)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_SET_HOME)) { | ||||||
|                 completions.add("home"); |                 completions.add("home"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_SET_MAIN)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_SET_MAIN)) { | ||||||
|                 completions.add("main"); |                 completions.add("main"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_SET_FLOOR)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_SET_FLOOR)) { | ||||||
|                 completions.add("floor"); |                 completions.add("floor"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_SET_AIR)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_SET_AIR)) { | ||||||
|                 completions.add("air"); |                 completions.add("air"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_SET_ALL)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_SET_ALL)) { | ||||||
|                 completions.add("all"); |                 completions.add("all"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_SET_BORDER)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_SET_BORDER)) { | ||||||
|                 completions.add("border"); |                 completions.add("border"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_SET_WALL)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_SET_WALL)) { | ||||||
|                 completions.add("wall"); |                 completions.add("wall"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_SET_OUTLINE)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_SET_OUTLINE)) { | ||||||
|                 completions.add("outline"); |                 completions.add("outline"); | ||||||
|             } |             } | ||||||
|             if (player.hasPermission(Permission.PERMISSION_SET_MIDDLE)) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_SET_MIDDLE)) { | ||||||
|                 completions.add("middle"); |                 completions.add("middle"); | ||||||
|             } |             } | ||||||
|             final List<Command> commands = completions.stream().filter(completion -> completion |             final List<Command> commands = completions.stream().filter(completion -> completion | ||||||
| @@ -284,7 +280,7 @@ public class Set extends SubCommand { | |||||||
|                     .map(completion -> new Command(null, true, completion, "", RequiredType.NONE, CommandCategory.APPEARANCE) { |                     .map(completion -> new Command(null, true, completion, "", RequiredType.NONE, CommandCategory.APPEARANCE) { | ||||||
|                     }).collect(Collectors.toCollection(LinkedList::new)); |                     }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|  |  | ||||||
|             if (player.hasPermission(Permission.PERMISSION_SET) && args[0].length() > 0) { |             if (Permissions.hasPermission(player, Permission.PERMISSION_SET) && args[0].length() > 0) { | ||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             return commands; | ||||||
| @@ -300,7 +296,7 @@ public class Set extends SubCommand { | |||||||
|  |  | ||||||
|             final Command cmd = MainCommand.getInstance().getCommand("set" + args[0]); |             final Command cmd = MainCommand.getInstance().getCommand("set" + args[0]); | ||||||
|             if (cmd != null) { |             if (cmd != null) { | ||||||
|                 if (!player.hasPermission(cmd.getPermission(), true)) { |                 if (!Permissions.hasPermission(player, cmd.getPermission(), true)) { | ||||||
|                     return new ArrayList<>(); |                     return new ArrayList<>(); | ||||||
|                 } |                 } | ||||||
|                 return cmd.tab(player, newArgs, space); |                 return cmd.tab(player, newArgs, space); | ||||||
|   | |||||||
| @@ -23,10 +23,9 @@ import com.plotsquared.core.location.Location; | |||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
|  |  | ||||||
| public abstract class SetCommand extends SubCommand { | public abstract class SetCommand extends SubCommand { | ||||||
|  |  | ||||||
| @@ -39,26 +38,20 @@ public abstract class SetCommand extends SubCommand { | |||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!plot.hasOwner()) { |         if (!plot.hasOwner()) { | ||||||
|             if (!player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND.format(getFullId()))) { |             if (!Permissions.hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND.format(getFullId()))) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission"), |                         TranslatableCaption.of("permission.no_permission"), | ||||||
|                         TagResolver.resolver( |                         Template.of("node", Permission.PERMISSION_ADMIN_COMMAND.format(getFullId())) | ||||||
|                                 "node", |  | ||||||
|                                 Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_COMMAND.format(getFullId()))) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 player.sendMessage(TranslatableCaption.of("working.plot_not_claimed")); |                 player.sendMessage(TranslatableCaption.of("working.plot_not_claimed")); | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         if (!plot.isOwner(player.getUUID())) { |         if (!plot.isOwner(player.getUUID())) { | ||||||
|             if (!player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND.format(getFullId()))) { |             if (!Permissions.hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND.format(getFullId()))) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission"), |                         TranslatableCaption.of("permission.no_permission"), | ||||||
|                         TagResolver.resolver( |                         Template.of("node", Permission.PERMISSION_ADMIN_COMMAND.format(getFullId())) | ||||||
|                                 "node", |  | ||||||
|                                 Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_COMMAND.format(getFullId()))) |  | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |                 player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|                 return false; |                 return false; | ||||||
|   | |||||||
| @@ -23,9 +23,7 @@ import com.plotsquared.core.location.BlockLoc; | |||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
|  |  | ||||||
| @CommandDeclaration(command = "sethome", | @CommandDeclaration(command = "sethome", | ||||||
|         permission = "plots.set.home", |         permission = "plots.set.home", | ||||||
| @@ -66,7 +64,7 @@ public class SetHome extends SetCommand { | |||||||
|             default -> { |             default -> { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("commandconfig.command_syntax"), |                         TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text("Use /plot set home [none]"))) |                         Template.of("value", "Use /plot set home [none]") | ||||||
|                 ); |                 ); | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -29,9 +29,7 @@ import com.plotsquared.core.player.PlotPlayer; | |||||||
| import com.plotsquared.core.setup.SetupProcess; | import com.plotsquared.core.setup.SetupProcess; | ||||||
| import com.plotsquared.core.setup.SetupStep; | import com.plotsquared.core.setup.SetupStep; | ||||||
| import com.plotsquared.core.util.SetupUtils; | import com.plotsquared.core.util.SetupUtils; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| @@ -80,10 +78,7 @@ public class Setup extends SubCommand { | |||||||
|                     player.sendMessage(TranslatableCaption.of("setup.setup_not_started")); |                     player.sendMessage(TranslatableCaption.of("setup.setup_not_started")); | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("commandconfig.command_syntax"), |                             TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                             TagResolver.resolver( |                             Template.of("value", "Use /plot setup to start a setup process.") | ||||||
|                                     "value", |  | ||||||
|                                     Tag.inserting(Component.text("Use /plot setup to start a setup process.")) |  | ||||||
|                             ) |  | ||||||
|                     ); |                     ); | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|   | |||||||
| @@ -23,11 +23,10 @@ import com.plotsquared.core.location.Location; | |||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
|  | import com.plotsquared.core.util.Permissions; | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
|  |  | ||||||
| import java.util.concurrent.CompletableFuture; | import java.util.concurrent.CompletableFuture; | ||||||
|  |  | ||||||
| @@ -50,7 +49,8 @@ public class Swap extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return CompletableFuture.completedFuture(false); |             return CompletableFuture.completedFuture(false); | ||||||
|         } |         } | ||||||
|         if (!plot1.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN)) { |         if (!plot1.isOwner(player.getUUID()) && !Permissions | ||||||
|  |                 .hasPermission(player, Permission.PERMISSION_ADMIN)) { | ||||||
|             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|             return CompletableFuture.completedFuture(false); |             return CompletableFuture.completedFuture(false); | ||||||
|         } |         } | ||||||
| @@ -84,10 +84,8 @@ public class Swap extends SubCommand { | |||||||
|             if (result) { |             if (result) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("swap.swap_success"), |                         TranslatableCaption.of("swap.swap_success"), | ||||||
|                         TagResolver.builder() |                         Template.of("origin", p1), | ||||||
|                                 .tag("origin", Tag.inserting(Component.text(p1))) |                         Template.of("target", p2) | ||||||
|                                 .tag("target", Tag.inserting(Component.text(p2))) |  | ||||||
|                                 .build() |  | ||||||
|                 ); |                 ); | ||||||
|                 return true; |                 return true; | ||||||
|             } else { |             } else { | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user